@azure-tools/rlc-common 0.11.0
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/.eslintrc.json +23 -0
- package/.prettierignore +1 -0
- package/.prettierrc +7 -0
- package/.rush/temp/package-deps_build.json +53 -0
- package/.rush/temp/shrinkwrap-deps.json +147 -0
- package/CHANGELOG.md +61 -0
- package/CONTRIBUTING.md +30 -0
- package/README.md +3 -0
- package/dist/buildClient.js +268 -0
- package/dist/buildClient.js.map +1 -0
- package/dist/buildClientDefinitions.js +160 -0
- package/dist/buildClientDefinitions.js.map +1 -0
- package/dist/buildIndexFile.js +170 -0
- package/dist/buildIndexFile.js.map +1 -0
- package/dist/buildIsUnexpectedHelper.js +220 -0
- package/dist/buildIsUnexpectedHelper.js.map +1 -0
- package/dist/buildMethodShortcuts.js +50 -0
- package/dist/buildMethodShortcuts.js.map +1 -0
- package/dist/buildObjectTypes.js +286 -0
- package/dist/buildObjectTypes.js.map +1 -0
- package/dist/buildPaginateHelper.js +30 -0
- package/dist/buildPaginateHelper.js.map +1 -0
- package/dist/buildParameterTypes.js +315 -0
- package/dist/buildParameterTypes.js.map +1 -0
- package/dist/buildPollingHelper.js +21 -0
- package/dist/buildPollingHelper.js.map +1 -0
- package/dist/buildResponseTypes.js +135 -0
- package/dist/buildResponseTypes.js.map +1 -0
- package/dist/buildSchemaType.js +65 -0
- package/dist/buildSchemaType.js.map +1 -0
- package/dist/buildSerializeHelper.js +35 -0
- package/dist/buildSerializeHelper.js.map +1 -0
- package/dist/buildTopLevelIndexFile.js +48 -0
- package/dist/buildTopLevelIndexFile.js.map +1 -0
- package/dist/helpers/nameConstructors.js +41 -0
- package/dist/helpers/nameConstructors.js.map +1 -0
- package/dist/helpers/nameUtils.js +196 -0
- package/dist/helpers/nameUtils.js.map +1 -0
- package/dist/helpers/operationHelpers.js +103 -0
- package/dist/helpers/operationHelpers.js.map +1 -0
- package/dist/helpers/pathUtils.js +13 -0
- package/dist/helpers/pathUtils.js.map +1 -0
- package/dist/helpers/schemaHelpers.js +27 -0
- package/dist/helpers/schemaHelpers.js.map +1 -0
- package/dist/helpers/shortcutMethods.js +46 -0
- package/dist/helpers/shortcutMethods.js.map +1 -0
- package/dist/index.js +45 -0
- package/dist/index.js.map +1 -0
- package/dist/interfaces.js +18 -0
- package/dist/interfaces.js.map +1 -0
- package/dist/metadata/buildApiExtractorConfig.js +56 -0
- package/dist/metadata/buildApiExtractorConfig.js.map +1 -0
- package/dist/metadata/buildESLintConfig.js +33 -0
- package/dist/metadata/buildESLintConfig.js.map +1 -0
- package/dist/metadata/buildLicenseFile.js +41 -0
- package/dist/metadata/buildLicenseFile.js.map +1 -0
- package/dist/metadata/buildPackageFile.js +274 -0
- package/dist/metadata/buildPackageFile.js.map +1 -0
- package/dist/metadata/buildReadmeFile.js +170 -0
- package/dist/metadata/buildReadmeFile.js.map +1 -0
- package/dist/metadata/buildRollupConfig.js +144 -0
- package/dist/metadata/buildRollupConfig.js.map +1 -0
- package/dist/metadata/buildTsConfig.js +72 -0
- package/dist/metadata/buildTsConfig.js.map +1 -0
- package/dist/package.json +1 -0
- package/dist/static/paginateContent.js +214 -0
- package/dist/static/paginateContent.js.map +1 -0
- package/dist/static/pollingContent.js +98 -0
- package/dist/static/pollingContent.js.map +1 -0
- package/dist/static/serializeHelper.js +30 -0
- package/dist/static/serializeHelper.js.map +1 -0
- package/dist/test/buildEnvFile.js +31 -0
- package/dist/test/buildEnvFile.js.map +1 -0
- package/dist/test/buildKarmaConfig.js +19 -0
- package/dist/test/buildKarmaConfig.js.map +1 -0
- package/dist/test/buildRecordedClient.js +22 -0
- package/dist/test/buildRecordedClient.js.map +1 -0
- package/dist/test/buildSampleTest.js +19 -0
- package/dist/test/buildSampleTest.js.map +1 -0
- package/dist/test/template.js +191 -0
- package/dist/test/template.js.map +1 -0
- package/dist-esm/buildClient.js +261 -0
- package/dist-esm/buildClient.js.map +1 -0
- package/dist-esm/buildClientDefinitions.js +155 -0
- package/dist-esm/buildClientDefinitions.js.map +1 -0
- package/dist-esm/buildIndexFile.js +165 -0
- package/dist-esm/buildIndexFile.js.map +1 -0
- package/dist-esm/buildIsUnexpectedHelper.js +216 -0
- package/dist-esm/buildIsUnexpectedHelper.js.map +1 -0
- package/dist-esm/buildMethodShortcuts.js +46 -0
- package/dist-esm/buildMethodShortcuts.js.map +1 -0
- package/dist-esm/buildObjectTypes.js +288 -0
- package/dist-esm/buildObjectTypes.js.map +1 -0
- package/dist-esm/buildPaginateHelper.js +26 -0
- package/dist-esm/buildPaginateHelper.js.map +1 -0
- package/dist-esm/buildParameterTypes.js +321 -0
- package/dist-esm/buildParameterTypes.js.map +1 -0
- package/dist-esm/buildPollingHelper.js +17 -0
- package/dist-esm/buildPollingHelper.js.map +1 -0
- package/dist-esm/buildResponseTypes.js +140 -0
- package/dist-esm/buildResponseTypes.js.map +1 -0
- package/dist-esm/buildSchemaType.js +60 -0
- package/dist-esm/buildSchemaType.js.map +1 -0
- package/dist-esm/buildSerializeHelper.js +31 -0
- package/dist-esm/buildSerializeHelper.js.map +1 -0
- package/dist-esm/buildTopLevelIndexFile.js +44 -0
- package/dist-esm/buildTopLevelIndexFile.js.map +1 -0
- package/dist-esm/helpers/nameConstructors.js +34 -0
- package/dist-esm/helpers/nameConstructors.js.map +1 -0
- package/dist-esm/helpers/nameUtils.js +187 -0
- package/dist-esm/helpers/nameUtils.js.map +1 -0
- package/dist-esm/helpers/operationHelpers.js +84 -0
- package/dist-esm/helpers/operationHelpers.js.map +1 -0
- package/dist-esm/helpers/pathUtils.js +9 -0
- package/dist-esm/helpers/pathUtils.js.map +1 -0
- package/dist-esm/helpers/schemaHelpers.js +21 -0
- package/dist-esm/helpers/schemaHelpers.js.map +1 -0
- package/dist-esm/helpers/shortcutMethods.js +42 -0
- package/dist-esm/helpers/shortcutMethods.js.map +1 -0
- package/dist-esm/index.js +29 -0
- package/dist-esm/index.js.map +1 -0
- package/dist-esm/interfaces.js +15 -0
- package/dist-esm/interfaces.js.map +1 -0
- package/dist-esm/metadata/buildApiExtractorConfig.js +51 -0
- package/dist-esm/metadata/buildApiExtractorConfig.js.map +1 -0
- package/dist-esm/metadata/buildESLintConfig.js +28 -0
- package/dist-esm/metadata/buildESLintConfig.js.map +1 -0
- package/dist-esm/metadata/buildLicenseFile.js +36 -0
- package/dist-esm/metadata/buildLicenseFile.js.map +1 -0
- package/dist-esm/metadata/buildPackageFile.js +276 -0
- package/dist-esm/metadata/buildPackageFile.js.map +1 -0
- package/dist-esm/metadata/buildReadmeFile.js +167 -0
- package/dist-esm/metadata/buildReadmeFile.js.map +1 -0
- package/dist-esm/metadata/buildRollupConfig.js +139 -0
- package/dist-esm/metadata/buildRollupConfig.js.map +1 -0
- package/dist-esm/metadata/buildTsConfig.js +67 -0
- package/dist-esm/metadata/buildTsConfig.js.map +1 -0
- package/dist-esm/package.json +1 -0
- package/dist-esm/static/paginateContent.js +211 -0
- package/dist-esm/static/paginateContent.js.map +1 -0
- package/dist-esm/static/pollingContent.js +95 -0
- package/dist-esm/static/pollingContent.js.map +1 -0
- package/dist-esm/static/serializeHelper.js +27 -0
- package/dist-esm/static/serializeHelper.js.map +1 -0
- package/dist-esm/test/buildEnvFile.js +24 -0
- package/dist-esm/test/buildEnvFile.js.map +1 -0
- package/dist-esm/test/buildKarmaConfig.js +14 -0
- package/dist-esm/test/buildKarmaConfig.js.map +1 -0
- package/dist-esm/test/buildRecordedClient.js +17 -0
- package/dist-esm/test/buildRecordedClient.js.map +1 -0
- package/dist-esm/test/buildSampleTest.js +14 -0
- package/dist-esm/test/buildSampleTest.js.map +1 -0
- package/dist-esm/test/template.js +188 -0
- package/dist-esm/test/template.js.map +1 -0
- package/package.json +46 -0
- package/publishPackage.js +11 -0
- package/rlc-common.build.log +2 -0
- package/src/buildClient.ts +353 -0
- package/src/buildClientDefinitions.ts +235 -0
- package/src/buildIndexFile.ts +202 -0
- package/src/buildIsUnexpectedHelper.ts +240 -0
- package/src/buildMethodShortcuts.ts +75 -0
- package/src/buildObjectTypes.ts +449 -0
- package/src/buildPaginateHelper.ts +33 -0
- package/src/buildParameterTypes.ts +477 -0
- package/src/buildPollingHelper.ts +18 -0
- package/src/buildResponseTypes.ts +186 -0
- package/src/buildSchemaType.ts +85 -0
- package/src/buildSerializeHelper.ts +42 -0
- package/src/buildTopLevelIndexFile.ts +52 -0
- package/src/helpers/nameConstructors.ts +93 -0
- package/src/helpers/nameUtils.ts +227 -0
- package/src/helpers/operationHelpers.ts +119 -0
- package/src/helpers/pathUtils.ts +9 -0
- package/src/helpers/schemaHelpers.ts +25 -0
- package/src/helpers/shortcutMethods.ts +60 -0
- package/src/index.ts +29 -0
- package/src/interfaces.ts +227 -0
- package/src/metadata/buildApiExtractorConfig.ts +59 -0
- package/src/metadata/buildESLintConfig.ts +34 -0
- package/src/metadata/buildLicenseFile.ts +39 -0
- package/src/metadata/buildPackageFile.ts +334 -0
- package/src/metadata/buildReadmeFile.ts +231 -0
- package/src/metadata/buildRollupConfig.ts +147 -0
- package/src/metadata/buildTsConfig.ts +79 -0
- package/src/static/paginateContent.ts +210 -0
- package/src/static/pollingContent.ts +94 -0
- package/src/static/serializeHelper.ts +29 -0
- package/src/test/buildEnvFile.ts +26 -0
- package/src/test/buildKarmaConfig.ts +15 -0
- package/src/test/buildRecordedClient.ts +18 -0
- package/src/test/buildSampleTest.ts +15 -0
- package/src/test/template.ts +191 -0
- package/tsconfig-cjs.json +9 -0
- package/tsconfig-common.json +13 -0
- package/tsconfig.json +13 -0
- package/types/buildClient.d.ts +2 -0
- package/types/buildClientDefinitions.d.ts +5 -0
- package/types/buildIndexFile.d.ts +5 -0
- package/types/buildIsUnexpectedHelper.d.ts +5 -0
- package/types/buildMethodShortcuts.d.ts +4 -0
- package/types/buildObjectTypes.d.ts +15 -0
- package/types/buildPaginateHelper.d.ts +5 -0
- package/types/buildParameterTypes.d.ts +13 -0
- package/types/buildPollingHelper.d.ts +5 -0
- package/types/buildResponseTypes.d.ts +5 -0
- package/types/buildSchemaType.d.ts +19 -0
- package/types/buildSerializeHelper.d.ts +5 -0
- package/types/buildTopLevelIndexFile.d.ts +5 -0
- package/types/helpers/nameConstructors.d.ts +28 -0
- package/types/helpers/nameUtils.d.ts +25 -0
- package/types/helpers/operationHelpers.d.ts +13 -0
- package/types/helpers/pathUtils.d.ts +1 -0
- package/types/helpers/schemaHelpers.d.ts +4 -0
- package/types/helpers/shortcutMethods.d.ts +3 -0
- package/types/index.d.ts +26 -0
- package/types/interfaces.d.ts +200 -0
- package/types/metadata/buildApiExtractorConfig.d.ts +5 -0
- package/types/metadata/buildESLintConfig.d.ts +5 -0
- package/types/metadata/buildLicenseFile.d.ts +5 -0
- package/types/metadata/buildPackageFile.d.ts +5 -0
- package/types/metadata/buildReadmeFile.d.ts +5 -0
- package/types/metadata/buildRollupConfig.d.ts +5 -0
- package/types/metadata/buildTsConfig.d.ts +5 -0
- package/types/static/paginateContent.d.ts +1 -0
- package/types/static/pollingContent.d.ts +1 -0
- package/types/static/serializeHelper.d.ts +4 -0
- package/types/test/buildEnvFile.d.ts +9 -0
- package/types/test/buildKarmaConfig.d.ts +5 -0
- package/types/test/buildRecordedClient.d.ts +5 -0
- package/types/test/buildSampleTest.d.ts +5 -0
- package/types/test/template.d.ts +5 -0
|
@@ -0,0 +1,334 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT License.
|
|
3
|
+
|
|
4
|
+
import { Project } from "ts-morph";
|
|
5
|
+
import { NameType, normalizeName } from "../helpers/nameUtils.js";
|
|
6
|
+
import {
|
|
7
|
+
hasPagingOperations,
|
|
8
|
+
hasPollingOperations
|
|
9
|
+
} from "../helpers/operationHelpers.js";
|
|
10
|
+
import { getRelativePartFromSrcPath } from "../helpers/pathUtils.js";
|
|
11
|
+
import { RLCModel } from "../interfaces.js";
|
|
12
|
+
|
|
13
|
+
let hasPaging = false;
|
|
14
|
+
let hasLRO = false;
|
|
15
|
+
let clientFilePaths: string[] = [];
|
|
16
|
+
|
|
17
|
+
export function buildPackageFile(model: RLCModel, hasSamplesGenerated = false) {
|
|
18
|
+
const generateMetadata = Boolean(model.options?.generateMetadata);
|
|
19
|
+
if (!generateMetadata) {
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
const project = new Project();
|
|
23
|
+
const filePath = "package.json";
|
|
24
|
+
const packageJsonContents = restLevelPackage(model, hasSamplesGenerated);
|
|
25
|
+
// return direclty if no content generated
|
|
26
|
+
if (!packageJsonContents) {
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
const packageFile = project.createSourceFile(
|
|
31
|
+
filePath,
|
|
32
|
+
JSON.stringify(packageJsonContents),
|
|
33
|
+
{
|
|
34
|
+
overwrite: true
|
|
35
|
+
}
|
|
36
|
+
);
|
|
37
|
+
return {
|
|
38
|
+
path: filePath,
|
|
39
|
+
content: packageFile.getFullText()
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* This function defines the REST Level client package.json file
|
|
45
|
+
* or High Level Client
|
|
46
|
+
*/
|
|
47
|
+
function restLevelPackage(model: RLCModel, hasSamplesGenerated: boolean) {
|
|
48
|
+
if (!model.options || !model.options.packageDetails) {
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
clientFilePaths.push(getClientFilePath(model));
|
|
53
|
+
hasPaging = hasPaging || hasPagingOperations(model);
|
|
54
|
+
hasLRO = hasLRO || hasPollingOperations(model);
|
|
55
|
+
|
|
56
|
+
const {
|
|
57
|
+
packageDetails,
|
|
58
|
+
generateTest,
|
|
59
|
+
generateSample,
|
|
60
|
+
azureOutputDirectory,
|
|
61
|
+
azureSdkForJs,
|
|
62
|
+
isCadlTest,
|
|
63
|
+
sourceFrom,
|
|
64
|
+
multiClient,
|
|
65
|
+
batch
|
|
66
|
+
} = model.options;
|
|
67
|
+
if (
|
|
68
|
+
multiClient &&
|
|
69
|
+
batch &&
|
|
70
|
+
batch.length > 1 &&
|
|
71
|
+
clientFilePaths.length < batch.length
|
|
72
|
+
) {
|
|
73
|
+
return;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
const clientPackageName = packageDetails.name;
|
|
77
|
+
let apiRefUrlQueryParameter: string = "";
|
|
78
|
+
if (packageDetails.version.includes("beta")) {
|
|
79
|
+
apiRefUrlQueryParameter = "?view=azure-node-preview";
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
const packageInfo: Record<string, any> = {
|
|
83
|
+
name: `${packageDetails.name}`,
|
|
84
|
+
"sdk-type": "client",
|
|
85
|
+
author: "Microsoft Corporation",
|
|
86
|
+
version: `${packageDetails.version}`,
|
|
87
|
+
description:
|
|
88
|
+
`${packageDetails.description}` ||
|
|
89
|
+
`A generated SDK for ${model.libraryName}.`,
|
|
90
|
+
keywords: ["node", "azure", "cloud", "typescript", "browser", "isomorphic"],
|
|
91
|
+
license: "MIT",
|
|
92
|
+
main: "dist/index.js",
|
|
93
|
+
module: generateTest ? "./dist-esm/src/index.js" : "./dist-esm/index.js",
|
|
94
|
+
types: `./types/${packageDetails.nameWithoutScope}.d.ts`,
|
|
95
|
+
repository: "github:Azure/azure-sdk-for-js",
|
|
96
|
+
bugs: {
|
|
97
|
+
url: "https://github.com/Azure/azure-sdk-for-js/issues"
|
|
98
|
+
},
|
|
99
|
+
files: [
|
|
100
|
+
"dist/",
|
|
101
|
+
generateTest ? "dist-esm/src/" : "dist-esm/",
|
|
102
|
+
`types/${packageDetails.nameWithoutScope}.d.ts`,
|
|
103
|
+
"README.md",
|
|
104
|
+
"LICENSE",
|
|
105
|
+
"review/*"
|
|
106
|
+
],
|
|
107
|
+
engines: {
|
|
108
|
+
node: ">=14.0.0"
|
|
109
|
+
},
|
|
110
|
+
scripts: {
|
|
111
|
+
audit:
|
|
112
|
+
"node ../../../common/scripts/rush-audit.js && rimraf node_modules package-lock.json && npm i --package-lock-only 2>&1 && npm audit",
|
|
113
|
+
"build:browser": "echo skipped.",
|
|
114
|
+
"build:node": "echo skipped.",
|
|
115
|
+
"build:samples": "echo skipped.",
|
|
116
|
+
"build:test": "echo skipped.",
|
|
117
|
+
"build:debug": "echo skipped.",
|
|
118
|
+
"check-format": `prettier --list-different --config ../../../.prettierrc.json --ignore-path ../../../.prettierignore "src/**/*.ts" "*.{js,json}" ${appendPathWhenFormat(
|
|
119
|
+
generateTest,
|
|
120
|
+
generateSample
|
|
121
|
+
)}`,
|
|
122
|
+
clean:
|
|
123
|
+
"rimraf dist dist-browser dist-esm test-dist temp types *.tgz *.log",
|
|
124
|
+
"execute:samples": "echo skipped",
|
|
125
|
+
"extract-api":
|
|
126
|
+
"rimraf review && mkdirp ./review && api-extractor run --local",
|
|
127
|
+
format: `prettier --write --config ../../../.prettierrc.json --ignore-path ../../../.prettierignore "src/**/*.ts" "*.{js,json}" ${appendPathWhenFormat(
|
|
128
|
+
generateTest,
|
|
129
|
+
generateSample
|
|
130
|
+
)}`,
|
|
131
|
+
"generate:client":
|
|
132
|
+
sourceFrom === "Swagger"
|
|
133
|
+
? "autorest --typescript swagger/README.md && npm run format"
|
|
134
|
+
: "echo skipped",
|
|
135
|
+
"integration-test:browser": "echo skipped",
|
|
136
|
+
"integration-test:node": "echo skipped",
|
|
137
|
+
"integration-test": "echo skipped",
|
|
138
|
+
"lint:fix": `eslint package.json api-extractor.json src ${appednPathWhenLint(
|
|
139
|
+
generateTest
|
|
140
|
+
)} --ext .ts --fix --fix-type [problem,suggestion]`,
|
|
141
|
+
lint: `eslint package.json api-extractor.json src ${appednPathWhenLint(
|
|
142
|
+
generateTest
|
|
143
|
+
)} --ext .ts`,
|
|
144
|
+
pack: "npm pack 2>&1",
|
|
145
|
+
"test:browser": "echo skipped",
|
|
146
|
+
"test:node": "echo skipped",
|
|
147
|
+
test: 'echo "Error: no test specified" && exit 1',
|
|
148
|
+
"unit-test": "echo skipped",
|
|
149
|
+
"unit-test:node": "echo skipped",
|
|
150
|
+
"unit-test:browser": "echo skipped"
|
|
151
|
+
},
|
|
152
|
+
sideEffects: false,
|
|
153
|
+
autoPublish: false,
|
|
154
|
+
dependencies: {
|
|
155
|
+
"@azure/core-auth": "^1.3.0",
|
|
156
|
+
"@azure-rest/core-client": "^1.1.0",
|
|
157
|
+
"@azure/core-rest-pipeline": "^1.8.0",
|
|
158
|
+
"@azure/logger": "^1.0.0",
|
|
159
|
+
tslib: "^2.2.0",
|
|
160
|
+
...(hasPaging && {
|
|
161
|
+
"@azure/core-paging": "^1.5.0"
|
|
162
|
+
}),
|
|
163
|
+
...(hasLRO && {
|
|
164
|
+
"@azure/core-lro": "^2.5.0",
|
|
165
|
+
"@azure/abort-controller": "^1.0.0"
|
|
166
|
+
})
|
|
167
|
+
},
|
|
168
|
+
devDependencies: {
|
|
169
|
+
"@microsoft/api-extractor": "^7.31.1",
|
|
170
|
+
autorest: "latest",
|
|
171
|
+
"@types/node": "^14.0.0",
|
|
172
|
+
dotenv: "^16.0.0",
|
|
173
|
+
eslint: "^8.0.0",
|
|
174
|
+
mkdirp: "^2.1.2",
|
|
175
|
+
prettier: "^2.5.1",
|
|
176
|
+
rimraf: "^3.0.0",
|
|
177
|
+
"source-map-support": "^0.5.9",
|
|
178
|
+
typescript: "~4.8.0"
|
|
179
|
+
}
|
|
180
|
+
};
|
|
181
|
+
|
|
182
|
+
if (azureOutputDirectory) {
|
|
183
|
+
packageInfo.homepage = `https://github.com/Azure/azure-sdk-for-js/tree/main/${azureOutputDirectory}/README.md`;
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
if (azureSdkForJs) {
|
|
187
|
+
packageInfo["//metadata"] = {
|
|
188
|
+
constantPaths: []
|
|
189
|
+
};
|
|
190
|
+
clientFilePaths.forEach((path) => {
|
|
191
|
+
packageInfo["//metadata"].constantPaths.push({
|
|
192
|
+
path,
|
|
193
|
+
prefix: "userAgentInfo"
|
|
194
|
+
});
|
|
195
|
+
});
|
|
196
|
+
// Only generate this from Swagger spec
|
|
197
|
+
if (sourceFrom === "Swagger") {
|
|
198
|
+
packageInfo["//metadata"].constantPaths.push({
|
|
199
|
+
path: "swagger/README.md",
|
|
200
|
+
prefix: "package-version"
|
|
201
|
+
});
|
|
202
|
+
}
|
|
203
|
+
packageInfo.scripts["build"] =
|
|
204
|
+
"npm run clean && tsc -p . && dev-tool run bundle && mkdirp ./review && api-extractor run --local";
|
|
205
|
+
packageInfo.scripts["build:debug"] =
|
|
206
|
+
"tsc -p . && dev-tool run bundle && api-extractor run --local";
|
|
207
|
+
packageInfo.scripts["build:browser"] = "tsc -p . && dev-tool run bundle";
|
|
208
|
+
packageInfo.scripts["build:node"] = "tsc -p . && dev-tool run bundle";
|
|
209
|
+
packageInfo.devDependencies["@azure/dev-tool"] = "^1.0.0";
|
|
210
|
+
packageInfo.devDependencies["@azure/eslint-plugin-azure-sdk"] = "^3.0.0";
|
|
211
|
+
} else {
|
|
212
|
+
packageInfo.scripts["build"] =
|
|
213
|
+
"npm run clean && tsc && rollup -c 2>&1 && npm run minify && mkdirp ./review && npm run extract-api";
|
|
214
|
+
packageInfo.scripts[
|
|
215
|
+
"minify"
|
|
216
|
+
] = `uglifyjs -c -m --comments --source-map "content='./dist/index.js.map'" -o ./dist/index.min.js ./dist/index.js`;
|
|
217
|
+
packageInfo.devDependencies["@rollup/plugin-commonjs"] = "^24.0.0";
|
|
218
|
+
packageInfo.devDependencies["@rollup/plugin-json"] = "^6.0.0";
|
|
219
|
+
packageInfo.devDependencies["@rollup/plugin-multi-entry"] = "^6.0.0";
|
|
220
|
+
packageInfo.devDependencies["@rollup/plugin-node-resolve"] = "^13.1.3";
|
|
221
|
+
packageInfo.devDependencies["rollup"] = "^2.66.1";
|
|
222
|
+
packageInfo.devDependencies["rollup-plugin-sourcemaps"] = "^0.6.3";
|
|
223
|
+
packageInfo.devDependencies["uglify-js"] = "^3.4.9";
|
|
224
|
+
}
|
|
225
|
+
|
|
226
|
+
if (isCadlTest) {
|
|
227
|
+
packageInfo["type"] = "module";
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
if (generateTest) {
|
|
231
|
+
packageInfo.module = `./dist-esm/src/index.js`;
|
|
232
|
+
packageInfo.devDependencies["@azure-tools/test-credential"] = "^1.0.0";
|
|
233
|
+
packageInfo.devDependencies["@azure/identity"] = "^2.0.1";
|
|
234
|
+
packageInfo.devDependencies["@azure-tools/test-recorder"] = "^3.0.0";
|
|
235
|
+
packageInfo.devDependencies["mocha"] = "^7.1.1";
|
|
236
|
+
packageInfo.devDependencies["@types/mocha"] = "^7.0.2";
|
|
237
|
+
packageInfo.devDependencies["mocha-junit-reporter"] = "^1.18.0";
|
|
238
|
+
packageInfo.devDependencies["cross-env"] = "^7.0.2";
|
|
239
|
+
packageInfo.devDependencies["@types/chai"] = "^4.2.8";
|
|
240
|
+
packageInfo.devDependencies["chai"] = "^4.2.0";
|
|
241
|
+
packageInfo.devDependencies["cross-env"] = "^7.0.2";
|
|
242
|
+
packageInfo.devDependencies["karma-chrome-launcher"] = "^3.0.0";
|
|
243
|
+
packageInfo.devDependencies["karma-coverage"] = "^2.0.0";
|
|
244
|
+
packageInfo.devDependencies["karma-env-preprocessor"] = "^0.1.1";
|
|
245
|
+
packageInfo.devDependencies["karma-firefox-launcher"] = "^1.1.0";
|
|
246
|
+
packageInfo.devDependencies["karma-junit-reporter"] = "^2.0.1";
|
|
247
|
+
packageInfo.devDependencies["karma-mocha-reporter"] = "^2.2.5";
|
|
248
|
+
packageInfo.devDependencies["karma-mocha"] = "^2.0.1";
|
|
249
|
+
packageInfo.devDependencies["karma-source-map-support"] = "~1.4.0";
|
|
250
|
+
packageInfo.devDependencies["karma-sourcemap-loader"] = "^0.3.8";
|
|
251
|
+
packageInfo.devDependencies["karma"] = "^6.2.0";
|
|
252
|
+
packageInfo.devDependencies["nyc"] = "^15.0.0";
|
|
253
|
+
packageInfo.devDependencies["source-map-support"] = "^0.5.9";
|
|
254
|
+
packageInfo.scripts["test"] =
|
|
255
|
+
"npm run clean && npm run build:test && npm run unit-test";
|
|
256
|
+
packageInfo.scripts["test:node"] =
|
|
257
|
+
"npm run clean && npm run build:test && npm run unit-test:node";
|
|
258
|
+
packageInfo.scripts["test:browser"] =
|
|
259
|
+
"npm run clean && npm run build:test && npm run unit-test:browser";
|
|
260
|
+
packageInfo.scripts["build:browser"] =
|
|
261
|
+
"tsc -p . && cross-env ONLY_BROWSER=true rollup -c 2>&1";
|
|
262
|
+
packageInfo.scripts["build:node"] =
|
|
263
|
+
"tsc -p . && cross-env ONLY_NODE=true rollup -c 2>&1";
|
|
264
|
+
packageInfo.scripts["build:test"] = "tsc -p . && rollup -c 2>&1";
|
|
265
|
+
packageInfo.scripts["unit-test"] =
|
|
266
|
+
"npm run unit-test:node && npm run unit-test:browser";
|
|
267
|
+
packageInfo.scripts["unit-test:node"] =
|
|
268
|
+
'mocha -r esm --require ts-node/register --reporter ../../../common/tools/mocha-multi-reporter.js --timeout 1200000 --full-trace "test/{,!(browser)/**/}*.spec.ts"';
|
|
269
|
+
packageInfo.scripts["unit-test:browser"] = "karma start --single-run";
|
|
270
|
+
packageInfo.scripts["integration-test:browser"] =
|
|
271
|
+
"karma start --single-run";
|
|
272
|
+
packageInfo.scripts["integration-test:node"] =
|
|
273
|
+
'nyc mocha -r esm --require source-map-support/register --reporter ../../../common/tools/mocha-multi-reporter.js --timeout 5000000 --full-trace "dist-esm/test/{,!(browser)/**/}*.spec.js"';
|
|
274
|
+
packageInfo.scripts["integration-test"] =
|
|
275
|
+
"npm run integration-test:node && npm run integration-test:browser";
|
|
276
|
+
if (azureSdkForJs) {
|
|
277
|
+
packageInfo.scripts["build:test"] = "tsc -p . && dev-tool run bundle";
|
|
278
|
+
packageInfo.scripts["integration-test:browser"] =
|
|
279
|
+
"dev-tool run test:browser";
|
|
280
|
+
packageInfo.scripts["unit-test:browser"] = "dev-tool run test:browser";
|
|
281
|
+
packageInfo.scripts["unit-test:node"] =
|
|
282
|
+
"dev-tool run test:node-ts-input -- --timeout 1200000 --exclude 'test/**/browser/*.spec.ts' 'test/**/*.spec.ts'";
|
|
283
|
+
packageInfo.scripts["integration-test:node"] =
|
|
284
|
+
"dev-tool run test:node-js-input -- --timeout 5000000 'dist-esm/test/**/*.spec.js'";
|
|
285
|
+
}
|
|
286
|
+
|
|
287
|
+
packageInfo["browser"] = {
|
|
288
|
+
"./dist-esm/test/public/utils/env.js":
|
|
289
|
+
"./dist-esm/test/public/utils/env.browser.js"
|
|
290
|
+
};
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
if (generateSample && hasSamplesGenerated) {
|
|
294
|
+
packageInfo["//sampleConfiguration"] = {
|
|
295
|
+
productName: model.options.serviceInfo?.title ?? model.libraryName,
|
|
296
|
+
productSlugs: ["azure"],
|
|
297
|
+
disableDocsMs: true,
|
|
298
|
+
apiRefLink: `https://docs.microsoft.com/javascript/api/${clientPackageName}${apiRefUrlQueryParameter}`
|
|
299
|
+
};
|
|
300
|
+
if (azureSdkForJs) {
|
|
301
|
+
packageInfo.scripts["execute:samples"] =
|
|
302
|
+
"dev-tool samples run samples-dev";
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
|
|
306
|
+
return packageInfo;
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
function appendPathWhenFormat(
|
|
310
|
+
generateTest?: boolean,
|
|
311
|
+
generateSample?: boolean
|
|
312
|
+
) {
|
|
313
|
+
let path = "";
|
|
314
|
+
if (generateTest) {
|
|
315
|
+
path = path + ` "test/**/*.ts"`;
|
|
316
|
+
}
|
|
317
|
+
if (generateSample) {
|
|
318
|
+
path = path + ` "samples-dev/**/*.ts"`;
|
|
319
|
+
}
|
|
320
|
+
return path;
|
|
321
|
+
}
|
|
322
|
+
|
|
323
|
+
function appednPathWhenLint(generateTest?: boolean) {
|
|
324
|
+
return generateTest ? "test" : "";
|
|
325
|
+
}
|
|
326
|
+
|
|
327
|
+
function getClientFilePath(model: RLCModel) {
|
|
328
|
+
const { srcPath } = model;
|
|
329
|
+
const sdkReletivePart = getRelativePartFromSrcPath(srcPath);
|
|
330
|
+
const clientFilename = normalizeName(model.libraryName, NameType.File);
|
|
331
|
+
return sdkReletivePart
|
|
332
|
+
? `src/${sdkReletivePart}/${clientFilename}.ts`
|
|
333
|
+
: `src/${clientFilename}.ts`;
|
|
334
|
+
}
|
|
@@ -0,0 +1,231 @@
|
|
|
1
|
+
import { RLCModel } from "../interfaces.js";
|
|
2
|
+
// @ts-ignore: to fix the handlebars issue
|
|
3
|
+
import hbs from "handlebars";
|
|
4
|
+
import { NameType, normalizeName } from "../helpers/nameUtils.js";
|
|
5
|
+
|
|
6
|
+
const readmeTemplate = `# {{ clientDescriptiveName }} library for JavaScript
|
|
7
|
+
|
|
8
|
+
{{ description }}
|
|
9
|
+
|
|
10
|
+
{{#if azureArm}}
|
|
11
|
+
**If you are not familiar with our REST client, please spend 5 minutes to take a look at {{#if serviceDocURL}}[the service's documentation]({{ serviceDocURL }}) and {{/if}}our [REST client docs](https://github.com/Azure/azure-sdk-for-js/blob/main/documentation/rest-clients.md) to use this library, the REST client provides a light-weighted & developer friendly way to call azure rest api
|
|
12
|
+
{{else}}
|
|
13
|
+
**Please rely heavily on {{#if serviceDocURL}}[the service's documentation]({{ serviceDocURL }}) and {{/if}}our [REST client docs](https://github.com/Azure/azure-sdk-for-js/blob/main/documentation/rest-clients.md) to use this library**
|
|
14
|
+
{{/if}}
|
|
15
|
+
|
|
16
|
+
Key links:
|
|
17
|
+
|
|
18
|
+
{{#if packageSourceURL}}
|
|
19
|
+
- [Source code]({{ packageSourceURL }})
|
|
20
|
+
{{/if}}
|
|
21
|
+
{{#if packageNPMURL}}
|
|
22
|
+
- [Package (NPM)]({{ packageNPMURL }})
|
|
23
|
+
{{/if}}
|
|
24
|
+
{{#if apiRefURL}}
|
|
25
|
+
- [API reference documentation]({{ apiRefURL }})
|
|
26
|
+
{{/if}}
|
|
27
|
+
{{#if serviceDocURL}}
|
|
28
|
+
- [Product documentation]({{ serviceDocURL }})
|
|
29
|
+
{{/if}}
|
|
30
|
+
{{#if samplesURL}}
|
|
31
|
+
- [Samples]({{ samplesURL }})
|
|
32
|
+
{{/if}}
|
|
33
|
+
|
|
34
|
+
## Getting started
|
|
35
|
+
|
|
36
|
+
### Currently supported environments
|
|
37
|
+
|
|
38
|
+
- LTS versions of Node.js
|
|
39
|
+
|
|
40
|
+
### Prerequisites
|
|
41
|
+
|
|
42
|
+
- You must have an [Azure subscription](https://azure.microsoft.com/free/){{#if dependencyLink}} and follow [these]({{ dependencyLink }}) instructions{{/if}} to use this package.
|
|
43
|
+
|
|
44
|
+
### Install the \`{{ clientPackageName }}\` package
|
|
45
|
+
|
|
46
|
+
Install the {{ clientDescriptiveName }} REST client library for JavaScript with \`npm\`:
|
|
47
|
+
|
|
48
|
+
\`\`\`bash
|
|
49
|
+
npm install {{ clientPackageName }}
|
|
50
|
+
\`\`\`
|
|
51
|
+
|
|
52
|
+
### Create and authenticate a \`{{ clientClassName }}\`
|
|
53
|
+
|
|
54
|
+
To use an [Azure Active Directory (AAD) token credential](https://github.com/Azure/azure-sdk-for-js/blob/main/sdk/identity/identity/samples/AzureIdentityExamples.md#authenticating-with-a-pre-fetched-access-token),
|
|
55
|
+
provide an instance of the desired credential type obtained from the
|
|
56
|
+
[@azure/identity](https://github.com/Azure/azure-sdk-for-js/tree/main/sdk/identity/identity#credentials) library.
|
|
57
|
+
|
|
58
|
+
To authenticate with AAD, you must first \`npm\` install [\`@azure/identity\`](https://www.npmjs.com/package/@azure/identity) {{#if dependencyLink}}and
|
|
59
|
+
[{{dependencyDescription }}]({{ dependencyLink }}){{/if}}
|
|
60
|
+
|
|
61
|
+
After setup, you can choose which type of [credential](https://github.com/Azure/azure-sdk-for-js/tree/main/sdk/identity/identity#credentials) from \`@azure/identity\` to use.
|
|
62
|
+
As an example, [DefaultAzureCredential](https://github.com/Azure/azure-sdk-for-js/tree/main/sdk/identity/identity#defaultazurecredential)
|
|
63
|
+
can be used to authenticate the client.
|
|
64
|
+
|
|
65
|
+
Set the values of the client ID, tenant ID, and client secret of the AAD application as environment variables:
|
|
66
|
+
AZURE_CLIENT_ID, AZURE_TENANT_ID, AZURE_CLIENT_SECRET
|
|
67
|
+
|
|
68
|
+
## Troubleshooting
|
|
69
|
+
|
|
70
|
+
### Logging
|
|
71
|
+
|
|
72
|
+
Enabling logging may help uncover useful information about failures. In order to see a log of HTTP requests and responses, set the \`AZURE_LOG_LEVEL\` environment variable to \`info\`. Alternatively, logging can be enabled at runtime by calling \`setLogLevel\` in the \`@azure/logger\`:
|
|
73
|
+
|
|
74
|
+
\`\`\`javascript
|
|
75
|
+
const { setLogLevel } = require("@azure/logger");
|
|
76
|
+
|
|
77
|
+
setLogLevel("info");
|
|
78
|
+
\`\`\`
|
|
79
|
+
|
|
80
|
+
For more detailed instructions on how to enable logs, you can look at the [@azure/logger package docs](https://github.com/Azure/azure-sdk-for-js/tree/main/sdk/core/logger).
|
|
81
|
+
`;
|
|
82
|
+
|
|
83
|
+
/**
|
|
84
|
+
* Meta data information about the service, the package, and the client.
|
|
85
|
+
*/
|
|
86
|
+
interface Metadata {
|
|
87
|
+
/** The name of the service */
|
|
88
|
+
serviceName: string;
|
|
89
|
+
/** The name of the package */
|
|
90
|
+
clientPackageName: string;
|
|
91
|
+
/** The name of the client class */
|
|
92
|
+
clientClassName: string;
|
|
93
|
+
/** The URL of the repository the package lives in */
|
|
94
|
+
repoURL?: string;
|
|
95
|
+
/** The URL to the package directory in the repository */
|
|
96
|
+
packageSourceURL?: string;
|
|
97
|
+
/** The URL to the package's samples */
|
|
98
|
+
samplesURL?: string;
|
|
99
|
+
/** A descriptive name for the client extracted from the swagger */
|
|
100
|
+
clientDescriptiveName?: string;
|
|
101
|
+
/** A description for the service extracted from the swagger */
|
|
102
|
+
description?: string;
|
|
103
|
+
/** The URL to the package on npmjs.org */
|
|
104
|
+
packageNPMURL?: string;
|
|
105
|
+
/** The name of the project that lives in the repository */
|
|
106
|
+
projectName?: string;
|
|
107
|
+
/** whether the client accepts standard credentials */
|
|
108
|
+
addCredentials?: boolean;
|
|
109
|
+
/** The link to the identity package in the repository */
|
|
110
|
+
identityPackageURL?: string;
|
|
111
|
+
/** The URL for the service document */
|
|
112
|
+
serviceDocURL?: string;
|
|
113
|
+
/** The dependency info for this service */
|
|
114
|
+
dependencyDescription?: string;
|
|
115
|
+
dependencyLink?: string;
|
|
116
|
+
/** Indicates if the package is a multi-client */
|
|
117
|
+
hasMultiClients?: boolean;
|
|
118
|
+
/** The URL to the API reference */
|
|
119
|
+
apiRefURL?: string;
|
|
120
|
+
/** Check if the rp is management plane */
|
|
121
|
+
azureArm?: boolean;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
export function buildReadmeFile(model: RLCModel) {
|
|
125
|
+
const generateMetadata = Boolean(model.options?.generateMetadata);
|
|
126
|
+
if (!generateMetadata) {
|
|
127
|
+
return;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
const metadata = createMetadata(model) ?? {};
|
|
131
|
+
const readmeFileContents = hbs.compile(readmeTemplate, { noEscape: true });
|
|
132
|
+
return {
|
|
133
|
+
path: "README.md",
|
|
134
|
+
content: readmeFileContents(metadata)
|
|
135
|
+
};
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
/**
|
|
139
|
+
* Returns meta data information about the service, the package, and the client.
|
|
140
|
+
* @param codeModel - include the client details
|
|
141
|
+
* @returns inferred metadata about the service, the package, and the client
|
|
142
|
+
*/
|
|
143
|
+
function createMetadata(model: RLCModel): Metadata | undefined {
|
|
144
|
+
if (!model.options || !model.options.packageDetails) {
|
|
145
|
+
return;
|
|
146
|
+
}
|
|
147
|
+
// const packageDetails = model.options.packageDetails;
|
|
148
|
+
const {
|
|
149
|
+
packageDetails,
|
|
150
|
+
azureOutputDirectory,
|
|
151
|
+
productDocLink,
|
|
152
|
+
dependencyInfo,
|
|
153
|
+
multiClient,
|
|
154
|
+
batch,
|
|
155
|
+
serviceInfo
|
|
156
|
+
} = model.options;
|
|
157
|
+
|
|
158
|
+
const azureHuh =
|
|
159
|
+
packageDetails?.scopeName === "azure" ||
|
|
160
|
+
packageDetails?.scopeName === "azure-rest";
|
|
161
|
+
const repoURL = "https://github.com/Azure/azure-sdk-for-js";
|
|
162
|
+
const relativePackageSourcePath = azureOutputDirectory;
|
|
163
|
+
const packageSourceURL =
|
|
164
|
+
relativePackageSourcePath &&
|
|
165
|
+
repoURL &&
|
|
166
|
+
`${repoURL}/tree/main/${relativePackageSourcePath}`;
|
|
167
|
+
|
|
168
|
+
const clientPackageName = packageDetails?.name;
|
|
169
|
+
const clientClassName = getClientName(model);
|
|
170
|
+
const serviceName = getServiceName(model);
|
|
171
|
+
let apiRefUrlQueryParameter: string = "";
|
|
172
|
+
if (packageDetails?.version.includes("beta")) {
|
|
173
|
+
apiRefUrlQueryParameter = "?view=azure-node-preview";
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
return {
|
|
177
|
+
serviceName,
|
|
178
|
+
clientClassName,
|
|
179
|
+
clientPackageName: clientPackageName,
|
|
180
|
+
clientDescriptiveName: `${serviceName} REST client`,
|
|
181
|
+
description: serviceInfo?.description ?? packageDetails.description,
|
|
182
|
+
serviceDocURL: productDocLink,
|
|
183
|
+
packageSourceURL: packageSourceURL,
|
|
184
|
+
packageNPMURL: `https://www.npmjs.com/package/${clientPackageName}`,
|
|
185
|
+
samplesURL: packageSourceURL && `${packageSourceURL}/samples`,
|
|
186
|
+
apiRefURL: azureHuh
|
|
187
|
+
? `https://docs.microsoft.com/javascript/api/${clientPackageName}${apiRefUrlQueryParameter}`
|
|
188
|
+
: undefined,
|
|
189
|
+
dependencyDescription: dependencyInfo?.description,
|
|
190
|
+
dependencyLink: dependencyInfo?.link,
|
|
191
|
+
hasMultiClients: multiClient && batch && batch.length > 1,
|
|
192
|
+
azureArm: Boolean(model.options.azureArm)
|
|
193
|
+
};
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
function getServiceName(model: RLCModel) {
|
|
197
|
+
const azureHuh =
|
|
198
|
+
model?.options?.packageDetails?.scopeName === "azure" ||
|
|
199
|
+
model?.options?.packageDetails?.scopeName === "azure-rest";
|
|
200
|
+
const libraryName = model.libraryName;
|
|
201
|
+
const serviceTitle = model.options?.serviceInfo?.title ?? model.libraryName;
|
|
202
|
+
const batch = model?.options?.batch,
|
|
203
|
+
packageDetails = model?.options?.packageDetails!;
|
|
204
|
+
let simpleServiceName =
|
|
205
|
+
batch && batch.length > 1
|
|
206
|
+
? normalizeName(packageDetails.nameWithoutScope || "", NameType.Class)
|
|
207
|
+
: normalizeName(serviceTitle, NameType.Class);
|
|
208
|
+
simpleServiceName =
|
|
209
|
+
/**
|
|
210
|
+
* It is a required convention in Azure swaggers for their titles to end with
|
|
211
|
+
* "Client".
|
|
212
|
+
*/
|
|
213
|
+
serviceTitle.match(/(.*) Client/)?.[1] ??
|
|
214
|
+
serviceTitle.match(/(.*)Client/)?.[1] ??
|
|
215
|
+
libraryName.match(/(.*)Client/)?.[1] ??
|
|
216
|
+
serviceTitle.match(/(.*) Service/)?.[1] ??
|
|
217
|
+
simpleServiceName;
|
|
218
|
+
|
|
219
|
+
return azureHuh
|
|
220
|
+
? simpleServiceName.startsWith("Azure")
|
|
221
|
+
? simpleServiceName
|
|
222
|
+
: `Azure ${simpleServiceName}`
|
|
223
|
+
: simpleServiceName;
|
|
224
|
+
}
|
|
225
|
+
|
|
226
|
+
function getClientName(model: RLCModel) {
|
|
227
|
+
const clientName = model.libraryName;
|
|
228
|
+
return clientName.endsWith("Client")
|
|
229
|
+
? `${clientName}`
|
|
230
|
+
: `${clientName}Client`;
|
|
231
|
+
}
|