/// <summary> /// Updates one or more properties of a product associated with a specific catalog. /// </summary> /// <param name="catalogId">The unique identifier of the catalog of products used by a site.</param> /// <param name="productCode">Merchant-created code that uniquely identifies the product such as a SKU or item number. Once created, the product code is read-only.</param> /// <param name="responseFields">Use this field to include those fields which are not included by default.</param> /// <param name="productInCatalogInfoIn">Properties of a product associated with a specific catalog.</param> /// <returns> /// <see cref="Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo"/> /// </returns> /// <example> /// <code> /// var product = new Product(); /// var productInCatalogInfo = await product.UpdateProductInCatalogAsync(_dataViewMode, productInCatalogInfoIn, productCode, catalogId, responseFields); /// </code> /// </example> public virtual async Task <Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo> UpdateProductInCatalogAsync(Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo productInCatalogInfoIn, string productCode, int catalogId, string responseFields = null) { MozuClient <Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo> response; var client = Mozu.Api.Clients.Commerce.Catalog.Admin.ProductClient.UpdateProductInCatalogClient(_dataViewMode, productInCatalogInfoIn, productCode, catalogId, responseFields); client.WithContext(_apiContext); response = await client.ExecuteAsync(); return(await response.ResultAsync()); }
public virtual Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo AddProductInCatalog(Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo productInCatalogInfoIn, string productCode, string responseFields = null) { MozuClient <Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo> response; var client = Mozu.Api.Clients.Commerce.Catalog.Admin.ProductClient.AddProductInCatalogClient(_dataViewMode, productInCatalogInfoIn, productCode, responseFields); client.WithContext(_apiContext); response = client.Execute(); return(response.Result()); }
/// <summary> /// Updates one or more properties of a product associated with a specific catalog. /// </summary> /// <param name="catalogId">The unique identifier of the catalog of products used by a site.</param> /// <param name="productCode">Merchant-created code that uniquely identifies the product such as a SKU or item number. Once created, the product code is read-only.</param> /// <param name="responseFields">Use this field to include those fields which are not included by default.</param> /// <param name="productInCatalogInfoIn">Properties of a product associated with a specific catalog.</param> /// <returns> /// <see cref="Mozu.Api.MozuClient" />{<see cref="Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo"/>} /// </returns> /// <example> /// <code> /// var mozuClient=UpdateProductInCatalog(dataViewMode, productInCatalogInfoIn, productCode, catalogId, responseFields); /// var productInCatalogInfoClient = mozuClient.WithBaseAddress(url).Execute().Result(); /// </code> /// </example> public static MozuClient <Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo> UpdateProductInCatalogClient(DataViewMode dataViewMode, Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo productInCatalogInfoIn, string productCode, int catalogId, string responseFields = null) { var url = Mozu.Api.Urls.Commerce.Catalog.Admin.ProductUrl.UpdateProductInCatalogUrl(productCode, catalogId, responseFields); const string verb = "PUT"; var mozuClient = new MozuClient <Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo>() .WithVerb(verb).WithResourceUrl(url) .WithBody <Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo>(productInCatalogInfoIn).WithHeader(Headers.X_VOL_DATAVIEW_MODE, dataViewMode.ToString()) ; return(mozuClient); }
/// <summary> /// Updates one or more properties of a product associated with a specific catalog. /// <example> /// <code> /// var result = ProductFactory.UpdateProductInCatalog(handler : handler, productInCatalogInfoIn : productInCatalogInfoIn, productCode : productCode, catalogId : catalogId, responseFields : responseFields, dataViewMode: dataViewMode, expectedCode: expectedCode, successCode: successCode); /// var optionalCasting = ConvertClass<ProductInCatalogInfo/>(result); /// return optionalCasting; /// </code> /// </example> /// </summary> public static Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo UpdateProductInCatalog(ServiceClientMessageHandler handler, Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo productInCatalogInfoIn, string productCode, int catalogId, string responseFields = null, DataViewMode dataViewMode = DataViewMode.Live, HttpStatusCode expectedCode = HttpStatusCode.OK, HttpStatusCode successCode = HttpStatusCode.OK) { SetSdKparameters(); var currentClassName = System.Reflection.MethodInfo.GetCurrentMethod().DeclaringType.Name; var currentMethodName = System.Reflection.MethodBase.GetCurrentMethod().Name; Debug.WriteLine(currentMethodName + '.' + currentMethodName); var apiClient = Mozu.Api.Clients.Commerce.Catalog.Admin.ProductClient.UpdateProductInCatalogClient( productInCatalogInfoIn: productInCatalogInfoIn, productCode: productCode, catalogId: catalogId, responseFields: responseFields, dataViewMode: dataViewMode); try { apiClient.WithContext(handler.ApiContext).Execute(); } catch (ApiException ex) { // Custom error handling for test cases can be placed here Exception customException = TestFailException.GetCustomTestException(ex, currentClassName, currentMethodName, expectedCode); if (customException != null) { throw customException; } return(null); } return(ResponseMessageFactory.CheckResponseCodes(apiClient.HttpResponse.StatusCode, expectedCode, successCode) ? (apiClient.Result()) : null); }
/// <summary> /// /// </summary> /// <param name="productCode">The unique, user-defined product code of a product, used throughout to reference and associate to a product.</param> /// <param name="responseFields">Filtering syntax appended to an API call to increase or decrease the amount of data returned inside a JSON object. This parameter should only be used to retrieve data. Attempting to update data using this parameter may cause data loss.</param> /// <param name="productInCatalogInfoIn">Properties of a product associated with a specific catalog.</param> /// <returns> /// <see cref="Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo"/> /// </returns> /// <example> /// <code> /// var product = new Product(); /// var productInCatalogInfo = await product.AddProductInCatalogAsync(_dataViewMode, productInCatalogInfoIn, productCode, responseFields); /// </code> /// </example> public virtual async Task <Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo> AddProductInCatalogAsync(Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo productInCatalogInfoIn, string productCode, string responseFields = null, CancellationToken ct = default(CancellationToken)) { MozuClient <Mozu.Api.Contracts.ProductAdmin.ProductInCatalogInfo> response; var client = Mozu.Api.Clients.Commerce.Catalog.Admin.ProductClient.AddProductInCatalogClient(_dataViewMode, productInCatalogInfoIn, productCode, responseFields); client.WithContext(_apiContext); response = await client.ExecuteAsync(ct).ConfigureAwait(false); return(await response.ResultAsync()); }