projen
Version:
CDK for software projects
80 lines • 13.7 kB
JavaScript
"use strict";
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.DockerComposeService = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const docker_compose_1 = require("./docker-compose");
/**
* A docker-compose service.
*/
class DockerComposeService {
constructor(serviceName, serviceDescription) {
if ((!serviceDescription.imageBuild && !serviceDescription.image) ||
(serviceDescription.imageBuild && serviceDescription.image)) {
throw new Error(`A service ${serviceName} requires exactly one of a \`imageBuild\` or \`image\` key`);
}
this.serviceName = serviceName;
this.command = serviceDescription.command;
this.image = serviceDescription.image;
this.imageBuild = serviceDescription.imageBuild;
this.dependsOn = serviceDescription.dependsOn ?? [];
this.volumes = serviceDescription.volumes ?? [];
this.networks = serviceDescription.networks ?? [];
this.ports = serviceDescription.ports ?? [];
this.environment = serviceDescription.environment ?? {};
this.labels = serviceDescription.labels ?? {};
this.entrypoint = serviceDescription.entrypoint;
this.platform = serviceDescription.platform;
this.privileged = serviceDescription.privileged;
}
/**
* Add a port mapping
* @param publishedPort Published port number
* @param targetPort Container's port number
* @param options Port mapping options
*/
addPort(publishedPort, targetPort, options) {
this.ports?.push(docker_compose_1.DockerCompose.portMapping(publishedPort, targetPort, options));
}
/**
* Add an environment variable
* @param name environment variable name
* @param value value of the environment variable
*/
addEnvironment(name, value) {
this.environment[name] = value;
}
/**
* Make the service depend on another service.
* @param serviceName
*/
addDependsOn(serviceName) {
this.dependsOn.push(serviceName);
}
/**
* Add a volume to the service.
* @param volume
*/
addVolume(volume) {
this.volumes.push(volume);
}
/**
* Add a network to the service.
* @param network
*/
addNetwork(network) {
this.networks.push(network);
}
/**
* Add a label
* @param name environment variable name
* @param value value of the environment variable
*/
addLabel(name, value) {
this.labels[name] = value;
}
}
exports.DockerComposeService = DockerComposeService;
_a = JSII_RTTI_SYMBOL_1;
DockerComposeService[_a] = { fqn: "projen.DockerComposeService", version: "0.99.17" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docker-compose-service.js","sourceRoot":"","sources":["../../src/docker-compose/docker-compose-service.ts"],"names":[],"mappings":";;;;;AAAA,qDAAqE;AAkBrE;;GAEG;AACH,MAAa,oBAAoB;IAiE/B,YACE,WAAmB,EACnB,kBAAmD;QAEnD,IACE,CAAC,CAAC,kBAAkB,CAAC,UAAU,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC;YAC7D,CAAC,kBAAkB,CAAC,UAAU,IAAI,kBAAkB,CAAC,KAAK,CAAC,EAC3D,CAAC;YACD,MAAM,IAAI,KAAK,CACb,aAAa,WAAW,4DAA4D,CACrF,CAAC;QACJ,CAAC;QAED,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,OAAO,GAAG,kBAAkB,CAAC,OAAO,CAAC;QAC1C,IAAI,CAAC,KAAK,GAAG,kBAAkB,CAAC,KAAK,CAAC;QACtC,IAAI,CAAC,UAAU,GAAG,kBAAkB,CAAC,UAAU,CAAC;QAChD,IAAI,CAAC,SAAS,GAAG,kBAAkB,CAAC,SAAS,IAAI,EAAE,CAAC;QACpD,IAAI,CAAC,OAAO,GAAG,kBAAkB,CAAC,OAAO,IAAI,EAAE,CAAC;QAChD,IAAI,CAAC,QAAQ,GAAG,kBAAkB,CAAC,QAAQ,IAAI,EAAE,CAAC;QAClD,IAAI,CAAC,KAAK,GAAG,kBAAkB,CAAC,KAAK,IAAI,EAAE,CAAC;QAC5C,IAAI,CAAC,WAAW,GAAG,kBAAkB,CAAC,WAAW,IAAI,EAAE,CAAC;QACxD,IAAI,CAAC,MAAM,GAAG,kBAAkB,CAAC,MAAM,IAAI,EAAE,CAAC;QAC9C,IAAI,CAAC,UAAU,GAAG,kBAAkB,CAAC,UAAU,CAAC;QAChD,IAAI,CAAC,QAAQ,GAAG,kBAAkB,CAAC,QAAQ,CAAC;QAC5C,IAAI,CAAC,UAAU,GAAG,kBAAkB,CAAC,UAAU,CAAC;IAClD,CAAC;IAED;;;;;OAKG;IACI,OAAO,CACZ,aAAqB,EACrB,UAAkB,EAClB,OAAyC;QAEzC,IAAI,CAAC,KAAK,EAAE,IAAI,CACd,8BAAa,CAAC,WAAW,CAAC,aAAa,EAAE,UAAU,EAAE,OAAO,CAAC,CAC9D,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACI,cAAc,CAAC,IAAY,EAAE,KAAa;QAC/C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC;IACjC,CAAC;IAED;;;OAGG;IACI,YAAY,CAAC,WAAsC;QACxD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACnC,CAAC;IAED;;;OAGG;IACI,SAAS,CAAC,MAAmC;QAClD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;IAED;;;OAGG;IACI,UAAU,CAAC,OAAqC;QACrD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC9B,CAAC;IAED;;;;OAIG;IACI,QAAQ,CAAC,IAAY,EAAE,KAAa;QACzC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC;IAC5B,CAAC;;AArJH,oDAsJC","sourcesContent":["import { DockerCompose, DockerComposeBuild } from \"./docker-compose\";\nimport { IDockerComposeNetworkBinding } from \"./docker-compose-network\";\nimport {\n  DockerComposePortMappingOptions,\n  DockerComposeServicePort,\n} from \"./docker-compose-port\";\nimport { IDockerComposeVolumeBinding } from \"./docker-compose-volume\";\n\n/**\n * An interface providing the name of a docker compose service.\n */\nexport interface IDockerComposeServiceName {\n  /**\n   * The name of the docker compose service.\n   */\n  readonly serviceName: string;\n}\n\n/**\n * A docker-compose service.\n */\nexport class DockerComposeService implements IDockerComposeServiceName {\n  /**\n   * Name of the service.\n   */\n  public readonly serviceName: string;\n\n  /**\n   * Docker image.\n   */\n  public readonly image?: string;\n\n  /**\n   * Docker image build instructions.\n   */\n  public readonly imageBuild?: DockerComposeBuild;\n\n  /**\n   * Command to run in the container.\n   */\n  public readonly command?: string[];\n\n  /**\n   * Entrypoint to run in the container.\n   */\n  public readonly entrypoint?: string[];\n\n  /**\n   * Other services that this service depends on.\n   */\n  public readonly dependsOn: IDockerComposeServiceName[];\n\n  /**\n   * Volumes mounted in the container.\n   */\n  public readonly volumes: IDockerComposeVolumeBinding[];\n\n  /**\n   * Networks mounted in the container.\n   */\n  public readonly networks: IDockerComposeNetworkBinding[];\n\n  /**\n   * Published ports.\n   */\n  public readonly ports: DockerComposeServicePort[];\n\n  /**\n   * Environment variables.\n   */\n  public readonly environment: Record<string, string>;\n\n  /**\n   * Attached labels.\n   */\n  public readonly labels: Record<string, string>;\n  /**\n   * Target platform\n   */\n  public readonly platform?: string;\n\n  /**\n   * Run in privileged mode\n   */\n  public readonly privileged?: boolean;\n\n  constructor(\n    serviceName: string,\n    serviceDescription: DockerComposeServiceDescription,\n  ) {\n    if (\n      (!serviceDescription.imageBuild && !serviceDescription.image) ||\n      (serviceDescription.imageBuild && serviceDescription.image)\n    ) {\n      throw new Error(\n        `A service ${serviceName} requires exactly one of a \\`imageBuild\\` or \\`image\\` key`,\n      );\n    }\n\n    this.serviceName = serviceName;\n    this.command = serviceDescription.command;\n    this.image = serviceDescription.image;\n    this.imageBuild = serviceDescription.imageBuild;\n    this.dependsOn = serviceDescription.dependsOn ?? [];\n    this.volumes = serviceDescription.volumes ?? [];\n    this.networks = serviceDescription.networks ?? [];\n    this.ports = serviceDescription.ports ?? [];\n    this.environment = serviceDescription.environment ?? {};\n    this.labels = serviceDescription.labels ?? {};\n    this.entrypoint = serviceDescription.entrypoint;\n    this.platform = serviceDescription.platform;\n    this.privileged = serviceDescription.privileged;\n  }\n\n  /**\n   * Add a port mapping\n   * @param publishedPort Published port number\n   * @param targetPort Container's port number\n   * @param options Port mapping options\n   */\n  public addPort(\n    publishedPort: number,\n    targetPort: number,\n    options?: DockerComposePortMappingOptions,\n  ) {\n    this.ports?.push(\n      DockerCompose.portMapping(publishedPort, targetPort, options),\n    );\n  }\n\n  /**\n   * Add an environment variable\n   * @param name environment variable name\n   * @param value value of the environment variable\n   */\n  public addEnvironment(name: string, value: string) {\n    this.environment[name] = value;\n  }\n\n  /**\n   * Make the service depend on another service.\n   * @param serviceName\n   */\n  public addDependsOn(serviceName: IDockerComposeServiceName) {\n    this.dependsOn.push(serviceName);\n  }\n\n  /**\n   * Add a volume to the service.\n   * @param volume\n   */\n  public addVolume(volume: IDockerComposeVolumeBinding) {\n    this.volumes.push(volume);\n  }\n\n  /**\n   * Add a network to the service.\n   * @param network\n   */\n  public addNetwork(network: IDockerComposeNetworkBinding) {\n    this.networks.push(network);\n  }\n\n  /**\n   * Add a label\n   * @param name environment variable name\n   * @param value value of the environment variable\n   */\n  public addLabel(name: string, value: string) {\n    this.labels[name] = value;\n  }\n}\n\n/**\n * Description of a docker-compose.yml service.\n */\nexport interface DockerComposeServiceDescription {\n  /**\n   * Use a docker image.\n   * Note: You must specify either `build` or `image` key.\n   * @see imageBuild\n   */\n  readonly image?: string;\n\n  /**\n   * Build a docker image.\n   * Note: You must specify either `imageBuild` or `image` key.\n   * @see image\n   */\n  readonly imageBuild?: DockerComposeBuild;\n\n  /**\n   * Provide a command to the docker container.\n   * @default - use the container's default command\n   */\n  readonly command?: string[];\n\n  /**\n   * Entrypoint to run in the container.\n   */\n  readonly entrypoint?: string[];\n\n  /**\n   * Names of other services this service depends on.\n   * @default - no dependencies\n   */\n  readonly dependsOn?: IDockerComposeServiceName[];\n\n  /**\n   * Mount some volumes into the service.\n   * Use one of the following to create volumes:\n   * @see DockerCompose.bindVolume() to mount a host path\n   * @see DockerCompose.namedVolume() to create & mount a named volume\n   */\n  readonly volumes?: IDockerComposeVolumeBinding[];\n\n  /**\n   * Add some networks to the service.\n   * @see DockerCompose.network() to create & mount a named network\n   */\n  readonly networks?: IDockerComposeNetworkBinding[];\n\n  /**\n   * Map some ports.\n   * @default - no ports are mapped\n   */\n  readonly ports?: DockerComposeServicePort[];\n\n  /**\n   * Add environment variables.\n   * @default - no environment variables are provided\n   */\n  readonly environment?: Record<string, string>;\n\n  /**\n   * Add labels.\n   * @default - no labels are provided\n   */\n  readonly labels?: Record<string, string>;\n  /**\n   * Add platform\n   * @default - no platform is provided\n   */\n  readonly platform?: string;\n\n  /**\n   * Run in privileged mode\n   * @default - no privileged mode flag is provided\n   */\n  readonly privileged?: boolean;\n}\n"]}