Skip to content

Commit

Permalink
feat: Add support for temp environments
Browse files Browse the repository at this point in the history
  • Loading branch information
gabe565 committed Jun 26, 2024
1 parent 45fb57c commit bd1af4f
Show file tree
Hide file tree
Showing 4 changed files with 70 additions and 15 deletions.
36 changes: 29 additions & 7 deletions dist/index.js

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

7 changes: 7 additions & 0 deletions package-lock.json

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

1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
"dependencies": {
"@actions/core": "1.10.1",
"@actions/github": "6.0.0",
"@octokit/webhooks-definitions": "3.67.3",
"js-yaml": "4.1.0",
"minimatch": "9.0.4"
},
Expand Down
41 changes: 33 additions & 8 deletions src/index.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,13 @@
import * as core from "@actions/core";
import * as github from "@actions/github";
import yaml from "js-yaml";
import { envName, matchPatterns, parseDynamicList } from "./util.js";
import * as path from "path";
import {
envName,
matchPatterns,
parseDynamicList,
toTitleCase,
} from "./util.js";

try {
const envs = yaml.load(core.getInput("envs"));
Expand All @@ -12,7 +18,7 @@ try {
const [, type, ref] = github.context.ref.match(/^refs\/(.+)\/(.+)$/);

let count = 0;
for (const [env, value] of Object.entries(envs)) {
for (let [env, value] of Object.entries(envs)) {
let patterns;
let extraValues = {};

Expand All @@ -21,12 +27,31 @@ try {
if (type !== "heads") continue;
patterns = value;
} else {
if (type === "heads") {
// Ref is a branch
patterns = value.branch;
} else if (type === "tags") {
// Ref is a tag
patterns = value.tag;
if (value.type === "temp") {
// Temp environments enabled
if (github.context.eventName === "pull_request") {
const prEvent = github.context.payload;
const targetLabel = value.label || prEvent.label?.name;
if (
prEvent.action === "labeled" &&
prEvent.label.name === targetLabel
) {
patterns = ref;
env += prEvent.number;
value.name = `${toTitleCase(env)} #${prEvent.number}`;
const dir = path.dirname(value.template);
value.path = path.join(dir, env);
value.pr = prEvent.number;
}
}
} else {
if (type === "heads") {
// Ref is a branch
patterns = value.branch;
} else if (type === "tags") {
// Ref is a tag
patterns = value.tag;
}
}

extraValues = { ...value };
Expand Down

0 comments on commit bd1af4f

Please sign in to comment.