Add payload support

Signed-off-by: Sanjula Ganepola <sanjulagane@gmail.com>
This commit is contained in:
Sanjula Ganepola
2024-11-22 21:51:05 -05:00
parent c4acae4961
commit e332993cc9
8 changed files with 127 additions and 16 deletions

View File

@@ -46,15 +46,16 @@ export enum Event {
}
export enum Option {
Workflows = '-W',
Job = '-j',
Platform = '-P',
Workflows = '--workflows',
Job = '--job',
Platform = '--platform',
Secret = '--secret',
SecretFile = '--secret-file',
Variable = '--var',
VariableFile = '--var-file',
Input = '--input',
InputFile = '--input-file'
InputFile = '--input-file',
PayloadFile = '--eventpath'
}
export interface CommandArgs {
@@ -315,6 +316,7 @@ export class Act {
(settings.inputs.length > 0 ? ` ${Option.Input} ${settings.inputs.map(input => `${input.key}=${input.value}`).join(` ${Option.Input} `)}` : ``) +
(settings.inputFiles.length > 0 ? ` ${Option.InputFile} "${settings.inputFiles[0].path}"` : ` ${Option.InputFile} ""`) +
(settings.runners.length > 0 ? ` ${Option.Platform} ${settings.runners.map(runner => `${runner.key}=${runner.value}`).join(` ${Option.Platform} `)}` : ``) +
(settings.payloadFiles.length > 0 ? ` ${Option.PayloadFile} "${settings.payloadFiles[0].path}"` : ` ${Option.PayloadFile} ""`) +
` 2>&1 | tee "${logPath}"`;
// Execute task

View File

@@ -13,6 +13,7 @@ export interface Settings {
inputs: Setting[];
inputFiles: SettingFile[];
runners: Setting[];
payloadFiles: SettingFile[];
environments: Setting[];
}
@@ -38,7 +39,8 @@ export enum Visibility {
export enum SettingFileName {
secretFile = '.secrets',
variableFile = '.env',
inputFile = '.input'
inputFile = '.input',
payloadFile = 'payload.json'
}
export class SettingsManager {
@@ -64,6 +66,7 @@ export class SettingsManager {
const inputs = (await this.getSetting(workspaceFolder, SettingsManager.inputsRegExp, StorageKey.Inputs, false, Visibility.show)).filter(input => !isUserSelected || (input.selected && input.value));
const inputFiles = (await this.getSettingFiles(workspaceFolder, StorageKey.InputFiles)).filter(inputFile => !isUserSelected || inputFile.selected);
const runners = (await this.getSetting(workspaceFolder, SettingsManager.runnersRegExp, StorageKey.Runners, false, Visibility.show)).filter(runner => !isUserSelected || (runner.selected && runner.value));
const payloadFiles = (await this.getSettingFiles(workspaceFolder, StorageKey.PayloadFiles)).filter(payloadFile => !isUserSelected || payloadFile.selected);
const environments = await this.getEnvironments(workspaceFolder);
return {
@@ -74,6 +77,7 @@ export class SettingsManager {
inputs: inputs,
inputFiles: inputFiles,
runners: runners,
payloadFiles: payloadFiles,
environments: environments
};
}

View File

@@ -8,6 +8,7 @@ export enum StorageKey {
VariableFiles = 'variableFiles',
Inputs = 'inputs',
InputFiles = 'inputFiles',
PayloadFiles = 'PayloadFiles',
Runners = 'runners'
}

View File

@@ -0,0 +1,33 @@
import { ThemeIcon, TreeItem, TreeItemCollapsibleState, WorkspaceFolder } from "vscode";
import { act } from "../../extension";
import { SettingFile } from "../../settingsManager";
import { StorageKey } from "../../storageManager";
import { GithubLocalActionsTreeItem } from "../githubLocalActionsTreeItem";
import SettingFileTreeItem from "./settingFile";
export default class PayloadsTreeItem extends TreeItem implements GithubLocalActionsTreeItem {
static contextValue = 'githubLocalActions.payloads';
storageKey = StorageKey.PayloadFiles;
constructor(public workspaceFolder: WorkspaceFolder, payloadFiles: SettingFile[]) {
super('Payloads', TreeItemCollapsibleState.Collapsed);
const selectedPayloadFiles = payloadFiles.filter(payloadFile => payloadFile.selected);
this.description = selectedPayloadFiles.length > 0 ? `${selectedPayloadFiles[0].name}` : ``;
this.contextValue = PayloadsTreeItem.contextValue;
this.iconPath = new ThemeIcon('json');
}
async getChildren(): Promise<GithubLocalActionsTreeItem[]> {
const items: GithubLocalActionsTreeItem[] = [];
const settings = await act.settingsManager.getSettings(this.workspaceFolder, false);
const payloadFileTreeItems: GithubLocalActionsTreeItem[] = [];
for (const payloadFile of settings.payloadFiles) {
payloadFileTreeItems.push(SettingFileTreeItem.getPayloadTreeItem(this.workspaceFolder, payloadFile));
}
items.push(...payloadFileTreeItems.sort((a, b) => a.label!.toString().localeCompare(b.label!.toString())));
return items;
}
}

View File

@@ -55,6 +55,18 @@ export default class SettingFileTreeItem extends TreeItem implements GithubLocal
);
}
static getPayloadTreeItem(workspaceFolder: WorkspaceFolder, payloadFile: SettingFile): SettingFileTreeItem {
return new SettingFileTreeItem(
workspaceFolder,
payloadFile,
StorageKey.PayloadFiles,
{
contextValue: 'githubLocalActions.payloadFile',
iconPath: new ThemeIcon('file')
}
);
}
async getChildren(): Promise<GithubLocalActionsTreeItem[]> {
return [];
}

View File

@@ -4,6 +4,7 @@ import { SettingFileName, Visibility } from "../../settingsManager";
import { StorageKey } from "../../storageManager";
import { GithubLocalActionsTreeItem } from "../githubLocalActionsTreeItem";
import InputsTreeItem from "./inputs";
import PayloadsTreeItem from "./payloads";
import SecretsTreeItem from "./secrets";
import SettingTreeItem from "./setting";
import SettingFileTreeItem from "./settingFile";
@@ -98,6 +99,32 @@ export default class SettingsTreeDataProvider implements TreeDataProvider<Github
this.refresh();
}
}),
commands.registerCommand('githubLocalActions.createPayloadFile', async (payloadsTreeItem: PayloadsTreeItem) => {
const payloadFileName = await window.showInputBox({
prompt: `Enter the name for the payload file`,
placeHolder: `Payload File Name`,
value: SettingFileName.payloadFile
});
if (payloadFileName) {
await act.settingsManager.createSettingFile(payloadsTreeItem.workspaceFolder, payloadsTreeItem.storageKey, payloadFileName);
this.refresh();
}
}),
commands.registerCommand('githubLocalActions.locatePayloadFiles', async (payloadsTreeItem: PayloadsTreeItem) => {
const payloadFilesUris = await window.showOpenDialog({
title: 'Locate Payload Files',
canSelectFiles: true,
canSelectFolders: false,
canSelectMany: true,
defaultUri: payloadsTreeItem.workspaceFolder.uri
});
if (payloadFilesUris) {
await act.settingsManager.locateSettingFile(payloadsTreeItem.workspaceFolder, payloadsTreeItem.storageKey, payloadFilesUris);
this.refresh();
}
}),
commands.registerCommand('githubLocalActions.openSettingFile', async (settingFileTreeItem: SettingFileTreeItem) => {
const document = await workspace.openTextDocument(settingFileTreeItem.settingFile.path);
await window.showTextDocument(document);

View File

@@ -2,6 +2,7 @@ import { ThemeIcon, TreeItem, TreeItemCollapsibleState, WorkspaceFolder } from "
import { act } from "../../extension";
import { GithubLocalActionsTreeItem } from "../githubLocalActionsTreeItem";
import InputsTreeItem from "./inputs";
import PayloadsTreeItem from "./payloads";
import RunnersTreeItem from "./runners";
import SecretsTreeItem from "./secrets";
import VariablesTreeItem from "./variables";
@@ -23,7 +24,8 @@ export default class WorkspaceFolderSettingsTreeItem extends TreeItem implements
new SecretsTreeItem(this.workspaceFolder, settings.secrets, settings.secretFiles),
new VariablesTreeItem(this.workspaceFolder, settings.variables, settings.variableFiles),
new InputsTreeItem(this.workspaceFolder, settings.inputs, settings.inputFiles),
new RunnersTreeItem(this.workspaceFolder, settings.runners)
new RunnersTreeItem(this.workspaceFolder, settings.runners),
new PayloadsTreeItem(this.workspaceFolder, settings.payloadFiles)
]);
return items;