UNPKG

projen

Version:

CDK for software projects

80 lines 13.8 kB
"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.51" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docker-compose-service.js","sourceRoot":"","sources":["../../src/docker-compose/docker-compose-service.ts"],"names":[],"mappings":";;;;;AACA,qDAAiD;AAkBjD;;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 type { DockerComposeBuild } from \"./docker-compose\";\nimport { DockerCompose } from \"./docker-compose\";\nimport type { IDockerComposeNetworkBinding } from \"./docker-compose-network\";\nimport type {\n  DockerComposePortMappingOptions,\n  DockerComposeServicePort,\n} from \"./docker-compose-port\";\nimport type { 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"]}