Skip to content

Commit

Permalink
Merge branch 'develop' into feature/61-copy-metadata-to-another-busin…
Browse files Browse the repository at this point in the history
…ess-unit
  • Loading branch information
anasilva105 committed Jan 24, 2024
2 parents bee3ea5 + 5a9357d commit 191b113
Show file tree
Hide file tree
Showing 13 changed files with 206 additions and 134 deletions.
2 changes: 1 addition & 1 deletion package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

26 changes: 24 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
"description": "Accenture Salesforce Marketing Cloud DevTools Vscode Extension",
"version": "0.0.1",
"peerDependencies": {
"mcdev": "^6.0.0"
"mcdev": ">=5.2.0"
},
"repository": {
"type": "git",
Expand Down Expand Up @@ -52,6 +52,28 @@
"command": "sfmc-devtools-vscext.devtoolsCMCopyToBU",
"group": "devtools"
}
],
"commandPalette": [
{
"command": "sfmc-devtools-vscext.devtoolsCMRetrieve",
"when": "false"
},
{
"command": "sfmc-devtools-vscext.devtoolsCMDeploy",
"when": "false"
}
],
"editor/title/context": [
{
"when": "resourcePath =~ /retrieve/",
"command": "sfmc-devtools-vscext.devtoolsCMRetrieve",
"group": "devtools"
},
{
"when": "resourcePath =~ /deploy/ || (resourcePath =~ /retrieve/ && (resourceLangId == json || resourceLangId == html || resourceLangId == sql || resourceLangId == markdown || resourceLangId == ssjs))",
"command": "sfmc-devtools-vscext.devtoolsCMDeploy",
"group": "devtools"
}
]
}
},
Expand Down Expand Up @@ -87,4 +109,4 @@
"@vscode/codicons": "^0.0.35",
"winston": "^3.11.0"
}
}
}
2 changes: 1 addition & 1 deletion src/config/containers.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ export const containersConfig: {
contextMenuDeployCommand: string,
contextMenuCopyToBUCommand: string
} = {
statusBarDevToolsName: "devtoolsmcdev",
statusBarDevToolsName: "mcdev",
statusBarDevToolsTitle: "mcdev",
statusBarDevToolsCommand: "sfmc-devtools-vscext.devtoolsSBMcdev",
statusBarDevToolsCredentialBUName: "devtoolscredentialbu",
Expand Down
73 changes: 44 additions & 29 deletions src/devtools/commands/DevToolsAdminCommands.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,10 @@ class DevToolsAdminCommands extends DevToolsCommands {
private commandMethods: {
[key: string]: (
config: DevToolsCommandSetting,
args: {[key: string]: any },
args: {[key: string]: string | string[] | boolean },
path: string,
handleResult: (result?: any) => void)
=> void
commandHandlers: { [key: string]: (args?: any) => void }
) => void
} = {};
constructor(){
super();
Expand All @@ -29,20 +29,25 @@ class DevToolsAdminCommands extends DevToolsCommands {
commandConfig,
commandArgs,
commandPath,
commandResultHandler
commandHandlers
}: DevToolsCommandRunner = commandRunner;

log("debug", `Running DevTools Admin Command for id '${commandId}'.`);
if(commandId in this.commandMethods){
this.commandMethods[commandId](commandConfig, commandArgs, commandPath, commandResultHandler);
this.commandMethods[commandId](commandConfig, commandArgs, commandPath, commandHandlers);
}else{
log("error", `DevTools Admin Command method for id '${commandId}' is not implemented.`);
}
}

setMetadataTypes(_: SupportedMetadataTypes[]): void {}

async init(config: DevToolsCommandSetting, _: {[key: string]: any}, path: string, handleResult: (result?: any) => void){
async init(
config: DevToolsCommandSetting,
_: {[key: string]: string | string[] | boolean},
path: string,
{ handleCommandResult }: { [key: string]: (args?: any) => void }){

log("info", `Running DevTools Admin Command: Init...`);
const initArgs: {[key: string]: string } = {};
if("command" in config && config.command){
Expand All @@ -67,39 +72,49 @@ class DevToolsAdminCommands extends DevToolsCommands {
// Checks if the command is still missing so required parameter
if(this.hasPlaceholders(commandConfigured)){
log("debug", `Required Parameters missing from Init command: ${commandConfigured}`);
handleCommandResult({ success: false, cancelled: true });
return;
}
log("debug", `Init final command: ${commandConfigured}`);
await this.executeCommand(commandConfigured, path, true);
handleResult();
const commandResult: string | number = await this.executeCommand(commandConfigured, path, true);
if(typeof(commandResult) === "number"){
handleCommandResult({ success: commandResult === 0, cancelled: false });
}
}else{
log("error", "DevToolsAdminCommand_Init: Command is empty or missing the configuration.");
}

}

async explainTypes(config: DevToolsCommandSetting, args: {[key: string]: any }, path: string, handleResult: (result: any) => void){
try{
log("info", `Running DevTools Admin Command: Explain Types...`);
if("command" in config && config.command){
const commandConfigured: string | undefined =
await this.configureCommandWithParameters(
config,
args,
[]
);
log("debug", `Explain types final command: ${commandConfigured}`);
const commandResult = await this.executeCommand(
commandConfigured,
path,
!("json" in args));
handleResult(commandResult);
}else{
log("error", "DevToolsAdminCommand_explainTypes: Command is empty or missing the configuration.");
async explainTypes(
config: DevToolsCommandSetting,
args: {[key: string]: string | string[] | boolean },
path: string,
{ handleCommandResult }: { [key: string]: (args?: any) => void }){

try{
log("info", `Running DevTools Admin Command: Explain Types...`);
if("command" in config && config.command){
const commandConfigured: string | undefined =
await this.configureCommandWithParameters(
config,
args,
[]
);
log("debug", `Explain types final command: ${commandConfigured}`);
const commandResult: string | number = await this.executeCommand(
commandConfigured,
path,
!("json" in args));
if(typeof(commandResult) === "string"){
handleCommandResult({ success: commandResult.length > 0, data: commandResult});
}
}else{
log("error", "DevToolsAdminCommand_explainTypes: Command is empty or missing some configuration.");
}
}catch(error){
log("error", `DevToolsAdminCommand_explainTypes Error: ${error}`);
}
}catch(error){
log("error", `DevToolsAdminCommand_explainTypes Error: ${error}`);
}
}
}

Expand Down
59 changes: 30 additions & 29 deletions src/devtools/commands/DevToolsCommands.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,16 +30,10 @@ abstract class DevToolsCommands {
resolve(code);
}
if(error){
log("error",
`[DevToolsCommands_executeCommand] Exit Code: ${error}`
);
log("error", `[DevToolsCommands_executeCommand] Exit Code: ${error}`);
}
if(output){
if(showOnTerminal){
log("info", output);
}else{
resolve(output);
}
showOnTerminal ? log("info", output) : resolve(output);
}
},
});
Expand All @@ -48,7 +42,7 @@ abstract class DevToolsCommands {

async configureCommandWithParameters(
config: DevToolsCommandSetting,
args: {[key: string]: string },
args: {[key: string]: string | string[] | boolean },
mdTypes: SupportedMetadataTypes[]): Promise<string> {

log("debug", `ConfigureCommandWithParameters: ${JSON.stringify(config)}`);
Expand All @@ -57,7 +51,7 @@ abstract class DevToolsCommands {
if("requiredParams" in config && config.requiredParams.length){
for(const param of config.requiredParams){
if(param in args && args[param]){
command = command.replace(`{{${param}}}`, args[param]);
command = command.replace(`{{${param}}}`, args[param] as string);
}else{
// Requests user
if(param.toLowerCase() === "mdtypes" && mdTypes.length){
Expand All @@ -79,7 +73,7 @@ abstract class DevToolsCommands {
? `--${param}`
: "";
}
command = command.replace(`{{${param}}}`, param in args ? args[param] : "");
command = command.replace(`{{${param}}}`, param in args ? args[param] as string : "");
});
}
return command;
Expand Down Expand Up @@ -145,28 +139,35 @@ abstract class DevToolsCommands {
"etypes",
path,
{ json: true },
((result: any) => {
// Parses the list of supported mtdata types
const parsedResult: SupportedMetadataTypes[] = JSON.parse(result);
if(parsedResult && parsedResult.length){
// Sends the supported mtdata types to each DevTools Command
Object.keys(this.commandMap).forEach((key: string) => {
const devToolCommand: DevToolsCommands =
this.commandMap[key];
devToolCommand.setMetadataTypes(parsedResult);
});
}else{
log("error", "DevToolsCommands_init: Failed to parse supported metadata type result.");
{
handleCommandResult: ({ success, data }: { success: boolean, data: string}) => {
if(success){
// Parses the list of supported mtdata types
const parsedResult: SupportedMetadataTypes[] = JSON.parse(data);
if(parsedResult && parsedResult.length){
// Sends the supported mtdata types to each DevTools Command
Object.keys(this.commandMap).forEach((key: string) => {
const devToolCommand: DevToolsCommands =
this.commandMap[key];
devToolCommand.setMetadataTypes(parsedResult);
});
}else{
log("error", "DevToolsCommands_init: Failed to parse supported metadata type result.");
}
}else{
log("error", "DevToolsCommands_init: Admin Command etypes failed.");
}
}
}
}));
);
}

static async runCommand(
typeId: string,
typeId: string | null,
commandId: string,
commandPath: string,
args: any,
handleResult: (result: any) => void) {
args: {[key: string]: string | string[] | boolean},
commandHandlers: {[key: string]: (args?: any) => void}){
// When the DevTools command type is unknown to the application
if(!typeId && commandId){
const [{ id }]: { id: string }[] =
Expand All @@ -186,7 +187,7 @@ abstract class DevToolsCommands {
}

if(this.commandMap){
if(typeId in this.commandMap){
if(typeId && typeId in this.commandMap){
const [ commandConfig ]: DevToolsCommandSetting[] =
this.getCommandsListByType(typeId)
.filter((commandSetting: DevToolsCommandSetting) => commandSetting.id === commandId);
Expand All @@ -198,7 +199,7 @@ abstract class DevToolsCommands {
commandConfig,
commandArgs: args,
commandPath,
commandResultHandler: handleResult
commandHandlers: commandHandlers
});
return;
}
Expand Down
40 changes: 29 additions & 11 deletions src/devtools/commands/DevToolsStandardCommands.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,10 @@ class DevToolsStandardCommands extends DevToolsCommands {
private commandMethods: {
[key: string]: (
config: DevToolsCommandSetting,
args: {[key: string]: any },
args: {[key: string]: string | string[] | boolean },
path: string,
handleResult: (result: any) => void)
=> void
commandHandlers: { [key: string]: (args?: any) => void }
) => void
} = {};
private metadataTypes: SupportedMetadataTypes[] = [];
constructor(){
Expand All @@ -30,12 +30,12 @@ class DevToolsStandardCommands extends DevToolsCommands {
commandConfig,
commandArgs,
commandPath,
commandResultHandler
commandHandlers
}: DevToolsCommandRunner = commandRunner;

log("debug", `Running DevTools Standard Command for id '${commandId}'.`);
if(commandId in this.commandMethods){
this.commandMethods[commandId](commandConfig, commandArgs, commandPath, commandResultHandler);
this.commandMethods[commandId](commandConfig, commandArgs, commandPath, commandHandlers);
}else{
log("error", `DevTools Standard Command method for id '${commandId}' is not implemented.`);
}
Expand All @@ -45,7 +45,12 @@ class DevToolsStandardCommands extends DevToolsCommands {
this.metadataTypes = mdTypes;
}

async retrieve(config: DevToolsCommandSetting, args: {[key: string]: string }, path: string, handleResult: (result: any) => void){
async retrieve(
config: DevToolsCommandSetting,
args: {[key: string]: string | string[] | boolean },
path: string,
{ handleCommandResult, loadingNotification }: { [key: string]: (args?: any) => void }){

log("info", `Running DevTools Standard Command: Retrieve...`);
if("command" in config && config.command){
// Gets that metadata types that are supported for retrieve
Expand All @@ -63,18 +68,27 @@ class DevToolsStandardCommands extends DevToolsCommands {
// Checks if the command is still missing so required parameter
if(this.hasPlaceholders(commandConfigured)){
log("debug", `Required Parameters missing from Retrieve command: ${commandConfigured}`);
handleCommandResult({ success: false, cancelled: true });
return;
}

log("debug", `Retrieve Command configured: ${commandConfigured}`);
const commandResult: Promise<unknown> = this.executeCommand(commandConfigured, path, true);
handleResult(commandResult);
loadingNotification();
const commandResult: string | number = await this.executeCommand(commandConfigured, path, true);
if(typeof(commandResult) === "number"){
handleCommandResult({ success: commandResult === 0, cancelled: false });
}
}else{
log("error", "DevToolsStandardCommand_retrieve: Command is empty or missing the configuration.");
}
}

async deploy(config: DevToolsCommandSetting, args: {[key: string]: any }, path: string, handleResult: (result: any) => void){
async deploy(
config: DevToolsCommandSetting,
args: {[key: string]: string | string[] | boolean },
path: string,
{ handleCommandResult, loadingNotification }: { [key: string]: (args?: any) => void }){

log("info", `Running DevTools Standard Command: Deploy...`);
if("command" in config && config.command){
// Gets that metadata types that are supported for deploy
Expand All @@ -92,12 +106,16 @@ class DevToolsStandardCommands extends DevToolsCommands {
// Checks if the command is still missing so required parameter
if(this.hasPlaceholders(commandConfigured)){
log("debug", `Required Parameters missing from Deploy command: ${commandConfigured}`);
handleCommandResult({ success: false, cancelled: true });
return;
}

log("debug", `Deploy Command configured: ${commandConfigured}`);
const commandResult: Promise<unknown> = this.executeCommand(commandConfigured, path, true);
handleResult(commandResult);
loadingNotification();
const commandResult: string | number = await this.executeCommand(commandConfigured, path, true);
if(typeof(commandResult) === "number"){
handleCommandResult({ success: commandResult === 0, cancelled: false });
}
}else{
log("error", "DevToolsStandardCommand_deploy: Command is empty or missing the configuration.");
}
Expand Down
Loading

0 comments on commit 191b113

Please sign in to comment.