| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264 |
- using System.Collections.Generic;
- using System.Threading.Tasks;
- using Abp;
- using Abp.Configuration;
- using Abp.Extensions;
- using Abp.Threading;
- namespace IwbZero.Setting
- {
- /// <summary>
- /// Extension methods for <see cref="IIwbSettingManager"/>.
- /// </summary>
- public static class IwbSettingManagerExtensions
- {
- /// <summary>
- /// Gets value of a setting in given type (<see cref="T"/>).
- /// </summary>
- /// <typeparam name="T">Type of the setting to get</typeparam>
- /// <param name="settingManager">Setting manager</param>
- /// <param name="name">Unique name of the setting</param>
- /// <returns>Value of the setting</returns>
- public static async Task<T> GetSettingValueAsync<T>(this IIwbSettingManager settingManager, string name)
- where T : struct
- {
- return (await settingManager.GetSettingValueAsync(name)).To<T>();
- }
- /// <summary>
- /// Gets current value of a setting for the application level.
- /// </summary>
- /// <param name="settingManager">Setting manager</param>
- /// <param name="name">Unique name of the setting</param>
- /// <returns>Current value of the setting for the application</returns>
- public static async Task<T> GetSettingValueForApplicationAsync<T>(this IIwbSettingManager settingManager, string name)
- where T : struct
- {
- return (await settingManager.GetSettingValueForApplicationAsync(name)).To<T>();
- }
- /// <summary>
- /// Gets current value of a setting for a user level.
- /// It gets the setting value, overwritten by given tenant and user.
- /// </summary>
- /// <param name="settingManager">Setting manager</param>
- /// <param name="name">Unique name of the setting</param>
- /// <param name="userId">User id</param>
- /// <returns>Current value of the setting for the user</returns>
- public static async Task<T> GetSettingValueForUserAsync<T>(this IIwbSettingManager settingManager, string name, long userId)
- where T : struct
- {
- return (await settingManager.GetSettingValueForUserAsync(name, userId)).To<T>();
- }
- /// <summary>
- /// Gets current value of a setting for a user level.
- /// It gets the setting value, overwritten by given tenant and user.
- /// </summary>
- /// <param name="settingManager">Setting manager</param>
- /// <param name="name">Unique name of the setting</param>
- /// <param name="user">User</param>
- /// <returns>Current value of the setting for the user</returns>
- public static async Task<T> GetSettingValueForUserAsync<T>(this IIwbSettingManager settingManager, string name, UserIdentifier user)
- where T : struct
- {
- return (await settingManager.GetSettingValueForUserAsync(name, user)).To<T>();
- }
- /// <summary>
- /// Gets current value of a setting.
- /// It gets the setting value, overwritten by application and the current user if exists.
- /// </summary>
- /// <param name="settingManager">Setting manager</param>
- /// <param name="name">Unique name of the setting</param>
- /// <returns>Current value of the setting</returns>
- public static string GetSettingValue(this IIwbSettingManager settingManager, string name)
- {
- return AsyncHelper.RunSync(() => settingManager.GetSettingValueAsync(name));
- }
- /// <summary>
- /// Gets current value of a setting for the application level.
- /// </summary>
- /// <param name="settingManager">Setting manager</param>
- /// <param name="name">Unique name of the setting</param>
- /// <returns>Current value of the setting for the application</returns>
- public static string GetSettingValueForApplication(this IIwbSettingManager settingManager, string name)
- {
- return AsyncHelper.RunSync(() => settingManager.GetSettingValueForApplicationAsync(name));
- }
- /// <summary>
- /// Gets current value of a setting for a user level.
- /// It gets the setting value, overwritten by given tenant and user.
- /// </summary>
- /// <param name="settingManager">Setting manager</param>
- /// <param name="name">Unique name of the setting</param>
- /// <param name="userId">User id</param>
- /// <returns>Current value of the setting for the user</returns>
- public static string GetSettingValueForUser(this IIwbSettingManager settingManager, string name, long userId)
- {
- return AsyncHelper.RunSync(() => settingManager.GetSettingValueForUserAsync(name, userId));
- }
- /// <summary>
- /// Gets current value of a setting for a user level.
- /// It gets the setting value, overwritten by given tenant and user.
- /// </summary>
- /// <param name="settingManager">Setting manager</param>
- /// <param name="name">Unique name of the setting</param>
- /// <param name="userId">User id</param>
- /// <param name="fallbackToDefault"></param>
- /// <returns>Current value of the setting for the user</returns>
- public static string GetSettingValueForUser(this IIwbSettingManager settingManager, string name, long userId, bool fallbackToDefault)
- {
- return AsyncHelper.RunSync(() => settingManager.GetSettingValueForUserAsync(name, userId, fallbackToDefault));
- }
- /// <summary>
- /// Gets value of a setting.
- /// </summary>
- /// <typeparam name="T">Type of the setting to get</typeparam>
- /// <param name="settingManager">Setting manager</param>
- /// <param name="name">Unique name of the setting</param>
- /// <returns>Value of the setting</returns>
- public static T GetSettingValue<T>(this IIwbSettingManager settingManager, string name)
- where T : struct
- {
- return AsyncHelper.RunSync(() => settingManager.GetSettingValueAsync<T>(name));
- }
- /// <summary>
- /// Gets current value of a setting for the application level.
- /// </summary>
- /// <typeparam name="T">Type of the setting to get</typeparam>
- /// <param name="settingManager">Setting manager</param>
- /// <param name="name">Unique name of the setting</param>
- /// <returns>Current value of the setting for the application</returns>
- public static T GetSettingValueForApplication<T>(this IIwbSettingManager settingManager, string name)
- where T : struct
- {
- return AsyncHelper.RunSync(() => settingManager.GetSettingValueForApplicationAsync<T>(name));
- }
- /// <summary>
- /// Gets current value of a setting for a user level.
- /// It gets the setting value, overwritten by given tenant and user.
- /// </summary>
- /// <typeparam name="T">Type of the setting to get</typeparam>
- /// <param name="settingManager">Setting manager</param>
- /// <param name="name">Unique name of the setting</param>
- /// <param name="tenantId">Tenant id</param>
- /// <param name="userId">User id</param>
- /// <returns>Current value of the setting for the user</returns>
- public static T GetSettingValueForUser<T>(this IIwbSettingManager settingManager, string name, int? tenantId, long userId)
- where T : struct
- {
- return AsyncHelper.RunSync(() => settingManager.GetSettingValueForUserAsync<T>(name, userId));
- }
- /// <summary>
- /// Gets current value of a setting for a user level.
- /// It gets the setting value, overwritten by given tenant and user.
- /// </summary>
- /// <typeparam name="T">Type of the setting to get</typeparam>
- /// <param name="settingManager">Setting manager</param>
- /// <param name="name">Unique name of the setting</param>
- /// <param name="user">User</param>
- /// <returns>Current value of the setting for the user</returns>
- public static T GetSettingValueForUser<T>(this IIwbSettingManager settingManager, string name, UserIdentifier user)
- where T : struct
- {
- return AsyncHelper.RunSync(() => settingManager.GetSettingValueForUserAsync<T>(name, user));
- }
- /// <summary>
- /// Gets current values of all settings.
- /// It gets all setting values, overwritten by application and the current user if exists.
- /// </summary>
- /// <param name="settingManager">Setting manager</param>
- /// <returns>List of setting values</returns>
- public static IReadOnlyList<ISettingValue> GetAllSettingValues(this IIwbSettingManager settingManager)
- {
- return AsyncHelper.RunSync(settingManager.GetAllSettingValuesAsync);
- }
- /// <summary>
- /// Gets a list of all setting values specified for the application.
- /// It returns only settings those are explicitly set for the application.
- /// If a setting's default value is used, it's not included the result list.
- /// If you want to get current values of all settings, use <see cref="GetAllSettingValues"/> method.
- /// </summary>
- /// <param name="settingManager">Setting manager</param>
- /// <returns>List of setting values</returns>
- public static IReadOnlyList<ISettingValue> GetAllSettingValuesForApplication(this IIwbSettingManager settingManager)
- {
- return AsyncHelper.RunSync(settingManager.GetAllSettingValuesForApplicationAsync);
- }
- /// <summary>
- /// Gets a list of all setting values specified for a tenant.
- /// It returns only settings those are explicitly set for the tenant.
- /// If a setting's default value is used, it's not included the result list.
- /// If you want to get current values of all settings, use <see cref="GetAllSettingValues"/> method.
- /// </summary>
- /// <param name="settingManager">Setting manager</param>
- /// <param name="tenantId">Tenant to get settings</param>
- /// <returns>List of setting values</returns>
- public static IReadOnlyList<ISettingValue> GetAllSettingValuesForTenant(this IIwbSettingManager settingManager, int tenantId)
- {
- return AsyncHelper.RunSync(() => settingManager.GetAllSettingValuesForTenantAsync(tenantId));
- }
- /// <summary>
- /// Gets a list of all setting values specified for a user.
- /// It returns only settings those are explicitly set for the user.
- /// If a setting's value is not set for the user (for example if user uses the default value), it's not included the result list.
- /// If you want to get current values of all settings, use <see cref="GetAllSettingValues"/> method.
- /// </summary>
- /// <param name="settingManager">Setting manager</param>
- /// <param name="user">User to get settings</param>
- /// <returns>All settings of the user</returns>
- public static IReadOnlyList<ISettingValue> GetAllSettingValuesForUser(this IIwbSettingManager settingManager, UserIdentifier user)
- {
- return AsyncHelper.RunSync(() => settingManager.GetAllSettingValuesForUserAsync(user));
- }
- /// <summary>
- /// Changes setting for the application level.
- /// </summary>
- /// <param name="settingManager">Setting manager</param>
- /// <param name="name">Unique name of the setting</param>
- /// <param name="value">Value of the setting</param>
- public static void ChangeSettingForApplication(this IIwbSettingManager settingManager, string name, string value)
- {
- AsyncHelper.RunSync(() => settingManager.ChangeSettingForApplicationAsync(name, value));
- }
- /// <summary>
- /// Changes setting for a Tenant.
- /// </summary>
- /// <param name="settingManager">Setting manager</param>
- /// <param name="tenantId">TenantId</param>
- /// <param name="name">Unique name of the setting</param>
- /// <param name="value">Value of the setting</param>
- public static void ChangeSettingForTenant(this IIwbSettingManager settingManager, int tenantId, string name, string value)
- {
- AsyncHelper.RunSync(() => settingManager.ChangeSettingForTenantAsync(tenantId, name, value));
- }
- /// <summary>
- /// Changes setting for a user.
- /// </summary>
- /// <param name="settingManager">Setting manager</param>
- /// <param name="user">User</param>
- /// <param name="name">Unique name of the setting</param>
- /// <param name="value">Value of the setting</param>
- public static void ChangeSettingForUser(this IIwbSettingManager settingManager, UserIdentifier user, string name, string value)
- {
- AsyncHelper.RunSync(() => settingManager.ChangeSettingForUserAsync(user, name, value));
- }
- }
- }
|