MobileUtils.cs 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242
  1. using System;
  2. using System.Linq;
  3. using System.Net;
  4. using System.Threading;
  5. using System.Threading.Tasks;
  6. using System.Collections.Generic;
  7. using Xamarin.Forms;
  8. using RestSharp;
  9. using Plugin.Permissions;
  10. using Plugin.Permissions.Abstractions;
  11. using Syncfusion.Licensing;
  12. using comal.timesheets;
  13. using Xamarin.Essentials;
  14. using PermissionStatus = Plugin.Permissions.Abstractions.PermissionStatus;
  15. using InABox.Core;
  16. using InABox.Clients;
  17. using InABox.Configuration;
  18. namespace InABox.Mobile
  19. {
  20. public enum PermissionType
  21. {
  22. Unknown,
  23. Calendar,
  24. Camera,
  25. Contacts,
  26. Location,
  27. Microphone,
  28. Phone,
  29. Photos,
  30. Reminders,
  31. Sensors,
  32. Sms,
  33. Storage,
  34. Speech,
  35. LocationAlways,
  36. LocationWhenInUse,
  37. MediaLibrary
  38. }
  39. public static class MobileUtils
  40. {
  41. public static void Init()
  42. {
  43. Syncfusion.Licensing.SyncfusionLicenseProvider.RegisterLicense(InABox.Core.CoreUtils.SyncfusionLicense(Core.SyncfusionVersion.v20_3));
  44. }
  45. public static String GetDeviceID()
  46. {
  47. IDeviceID deviceID = DependencyService.Get<IDeviceID>();
  48. return deviceID.DeviceID();
  49. }
  50. public static IAppVersion AppVersion { get { return DependencyService.Get<IAppVersion>(); } }
  51. public static void SaveToSecureStorage()
  52. {
  53. try
  54. {
  55. SecureStorage.SetAsync(GlobalVariables.CacheURLString, App.Settings.URL);
  56. SecureStorage.SetAsync(GlobalVariables.CachePortString, App.Settings.Port.ToString());
  57. SecureStorage.SetAsync(GlobalVariables.CacheUserIDString, App.Settings.UserID);
  58. SecureStorage.SetAsync(GlobalVariables.CachePasswordString, App.Settings.Password);
  59. }
  60. catch { }
  61. }
  62. public static void LoadFromLink()
  63. {
  64. try
  65. {
  66. var s = Encryption.Decrypt(GlobalVariables.LoadFromLinkString, "logindetailslink");
  67. var array = s.Split(',');
  68. DateTime expiry = DateTime.Parse(array[4]);
  69. if (DateTime.Now.Subtract(expiry) < new TimeSpan(0, 5, 0))
  70. {
  71. App.Settings.URL = array[0];
  72. App.Settings.Port = int.Parse(array[1]);
  73. App.Settings.UserID = array[2];
  74. App.Settings.Password = array[3];
  75. ClientFactory.InvalidateUser();
  76. new LocalConfiguration<ConnectionSettings>().Delete();
  77. new LocalConfiguration<ConnectionSettings>().Save(App.Settings);
  78. App.Settings = new LocalConfiguration<ConnectionSettings>().Load();
  79. if (App.Current.Properties.ContainsKey("SessionID"))
  80. App.Current.Properties.Remove("SessionID");
  81. MobileUtils.SaveToSecureStorage();
  82. }
  83. else
  84. GlobalVariables.LoadFromLinkString = "Link has expired";
  85. }
  86. catch (Exception e)
  87. {
  88. if (String.IsNullOrWhiteSpace(App.Settings.URL))
  89. LoadDemoSettings(App.Settings);
  90. }
  91. }
  92. public static void LoadDemoSettings(ConnectionSettings settings)
  93. {
  94. settings.URL = "http://demo.prsdigital.com.au";
  95. settings.Port = 8003;
  96. settings.UserID = "GUEST";
  97. settings.Password = "guest";
  98. }
  99. private static async Task<bool> Retry(Func<Task<bool>> action, int interval, int retryCount = 3)
  100. {
  101. bool flag = false;
  102. List<Exception> source = new List<Exception>();
  103. TimeSpan delay = TimeSpan.FromMilliseconds((double)interval);
  104. for (int index = 0; index < retryCount; ++index)
  105. {
  106. try
  107. {
  108. flag = await action();
  109. if (flag)
  110. return true;
  111. Task.Delay(delay).Wait();
  112. }
  113. catch (Exception ex)
  114. {
  115. if (source.All<Exception>((Func<Exception, bool>)(x => x.Message != ex.Message)))
  116. source.Add(ex);
  117. Task.Delay(delay).Wait();
  118. }
  119. }
  120. if (!flag && !source.Any<Exception>())
  121. return false;
  122. if (source.Count<Exception>() == 1)
  123. throw source[0];
  124. if (source.Count<Exception>() > 1)
  125. throw new AggregateException((IEnumerable<Exception>)source);
  126. return flag;
  127. }
  128. public static async Task<bool> IsPermitted(PermissionType permissiontype)
  129. {
  130. Permission permission = (Permission)permissiontype;
  131. PermissionStatus status = await CrossPermissions.Current.CheckPermissionStatusAsync(permission);
  132. if (status == PermissionStatus.Granted)
  133. return true;
  134. Dictionary<Permission,PermissionStatus> statuses = await CrossPermissions.Current.RequestPermissionsAsync(permission);
  135. if (statuses[permission] == PermissionStatus.Granted)
  136. return true;
  137. return false;
  138. //request.Wait();
  139. //var statuses = request.Result;
  140. //return (statuses.ContainsKey(permission) && (statuses[permission] == PermissionStatus.Granted));
  141. //PermissionStatus status = PermissionStatus.Unknown;
  142. //var result = Retry(async () =>
  143. //{
  144. // status = await CrossPermissions.Current.CheckPermissionStatusAsync(permission);
  145. // if (status != PermissionStatus.Granted)
  146. // {
  147. // var results = await CrossPermissions.Current.RequestPermissionsAsync(permission);
  148. // if (results.ContainsKey(permission))
  149. // status = results[permission];
  150. // }
  151. // return status == PermissionStatus.Granted;
  152. //}, 5000, 3);
  153. //result.Wait();
  154. //return result.Result;
  155. }
  156. public static async Task<bool> CheckPermissions(PermissionType permissiontype)
  157. {
  158. Permission permission = (Permission)permissiontype;
  159. var permissionStatus = await CrossPermissions.Current.CheckPermissionStatusAsync(permission);
  160. bool request = false;
  161. if (permissionStatus == PermissionStatus.Denied)
  162. {
  163. if (String.Equals(Device.RuntimePlatform,Device.iOS))
  164. {
  165. var title = $"{permission} Permission";
  166. var question = $"To use this plugin the {permission} permission is required. Please go into Settings and turn on {permission} for the app.";
  167. var positive = "Settings";
  168. var negative = "Maybe Later";
  169. var task = Application.Current?.MainPage?.DisplayAlert(title, question, positive, negative);
  170. if (task == null)
  171. return false;
  172. var result = await task;
  173. if (result)
  174. {
  175. CrossPermissions.Current.OpenAppSettings();
  176. }
  177. return false;
  178. }
  179. request = true;
  180. }
  181. if (request || permissionStatus != PermissionStatus.Granted)
  182. {
  183. var newStatus = await CrossPermissions.Current.RequestPermissionsAsync(permission);
  184. if (newStatus.ContainsKey(permission) && newStatus[permission] != PermissionStatus.Granted)
  185. {
  186. var title = $"{permission} Permission";
  187. var question = $"To use the plugin the {permission} permission is required.";
  188. var positive = "Settings";
  189. var negative = "Maybe Later";
  190. var task = Application.Current?.MainPage?.DisplayAlert(title, question, positive, negative);
  191. if (task == null)
  192. return false;
  193. var result = await task;
  194. if (result)
  195. {
  196. CrossPermissions.Current.OpenAppSettings();
  197. }
  198. return false;
  199. }
  200. }
  201. return true;
  202. }
  203. }
  204. }