@backstage/plugin-catalog-backend-module-aws 0.4.11-next.0 → 0.4.11-next.2

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,38 @@
1
1
  # @backstage/plugin-catalog-backend-module-aws
2
2
 
3
+ ## 0.4.11-next.2
4
+
5
+ ### Patch Changes
6
+
7
+ - Updated dependencies
8
+ - @backstage/integration-aws-node@0.1.16-next.0
9
+ - @backstage/integration@1.17.0-next.2
10
+ - @backstage/backend-defaults@0.10.0-next.2
11
+ - @backstage/config@1.3.2
12
+ - @backstage/backend-plugin-api@1.3.1-next.1
13
+ - @backstage/catalog-model@1.7.3
14
+ - @backstage/errors@1.2.7
15
+ - @backstage/plugin-catalog-common@1.1.4-next.0
16
+ - @backstage/plugin-catalog-node@1.17.0-next.1
17
+ - @backstage/plugin-kubernetes-common@0.9.5-next.0
18
+
19
+ ## 0.4.11-next.1
20
+
21
+ ### Patch Changes
22
+
23
+ - 72d019d: Removed various typos
24
+ - Updated dependencies
25
+ - @backstage/backend-defaults@0.10.0-next.1
26
+ - @backstage/plugin-catalog-node@1.17.0-next.1
27
+ - @backstage/backend-plugin-api@1.3.1-next.1
28
+ - @backstage/integration@1.16.4-next.1
29
+ - @backstage/plugin-kubernetes-common@0.9.5-next.0
30
+ - @backstage/catalog-model@1.7.3
31
+ - @backstage/config@1.3.2
32
+ - @backstage/errors@1.2.7
33
+ - @backstage/integration-aws-node@0.1.15
34
+ - @backstage/plugin-catalog-common@1.1.4-next.0
35
+
3
36
  ## 0.4.11-next.0
4
37
 
5
38
  ### Patch Changes
@@ -9,9 +9,9 @@ class AwsEKSClusterProcessor {
9
9
  credentialsManager;
10
10
  clusterEntityTransformer;
11
11
  static fromConfig(configRoot, options) {
12
- const awsCredentaislManager = integrationAwsNode.DefaultAwsCredentialsManager.fromConfig(configRoot);
12
+ const awsCredentialsManager = integrationAwsNode.DefaultAwsCredentialsManager.fromConfig(configRoot);
13
13
  return new AwsEKSClusterProcessor({
14
- credentialsManager: awsCredentaislManager,
14
+ credentialsManager: awsCredentialsManager,
15
15
  ...options
16
16
  });
17
17
  }
@@ -1 +1 @@
1
- {"version":3,"file":"AwsEKSClusterProcessor.cjs.js","sources":["../../src/processors/AwsEKSClusterProcessor.ts"],"sourcesContent":["/*\n * Copyright 2022 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 CatalogProcessor,\n CatalogProcessorEmit,\n} from '@backstage/plugin-catalog-node';\nimport { LocationSpec } from '@backstage/plugin-catalog-common';\nimport { EKS } from '@aws-sdk/client-eks';\nimport { AWSCredentialFactory } from '../types';\nimport { AwsCredentialIdentity, Provider } from '@aws-sdk/types';\nimport {\n AwsCredentialsManager,\n DefaultAwsCredentialsManager,\n} from '@backstage/integration-aws-node';\nimport { Config } from '@backstage/config';\n\nimport type { EksClusterEntityTransformer } from './types';\nimport { defaultEksClusterEntityTransformer } from '../lib';\n\n/**\n * A processor for automatic discovery of resources from EKS clusters. Handles the\n * `aws-eks` location type, and target accounts/regions of the form\n * `<accountId>/<region>`.\n *\n * @public\n */\nexport class AwsEKSClusterProcessor implements CatalogProcessor {\n private credentialsFactory?: AWSCredentialFactory;\n private credentialsManager?: AwsCredentialsManager;\n private readonly clusterEntityTransformer: EksClusterEntityTransformer;\n\n static fromConfig(\n configRoot: Config,\n options?: {\n clusterEntityTransformer?: EksClusterEntityTransformer;\n },\n ): AwsEKSClusterProcessor {\n const awsCredentaislManager =\n DefaultAwsCredentialsManager.fromConfig(configRoot);\n return new AwsEKSClusterProcessor({\n credentialsManager: awsCredentaislManager,\n ...options,\n });\n }\n\n constructor(options: {\n credentialsFactory?: AWSCredentialFactory;\n credentialsManager?: AwsCredentialsManager;\n clusterEntityTransformer?: EksClusterEntityTransformer;\n }) {\n this.credentialsFactory = options.credentialsFactory;\n this.credentialsManager = options.credentialsManager;\n\n // If the callback function is not passed in, then default to the one upstream is using\n this.clusterEntityTransformer =\n options.clusterEntityTransformer || defaultEksClusterEntityTransformer;\n }\n\n getProcessorName(): string {\n return 'aws-eks';\n }\n\n async readLocation(\n location: LocationSpec,\n _optional: boolean,\n emit: CatalogProcessorEmit,\n ): Promise<boolean> {\n if (location.type !== 'aws-eks') {\n return false;\n }\n\n // location target is of format \"account-id/region\"\n const [accountId, region] = location.target.split('/');\n\n if (!accountId || !region) {\n throw new Error(\n 'AWS EKS location specified without account or region information',\n );\n }\n\n let credentials: AwsCredentialIdentity | undefined;\n\n if (this.credentialsFactory) {\n credentials = await this.credentialsFactory(accountId);\n }\n\n let providerFunction: (() => Provider<AwsCredentialIdentity>) | undefined;\n if (this.credentialsManager) {\n const credentialsProvider =\n await this.credentialsManager.getCredentialProvider({ accountId });\n providerFunction = () => credentialsProvider.sdkCredentialProvider;\n }\n\n const eksClient = new EKS({\n customUserAgent: 'backstage-aws-catalog-eks-cluster-processor',\n credentials,\n credentialDefaultProvider: providerFunction,\n region,\n });\n const clusters = await eksClient.listClusters({});\n if (clusters.clusters === undefined) {\n return true;\n }\n\n const results = clusters.clusters\n .map(cluster => eksClient.describeCluster({ name: cluster }))\n .map(async describedClusterPromise => {\n const describedCluster = await describedClusterPromise;\n if (describedCluster.cluster) {\n const entity = await this.clusterEntityTransformer(\n describedCluster.cluster,\n accountId,\n );\n\n emit({\n type: 'entity',\n entity,\n location,\n });\n }\n });\n await Promise.all(results);\n return true;\n }\n}\n"],"names":["DefaultAwsCredentialsManager","defaultEksClusterEntityTransformer","EKS"],"mappings":";;;;;;AAwCO,MAAM,sBAAmD,CAAA;AAAA,EACtD,kBAAA;AAAA,EACA,kBAAA;AAAA,EACS,wBAAA;AAAA,EAEjB,OAAO,UACL,CAAA,UAAA,EACA,OAGwB,EAAA;AACxB,IAAM,MAAA,qBAAA,GACJA,+CAA6B,CAAA,UAAA,CAAW,UAAU,CAAA;AACpD,IAAA,OAAO,IAAI,sBAAuB,CAAA;AAAA,MAChC,kBAAoB,EAAA,qBAAA;AAAA,MACpB,GAAG;AAAA,KACJ,CAAA;AAAA;AACH,EAEA,YAAY,OAIT,EAAA;AACD,IAAA,IAAA,CAAK,qBAAqB,OAAQ,CAAA,kBAAA;AAClC,IAAA,IAAA,CAAK,qBAAqB,OAAQ,CAAA,kBAAA;AAGlC,IAAK,IAAA,CAAA,wBAAA,GACH,QAAQ,wBAA4B,IAAAC,sDAAA;AAAA;AACxC,EAEA,gBAA2B,GAAA;AACzB,IAAO,OAAA,SAAA;AAAA;AACT,EAEA,MAAM,YAAA,CACJ,QACA,EAAA,SAAA,EACA,IACkB,EAAA;AAClB,IAAI,IAAA,QAAA,CAAS,SAAS,SAAW,EAAA;AAC/B,MAAO,OAAA,KAAA;AAAA;AAIT,IAAA,MAAM,CAAC,SAAW,EAAA,MAAM,IAAI,QAAS,CAAA,MAAA,CAAO,MAAM,GAAG,CAAA;AAErD,IAAI,IAAA,CAAC,SAAa,IAAA,CAAC,MAAQ,EAAA;AACzB,MAAA,MAAM,IAAI,KAAA;AAAA,QACR;AAAA,OACF;AAAA;AAGF,IAAI,IAAA,WAAA;AAEJ,IAAA,IAAI,KAAK,kBAAoB,EAAA;AAC3B,MAAc,WAAA,GAAA,MAAM,IAAK,CAAA,kBAAA,CAAmB,SAAS,CAAA;AAAA;AAGvD,IAAI,IAAA,gBAAA;AACJ,IAAA,IAAI,KAAK,kBAAoB,EAAA;AAC3B,MAAA,MAAM,sBACJ,MAAM,IAAA,CAAK,mBAAmB,qBAAsB,CAAA,EAAE,WAAW,CAAA;AACnE,MAAA,gBAAA,GAAmB,MAAM,mBAAoB,CAAA,qBAAA;AAAA;AAG/C,IAAM,MAAA,SAAA,GAAY,IAAIC,aAAI,CAAA;AAAA,MACxB,eAAiB,EAAA,6CAAA;AAAA,MACjB,WAAA;AAAA,MACA,yBAA2B,EAAA,gBAAA;AAAA,MAC3B;AAAA,KACD,CAAA;AACD,IAAA,MAAM,QAAW,GAAA,MAAM,SAAU,CAAA,YAAA,CAAa,EAAE,CAAA;AAChD,IAAI,IAAA,QAAA,CAAS,aAAa,KAAW,CAAA,EAAA;AACnC,MAAO,OAAA,IAAA;AAAA;AAGT,IAAA,MAAM,OAAU,GAAA,QAAA,CAAS,QACtB,CAAA,GAAA,CAAI,aAAW,SAAU,CAAA,eAAA,CAAgB,EAAE,IAAA,EAAM,SAAS,CAAC,CAC3D,CAAA,GAAA,CAAI,OAAM,uBAA2B,KAAA;AACpC,MAAA,MAAM,mBAAmB,MAAM,uBAAA;AAC/B,MAAA,IAAI,iBAAiB,OAAS,EAAA;AAC5B,QAAM,MAAA,MAAA,GAAS,MAAM,IAAK,CAAA,wBAAA;AAAA,UACxB,gBAAiB,CAAA,OAAA;AAAA,UACjB;AAAA,SACF;AAEA,QAAK,IAAA,CAAA;AAAA,UACH,IAAM,EAAA,QAAA;AAAA,UACN,MAAA;AAAA,UACA;AAAA,SACD,CAAA;AAAA;AACH,KACD,CAAA;AACH,IAAM,MAAA,OAAA,CAAQ,IAAI,OAAO,CAAA;AACzB,IAAO,OAAA,IAAA;AAAA;AAEX;;;;"}
1
+ {"version":3,"file":"AwsEKSClusterProcessor.cjs.js","sources":["../../src/processors/AwsEKSClusterProcessor.ts"],"sourcesContent":["/*\n * Copyright 2022 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 CatalogProcessor,\n CatalogProcessorEmit,\n} from '@backstage/plugin-catalog-node';\nimport { LocationSpec } from '@backstage/plugin-catalog-common';\nimport { EKS } from '@aws-sdk/client-eks';\nimport { AWSCredentialFactory } from '../types';\nimport { AwsCredentialIdentity, Provider } from '@aws-sdk/types';\nimport {\n AwsCredentialsManager,\n DefaultAwsCredentialsManager,\n} from '@backstage/integration-aws-node';\nimport { Config } from '@backstage/config';\n\nimport type { EksClusterEntityTransformer } from './types';\nimport { defaultEksClusterEntityTransformer } from '../lib';\n\n/**\n * A processor for automatic discovery of resources from EKS clusters. Handles the\n * `aws-eks` location type, and target accounts/regions of the form\n * `<accountId>/<region>`.\n *\n * @public\n */\nexport class AwsEKSClusterProcessor implements CatalogProcessor {\n private credentialsFactory?: AWSCredentialFactory;\n private credentialsManager?: AwsCredentialsManager;\n private readonly clusterEntityTransformer: EksClusterEntityTransformer;\n\n static fromConfig(\n configRoot: Config,\n options?: {\n clusterEntityTransformer?: EksClusterEntityTransformer;\n },\n ): AwsEKSClusterProcessor {\n const awsCredentialsManager =\n DefaultAwsCredentialsManager.fromConfig(configRoot);\n return new AwsEKSClusterProcessor({\n credentialsManager: awsCredentialsManager,\n ...options,\n });\n }\n\n constructor(options: {\n credentialsFactory?: AWSCredentialFactory;\n credentialsManager?: AwsCredentialsManager;\n clusterEntityTransformer?: EksClusterEntityTransformer;\n }) {\n this.credentialsFactory = options.credentialsFactory;\n this.credentialsManager = options.credentialsManager;\n\n // If the callback function is not passed in, then default to the one upstream is using\n this.clusterEntityTransformer =\n options.clusterEntityTransformer || defaultEksClusterEntityTransformer;\n }\n\n getProcessorName(): string {\n return 'aws-eks';\n }\n\n async readLocation(\n location: LocationSpec,\n _optional: boolean,\n emit: CatalogProcessorEmit,\n ): Promise<boolean> {\n if (location.type !== 'aws-eks') {\n return false;\n }\n\n // location target is of format \"account-id/region\"\n const [accountId, region] = location.target.split('/');\n\n if (!accountId || !region) {\n throw new Error(\n 'AWS EKS location specified without account or region information',\n );\n }\n\n let credentials: AwsCredentialIdentity | undefined;\n\n if (this.credentialsFactory) {\n credentials = await this.credentialsFactory(accountId);\n }\n\n let providerFunction: (() => Provider<AwsCredentialIdentity>) | undefined;\n if (this.credentialsManager) {\n const credentialsProvider =\n await this.credentialsManager.getCredentialProvider({ accountId });\n providerFunction = () => credentialsProvider.sdkCredentialProvider;\n }\n\n const eksClient = new EKS({\n customUserAgent: 'backstage-aws-catalog-eks-cluster-processor',\n credentials,\n credentialDefaultProvider: providerFunction,\n region,\n });\n const clusters = await eksClient.listClusters({});\n if (clusters.clusters === undefined) {\n return true;\n }\n\n const results = clusters.clusters\n .map(cluster => eksClient.describeCluster({ name: cluster }))\n .map(async describedClusterPromise => {\n const describedCluster = await describedClusterPromise;\n if (describedCluster.cluster) {\n const entity = await this.clusterEntityTransformer(\n describedCluster.cluster,\n accountId,\n );\n\n emit({\n type: 'entity',\n entity,\n location,\n });\n }\n });\n await Promise.all(results);\n return true;\n }\n}\n"],"names":["DefaultAwsCredentialsManager","defaultEksClusterEntityTransformer","EKS"],"mappings":";;;;;;AAwCO,MAAM,sBAAmD,CAAA;AAAA,EACtD,kBAAA;AAAA,EACA,kBAAA;AAAA,EACS,wBAAA;AAAA,EAEjB,OAAO,UACL,CAAA,UAAA,EACA,OAGwB,EAAA;AACxB,IAAM,MAAA,qBAAA,GACJA,+CAA6B,CAAA,UAAA,CAAW,UAAU,CAAA;AACpD,IAAA,OAAO,IAAI,sBAAuB,CAAA;AAAA,MAChC,kBAAoB,EAAA,qBAAA;AAAA,MACpB,GAAG;AAAA,KACJ,CAAA;AAAA;AACH,EAEA,YAAY,OAIT,EAAA;AACD,IAAA,IAAA,CAAK,qBAAqB,OAAQ,CAAA,kBAAA;AAClC,IAAA,IAAA,CAAK,qBAAqB,OAAQ,CAAA,kBAAA;AAGlC,IAAK,IAAA,CAAA,wBAAA,GACH,QAAQ,wBAA4B,IAAAC,sDAAA;AAAA;AACxC,EAEA,gBAA2B,GAAA;AACzB,IAAO,OAAA,SAAA;AAAA;AACT,EAEA,MAAM,YAAA,CACJ,QACA,EAAA,SAAA,EACA,IACkB,EAAA;AAClB,IAAI,IAAA,QAAA,CAAS,SAAS,SAAW,EAAA;AAC/B,MAAO,OAAA,KAAA;AAAA;AAIT,IAAA,MAAM,CAAC,SAAW,EAAA,MAAM,IAAI,QAAS,CAAA,MAAA,CAAO,MAAM,GAAG,CAAA;AAErD,IAAI,IAAA,CAAC,SAAa,IAAA,CAAC,MAAQ,EAAA;AACzB,MAAA,MAAM,IAAI,KAAA;AAAA,QACR;AAAA,OACF;AAAA;AAGF,IAAI,IAAA,WAAA;AAEJ,IAAA,IAAI,KAAK,kBAAoB,EAAA;AAC3B,MAAc,WAAA,GAAA,MAAM,IAAK,CAAA,kBAAA,CAAmB,SAAS,CAAA;AAAA;AAGvD,IAAI,IAAA,gBAAA;AACJ,IAAA,IAAI,KAAK,kBAAoB,EAAA;AAC3B,MAAA,MAAM,sBACJ,MAAM,IAAA,CAAK,mBAAmB,qBAAsB,CAAA,EAAE,WAAW,CAAA;AACnE,MAAA,gBAAA,GAAmB,MAAM,mBAAoB,CAAA,qBAAA;AAAA;AAG/C,IAAM,MAAA,SAAA,GAAY,IAAIC,aAAI,CAAA;AAAA,MACxB,eAAiB,EAAA,6CAAA;AAAA,MACjB,WAAA;AAAA,MACA,yBAA2B,EAAA,gBAAA;AAAA,MAC3B;AAAA,KACD,CAAA;AACD,IAAA,MAAM,QAAW,GAAA,MAAM,SAAU,CAAA,YAAA,CAAa,EAAE,CAAA;AAChD,IAAI,IAAA,QAAA,CAAS,aAAa,KAAW,CAAA,EAAA;AACnC,MAAO,OAAA,IAAA;AAAA;AAGT,IAAA,MAAM,OAAU,GAAA,QAAA,CAAS,QACtB,CAAA,GAAA,CAAI,aAAW,SAAU,CAAA,eAAA,CAAgB,EAAE,IAAA,EAAM,SAAS,CAAC,CAC3D,CAAA,GAAA,CAAI,OAAM,uBAA2B,KAAA;AACpC,MAAA,MAAM,mBAAmB,MAAM,uBAAA;AAC/B,MAAA,IAAI,iBAAiB,OAAS,EAAA;AAC5B,QAAM,MAAA,MAAA,GAAS,MAAM,IAAK,CAAA,wBAAA;AAAA,UACxB,gBAAiB,CAAA,OAAA;AAAA,UACjB;AAAA,SACF;AAEA,QAAK,IAAA,CAAA;AAAA,UACH,IAAM,EAAA,QAAA;AAAA,UACN,MAAA;AAAA,UACA;AAAA,SACD,CAAA;AAAA;AACH,KACD,CAAA;AACH,IAAM,MAAA,OAAA,CAAQ,IAAI,OAAO,CAAA;AACzB,IAAO,OAAA,IAAA;AAAA;AAEX;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@backstage/plugin-catalog-backend-module-aws",
3
- "version": "0.4.11-next.0",
3
+ "version": "0.4.11-next.2",
4
4
  "description": "A Backstage catalog backend module that helps integrate towards AWS",
5
5
  "backstage": {
6
6
  "role": "backend-plugin-module",
@@ -71,24 +71,24 @@
71
71
  "@aws-sdk/credential-providers": "^3.350.0",
72
72
  "@aws-sdk/middleware-endpoint": "^3.347.0",
73
73
  "@aws-sdk/types": "^3.347.0",
74
- "@backstage/backend-defaults": "0.9.1-next.0",
75
- "@backstage/backend-plugin-api": "1.3.1-next.0",
74
+ "@backstage/backend-defaults": "0.10.0-next.2",
75
+ "@backstage/backend-plugin-api": "1.3.1-next.1",
76
76
  "@backstage/catalog-model": "1.7.3",
77
77
  "@backstage/config": "1.3.2",
78
78
  "@backstage/errors": "1.2.7",
79
- "@backstage/integration": "1.16.4-next.0",
80
- "@backstage/integration-aws-node": "0.1.15",
81
- "@backstage/plugin-catalog-common": "1.1.3",
82
- "@backstage/plugin-catalog-node": "1.17.0-next.0",
83
- "@backstage/plugin-kubernetes-common": "0.9.4",
79
+ "@backstage/integration": "1.17.0-next.2",
80
+ "@backstage/integration-aws-node": "0.1.16-next.0",
81
+ "@backstage/plugin-catalog-common": "1.1.4-next.0",
82
+ "@backstage/plugin-catalog-node": "1.17.0-next.1",
83
+ "@backstage/plugin-kubernetes-common": "0.9.5-next.0",
84
84
  "p-limit": "^3.0.2",
85
85
  "uuid": "^11.0.0",
86
86
  "winston": "^3.2.1"
87
87
  },
88
88
  "devDependencies": {
89
89
  "@aws-sdk/util-stream-node": "^3.350.0",
90
- "@backstage/backend-test-utils": "1.5.0-next.0",
91
- "@backstage/cli": "0.32.1-next.0",
90
+ "@backstage/backend-test-utils": "1.5.0-next.2",
91
+ "@backstage/cli": "0.32.1-next.2",
92
92
  "aws-sdk-client-mock": "^4.0.0",
93
93
  "aws-sdk-client-mock-jest": "^4.0.0",
94
94
  "luxon": "^3.0.0",