public async Task ApplyConfiguration(JToken configJson) { cookies = new CookieContainer(); client = new HttpClient(handler); var configSaveData = new JObject(); if (OnSaveConfigurationRequested != null) OnSaveConfigurationRequested(this, configSaveData); var config = new ConfigurationDataBasicLogin(); config.LoadValuesFromJson(configJson); var pairs = new Dictionary<string, string> { { "username", config.Username.Value }, { "password", @config.Password.Value }, { "login", "Login" }, { "keeplogged", "1" } }; var content = new FormUrlEncodedContent(pairs); var message = CreateHttpRequest(new Uri(LoginUrl)); message.Content = content; //message.Headers.Referrer = new Uri(LoginUrl); string responseContent; JArray cookieJArray; if (Program.IsWindows) { // If Windows use .net http var response = await client.SendAsync(message); responseContent = await response.Content.ReadAsStringAsync(); cookieJArray = cookies.ToJson(SiteLink); } else { // If UNIX system use curl, probably broken due to missing chromeUseragent record for CURL...cannot test var response = await CurlHelper.PostAsync(LoginUrl, pairs); responseContent = Encoding.UTF8.GetString(response.Content); cookieHeader = response.CookieHeader; cookieJArray = new JArray(response.CookiesFlat); } if (!responseContent.Contains("logout.php?")) { CQ dom = responseContent; dom["#loginform > table"].Remove(); var errorMessage = dom["#loginform"].Text().Trim().Replace("\n\t", " "); throw new ExceptionWithConfigData(errorMessage, (ConfigurationData)config); } else { configSaveData = new JObject(); configSaveData["cookies"] = cookieJArray; if (OnSaveConfigurationRequested != null) OnSaveConfigurationRequested(this, configSaveData); IsConfigured = true; } }