mcdev
Version:
Accenture Salesforce Marketing Cloud DevTools
142 lines (131 loc) • 5.37 kB
JavaScript
;
import MetadataType from './MetadataType.js';
import { Util } from '../util/util.js';
/**
* @typedef {import('../../types/mcdev.d.js').BuObject} BuObject
* @typedef {import('../../types/mcdev.d.js').CodeExtract} CodeExtract
* @typedef {import('../../types/mcdev.d.js').CodeExtractItem} CodeExtractItem
* @typedef {import('../../types/mcdev.d.js').MetadataTypeItem} MetadataTypeItem
* @typedef {import('../../types/mcdev.d.js').MetadataTypeItemDiff} MetadataTypeItemDiff
* @typedef {import('../../types/mcdev.d.js').MetadataTypeItemObj} MetadataTypeItemObj
* @typedef {import('../../types/mcdev.d.js').MetadataTypeMap} MetadataTypeMap
* @typedef {import('../../types/mcdev.d.js').MetadataTypeMapObj} MetadataTypeMapObj
* @typedef {import('../../types/mcdev.d.js').SoapRequestParams} SoapRequestParams
* @typedef {import('../../types/mcdev.d.js').TemplateMap} TemplateMap
*/
/**
* TransactionalMessage MetadataType
*
* @augments MetadataType
*/
class TransactionalMessage extends MetadataType {
// define this.subType as string here for intellisense; requires to be redefined in child class
static subType;
/**
* Retrieves Metadata
*
* @param {string} [retrieveDir] Directory where retrieved metadata directory will be saved
* @param {void | string[]} [_] unused parameter
* @param {void | string[]} [__] unused parameter
* @param {string} [key] customer key of single item to retrieve
* @returns {Promise.<MetadataTypeMapObj>} Promise of metadata
*/
static async retrieve(retrieveDir, _, __, key) {
let keyList;
const baseUri = '/messaging/v1/' + this.subType + '/definitions/';
if (key) {
// Retrieve single
keyList = [key];
} else {
// Retrieve all
// * keep deleted items for caching (and to decide on update vs create)
const parsed = (
await this.retrieveREST(
null,
baseUri + (retrieveDir ? '?$filter=status%20neq%20deleted' : '')
)
).metadata;
keyList = Object.keys(parsed);
}
// get all transactionalX items with additional details not given by the list endpoint
const details = (
await Promise.all(
keyList.map(async (key) => {
try {
return await this.client.rest.get(baseUri + (key || ''));
} catch {
return null;
}
})
)
).filter(Boolean);
const parsed = this.parseResponseBody({ definitions: details });
let savedMetadata;
if (retrieveDir) {
// * retrieveDir is mandatory in this method as it is not used for caching (there is a seperate method for that)
savedMetadata = await this.saveResults(parsed, retrieveDir, null, null);
Util.logger.info(
`Downloaded: ${this.definition.type} (${Object.keys(savedMetadata).length})` +
Util.getKeysString(key)
);
if (!Object.keys(savedMetadata).length && key) {
this.postDeleteTasks(key);
}
}
return { metadata: savedMetadata || parsed, type: this.definition.type };
}
/**
* Retrieves event definition metadata for caching
*
* @param {void | string[]} [_] parameter not used
* @param {void | string[]} [__] parameter not used
* @param {string} [key] customer key of single item to cache
* @returns {Promise.<MetadataTypeMapObj>} Promise of metadata
*/
static retrieveForCache(_, __, key) {
// the call to /messaging/v1/email/definitions/ does not return definitionId
// definitionId is required for resolving dependencies on interactions.
// we should therefore use the already defined retrieve method
return this.retrieve(undefined, undefined, undefined, key);
}
/**
* Updates a single item
*
* @param {MetadataTypeItem} metadata a single item
* @returns {Promise} Promise
*/
static update(metadata) {
return super.updateREST(
metadata,
'/messaging/v1/' + this.subType + '/definitions/' + metadata[this.definition.keyField]
);
}
/**
* Creates a single item
*
* @param {MetadataTypeItem} metadata a single item
* @returns {Promise} Promise
*/
static create(metadata) {
return super.createREST(metadata, '/messaging/v1/' + this.subType + '/definitions');
}
/**
* Delete a metadata item from the specified business unit
*
* @param {string} key Identifier of item
* @returns {Promise.<boolean>} deletion success status
*/
static deleteByKey(key) {
return super.deleteByKeyREST(
'/messaging/v1/' + this.subType + '/definitions/' + key,
key,
30003
);
}
}
// Assign definition to static attributes
// ! using SMS definitions here as placeholder to have auto completion
import MetadataTypeDefinitions from '../MetadataTypeDefinitions.js';
TransactionalMessage.definition = MetadataTypeDefinitions.transactionalMessage;
TransactionalMessage.definition;
export default TransactionalMessage;