/// <summary> /// Saves a category assignment /// </summary> /// <param name="request"></param> /// <param name="tableName"></param> /// <param name="context"></param> /// <param name="trackingGuid"></param> /// <returns></returns> public async Task <Tagge.Common.Models.ProductCategoryResponse> Save(IBaseContextModel context, Tagge.Common.Models.ProductCategoryRequest request, string tableName, Guid trackingGuid) { var response = new Tagge.Common.Models.ProductCategoryResponse(); // Company Id var companyId = context.Security.GetCompanyId(); try { // MongoDB Settings var database = context.MongoDbSettings.Value.Databases.FirstOrDefault(x => x.Name == "DeathStar"); string productCollectionName = database.Collections.FirstOrDefault(x => x.Name == "PC_Product").Name; string variantCollectionName = database.Collections.FirstOrDefault(x => x.Name == "PC_ProductVariant").Name; // Get MongoDB var db = context.Database; // Word var dbCategory = new Deathstar.Data.Models.PC_Category(); // Id prefix string idPrefix = string.Empty; // Validate Category ////Circular Reference string dbCategoryName = await CategoryModel.Validate(request.CategoryId, context, trackingGuid);// _new CategoryModel(context).Validate(request.CategoryId, trackingGuid); // Product Category var dbProductCategory = new Deathstar.Data.Models.PC_ProductCategory(); // Convert To Database Object dbProductCategory.ConvertToDatabaseObject(dbCategoryName, request); // Set Primary Key dbProductCategory.SetPrimaryKey(request.InternalId.ToString(), request.CategoryId.ToString()); // Set Is Active to true dbProductCategory.IsActive = true; switch (tableName) { case "PC_Product": var productCollection = db.GetCollection <Deathstar.Data.Models.PC_Product>(productCollectionName); // Product var dbProduct = new Deathstar.Data.Models.PC_Product(); // Filters - note always start with the company id var filters = Builders <Deathstar.Data.Models.PC_Product> .Filter.Eq(x => x.DV_CompanyId, companyId.ToString()); filters = filters & Builders <Deathstar.Data.Models.PC_Product> .Filter.Eq(x => x.Id, request.InternalId); filters = filters & Builders <Deathstar.Data.Models.PC_Product> .Filter.Eq(x => x.IsActive, true); // Find the product dbProduct = await productCollection.Find(filters).FirstOrDefaultAsync(); // The product was not valid if (dbProduct == null) { var message = $"Product Id not valid: {request.InternalId}"; throw new HttpResponseException() { StatusCode = Microsoft.AspNetCore.Http.StatusCodes.Status400BadRequest, ReasonPhrase = message }; } if (dbProduct.Categories != null && dbProduct.Categories.Count > 0) { var dbtempCategory = dbProduct.Categories.FirstOrDefault(x => x.PC_ProductCategory_Id == dbProductCategory.PC_ProductCategory_Id && x.CategoryId == request.CategoryId); if (dbtempCategory == null) { // Add the Category Assignment dbProduct.Categories.Add(dbProductCategory); } else { // Update the Category Assignment dbProductCategory = dbtempCategory; dbProductCategory.IsActive = true; } } else { // Add the Category Assignment dbProduct.Categories.Add(dbProductCategory); } // Set Product Id to 0 cause of the serializer var productId = dbProduct.Id; dbProduct.Id = 0; var serializerSettings = new JsonSerializerSettings() { NullValueHandling = NullValueHandling.Ignore, DefaultValueHandling = DefaultValueHandling.Ignore }; var update = new BsonDocument() { { "$set", BsonDocument.Parse(JsonConvert.SerializeObject(dbProduct, serializerSettings)) } }; // Update database record await productCollection.UpdateOneAsync(filters, update); response = new Common.Models.ProductCategoryResponse() { Id = dbProductCategory.PC_ProductCategory_Id, ProductId = productId, CategoryId = request.CategoryId, Type = "Product" }; // Build the Webhook event var whProductRequest = new Sheev.Common.Models.WebhookResponse() { CompanyId = companyId.ToString(), Type = "Product Category Assignment", Scope = $"product/category/created", Id = response.Id, TrackingGuid = trackingGuid }; // Trigger the Webhook event await _webHookModel.FireWebhookEvent(whProductRequest, context, trackingGuid); break; case "PC_ProductVariant": var variantCollection = db.GetCollection <Deathstar.Data.Models.PC_ProductVariant>(variantCollectionName); // Variant var dbVariant = new Deathstar.Data.Models.PC_ProductVariant(); var variantFilter = Builders <Deathstar.Data.Models.PC_ProductVariant> .Filter.Eq(x => x.Id, request.InternalId); variantFilter = variantFilter & Builders <Deathstar.Data.Models.PC_ProductVariant> .Filter.Eq(x => x.IsActive, true); variantFilter = variantFilter & Builders <Deathstar.Data.Models.PC_ProductVariant> .Filter.Eq(x => x.DV_CompanyId, companyId.ToString()); dbVariant = await variantCollection.Find(variantFilter).FirstOrDefaultAsync(); if (dbVariant == null) { var message = $"Product Variant Id not valid: {request.InternalId}"; throw new HttpResponseException() { StatusCode = Microsoft.AspNetCore.Http.StatusCodes.Status400BadRequest, ReasonPhrase = message }; } if (dbVariant.Categories != null && dbVariant.Categories.Count > 0) { var dbtempCategory = dbVariant.Categories.FirstOrDefault(x => x.PC_ProductCategory_Id == dbProductCategory.PC_ProductCategory_Id && x.CategoryId == request.CategoryId && x.IsActive); if (dbtempCategory == null) { // Add the Category Assignment dbVariant.Categories.Add(dbProductCategory); } else { // Update the Category Assignment dbProductCategory = dbtempCategory; dbProductCategory.IsActive = true; } } else { // Add the Category Assignment dbVariant.Categories.Add(dbProductCategory); } // Set Product Id to 0 cause of the serializer var variantId = dbVariant.Id; dbVariant.Id = 0; var variantSerializerSettings = new JsonSerializerSettings() { NullValueHandling = NullValueHandling.Ignore, DefaultValueHandling = DefaultValueHandling.Ignore }; var variantUpdate = new BsonDocument() { { "$set", BsonDocument.Parse(JsonConvert.SerializeObject(dbVariant, variantSerializerSettings)) } }; // Update database record await variantCollection.UpdateOneAsync(variantFilter, variantUpdate); response = new Common.Models.ProductCategoryResponse() { Id = dbProductCategory.PC_ProductCategory_Id, ProductId = variantId, CategoryId = request.CategoryId, Type = "Variant" }; // Build the Webhook event var whVariantRequest = new Sheev.Common.Models.WebhookResponse() { CompanyId = companyId.ToString(), Type = "Product Category Assignment", Scope = $"product/variant/category/created", Id = response.Id, TrackingGuid = trackingGuid }; // Trigger the Webhook event await _webHookModel.FireWebhookEvent(whVariantRequest, context, trackingGuid); break; default: throw new HttpResponseException() { StatusCode = Microsoft.AspNetCore.Http.StatusCodes.Status400BadRequest, ReasonPhrase = $"Invalid Type: {tableName}. Please specify a correct type: Product or Variant" }; } return(response); } catch (HttpResponseException webEx) { IG2000.Data.Utilities.Logging.LogTrackingEvent($"Inventory failed to save! Reason: {webEx.ReasonPhrase}", $"Status Code: {webEx.StatusCode}", LT319.Common.Utilities.Constants.TrackingStatus.Error, context, trackingGuid); throw; } catch (Exception ex) { IG2000.Data.Utilities.Logging.LogTrackingEvent($"See logs for additional details", "Failed", LT319.Common.Utilities.Constants.TrackingStatus.Error, context, trackingGuid); IG2000.Data.Utilities.ErrorLogger.Report(ex.Message, "InventoryModel.Save()", context, trackingGuid, System.Diagnostics.EventLogEntryType.Error); throw new HttpResponseException() { StatusCode = Microsoft.AspNetCore.Http.StatusCodes.Status500InternalServerError, ReasonPhrase = ex.Message }; } }
public void ConvertToDatabaseObject(string categoryName, Tagge.Common.Models.ProductCategoryRequest request) { // Properties CategoryId = Convert.ToInt64(request.CategoryId); CategoryName = categoryName; }