projen
Version:
CDK for software projects
245 lines • 26.9 kB
JavaScript
;
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.Gitpod = exports.GitpodPortVisibility = exports.GitpodOnOpen = exports.GitpodOpenIn = exports.GitpodOpenMode = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const component_1 = require("./component");
const yaml_1 = require("./yaml");
/**
* Relative path of Gitpod file to generate
*/
const GITPOD_FILE = ".gitpod.yml";
/**
* https://www.gitpod.io/docs/configuration/
* https://www.gitpod.io/docs/config-start-tasks/
* https://www.gitpod.io/docs/prebuilds/#configure-the-github-app
* https://www.gitpod.io/docs/vscode-extensions/
*/
/**
* Configure how the terminal should be opened relative to the previous task.
*/
var GitpodOpenMode;
(function (GitpodOpenMode) {
/**
* Opens in the same tab group right after the previous tab
*/
GitpodOpenMode["TAB_AFTER"] = "tab-after";
/**
* Opens in the same tab group left before the previous tab
*/
GitpodOpenMode["TAB_BEFORE"] = "tab-before";
/**
* Splits and adds the terminal to the right
*/
GitpodOpenMode["SPLIT_RIGHT"] = "split-right";
/**
* Splits and adds the terminal to the left
*/
GitpodOpenMode["SPLIT_LEFT"] = "split-left";
/**
* Splits and adds the terminal to the top
*/
GitpodOpenMode["SPLIT_TOP"] = "split-top";
/**
* Splits and adds the terminal to the bottom
*/
GitpodOpenMode["SPLIT_BOTTOM"] = "split-bottom";
})(GitpodOpenMode || (exports.GitpodOpenMode = GitpodOpenMode = {}));
/**
* Configure where in the IDE the terminal should be opened.
*/
var GitpodOpenIn;
(function (GitpodOpenIn) {
/**
* the bottom panel (default)
*/
GitpodOpenIn["BOTTOM"] = "bottom";
/**
* the left panel
*/
GitpodOpenIn["LEFT"] = "left";
/**
* the right panel
*/
GitpodOpenIn["RIGHT"] = "right";
/**
* the main editor area
*/
GitpodOpenIn["MAIN"] = "main";
})(GitpodOpenIn || (exports.GitpodOpenIn = GitpodOpenIn = {}));
/**
* What to do when a service on a port is detected.
*/
var GitpodOnOpen;
(function (GitpodOnOpen) {
/**
* Open a new browser tab
*/
GitpodOnOpen["OPEN_BROWSER"] = "open-browser";
/**
* Open a preview on the right side of the IDE
*/
GitpodOnOpen["OPEN_PREVIEW"] = "open-preview";
/**
* Show a notification asking the user what to do (default)
*/
GitpodOnOpen["NOTIFY"] = "notify";
/**
* Do nothing.
*/
GitpodOnOpen["IGNORE"] = "ignore";
})(GitpodOnOpen || (exports.GitpodOnOpen = GitpodOnOpen = {}));
/**
* Whether the port visibility should be private or public
*/
var GitpodPortVisibility;
(function (GitpodPortVisibility) {
/**
* Allows everyone with the port URL to access the port (default)
*/
GitpodPortVisibility["PUBLIC"] = "public";
/**
* Only allows users with workspace access to access the port
*/
GitpodPortVisibility["PRIVATE"] = "private";
})(GitpodPortVisibility || (exports.GitpodPortVisibility = GitpodPortVisibility = {}));
/**
* The Gitpod component which emits .gitpod.yml
*/
class Gitpod extends component_1.Component {
constructor(project, options = {}) {
super(project);
this.tasks = new Array();
this.ports = new Array();
this.vscodeExtensions = new Array();
this.dockerImage = options?.dockerImage;
if (options?.tasks) {
for (const task of options.tasks) {
this.addTasks(task);
}
}
if (options?.prebuilds) {
this.addPrebuilds(options.prebuilds);
}
if (options?.ports) {
this.addPorts(...options.ports);
}
if (options?.vscodeExtensions) {
this.addVscodeExtensions(...options.vscodeExtensions);
}
this.config = {
image: () => this.renderDockerImage(),
tasks: this.tasks,
github: () => this.renderPrebuilds(),
ports: this.ports,
vscode: {
extensions: this.vscodeExtensions,
},
};
new yaml_1.YamlFile(this.project, GITPOD_FILE, {
obj: this.config,
omitEmpty: true,
// GitPod needs to read the file from the repository in order to work.
committed: true,
});
}
/**
* Add a custom Docker image or Dockerfile for the container.
*
* @param image The Docker image
*/
addDockerImage(image) {
if (this.dockerImage) {
throw new Error("dockerImage cannot be redefined.");
}
this.dockerImage = image;
}
/**
* Add tasks to run when gitpod starts.
*
* By default, all tasks will be run in parallel. To run tasks in sequence,
* create a new `Task` and specify the other tasks as subtasks.
*
* @param tasks The new tasks
*/
addTasks(...tasks) {
this.tasks.push(...tasks.map((task) => ({
name: task.name,
command: `npx projen ${task.name}`,
})));
}
/**
* Add a prebuilds configuration for the Gitpod App
* @param config The configuration
*/
addPrebuilds(config) {
this.prebuilds = config;
}
/**
* Add a task with more granular options.
*
* By default, all tasks will be run in parallel. To run tasks in sequence,
* create a new `Task` and set the other tasks as subtasks.
*
* @param options The task parameters
*/
addCustomTask(options) {
this.tasks.push({
name: options.name,
command: options.command,
openMode: options.openMode,
openIn: options.openIn,
before: options.before,
init: options.init,
prebuild: options.prebuild,
});
}
/**
* Add ports that should be exposed (forwarded) from the container.
*
* @param ports The new ports
*/
addPorts(...ports) {
this.ports.push(...ports.map((port) => ({ port: port })));
}
/**
* Add a list of VSCode extensions that should be automatically installed
* in the container.
*
* These must be in the format defined in the Open VSX registry.
* @example 'scala-lang.scala@0.3.9:O5XmjwY5Gz+0oDZAmqneJw=='
* @see https://www.gitpod.io/docs/vscode-extensions/
*
* @param extensions The extension IDs
*/
addVscodeExtensions(...extensions) {
this.vscodeExtensions.push(...extensions);
}
renderDockerImage() {
if (this.dockerImage?.image) {
return this.dockerImage.image;
}
else if (this.dockerImage?.dockerFile) {
return {
file: this.dockerImage.dockerFile,
};
}
else {
return undefined;
}
}
renderPrebuilds() {
if (this.prebuilds) {
return {
prebuilds: this.prebuilds,
};
}
else {
return undefined;
}
}
}
exports.Gitpod = Gitpod;
_a = JSII_RTTI_SYMBOL_1;
Gitpod[_a] = { fqn: "projen.Gitpod", version: "0.95.2" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gitpod.js","sourceRoot":"","sources":["../src/gitpod.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component } from \"./component\";\nimport {\n  IDevEnvironment,\n  DevEnvironmentOptions,\n  DevEnvironmentDockerImage,\n} from \"./dev-env\";\nimport { Project } from \"./project\";\nimport { Task } from \"./task\";\nimport { YamlFile } from \"./yaml\";\n\n/**\n * Relative path of Gitpod file to generate\n */\nconst GITPOD_FILE = \".gitpod.yml\";\n\n/**\n * https://www.gitpod.io/docs/configuration/\n * https://www.gitpod.io/docs/config-start-tasks/\n * https://www.gitpod.io/docs/prebuilds/#configure-the-github-app\n * https://www.gitpod.io/docs/vscode-extensions/\n */\n\n/**\n * Configure how the terminal should be opened relative to the previous task.\n */\nexport enum GitpodOpenMode {\n  /**\n   * Opens in the same tab group right after the previous tab\n   */\n  TAB_AFTER = \"tab-after\",\n  /**\n   * Opens in the same tab group left before the previous tab\n   */\n  TAB_BEFORE = \"tab-before\",\n  /**\n   * Splits and adds the terminal to the right\n   */\n  SPLIT_RIGHT = \"split-right\",\n  /**\n   * Splits and adds the terminal to the left\n   */\n  SPLIT_LEFT = \"split-left\",\n  /**\n   * Splits and adds the terminal to the top\n   */\n  SPLIT_TOP = \"split-top\",\n  /**\n   * Splits and adds the terminal to the bottom\n   */\n  SPLIT_BOTTOM = \"split-bottom\",\n}\n\n/**\n * Configure where in the IDE the terminal should be opened.\n */\nexport enum GitpodOpenIn {\n  /**\n   * the bottom panel (default)\n   */\n  BOTTOM = \"bottom\",\n  /**\n   * the left panel\n   */\n  LEFT = \"left\",\n  /**\n   * the right panel\n   */\n  RIGHT = \"right\",\n  /**\n   * the main editor area\n   */\n  MAIN = \"main\",\n}\n\n/**\n * Configure options for a task to be run when opening a Gitpod\n * workspace (e.g. running tests, or starting a dev server).\n *\n * Start Mode         | Execution\n * Fresh Workspace    | before && init && command\n * Restart Workspace  | before && command\n * Snapshot           | before && command\n * Prebuild           | before && init && prebuild\n */\nexport interface GitpodTask {\n  /**\n   * Required. The shell command to run\n   */\n  readonly command: string;\n\n  /**\n   * A name for this task.\n   * @default - task names are omitted when blank\n   */\n  readonly name?: string;\n\n  /**\n   * You can configure how the terminal should be opened relative to the previous task.\n   * @default GitpodOpenMode.TAB_AFTER\n   */\n  readonly openMode?: GitpodOpenMode;\n\n  /**\n   * You can configure where in the IDE the terminal should be opened\n   * @default GitpodOpenIn.BOTTOM\n   */\n  readonly openIn?: GitpodOpenIn;\n\n  /**\n   * In case you need to run something even before init, that is a requirement for both init and command,\n   * you can use the before property.\n   * @default\n   */\n  readonly before?: string;\n\n  /**\n   * The init property can be used to specify shell commands that should only be executed after a workspace\n   * was freshly cloned and needs to be initialized somehow. Such tasks are usually builds or downloading\n   * dependencies. Anything you only want to do once but not when you restart a workspace or start a snapshot.\n   * @default\n   */\n  readonly init?: string;\n\n  /**\n   * The optional prebuild command will be executed during prebuilds. It is meant to run additional long running\n   * processes that could be useful, e.g. running test suites.\n   * @default\n   */\n  readonly prebuild?: string;\n}\n\n/**\n * What to do when a service on a port is detected.\n */\nexport enum GitpodOnOpen {\n  /**\n   * Open a new browser tab\n   */\n  OPEN_BROWSER = \"open-browser\",\n\n  /**\n   * Open a preview on the right side of the IDE\n   */\n  OPEN_PREVIEW = \"open-preview\",\n\n  /**\n   * Show a notification asking the user what to do (default)\n   */\n  NOTIFY = \"notify\",\n\n  /**\n   * Do nothing.\n   */\n  IGNORE = \"ignore\",\n}\n\n/**\n * Whether the port visibility should be private or public\n */\nexport enum GitpodPortVisibility {\n  /**\n   * Allows everyone with the port URL to access the port (default)\n   */\n  PUBLIC = \"public\",\n\n  /**\n   * Only allows users with workspace access to access the port\n   */\n  PRIVATE = \"private\",\n}\n\n/**\n * Options for an exposed port on Gitpod\n */\nexport interface GitpodPort {\n  /**\n   * A port that should be exposed (forwarded) from the container.\n   *\n   * @example \"8080\"\n   */\n  readonly port?: string;\n\n  /**\n   * What to do when a service on a port is detected.\n   *\n   * @default GitpodOnOpen.NOTIFY\n   */\n  readonly onOpen?: GitpodOnOpen;\n\n  /**\n   * Whether the port visibility should be private or public.\n   *\n   * @default GitpodPortVisibility.PUBLIC\n   */\n  readonly visibility?: GitpodPortVisibility;\n}\n\n/**\n * Configure the Gitpod App for prebuilds.\n * Currently only GitHub is supported.\n * @see https://www.gitpod.io/docs/prebuilds/\n */\nexport interface GitpodPrebuilds {\n  /**\n   * Enable for the master/default branch\n   * @default true\n   */\n  readonly master?: boolean;\n\n  /**\n   * Enable for all branches in this repo\n   * @default false\n   */\n  readonly branches?: boolean;\n\n  /**\n   * Enable for pull requests coming from this repo\n   * @default true\n   */\n  readonly pullRequests?: boolean;\n\n  /**\n   * Enable for pull requests coming from forks\n   * @default false\n   */\n  readonly pullRequestsFromForks?: boolean;\n\n  /**\n   * Add a check to pull requests\n   * @default true\n   */\n  readonly addCheck?: boolean;\n\n  /**\n   * Add a \"Review in Gitpod\" button as a comment to pull requests\n   * @default false\n   */\n  readonly addComment?: boolean;\n\n  /**\n   * Add a \"Review in Gitpod\" button to the pull request's description\n   * @default false\n   */\n  readonly addBadge?: boolean;\n\n  /**\n   * Add a label once the prebuild is ready to pull requests\n   * @default false\n   */\n  readonly addLabel?: boolean;\n}\n\n/**\n * Constructor options for the Gitpod component.\n *\n * By default, Gitpod uses the 'gitpod/workspace-full' docker image.\n * @see https://github.com/gitpod-io/workspace-images/blob/master/full/Dockerfile\n *\n * By default, all tasks will be run in parallel. To run the tasks in sequence,\n * create a new task and specify the other tasks as subtasks.\n */\nexport interface GitpodOptions extends DevEnvironmentOptions {\n  /**\n   * Optional Gitpod's Github App integration for prebuilds\n   * If this is not set and Gitpod's Github App is installed, then Gitpod will apply\n   * these defaults: https://www.gitpod.io/docs/prebuilds/#configure-the-github-app\n   * @default undefined\n   */\n  readonly prebuilds?: GitpodPrebuilds;\n}\n\n/**\n * The Gitpod component which emits .gitpod.yml\n */\nexport class Gitpod extends Component implements IDevEnvironment {\n  private dockerImage: DevEnvironmentDockerImage | undefined;\n  private prebuilds: GitpodPrebuilds | undefined;\n  private readonly tasks = new Array<GitpodTask>();\n  private readonly ports = new Array<GitpodPort>();\n  private readonly vscodeExtensions = new Array<string>();\n\n  /**\n   * Direct access to the gitpod configuration (escape hatch)\n   */\n  public readonly config: any;\n\n  constructor(project: Project, options: GitpodOptions = {}) {\n    super(project);\n\n    this.dockerImage = options?.dockerImage;\n\n    if (options?.tasks) {\n      for (const task of options.tasks) {\n        this.addTasks(task);\n      }\n    }\n\n    if (options?.prebuilds) {\n      this.addPrebuilds(options.prebuilds);\n    }\n\n    if (options?.ports) {\n      this.addPorts(...options.ports);\n    }\n\n    if (options?.vscodeExtensions) {\n      this.addVscodeExtensions(...options.vscodeExtensions);\n    }\n\n    this.config = {\n      image: () => this.renderDockerImage(),\n      tasks: this.tasks,\n      github: () => this.renderPrebuilds(),\n      ports: this.ports,\n      vscode: {\n        extensions: this.vscodeExtensions,\n      },\n    };\n\n    new YamlFile(this.project, GITPOD_FILE, {\n      obj: this.config,\n      omitEmpty: true,\n      // GitPod needs to read the file from the repository in order to work.\n      committed: true,\n    });\n  }\n\n  /**\n   * Add a custom Docker image or Dockerfile for the container.\n   *\n   * @param image The Docker image\n   */\n  public addDockerImage(image: DevEnvironmentDockerImage) {\n    if (this.dockerImage) {\n      throw new Error(\"dockerImage cannot be redefined.\");\n    }\n    this.dockerImage = image;\n  }\n\n  /**\n   * Add tasks to run when gitpod starts.\n   *\n   * By default, all tasks will be run in parallel. To run tasks in sequence,\n   * create a new `Task` and specify the other tasks as subtasks.\n   *\n   * @param tasks The new tasks\n   */\n  public addTasks(...tasks: Task[]) {\n    this.tasks.push(\n      ...tasks.map((task) => ({\n        name: task.name,\n        command: `npx projen ${task.name}`,\n      }))\n    );\n  }\n\n  /**\n   * Add a prebuilds configuration for the Gitpod App\n   * @param config The configuration\n   */\n  public addPrebuilds(config: GitpodPrebuilds) {\n    this.prebuilds = config;\n  }\n\n  /**\n   * Add a task with more granular options.\n   *\n   * By default, all tasks will be run in parallel. To run tasks in sequence,\n   * create a new `Task` and set the other tasks as subtasks.\n   *\n   * @param options The task parameters\n   */\n  public addCustomTask(options: GitpodTask) {\n    this.tasks.push({\n      name: options.name,\n      command: options.command,\n      openMode: options.openMode,\n      openIn: options.openIn,\n      before: options.before,\n      init: options.init,\n      prebuild: options.prebuild,\n    });\n  }\n\n  /**\n   * Add ports that should be exposed (forwarded) from the container.\n   *\n   * @param ports The new ports\n   */\n  public addPorts(...ports: string[]) {\n    this.ports.push(...ports.map((port) => ({ port: port })));\n  }\n\n  /**\n   * Add a list of VSCode extensions that should be automatically installed\n   * in the container.\n   *\n   * These must be in the format defined in the Open VSX registry.\n   * @example 'scala-lang.scala@0.3.9:O5XmjwY5Gz+0oDZAmqneJw=='\n   * @see https://www.gitpod.io/docs/vscode-extensions/\n   *\n   * @param extensions The extension IDs\n   */\n  public addVscodeExtensions(...extensions: GitpodCodeExtensionId[]) {\n    this.vscodeExtensions.push(...extensions);\n  }\n\n  private renderDockerImage() {\n    if (this.dockerImage?.image) {\n      return this.dockerImage.image;\n    } else if (this.dockerImage?.dockerFile) {\n      return {\n        file: this.dockerImage.dockerFile,\n      };\n    } else {\n      return undefined;\n    }\n  }\n\n  private renderPrebuilds() {\n    if (this.prebuilds) {\n      return {\n        prebuilds: this.prebuilds,\n      };\n    } else {\n      return undefined;\n    }\n  }\n}\n\n/**\n * VS Code extensions as defined in the Open VSX registry\n * Example: `scala-lang.scala@0.3.9:O5XmjwY5Gz+0oDZAmqneJw==`\n */\ntype GitpodCodeExtensionId = string;\n"]}