@backstage/plugin-scaffolder-backend-module-confluence-to-markdown 0.2.15 → 0.2.16

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,17 @@
1
1
  # @backstage/plugin-scaffolder-backend-module-confluence-to-markdown
2
2
 
3
+ ## 0.2.16
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
+
3
15
  ## 0.2.15
4
16
 
5
17
  ### Patch Changes
package/dist/index.cjs.js CHANGED
@@ -13,12 +13,12 @@ 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 fs__default = /*#__PURE__*/_interopDefaultLegacy(fs);
19
- var parseGitUrl__default = /*#__PURE__*/_interopDefaultLegacy(parseGitUrl);
20
- var YAML__default = /*#__PURE__*/_interopDefaultLegacy(YAML);
21
- var fetch__default = /*#__PURE__*/_interopDefaultLegacy(fetch);
18
+ var fs__default = /*#__PURE__*/_interopDefaultCompat(fs);
19
+ var parseGitUrl__default = /*#__PURE__*/_interopDefaultCompat(parseGitUrl);
20
+ var YAML__default = /*#__PURE__*/_interopDefaultCompat(YAML);
21
+ var fetch__default = /*#__PURE__*/_interopDefaultCompat(fetch);
22
22
 
23
23
  const getConfluenceConfig = (config) => {
24
24
  var _a;
@@ -67,14 +67,14 @@ const getAuthorizationHeaderValue = (config) => {
67
67
  }
68
68
  };
69
69
  const readFileAsString = async (fileDir) => {
70
- const content = await fs__default["default"].readFile(fileDir, "utf-8");
70
+ const content = await fs__default.default.readFile(fileDir, "utf-8");
71
71
  return content.toString();
72
72
  };
73
73
  const fetchConfluence = async (relativeUrl, config) => {
74
74
  const baseUrl = config.baseUrl;
75
75
  const authHeaderValue = getAuthorizationHeaderValue(config);
76
76
  const url = `${baseUrl}${relativeUrl}`;
77
- const response = await fetch__default["default"](url, {
77
+ const response = await fetch__default.default(url, {
78
78
  method: "GET",
79
79
  headers: {
80
80
  Authorization: authHeaderValue
@@ -97,7 +97,7 @@ const getAndWriteAttachments = async (arr, workspace, config, mkdocsDir) => {
97
97
  productArr.push([result.title.replace(/ /g, "%20"), downloadTitle]);
98
98
  }
99
99
  const url = `${baseUrl}${downloadLink}`;
100
- const res = await fetch__default["default"](url, {
100
+ const res = await fetch__default.default(url, {
101
101
  method: "GET",
102
102
  headers: {
103
103
  Authorization: authHeaderValue
@@ -106,8 +106,8 @@ const getAndWriteAttachments = async (arr, workspace, config, mkdocsDir) => {
106
106
  if (!res.ok) {
107
107
  throw await errors.ResponseError.fromResponse(res);
108
108
  } else if (res.body !== null) {
109
- fs__default["default"].openSync(`${workspace}/${mkdocsDir}docs/img/${downloadTitle}`, "w");
110
- const writeStream = fs__default["default"].createWriteStream(
109
+ fs__default.default.openSync(`${workspace}/${mkdocsDir}docs/img/${downloadTitle}`, "w");
110
+ const writeStream = fs__default.default.createWriteStream(
111
111
  `${workspace}/${mkdocsDir}docs/img/${downloadTitle}`
112
112
  );
113
113
  res.body.pipe(writeStream);
@@ -155,7 +155,7 @@ const createConfluenceVariables = (url) => {
155
155
  const examples = [
156
156
  {
157
157
  description: "Downloads content from provided Confluence URLs and converts it to Markdown.",
158
- example: YAML__default["default"].stringify({
158
+ example: YAML__default.default.stringify({
159
159
  steps: [
160
160
  {
161
161
  action: "confluence:transform:markdown",
@@ -203,7 +203,7 @@ const createConfluenceToMarkdownAction = (options) => {
203
203
  var _a;
204
204
  const confluenceConfig = getConfluenceConfig(config);
205
205
  const { confluenceUrls, repoUrl } = ctx.input;
206
- const parsedRepoUrl = parseGitUrl__default["default"](repoUrl);
206
+ const parsedRepoUrl = parseGitUrl__default.default(repoUrl);
207
207
  const filePathToMkdocs = parsedRepoUrl.filepath.substring(
208
208
  0,
209
209
  parsedRepoUrl.filepath.lastIndexOf("/") + 1
@@ -236,7 +236,7 @@ const createConfluenceToMarkdownAction = (options) => {
236
236
  confluenceConfig
237
237
  );
238
238
  if (getDocAttachments.results.length) {
239
- fs__default["default"].mkdirSync(`${dirPath}/${filePathToMkdocs}docs/img`, {
239
+ fs__default.default.mkdirSync(`${dirPath}/${filePathToMkdocs}docs/img`, {
240
240
  recursive: true
241
241
  });
242
242
  productArray = await getAndWriteAttachments(
@@ -250,7 +250,7 @@ const createConfluenceToMarkdownAction = (options) => {
250
250
  `starting action for converting ${titleWithSpaces} from Confluence To Markdown`
251
251
  );
252
252
  const mkdocsFileContent = await readFileAsString(repoFileDir);
253
- const mkdocsFile = await YAML__default["default"].parse(mkdocsFileContent);
253
+ const mkdocsFile = await YAML__default.default.parse(mkdocsFileContent);
254
254
  ctx.logger.info(
255
255
  `Adding new file - ${titleWithSpaces} to the current mkdocs.yml file`
256
256
  );
@@ -267,7 +267,7 @@ const createConfluenceToMarkdownAction = (options) => {
267
267
  );
268
268
  }
269
269
  }
270
- await fs__default["default"].writeFile(repoFileDir, YAML__default["default"].stringify(mkdocsFile));
270
+ await fs__default.default.writeFile(repoFileDir, YAML__default.default.stringify(mkdocsFile));
271
271
  const html = getConfluenceDoc.results[0].body.export_view.value;
272
272
  const markdownToPublish = nodeHtmlMarkdown.NodeHtmlMarkdown.translate(html);
273
273
  let newString = markdownToPublish;
@@ -276,7 +276,7 @@ const createConfluenceToMarkdownAction = (options) => {
276
276
  newString = newString.replace(regex, `$1./img/${product[1]}$3`);
277
277
  });
278
278
  ctx.logger.info(`Adding new file to repo.`);
279
- await fs__default["default"].outputFile(
279
+ await fs__default.default.outputFile(
280
280
  `${dirPath}/${filePathToMkdocs}docs/${titleWithSpaces.replace(
281
281
  /\s+/g,
282
282
  "-"
@@ -315,5 +315,5 @@ const confluenceToMarkdownModule = backendPluginApi.createBackendModule({
315
315
  });
316
316
 
317
317
  exports.createConfluenceToMarkdownAction = createConfluenceToMarkdownAction;
318
- exports["default"] = confluenceToMarkdownModule;
318
+ exports.default = confluenceToMarkdownModule;
319
319
  //# sourceMappingURL=index.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs.js","sources":["../src/actions/confluence/helpers.ts","../src/actions/confluence/confluenceToMarkdown.examples.ts","../src/actions/confluence/confluenceToMarkdown.ts","../src/module.ts"],"sourcesContent":["/*\n * Copyright 2023 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 { Config } from '@backstage/config';\nimport { ResponseError, ConflictError, InputError } from '@backstage/errors';\nimport fs from 'fs-extra';\nimport fetch, { Response } from 'node-fetch';\n\ninterface Links {\n webui: string;\n download: string;\n thumbnail: string;\n self: string;\n}\n\ninterface Metadata {\n mediaType: string;\n}\n\nexport interface Result {\n id: string;\n type: string;\n status: string;\n title: string;\n metadata: Metadata;\n _links: Links;\n}\n\nexport interface Results {\n results: Result[];\n}\n\nexport type LocalConfluenceConfig = {\n baseUrl: string;\n auth: string;\n token?: string;\n email?: string;\n username?: string;\n password?: string;\n};\n\nexport const getConfluenceConfig = (config: Config) => {\n const confluenceConfig = {\n baseUrl: config.getString('confluence.baseUrl'),\n auth: config.getOptionalString('confluence.auth.type') ?? 'bearer',\n token: config.getOptionalString('confluence.auth.token'),\n email: config.getOptionalString('confluence.auth.email'),\n username: config.getOptionalString('confluence.auth.username'),\n password: config.getOptionalString('confluence.auth.password'),\n };\n\n if (\n (confluenceConfig.auth === 'basic' || confluenceConfig.auth === 'bearer') &&\n !confluenceConfig.token\n ) {\n throw new Error(\n `No token provided for the configured '${confluenceConfig.auth}' auth method`,\n );\n }\n\n if (confluenceConfig.auth === 'basic' && !confluenceConfig.email) {\n throw new Error(\n `No email provided for the configured '${confluenceConfig.auth}' auth method`,\n );\n }\n\n if (\n confluenceConfig.auth === 'userpass' &&\n (!confluenceConfig.username || !confluenceConfig.password)\n ) {\n throw new Error(\n `No username/password provided for the configured '${confluenceConfig.auth}' auth method`,\n );\n }\n\n return confluenceConfig;\n};\n\nexport const getAuthorizationHeaderValue = (config: LocalConfluenceConfig) => {\n switch (config.auth) {\n case 'bearer':\n return `Bearer ${config.token}`;\n case 'basic': {\n const buffer = Buffer.from(`${config.email}:${config.token}`, 'utf8');\n return `Basic ${buffer.toString('base64')}`;\n }\n case 'userpass': {\n const buffer = Buffer.from(\n `${config.username}:${config.password}`,\n 'utf8',\n );\n return `Basic ${buffer.toString('base64')}`;\n }\n default:\n throw new Error(`Unknown auth method '${config.auth}' provided`);\n }\n};\n\nexport const readFileAsString = async (fileDir: string) => {\n const content = await fs.readFile(fileDir, 'utf-8');\n return content.toString();\n};\n\nexport const fetchConfluence = async (\n relativeUrl: string,\n config: LocalConfluenceConfig,\n) => {\n const baseUrl = config.baseUrl;\n const authHeaderValue = getAuthorizationHeaderValue(config);\n const url = `${baseUrl}${relativeUrl}`;\n const response: Response = await fetch(url, {\n method: 'GET',\n headers: {\n Authorization: authHeaderValue,\n },\n });\n if (!response.ok) {\n throw await ResponseError.fromResponse(response);\n }\n\n return response.json();\n};\n\nexport const getAndWriteAttachments = async (\n arr: Results,\n workspace: string,\n config: LocalConfluenceConfig,\n mkdocsDir: string,\n) => {\n const productArr: string[][] = [];\n const baseUrl = config.baseUrl;\n const authHeaderValue = getAuthorizationHeaderValue(config);\n await Promise.all(\n await arr.results.map(async (result: Result) => {\n const downloadLink = result._links.download;\n const downloadTitle = result.title.replace(/ /g, '-');\n if (result.metadata.mediaType !== 'application/gliffy+json') {\n productArr.push([result.title.replace(/ /g, '%20'), downloadTitle]);\n }\n const url = `${baseUrl}${downloadLink}`;\n const res = await fetch(url, {\n method: 'GET',\n headers: {\n Authorization: authHeaderValue,\n },\n });\n if (!res.ok) {\n throw await ResponseError.fromResponse(res);\n } else if (res.body !== null) {\n fs.openSync(`${workspace}/${mkdocsDir}docs/img/${downloadTitle}`, 'w');\n const writeStream = fs.createWriteStream(\n `${workspace}/${mkdocsDir}docs/img/${downloadTitle}`,\n );\n res.body.pipe(writeStream);\n await new Promise((resolve, reject) => {\n writeStream.on('finish', () => {\n resolve(`${workspace}/${mkdocsDir}docs/img/${downloadTitle}`);\n });\n writeStream.on('error', reject);\n });\n } else {\n throw new ConflictError(\n 'No Body on the response. Can not save images from Confluence Doc',\n );\n }\n }),\n );\n return productArr;\n};\n\nexport const createConfluenceVariables = (url: string) => {\n let spacekey: string | undefined = undefined;\n let title: string | undefined = undefined;\n let titleWithSpaces: string | undefined = '';\n const params = new URL(url);\n if (params.pathname.split('/')[1] === 'display') {\n // https://confluence.example.com/display/SPACEKEY/Page+Title\n spacekey = params.pathname.split('/')[2];\n title = params.pathname.split('/')[3];\n titleWithSpaces = title?.replace(/\\+/g, ' ');\n return { spacekey, title, titleWithSpaces };\n } else if (params.pathname.split('/')[2] === 'display') {\n // https://confluence.example.com/prefix/display/SPACEKEY/Page+Title\n spacekey = params.pathname.split('/')[3];\n title = params.pathname.split('/')[4];\n titleWithSpaces = title?.replace(/\\+/g, ' ');\n return { spacekey, title, titleWithSpaces };\n } else if (params.pathname.split('/')[2] === 'spaces') {\n // https://example.atlassian.net/wiki/spaces/SPACEKEY/pages/1234567/Page+Title\n spacekey = params.pathname.split('/')[3];\n title = params.pathname.split('/')[6];\n titleWithSpaces = title?.replace(/\\+/g, ' ');\n return { spacekey, title, titleWithSpaces };\n }\n throw new InputError(\n 'The Url format for Confluence is incorrect. Acceptable format is `<CONFLUENCE_BASE_URL>/display/<SPACEKEY>/<PAGE+TITLE>` or `<CONFLUENCE_BASE_URL>/spaces/<SPACEKEY>/pages/<PAGEID>/<PAGE+TITLE>` for Confluence cloud',\n );\n};\n","/*\n * Copyright 2023 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 { TemplateExample } from '@backstage/plugin-scaffolder-node';\nimport yaml from 'yaml';\n\nexport const examples: TemplateExample[] = [\n {\n description:\n 'Downloads content from provided Confluence URLs and converts it to Markdown.',\n example: yaml.stringify({\n steps: [\n {\n action: 'confluence:transform:markdown',\n id: 'confluence-transform-markdown',\n name: 'Transform Confluence content to Markdown',\n input: {\n confluenceUrls: [\n 'https://confluence.example.com/display/SPACEKEY/Page+Title',\n ],\n repoUrl:\n 'https://github.com/organization-name/repo-name/blob/main/mkdocs.yml',\n },\n },\n ],\n }),\n },\n];\n","/*\n * Copyright 2023 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 { Config } from '@backstage/config';\nimport { UrlReader } from '@backstage/backend-common';\nimport { ScmIntegrations } from '@backstage/integration';\nimport {\n createTemplateAction,\n fetchContents,\n} from '@backstage/plugin-scaffolder-node';\nimport { InputError, ConflictError } from '@backstage/errors';\nimport { NodeHtmlMarkdown } from 'node-html-markdown';\nimport fs from 'fs-extra';\nimport parseGitUrl from 'git-url-parse';\nimport YAML from 'yaml';\nimport {\n readFileAsString,\n fetchConfluence,\n getAndWriteAttachments,\n createConfluenceVariables,\n getConfluenceConfig,\n} from './helpers';\nimport { examples } from './confluenceToMarkdown.examples';\n\n/**\n * @public\n */\n\nexport const createConfluenceToMarkdownAction = (options: {\n reader: UrlReader;\n integrations: ScmIntegrations;\n config: Config;\n}) => {\n const { config, reader, integrations } = options;\n type Obj = {\n [key: string]: string;\n };\n\n return createTemplateAction<{\n confluenceUrls: string[];\n repoUrl: string;\n }>({\n id: 'confluence:transform:markdown',\n description: 'Transforms Confluence content to Markdown',\n examples,\n schema: {\n input: {\n properties: {\n confluenceUrls: {\n type: 'array',\n title: 'Confluence URL',\n description:\n 'Paste your Confluence url. Ensure it follows this format: https://{confluence+base+url}/display/{spacekey}/{page+title} or https://{confluence+base+url}/spaces/{spacekey}/pages/1234567/{page+title} for Confluence Cloud',\n items: {\n type: 'string',\n default: 'Confluence URL',\n },\n },\n repoUrl: {\n type: 'string',\n title: 'GitHub Repo Url',\n description:\n 'mkdocs.yml file location inside the github repo you want to store the document',\n },\n },\n },\n },\n async handler(ctx) {\n const confluenceConfig = getConfluenceConfig(config);\n const { confluenceUrls, repoUrl } = ctx.input;\n const parsedRepoUrl = parseGitUrl(repoUrl);\n const filePathToMkdocs = parsedRepoUrl.filepath.substring(\n 0,\n parsedRepoUrl.filepath.lastIndexOf('/') + 1,\n );\n const dirPath = ctx.workspacePath;\n const repoFileDir = `${dirPath}/${parsedRepoUrl.filepath}`;\n let productArray: string[][] = [];\n\n ctx.logger.info(`Fetching the mkdocs.yml catalog from ${repoUrl}`);\n\n // This grabs the files from Github\n await fetchContents({\n reader,\n integrations,\n baseUrl: ctx.templateInfo?.baseUrl,\n fetchUrl: `https://${parsedRepoUrl.resource}/${parsedRepoUrl.owner}/${parsedRepoUrl.name}`,\n outputPath: ctx.workspacePath,\n });\n\n for (const url of confluenceUrls) {\n const { spacekey, title, titleWithSpaces } =\n createConfluenceVariables(url);\n // This calls confluence to get the page html and page id\n ctx.logger.info(`Fetching the Confluence content for ${url}`);\n const getConfluenceDoc = await fetchConfluence(\n `/rest/api/content?title=${title}&spaceKey=${spacekey}&expand=body.export_view`,\n confluenceConfig,\n );\n if (getConfluenceDoc.results.length === 0) {\n throw new InputError(\n `Could not find document ${url}. Please check your input.`,\n );\n }\n // This gets attachments for the confluence page if they exist\n const getDocAttachments = await fetchConfluence(\n `/rest/api/content/${getConfluenceDoc.results[0].id}/child/attachment`,\n confluenceConfig,\n );\n\n if (getDocAttachments.results.length) {\n fs.mkdirSync(`${dirPath}/${filePathToMkdocs}docs/img`, {\n recursive: true,\n });\n productArray = await getAndWriteAttachments(\n getDocAttachments,\n dirPath,\n confluenceConfig,\n filePathToMkdocs,\n );\n }\n\n ctx.logger.info(\n `starting action for converting ${titleWithSpaces} from Confluence To Markdown`,\n );\n\n // This reads mkdocs.yml file\n const mkdocsFileContent = await readFileAsString(repoFileDir);\n const mkdocsFile = await YAML.parse(mkdocsFileContent);\n ctx.logger.info(\n `Adding new file - ${titleWithSpaces} to the current mkdocs.yml file`,\n );\n\n // This modifies the mkdocs.yml file\n if (mkdocsFile !== undefined && mkdocsFile.hasOwnProperty('nav')) {\n const { nav } = mkdocsFile;\n if (!nav.some((i: Obj) => i.hasOwnProperty(titleWithSpaces))) {\n nav.push({\n [titleWithSpaces]: `${titleWithSpaces.replace(/\\s+/g, '-')}.md`,\n });\n mkdocsFile.nav = nav;\n } else {\n throw new ConflictError(\n 'This document looks to exist inside the GitHub repo. Will end the action.',\n );\n }\n }\n\n await fs.writeFile(repoFileDir, YAML.stringify(mkdocsFile));\n\n // This grabs the confluence html and converts it to markdown and adds attachments\n const html = getConfluenceDoc.results[0].body.export_view.value;\n const markdownToPublish = NodeHtmlMarkdown.translate(html);\n let newString: string = markdownToPublish;\n productArray.forEach((product: string[]) => {\n // This regex is looking for either [](link to confluence) or ![](link to confluence) in the newly created markdown doc and updating it to point to the versions saved(in ./docs/img) in the local version of GitHub Repo during getAndWriteAttachments\n const regex = product[0].includes('.pdf')\n ? new RegExp(`(\\\\[.*?\\\\]\\\\()(.*?${product[0]}.*?)(\\\\))`, 'gi')\n : new RegExp(`(\\\\!\\\\[.*?\\\\]\\\\()(.*?${product[0]}.*?)(\\\\))`, 'gi');\n newString = newString.replace(regex, `$1./img/${product[1]}$3`);\n });\n\n ctx.logger.info(`Adding new file to repo.`);\n await fs.outputFile(\n `${dirPath}/${filePathToMkdocs}docs/${titleWithSpaces.replace(\n /\\s+/g,\n '-',\n )}.md`,\n newString,\n );\n }\n\n ctx.output('repo', parsedRepoUrl.name);\n ctx.output('owner', parsedRepoUrl.owner);\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 createBackendModule,\n coreServices,\n} from '@backstage/backend-plugin-api';\nimport { scaffolderActionsExtensionPoint } from '@backstage/plugin-scaffolder-node/alpha';\nimport { createConfluenceToMarkdownAction } from './actions';\nimport { ScmIntegrations } from '@backstage/integration';\n\n/**\n * @public\n * The Confluence to Markdown Module for the Scaffolder Backend\n */\nexport const confluenceToMarkdownModule = createBackendModule({\n pluginId: 'scaffolder',\n moduleId: 'confluence-to-markdown',\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 createConfluenceToMarkdownAction({\n config,\n integrations,\n reader,\n }),\n );\n },\n });\n },\n});\n"],"names":["fs","fetch","ResponseError","ConflictError","InputError","yaml","createTemplateAction","parseGitUrl","fetchContents","YAML","NodeHtmlMarkdown","createBackendModule","scaffolderActionsExtensionPoint","coreServices","ScmIntegrations"],"mappings":"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"}
1
+ {"version":3,"file":"index.cjs.js","sources":["../src/actions/confluence/helpers.ts","../src/actions/confluence/confluenceToMarkdown.examples.ts","../src/actions/confluence/confluenceToMarkdown.ts","../src/module.ts"],"sourcesContent":["/*\n * Copyright 2023 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 { Config } from '@backstage/config';\nimport { ResponseError, ConflictError, InputError } from '@backstage/errors';\nimport fs from 'fs-extra';\nimport fetch, { Response } from 'node-fetch';\n\ninterface Links {\n webui: string;\n download: string;\n thumbnail: string;\n self: string;\n}\n\ninterface Metadata {\n mediaType: string;\n}\n\nexport interface Result {\n id: string;\n type: string;\n status: string;\n title: string;\n metadata: Metadata;\n _links: Links;\n}\n\nexport interface Results {\n results: Result[];\n}\n\nexport type LocalConfluenceConfig = {\n baseUrl: string;\n auth: string;\n token?: string;\n email?: string;\n username?: string;\n password?: string;\n};\n\nexport const getConfluenceConfig = (config: Config) => {\n const confluenceConfig = {\n baseUrl: config.getString('confluence.baseUrl'),\n auth: config.getOptionalString('confluence.auth.type') ?? 'bearer',\n token: config.getOptionalString('confluence.auth.token'),\n email: config.getOptionalString('confluence.auth.email'),\n username: config.getOptionalString('confluence.auth.username'),\n password: config.getOptionalString('confluence.auth.password'),\n };\n\n if (\n (confluenceConfig.auth === 'basic' || confluenceConfig.auth === 'bearer') &&\n !confluenceConfig.token\n ) {\n throw new Error(\n `No token provided for the configured '${confluenceConfig.auth}' auth method`,\n );\n }\n\n if (confluenceConfig.auth === 'basic' && !confluenceConfig.email) {\n throw new Error(\n `No email provided for the configured '${confluenceConfig.auth}' auth method`,\n );\n }\n\n if (\n confluenceConfig.auth === 'userpass' &&\n (!confluenceConfig.username || !confluenceConfig.password)\n ) {\n throw new Error(\n `No username/password provided for the configured '${confluenceConfig.auth}' auth method`,\n );\n }\n\n return confluenceConfig;\n};\n\nexport const getAuthorizationHeaderValue = (config: LocalConfluenceConfig) => {\n switch (config.auth) {\n case 'bearer':\n return `Bearer ${config.token}`;\n case 'basic': {\n const buffer = Buffer.from(`${config.email}:${config.token}`, 'utf8');\n return `Basic ${buffer.toString('base64')}`;\n }\n case 'userpass': {\n const buffer = Buffer.from(\n `${config.username}:${config.password}`,\n 'utf8',\n );\n return `Basic ${buffer.toString('base64')}`;\n }\n default:\n throw new Error(`Unknown auth method '${config.auth}' provided`);\n }\n};\n\nexport const readFileAsString = async (fileDir: string) => {\n const content = await fs.readFile(fileDir, 'utf-8');\n return content.toString();\n};\n\nexport const fetchConfluence = async (\n relativeUrl: string,\n config: LocalConfluenceConfig,\n) => {\n const baseUrl = config.baseUrl;\n const authHeaderValue = getAuthorizationHeaderValue(config);\n const url = `${baseUrl}${relativeUrl}`;\n const response: Response = await fetch(url, {\n method: 'GET',\n headers: {\n Authorization: authHeaderValue,\n },\n });\n if (!response.ok) {\n throw await ResponseError.fromResponse(response);\n }\n\n return response.json();\n};\n\nexport const getAndWriteAttachments = async (\n arr: Results,\n workspace: string,\n config: LocalConfluenceConfig,\n mkdocsDir: string,\n) => {\n const productArr: string[][] = [];\n const baseUrl = config.baseUrl;\n const authHeaderValue = getAuthorizationHeaderValue(config);\n await Promise.all(\n await arr.results.map(async (result: Result) => {\n const downloadLink = result._links.download;\n const downloadTitle = result.title.replace(/ /g, '-');\n if (result.metadata.mediaType !== 'application/gliffy+json') {\n productArr.push([result.title.replace(/ /g, '%20'), downloadTitle]);\n }\n const url = `${baseUrl}${downloadLink}`;\n const res = await fetch(url, {\n method: 'GET',\n headers: {\n Authorization: authHeaderValue,\n },\n });\n if (!res.ok) {\n throw await ResponseError.fromResponse(res);\n } else if (res.body !== null) {\n fs.openSync(`${workspace}/${mkdocsDir}docs/img/${downloadTitle}`, 'w');\n const writeStream = fs.createWriteStream(\n `${workspace}/${mkdocsDir}docs/img/${downloadTitle}`,\n );\n res.body.pipe(writeStream);\n await new Promise((resolve, reject) => {\n writeStream.on('finish', () => {\n resolve(`${workspace}/${mkdocsDir}docs/img/${downloadTitle}`);\n });\n writeStream.on('error', reject);\n });\n } else {\n throw new ConflictError(\n 'No Body on the response. Can not save images from Confluence Doc',\n );\n }\n }),\n );\n return productArr;\n};\n\nexport const createConfluenceVariables = (url: string) => {\n let spacekey: string | undefined = undefined;\n let title: string | undefined = undefined;\n let titleWithSpaces: string | undefined = '';\n const params = new URL(url);\n if (params.pathname.split('/')[1] === 'display') {\n // https://confluence.example.com/display/SPACEKEY/Page+Title\n spacekey = params.pathname.split('/')[2];\n title = params.pathname.split('/')[3];\n titleWithSpaces = title?.replace(/\\+/g, ' ');\n return { spacekey, title, titleWithSpaces };\n } else if (params.pathname.split('/')[2] === 'display') {\n // https://confluence.example.com/prefix/display/SPACEKEY/Page+Title\n spacekey = params.pathname.split('/')[3];\n title = params.pathname.split('/')[4];\n titleWithSpaces = title?.replace(/\\+/g, ' ');\n return { spacekey, title, titleWithSpaces };\n } else if (params.pathname.split('/')[2] === 'spaces') {\n // https://example.atlassian.net/wiki/spaces/SPACEKEY/pages/1234567/Page+Title\n spacekey = params.pathname.split('/')[3];\n title = params.pathname.split('/')[6];\n titleWithSpaces = title?.replace(/\\+/g, ' ');\n return { spacekey, title, titleWithSpaces };\n }\n throw new InputError(\n 'The Url format for Confluence is incorrect. Acceptable format is `<CONFLUENCE_BASE_URL>/display/<SPACEKEY>/<PAGE+TITLE>` or `<CONFLUENCE_BASE_URL>/spaces/<SPACEKEY>/pages/<PAGEID>/<PAGE+TITLE>` for Confluence cloud',\n );\n};\n","/*\n * Copyright 2023 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 { TemplateExample } from '@backstage/plugin-scaffolder-node';\nimport yaml from 'yaml';\n\nexport const examples: TemplateExample[] = [\n {\n description:\n 'Downloads content from provided Confluence URLs and converts it to Markdown.',\n example: yaml.stringify({\n steps: [\n {\n action: 'confluence:transform:markdown',\n id: 'confluence-transform-markdown',\n name: 'Transform Confluence content to Markdown',\n input: {\n confluenceUrls: [\n 'https://confluence.example.com/display/SPACEKEY/Page+Title',\n ],\n repoUrl:\n 'https://github.com/organization-name/repo-name/blob/main/mkdocs.yml',\n },\n },\n ],\n }),\n },\n];\n","/*\n * Copyright 2023 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 { Config } from '@backstage/config';\nimport { UrlReader } from '@backstage/backend-common';\nimport { ScmIntegrations } from '@backstage/integration';\nimport {\n createTemplateAction,\n fetchContents,\n} from '@backstage/plugin-scaffolder-node';\nimport { InputError, ConflictError } from '@backstage/errors';\nimport { NodeHtmlMarkdown } from 'node-html-markdown';\nimport fs from 'fs-extra';\nimport parseGitUrl from 'git-url-parse';\nimport YAML from 'yaml';\nimport {\n readFileAsString,\n fetchConfluence,\n getAndWriteAttachments,\n createConfluenceVariables,\n getConfluenceConfig,\n} from './helpers';\nimport { examples } from './confluenceToMarkdown.examples';\n\n/**\n * @public\n */\n\nexport const createConfluenceToMarkdownAction = (options: {\n reader: UrlReader;\n integrations: ScmIntegrations;\n config: Config;\n}) => {\n const { config, reader, integrations } = options;\n type Obj = {\n [key: string]: string;\n };\n\n return createTemplateAction<{\n confluenceUrls: string[];\n repoUrl: string;\n }>({\n id: 'confluence:transform:markdown',\n description: 'Transforms Confluence content to Markdown',\n examples,\n schema: {\n input: {\n properties: {\n confluenceUrls: {\n type: 'array',\n title: 'Confluence URL',\n description:\n 'Paste your Confluence url. Ensure it follows this format: https://{confluence+base+url}/display/{spacekey}/{page+title} or https://{confluence+base+url}/spaces/{spacekey}/pages/1234567/{page+title} for Confluence Cloud',\n items: {\n type: 'string',\n default: 'Confluence URL',\n },\n },\n repoUrl: {\n type: 'string',\n title: 'GitHub Repo Url',\n description:\n 'mkdocs.yml file location inside the github repo you want to store the document',\n },\n },\n },\n },\n async handler(ctx) {\n const confluenceConfig = getConfluenceConfig(config);\n const { confluenceUrls, repoUrl } = ctx.input;\n const parsedRepoUrl = parseGitUrl(repoUrl);\n const filePathToMkdocs = parsedRepoUrl.filepath.substring(\n 0,\n parsedRepoUrl.filepath.lastIndexOf('/') + 1,\n );\n const dirPath = ctx.workspacePath;\n const repoFileDir = `${dirPath}/${parsedRepoUrl.filepath}`;\n let productArray: string[][] = [];\n\n ctx.logger.info(`Fetching the mkdocs.yml catalog from ${repoUrl}`);\n\n // This grabs the files from Github\n await fetchContents({\n reader,\n integrations,\n baseUrl: ctx.templateInfo?.baseUrl,\n fetchUrl: `https://${parsedRepoUrl.resource}/${parsedRepoUrl.owner}/${parsedRepoUrl.name}`,\n outputPath: ctx.workspacePath,\n });\n\n for (const url of confluenceUrls) {\n const { spacekey, title, titleWithSpaces } =\n createConfluenceVariables(url);\n // This calls confluence to get the page html and page id\n ctx.logger.info(`Fetching the Confluence content for ${url}`);\n const getConfluenceDoc = await fetchConfluence(\n `/rest/api/content?title=${title}&spaceKey=${spacekey}&expand=body.export_view`,\n confluenceConfig,\n );\n if (getConfluenceDoc.results.length === 0) {\n throw new InputError(\n `Could not find document ${url}. Please check your input.`,\n );\n }\n // This gets attachments for the confluence page if they exist\n const getDocAttachments = await fetchConfluence(\n `/rest/api/content/${getConfluenceDoc.results[0].id}/child/attachment`,\n confluenceConfig,\n );\n\n if (getDocAttachments.results.length) {\n fs.mkdirSync(`${dirPath}/${filePathToMkdocs}docs/img`, {\n recursive: true,\n });\n productArray = await getAndWriteAttachments(\n getDocAttachments,\n dirPath,\n confluenceConfig,\n filePathToMkdocs,\n );\n }\n\n ctx.logger.info(\n `starting action for converting ${titleWithSpaces} from Confluence To Markdown`,\n );\n\n // This reads mkdocs.yml file\n const mkdocsFileContent = await readFileAsString(repoFileDir);\n const mkdocsFile = await YAML.parse(mkdocsFileContent);\n ctx.logger.info(\n `Adding new file - ${titleWithSpaces} to the current mkdocs.yml file`,\n );\n\n // This modifies the mkdocs.yml file\n if (mkdocsFile !== undefined && mkdocsFile.hasOwnProperty('nav')) {\n const { nav } = mkdocsFile;\n if (!nav.some((i: Obj) => i.hasOwnProperty(titleWithSpaces))) {\n nav.push({\n [titleWithSpaces]: `${titleWithSpaces.replace(/\\s+/g, '-')}.md`,\n });\n mkdocsFile.nav = nav;\n } else {\n throw new ConflictError(\n 'This document looks to exist inside the GitHub repo. Will end the action.',\n );\n }\n }\n\n await fs.writeFile(repoFileDir, YAML.stringify(mkdocsFile));\n\n // This grabs the confluence html and converts it to markdown and adds attachments\n const html = getConfluenceDoc.results[0].body.export_view.value;\n const markdownToPublish = NodeHtmlMarkdown.translate(html);\n let newString: string = markdownToPublish;\n productArray.forEach((product: string[]) => {\n // This regex is looking for either [](link to confluence) or ![](link to confluence) in the newly created markdown doc and updating it to point to the versions saved(in ./docs/img) in the local version of GitHub Repo during getAndWriteAttachments\n const regex = product[0].includes('.pdf')\n ? new RegExp(`(\\\\[.*?\\\\]\\\\()(.*?${product[0]}.*?)(\\\\))`, 'gi')\n : new RegExp(`(\\\\!\\\\[.*?\\\\]\\\\()(.*?${product[0]}.*?)(\\\\))`, 'gi');\n newString = newString.replace(regex, `$1./img/${product[1]}$3`);\n });\n\n ctx.logger.info(`Adding new file to repo.`);\n await fs.outputFile(\n `${dirPath}/${filePathToMkdocs}docs/${titleWithSpaces.replace(\n /\\s+/g,\n '-',\n )}.md`,\n newString,\n );\n }\n\n ctx.output('repo', parsedRepoUrl.name);\n ctx.output('owner', parsedRepoUrl.owner);\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 createBackendModule,\n coreServices,\n} from '@backstage/backend-plugin-api';\nimport { scaffolderActionsExtensionPoint } from '@backstage/plugin-scaffolder-node/alpha';\nimport { createConfluenceToMarkdownAction } from './actions';\nimport { ScmIntegrations } from '@backstage/integration';\n\n/**\n * @public\n * The Confluence to Markdown Module for the Scaffolder Backend\n */\nexport const confluenceToMarkdownModule = createBackendModule({\n pluginId: 'scaffolder',\n moduleId: 'confluence-to-markdown',\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 createConfluenceToMarkdownAction({\n config,\n integrations,\n reader,\n }),\n );\n },\n });\n },\n});\n"],"names":["fs","fetch","ResponseError","ConflictError","InputError","yaml","createTemplateAction","parseGitUrl","fetchContents","YAML","NodeHtmlMarkdown","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-confluence-to-markdown",
3
3
  "description": "The confluence-to-markdown module for @backstage/plugin-scaffolder-backend",
4
- "version": "0.2.15",
4
+ "version": "0.2.16",
5
5
  "main": "./dist/index.cjs.js",
6
6
  "types": "./dist/index.d.ts",
7
7
  "license": "Apache-2.0",
@@ -36,12 +36,12 @@
36
36
  "help": "backstage-cli help"
37
37
  },
38
38
  "dependencies": {
39
- "@backstage/backend-common": "^0.21.4",
40
- "@backstage/backend-plugin-api": "^0.6.14",
39
+ "@backstage/backend-common": "^0.21.5",
40
+ "@backstage/backend-plugin-api": "^0.6.15",
41
41
  "@backstage/config": "^1.2.0",
42
42
  "@backstage/errors": "^1.2.4",
43
43
  "@backstage/integration": "^1.9.1",
44
- "@backstage/plugin-scaffolder-node": "^0.4.0",
44
+ "@backstage/plugin-scaffolder-node": "^0.4.1",
45
45
  "fs-extra": "^11.2.0",
46
46
  "git-url-parse": "^14.0.0",
47
47
  "node-fetch": "^2.6.7",
@@ -49,9 +49,9 @@
49
49
  "yaml": "^2.0.0"
50
50
  },
51
51
  "devDependencies": {
52
- "@backstage/backend-test-utils": "^0.3.4",
53
- "@backstage/cli": "^0.26.0",
54
- "@backstage/plugin-scaffolder-node-test-utils": "^0.1.0",
52
+ "@backstage/backend-test-utils": "^0.3.5",
53
+ "@backstage/cli": "^0.26.1",
54
+ "@backstage/plugin-scaffolder-node-test-utils": "^0.1.1",
55
55
  "msw": "^1.0.0"
56
56
  },
57
57
  "files": [