private async void mnuDelete_Click(object sender, EventArgs e) { try { if (DGrid.RowCount <= 0) { return; } if (DGrid.CurrentRow == null) { return; } var guid = (Guid)DGrid[dgGuid.Index, DGrid.CurrentRow.Index].Value; if (MessageBox.Show($@"آیا از حذف شماره {DGrid[dgNumber.Index, DGrid.CurrentRow.Index].Value} اطمینان دارید؟", "حذف", MessageBoxButtons.YesNo, MessageBoxIcon.Question) == DialogResult.No) { return; } var sim = await SimcardBussines.GetAsync(guid); var res = await sim.RemoveAsync(); if (res.HasError) { frmNotification.PublicInfo.ShowMessage(res.ErrorMessage); return; } frmLoading.PublicInfo.ShowForm(); await LoadData(txtSearch.Text); } catch (Exception ex) { WebErrorLog.ErrorInstence.StartErrorLog(ex); } }
private async void mnuDelete_Click(object sender, EventArgs e) { try { if (DGrid.RowCount == 0) { return; } if (DGrid.CurrentRow == null) { return; } var accGuid = (Guid)DGrid[dgGuid.Index, DGrid.CurrentRow.Index].Value; var Acc = SimcardBussines.GetAsync(accGuid); var message = "آیا از حذف سیمکارت " + Acc.Number + " " + "اطمینان دارید؟"; if (FarsiMessegeBox.Show(message, "حذف", FMessegeBoxButtons.YesNo, FMessegeBoxIcons.Question) != DialogResult.Yes) { return; } Acc = SimcardBussines.Change_Status(accGuid, false); await Acc.SaveAsync(); await LoadData(txtSearch.Text); } catch (Exception exception) { WebErrorLog.ErrorInstence.StartErrorLog(exception); } }
public frmSimcard_Main(Guid guid) { InitializeComponent(); cmAds.Renderer = new ToolStripProfessionalRenderer(new ContextMenuSetter()); cmCity.Renderer = new ToolStripProfessionalRenderer(new ContextMenuSetter()); cmSheypoor.Renderer = new ToolStripProfessionalRenderer(new ContextMenuSetter()); cls = SimcardBussines.GetAsync(guid); lblHeader.Text = "ویرایش سیمکارت"; }
private async Task GetChatCount(long number) { try { _driver = Utility.RefreshDriver(clsAdvertise.IsSilent); await Utility.Wait(); var link = _driver.FindElements(By.TagName("span")).Any(q => q.Text == "حساب من"); if (!link) { return; } await Utility.Wait(); _driver.FindElements(By.TagName("span")).FirstOrDefault(q => q.Text == "حساب من")?.Click(); await Utility.Wait(); var badge = _driver.FindElements(By.ClassName("badge")).Any(); if (!badge) { return; } await Utility.Wait(); var newChat = _driver.FindElement(By.ClassName("badge"))?.FindElement(By.TagName("span"))?.Text ?? ""; if (string.IsNullOrEmpty(newChat)) { return; } var sim = await SimcardBussines.GetAsync(number); TelegramSender.GetChatLog_bot() .Send( $"#چت_شیپور \r\nسیستم مرجع: {await Utilities.GetNetworkIpAddress()} \r\n شماره: {number} \r\n مالک: {sim.Owner} \r\n تعداد چت شیپور: {newChat.FixString()}"); } catch (Exception ex) { WebErrorLog.ErrorInstence.StartErrorLog(ex); } }
public async Task <bool> Login(long simCardNumber, bool isFromSimcard) { try { var sim_ = await SimcardBussines.GetAsync(simCardNumber); if (isFromSimcard) { _driver = Utility.RefreshDriver(clsAdvertise.IsSilent); var simBusiness = await Utility.CheckToken(simCardNumber, AdvertiseType.Sheypoor); // در صورتیکه توکن قبلا ثبت شده باشد لاگین می کند if (!simBusiness.HasError) { // token = _driver.Manage().Cookies.GetCookieNamed("ts").ToString().Substring(3, 32); _driver.Navigate().GoToUrl("https://www.sheypoor.com"); _driver.Manage().Cookies.DeleteCookieNamed("ts"); var newToken = new OpenQA.Selenium.Cookie("ts", simBusiness.value); _driver.Manage().Cookies.AddCookie(newToken); _driver.Navigate().GoToUrl("https://www.sheypoor.com/session/myListings"); var linksElements = _driver.FindElements(By.TagName("a")).ToList(); foreach (var link in linksElements) { if (link?.GetAttribute("href") == null || !link.GetAttribute("href").Contains("logout")) { continue; } _driver.ExecuteJavaScript(@"alert('لاگین انجام شد');"); await Utility.Wait(); _driver.SwitchTo().Alert().Accept(); return(true); } } //اگر قبلا توکن نداشته و یا توکن اشتباه باشد وارد صفحه دریافت کد تائید لاگین می شود _driver.Manage().Timeouts().PageLoad = new TimeSpan(0, 2, 0); _driver.Navigate().GoToUrl("https://www.sheypoor.com/session/myListings"); //var all = _driver.Manage().Cookies.AllCookies; if (_driver.FindElements(By.Id("username")).Count > 0) { _driver.FindElement(By.Id("username")).SendKeys(simCardNumber + "\n"); } //انتظار برای لاگین شدن int repeat = 0; //حدود 120 ثانیه فرصت لاگین دارد while (repeat < 20) { //تا زمانی که لاگین اوکی نشده باشد این حلقه تکرار می شود var badGateWay = _driver.FindElements(By.TagName("h1")) .Any(q => q.Text == "502 Bad Gateway" || q.Text == "Error 503 Service Unavailable"); if (badGateWay) { return(false); } var message = $@"مالک: {sim_.Owner} \r\nشماره: {simCardNumber} \r\nلطفا لاگین نمائید "; _driver.ExecuteJavaScript($"alert('{message}');"); //Wait(); await Utility.Wait(5); try { _driver.SwitchTo().Alert().Accept(); await Utility.Wait(10); repeat++; } catch { await Utility.Wait(15); } var linksElements = _driver?.FindElements(By.TagName("a")).ToList() ?? null; AdvTokenBussines advToken = null; foreach (var link in linksElements) { if (link?.GetAttribute("href") == null || !link.GetAttribute("href").Contains("logout")) { continue; } advToken = await AdvTokenBussines.GetTokenAsync(simCardNumber, AdvertiseType.Sheypoor); var token = _driver.Manage().Cookies.GetCookieNamed("ts").ToString().Substring(3, 32); if (advToken != null) { advToken.Token = token; } else { advToken = new AdvTokenBussines() { Type = AdvertiseType.Sheypoor, Token = token, Number = simCardNumber, Guid = Guid.NewGuid(), } }; await advToken.SaveAsync(); _driver.ExecuteJavaScript(@"alert('لاگین انجام شد');"); await Utility.Wait(); _driver.SwitchTo().Alert().Accept(); return(true); } } var linksElements1 = _driver?.FindElements(By.TagName("a")).FirstOrDefault(q => q.Text == "خروج") ?? null; if (linksElements1 == null) { var msg = $@"فرصت لاگین کردن به اتمام رسید. لطفا دقایقی بعد مجددا امتحان نمایید"; _driver.ExecuteJavaScript($"alert('{msg}');"); _driver.SwitchTo().Alert().Accept(); await Utility.Wait(3); } await Utility.Wait(); } else { _driver = Utility.RefreshDriver(clsAdvertise.IsSilent); var simBusiness = await Utility.CheckToken(simCardNumber, AdvertiseType.Sheypoor); // در صورتیکه توکن قبلا ثبت شده باشد لاگین می کند if (!simBusiness.HasError) { // token = _driver.Manage().Cookies.GetCookieNamed("ts").ToString().Substring(3, 32); _driver.Navigate().GoToUrl("https://www.sheypoor.com"); _driver.Manage().Cookies.DeleteCookieNamed("ts"); var newToken = new OpenQA.Selenium.Cookie("ts", simBusiness.value); _driver.Manage().Cookies.AddCookie(newToken); _driver.Navigate().GoToUrl("https://www.sheypoor.com/session/myListings"); var linksElements = _driver.FindElements(By.TagName("a")).ToList(); foreach (var link in linksElements) { if (link?.GetAttribute("href") == null || !link.GetAttribute("href").Contains("logout")) { continue; } _driver.ExecuteJavaScript(@"alert('لاگین انجام شد');"); await Utility.Wait(); _driver.SwitchTo().Alert().Accept(); return(true); } } _driver.Navigate().GoToUrl("https://www.sheypoor.com/session/myListings"); //انتظار برای لاگین شدن int repeat = 0; //حدود 120 ثانیه فرصت لاگین دارد while (repeat < 5) { //تا زمانی که لاگین اوکی نشده باشد این حلقه تکرار می شود var badGateWay = _driver.FindElements(By.TagName("h1")) .Any(q => q.Text == "502 Bad Gateway" || q.Text == "Error 503 Service Unavailable"); if (!badGateWay) { return(false); } var message = $@"مالک: {sim_.Owner} \r\nشماره: {simCardNumber} \r\nلطفا لاگین نمائید "; _driver.ExecuteJavaScript($"alert('{message}');"); //Wait(); await Utility.Wait(2); try { _driver.SwitchTo().Alert().Accept(); await Utility.Wait(1); repeat++; } catch { await Utility.Wait(15); } var linksElements = _driver?.FindElements(By.TagName("a")).ToList() ?? null; AdvTokenBussines advToken = null; foreach (var link in linksElements) { if (link?.GetAttribute("href") == null || !link.GetAttribute("href").Contains("logout")) { continue; } var token = _driver.Manage().Cookies.GetCookieNamed("ts").ToString().Substring(3, 32); advToken = await AdvTokenBussines.GetTokenAsync(simCardNumber, AdvertiseType.Sheypoor); if (advToken != null) { advToken.Token = token; } else { advToken = new AdvTokenBussines() { Type = AdvertiseType.Sheypoor, Token = token, Number = simCardNumber, Guid = Guid.NewGuid(), } }; } await advToken?.SaveAsync(); _driver.ExecuteJavaScript(@"alert('لاگین انجام شد');"); await Utility.Wait(); _driver.SwitchTo().Alert().Accept(); return(true); } } await Utility.Wait(); TelegramSender.GetChatLog_bot().Send( $"#نداشتن_توکن \r\n سیستم مرجع: {await Utilities.GetNetworkIpAddress()} \r\n شماره {simCardNumber} به مالکیت {sim_.Owner} توکن ارسال آگهی شیپور داشته، اما منقضی شده و موفق به لاگین نشد " + $"\r\n به همین سبب توکن شیپور این شماره از دیتابیس حذف خواهد شد " + $"\r\n لطفا نسبت به دریافت مجدد توکن اقدام گردد."); var advTokens = await AdvTokenBussines.GetTokenAsync(simCardNumber, AdvertiseType.Sheypoor); await advTokens?.RemoveAsync(); return(false); } catch (WebException) { return(false); } catch (Exception ex) { if (ex.Source != "WebDriver") { WebErrorLog.ErrorInstence.StartErrorLog(ex); } return(false); } }
public async Task StartRegisterAdv(AdvertiseLogBussines adv, long number) { var counter = 0; try { var res__ = await Utilities.PingHostAsync(); while (res__.HasError) { await Utility.Wait(10); lstMessage.Clear(); lstMessage.Add("خطای اتصال به شبکه"); Utility.ShowBalloon("لطفا اتصال به شبکه را چک نمایید", lstMessage); counter++; } var sim = await SimcardBussines.GetAsync(number); if (sim.isSheypoorBlocked) { lstMessage.Clear(); lstMessage.Add($"نوع آگهی: شیپور"); lstMessage.Add($"شماره: {number}"); lstMessage.Add($"مالک: {sim.Owner}"); lstMessage.Add("بدلیل بلاک بودن، موفق به لاگین نشد"); Utility.ShowBalloon("عدم انجام لاگین", lstMessage); sim.NextUseSheypoor = DateTime.Now.AddDays(1); await sim.SaveAsync(); return; } var tt = await Utility.CheckToken(number, AdvertiseType.Sheypoor); if (tt.HasError) { lstMessage.Clear(); lstMessage.Add($"نوع آگهی: شیپور"); lstMessage.Add($"شماره: {number}"); lstMessage.Add($"مالک: {sim.Owner}"); lstMessage.Add("بدلیل توکن نداشتن، موفق به لاگین نشد"); Utility.ShowBalloon("عدم انجام لاگین", lstMessage); sim.NextUseSheypoor = DateTime.Now.AddDays(1); await sim.SaveAsync(); return; } if (!await Login(number, false)) { return; } await GetChatCount(number); var res_ = await RegisterAdv(adv); if (res_.HasError) { return; } //تشخیص بلاکی _driver.Navigate().GoToUrl("https://www.sheypoor.com/session/myListings"); await Utility.Wait(2); var el = _driver.FindElements(By.TagName("article")).Any(); await Utility.Wait(); if (el) { return; } TelegramSender.GetChatLog_bot().Send($"#گزارش_تشخیص_بلاکی_در_شیپور \r\n" + $" سیمکارت {number} " + $"\r\n به مالکیت {sim.Owner}" + $" \r\n در تاریخ {Calendar.MiladiToShamsi(DateTime.Now)} " + $"\r\n و ساعت {DateTime.Now.ToLongTimeString()} " + $"\r\n از سوی ربات، بلاک شده تشخیص داده شد"); } catch (WebDriverException) { } catch (Exception ex) { WebErrorLog.ErrorInstence.StartErrorLog(ex); } }
public static async Task ManageAdvSend(SettingBussines clsSetting) { try { var tokenSource = new CancellationTokenSource(); SimcardBussines firstSimCardBusiness = null; var list = await SimcardBussines.GetAllAsync(); list = list.OrderBy(q => q.NextUse).Where(q => q.Status).ToList(); foreach (var simCard in list) { while (!await Utility.PingHost("www.google.com")) { //خطا در برقراری اتصال به اینترنت await Utility.Wait(10); lstMessage.Clear(); lstMessage.Add("خطا در برقراری اتصال به اینترنت"); Utility.ShowBalloon("لطفا شبکه خود را چک نمایید", lstMessage); } if (simCard.isSendPostToTelegram) { var city = DivarCityBussines.GetAsync(simCard.CityForGetPost ?? Guid.Empty)?.Name ?? "مشهد"; var cat1 = AdvCategoryBussines.Get(simCard.DivarPostCat1 ?? Guid.Empty)?.Name ?? "خدمات"; var cat2 = AdvCategoryBussines.Get(simCard.DivarPostCat2 ?? Guid.Empty)?.Name ?? "آرایشگری و زیبایی"; var cat3 = AdvCategoryBussines.Get(simCard.DivarPostCat3 ?? Guid.Empty)?.Name ?? ""; var chatID = simCard.ChannelForSendPost ?? "@Test2_2211201"; var divar = await DivarAdv.GetInstance(); await divar.GetPost(simCard.Number, cat1, cat2, cat3 , city, simCard.PostCount ?? 5, chatID, simCard.DescriptionForPost ?? "", simCard.SMS_Description); } if (simCard.IsSendAdv) { try { //کنترل شماره خروجی if (simCard.Number == 0) { lstMessage.Clear(); lstMessage.Add("پر شدن تعداد آگهی در IP"); Utility.ShowBalloon("پر شدن تعداد آگهی در " + await Utility.FindGateWay(), lstMessage); continue; } //کنترل تعداد آگهی ارسال شده در هر IP while (clsSetting?.CountAdvInIP <= AdvertiseLogBussines.GetAllAdvInDayFromIP(await Utility.GetLocalIpAddress())) { await Utility.Wait(20); lstMessage.Clear(); lstMessage.Add("پر شدن تعداد آگهی"); Utility.ShowBalloon("پر شدن تعداد آگهی در " + await Utility.FindGateWay(), lstMessage); await SendChat(clsSetting, simCard); } firstSimCardBusiness = await SimcardBussines.GetAsync(simCard.Number); if (firstSimCardBusiness is null) { continue; } var lastUse = firstSimCardBusiness.NextUse; var startDayOfCurrentMonthOfDateShToMiladi = DateConvertor.StartDayOfPersianMonth(); var startDayOfNextMonthOfDateShToMiladi = DateConvertor.EndDayOfPersianMonth().AddDays(1); //آمار آگهی های ثبت شده برای سیم کارت در ماه جاری var a1 = await AdvertiseLogBussines.GetAllAsync(); a1 = a1.Where(p => p.SimCardNumber == simCard.Number && (p.StatusCode == StatusCode .Published || p.StatusCode == StatusCode .InPublishQueue || p.StatusCode == StatusCode .WaitForPayment) && p.DateM >= startDayOfCurrentMonthOfDateShToMiladi).ToList(); var registeredAdvCount = a1.Count; if (registeredAdvCount >= clsSetting?.CountAdvInMounth) { //تاریخ روز اول ماه شمسی بعد را تنظیم می کند چون تا سر ماه بعد دیگر نیازی به این سیم کارت نیست firstSimCardBusiness.NextUse = startDayOfNextMonthOfDateShToMiladi; await firstSimCardBusiness.SaveAsync(); lstMessage.Clear(); lstMessage.Add( $"سیمکارت {simCard.Number} به دلیل پر بودن آگهی ها در ماه موفق به ارسال آگهی نشد"); Utility.ShowBalloon("عدم ارسال آگهی", lstMessage); await SendChat(clsSetting, simCard); continue; } //آمار آگهی های ثبت شده امروز var currentDate = DateTime.Now.Date; var a2 = await AdvertiseLogBussines.GetAllAsync(); a2 = a2.Where(p => p.SimCardNumber == simCard.Number && (p.StatusCode == StatusCode.Published || p.StatusCode == StatusCode.InPublishQueue || p.StatusCode == StatusCode.WaitForPayment) && p.DateM >= currentDate).ToList(); registeredAdvCount = a2.Count; if (registeredAdvCount >= clsSetting?.CountAdvInDay) { //تاریخ فردا رو ست می کند چون تا فردا دیگه نیازی به این سیم کارت نیست firstSimCardBusiness.NextUse = DateTime.Today.AddDays(1); await firstSimCardBusiness.SaveAsync(); lstMessage.Clear(); lstMessage.Add( $"سیمکارت {simCard.Number} به دلیل پرپودن آگهی ها در روز موفق به ارسال آگهی نشد"); Utility.ShowBalloon("عدم ارسال آگهی", lstMessage); await SendChat(clsSetting, simCard); continue; } var divar = await DivarAdv.GetInstance(); await divar.StartRegisterAdv(simCard); simCard.NextUse = DateTime.Now.AddMinutes(30); await simCard.SaveAsync(); await Wait(2); } catch (Exception e) { } } if (simCard.IsSendAdvSheypoor) { //کنترل شماره خروجی if (simCard.Number == 0) { lstMessage.Clear(); lstMessage.Add("پر شدن تعداد آگهی در IP"); Utility.ShowBalloon("پر شدن تعداد آگهی در " + await Utility.FindGateWay(), lstMessage); continue; } //کنترل تعداد آگهی ارسال شده در هر IP while (clsSetting?.CountAdvInIP <= AdvertiseLogBussines.GetAllAdvInDayFromIP(await Utility.GetLocalIpAddress())) { await Utility.Wait(20); lstMessage.Clear(); lstMessage.Add("پر شدن تعداد آگهی"); Utility.ShowBalloon("پر شدن تعداد آگهی در " + await Utility.FindGateWay(), lstMessage); await SendChat(clsSetting, simCard); } firstSimCardBusiness = await SimcardBussines.GetAsync(simCard.Number); if (firstSimCardBusiness is null) { continue; } var lastUse = firstSimCardBusiness.NextUse; var card1 = simCard.Number; var startDayOfCurrentMonthOfDateShToMiladi = DateConvertor.StartDayOfPersianMonth(); var startDayOfNextMonthOfDateShToMiladi = DateConvertor.EndDayOfPersianMonth().AddDays(1); //آمار آگهی های ثبت شده برای سیم کارت در ماه جاری var a1 = await AdvertiseLogBussines.GetAllAsync(); a1 = a1.Where(p => p.SimCardNumber == card1 && (p.StatusCode == StatusCode .Published || p.StatusCode == StatusCode .InPublishQueue || p.StatusCode == StatusCode .WaitForPayment) && p.DateM >= startDayOfCurrentMonthOfDateShToMiladi).ToList(); var registeredAdvCount = a1.Count; if (registeredAdvCount >= clsSetting?.CountAdvInMounth) { //تاریخ روز اول ماه شمسی بعد را تنظیم می کند چون تا سر ماه بعد دیگر نیازی به این سیم کارت نیست firstSimCardBusiness.NextUse = startDayOfNextMonthOfDateShToMiladi; await firstSimCardBusiness.SaveAsync(); lstMessage.Clear(); lstMessage.Add( $"سیمکارت {simCard.Number} به دلیل پر بودن آگهی ها در ماه موفق به ارسال آگهی نشد"); Utility.ShowBalloon("عدم ارسال آگهی", lstMessage); await SendChat(clsSetting, simCard); continue; } //آمار آگهی های ثبت شده امروز var currentDate = DateTime.Now.Date; var a2 = await AdvertiseLogBussines.GetAllAsync(); a2 = a2.Where(p => p.SimCardNumber == card1 && (p.StatusCode == StatusCode.Published || p.StatusCode == StatusCode.InPublishQueue || p.StatusCode == StatusCode.WaitForPayment) && p.DateM >= currentDate).ToList(); registeredAdvCount = a2.Count; if (registeredAdvCount >= clsSetting?.CountAdvInDay) { //تاریخ فردا رو ست می کند چون تا فردا دیگه نیازی به این سیم کارت نیست firstSimCardBusiness.NextUse = DateTime.Today.AddDays(1); await firstSimCardBusiness.SaveAsync(); lstMessage.Clear(); lstMessage.Add( $"سیمکارت {simCard.Number} به دلیل پرپودن آگهی ها در روز موفق به ارسال آگهی نشد"); Utility.ShowBalloon("عدم ارسال آگهی", lstMessage); await SendChat(clsSetting, simCard); continue; } var shey = await SheypoorAdv.GetInstance(); await shey.StartRegisterAdv(simCard); simCard.NextUse = DateTime.Now.AddMinutes(30); await simCard.SaveAsync(); await Wait(2); } if (simCard.IsSendChat) { await SendChat(clsSetting, simCard); } CloseAllChromeWindows(); simCard.NextUse = DateTime.Now.AddHours(1); await simCard.SaveAsync(); } await Utility.Wait(10); lstMessage.Clear(); lstMessage.Add("لیست کاملا پیمایش شد"); Utility.ShowBalloon("اتمام یک دور کامل از پیمایش سیمکارت ها", lstMessage); await UpdateAdvStatus(clsSetting?.DayCountForUpdateState ?? 10); CloseAllChromeWindows(); } catch (Exception ex) { WebErrorLog.ErrorInstence.StartErrorLog(ex); } }
public async Task <bool> Login(long simCardNumber) { try { _driver = Utility.RefreshDriver(_driver); if (!_driver.Url.Contains("divar.ir")) { _driver.Navigate().GoToUrl("https://divar.ir"); } var simBusiness = await SimcardBussines.GetAsync(simCardNumber); var tokenInDatabase = simBusiness?.DivarToken ?? null; var listLinkItems = _driver.FindElements(By.TagName("a")); var isLogined = listLinkItems.Any(linkItem => linkItem.Text == @"خروج"); //اگر کاربر لاگین شده فعلی همان کاربر مورد نظر است نیازی به لاگین نیست if (isLogined && !string.IsNullOrEmpty(tokenInDatabase)) { var currentTokenOnDivar = _driver.Manage().Cookies.GetCookieNamed("token").Value; if (!string.IsNullOrEmpty(currentTokenOnDivar) && currentTokenOnDivar == tokenInDatabase) { return(true); } } //اگر کاربرلاگین شده کاربر مد نظر ما نیست از آن کاربری خارج می شود if (isLogined) { _driver.Manage().Cookies.DeleteCookieNamed("_gat"); _driver.Manage().Cookies.DeleteCookieNamed("token"); } //در صورتیکه توکن قبلا ثبت شده باشد لاگین می کند if (!string.IsNullOrEmpty(tokenInDatabase)) { var token = new Cookie("token", tokenInDatabase); _driver.Manage().Cookies.AddCookie(token); _driver.Navigate().Refresh(); } //اگر قبلا توکن نداشته وارد صفحه دریافت کد تائید لاگین می شود else { _driver.Navigate().GoToUrl("https://divar.ir/my-divar/my-posts"); //کلیک روی دکمه ورود و ثبت نام await Utility.Wait(); _driver.FindElement(By.ClassName("login-message__login-btn")).Click(); await Utility.Wait(); var currentWindow = _driver.CurrentWindowHandle; _driver.SwitchTo().Window(currentWindow); if (_driver.FindElements(By.Name("mobile")).Count > 0) { _driver.FindElement(By.Name("mobile")).SendKeys("0" + simCardNumber); } } //انتظار برای لاگین شدن int repeat = 0; //حدود 120 ثانیه فرصت لاگین دارد while (repeat < 20) { //تا زمانی که لاگین اوکی نشده باشد این حلقه تکرار می شود listLinkItems = _driver.FindElements(By.TagName("a")); if (listLinkItems.Count < 5) { return(false); } var isLogin = listLinkItems.Any(linkItem => linkItem.Text == @"خروج"); if (isLogin) { //var all = _driver.Manage().Cookies.AllCookies.ToList(); tokenInDatabase = _driver.Manage().Cookies.GetCookieNamed("token").Value; if (simBusiness is null) { simBusiness = new SimcardBussines() { Guid = Guid.NewGuid() } } ; simBusiness.DivarToken = tokenInDatabase; simBusiness.Modified = DateTime.Now; simBusiness.Number = simCardNumber; await simBusiness.SaveAsync(); ((IJavaScriptExecutor)_driver).ExecuteScript(@"alert('لاگین انجام شد');"); await Utility.Wait(); _driver.SwitchTo().Alert().Accept(); return(true); } var name = await SimcardBussines.GetAsync(simCardNumber); var message = $@"مالک: {name.OwnerName} \r\nشماره: {name.Number} \r\nلطفا لاگین نمائید "; ((IJavaScriptExecutor)_driver).ExecuteScript($"alert('{message}');"); await Utility.Wait(3); try { _driver.SwitchTo().Alert().Accept(); await Utility.Wait(3); repeat++; } catch { await Utility.Wait(10); } } return(false); } catch (WebException) { return(false); } catch (Exception ex) { if (ex.Source != "WebDriver") { WebErrorLog.ErrorInstence.StartErrorLog(ex); } return(false); } }