@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.
Files changed (232) hide show
  1. package/.eslintrc.json +23 -0
  2. package/.prettierignore +1 -0
  3. package/.prettierrc +7 -0
  4. package/.rush/temp/package-deps_build.json +53 -0
  5. package/.rush/temp/shrinkwrap-deps.json +147 -0
  6. package/CHANGELOG.md +61 -0
  7. package/CONTRIBUTING.md +30 -0
  8. package/README.md +3 -0
  9. package/dist/buildClient.js +268 -0
  10. package/dist/buildClient.js.map +1 -0
  11. package/dist/buildClientDefinitions.js +160 -0
  12. package/dist/buildClientDefinitions.js.map +1 -0
  13. package/dist/buildIndexFile.js +170 -0
  14. package/dist/buildIndexFile.js.map +1 -0
  15. package/dist/buildIsUnexpectedHelper.js +220 -0
  16. package/dist/buildIsUnexpectedHelper.js.map +1 -0
  17. package/dist/buildMethodShortcuts.js +50 -0
  18. package/dist/buildMethodShortcuts.js.map +1 -0
  19. package/dist/buildObjectTypes.js +286 -0
  20. package/dist/buildObjectTypes.js.map +1 -0
  21. package/dist/buildPaginateHelper.js +30 -0
  22. package/dist/buildPaginateHelper.js.map +1 -0
  23. package/dist/buildParameterTypes.js +315 -0
  24. package/dist/buildParameterTypes.js.map +1 -0
  25. package/dist/buildPollingHelper.js +21 -0
  26. package/dist/buildPollingHelper.js.map +1 -0
  27. package/dist/buildResponseTypes.js +135 -0
  28. package/dist/buildResponseTypes.js.map +1 -0
  29. package/dist/buildSchemaType.js +65 -0
  30. package/dist/buildSchemaType.js.map +1 -0
  31. package/dist/buildSerializeHelper.js +35 -0
  32. package/dist/buildSerializeHelper.js.map +1 -0
  33. package/dist/buildTopLevelIndexFile.js +48 -0
  34. package/dist/buildTopLevelIndexFile.js.map +1 -0
  35. package/dist/helpers/nameConstructors.js +41 -0
  36. package/dist/helpers/nameConstructors.js.map +1 -0
  37. package/dist/helpers/nameUtils.js +196 -0
  38. package/dist/helpers/nameUtils.js.map +1 -0
  39. package/dist/helpers/operationHelpers.js +103 -0
  40. package/dist/helpers/operationHelpers.js.map +1 -0
  41. package/dist/helpers/pathUtils.js +13 -0
  42. package/dist/helpers/pathUtils.js.map +1 -0
  43. package/dist/helpers/schemaHelpers.js +27 -0
  44. package/dist/helpers/schemaHelpers.js.map +1 -0
  45. package/dist/helpers/shortcutMethods.js +46 -0
  46. package/dist/helpers/shortcutMethods.js.map +1 -0
  47. package/dist/index.js +45 -0
  48. package/dist/index.js.map +1 -0
  49. package/dist/interfaces.js +18 -0
  50. package/dist/interfaces.js.map +1 -0
  51. package/dist/metadata/buildApiExtractorConfig.js +56 -0
  52. package/dist/metadata/buildApiExtractorConfig.js.map +1 -0
  53. package/dist/metadata/buildESLintConfig.js +33 -0
  54. package/dist/metadata/buildESLintConfig.js.map +1 -0
  55. package/dist/metadata/buildLicenseFile.js +41 -0
  56. package/dist/metadata/buildLicenseFile.js.map +1 -0
  57. package/dist/metadata/buildPackageFile.js +274 -0
  58. package/dist/metadata/buildPackageFile.js.map +1 -0
  59. package/dist/metadata/buildReadmeFile.js +170 -0
  60. package/dist/metadata/buildReadmeFile.js.map +1 -0
  61. package/dist/metadata/buildRollupConfig.js +144 -0
  62. package/dist/metadata/buildRollupConfig.js.map +1 -0
  63. package/dist/metadata/buildTsConfig.js +72 -0
  64. package/dist/metadata/buildTsConfig.js.map +1 -0
  65. package/dist/package.json +1 -0
  66. package/dist/static/paginateContent.js +214 -0
  67. package/dist/static/paginateContent.js.map +1 -0
  68. package/dist/static/pollingContent.js +98 -0
  69. package/dist/static/pollingContent.js.map +1 -0
  70. package/dist/static/serializeHelper.js +30 -0
  71. package/dist/static/serializeHelper.js.map +1 -0
  72. package/dist/test/buildEnvFile.js +31 -0
  73. package/dist/test/buildEnvFile.js.map +1 -0
  74. package/dist/test/buildKarmaConfig.js +19 -0
  75. package/dist/test/buildKarmaConfig.js.map +1 -0
  76. package/dist/test/buildRecordedClient.js +22 -0
  77. package/dist/test/buildRecordedClient.js.map +1 -0
  78. package/dist/test/buildSampleTest.js +19 -0
  79. package/dist/test/buildSampleTest.js.map +1 -0
  80. package/dist/test/template.js +191 -0
  81. package/dist/test/template.js.map +1 -0
  82. package/dist-esm/buildClient.js +261 -0
  83. package/dist-esm/buildClient.js.map +1 -0
  84. package/dist-esm/buildClientDefinitions.js +155 -0
  85. package/dist-esm/buildClientDefinitions.js.map +1 -0
  86. package/dist-esm/buildIndexFile.js +165 -0
  87. package/dist-esm/buildIndexFile.js.map +1 -0
  88. package/dist-esm/buildIsUnexpectedHelper.js +216 -0
  89. package/dist-esm/buildIsUnexpectedHelper.js.map +1 -0
  90. package/dist-esm/buildMethodShortcuts.js +46 -0
  91. package/dist-esm/buildMethodShortcuts.js.map +1 -0
  92. package/dist-esm/buildObjectTypes.js +288 -0
  93. package/dist-esm/buildObjectTypes.js.map +1 -0
  94. package/dist-esm/buildPaginateHelper.js +26 -0
  95. package/dist-esm/buildPaginateHelper.js.map +1 -0
  96. package/dist-esm/buildParameterTypes.js +321 -0
  97. package/dist-esm/buildParameterTypes.js.map +1 -0
  98. package/dist-esm/buildPollingHelper.js +17 -0
  99. package/dist-esm/buildPollingHelper.js.map +1 -0
  100. package/dist-esm/buildResponseTypes.js +140 -0
  101. package/dist-esm/buildResponseTypes.js.map +1 -0
  102. package/dist-esm/buildSchemaType.js +60 -0
  103. package/dist-esm/buildSchemaType.js.map +1 -0
  104. package/dist-esm/buildSerializeHelper.js +31 -0
  105. package/dist-esm/buildSerializeHelper.js.map +1 -0
  106. package/dist-esm/buildTopLevelIndexFile.js +44 -0
  107. package/dist-esm/buildTopLevelIndexFile.js.map +1 -0
  108. package/dist-esm/helpers/nameConstructors.js +34 -0
  109. package/dist-esm/helpers/nameConstructors.js.map +1 -0
  110. package/dist-esm/helpers/nameUtils.js +187 -0
  111. package/dist-esm/helpers/nameUtils.js.map +1 -0
  112. package/dist-esm/helpers/operationHelpers.js +84 -0
  113. package/dist-esm/helpers/operationHelpers.js.map +1 -0
  114. package/dist-esm/helpers/pathUtils.js +9 -0
  115. package/dist-esm/helpers/pathUtils.js.map +1 -0
  116. package/dist-esm/helpers/schemaHelpers.js +21 -0
  117. package/dist-esm/helpers/schemaHelpers.js.map +1 -0
  118. package/dist-esm/helpers/shortcutMethods.js +42 -0
  119. package/dist-esm/helpers/shortcutMethods.js.map +1 -0
  120. package/dist-esm/index.js +29 -0
  121. package/dist-esm/index.js.map +1 -0
  122. package/dist-esm/interfaces.js +15 -0
  123. package/dist-esm/interfaces.js.map +1 -0
  124. package/dist-esm/metadata/buildApiExtractorConfig.js +51 -0
  125. package/dist-esm/metadata/buildApiExtractorConfig.js.map +1 -0
  126. package/dist-esm/metadata/buildESLintConfig.js +28 -0
  127. package/dist-esm/metadata/buildESLintConfig.js.map +1 -0
  128. package/dist-esm/metadata/buildLicenseFile.js +36 -0
  129. package/dist-esm/metadata/buildLicenseFile.js.map +1 -0
  130. package/dist-esm/metadata/buildPackageFile.js +276 -0
  131. package/dist-esm/metadata/buildPackageFile.js.map +1 -0
  132. package/dist-esm/metadata/buildReadmeFile.js +167 -0
  133. package/dist-esm/metadata/buildReadmeFile.js.map +1 -0
  134. package/dist-esm/metadata/buildRollupConfig.js +139 -0
  135. package/dist-esm/metadata/buildRollupConfig.js.map +1 -0
  136. package/dist-esm/metadata/buildTsConfig.js +67 -0
  137. package/dist-esm/metadata/buildTsConfig.js.map +1 -0
  138. package/dist-esm/package.json +1 -0
  139. package/dist-esm/static/paginateContent.js +211 -0
  140. package/dist-esm/static/paginateContent.js.map +1 -0
  141. package/dist-esm/static/pollingContent.js +95 -0
  142. package/dist-esm/static/pollingContent.js.map +1 -0
  143. package/dist-esm/static/serializeHelper.js +27 -0
  144. package/dist-esm/static/serializeHelper.js.map +1 -0
  145. package/dist-esm/test/buildEnvFile.js +24 -0
  146. package/dist-esm/test/buildEnvFile.js.map +1 -0
  147. package/dist-esm/test/buildKarmaConfig.js +14 -0
  148. package/dist-esm/test/buildKarmaConfig.js.map +1 -0
  149. package/dist-esm/test/buildRecordedClient.js +17 -0
  150. package/dist-esm/test/buildRecordedClient.js.map +1 -0
  151. package/dist-esm/test/buildSampleTest.js +14 -0
  152. package/dist-esm/test/buildSampleTest.js.map +1 -0
  153. package/dist-esm/test/template.js +188 -0
  154. package/dist-esm/test/template.js.map +1 -0
  155. package/package.json +46 -0
  156. package/publishPackage.js +11 -0
  157. package/rlc-common.build.log +2 -0
  158. package/src/buildClient.ts +353 -0
  159. package/src/buildClientDefinitions.ts +235 -0
  160. package/src/buildIndexFile.ts +202 -0
  161. package/src/buildIsUnexpectedHelper.ts +240 -0
  162. package/src/buildMethodShortcuts.ts +75 -0
  163. package/src/buildObjectTypes.ts +449 -0
  164. package/src/buildPaginateHelper.ts +33 -0
  165. package/src/buildParameterTypes.ts +477 -0
  166. package/src/buildPollingHelper.ts +18 -0
  167. package/src/buildResponseTypes.ts +186 -0
  168. package/src/buildSchemaType.ts +85 -0
  169. package/src/buildSerializeHelper.ts +42 -0
  170. package/src/buildTopLevelIndexFile.ts +52 -0
  171. package/src/helpers/nameConstructors.ts +93 -0
  172. package/src/helpers/nameUtils.ts +227 -0
  173. package/src/helpers/operationHelpers.ts +119 -0
  174. package/src/helpers/pathUtils.ts +9 -0
  175. package/src/helpers/schemaHelpers.ts +25 -0
  176. package/src/helpers/shortcutMethods.ts +60 -0
  177. package/src/index.ts +29 -0
  178. package/src/interfaces.ts +227 -0
  179. package/src/metadata/buildApiExtractorConfig.ts +59 -0
  180. package/src/metadata/buildESLintConfig.ts +34 -0
  181. package/src/metadata/buildLicenseFile.ts +39 -0
  182. package/src/metadata/buildPackageFile.ts +334 -0
  183. package/src/metadata/buildReadmeFile.ts +231 -0
  184. package/src/metadata/buildRollupConfig.ts +147 -0
  185. package/src/metadata/buildTsConfig.ts +79 -0
  186. package/src/static/paginateContent.ts +210 -0
  187. package/src/static/pollingContent.ts +94 -0
  188. package/src/static/serializeHelper.ts +29 -0
  189. package/src/test/buildEnvFile.ts +26 -0
  190. package/src/test/buildKarmaConfig.ts +15 -0
  191. package/src/test/buildRecordedClient.ts +18 -0
  192. package/src/test/buildSampleTest.ts +15 -0
  193. package/src/test/template.ts +191 -0
  194. package/tsconfig-cjs.json +9 -0
  195. package/tsconfig-common.json +13 -0
  196. package/tsconfig.json +13 -0
  197. package/types/buildClient.d.ts +2 -0
  198. package/types/buildClientDefinitions.d.ts +5 -0
  199. package/types/buildIndexFile.d.ts +5 -0
  200. package/types/buildIsUnexpectedHelper.d.ts +5 -0
  201. package/types/buildMethodShortcuts.d.ts +4 -0
  202. package/types/buildObjectTypes.d.ts +15 -0
  203. package/types/buildPaginateHelper.d.ts +5 -0
  204. package/types/buildParameterTypes.d.ts +13 -0
  205. package/types/buildPollingHelper.d.ts +5 -0
  206. package/types/buildResponseTypes.d.ts +5 -0
  207. package/types/buildSchemaType.d.ts +19 -0
  208. package/types/buildSerializeHelper.d.ts +5 -0
  209. package/types/buildTopLevelIndexFile.d.ts +5 -0
  210. package/types/helpers/nameConstructors.d.ts +28 -0
  211. package/types/helpers/nameUtils.d.ts +25 -0
  212. package/types/helpers/operationHelpers.d.ts +13 -0
  213. package/types/helpers/pathUtils.d.ts +1 -0
  214. package/types/helpers/schemaHelpers.d.ts +4 -0
  215. package/types/helpers/shortcutMethods.d.ts +3 -0
  216. package/types/index.d.ts +26 -0
  217. package/types/interfaces.d.ts +200 -0
  218. package/types/metadata/buildApiExtractorConfig.d.ts +5 -0
  219. package/types/metadata/buildESLintConfig.d.ts +5 -0
  220. package/types/metadata/buildLicenseFile.d.ts +5 -0
  221. package/types/metadata/buildPackageFile.d.ts +5 -0
  222. package/types/metadata/buildReadmeFile.d.ts +5 -0
  223. package/types/metadata/buildRollupConfig.d.ts +5 -0
  224. package/types/metadata/buildTsConfig.d.ts +5 -0
  225. package/types/static/paginateContent.d.ts +1 -0
  226. package/types/static/pollingContent.d.ts +1 -0
  227. package/types/static/serializeHelper.d.ts +4 -0
  228. package/types/test/buildEnvFile.d.ts +9 -0
  229. package/types/test/buildKarmaConfig.d.ts +5 -0
  230. package/types/test/buildRecordedClient.d.ts +5 -0
  231. package/types/test/buildSampleTest.d.ts +5 -0
  232. 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
+ }