SettingManagerExtensions.cs 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305
  1. using System.Collections.Generic;
  2. using System.Threading.Tasks;
  3. using Abp.Extensions;
  4. using Abp.Threading;
  5. namespace Abp.Configuration
  6. {
  7. /// <summary>
  8. /// Extension methods for <see cref="ISettingManager"/>.
  9. /// </summary>
  10. public static class SettingManagerExtensions
  11. {
  12. /// <summary>
  13. /// Gets value of a setting in given type (<see cref="T"/>).
  14. /// </summary>
  15. /// <typeparam name="T">Type of the setting to get</typeparam>
  16. /// <param name="settingManager">Setting manager</param>
  17. /// <param name="name">Unique name of the setting</param>
  18. /// <returns>Value of the setting</returns>
  19. public static async Task<T> GetSettingValueAsync<T>(this ISettingManager settingManager, string name)
  20. where T : struct
  21. {
  22. return (await settingManager.GetSettingValueAsync(name)).To<T>();
  23. }
  24. /// <summary>
  25. /// Gets current value of a setting for the application level.
  26. /// </summary>
  27. /// <param name="settingManager">Setting manager</param>
  28. /// <param name="name">Unique name of the setting</param>
  29. /// <returns>Current value of the setting for the application</returns>
  30. public static async Task<T> GetSettingValueForApplicationAsync<T>(this ISettingManager settingManager, string name)
  31. where T : struct
  32. {
  33. return (await settingManager.GetSettingValueForApplicationAsync(name)).To<T>();
  34. }
  35. /// <summary>
  36. /// Gets current value of a setting for a tenant level.
  37. /// It gets the setting value, overwritten by given tenant.
  38. /// </summary>
  39. /// <param name="settingManager">Setting manager</param>
  40. /// <param name="name">Unique name of the setting</param>
  41. /// <param name="tenantId">Tenant id</param>
  42. /// <returns>Current value of the setting</returns>
  43. public static async Task<T> GetSettingValueForTenantAsync<T>(this ISettingManager settingManager, string name, int tenantId)
  44. where T : struct
  45. {
  46. return (await settingManager.GetSettingValueForTenantAsync(name, tenantId)).To<T>();
  47. }
  48. /// <summary>
  49. /// Gets current value of a setting for a user level.
  50. /// It gets the setting value, overwritten by given tenant and user.
  51. /// </summary>
  52. /// <param name="settingManager">Setting manager</param>
  53. /// <param name="name">Unique name of the setting</param>
  54. /// <param name="tenantId">Tenant id</param>
  55. /// <param name="userId">User id</param>
  56. /// <returns>Current value of the setting for the user</returns>
  57. public static async Task<T> GetSettingValueForUserAsync<T>(this ISettingManager settingManager, string name, int? tenantId, long userId)
  58. where T : struct
  59. {
  60. return (await settingManager.GetSettingValueForUserAsync(name, tenantId, userId)).To<T>();
  61. }
  62. /// <summary>
  63. /// Gets current value of a setting for a user level.
  64. /// It gets the setting value, overwritten by given tenant and user.
  65. /// </summary>
  66. /// <param name="settingManager">Setting manager</param>
  67. /// <param name="name">Unique name of the setting</param>
  68. /// <param name="user">User</param>
  69. /// <returns>Current value of the setting for the user</returns>
  70. public static async Task<T> GetSettingValueForUserAsync<T>(this ISettingManager settingManager, string name, UserIdentifier user)
  71. where T : struct
  72. {
  73. return (await settingManager.GetSettingValueForUserAsync(name, user)).To<T>();
  74. }
  75. /// <summary>
  76. /// Gets current value of a setting.
  77. /// It gets the setting value, overwritten by application and the current user if exists.
  78. /// </summary>
  79. /// <param name="settingManager">Setting manager</param>
  80. /// <param name="name">Unique name of the setting</param>
  81. /// <returns>Current value of the setting</returns>
  82. public static string GetSettingValue(this ISettingManager settingManager, string name)
  83. {
  84. return AsyncHelper.RunSync(() => settingManager.GetSettingValueAsync(name));
  85. }
  86. /// <summary>
  87. /// Gets current value of a setting for the application level.
  88. /// </summary>
  89. /// <param name="settingManager">Setting manager</param>
  90. /// <param name="name">Unique name of the setting</param>
  91. /// <returns>Current value of the setting for the application</returns>
  92. public static string GetSettingValueForApplication(this ISettingManager settingManager, string name)
  93. {
  94. return AsyncHelper.RunSync(() => settingManager.GetSettingValueForApplicationAsync(name));
  95. }
  96. /// <summary>
  97. /// Gets current value of a setting for a tenant level.
  98. /// It gets the setting value, overwritten by given tenant.
  99. /// </summary>
  100. /// <param name="settingManager">Setting manager</param>
  101. /// <param name="name">Unique name of the setting</param>
  102. /// <param name="tenantId">Tenant id</param>
  103. /// <returns>Current value of the setting</returns>
  104. public static string GetSettingValueForTenant(this ISettingManager settingManager, string name, int tenantId)
  105. {
  106. return AsyncHelper.RunSync(() => settingManager.GetSettingValueForTenantAsync(name, tenantId));
  107. }
  108. /// <summary>
  109. /// Gets current value of a setting for a user level.
  110. /// It gets the setting value, overwritten by given tenant and user.
  111. /// </summary>
  112. /// <param name="settingManager">Setting manager</param>
  113. /// <param name="name">Unique name of the setting</param>
  114. /// <param name="tenantId">Tenant id</param>
  115. /// <param name="userId">User id</param>
  116. /// <returns>Current value of the setting for the user</returns>
  117. public static string GetSettingValueForUser(this ISettingManager settingManager, string name, int? tenantId, long userId)
  118. {
  119. return AsyncHelper.RunSync(() => settingManager.GetSettingValueForUserAsync(name, tenantId, userId));
  120. }
  121. /// <summary>
  122. /// Gets current value of a setting for a user level.
  123. /// It gets the setting value, overwritten by given tenant and user.
  124. /// </summary>
  125. /// <param name="settingManager">Setting manager</param>
  126. /// <param name="name">Unique name of the setting</param>
  127. /// <param name="tenantId">Tenant id</param>
  128. /// <param name="userId">User id</param>
  129. /// <param name="fallbackToDefault"></param>
  130. /// <returns>Current value of the setting for the user</returns>
  131. public static string GetSettingValueForUser(this ISettingManager settingManager, string name, int? tenantId, long userId, bool fallbackToDefault)
  132. {
  133. return AsyncHelper.RunSync(() => settingManager.GetSettingValueForUserAsync(name, tenantId, userId, fallbackToDefault));
  134. }
  135. /// <summary>
  136. /// Gets value of a setting.
  137. /// </summary>
  138. /// <typeparam name="T">Type of the setting to get</typeparam>
  139. /// <param name="settingManager">Setting manager</param>
  140. /// <param name="name">Unique name of the setting</param>
  141. /// <returns>Value of the setting</returns>
  142. public static T GetSettingValue<T>(this ISettingManager settingManager, string name)
  143. where T : struct
  144. {
  145. return AsyncHelper.RunSync(() => settingManager.GetSettingValueAsync<T>(name));
  146. }
  147. /// <summary>
  148. /// Gets current value of a setting for the application level.
  149. /// </summary>
  150. /// <typeparam name="T">Type of the setting to get</typeparam>
  151. /// <param name="settingManager">Setting manager</param>
  152. /// <param name="name">Unique name of the setting</param>
  153. /// <returns>Current value of the setting for the application</returns>
  154. public static T GetSettingValueForApplication<T>(this ISettingManager settingManager, string name)
  155. where T : struct
  156. {
  157. return AsyncHelper.RunSync(() => settingManager.GetSettingValueForApplicationAsync<T>(name));
  158. }
  159. /// <summary>
  160. /// Gets current value of a setting for a tenant level.
  161. /// It gets the setting value, overwritten by given tenant.
  162. /// </summary>
  163. /// <typeparam name="T">Type of the setting to get</typeparam>
  164. /// <param name="settingManager">Setting manager</param>
  165. /// <param name="name">Unique name of the setting</param>
  166. /// <param name="tenantId">Tenant id</param>
  167. /// <returns>Current value of the setting</returns>
  168. public static T GetSettingValueForTenant<T>(this ISettingManager settingManager, string name, int tenantId)
  169. where T : struct
  170. {
  171. return AsyncHelper.RunSync(() => settingManager.GetSettingValueForTenantAsync<T>(name, tenantId));
  172. }
  173. /// <summary>
  174. /// Gets current value of a setting for a user level.
  175. /// It gets the setting value, overwritten by given tenant and user.
  176. /// </summary>
  177. /// <typeparam name="T">Type of the setting to get</typeparam>
  178. /// <param name="settingManager">Setting manager</param>
  179. /// <param name="name">Unique name of the setting</param>
  180. /// <param name="tenantId">Tenant id</param>
  181. /// <param name="userId">User id</param>
  182. /// <returns>Current value of the setting for the user</returns>
  183. public static T GetSettingValueForUser<T>(this ISettingManager settingManager, string name, int? tenantId, long userId)
  184. where T : struct
  185. {
  186. return AsyncHelper.RunSync(() => settingManager.GetSettingValueForUserAsync<T>(name, tenantId, userId));
  187. }
  188. /// <summary>
  189. /// Gets current value of a setting for a user level.
  190. /// It gets the setting value, overwritten by given tenant and user.
  191. /// </summary>
  192. /// <typeparam name="T">Type of the setting to get</typeparam>
  193. /// <param name="settingManager">Setting manager</param>
  194. /// <param name="name">Unique name of the setting</param>
  195. /// <param name="user">User</param>
  196. /// <returns>Current value of the setting for the user</returns>
  197. public static T GetSettingValueForUser<T>(this ISettingManager settingManager, string name, UserIdentifier user)
  198. where T : struct
  199. {
  200. return AsyncHelper.RunSync(() => settingManager.GetSettingValueForUserAsync<T>(name, user));
  201. }
  202. /// <summary>
  203. /// Gets current values of all settings.
  204. /// It gets all setting values, overwritten by application and the current user if exists.
  205. /// </summary>
  206. /// <param name="settingManager">Setting manager</param>
  207. /// <returns>List of setting values</returns>
  208. public static IReadOnlyList<ISettingValue> GetAllSettingValues(this ISettingManager settingManager)
  209. {
  210. return AsyncHelper.RunSync(settingManager.GetAllSettingValuesAsync);
  211. }
  212. /// <summary>
  213. /// Gets a list of all setting values specified for the application.
  214. /// It returns only settings those are explicitly set for the application.
  215. /// If a setting's default value is used, it's not included the result list.
  216. /// If you want to get current values of all settings, use <see cref="GetAllSettingValues"/> method.
  217. /// </summary>
  218. /// <param name="settingManager">Setting manager</param>
  219. /// <returns>List of setting values</returns>
  220. public static IReadOnlyList<ISettingValue> GetAllSettingValuesForApplication(this ISettingManager settingManager)
  221. {
  222. return AsyncHelper.RunSync(settingManager.GetAllSettingValuesForApplicationAsync);
  223. }
  224. /// <summary>
  225. /// Gets a list of all setting values specified for a tenant.
  226. /// It returns only settings those are explicitly set for the tenant.
  227. /// If a setting's default value is used, it's not included the result list.
  228. /// If you want to get current values of all settings, use <see cref="GetAllSettingValues"/> method.
  229. /// </summary>
  230. /// <param name="settingManager">Setting manager</param>
  231. /// <param name="tenantId">Tenant to get settings</param>
  232. /// <returns>List of setting values</returns>
  233. public static IReadOnlyList<ISettingValue> GetAllSettingValuesForTenant(this ISettingManager settingManager, int tenantId)
  234. {
  235. return AsyncHelper.RunSync(() => settingManager.GetAllSettingValuesForTenantAsync(tenantId));
  236. }
  237. /// <summary>
  238. /// Gets a list of all setting values specified for a user.
  239. /// It returns only settings those are explicitly set for the user.
  240. /// 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.
  241. /// If you want to get current values of all settings, use <see cref="GetAllSettingValues"/> method.
  242. /// </summary>
  243. /// <param name="settingManager">Setting manager</param>
  244. /// <param name="user">User to get settings</param>
  245. /// <returns>All settings of the user</returns>
  246. public static IReadOnlyList<ISettingValue> GetAllSettingValuesForUser(this ISettingManager settingManager, UserIdentifier user)
  247. {
  248. return AsyncHelper.RunSync(() => settingManager.GetAllSettingValuesForUserAsync(user));
  249. }
  250. /// <summary>
  251. /// Changes setting for the application level.
  252. /// </summary>
  253. /// <param name="settingManager">Setting manager</param>
  254. /// <param name="name">Unique name of the setting</param>
  255. /// <param name="value">Value of the setting</param>
  256. public static void ChangeSettingForApplication(this ISettingManager settingManager, string name, string value)
  257. {
  258. AsyncHelper.RunSync(() => settingManager.ChangeSettingForApplicationAsync(name, value));
  259. }
  260. /// <summary>
  261. /// Changes setting for a Tenant.
  262. /// </summary>
  263. /// <param name="settingManager">Setting manager</param>
  264. /// <param name="tenantId">TenantId</param>
  265. /// <param name="name">Unique name of the setting</param>
  266. /// <param name="value">Value of the setting</param>
  267. public static void ChangeSettingForTenant(this ISettingManager settingManager, int tenantId, string name, string value)
  268. {
  269. AsyncHelper.RunSync(() => settingManager.ChangeSettingForTenantAsync(tenantId, name, value));
  270. }
  271. /// <summary>
  272. /// Changes setting for a user.
  273. /// </summary>
  274. /// <param name="settingManager">Setting manager</param>
  275. /// <param name="user">User</param>
  276. /// <param name="name">Unique name of the setting</param>
  277. /// <param name="value">Value of the setting</param>
  278. public static void ChangeSettingForUser(this ISettingManager settingManager, UserIdentifier user, string name, string value)
  279. {
  280. AsyncHelper.RunSync(() => settingManager.ChangeSettingForUserAsync(user, name, value));
  281. }
  282. }
  283. }