This action manipulates the HTTP request or response after a Category page loads on the live site.
| Action Type | HTTP | 
|---|---|
| Full Action ID | http.storefront.pages.category.request.after | 
| Runs multiple custom functions? | Yes | 
JavaScript File Structure
Action files share the following basic structure:
module.exports = function(context, callback) {
   // Your custom code here
   callback();
};
When you code the custom function for an action, you have access to two arguments:
callback—This argument follows the established JavaScript callback pattern: it takes an error as the first argument (or null if there is no error) and a result as the second argument (if required).
context—This argument provides the function access to relevant objects and methods that interface with Kibo eCommerce.
Context: HTTP
The methods and objects documented here are available to this action through the use of the context argument.
Storefront Operation
This action occurs during the storefront operation that obtains and renders view and model data from Hypr particular to the requested page.
Context Objects Available to All HTTP Actions
request
Accesses the current HTTP request. In the case of Before actions, updates can be made to the request before Kibo eCommerce processes it.
| Property | Type | Description | 
|---|---|---|
| params | object | The input parameters to the service or webpage. | 
| headers | object | The request headers. | 
| method | string | The request method. | 
| url | string | The request URL. | 
| path | string | The request path. | 
| cookies | object | The request cookies. *Available only for Storefront HTTP actions. | 
| query | object | The request query. | 
| href | string | The request href. | 
| secure | Boolean | Indicates whether the request uses HTTPS. | 
| ip | string | The request IP address. | 
| ips | string | The request secure IP address. | 
| body | object | The request body of the API operation associated with this action. | 
Example:
context.request.url;
response
Accesses the current HTTP response. For both Before and After actions, updates can be made to the response before Kibo eCommerce processes it.
| Property | Type | Description | 
|---|---|---|
| header | object | The response header collection. | 
| viewData | object | The viewData collection used by the storefront rendering engine. *Available only for Storefront HTTP actions. | 
| viewName | string | The response viewName value. *Available only for Storefront HTTP actions. | 
| body | object | The response body of the API operation associated with this action. | 
| status | integer | The response status code. | 
| message | string | The response message. | 
| length | integer | The response length. | 
| type | string | The response type. | 
Example:
context.response.header;
items.siteContext
Accesses the current site context.
| Property | Type | Description | 
|---|---|---|
| tenantId | integer | Unique identifier for the tenant. | 
| siteId | integer | Unique identifier for the site. | 
| hashString | string | A string to append to URLs that will change when cache is invalidated, either by a change to catalog or a publish of content. | 
| labels | object | The theme labels, which are key-value pairs used for localization. | 
| themeId | string | Unique identifier for the theme. | 
| generalSettings | GeneralSettings | An object the includes the following properties: 
 | 
| checkoutSettings | CheckoutSettings | An object with the following properties: 
 | 
| themeSettings | object | An object that contains the theme settings available in theme.json. | 
| isEditMode | Boolean | TRUE if the current site is being rendered inside an editor frame. Use this to display preview content in widgets or templates that would not work properly in an editing session. | 
| cdnPrefix | string | The URL prefix for CDN content, composed of the host name plus a unique CDN identifier for the site. | 
| secureHost | string | HTTPS version of the requested host name. | 
| supportsInStorePickup | Boolean | TRUE if store pickup is enabled in the Admin location settings. | 
| domains | siteDomains | An object that lists the Current domain and the Primary domain, each of which has the following properties: 
 | 
| currencyInfo | Currency | An object with the following properties: 
 | 
Example:
context.items.siteContext.siteId;
items.pageContext
Accesses the current page context.
| Property | Type | Description | 
|---|---|---|
| query | object | Read-only object of the key-value pairs in the current URL. | 
| themeId | string | Unique identifier for the theme. | 
| isDebugMode | Boolean | Indicates whether debug mode is enabled. | 
| cdnCacheBustKey | string | The randomly generated number appended to the URL of CDN content. This number changes in order to refresh cached content every time a Kibo eCommerce Admin user clicks the Bust Cache button available in the General Settings. | 
| isSecure | Boolean | TRUE if the current page is a secure (HTTPS) page. | 
| pageType | string | The documentTypeof the current page, such as "web_page", "cart", "search", etc. | 
| isCrawler | Boolean | TRUE if the current page is requested by a search engine crawler. | 
| isMobile | Boolean | TRUE if the current page is requested by a mobile device. | 
| isTablet | Boolean | TRUE if the current page is requested by a tablet. | 
| isDesktop | Boolean | TRUE if the visitor’s browser does not identify itself as a mobile or tablet device. | 
| cmsContext | CmsPageContext | An object with the following the  
 | 
| search | SearchContext | An object related to URL paging and URL queries of product collections on Search pages and Category pages. It contains the following properties: 
 | 
| visit | Visit | The unique visitor ID. | 
| title | string | The title of the current page. | 
| metaDescription | string | The contents of the description field entered into the SEO settings for the current page. | 
| metaTitle | string | The contents of the title field entered into the SEO settings for the current page. | 
| metaKeywords | string | The contents of the keywords field entered into the SEO settings for the current page. | 
| user | User | An object with the following properties: 
 | 
| isEditMode | Boolean | TRUE if the current site is being rendered inside an editor frame. Use this to display preview content in widgets or templates that would not work properly in an editing session. | 
| url | string | The canonical URL for the current page. | 
| dataViewMode | string | Either "live" or "pending". | 
| secureHost | string | The fully-qualified secure CDN domain for the site. | 
| now | DateTime | The current server date/time when the page is viewed. | 
| categoryCode | string | The category code for the current page if the page is a Category page or Search page. | 
| categoryId | integer | The category ID for the current page if the page is a Category page or Search page. | 
Example:
context.items.pageContext.categoryCode;
items.navigation
Accesses the current navigation context.
| Property | Type | Description | 
|---|---|---|
| tree | NavigationNode array | The navigation tree used to build the main navigation bar for the site. Consists of a list of navigation nodes, each of which may contain children nodes which also are a list of nodes, and so on. The navigation nodes contain the following properties: 
 | 
| rootCategories | NavigationNode array | This is the same as the tree, except it only includes the root-level or top level of the tree, and also excludes CMS pages and external links. | 
| currentNode | NavigationNode | The current node in the tree. | 
| breadcrumbs | NavigationNode array | Shows the "breadcrumbs" that navigate to the current page. This is the same as the treebut it excludes theparentanditemsproperties. | 
Example:
context.items.navigation.breadcrumbs;
Context Methods Available to All Storefront Actions
exec.loginUser
Asynchronously retrieves a user, creates an authentication ticket, and sets the authentication cookies.
| Property | Type | Description | 
|---|---|---|
| config | object | An object that contains the following fields: 
 | 
| callback | function | A callback function that contains the following fields: 
 | 
Example:
var config = {
   rememberUser:true,
   userId: '48577d74a86044bfb2872a4c184ce33c'
};
context.exec.loginUser(config, function (err, result){
//handle the possible error and call the callback
//if successful the result should be the customer auth ticket.
   if (err){
   //bubble up error to the platform
      callback (err);
      return;
   }
//return control flow to the platform
callback();
});
Response: NA
exec.logOut
Synchronously logs out the current user by resetting the user context to an anonymous user and updating the associated cookies.
| N/A | N/A | N/A | 
|---|---|---|
| Property | Type | Description | 
Example:
context.exec.logOut();
Response: NA
Context Methods Available to All HTTP Actions
request.get
Returns an HTTP header value for the specified header key.
| Parameter | Type | Description | 
|---|---|---|
| key | string | The header key. | 
Example:
context.request.get(field);
Response:
"object"
response.get
Gets a field from the response.
| Parameter | Type | Description | 
|---|---|---|
| key | object | The field to obtain. | 
Example:
context.response.get(field);
Response:
"string"
response.set
Sets the HTTP headers for the response.
| Parameter | Type | Description | 
|---|---|---|
| values | object | The values for the HTTP headers. | 
Example:
context.response.set({ myCustomHeader: "howdy" });
Response: N/A
response.set2
Updates a field in the response.
| Parameter | Type | Description | 
|---|---|---|
| key | string | The key of the field. | 
| value | string | The value of the field. | 
Example:
context.response.set("name", "stuff");
Response: N/A
response.remove
Removes an HTTP header from the response.
| Parameter | Type | Description | 
|---|---|---|
| key | string | The HTTP header to remove. | 
Example:
context.response.remove(header);
Response: N/A
response.redirect
Redirects the incoming URL.
| Parameter | Type | Description | 
|---|---|---|
| url | string | The destination URL. | 
Example:
context.response.redirect("http://someOtherSite/foo");
Response: N/A
response.end
Ends the response so that other actions or Kibo eCommerce logic can run. Also, signals the callback to complete.
| Parameter | Type | Description | 
|---|---|---|
| N/A | N/A | N/A | 
Example:
context.response.end();
Response: N/A
get.resource
Returns the currently persisted value of the requested resource. **Not available for all calls.
| Parameter | Type | Description | 
|---|---|---|
| N/A | N/A | N/A | 
Example:
context.get.resource();
Response: N/A
get.resourceStatus
Gets the HTTP resource status.
| Parameter | Type | Description | 
|---|---|---|
| N/A | N/A | N/A | 
Example:
context.get.resourceStatus();
Response: N/A
items.urlHelper.getUrl
Gets the current URL.
| Parameter | Type | Description | 
|---|---|---|
| type |  |  | 
| object |  |  | 
| config |  |  | 
Example:
context.items.urlHelper.getUrl(type, object, config);
Context Objects Available to All Actions
apiContext
Accesses Kibo eCommerce tenant information.
| Property | Type | Description | 
|---|---|---|
| baseUrl | string | The base URL for the site. | 
| basePciUrl | string | The base PCI URL for the site. | 
| tenantPod | string | The name of the tenant pod in which the tenant resides. | 
| appClaims | string | The application claims token. | 
| appKey | string | The application key. | 
| tenantId | integer | Unique identifier for the tenant. | 
| siteId | integer | Unique identifier for the site. This ID is used at all levels of a store, catalog, and tenant to associate objects to a site. | 
| masterCatalogId | integer | Unique identifier for the master catalog. | 
| catalogId | integer | The unique identifier for the product catalog. Catalogs are part of a master catalog. | 
| currencyCode | string | The default three-letter ISO currency code for monetary amounts. | 
| previewDate | date/time | The date and time that the content is being viewed. This might be a future date if the content is previewed with an active date range set in the future. | 
| localeCode | string | The locale code per the country code provided. This code determines the localized content to use and display. | 
| correlationId | string | The unique identifier of the API request associated with the event action, which might contain multiple actions. | 
| isAuthorizedAsAdmin | Boolean | Indicates whether the Dev Account user is authorized as an admin. | 
| userClaims | string | The user claims token. | 
Example:
context.apiContext.baseUrl;
configuration
Receives a JSON response that contains information about the configuration data set in the Action Management JSON editor.
| Property | Type | Description | 
|---|---|---|
| Varies | object | Custom fields and values that you can set in the Action Management JSON Editor. | 
Example:
context.configuration.customData;