public HttpResponseMessage UpdateAccount() { var body = Request.Content.ReadAsStringAsync().Result; UpdateAccountModel account = JsonConvert.DeserializeObject<UpdateAccountModel>(Encrypt.DecryptRJ256(body, Config.AESKey, Config.IV)); // TODO : à modifier // Ajoutez ici votre logique de verification des donnees en base à partir de l'objet UpdateAccountModel // Exemple de composition du modele à partir des donnees en base ValidationResponseModel model = new ValidationResponseModel { IsValid = true, CodeUtilisateur = account.CodeUtilisateur, PartenaireID = Config.PartID }; string json = Encrypt.EncryptRJ256(JsonConvert.SerializeObject(model), Config.AESKey, Config.IV); string timeStampHeader = Timestamp.UnixTimestamp().ToString(); string concat = string.Concat(Config.PartID.ToString(), "+", timeStampHeader, "+", Config.CodeSecret); HttpContext.Current.Response.AddHeader("X-TS", timeStampHeader); HttpContext.Current.Response.AddHeader("X-PART", Config.PartID.ToString()); HttpContext.Current.Response.AddHeader("X-LPL", Hash.SHA1Hash(Encoding.UTF8.GetBytes(concat))); var resp = new HttpResponseMessage(HttpStatusCode.OK) { Content = new StringContent(json, Encoding.UTF8, "text/plain") }; return resp; }
public HttpResponseMessage CreateAccountService() { var body = Request.Content.ReadAsStringAsync().Result; CreationCompteModel compte = JsonConvert.DeserializeObject<CreationCompteModel>(Encrypt.DecryptRJ256(body, Config.AESKey, Config.IV)); ValidationResponseModel model = new ValidationResponseModel { PartenaireID = Config.PartID }; if (Request.Headers.Contains("X-CTX")) { // Ne pas modifier model.CreateDummyModel(); } else { // TODO : à modifier // Ajoutez ici votre logique de verification des donnees en base a partir de l'objet CreationCompteModel // Exemple de composition du modele a partir des donnees en base model.IsValid = true; model.PartenaireID = Config.PartID; model.CodeUtilisateur = compte.CodeUtilisateur; model.CodeEtat = Etat.Success; } string json = Encrypt.EncryptRJ256(JsonConvert.SerializeObject(model), Config.AESKey, Config.IV); string timeStampHeader = Timestamp.UnixTimestamp().ToString(); string concat = string.Concat(Config.PartID.ToString(), "+", timeStampHeader, "+", Config.CodeSecret); HttpContext.Current.Response.AddHeader("X-TS", timeStampHeader); HttpContext.Current.Response.AddHeader("X-PART", Config.PartID.ToString()); HttpContext.Current.Response.AddHeader("X-LPL", Hash.SHA1Hash(Encoding.UTF8.GetBytes(concat))); var resp = new HttpResponseMessage(HttpStatusCode.OK) { Content = new StringContent(json, Encoding.UTF8, "text/plain") }; return resp; }