sfcc-dev-mcp
Version:
MCP server for Salesforce B2C Commerce Cloud development assistance including logs, debugging, and development tools
53 lines • 2.33 kB
JavaScript
/**
* OCAPI Site Preferences Client
*
* This module handles all SFCC site preference related operations including
* searching preferences across different instance types and preference groups.
*/
import { OCAPIAuthClient } from '../base/ocapi-auth-client.js';
import { QueryBuilder } from '../../utils/query-builder.js';
import { Validator } from '../../utils/validator.js';
import { buildOCAPIBaseUrl } from '../../utils/ocapi-url-builder.js';
/**
* OCAPI Site Preferences Client
* Specialized client for site preference operations
*/
export class OCAPISitePreferencesClient extends OCAPIAuthClient {
constructor(config) {
super(config);
// Override the baseUrl for this specialized client
this.baseUrl = buildOCAPIBaseUrl(config);
}
/**
* Search site preferences across sites in the specified preference group and instance
*
* Allows searching for preferences by id, display_name, description, and value_type
* Supports text queries, term queries, filtered queries, and boolean queries
*
* Searchable fields:
* - id - String
* - display_name - Localized String
* - description - Localized String
* - value_type - one of {
* string, int, double, text, html, date, image, boolean, money, quantity,
* datetime, email, password, set_of_string, set_of_int, set_of_double, enum_of_string, enum_of_int
* }
*
* Note: value_type can only be joined with other attributes using a conjunction (AND)
* Only searchable attributes can be used in sorting
*/
async searchSitePreferences(groupId, instanceType, searchRequest, options) {
Validator.validateRequired({ groupId, instanceType }, ['groupId', 'instanceType']);
const validatedInstanceType = Validator.validateInstanceType(instanceType);
Validator.validateSearchRequest(searchRequest);
let endpoint = `/site_preferences/preference_groups/${encodeURIComponent(groupId)}/${validatedInstanceType}/preference_search`;
if (options) {
const queryString = QueryBuilder.fromObject(options);
if (queryString) {
endpoint += `?${queryString}`;
}
}
return this.post(endpoint, searchRequest);
}
}
//# sourceMappingURL=site-preferences-client.js.map