public static void ImportGeocaches(Core.Storage.Database db, List <string> gcCodes) { try { using (Utils.ProgressBlock progress = new Utils.ProgressBlock("ImportingGeocaches", "ImportingGeocaches", gcCodes.Count, 0, true)) { int totalcount = gcCodes.Count; using (var client = new GeocachingLiveV6()) { int index = 0; while (gcCodes.Count > 0) { LiveV6.SearchForGeocachesRequest req = new LiveV6.SearchForGeocachesRequest(); req.IsLite = Core.Settings.Default.LiveAPIMemberTypeId == 1; req.AccessToken = client.Token; req.CacheCode = new LiveV6.CacheCodeFilter(); req.CacheCode.CacheCodes = (from a in gcCodes select a).Take(Core.Settings.Default.LiveAPIImportGeocachesBatchSize).ToArray(); req.MaxPerPage = Core.Settings.Default.LiveAPIImportGeocachesBatchSize; req.GeocacheLogCount = 5; index += req.CacheCode.CacheCodes.Length; gcCodes.RemoveRange(0, req.CacheCode.CacheCodes.Length); var resp = client.Client.SearchForGeocaches(req); if (resp.Status.StatusCode == 0 && resp.Geocaches != null) { List <Core.Data.Geocache> upList = ImportGeocaches(db, resp.Geocaches); if (Core.Settings.Default.LiveAPIDeselectAfterUpdate) { foreach (var g in upList) { g.Selected = false; } } } else { Core.ApplicationData.Instance.Logger.AddLog(new Import(), new Exception(resp.Status.StatusMessage)); break; } if (!progress.Update("ImportingGeocaches", totalcount, index)) { break; } if (gcCodes.Count > 0) { System.Threading.Thread.Sleep(Core.Settings.Default.LiveAPIDelaySearchForGeocaches); } } } } } catch (Exception e) { Core.ApplicationData.Instance.Logger.AddLog(new Import(), e); } }
public static void ImportGeocaches(Core.Storage.Database db, LiveV6.SearchForGeocachesRequest req, int max) { using (Utils.ProgressBlock progress = new Utils.ProgressBlock("ImportingGeocaches", "ImportingGeocaches", max, 0, true)) { try { using (GeocachingLiveV6 client = new GeocachingLiveV6()) { req.AccessToken = client.Token; var resp = client.Client.SearchForGeocaches(req); if (resp.Status.StatusCode == 0 && resp.Geocaches != null) { ImportGeocaches(db, resp.Geocaches); if (resp.Geocaches.Count() >= req.MaxPerPage && req.MaxPerPage < max) { if (progress.Update("ImportingGeocaches", max, resp.Geocaches.Count())) { var mreq = new LiveV6.GetMoreGeocachesRequest(); mreq.AccessToken = req.AccessToken; mreq.GeocacheLogCount = req.GeocacheLogCount; mreq.MaxPerPage = (int)Math.Min(req.MaxPerPage, max - resp.Geocaches.Count()); mreq.StartIndex = resp.Geocaches.Count(); mreq.TrackableLogCount = req.TrackableLogCount; mreq.IsLite = req.IsLite; mreq.GeocacheLogCount = req.GeocacheLogCount; while (resp.Status.StatusCode == 0 && resp.Geocaches != null && resp.Geocaches.Count() >= req.MaxPerPage) { resp = client.Client.GetMoreGeocaches(mreq); if (resp.Status.StatusCode == 0 && resp.Geocaches != null) { ImportGeocaches(db, resp.Geocaches); if (!progress.Update("ImportingGeocaches", max, mreq.StartIndex + resp.Geocaches.Count())) { break; } mreq.StartIndex += resp.Geocaches.Count(); mreq.MaxPerPage = (int)Math.Min(req.MaxPerPage, max - mreq.StartIndex); if (mreq.StartIndex >= max - 1) { break; } } else { Core.ApplicationData.Instance.Logger.AddLog(new Import(), Core.Logger.Level.Error, resp.Status.StatusMessage); } } } } } else { Core.ApplicationData.Instance.Logger.AddLog(new Import(), Core.Logger.Level.Error, resp.Status.StatusMessage); } } } catch (Exception e) { Core.ApplicationData.Instance.Logger.AddLog(new Import(), e); } } }
public static void ImportGeocaches(Core.Storage.Database db, List<string> gcCodes) { try { using (Utils.ProgressBlock progress = new Utils.ProgressBlock("ImportingGeocaches", "ImportingGeocaches", gcCodes.Count, 0, true)) { int totalcount = gcCodes.Count; using (var client = new GeocachingLiveV6()) { int index = 0; while (gcCodes.Count > 0) { LiveV6.SearchForGeocachesRequest req = new LiveV6.SearchForGeocachesRequest(); req.IsLite = Core.Settings.Default.LiveAPIMemberTypeId == 1; req.AccessToken = client.Token; req.CacheCode = new LiveV6.CacheCodeFilter(); req.CacheCode.CacheCodes = (from a in gcCodes select a).Take(Core.Settings.Default.LiveAPIImportGeocachesBatchSize).ToArray(); req.MaxPerPage = Core.Settings.Default.LiveAPIImportGeocachesBatchSize; req.GeocacheLogCount = 5; index += req.CacheCode.CacheCodes.Length; gcCodes.RemoveRange(0, req.CacheCode.CacheCodes.Length); var resp = client.Client.SearchForGeocaches(req); if (resp.Status.StatusCode == 0 && resp.Geocaches != null) { List<Core.Data.Geocache> upList = ImportGeocaches(db, resp.Geocaches); if (Core.Settings.Default.LiveAPIDeselectAfterUpdate) { foreach (var g in upList) { g.Selected = false; } } } else { Core.ApplicationData.Instance.Logger.AddLog(new Import(), new Exception(resp.Status.StatusMessage)); break; } if (!progress.Update("ImportingGeocaches", totalcount, index)) { break; } if (gcCodes.Count>0) { System.Threading.Thread.Sleep(Core.Settings.Default.LiveAPIDelaySearchForGeocaches); } } } } } catch(Exception e) { Core.ApplicationData.Instance.Logger.AddLog(new Import(), e); } }