This commit is contained in:
@@ -50,33 +50,18 @@ namespace Sockeye.Api.Controllers
|
||||
return BadRequest(ModelState);
|
||||
}
|
||||
try
|
||||
{
|
||||
//do stuff with the notification
|
||||
(string username, string password) = Sockeye.Util.AutoOrderProcessingUtil.GetUsernameAndPasswordFromAuthorizeHeader(Authorization);
|
||||
// Now use username and password with whatever authentication process you want
|
||||
{
|
||||
(string username, string password) = Sockeye.Util.AutoOrderProcessingUtil.GetUsernameAndPasswordFromAuthorizeHeader(Authorization);
|
||||
if (username == "Y24PYYDQSA1L12905N5MKU" && password == "MA8GMQK2PC3FDNT1RTR68R")
|
||||
{
|
||||
//put the jobject notification into the db as json string freeform notification information
|
||||
//to be processed by other code later. i.e. just capture it as is cleanly and don't bother trying to do anything fancy here this should be tight and focused and side effect free
|
||||
|
||||
|
||||
//although...on second thought it could just make a purchase record with some sort of state of unprocessed so a job could swing by and process it or we could
|
||||
//do that manually so then there would be no need for extra UI and stuff, and it wont' conflict with the need to process immediately and lightly here
|
||||
//i.e. two stage: one is to make the record barebones for purchase then a job comes along and turns it into a real purchase
|
||||
//also add error handling here iwth proper notification see trial request code so we get notified on error
|
||||
//and don't return OK / 200 unless the order is stored successfully in db as shareit will retry until it's successful several times, see the link below for deets
|
||||
//Need to be able to make a manual purchase record with almost nothing more than the vendor notifciation text so can recover if auto system fails and for testing
|
||||
|
||||
{
|
||||
//save it to the database
|
||||
var Purchase = new Purchase();
|
||||
Purchase.PurchaseDate = DateTime.UtcNow;//this is kind of fucky, what if the order takes more than a day to arrive? I guess fixup from the vendordata later
|
||||
Purchase.VendorId = 1;//MyCommerce/shareit is vendor 1, for now that's all that's needed
|
||||
Purchase.VendorData = j.ToString();
|
||||
await ct.Purchase.AddAsync(Purchase);
|
||||
var vn = new VendorNotification();
|
||||
vn.Created = DateTime.UtcNow;
|
||||
vn.VendorId = 1;//MyCommerce/shareit is vendor 1, for now that's all that's needed
|
||||
vn.VendorData = j.ToString();
|
||||
await ct.VendorNotification.AddAsync(vn);
|
||||
await ct.SaveChangesAsync();
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
@@ -84,7 +69,7 @@ namespace Sockeye.Api.Controllers
|
||||
await NotifyEventHelper.AddOpsProblemEvent("OrderController/shareit - Exception processing vendor notification, see log");
|
||||
return StatusCode(503);//ask it to retry again later
|
||||
}
|
||||
return Ok("ok");//shareit robot looks for an OK response to know if it should resend or not https://account.mycommerce.com/home/wiki/7479805
|
||||
return Ok("ok");//shareit notifier looks for an OK response to know if it should resend or not https://account.mycommerce.com/home/wiki/7479805
|
||||
}
|
||||
//------------
|
||||
|
||||
|
||||
Reference in New Issue
Block a user