@backstage/plugin-scaffolder-backend-module-cookiecutter 0.2.38-next.2 → 0.2.39

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,36 @@
1
1
  # @backstage/plugin-scaffolder-backend-module-cookiecutter
2
2
 
3
+ ## 0.2.39
4
+
5
+ ### Patch Changes
6
+
7
+ - Updated dependencies
8
+ - @backstage/backend-common@0.21.5
9
+ - @backstage/plugin-scaffolder-node@0.4.1
10
+ - @backstage/backend-plugin-api@0.6.15
11
+ - @backstage/config@1.2.0
12
+ - @backstage/errors@1.2.4
13
+ - @backstage/integration@1.9.1
14
+ - @backstage/types@1.1.1
15
+
16
+ ## 0.2.38
17
+
18
+ ### Patch Changes
19
+
20
+ - e9663a9: Move away from using `ctx.logStream`
21
+ - f44589d: Introduced `createMockActionContext` to unify the way of creating scaffolder mock context.
22
+
23
+ It will help to maintain tests in a long run during structural changes of action context.
24
+
25
+ - Updated dependencies
26
+ - @backstage/plugin-scaffolder-node@0.4.0
27
+ - @backstage/backend-common@0.21.4
28
+ - @backstage/integration@1.9.1
29
+ - @backstage/config@1.2.0
30
+ - @backstage/errors@1.2.4
31
+ - @backstage/backend-plugin-api@0.6.14
32
+ - @backstage/types@1.1.1
33
+
3
34
  ## 0.2.38-next.2
4
35
 
5
36
  ### Patch Changes
package/dist/index.cjs.js CHANGED
@@ -13,11 +13,11 @@ var backendPluginApi = require('@backstage/backend-plugin-api');
13
13
  var alpha = require('@backstage/plugin-scaffolder-node/alpha');
14
14
  var integration = require('@backstage/integration');
15
15
 
16
- function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
16
+ function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
17
17
 
18
- var commandExists__default = /*#__PURE__*/_interopDefaultLegacy(commandExists);
19
- var fs__default = /*#__PURE__*/_interopDefaultLegacy(fs);
20
- var path__default = /*#__PURE__*/_interopDefaultLegacy(path);
18
+ var commandExists__default = /*#__PURE__*/_interopDefaultCompat(commandExists);
19
+ var fs__default = /*#__PURE__*/_interopDefaultCompat(fs);
20
+ var path__default = /*#__PURE__*/_interopDefaultCompat(path);
21
21
 
22
22
  var __defProp = Object.defineProperty;
23
23
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
@@ -32,7 +32,7 @@ class CookiecutterRunner {
32
32
  }
33
33
  async fetchTemplateCookieCutter(directory) {
34
34
  try {
35
- return await fs__default["default"].readJSON(path__default["default"].join(directory, "cookiecutter.json"));
35
+ return await fs__default.default.readJSON(path__default.default.join(directory, "cookiecutter.json"));
36
36
  } catch (ex) {
37
37
  if (ex.code !== "ENOENT") {
38
38
  throw ex;
@@ -48,9 +48,9 @@ class CookiecutterRunner {
48
48
  templateDir,
49
49
  templateContentsDir
50
50
  }) {
51
- const intermediateDir = path__default["default"].join(workspacePath, "intermediate");
52
- await fs__default["default"].ensureDir(intermediateDir);
53
- const resultDir = path__default["default"].join(workspacePath, "result");
51
+ const intermediateDir = path__default.default.join(workspacePath, "intermediate");
52
+ await fs__default.default.ensureDir(intermediateDir);
53
+ const resultDir = path__default.default.join(workspacePath, "result");
54
54
  const cookieCutterJson = await this.fetchTemplateCookieCutter(
55
55
  templateContentsDir
56
56
  );
@@ -58,12 +58,12 @@ class CookiecutterRunner {
58
58
  ...cookieCutterJson,
59
59
  ...values
60
60
  };
61
- await fs__default["default"].writeJSON(path__default["default"].join(templateDir, "cookiecutter.json"), cookieInfo);
61
+ await fs__default.default.writeJSON(path__default.default.join(templateDir, "cookiecutter.json"), cookieInfo);
62
62
  const mountDirs = {
63
63
  [templateDir]: "/input",
64
64
  [intermediateDir]: "/output"
65
65
  };
66
- const cookieCutterInstalled = await commandExists__default["default"]("cookiecutter").catch(
66
+ const cookieCutterInstalled = await commandExists__default.default("cookiecutter").catch(
67
67
  () => false
68
68
  );
69
69
  if (cookieCutterInstalled) {
@@ -90,11 +90,11 @@ class CookiecutterRunner {
90
90
  logStream
91
91
  });
92
92
  }
93
- const [generated] = await fs__default["default"].readdir(intermediateDir);
93
+ const [generated] = await fs__default.default.readdir(intermediateDir);
94
94
  if (generated === void 0) {
95
95
  throw new Error("No data generated by cookiecutter");
96
96
  }
97
- await fs__default["default"].move(path__default["default"].join(intermediateDir, generated), resultDir);
97
+ await fs__default.default.move(path__default.default.join(intermediateDir, generated), resultDir);
98
98
  }
99
99
  }
100
100
  function createFetchCookiecutterAction(options) {
@@ -191,7 +191,7 @@ function createFetchCookiecutterAction(options) {
191
191
  });
192
192
  const targetPath = (_b = ctx.input.targetPath) != null ? _b : "./";
193
193
  const outputPath = backendCommon.resolveSafeChildPath(ctx.workspacePath, targetPath);
194
- await fs__default["default"].copy(resultDir, outputPath);
194
+ await fs__default.default.copy(resultDir, outputPath);
195
195
  }
196
196
  });
197
197
  }
@@ -217,5 +217,5 @@ const cookiecutterModule = backendPluginApi.createBackendModule({
217
217
  });
218
218
 
219
219
  exports.createFetchCookiecutterAction = createFetchCookiecutterAction;
220
- exports["default"] = cookiecutterModule;
220
+ exports.default = cookiecutterModule;
221
221
  //# sourceMappingURL=index.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs.js","sources":["../src/actions/fetch/cookiecutter.ts","../src/module.ts"],"sourcesContent":["/*\n * Copyright 2021 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n ContainerRunner,\n UrlReader,\n resolveSafeChildPath,\n} from '@backstage/backend-common';\nimport { JsonObject, JsonValue } from '@backstage/types';\nimport { InputError } from '@backstage/errors';\nimport { ScmIntegrations } from '@backstage/integration';\nimport commandExists from 'command-exists';\nimport fs from 'fs-extra';\nimport path, { resolve as resolvePath } from 'path';\nimport { PassThrough, Writable } from 'stream';\nimport {\n createTemplateAction,\n fetchContents,\n executeShellCommand,\n} from '@backstage/plugin-scaffolder-node';\n\nexport class CookiecutterRunner {\n private readonly containerRunner?: ContainerRunner;\n\n constructor({ containerRunner }: { containerRunner?: ContainerRunner }) {\n this.containerRunner = containerRunner;\n }\n\n private async fetchTemplateCookieCutter(\n directory: string,\n ): Promise<Record<string, JsonValue>> {\n try {\n return await fs.readJSON(path.join(directory, 'cookiecutter.json'));\n } catch (ex) {\n if (ex.code !== 'ENOENT') {\n throw ex;\n }\n\n return {};\n }\n }\n\n public async run({\n workspacePath,\n values,\n logStream,\n imageName,\n templateDir,\n templateContentsDir,\n }: {\n workspacePath: string;\n values: JsonObject;\n logStream: Writable;\n imageName?: string;\n templateDir: string;\n templateContentsDir: string;\n }): Promise<void> {\n const intermediateDir = path.join(workspacePath, 'intermediate');\n await fs.ensureDir(intermediateDir);\n const resultDir = path.join(workspacePath, 'result');\n\n // First lets grab the default cookiecutter.json file\n const cookieCutterJson = await this.fetchTemplateCookieCutter(\n templateContentsDir,\n );\n\n const cookieInfo = {\n ...cookieCutterJson,\n ...values,\n };\n\n await fs.writeJSON(path.join(templateDir, 'cookiecutter.json'), cookieInfo);\n\n // Directories to bind on container\n const mountDirs = {\n [templateDir]: '/input',\n [intermediateDir]: '/output',\n };\n\n // the command-exists package returns `true` or throws an error\n const cookieCutterInstalled = await commandExists('cookiecutter').catch(\n () => false,\n );\n if (cookieCutterInstalled) {\n await executeShellCommand({\n command: 'cookiecutter',\n args: ['--no-input', '-o', intermediateDir, templateDir, '--verbose'],\n logStream,\n });\n } else {\n if (this.containerRunner === undefined) {\n throw new Error(\n 'Invalid state: containerRunner cannot be undefined when cookiecutter is not installed',\n );\n }\n await this.containerRunner.runContainer({\n imageName: imageName ?? 'spotify/backstage-cookiecutter',\n command: 'cookiecutter',\n args: ['--no-input', '-o', '/output', '/input', '--verbose'],\n mountDirs,\n workingDir: '/input',\n // Set the home directory inside the container as something that applications can\n // write to, otherwise they will just fail trying to write to /\n envVars: { HOME: '/tmp' },\n logStream,\n });\n }\n\n // if cookiecutter was successful, intermediateDir will contain\n // exactly one directory.\n\n const [generated] = await fs.readdir(intermediateDir);\n\n if (generated === undefined) {\n throw new Error('No data generated by cookiecutter');\n }\n\n await fs.move(path.join(intermediateDir, generated), resultDir);\n }\n}\n\n/**\n * Creates a `fetch:cookiecutter` Scaffolder action.\n *\n * @remarks\n *\n * See {@link https://cookiecutter.readthedocs.io/} and {@link https://backstage.io/docs/features/software-templates/writing-custom-actions}.\n * @param options - Templating configuration.\n * @public\n */\nexport function createFetchCookiecutterAction(options: {\n reader: UrlReader;\n integrations: ScmIntegrations;\n containerRunner?: ContainerRunner;\n}) {\n const { reader, containerRunner, integrations } = options;\n\n return createTemplateAction<{\n url: string;\n targetPath?: string;\n values: JsonObject;\n copyWithoutRender?: string[];\n extensions?: string[];\n imageName?: string;\n }>({\n id: 'fetch:cookiecutter',\n description:\n 'Downloads a template from the given URL into the workspace, and runs cookiecutter on it.',\n schema: {\n input: {\n type: 'object',\n required: ['url'],\n properties: {\n url: {\n title: 'Fetch URL',\n description:\n 'Relative path or absolute URL pointing to the directory tree to fetch',\n type: 'string',\n },\n targetPath: {\n title: 'Target Path',\n description:\n 'Target path within the working directory to download the contents to.',\n type: 'string',\n },\n values: {\n title: 'Template Values',\n description: 'Values to pass on to cookiecutter for templating',\n type: 'object',\n },\n copyWithoutRender: {\n title: 'Copy Without Render',\n description:\n 'Avoid rendering directories and files in the template',\n type: 'array',\n items: {\n type: 'string',\n },\n },\n extensions: {\n title: 'Template Extensions',\n description:\n \"Jinja2 extensions to add filters, tests, globals or extend the parser. Extensions must be installed in the container or on the host where Cookiecutter executes. See the contrib directory in Backstage's repo for more information\",\n type: 'array',\n items: {\n type: 'string',\n },\n },\n imageName: {\n title: 'Cookiecutter Docker image',\n description:\n \"Specify a custom Docker image to run cookiecutter, to override the default: 'spotify/backstage-cookiecutter'. This can be used to execute cookiecutter with Template Extensions. Used only when a local cookiecutter is not found.\",\n type: 'string',\n },\n },\n },\n },\n async handler(ctx) {\n ctx.logger.info('Fetching and then templating using cookiecutter');\n const workDir = await ctx.createTemporaryDirectory();\n const templateDir = resolvePath(workDir, 'template');\n const templateContentsDir = resolvePath(\n templateDir,\n \"{{cookiecutter and 'contents'}}\",\n );\n const resultDir = resolvePath(workDir, 'result');\n\n if (\n ctx.input.copyWithoutRender &&\n !Array.isArray(ctx.input.copyWithoutRender)\n ) {\n throw new InputError(\n 'Fetch action input copyWithoutRender must be an Array',\n );\n }\n if (ctx.input.extensions && !Array.isArray(ctx.input.extensions)) {\n throw new InputError('Fetch action input extensions must be an Array');\n }\n\n await fetchContents({\n reader,\n integrations,\n baseUrl: ctx.templateInfo?.baseUrl,\n fetchUrl: ctx.input.url,\n outputPath: templateContentsDir,\n });\n\n const cookiecutter = new CookiecutterRunner({ containerRunner });\n const values = {\n ...ctx.input.values,\n _copy_without_render: ctx.input.copyWithoutRender,\n _extensions: ctx.input.extensions,\n };\n\n const logStream = new PassThrough();\n logStream.on('data', chunk => {\n ctx.logger.info(chunk.toString());\n });\n\n // Will execute the template in ./template and put the result in ./result\n await cookiecutter.run({\n workspacePath: workDir,\n logStream,\n values: values,\n imageName: ctx.input.imageName,\n templateDir: templateDir,\n templateContentsDir: templateContentsDir,\n });\n\n // Finally move the template result into the task workspace\n const targetPath = ctx.input.targetPath ?? './';\n const outputPath = resolveSafeChildPath(ctx.workspacePath, targetPath);\n await fs.copy(resultDir, outputPath);\n },\n });\n}\n","/*\n * Copyright 2024 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {\n coreServices,\n createBackendModule,\n} from '@backstage/backend-plugin-api';\nimport { scaffolderActionsExtensionPoint } from '@backstage/plugin-scaffolder-node/alpha';\nimport { createFetchCookiecutterAction } from './actions';\nimport { ScmIntegrations } from '@backstage/integration';\n\n/**\n * @public\n * The Cookiecutter Module for the Scaffolder Backend\n */\nexport const cookiecutterModule = createBackendModule({\n pluginId: 'scaffolder',\n moduleId: 'cookiecutter',\n register({ registerInit }) {\n registerInit({\n deps: {\n scaffolder: scaffolderActionsExtensionPoint,\n config: coreServices.rootConfig,\n reader: coreServices.urlReader,\n },\n async init({ scaffolder, config, reader }) {\n const integrations = ScmIntegrations.fromConfig(config);\n scaffolder.addActions(\n createFetchCookiecutterAction({ reader, integrations }),\n );\n },\n });\n },\n});\n"],"names":["fs","path","commandExists","executeShellCommand","createTemplateAction","resolvePath","InputError","fetchContents","PassThrough","resolveSafeChildPath","createBackendModule","scaffolderActionsExtensionPoint","coreServices","ScmIntegrations"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAkCO,MAAM,kBAAmB,CAAA;AAAA,EAG9B,WAAA,CAAY,EAAE,eAAA,EAA0D,EAAA;AAFxE,IAAiB,aAAA,CAAA,IAAA,EAAA,iBAAA,CAAA,CAAA;AAGf,IAAA,IAAA,CAAK,eAAkB,GAAA,eAAA,CAAA;AAAA,GACzB;AAAA,EAEA,MAAc,0BACZ,SACoC,EAAA;AACpC,IAAI,IAAA;AACF,MAAA,OAAO,MAAMA,sBAAG,CAAA,QAAA,CAASC,yBAAK,IAAK,CAAA,SAAA,EAAW,mBAAmB,CAAC,CAAA,CAAA;AAAA,aAC3D,EAAI,EAAA;AACX,MAAI,IAAA,EAAA,CAAG,SAAS,QAAU,EAAA;AACxB,QAAM,MAAA,EAAA,CAAA;AAAA,OACR;AAEA,MAAA,OAAO,EAAC,CAAA;AAAA,KACV;AAAA,GACF;AAAA,EAEA,MAAa,GAAI,CAAA;AAAA,IACf,aAAA;AAAA,IACA,MAAA;AAAA,IACA,SAAA;AAAA,IACA,SAAA;AAAA,IACA,WAAA;AAAA,IACA,mBAAA;AAAA,GAQgB,EAAA;AAChB,IAAA,MAAM,eAAkB,GAAAA,wBAAA,CAAK,IAAK,CAAA,aAAA,EAAe,cAAc,CAAA,CAAA;AAC/D,IAAM,MAAAD,sBAAA,CAAG,UAAU,eAAe,CAAA,CAAA;AAClC,IAAA,MAAM,SAAY,GAAAC,wBAAA,CAAK,IAAK,CAAA,aAAA,EAAe,QAAQ,CAAA,CAAA;AAGnD,IAAM,MAAA,gBAAA,GAAmB,MAAM,IAAK,CAAA,yBAAA;AAAA,MAClC,mBAAA;AAAA,KACF,CAAA;AAEA,IAAA,MAAM,UAAa,GAAA;AAAA,MACjB,GAAG,gBAAA;AAAA,MACH,GAAG,MAAA;AAAA,KACL,CAAA;AAEA,IAAA,MAAMD,uBAAG,SAAU,CAAAC,wBAAA,CAAK,KAAK,WAAa,EAAA,mBAAmB,GAAG,UAAU,CAAA,CAAA;AAG1E,IAAA,MAAM,SAAY,GAAA;AAAA,MAChB,CAAC,WAAW,GAAG,QAAA;AAAA,MACf,CAAC,eAAe,GAAG,SAAA;AAAA,KACrB,CAAA;AAGA,IAAA,MAAM,qBAAwB,GAAA,MAAMC,iCAAc,CAAA,cAAc,CAAE,CAAA,KAAA;AAAA,MAChE,MAAM,KAAA;AAAA,KACR,CAAA;AACA,IAAA,IAAI,qBAAuB,EAAA;AACzB,MAAA,MAAMC,wCAAoB,CAAA;AAAA,QACxB,OAAS,EAAA,cAAA;AAAA,QACT,MAAM,CAAC,YAAA,EAAc,IAAM,EAAA,eAAA,EAAiB,aAAa,WAAW,CAAA;AAAA,QACpE,SAAA;AAAA,OACD,CAAA,CAAA;AAAA,KACI,MAAA;AACL,MAAI,IAAA,IAAA,CAAK,oBAAoB,KAAW,CAAA,EAAA;AACtC,QAAA,MAAM,IAAI,KAAA;AAAA,UACR,uFAAA;AAAA,SACF,CAAA;AAAA,OACF;AACA,MAAM,MAAA,IAAA,CAAK,gBAAgB,YAAa,CAAA;AAAA,QACtC,WAAW,SAAa,IAAA,IAAA,GAAA,SAAA,GAAA,gCAAA;AAAA,QACxB,OAAS,EAAA,cAAA;AAAA,QACT,MAAM,CAAC,YAAA,EAAc,IAAM,EAAA,SAAA,EAAW,UAAU,WAAW,CAAA;AAAA,QAC3D,SAAA;AAAA,QACA,UAAY,EAAA,QAAA;AAAA;AAAA;AAAA,QAGZ,OAAA,EAAS,EAAE,IAAA,EAAM,MAAO,EAAA;AAAA,QACxB,SAAA;AAAA,OACD,CAAA,CAAA;AAAA,KACH;AAKA,IAAA,MAAM,CAAC,SAAS,CAAA,GAAI,MAAMH,sBAAA,CAAG,QAAQ,eAAe,CAAA,CAAA;AAEpD,IAAA,IAAI,cAAc,KAAW,CAAA,EAAA;AAC3B,MAAM,MAAA,IAAI,MAAM,mCAAmC,CAAA,CAAA;AAAA,KACrD;AAEA,IAAA,MAAMA,uBAAG,IAAK,CAAAC,wBAAA,CAAK,KAAK,eAAiB,EAAA,SAAS,GAAG,SAAS,CAAA,CAAA;AAAA,GAChE;AACF,CAAA;AAWO,SAAS,8BAA8B,OAI3C,EAAA;AACD,EAAA,MAAM,EAAE,MAAA,EAAQ,eAAiB,EAAA,YAAA,EAAiB,GAAA,OAAA,CAAA;AAElD,EAAA,OAAOG,yCAOJ,CAAA;AAAA,IACD,EAAI,EAAA,oBAAA;AAAA,IACJ,WACE,EAAA,0FAAA;AAAA,IACF,MAAQ,EAAA;AAAA,MACN,KAAO,EAAA;AAAA,QACL,IAAM,EAAA,QAAA;AAAA,QACN,QAAA,EAAU,CAAC,KAAK,CAAA;AAAA,QAChB,UAAY,EAAA;AAAA,UACV,GAAK,EAAA;AAAA,YACH,KAAO,EAAA,WAAA;AAAA,YACP,WACE,EAAA,uEAAA;AAAA,YACF,IAAM,EAAA,QAAA;AAAA,WACR;AAAA,UACA,UAAY,EAAA;AAAA,YACV,KAAO,EAAA,aAAA;AAAA,YACP,WACE,EAAA,uEAAA;AAAA,YACF,IAAM,EAAA,QAAA;AAAA,WACR;AAAA,UACA,MAAQ,EAAA;AAAA,YACN,KAAO,EAAA,iBAAA;AAAA,YACP,WAAa,EAAA,kDAAA;AAAA,YACb,IAAM,EAAA,QAAA;AAAA,WACR;AAAA,UACA,iBAAmB,EAAA;AAAA,YACjB,KAAO,EAAA,qBAAA;AAAA,YACP,WACE,EAAA,uDAAA;AAAA,YACF,IAAM,EAAA,OAAA;AAAA,YACN,KAAO,EAAA;AAAA,cACL,IAAM,EAAA,QAAA;AAAA,aACR;AAAA,WACF;AAAA,UACA,UAAY,EAAA;AAAA,YACV,KAAO,EAAA,qBAAA;AAAA,YACP,WACE,EAAA,qOAAA;AAAA,YACF,IAAM,EAAA,OAAA;AAAA,YACN,KAAO,EAAA;AAAA,cACL,IAAM,EAAA,QAAA;AAAA,aACR;AAAA,WACF;AAAA,UACA,SAAW,EAAA;AAAA,YACT,KAAO,EAAA,2BAAA;AAAA,YACP,WACE,EAAA,oOAAA;AAAA,YACF,IAAM,EAAA,QAAA;AAAA,WACR;AAAA,SACF;AAAA,OACF;AAAA,KACF;AAAA,IACA,MAAM,QAAQ,GAAK,EAAA;AAlNvB,MAAA,IAAA,EAAA,EAAA,EAAA,CAAA;AAmNM,MAAI,GAAA,CAAA,MAAA,CAAO,KAAK,iDAAiD,CAAA,CAAA;AACjE,MAAM,MAAA,OAAA,GAAU,MAAM,GAAA,CAAI,wBAAyB,EAAA,CAAA;AACnD,MAAM,MAAA,WAAA,GAAcC,YAAY,CAAA,OAAA,EAAS,UAAU,CAAA,CAAA;AACnD,MAAA,MAAM,mBAAsB,GAAAA,YAAA;AAAA,QAC1B,WAAA;AAAA,QACA,iCAAA;AAAA,OACF,CAAA;AACA,MAAM,MAAA,SAAA,GAAYA,YAAY,CAAA,OAAA,EAAS,QAAQ,CAAA,CAAA;AAE/C,MACE,IAAA,GAAA,CAAI,MAAM,iBACV,IAAA,CAAC,MAAM,OAAQ,CAAA,GAAA,CAAI,KAAM,CAAA,iBAAiB,CAC1C,EAAA;AACA,QAAA,MAAM,IAAIC,iBAAA;AAAA,UACR,uDAAA;AAAA,SACF,CAAA;AAAA,OACF;AACA,MAAI,IAAA,GAAA,CAAI,MAAM,UAAc,IAAA,CAAC,MAAM,OAAQ,CAAA,GAAA,CAAI,KAAM,CAAA,UAAU,CAAG,EAAA;AAChE,QAAM,MAAA,IAAIA,kBAAW,gDAAgD,CAAA,CAAA;AAAA,OACvE;AAEA,MAAA,MAAMC,kCAAc,CAAA;AAAA,QAClB,MAAA;AAAA,QACA,YAAA;AAAA,QACA,OAAA,EAAA,CAAS,EAAI,GAAA,GAAA,CAAA,YAAA,KAAJ,IAAkB,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,OAAA;AAAA,QAC3B,QAAA,EAAU,IAAI,KAAM,CAAA,GAAA;AAAA,QACpB,UAAY,EAAA,mBAAA;AAAA,OACb,CAAA,CAAA;AAED,MAAA,MAAM,YAAe,GAAA,IAAI,kBAAmB,CAAA,EAAE,iBAAiB,CAAA,CAAA;AAC/D,MAAA,MAAM,MAAS,GAAA;AAAA,QACb,GAAG,IAAI,KAAM,CAAA,MAAA;AAAA,QACb,oBAAA,EAAsB,IAAI,KAAM,CAAA,iBAAA;AAAA,QAChC,WAAA,EAAa,IAAI,KAAM,CAAA,UAAA;AAAA,OACzB,CAAA;AAEA,MAAM,MAAA,SAAA,GAAY,IAAIC,kBAAY,EAAA,CAAA;AAClC,MAAU,SAAA,CAAA,EAAA,CAAG,QAAQ,CAAS,KAAA,KAAA;AAC5B,QAAA,GAAA,CAAI,MAAO,CAAA,IAAA,CAAK,KAAM,CAAA,QAAA,EAAU,CAAA,CAAA;AAAA,OACjC,CAAA,CAAA;AAGD,MAAA,MAAM,aAAa,GAAI,CAAA;AAAA,QACrB,aAAe,EAAA,OAAA;AAAA,QACf,SAAA;AAAA,QACA,MAAA;AAAA,QACA,SAAA,EAAW,IAAI,KAAM,CAAA,SAAA;AAAA,QACrB,WAAA;AAAA,QACA,mBAAA;AAAA,OACD,CAAA,CAAA;AAGD,MAAA,MAAM,UAAa,GAAA,CAAA,EAAA,GAAA,GAAA,CAAI,KAAM,CAAA,UAAA,KAAV,IAAwB,GAAA,EAAA,GAAA,IAAA,CAAA;AAC3C,MAAA,MAAM,UAAa,GAAAC,kCAAA,CAAqB,GAAI,CAAA,aAAA,EAAe,UAAU,CAAA,CAAA;AACrE,MAAM,MAAAT,sBAAA,CAAG,IAAK,CAAA,SAAA,EAAW,UAAU,CAAA,CAAA;AAAA,KACrC;AAAA,GACD,CAAA,CAAA;AACH;;ACjPO,MAAM,qBAAqBU,oCAAoB,CAAA;AAAA,EACpD,QAAU,EAAA,YAAA;AAAA,EACV,QAAU,EAAA,cAAA;AAAA,EACV,QAAA,CAAS,EAAE,YAAA,EAAgB,EAAA;AACzB,IAAa,YAAA,CAAA;AAAA,MACX,IAAM,EAAA;AAAA,QACJ,UAAY,EAAAC,qCAAA;AAAA,QACZ,QAAQC,6BAAa,CAAA,UAAA;AAAA,QACrB,QAAQA,6BAAa,CAAA,SAAA;AAAA,OACvB;AAAA,MACA,MAAM,IAAK,CAAA,EAAE,UAAY,EAAA,MAAA,EAAQ,QAAU,EAAA;AACzC,QAAM,MAAA,YAAA,GAAeC,2BAAgB,CAAA,UAAA,CAAW,MAAM,CAAA,CAAA;AACtD,QAAW,UAAA,CAAA,UAAA;AAAA,UACT,6BAA8B,CAAA,EAAE,MAAQ,EAAA,YAAA,EAAc,CAAA;AAAA,SACxD,CAAA;AAAA,OACF;AAAA,KACD,CAAA,CAAA;AAAA,GACH;AACF,CAAC;;;;;"}
1
+ {"version":3,"file":"index.cjs.js","sources":["../src/actions/fetch/cookiecutter.ts","../src/module.ts"],"sourcesContent":["/*\n * Copyright 2021 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n ContainerRunner,\n UrlReader,\n resolveSafeChildPath,\n} from '@backstage/backend-common';\nimport { JsonObject, JsonValue } from '@backstage/types';\nimport { InputError } from '@backstage/errors';\nimport { ScmIntegrations } from '@backstage/integration';\nimport commandExists from 'command-exists';\nimport fs from 'fs-extra';\nimport path, { resolve as resolvePath } from 'path';\nimport { PassThrough, Writable } from 'stream';\nimport {\n createTemplateAction,\n fetchContents,\n executeShellCommand,\n} from '@backstage/plugin-scaffolder-node';\n\nexport class CookiecutterRunner {\n private readonly containerRunner?: ContainerRunner;\n\n constructor({ containerRunner }: { containerRunner?: ContainerRunner }) {\n this.containerRunner = containerRunner;\n }\n\n private async fetchTemplateCookieCutter(\n directory: string,\n ): Promise<Record<string, JsonValue>> {\n try {\n return await fs.readJSON(path.join(directory, 'cookiecutter.json'));\n } catch (ex) {\n if (ex.code !== 'ENOENT') {\n throw ex;\n }\n\n return {};\n }\n }\n\n public async run({\n workspacePath,\n values,\n logStream,\n imageName,\n templateDir,\n templateContentsDir,\n }: {\n workspacePath: string;\n values: JsonObject;\n logStream: Writable;\n imageName?: string;\n templateDir: string;\n templateContentsDir: string;\n }): Promise<void> {\n const intermediateDir = path.join(workspacePath, 'intermediate');\n await fs.ensureDir(intermediateDir);\n const resultDir = path.join(workspacePath, 'result');\n\n // First lets grab the default cookiecutter.json file\n const cookieCutterJson = await this.fetchTemplateCookieCutter(\n templateContentsDir,\n );\n\n const cookieInfo = {\n ...cookieCutterJson,\n ...values,\n };\n\n await fs.writeJSON(path.join(templateDir, 'cookiecutter.json'), cookieInfo);\n\n // Directories to bind on container\n const mountDirs = {\n [templateDir]: '/input',\n [intermediateDir]: '/output',\n };\n\n // the command-exists package returns `true` or throws an error\n const cookieCutterInstalled = await commandExists('cookiecutter').catch(\n () => false,\n );\n if (cookieCutterInstalled) {\n await executeShellCommand({\n command: 'cookiecutter',\n args: ['--no-input', '-o', intermediateDir, templateDir, '--verbose'],\n logStream,\n });\n } else {\n if (this.containerRunner === undefined) {\n throw new Error(\n 'Invalid state: containerRunner cannot be undefined when cookiecutter is not installed',\n );\n }\n await this.containerRunner.runContainer({\n imageName: imageName ?? 'spotify/backstage-cookiecutter',\n command: 'cookiecutter',\n args: ['--no-input', '-o', '/output', '/input', '--verbose'],\n mountDirs,\n workingDir: '/input',\n // Set the home directory inside the container as something that applications can\n // write to, otherwise they will just fail trying to write to /\n envVars: { HOME: '/tmp' },\n logStream,\n });\n }\n\n // if cookiecutter was successful, intermediateDir will contain\n // exactly one directory.\n\n const [generated] = await fs.readdir(intermediateDir);\n\n if (generated === undefined) {\n throw new Error('No data generated by cookiecutter');\n }\n\n await fs.move(path.join(intermediateDir, generated), resultDir);\n }\n}\n\n/**\n * Creates a `fetch:cookiecutter` Scaffolder action.\n *\n * @remarks\n *\n * See {@link https://cookiecutter.readthedocs.io/} and {@link https://backstage.io/docs/features/software-templates/writing-custom-actions}.\n * @param options - Templating configuration.\n * @public\n */\nexport function createFetchCookiecutterAction(options: {\n reader: UrlReader;\n integrations: ScmIntegrations;\n containerRunner?: ContainerRunner;\n}) {\n const { reader, containerRunner, integrations } = options;\n\n return createTemplateAction<{\n url: string;\n targetPath?: string;\n values: JsonObject;\n copyWithoutRender?: string[];\n extensions?: string[];\n imageName?: string;\n }>({\n id: 'fetch:cookiecutter',\n description:\n 'Downloads a template from the given URL into the workspace, and runs cookiecutter on it.',\n schema: {\n input: {\n type: 'object',\n required: ['url'],\n properties: {\n url: {\n title: 'Fetch URL',\n description:\n 'Relative path or absolute URL pointing to the directory tree to fetch',\n type: 'string',\n },\n targetPath: {\n title: 'Target Path',\n description:\n 'Target path within the working directory to download the contents to.',\n type: 'string',\n },\n values: {\n title: 'Template Values',\n description: 'Values to pass on to cookiecutter for templating',\n type: 'object',\n },\n copyWithoutRender: {\n title: 'Copy Without Render',\n description:\n 'Avoid rendering directories and files in the template',\n type: 'array',\n items: {\n type: 'string',\n },\n },\n extensions: {\n title: 'Template Extensions',\n description:\n \"Jinja2 extensions to add filters, tests, globals or extend the parser. Extensions must be installed in the container or on the host where Cookiecutter executes. See the contrib directory in Backstage's repo for more information\",\n type: 'array',\n items: {\n type: 'string',\n },\n },\n imageName: {\n title: 'Cookiecutter Docker image',\n description:\n \"Specify a custom Docker image to run cookiecutter, to override the default: 'spotify/backstage-cookiecutter'. This can be used to execute cookiecutter with Template Extensions. Used only when a local cookiecutter is not found.\",\n type: 'string',\n },\n },\n },\n },\n async handler(ctx) {\n ctx.logger.info('Fetching and then templating using cookiecutter');\n const workDir = await ctx.createTemporaryDirectory();\n const templateDir = resolvePath(workDir, 'template');\n const templateContentsDir = resolvePath(\n templateDir,\n \"{{cookiecutter and 'contents'}}\",\n );\n const resultDir = resolvePath(workDir, 'result');\n\n if (\n ctx.input.copyWithoutRender &&\n !Array.isArray(ctx.input.copyWithoutRender)\n ) {\n throw new InputError(\n 'Fetch action input copyWithoutRender must be an Array',\n );\n }\n if (ctx.input.extensions && !Array.isArray(ctx.input.extensions)) {\n throw new InputError('Fetch action input extensions must be an Array');\n }\n\n await fetchContents({\n reader,\n integrations,\n baseUrl: ctx.templateInfo?.baseUrl,\n fetchUrl: ctx.input.url,\n outputPath: templateContentsDir,\n });\n\n const cookiecutter = new CookiecutterRunner({ containerRunner });\n const values = {\n ...ctx.input.values,\n _copy_without_render: ctx.input.copyWithoutRender,\n _extensions: ctx.input.extensions,\n };\n\n const logStream = new PassThrough();\n logStream.on('data', chunk => {\n ctx.logger.info(chunk.toString());\n });\n\n // Will execute the template in ./template and put the result in ./result\n await cookiecutter.run({\n workspacePath: workDir,\n logStream,\n values: values,\n imageName: ctx.input.imageName,\n templateDir: templateDir,\n templateContentsDir: templateContentsDir,\n });\n\n // Finally move the template result into the task workspace\n const targetPath = ctx.input.targetPath ?? './';\n const outputPath = resolveSafeChildPath(ctx.workspacePath, targetPath);\n await fs.copy(resultDir, outputPath);\n },\n });\n}\n","/*\n * Copyright 2024 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {\n coreServices,\n createBackendModule,\n} from '@backstage/backend-plugin-api';\nimport { scaffolderActionsExtensionPoint } from '@backstage/plugin-scaffolder-node/alpha';\nimport { createFetchCookiecutterAction } from './actions';\nimport { ScmIntegrations } from '@backstage/integration';\n\n/**\n * @public\n * The Cookiecutter Module for the Scaffolder Backend\n */\nexport const cookiecutterModule = createBackendModule({\n pluginId: 'scaffolder',\n moduleId: 'cookiecutter',\n register({ registerInit }) {\n registerInit({\n deps: {\n scaffolder: scaffolderActionsExtensionPoint,\n config: coreServices.rootConfig,\n reader: coreServices.urlReader,\n },\n async init({ scaffolder, config, reader }) {\n const integrations = ScmIntegrations.fromConfig(config);\n scaffolder.addActions(\n createFetchCookiecutterAction({ reader, integrations }),\n );\n },\n });\n },\n});\n"],"names":["fs","path","commandExists","executeShellCommand","createTemplateAction","resolvePath","InputError","fetchContents","PassThrough","resolveSafeChildPath","createBackendModule","scaffolderActionsExtensionPoint","coreServices","ScmIntegrations"],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@backstage/plugin-scaffolder-backend-module-cookiecutter",
3
3
  "description": "A module for the scaffolder backend that lets you template projects using cookiecutter",
4
- "version": "0.2.38-next.2",
4
+ "version": "0.2.39",
5
5
  "main": "./dist/index.cjs.js",
6
6
  "types": "./dist/index.d.ts",
7
7
  "license": "Apache-2.0",
@@ -35,12 +35,12 @@
35
35
  "clean": "backstage-cli package clean"
36
36
  },
37
37
  "dependencies": {
38
- "@backstage/backend-common": "^0.21.4-next.2",
39
- "@backstage/backend-plugin-api": "^0.6.14-next.2",
40
- "@backstage/config": "^1.2.0-next.1",
41
- "@backstage/errors": "^1.2.4-next.0",
42
- "@backstage/integration": "^1.9.1-next.2",
43
- "@backstage/plugin-scaffolder-node": "^0.4.0-next.2",
38
+ "@backstage/backend-common": "^0.21.5",
39
+ "@backstage/backend-plugin-api": "^0.6.15",
40
+ "@backstage/config": "^1.2.0",
41
+ "@backstage/errors": "^1.2.4",
42
+ "@backstage/integration": "^1.9.1",
43
+ "@backstage/plugin-scaffolder-node": "^0.4.1",
44
44
  "@backstage/types": "^1.1.1",
45
45
  "command-exists": "^1.2.9",
46
46
  "fs-extra": "^11.2.0",
@@ -48,9 +48,9 @@
48
48
  "yn": "^4.0.0"
49
49
  },
50
50
  "devDependencies": {
51
- "@backstage/backend-test-utils": "^0.3.4-next.2",
52
- "@backstage/cli": "^0.25.3-next.2",
53
- "@backstage/plugin-scaffolder-node-test-utils": "^0.1.0-next.2",
51
+ "@backstage/backend-test-utils": "^0.3.5",
52
+ "@backstage/cli": "^0.26.1",
53
+ "@backstage/plugin-scaffolder-node-test-utils": "^0.1.1",
54
54
  "@types/command-exists": "^1.2.0",
55
55
  "@types/fs-extra": "^11.0.0"
56
56
  },