private async void btnFinish_Click(object sender, EventArgs e) { try { if (cls.Guid == Guid.Empty) { cls.Guid = Guid.NewGuid(); } if (string.IsNullOrEmpty(txtName.Text)) { frmNotification.PublicInfo.ShowMessage("مالک نمی تواند خالی باشد"); txtName.Focus(); return; } if (string.IsNullOrEmpty(txtNumber.Text)) { frmNotification.PublicInfo.ShowMessage("شماره نمی تواند خالی باشد"); txtNumber.Focus(); return; } if (!await SimcardBussines.CheckNumber(cls.Guid, txtNumber.Text.ParseToLong())) { frmNotification.PublicInfo.ShowMessage("شماره وارد شده تکراری است"); txtName.Focus(); return; } cls.OwnerName = txtName.Text.Trim(); cls.Number = txtNumber.Text.ParseToLong(); cls.AdvCat1 = (Guid?)cmbAdv1.SelectedValue; cls.AdvCat2 = (Guid?)cmbAdv2.SelectedValue; cls.AdvCat3 = (Guid?)cmbAdv3.SelectedValue; cls.ChatCat1 = (Guid?)cmbChat1.SelectedValue; cls.ChatCat2 = (Guid?)cmbChat2.SelectedValue; cls.ChatCat3 = (Guid?)cmbChat3.SelectedValue; var res = await cls.SaveAsync(); if (res.HasError) { frmNotification.PublicInfo.ShowMessage(res.ErrorMessage); return; } DialogResult = DialogResult.OK; frmLoading.PublicInfo.ShowForm(); Close(); } catch (Exception exception) { WebErrorLog.ErrorInstence.StartErrorLog(exception); } }
private async void btnInsSim_Click(object sender, EventArgs e) { var a = new SimcardBussines { Guid = Guid.NewGuid(), OwnerName = txtOwner.Text, DateSabt = DateConvertor.M2SH(DateTime.Now), Status = true, Number = long.Parse(txtNumber.Text), //NextUseDivar = DateTime.Now, //NextUseSheypoor = DateTime.Now, //NextUseDivarChat = DateTime.Now, Operator = txtOperator.Text, UserName = txtUserName.Text }; await a.SaveAsync(); }
private async void btnFinish_Click(object sender, EventArgs e) { var res = new ReturnedSaveFuncInfo(); try { if (cls.Guid == Guid.Empty) { cls.Guid = Guid.NewGuid(); } cls.Owner = txtOwner.Text.Trim(); cls.Number = txtNumber.Text.FixString().Trim().ParseToLong(); cls.Operator = cmbOperator.Text; res.AddReturnedValue(await cls.SaveAsync()); } catch (Exception ex) { WebErrorLog.ErrorInstence.StartErrorLog(ex); res.AddReturnedValue(ex); } finally { if (res.HasError) { var frm = new FrmShowErrorMessage(res, "خطا در ثبت سیمکارت"); frm.ShowDialog(this); frm.Dispose(); } else { DialogResult = DialogResult.OK; Close(); } } }
private static async Task SendChat(SettingBussines clsSetting, SimcardBussines simCard) { try { var passage1 = new List <string>(); if (!string.IsNullOrEmpty(simCard.FirstChatPassage)) { passage1.Add(simCard.FirstChatPassage); } if (!string.IsNullOrEmpty(simCard.FirstChatPassage2)) { passage1.Add(simCard.FirstChatPassage2); } if (!string.IsNullOrEmpty(simCard.FirstChatPassage3)) { passage1.Add(simCard.FirstChatPassage3); } if (!string.IsNullOrEmpty(simCard.FirstChatPassage4)) { passage1.Add(simCard.FirstChatPassage4); } var passage2 = new List <string>(); if (!string.IsNullOrEmpty(simCard.SecondChatPassage)) { passage2.Add(simCard.SecondChatPassage); } if (!string.IsNullOrEmpty(simCard.SecondChatPassage2)) { passage2.Add(simCard.SecondChatPassage2); } if (!string.IsNullOrEmpty(simCard.SecondChatPassage3)) { passage2.Add(simCard.SecondChatPassage3); } if (!string.IsNullOrEmpty(simCard.SecondChatPassage4)) { passage2.Add(simCard.SecondChatPassage4); } var date = DateConvertor.M2SH(DateTime.Now); date = date.Replace("/", "_"); if (simCard.IsSendChat) { var city = DivarCityBussines.GetAsync(simCard.DivarCityForChat); var cat1 = AdvCategoryBussines.Get(simCard.DivarChatCat1)?.Name ?? ""; var cat2 = AdvCategoryBussines.Get(simCard.DivarChatCat2)?.Name ?? ""; var cat3 = AdvCategoryBussines.Get(simCard.DivarChatCat3)?.Name ?? ""; var fileName = $"{cat1}__{cat2}__{cat3}__{date}"; fileName = fileName.Replace(" ", "_"); var ff = Path.Combine(clsSetting.Address, fileName + ".txt"); var divar = await DivarAdv.GetInstance(); await divar.SendChat(passage1, passage2, simCard.ChatCount, city.Name, cat1, cat2, cat3, ff, simCard); } //if (simCard.IsSendChatSheypoor) //{ // var city1 = SheypoorCityBussines.GetAsync(simCard.SheypoorCityForChat); // var cat1 = AdvCategoryBussines.Get(simCard.SheypoorChatCat1)?.Name ?? ""; // var cat2 = AdvCategoryBussines.Get(simCard.SheypoorChatCat2)?.Name ?? ""; // var fileName = $"{cat1}__{cat2}__{date}"; // var ff = Path.Combine(clsSetting.Address, fileName + ".txt"); // var shey = await SheypoorAdv.GetInstance(); // await shey.SendChat(passage1, passage2, simCard.ChatCount, city1.Name, cat1, cat2, null, // ff, simCard); //} simCard.NextUse = DateTime.Now.AddMinutes(30); await simCard.SaveAsync(); } catch (Exception e) { WebErrorLog.ErrorInstence.StartErrorLog(e); } }
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); } }
private async void btnFinish_Click(object sender, EventArgs e) { try { btnFinish.Enabled = false; if (cls.Guid == Guid.Empty) { cls.Guid = Guid.NewGuid(); cls.DateSabt = DateConvertor.M2SH(DateTime.Now); } if (string.IsNullOrWhiteSpace(txtNumber.Text)) { WebErrorLog.ErrorInstence.StartErrorLog("لطفا شماره را وارد نمایید", false); txtNumber.Focus(); return; } if (txtNumber.Text.Length < 10 || txtNumber.Text.Length > 12) { WebErrorLog.ErrorInstence.StartErrorLog("شماره وارد شده اشتباه است", false); txtNumber.Focus(); return; } if (!SimcardBussines.Check_Number(long.Parse(txtNumber.Text), cls.Guid)) { WebErrorLog.ErrorInstence.StartErrorLog("شماره وارد شده تکراری است", false); txtNumber.Focus(); return; } if (string.IsNullOrWhiteSpace(txtOwner.Text)) { WebErrorLog.ErrorInstence.StartErrorLog("لطفا مالک را وارد نمایید", false); txtNumber.Focus(); return; } if (string.IsNullOrWhiteSpace(cmbOperator.Text)) { WebErrorLog.ErrorInstence.StartErrorLog("لطفا اپراتور را وارد نمایید", false); txtNumber.Focus(); return; } if (!chbIsEnableNumber.Checked && !chbIsEnableChat.Checked) { WebErrorLog.ErrorInstence.StartErrorLog( "بنابر قوانین سایت دیوار و شیپور، حداقل یکی از گزینه های نمایش شماره یا ارسال چت باید فعال باشد", false); chbIsEnableNumber.Focus(); return; } var listCity = new List <DivarSimCityBussines>(); for (int i = 0; i < dgCity.RowCount; i++) { if ((bool)dgCity[dg_CityChecked.Index, i].Value) { var a = new DivarSimCityBussines() { Guid = Guid.NewGuid(), DateSabt = DateConvertor.M2SH(DateTime.Now), Status = true, SimcardGuid = cls.Guid, CityGuid = (Guid)dgCity[dg_CityGuid.Index, i].Value }; listCity.Add(a); } } var listCitySh = new List <SheypoorSimCityBussines>(); for (int i = 0; i < dgSheypoorCity.RowCount; i++) { if ((bool)dgSheypoorCity[dg_SheypoorCityChecked.Index, i].Value) { var a = new SheypoorSimCityBussines() { Guid = Guid.NewGuid(), DateSabt = DateConvertor.M2SH(DateTime.Now), Status = true, SimcardGuid = cls.Guid, CityGuid = (Guid)dgSheypoorCity[dg_SheypoorCityGuid.Index, i].Value, StateGuid = (Guid)dgSheypoorCity[dg_StateGuid.Index, i].Value }; listCitySh.Add(a); } } var listAds = new List <SimcardAdsBussines>(); for (int i = 0; i < dgAds.RowCount; i++) { if ((bool)dgAds[dg_AdvChecked.Index, i].Value) { var a = new SimcardAdsBussines() { Guid = Guid.NewGuid(), DateSabt = DateConvertor.M2SH(DateTime.Now), Status = true, SimcardGuid = cls.Guid, Advertise = (Guid)dgAds[dg_AdvGuid.Index, i].Value }; listAds.Add(a); } } cls.OwnerName = txtOwner.Text; cls.Status = true; cls.Number = long.Parse(txtNumber.Text); cls.NextUse = DateTime.Now; cls.Operator = cmbOperator.Text; cls.UserName = txtUserName.Text; cls.DivarPostCat1 = (Guid?)cmbPostCat1.SelectedValue ?? null; cls.DivarPostCat2 = (Guid?)cmbPostCat2.SelectedValue ?? null; cls.DivarPostCat3 = (Guid?)cmbPostCat3.SelectedValue ?? null; cls.IsEnableChat = chbIsEnableChat.Checked; cls.IsEnableNumber = chbIsEnableNumber.Checked; cls.IsSendAdv = chbIsSendAdvDivar.Checked; cls.IsSendAdvSheypoor = chbIsSendAdvSheypoor.Checked; cls.IsSendChat = chbIsSendChatDivar.Checked; cls.IsSendChatSheypoor = chbIsSendChatSheypoor.Checked; cls.ChatCount = int.Parse(txtChatCount.Text); cls.DivarCityForChat = (Guid)cmbDivarCity.SelectedValue; cls.SheypoorCityForChat = (Guid)cmbSheypoorCity.SelectedValue; cls.DivarChatCat1 = (Guid)cmbDivarChat1.SelectedValue; cls.DivarChatCat2 = (Guid)cmbDivarChat2.SelectedValue; cls.DivarChatCat3 = (Guid?)cmbDivarChat3.SelectedValue ?? Guid.Empty; cls.SheypoorChatCat1 = (Guid)cmbSheypoorChat1.SelectedValue; cls.SheypoorChatCat2 = (Guid)cmbSheypoorChat2.SelectedValue; cls.isSendPostToTelegram = chbIsSendPostToTelegram.Checked; cls.ChannelForSendPost = txtChannel.Text; cls.PostCount = txtPostCount.Text?.ParseToInt() ?? null; cls.CityForGetPost = (Guid?)cmbPostCity.SelectedValue ?? null; cls.DescriptionForPost = txtPostDescription.Text; cls.isSendSecondChat = chbIsSendSecondText.Checked; cls.FirstChatPassage = txtFirstChatPassage1.Text; cls.FirstChatPassage2 = txtFirstChatPassage2.Text; cls.FirstChatPassage3 = txtFirstChatPassage3.Text; cls.FirstChatPassage4 = txtFirstChatPassage4.Text; cls.SecondChatPassage = txtSecondChatPassage1.Text; cls.FirstChatPassage2 = txtFirstChatPassage2.Text; cls.FirstChatPassage3 = txtFirstChatPassage3.Text; cls.FirstChatPassage4 = txtFirstChatPassage4.Text; cls.SMS_Description = txtSMS.Text; await cls.SaveAsync(listCity, listAds, listCitySh); DialogResult = DialogResult.OK; Close(); } catch (Exception exception) { WebErrorLog.ErrorInstence.StartErrorLog(exception); } finally { btnFinish.Enabled = true; } }