@accelbyte/codegen 3.0.6 → 3.1.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.
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"accelbyte-codegen.mjs","sources":["../src/CliParser.ts","../src/templates/template-class.ts","../src/templates/template-api-class.ts","../src/helpers/VersionHelpers.ts","../src/ParserUtils.ts","../src/templates/template-zod.ts","../src/templates/template-api-index.ts","../src/Swagger.ts","../src/templates/template-method.ts","../src/templates/template-api-method.ts","../src/templates/template-sdk-snippet.ts","../src/helpers/SwaggerReaderHelpers.ts","../src/CodeGenerator.ts","../src/SwaggerDownloader.ts","../src/cli.ts"],"sourcesContent":["/*\n * Copyright (c) 2022-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\n\nimport { Argv } from 'yargs'\nimport { z } from 'zod'\nimport fs from 'fs'\nimport * as path from 'path'\n\nconst SwaggersConfig = z.array(z.array(z.string()))\ntype SwaggersConfig = z.TypeOf<typeof SwaggersConfig>\n\nexport interface CliOption\n extends Argv<{\n config: string\n swaggersOutput: string\n output: string\n }> {}\n\nexport class CliParser {\n private static _instance: CliParser\n public argv\n constructor(yargs: CliOption) {\n this.argv = yargs.parse()\n }\n\n public static createInstance = (yargs: CliOption) => {\n CliParser._instance = new CliParser(yargs)\n return CliParser._instance\n }\n\n private static instance = (yargs?: CliOption) => {\n if (!CliParser._instance && yargs) {\n return CliParser.createInstance(yargs)\n }\n return CliParser._instance\n }\n\n public static getConfigPath = (): string => {\n return CliParser.instance().argv.config\n }\n\n public static getConfigFile = (): SwaggersConfig => {\n const configPath = CliParser.getConfigPath()\n if (!configPath) throw new Error('Missing config file')\n const config = JSON.parse(fs.readFileSync(configPath, 'utf8'))\n if (!SwaggersConfig.safeParse(config).success) {\n throw new Error('Wrong config file format')\n }\n return config\n }\n\n public static getOutputPath = (): string => {\n return CliParser.instance().argv.output\n }\n\n public static getSwaggersOutputPath = (): string => {\n return CliParser.instance().argv.swaggersOutput\n }\n\n public static getResolvedSwaggersOutputPath = (): string => {\n return path.resolve(CliParser.getSwaggersOutputPath())\n }\n\n public static getSnippetOutputPath = (): string => {\n return CliParser.instance().argv.snippetOutput\n }\n\n // TODO: remove this, since this is not used apparently.\n public static skipVersionSync = (): boolean => {\n return CliParser.instance().argv.skipVersionSync\n }\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nconst getImportableVarMap = () => ({\n '@accelbyte/sdk': ['CodeGenUtil', 'IResponse', 'Validate'],\n axios: ['AxiosRequestConfig', 'AxiosResponse'],\n zod: ['z']\n})\n\nconst makeNewImportVarMap = () => ({\n axios: ['AxiosInstance'],\n '@accelbyte/sdk': ['SDKRequestConfig']\n})\n\nexport const generateImports = (body: string, importStatements: string[], makeNewImportVarMap, getImportableVarMap) => {\n const usedImportVarMap = makeNewImportVarMap\n const importableVarMap = getImportableVarMap\n\n for (const [moduleSource, importableVars] of Object.entries(importableVarMap)) {\n // @ts-ignore\n for (const importableVar of importableVars) {\n const importVarRegex = new RegExp(`(?<![\\\\d\\\\w_])${importableVar}(?![\\\\d\\\\w_])`)\n if (body.match(importVarRegex)) {\n usedImportVarMap[moduleSource] = [...(usedImportVarMap[moduleSource] || []), importableVar]\n }\n }\n }\n\n const generatedImports = Object.keys(usedImportVarMap)\n .sort()\n .map((moduleSource: string) => {\n return `import { ${usedImportVarMap[moduleSource].sort().join(', ')} } from '${moduleSource}'`\n })\n .join('\\n')\n return `${generatedImports}\\n${importStatements.sort().join('\\n')}`\n}\n\nexport const templateClass = (className: string, body: string, importStatements: string[]): string => {\n return `/**\n * AUTO GENERATED\n */\n${generateImports(body, importStatements, makeNewImportVarMap(), getImportableVarMap())}\n\nexport class ${className} {\n // @ts-ignore\n constructor(private axiosInstance: AxiosInstance, private namespace: string, private isZodEnabled = true) {}\n ${body}\n}\n `\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport { generateImports } from './template-class'\n\nconst getImportableVarMap = () => ({\n '@accelbyte/sdk': ['CodeGenUtil', 'IResponse', 'Validate', 'ApiArgs', 'Network', 'AccelbyteSDK']\n})\n\nconst makeNewImportVarMap = () => ({\n '@accelbyte/sdk': ['AccelbyteSDK', 'ApiArgs', 'ApiUtils']\n})\n\n// TODO localStorage('ZodEnabled')=false disables Zod validation in browser only. TODO move to Featureflag instead\nexport const templateApiClass = (className: string, body: string, importStatements: string[], returnMethods: string): string => {\n return `/**\n * AUTO GENERATED\n */\n/* eslint-disable camelcase */\n// @ts-ignore -> ts-expect-error TS6133\n${generateImports(body, importStatements, makeNewImportVarMap(), getImportableVarMap())}\n\nexport function ${className}(sdk: AccelbyteSDK, args?: ApiArgs) {\n const sdkAssembly = sdk.assembly()\n \n const namespace = args?.namespace ? args?.namespace : sdkAssembly.namespace\n const requestConfig = ApiUtils.mergedConfigs(sdkAssembly.config, args)\n const isZodEnabled = typeof window !== \"undefined\" && localStorage.getItem('ZodEnabled') !== 'false' \n ${body}\n \n return {\n ${returnMethods}\n }\n}\n `\n}\n","/*\n * Copyright (c) 2023 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\n\nimport semver from 'semver'\nimport { z } from 'zod'\n\nexport const VersionBumpType = z.enum(['CUTOFF', 'RELEASE', 'HOTFIX', 'BREAKING'])\n\nexport class VersionHelpers {\n /**\n * This function calculates the next version, given 5 aspects:\n *\n * 1. The SDK version (prerelease)\n * 2. Prerelease ID\n *\n * Each of the component (major, minor, patch) will be added up, then the prerelease version will be matched with the prerelease ID.\n * If the current prerelease ID == next prerelease ID and there are no component changes, then bump the prerelease ID.\n *\n * For more examples, see the test file.\n *\n * @param param0\n * @returns\n */\n static getNextVersion = ({\n serviceVersion,\n versionBumpType,\n sdkVersion,\n nextPrereleaseId\n }: {\n serviceVersion: string\n versionBumpType?: string\n sdkVersion: string\n nextPrereleaseId: string\n }) => {\n // Validate the `versionBumpType`, if it's defined.\n if (versionBumpType !== undefined) {\n const parsed = VersionBumpType.safeParse(versionBumpType)\n if (!parsed.success) {\n throw new Error(`Invalid process.env.VERSION_BUMP_TYPE: ${versionBumpType}`)\n }\n\n // When `versionBumpType` is eitehr HOTFIX or RELEASE, `nextPrereleaseId` should not be set.\n // This is because official stable releases don't use prerelease versions.\n if ((parsed.data === 'HOTFIX' || parsed.data === 'RELEASE') && nextPrereleaseId) {\n throw new Error(`process.env.PRERELEASE_ID should be empty when process.env.VERSION_BUMP_TYPE is \"HOTFIX\" or \"PRELEASE\".`)\n }\n }\n\n // For reference, try this playground: https://codesandbox.io/s/dreamy-hopper-9drqcu?file=/src/App.js.\n const serviceSemvers = semver.parse(serviceVersion)\n const sdkSemvers = semver.parse(sdkVersion)\n\n if (serviceSemvers === null) {\n throw new Error(`Invalid service version: ${serviceVersion}`)\n }\n\n if (sdkSemvers === null) {\n throw new Error(`Invalid sdk version: ${sdkVersion}`)\n }\n\n const { major: currentMajor, minor: currentMinor, patch: currentPatch, prerelease: currentPrerelease } = sdkSemvers\n let nextMajor = currentMajor\n let nextMinor = currentMinor\n let nextPatch = currentPatch\n\n switch (versionBumpType) {\n // This only exist if we want to bump the sdk major versions\n // Probably, it'll be best if we manually bump it if it's an actual BREAKING CHANGE\n case VersionBumpType.Enum.BREAKING: {\n nextMajor++\n nextMinor = 0\n nextPatch = 0\n break\n }\n\n case VersionBumpType.Enum.CUTOFF: {\n nextMinor++\n nextPatch = 0\n break\n }\n case VersionBumpType.Enum.RELEASE:\n break\n case VersionBumpType.Enum.HOTFIX: {\n nextPatch++\n break\n }\n default:\n break\n }\n\n let nextVersion = [\n // For major version, we want to avoid false-positive breaking changes.\n // If we want to publish major version, we have to bump manually via\n // `predefinedMajorVersion` in the `sdk-*` that needs updating.\n nextMajor,\n nextMinor,\n nextPatch\n ].join('.')\n\n if (nextPrereleaseId) {\n if (nextMinor !== currentMinor) {\n // If minor/patch version is the same, then we want to keep the current prerelase version, e.g.\n // `-beta.5` to `-beta.6` instead of going back to 0.\n //\n // However, if it's different, we want to reset it to 0.\n nextVersion += `-${nextPrereleaseId}.0`\n } else {\n if (currentPrerelease.length) nextVersion += `-${currentPrerelease.join('.')}`\n nextVersion = semver.inc(nextVersion, 'prerelease', undefined, nextPrereleaseId)\n }\n }\n\n return nextVersion\n }\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport { applyPatch, Operation } from 'fast-json-patch'\nimport fs, { readFileSync, writeFileSync } from 'fs'\nimport _ from 'lodash'\nimport path from 'path'\nimport { Endpoint, EndpointParameters } from './Swagger'\nimport { templateClass } from './templates/template-class'\nimport { templateApiClass } from './templates/template-api-class'\nimport { CliParser } from './CliParser'\nimport { VersionHelpers } from './helpers/VersionHelpers'\n\nconst UNDEFINED_SWAGGER_SEMVER = '0.0.0'\nconst REMOVED_KEYWORDS = [\n '/admin/',\n '/public/',\n '/v1/',\n '/v2/',\n '/v3/',\n '/v4/',\n '/v5/',\n '/namespace/' /* Note, it's not plural */,\n '/namespaces/',\n '/{namespace}/'\n]\n\nexport class ParserUtils {\n static replaceAll = (string, search, replace) => {\n return string.split(search).join(replace)\n }\n\n static generateClassName = (tag: string, isAdmin: boolean) => {\n const className = _.upperFirst(_.camelCase(tag))\n const classGenName = isAdmin ? className + 'Admin$' : className + '$'\n return { className, classGenName }\n }\n\n static generateApiName = (tag: string, isAdmin: boolean) => {\n const apiName = _.upperFirst(_.camelCase(tag))\n const apiGenName = isAdmin ? apiName + 'AdminApi' : apiName + 'Api'\n return { apiName, apiGenName }\n }\n\n static parseQueryParamAttributeDefault = (definition: EndpointParameters) => {\n const attrName = definition.name.slice(definition.name.lastIndexOf('.') + 1)\n let defaultValue = definition.default\n\n if (definition.type === 'array' && Array.isArray(definition.default)) {\n const mappedDefaultValue = definition.default.map(defaultValue =>\n typeof defaultValue === 'string' ? `'${defaultValue}'` : defaultValue\n )\n defaultValue = `[${mappedDefaultValue.join(', ')}]`\n }\n\n if (definition.type === 'string') {\n defaultValue = `'${definition.default}'`\n }\n return `${attrName}: ${defaultValue}`\n }\n\n static parseType = (pathParam: EndpointParameters) => {\n if (isSwaggerIntegerType(pathParam.type || pathParam?.schema?.type)) return 'number'\n if (pathParam.type === 'array') {\n if (isSwaggerIntegerType(pathParam.items.type)) return 'number[]'\n return `${pathParam.items.type ?? 'any'}[]`\n }\n if (pathParam?.schema?.type === 'array') {\n if (isSwaggerIntegerType(pathParam.schema.items.type)) return 'number[]'\n return `${pathParam.schema.items.type ?? 'any'}[]`\n }\n if (pathParam?.schema?.type) return pathParam.schema.type\n return pathParam.type\n }\n\n static parseQueryParamsType = (queryParams: EndpointParameters[]) => {\n return queryParams.map(queryParam => ParserUtils.parseAttributeType(queryParam)).join(', ')\n }\n\n static isAnyQueryParamRequired = (queryParams: EndpointParameters[]) => {\n return queryParams.some(queryParam => queryParam.required)\n }\n\n static convertDashesToTitleCase = str => {\n const result = str\n .split('-') // split the string at the hyphen\n .map((word, index) => {\n // capitalize the first letter of each word\n if (index === 0) {\n return word.charAt(0).toUpperCase() + word.slice(1)\n }\n return word.charAt(0).toUpperCase() + word.slice(1).toLowerCase()\n })\n .join('') // join the words together without a separator\n return result\n }\n\n static parseQueryParamsDefault = (queryParams: EndpointParameters[]) => {\n const result = queryParams\n .filter(queryParam => !!queryParam.default && !queryParam.required)\n .map(ParserUtils.parseQueryParamAttributeDefault)\n .join(',')\n return result ? `${result},` : ''\n }\n\n static parseBodyParamsImports = (bodyParams: EndpointParameters[]) => {\n return bodyParams.map(bodyParams => ParserUtils.parseRefImport(bodyParams)).filter(Boolean)\n }\n\n static parseImportDir = ($ref: string) => {\n let ref = $ref.replace('.', '/')\n if (ref[ref.length - 1] === '.' || ref[ref.length - 1] === '/') {\n ref = ref.slice(0, -1)\n }\n if (!ref.includes('/')) {\n return ''\n } else {\n return ref.slice(0, ref.lastIndexOf('/')).replace('#', '.')\n }\n }\n\n static parseRefImport = (bodyParam: EndpointParameters) => {\n const $ref = bodyParam?.schema?.$ref || bodyParam?.schema?.items?.$ref\n if (!$ref) {\n return null\n }\n const type = ParserUtils.parseRefType($ref)\n return `import { ${type} } from '../../generated-definitions/${type}.js'`\n }\n\n static parseRefType = ($ref: string) => {\n let ref = $ref.replace('.', '/')\n if (ref[ref.length - 1] === '.' || ref[ref.length - 1] === '/') {\n ref = ref.slice(0, -1)\n }\n const val = ref.slice(ref.lastIndexOf('/') + 1)\n // Converting it to TitleCase breaks schema refs. E.g. UserDataURL schema is converted to UserDataUrl breaking refs\n return _.upperFirst(_.camelCase(val)).replace(/( \\w)/g, group => group.replace(' ', '').toUpperCase())\n }\n\n static parseAttributeType = (definition: EndpointParameters) => {\n const required = definition.required ? '' : '?'\n\n const attrName = definition.name.slice(definition.name.lastIndexOf('.') + 1)\n\n if (definition.enum) {\n const enums = definition.enum.map(enm => (definition.type === 'string' ? `'${enm}'` : enm)).join(' | ')\n return `${attrName}${required}: ${enums}`\n }\n\n if (definition.type && ParserUtils.parseType(definition) === 'number') {\n return `${attrName}${required}: number`\n }\n\n if (definition?.schema?.type && ParserUtils.parseType(definition) === 'number') {\n return `${attrName}${required}: number`\n }\n\n if (definition.type && definition.type === 'array') {\n return `${attrName}${required}: ${definition.items.type ?? 'any'}[]`\n }\n\n if (definition?.schema?.type && definition.schema.type === 'array') {\n return `${attrName}${required}: ${definition.schema.items.type ?? 'any'}[]`\n }\n\n if (definition.type && definition.type === 'file') {\n return `${attrName}${required}: File`\n }\n\n if (definition?.schema?.type && definition.schema.type === 'file') {\n return `${attrName}${required}: File`\n }\n\n if (definition.type && definition.type) {\n return `${attrName}${required}: ${definition.type} | null`\n }\n\n if (definition?.schema?.type && definition.schema.type) {\n return `${attrName}${required}: ${definition.schema.type} | null`\n }\n\n return `${attrName}${required}: any`\n }\n\n static parseBodyParamsType = (bodyParams: EndpointParameters[]): string => {\n const [bodyParam] = bodyParams\n\n if (!bodyParam) return null\n\n if (bodyParams.length > 0 && bodyParam?.name !== 'body' && !bodyParam?.schema) {\n let retBodyParams = `{${bodyParams.map(bodyParam => ParserUtils.parseAttributeType(bodyParam)).join(',')}}`\n retBodyParams = retBodyParams.replace('file?: file', 'file?: File') // fixed TS type File\n return retBodyParams\n }\n\n if (bodyParam?.schema?.type === 'array' && !bodyParam?.schema?.items?.$ref) {\n if (isSwaggerIntegerType(bodyParam.schema.items.type)) return 'number[]'\n return `${bodyParam.schema.items.type ?? 'any'}[]`\n }\n\n if (bodyParam?.schema?.type === 'array' && bodyParam?.schema?.items?.$ref) {\n return `${ParserUtils.parseRefType(bodyParam.schema.items.$ref)}[]`\n }\n\n if (bodyParam?.schema.$ref) {\n return ParserUtils.parseRefType(bodyParam.schema.$ref)\n }\n\n if (bodyParam?.schema?.additionalProperties?.type === 'object') {\n return 'any'\n }\n\n return null\n }\n\n static get2xxResponse(methodEntity: Endpoint['responses']): string {\n const keys = Object.keys(methodEntity)\n let responseClass = null\n keys.forEach(key => {\n if (String(key).startsWith('2')) {\n const sch = methodEntity[key].schema\n const schV3 = methodEntity[key].content && methodEntity[key].content['application/json'].schema\n if (sch?.$ref) {\n responseClass = ParserUtils.parseRefType(sch.$ref)\n } else if (sch?.type === 'array' && sch.items?.$ref) {\n responseClass = ParserUtils.parseRefType(sch.items.$ref)\n responseClass = `${responseClass}Array` // Adds support for z.array() types\n } else if (schV3?.$ref) {\n responseClass = ParserUtils.parseRefType(schV3.$ref)\n } else {\n // TODO add support for non $ref types. E.g. { type: 'array', items: { type: 'string', enum: [ 'WALLET', 'XSOLLA', .. ] } }\n }\n }\n })\n\n return responseClass\n }\n\n static isFormUrlEncoded(httpMethod: string, contentTypes: string[]): boolean {\n if (!contentTypes || contentTypes.length < 1) {\n return false\n }\n if (!['post', 'put', 'patch'].includes(httpMethod)) {\n return false\n }\n return contentTypes.includes('application/x-www-form-urlencoded')\n }\n\n static filterPathParams(parameters?: EndpointParameters[]): EndpointParameters[] {\n if (!parameters) {\n return []\n }\n return parameters.filter(parameter => parameter.in === 'path')\n }\n\n /**\n * This method converts this\n * POST `/gdpr/public/namespaces/{namespace}/users/{userId}/requests/{requestDate}/generate`\n *\n * to this\n * `createGenerateByRequestIdByUserId`\n */\n static generateNaturalLangMethod = ({ servicePrefix, path, httpMethod, isForm, existingMethods }) => {\n let path_ = path\n path_ = path_.replace(`/${servicePrefix}/`, '/')\n REMOVED_KEYWORDS.forEach(prefix => {\n path_ = path_.replace(prefix, '/')\n })\n path_ = path_.substring(1) // remove first '/'\n\n // Example GET /xxx/yyy/{id}/items is \"fetchItems\" PLURAL\n // Example GET /xxx/yyy/{id}/items/{itemId} is \"fetchItem\" SINGULAR\n const isPlural = httpMethod === 'get' && !(path.slice(-1) === '}') // last char is '}'\n if (!isPlural) {\n path_ = ParserUtils.replaceAll(path_, 'ies/', 'y/') // parties, countries, policies\n path_ = ParserUtils.replaceAll(path_, 's/', '/')\n if (path_.indexOf('status') < 0) {\n path_ = path_.replace(/ies$/, 'y')\n path_ = path_.replace(/s$/, '')\n } // remove all tail end \"s\" -> /profiles, /users except /status\n } // make it non plural\n\n const arrLastWords = path_.split('}/')\n let lastWords = arrLastWords[arrLastWords.length - 1]\n\n const extractLastWord = lastWords_ => {\n let res = lastWords_\n res = res.split('/{')[0]\n return res\n }\n // convert \"/dlcs/latest/byGameAppId/{appId\" to \"/dlcs/latest/byGameAppId\" by dropping \"{appId\"\n lastWords = extractLastWord(lastWords)\n if (lastWords.indexOf('{') >= 0 && arrLastWords.length > 1) {\n lastWords = arrLastWords[arrLastWords.length - 2]\n lastWords = extractLastWord(lastWords)\n }\n\n const listBeforeLastWords = []\n let foundParam = false\n const listByParams = []\n\n // reverse iterate retrieving last words of the endpoint\n const pathElements = path_.split('/')\n pathElements\n .slice()\n .reverse()\n .forEach(item => {\n if (item.indexOf('}') >= 0) {\n foundParam = true\n let param = item.replace('{', '')\n param = param.replace('}', '')\n param = 'Byword' + _.upperFirst(param) + ''\n listByParams.push(param)\n } else if (!foundParam) {\n if (lastWords.indexOf(item) === -1) {\n listBeforeLastWords.push(item)\n }\n } else {\n foundParam = false\n }\n })\n\n const genPath = _.upperFirst(lastWords) + '/' + listBeforeLastWords.join('/') + listByParams.reverse().join('/')\n let generatedMethod = _.camelCase(mappedMethod(httpMethod, isForm) + genPath)\n generatedMethod = ParserUtils.replaceAll(generatedMethod, 'Byword', '_By') // lodash remvoes the '_'\n generatedMethod = resolveConflicts(path, generatedMethod, existingMethods)\n return generatedMethod\n }\n\n static filterBodyParams(parameters?: EndpointParameters[]) {\n if (Array.isArray(parameters) && parameters.length > 0) {\n return parameters.filter(parameter => parameter.in === 'body' || parameter.in === 'formData')\n }\n return []\n }\n\n static filterQueryParameters(parameters?: EndpointParameters[]): EndpointParameters[] {\n if (!parameters) {\n return []\n }\n return parameters.filter(parameter => parameter.in === 'query')\n }\n\n static mkdirIfNotExist(dirToCreate: string) {\n if (!fs.existsSync(dirToCreate)) {\n fs.mkdirSync(dirToCreate, { recursive: true })\n }\n }\n\n static writeClassFile(distDir: string, apiName: string, apiBuffer: string, imports?: string[]) {\n const fileContent = templateClass(apiName, apiBuffer, imports)\n fs.writeFileSync(`${distDir}/${apiName}.ts`, ParserUtils.prependCopyrightHeader(fileContent))\n }\n\n static writeXVersion(distDir: string, xversionJson: string, apiInfo) {\n if (xversionJson) {\n console.log('x-version:', xversionJson)\n fs.writeFileSync(`${distDir}/version.json`, JSON.stringify(xversionJson, null, 2))\n } else {\n const customVersion = {\n ...apiInfo,\n gitHash: apiInfo.version\n }\n console.error('!!!! Missing x-version for ', distDir, customVersion)\n fs.writeFileSync(`${distDir}/version.json`, JSON.stringify(customVersion, null, 2))\n }\n }\n\n static writeApiFile(distDir: string, apiName: string, apiBuffer: string, imports: string[], returnMethods: string) {\n const newImports = []\n imports.forEach((el, index) => {\n newImports.push(el.replace('../../generated-definitions', '../generated-definitions'))\n })\n const fileContent = templateApiClass(apiName, apiBuffer, newImports, returnMethods)\n fs.writeFileSync(`${distDir}/${apiName}.ts`, ParserUtils.prependCopyrightHeader(fileContent))\n }\n\n static writeApiMainFile(distDir: string, serviceName: string, fileContent: string) {\n fs.writeFileSync(`${distDir}/${serviceName}.ts`, ParserUtils.prependCopyrightHeader(fileContent))\n }\n\n static writeSnippetFile(distDir: string, name: string, docBuffer: string) {\n let snippetFileName = ParserUtils.replaceAll(name, ' ', '-').toLowerCase()\n snippetFileName = snippetFileName.replace('justice-', '')\n snippetFileName = 'snippet-' + snippetFileName + '.json'\n fs.writeFileSync(`${distDir}/${snippetFileName}`, docBuffer)\n }\n\n static writeDefinitionFile(distDir: string, name: string, buffer: string) {\n ParserUtils.mkdirIfNotExist(distDir)\n fs.writeFileSync(path.join(distDir, `${name}.ts`), ParserUtils.prependCopyrightHeader(buffer))\n }\n\n static writeAllImportsFile(distDir: string, buffer: string) {\n ParserUtils.mkdirIfNotExist(distDir)\n fs.writeFileSync(path.join(distDir, 'all-imports.ts'), ParserUtils.prependCopyrightHeader(buffer))\n }\n\n static syncPackageVersion(apiInfo: any, skipVersionSync: boolean, prereleaseId: string) {\n if (skipVersionSync) return\n\n const currDir = process.cwd()\n const { packageJSON, pathToPackageJSON } = ParserUtils.getPackageJSONInfo(currDir)\n\n // Construct based on the Swagger minor version first.\n // Keep the major and patch untouched, which we will bump only by using `.inc()` for consistency purposes.\n const nextSemver = VersionHelpers.getNextVersion({\n serviceVersion: apiInfo['x-version'] || apiInfo.version || UNDEFINED_SWAGGER_SEMVER,\n versionBumpType: process.env.VERSION_BUMP_TYPE,\n sdkVersion: packageJSON.version,\n nextPrereleaseId: prereleaseId\n })\n\n packageJSON.version = nextSemver\n writeFileSync(pathToPackageJSON, JSON.stringify(packageJSON, null, 2))\n }\n\n static getPackageJSONInfo(dir) {\n const pathToPackageJSON = path.join(dir, './package.json')\n return { packageJSON: JSON.parse(readFileSync(pathToPackageJSON, 'utf-8')), pathToPackageJSON }\n }\n\n static toCamelCase(str: string) {\n return str\n .split('/')\n .map(function (word, index) {\n // If it is the first word make sure to lowercase all the chars.\n if (index === 0) {\n return word.toLowerCase()\n }\n // If it is not the first word only upper case the first char\n return ParserUtils.toCamelCaseWord(word)\n })\n .join('')\n }\n\n static toCamelCaseWord(word: string) {\n if (!word) {\n return ''\n }\n // convert hyphen separated case to camel case\n word = word.replace(/(-\\w)/g, m => m[1].toUpperCase())\n // capitalize first letter\n return word.charAt(0).toUpperCase() + word.slice(1)\n }\n\n static toTitleCaseWord(word: string) {\n if (!word) {\n return ''\n }\n return word.replace(/\\w\\S*/g, txt => {\n return txt.charAt(0).toUpperCase() + txt.substring(1).toLowerCase()\n })\n }\n\n static applyPatchIfExists(\n swaggerFilePath: string,\n possibleSwaggerPatchFilePath: string,\n swaggerPatchedFilePath: string,\n swaggerPatchedDir: string\n ) {\n if (!fs.existsSync(swaggerPatchedDir)) {\n fs.mkdirSync(swaggerPatchedDir, { recursive: true })\n }\n\n if (!fs.existsSync(possibleSwaggerPatchFilePath)) {\n fs.copyFileSync(swaggerFilePath, swaggerPatchedFilePath)\n return\n }\n const swaggerContent = JSON.parse(fs.readFileSync(swaggerFilePath, 'utf8'))\n const swaggerPatchFileContent: Operation[] = JSON.parse(fs.readFileSync(possibleSwaggerPatchFilePath, 'utf8'))\n\n // Check out the existence of the paths listed in the Swagger JSON patch.\n for (const patchEntry of swaggerPatchFileContent) {\n // Trim out empty string array elements.\n const segments = patchEntry.path.split('/').filter(Boolean)\n let currentNode = swaggerContent\n // This `aggregatedPath` is to pinpoint the erroring path, so that we can display the exact path where it errors\n // and not the entire `patchEntry.path`.\n let aggregatedPath = ''\n\n for (let i = 0; i < segments.length; i++) {\n const segment = segments[i]\n aggregatedPath += `/${segment}`\n\n // Replace the JSON pointers.\n // More on this: https://jsonpatch.com/#json-pointer.\n const effectiveSegment = segment.replace(/(~1)/g, '/').replace(/(~0)/g, '~')\n\n if (!currentNode[effectiveSegment]) {\n if (i + 1 === segments.length && patchEntry.op === 'add') {\n // Only allow missing node when we're adding a node and we're at the end of the segment array.\n // No-op.\n } else {\n // If it's not leaf node yet, then throw error.\n // If it's leaf node and the mode isn't \"add\", then throw error.\n throw new Error(\n [\n `JSON patch error: operation \"${patchEntry.op}\" on path \"${aggregatedPath}\" fails because the path doesn't exist in ${swaggerFilePath}. This may be caused by:\\n`,\n '1. The related service has patched the service, so patch is no longer needed.',\n '2. There is a breaking change on the service that causes the path to change.\\n',\n `In any case, revisit this file: \"${possibleSwaggerPatchFilePath}\", then try again.\\n`\n ].join('\\n')\n )\n }\n }\n\n currentNode = currentNode[effectiveSegment]\n }\n }\n\n const { newDocument } = applyPatch(swaggerContent, swaggerPatchFileContent)\n fs.writeFileSync(swaggerPatchedFilePath, JSON.stringify(newDocument, null, 2))\n }\n\n static getRelativePathToWebSdkSrcFolder(srcFolder: string, targetSrcFolder: string) {\n // For example:\n // Input: ../../accelbyte-web-sdk/packages/sdk/src/generated/...\n // Output: ./generated/...\n // Need to replace for Windows as `/` becomes `\\`.\n const replaced = srcFolder.replace(/\\\\/g, '/')\n return replaced.replace(/\\\\/g, '/').replace(targetSrcFolder, './')\n }\n\n static prependCopyrightHeader = (content: string): string => {\n const currentYear = new Date().getFullYear()\n return `/* \n * Copyright (c) 2022${currentYear > 2022 ? `-${currentYear}` : ''} AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\n${content}`\n }\n\n static sortPathParamsByPath = (pathParams: EndpointParameters[], path: string) => {\n const params = path.match(/{\\w*}/g) || []\n const cleanParams = params.map(param => param.replace('{', '').replace('}', ''))\n return pathParams.sort((a, b) => cleanParams.indexOf(a.name) - cleanParams.indexOf(b.name))\n }\n}\n\nconst mappedMethod = (httpMethod: string, isForm: boolean) => {\n if (httpMethod === 'get') {\n // return 'fetch'\n return 'get'\n } else if (httpMethod === 'post' && isForm) {\n return 'post'\n } else if (httpMethod === 'post') {\n return 'create'\n } else if (httpMethod === 'put') {\n return 'update'\n } else if (httpMethod === 'patch') {\n return 'patch'\n } else if (httpMethod === 'delete') {\n return 'delete'\n }\n}\n\nconst resolveConflicts = (path, generatedMethod, existingMethods) => {\n // generatedMethod = generatedMethod.replace('Namespaces', '')\n try {\n testConflict(path, generatedMethod, existingMethods)\n } catch (e) {\n if (path.indexOf('/namespaces/') >= 0) {\n generatedMethod += '_ByNS'\n }\n }\n\n try {\n testConflict(path, generatedMethod, existingMethods)\n } catch (e) {\n if (path.indexOf('/v4/') >= 0) {\n generatedMethod += '_v4'\n }\n }\n\n try {\n testConflict(path, generatedMethod, existingMethods)\n } catch (e) {\n if (path.indexOf('/v3/') >= 0) {\n generatedMethod += '_v3'\n }\n }\n\n try {\n testConflict(path, generatedMethod, existingMethods)\n } catch (e) {\n if (path.indexOf('/v2/') >= 0) {\n generatedMethod += '_v2'\n }\n }\n\n try {\n testConflict(path, generatedMethod, existingMethods)\n } catch (e) {\n if (path.indexOf('/admin/') >= 0) {\n generatedMethod += '_admin'\n }\n }\n\n // Still failed? dump it and fail the code gen build\n testConflict(path, generatedMethod, existingMethods)\n\n return generatedMethod\n}\n\nconst testConflict = (path, generatedMethod, existingMethods) => {\n if (existingMethods[generatedMethod]) {\n const conflictingMethod = { path, generatedMethod }\n throw Error(\n `Duplicate method conflict in ${JSON.stringify(conflictingMethod)},\\n existingMethods: ${JSON.stringify(existingMethods, null, 2)}`\n )\n }\n}\n\nconst isSwaggerIntegerType = (type: string) => {\n return type === 'integer' || type === 'int'\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport { ParserUtils } from '../ParserUtils'\nimport { Definition } from './../Swagger'\n\n// The expected output that we return from most of the functions below.\n// Normally, we will mostly use `schemaString`. In some unique cases\n// where there are recursive types, we cannot infer type. Hence, we need\n// to store the TypeScript syntax so we can write them manually.\ninterface ResultType {\n schemaString: string\n typeString: string\n}\n\nexport class TemplateZod {\n duplicates: Map<string, string>\n duplicateFound = false\n //\n private importClasses = new Set()\n\n // --\n render = (fileName: string, definition: Definition, duplicates: Map<string, string>) => {\n this.duplicates = duplicates\n const content = this.parseToZodSchema(definition, definition.required || [])\n\n // Prevent self-importing and handle recursive types.\n const containsRecursiveType = this.importClasses.has(fileName)\n if (containsRecursiveType) {\n this.importClasses.delete(fileName)\n }\n\n let imports = ''\n for (const cl of Array.from(this.importClasses).sort()) {\n imports += `import { ${cl} } from './${cl}.js'\\n`\n }\n\n // Modify export variable string, based on existence of recursive types.\n // Reference: https://github.com/colinhacks/zod#recursive-types.\n let exportedVariableString: string\n let exportedTypeString: string\n\n if (containsRecursiveType) {\n // If it contains recursive type, then we need to modify the exported variable in a way,\n // so that there are no TypeScript errors.\n exportedVariableString = `\nexport const ${fileName}: z.ZodType<${fileName}> = z.lazy(() =>\n ${content.schemaString}\n )\n `\n exportedTypeString = `\nexport interface ${fileName} {\n ${content.typeString}\n}\n`\n } else {\n // Export normally by writing the `z.ZodObject` and type inferring with `z.TypeOf`.\n exportedVariableString = `export const ${fileName} = ${content.schemaString}`\n exportedTypeString = `export interface ${fileName} extends z.TypeOf<typeof ${fileName}> {}`\n }\n\n const template = `import { z } from 'zod'\n${imports}\n\n${exportedVariableString}\n\n${exportedTypeString}\n `\n return { buffer: template, duplicateFound: this.duplicateFound }\n }\n\n // --\n parseToZodSchema = (definition, requiredAttrs): ResultType => {\n if (definition.additionalProperties) {\n return this.parseToZodAttribute('', definition, [])\n }\n\n let properties: [string, any]\n if (definition.properties) {\n properties = Object.entries(definition.properties) as [string, any]\n } else if (definition.items?.properties) {\n properties = Object.entries(definition.items.properties) as [string, any]\n } else {\n return {\n schemaString: 'z.any()',\n typeString: 'any'\n }\n }\n\n const schemaFields: string[] = []\n const typeFields: string[] = []\n\n for (const property of properties) {\n const [name, definition] = property\n const result = this.parseToZodAttribute(name, definition, requiredAttrs)\n\n schemaFields.push(result.schemaString)\n typeFields.push(result.typeString)\n }\n\n if (definition?.type === 'array') {\n return {\n schemaString: `z.array(z.object({${schemaFields.join(',')}}))`,\n typeString: typeFields.join(';')\n }\n }\n\n return {\n schemaString: `z.object({${schemaFields.join(',')}})`,\n typeString: typeFields.join(';')\n }\n }\n\n // --\n parseToZodAttribute = (name, definition, requiredAttrs): ResultType => {\n // Required field syntax.\n // Empty name check is required for fields with type records.\n const isRequired = requiredAttrs.includes(name) || name === ''\n const schemaRequired = isRequired ? '' : '.nullish()'\n const typeRequired = isRequired ? '' : '?'\n const typeNullishability = isRequired ? '' : ' | null | undefined'\n // Field name syntax.\n const schemaAttribute = name ? `'${name}':` : ''\n const typeAttribute = name ? `'${name}'${typeRequired}:` : ''\n\n const type = definition?.type\n\n if (definition.properties) {\n const result = this.parseToZodSchema(definition, requiredAttrs)\n return {\n schemaString: `${schemaAttribute} ${result.schemaString}${schemaRequired}`,\n typeString: `${typeAttribute} ${result.typeString}${typeNullishability}`\n }\n } else if (type) {\n if (type === 'object' && definition.additionalProperties) {\n const zodAttribute = this.parseToZodAttribute('', definition.additionalProperties, [''])\n return {\n schemaString: `${schemaAttribute} z.record(${zodAttribute.schemaString})${schemaRequired}`,\n typeString: `${typeAttribute} Record<string, ${zodAttribute.typeString}>${typeNullishability}`\n }\n }\n\n if (type === 'object' && !definition.additionalProperties && !name) {\n return {\n schemaString: `z.any()`,\n typeString: 'any'\n }\n }\n\n if (type === 'object' && !definition.additionalProperties) {\n return {\n schemaString: `${schemaAttribute} z.record(z.any())${schemaRequired}`,\n typeString: `${typeAttribute} Record<string, any>${typeNullishability}`\n }\n }\n\n if (type === 'integer' || type === 'number') {\n const effectiveType = getZodNumberType(type)\n return {\n schemaString: `${schemaAttribute} z.${effectiveType.schemaString}()${schemaRequired}`,\n typeString: `${typeAttribute} ${effectiveType.typeString}${typeNullishability}`\n }\n }\n\n if (type === 'array') {\n const items = definition.items\n const ref = items?.$ref\n let model: ResultType\n if (ref) {\n const refType = ParserUtils.parseRefType(ref)\n this.importClasses.add(refType)\n\n model = {\n schemaString: refType,\n typeString: refType\n }\n } else if (items) {\n if (items.type === 'array') {\n const ref = items.items?.$ref\n if (ref) {\n const refType = ParserUtils.parseRefType(ref)\n this.importClasses.add(refType)\n\n model = {\n schemaString: refType,\n typeString: refType\n }\n } else if (items.items) {\n model = this.parseEnumItems(items.items)\n }\n return {\n schemaString: `${schemaAttribute} z.array(z.array(${model.schemaString}))${schemaRequired}`,\n typeString: `${typeAttribute} ${model.typeString}[]${typeNullishability}`\n }\n } else {\n model = this.parseEnumItems(items)\n }\n } else {\n return {\n schemaString: `${schemaAttribute} z.array(z.any())${schemaRequired}`,\n typeString: `${typeAttribute} any[]${typeNullishability}`\n }\n }\n return {\n schemaString: `${schemaAttribute} z.array(${model.schemaString})${schemaRequired}`,\n typeString: `${typeAttribute} ${model.typeString}[]${typeNullishability}`\n }\n }\n\n if (type !== 'object') {\n const result = extractEnumObject(type, isRequired, definition.enum)\n return {\n schemaString: `${schemaAttribute} ${result.schemaString}`,\n typeString: `${typeAttribute} ${result.typeString}`\n }\n }\n }\n\n const ref = definition.$ref\n let model = `z.record(z.any())`\n\n if (ref) {\n model = ParserUtils.parseRefType(ref)\n\n const fullModelName = ref.replace('#/definitions/', '')\n this.duplicateFound = this.duplicates.has(fullModelName)\n if (this.duplicateFound) {\n model = this.duplicates.get(fullModelName)\n }\n this.importClasses.add(model)\n model = `${model}`\n }\n\n return {\n schemaString: `${schemaAttribute} ${model}${schemaRequired}`,\n typeString: `${typeAttribute} ${model}${typeNullishability}`\n }\n }\n\n parseEnumItems = (items): ResultType => {\n if (items.enum) {\n const enumStr = items.enum.map(e => {\n return `\"${e}\"`\n })\n return {\n schemaString: `z.enum([${enumStr}])`,\n typeString: `(${enumStr.join(' | ')})`\n }\n }\n\n if (items.type === 'object') {\n return this.parseToZodSchema(items, items.required)\n }\n\n let effectiveType: ResultType\n if (items.type === 'integer' || items.type === 'number') {\n effectiveType = getZodNumberType(items.type)\n } else {\n effectiveType = { typeString: items.type, schemaString: items.type }\n }\n\n return {\n schemaString: `z.${effectiveType.schemaString}()`,\n typeString: effectiveType.typeString\n }\n }\n}\n\nexport class TemplateZodArray {\n //\n render = name => {\n const cls = name.replace('Array', '')\n const template = `import { z } from 'zod'\nimport { ${cls} } from './${cls}.js'\n \nexport const ${name} = z.array(${cls})\n\nexport interface ${name} extends z.TypeOf<typeof ${name}> {}\n `\n return template\n }\n}\n\nconst getZodNumberType = (type: string) => {\n // In Swagger, integer and number are different types.\n // As such, we need to map them separately.\n // Example how to use:\n //\n // if (type === 'integer' || type === 'number') return getZodNumberType(type);\n //\n // Reference 1: https://swagger.io/docs/specification/data-models/data-types/.\n // Reference 2: https://github.com/colinhacks/zod#numbers.\n if (type === 'integer') {\n return {\n schemaString: 'number().int',\n typeString: 'number'\n }\n }\n\n return {\n schemaString: type,\n typeString: type\n }\n}\n\nconst extractEnumObject = (type: string, isRequired: boolean, enumArr?: string[]): ResultType => {\n const schemaRequired = isRequired ? '' : '.nullish()'\n const typeNullishability = isRequired ? '' : ' | null | undefined'\n if (enumArr) {\n const enumStr = enumArr.map(e => {\n return `\"${e}\"`\n })\n return {\n schemaString: `z.enum([${enumStr}])${schemaRequired}`,\n typeString: `(${enumStr.join(' | ')}${typeNullishability})`\n }\n }\n return {\n schemaString: `z.${type}()${schemaRequired}`,\n typeString: `${type}${typeNullishability}`\n }\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\n\nimport { ParserUtils } from '../ParserUtils'\n\nexport const templateApiIndex = (serviceName: string, serviceNameTitle: string, apiList: string[]): string => {\n let imports = ''\n let returnStatement = ''\n for (const cl of apiList) {\n // We have to exclude AdminApi as it was the title of the section\n // in swagger, but it has public/admin version of the endpoint too\n const dir = cl.toLowerCase().includes('admin') && cl !== 'AdminApi' ? 'generated-admin' : 'generated-public'\n imports += `\\nimport { ${cl} } from './${dir}/${cl}.js'`\n returnStatement += `\\n${cl}, `\n }\n\n return `/**\n * AUTO GENERATED\n */\n${imports}\n\nconst apis = {\n${returnStatement}\n}\n\nexport const ${ParserUtils.convertDashesToTitleCase(serviceNameTitle)} = apis\n `\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport { z } from 'zod'\n\nconst Schema = z.object({\n $ref: z.string().nullish(),\n type: z\n .union([z.literal('array'), z.literal('object'), z.literal('file'), z.literal('string'), z.literal('boolean'), z.literal('integer')])\n .nullish(),\n items: z\n .object({\n $ref: z.string().nullish(),\n type: z.string().nullish()\n })\n .nullish(),\n properties: z.union([z.array(z.string()).nullish(), z.record(z.object({ type: z.string() })).nullish()]),\n description: z.string().nullish(),\n additionalProperties: z\n .object({\n type: z.string().nullish()\n })\n .nullish()\n})\n\nexport type Schema = z.TypeOf<typeof Schema>\n\nexport const Definition = z.object({\n required: z.array(z.string()).nullish(),\n properties: z\n .record(\n z.object({\n type: z.string()\n })\n )\n .nullish()\n})\n\nexport type Definition = z.TypeOf<typeof Definition>\n\nexport const Definitions = z.record(Definition)\n\nexport type Definitions = z.TypeOf<typeof Definitions>\n\nconst EndpointParametersType = z.enum(['apiKey', 'boolean', 'int', 'integer', 'number', 'string', 'array', 'file'])\nconst EndpointParametersIn = z.enum(['body', 'formData', 'header', 'path', 'query'])\n\nconst EndpointParameters = z.object({\n type: EndpointParametersType.nullish(),\n description: z.string().nullish(),\n name: z.string(),\n in: EndpointParametersIn,\n required: z.boolean().nullish(),\n schema: Schema.nullish(),\n default: z.union([z.boolean(), z.string(), z.number(), z.array(z.any())]).nullish(),\n enum: z.array(z.union([z.boolean(), z.string(), z.number()])).nullish(),\n items: z\n .object({\n type: z.string(),\n enum: z.array(z.any()).nullish()\n })\n .nullish()\n})\n\nexport type EndpointParameters = z.TypeOf<typeof EndpointParameters>\n\nexport const Endpoint = z.object({\n description: z.string().nullish(),\n consumes: z.array(z.string()).nullish(),\n produces: z.array(z.string()).nullish(),\n tags: z.array(z.string()).nullish(),\n summary: z.string().nullish(),\n operationId: z.string(),\n deprecated: z.boolean().nullish(),\n responses: z.record(\n z.object({\n description: z.string().nullish(),\n schema: Schema.nullish(),\n content: z\n .object({\n 'application/json': z.object({\n schema: Schema.nullish()\n })\n })\n .nullish()\n })\n ),\n parameters: z.array(EndpointParameters).nullish(),\n requestBody: z\n .object({\n required: z.boolean(),\n content: z\n .object({\n 'application/json': z.object({\n schema: Schema.nullish()\n })\n })\n .nullish()\n })\n .nullish(),\n // The proper type is z.array(z.record(z.array(z.string()))).nullish() but somehow there are endpoints with\n // an object type instead of an array type, so, yeah.\n //\n // Services with this error: sdk-iam, sdk-ugc.\n 'x-security': z.any().nullish()\n})\nexport type Endpoint = z.TypeOf<typeof Endpoint>\n\nconst Operation = z.object({\n get: Endpoint.nullish(),\n post: Endpoint.nullish(),\n patch: Endpoint.nullish(),\n delete: Endpoint.nullish(),\n put: Endpoint.nullish()\n})\nexport type Operation = z.TypeOf<typeof Operation>\nexport type HttpMethod = keyof Operation\n\nexport const Paths = z.record(Operation)\n\nexport const OpenApiSpec = z.object({\n paths: Paths,\n definitions: Definitions,\n basePath: z.string(),\n info: z.object({\n description: z.string(),\n title: z.string(),\n contact: z.object({\n name: z.string(),\n url: z.string(),\n email: z.string()\n }),\n version: z.string()\n }),\n schemes: z.array(z.string()).nullish(),\n components: z\n .object({\n schemas: Definitions\n })\n .nullish()\n})\n\nexport type OpenApiSpec = z.TypeOf<typeof OpenApiSpec>\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport { ParserUtils } from '../ParserUtils'\nimport { EndpointParameters } from './../Swagger'\n\nexport const templateMethod = ({\n classMethod,\n description,\n httpMethod,\n path,\n pathParams,\n bodyParams,\n queryParams,\n isFormUrlEncoded,\n responseClass,\n deprecated\n}: {\n classMethod: string\n description: string\n httpMethod: string\n path: string\n pathParams: EndpointParameters[]\n bodyParams: EndpointParameters[]\n queryParams: EndpointParameters[]\n isFormUrlEncoded: boolean\n responseClass: string\n deprecated: boolean\n}) => {\n let methodParams = ''\n let methodParamsNoTypes = ''\n let newPath = `'${path}'`\n let importStatements: string[] = []\n\n const sortedPathParams = ParserUtils.sortPathParamsByPath(pathParams, path)\n for (const pathParam of sortedPathParams) {\n const type = ParserUtils.parseType(pathParam)\n if (pathParam.name !== 'namespace') {\n methodParams += pathParam.name + `:${type}` + ', '\n methodParamsNoTypes += pathParam.name + ', '\n }\n const pName = pathParam.name === 'namespace' ? 'this.namespace' : pathParam.name\n if (path.match(`{${pathParam.name}}`)) {\n if (type === 'string') {\n newPath = `${newPath}.replace('{${pathParam.name}}', ${pName})`\n } else {\n newPath = `${newPath}.replace('{${pathParam.name}}', String(${pName}))`\n }\n }\n }\n\n let dataType = null\n if (httpMethod !== 'get') {\n dataType = ParserUtils.parseBodyParamsType(bodyParams)\n importStatements = ParserUtils.parseBodyParamsImports(bodyParams)\n methodParams += dataType ? `data: ${dataType},` : ''\n methodParamsNoTypes += dataType ? `data,` : ''\n }\n\n const isAnyRequired = ParserUtils.isAnyQueryParamRequired(queryParams)\n const queryParamsType = queryParams.length\n ? `queryParams${isAnyRequired ? '' : '?'}: {${ParserUtils.parseQueryParamsType(queryParams)}}`\n : ''\n\n const queryParamsDefault = queryParams.length\n ? `const params = {${ParserUtils.parseQueryParamsDefault(queryParams)} ...queryParams} as SDKRequestConfig`\n : 'const params = {} as SDKRequestConfig'\n\n const isPostPutPatch = ['post', 'put', 'patch'].includes(httpMethod)\n const isDelete = ['delete'].includes(httpMethod)\n let dataPayload = '{params}'\n\n const descriptionText = description\n ? `\n /**${deprecated ? '\\n * @deprecated' : ''}\n * ${description.replace(/\\n/g, '\\n * ')} \n */`\n : ''\n\n let formPayloadString = ''\n if (isFormUrlEncoded) {\n formPayloadString = ``\n const params = \"{ ...params, headers: { ...params.headers, 'content-type': 'application/x-www-form-urlencoded' } }\"\n\n dataPayload = dataType ? `CodeGenUtil.getFormUrlEncodedData(data), ${params}` : `null, ${params}`\n } else if (isPostPutPatch) {\n dataPayload = dataType ? `data, {params}` : 'null, {params}'\n } else if (isDelete) {\n dataPayload = dataType ? `{data, params}` : '{params}'\n }\n const isFileUpload = methodParams.indexOf('data: {file') > -1\n\n const resolvedResponseClass = responseClass || 'unknown'\n const resolvedResponseClassValidated = responseClass || 'z.unknown()'\n methodParams = (queryParamsType ? `${methodParams} ${queryParamsType}` : methodParams).replace(/,\\s*$/, '')\n methodParamsNoTypes = queryParamsType ? `${methodParamsNoTypes} queryParams` : methodParamsNoTypes\n\n let methodImpl = ''\n const isCacheFetch = ['get'].includes(httpMethod) && resolvedResponseClass !== 'unknown'\n const deprecateTag = isCacheFetch\n ? `/**\n * @deprecated Use \"${classMethod}()\" instead.\n */`\n : ''\n\n const isGuardInvoked = ['get', 'post', 'put', 'patch', 'delete'].includes(httpMethod)\n const responseType = resolvedResponseClass !== 'unknown' ? `${resolvedResponseClass}` : 'unknown'\n\n const generateMethodName = () => `${classMethod}(${methodParams}): Promise<${responseSyncType}<${responseType}>>`\n\n const responseSyncType = 'IResponse'\n methodImpl = `${descriptionText}\n ${generateMethodName()} {\n ${queryParamsDefault}\n const url = ${newPath} ${formPayloadString} ${isFileUpload ? '\\n// TODO file upload not implemented' : ''}\n const resultPromise = this.axiosInstance.${httpMethod}(url, ${dataPayload})\n\n${` return Validate.validateOrReturnResponse(this.isZodEnabled, () => resultPromise, ${resolvedResponseClassValidated}, '${resolvedResponseClassValidated}')`}\n }\n `\n\n if (!isGuardInvoked) {\n methodImpl = `${descriptionText}\n ${deprecateTag}\n TODO_${classMethod}(${methodParams}): Promise<AxiosResponse<${resolvedResponseClass}>> {\n ${queryParamsDefault}\n const url = ${newPath} ${formPayloadString} ${isFileUpload ? '\\n// TODO file upload not implemented' : ''}\n return this.axiosInstance.${httpMethod}(url, ${dataPayload})\n }\n `\n }\n\n const res = {\n methodImpl,\n methodParams,\n methodParamsNoTypes,\n importStatements\n }\n return res\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport { ParserUtils } from '../ParserUtils'\nimport { EndpointParameters } from './../Swagger'\n\nexport const templateApiMethod = ({\n classMethod,\n description,\n httpMethod,\n path,\n pathParams,\n bodyParams,\n responseClass,\n classGenName,\n methodParams,\n methodParamsNoTypes,\n deprecated,\n xSecurity\n}: {\n classMethod: string\n description: string\n httpMethod: string\n path: string\n pathParams: EndpointParameters[]\n bodyParams: EndpointParameters[]\n responseClass: string\n classGenName: string\n methodParams: string\n methodParamsNoTypes: string\n deprecated: boolean\n // Reference: https://accelbyte.atlassian.net/wiki/spaces/CW/pages/2991423677/Draft+Swagger+validation+for+API+explorer+content+proposal.\n // Endpoint with `x-security` means it requires authentication.\n xSecurity: Array<Record<string, string[]>> | undefined\n}) => {\n let newPath = `'${path}'`\n let snippetMethod = ''\n\n for (const pathParam of pathParams) {\n const type = ParserUtils.parseType(pathParam)\n const pName = pathParam.name === 'namespace' ? 'this.namespace' : pathParam.name\n if (path.match(`{${pathParam.name}}`)) {\n if (type === 'string') {\n newPath = `${newPath}.replace('{${pathParam.name}}', ${pName})`\n } else {\n newPath = `${newPath}.replace('{${pathParam.name}}', String(${pName}))`\n }\n }\n }\n\n const snippetShellArgs: string[] = ['--location --request', `${httpMethod} '__DOMAIN__${path}'`, \"--header 'accept: application/json'\"]\n const snippetApiArgs: string[] = []\n\n // Admin paths _usually_ always require authentication.\n // If it's public, then it can't be helped, we need to rely on `x-security` that's provided from the domain service teams.\n if (xSecurity !== undefined || path.includes('/admin')) {\n snippetShellArgs.push(\"--header 'Authorization: Bearer {access_token}'\")\n snippetApiArgs.push(\"{ config: { headers: { Authorization: 'Bearer {access_token}' } }}\".trim())\n }\n\n if (httpMethod !== 'get') {\n const curlParams = bodyParams?.map(ob => {\n return ` \"${ob.name}\": \"\"`\n })\n\n // Prevent sending `--data-raw` in case of `DELETE` method without body.\n if (curlParams.length > 0) {\n snippetShellArgs.push(`--data-raw '{ ${curlParams}}'`)\n }\n }\n\n const snippetShell = `curl ${snippetShellArgs.join(' \\\\\\n ')}`\n\n const descriptionText = description\n ? `\n /**${deprecated ? '\\n * @deprecated' : ''}\n * ${description.replace(/\\n/g, '\\n * ')} \n */`\n : ''\n\n const resolvedResponseClass = responseClass || 'unknown'\n const responseType = resolvedResponseClass !== 'unknown' ? `${resolvedResponseClass}` : 'unknown'\n\n const methodImpl = `\n ${descriptionText}\n async function ${classMethod}(${methodParams}): Promise<${responseType}> {\n const $ = new ${classGenName}(Network.create(requestConfig), namespace, isZodEnabled)\n const resp = await $.${classMethod}(${methodParamsNoTypes})\n if (resp.error) throw resp.error\n return resp.response.data\n }\n `\n const snippetPromiseString = responseType !== 'unknown' ? `Promise<${responseType}>` : 'Promise'\n snippetMethod += `${classMethod}(${methodParams}) \\n // return ${snippetPromiseString}`\n\n return {\n generatedMethodString: methodImpl,\n snippetApiArgs,\n snippetMethod,\n snippetShell\n }\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport { ParserUtils } from '../ParserUtils'\n\nexport const templateSdkSnippet = ({\n serviceNameTitle,\n apiName,\n snippetMethod,\n snippetApiArgs: snippetApiArgsParam\n}: {\n serviceNameTitle: string\n apiName: string\n snippetMethod: string\n snippetApiArgs: string[]\n}) => {\n const methodArr = snippetMethod.split('//')\n const snippetApiArgs = ['sdk', ...snippetApiArgsParam]\n\n let normMethod = normalizeMethodSnippet(methodArr[0].trim(), 'data:')\n normMethod = normalizeMethodSnippet(normMethod, 'queryParams:')\n normMethod = normalizeMethodSnippet(normMethod, 'queryParams?:')\n normMethod += '\\n\\n//' + methodArr[1]\n\n const sdkSnippet = `import { Accelbyte } from '@accelbyte/sdk'\nimport { ${serviceNameTitle} } from '@accelbyte/sdk-${serviceNameTitle.toLowerCase()}'\n\nconst sdk = Accelbyte.SDK({\n options: {\n baseURL: 'https://demo.accelbyte.io',\n clientId: '77f88506b6174c3ea4d925f5b4096ce8',\n namespace: 'accelbyte',\n redirectURI: 'http://localhost:3030'\n }\n})\n\n${serviceNameTitle}.${apiName}(${snippetApiArgs.join(', ')})\n .${normMethod}`\n return sdkSnippet\n}\n\nconst normalizeMethodSnippet = (methodInput: any, splitWord: string) => {\n const split1 = methodInput.split(splitWord)\n if (!split1[1]) {\n return methodInput\n }\n let split2 = split1[1].trim()\n split2 = ParserUtils.replaceAll(split2, '{', '')\n split2 = ParserUtils.replaceAll(split2, '})', '')\n split2 = split2.split(',')\n let params = ''\n split2.forEach(p => {\n params += '\\n ' + ParserUtils.replaceAll(p.trim(), ')', '') + ','\n })\n params = params.slice(0, -1) // remove last , char\n\n const result = split1[0] + splitWord + ' {' + params + '\\n })'\n return result\n}\n","/*\n * Copyright (c) 2023-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\n\nimport { ParserUtils } from '../ParserUtils'\nimport { Endpoint, OpenApiSpec } from '../Swagger'\nimport { templateMethod } from '../templates/template-method'\nimport { templateApiMethod } from '../templates/template-api-method'\nimport { templateSdkSnippet } from '../templates/template-sdk-snippet'\n\nconst GIT_URL = 'https://github.com/AccelByte/accelbyte-web-sdk/blob/main/packages'\n\nexport type Methods = 'get' | 'post' | 'put' | 'delete' | 'patch'\ntype SnippetMap = {\n [K in Methods]?: {\n web?: string\n webGit?: string\n shell?: string\n }\n}\n\ninterface Result {\n // 'Users V4': 'createUserInvite,createUser,patchUserMe,createTestUser,updateUserMeEmail,deleteUserMeMfaDevice,getUsersMeMfaFactor,postUserMeMfaFactor,getUsersMeMfaBackupCode,createUserMeMfaBackupCode,createUserMeMfaEmailCode,createUserMeHeadlesVerify,postUserMeMfaEmailEnable,createUserMeMfaEmailDisable,createUserInvite_ByInvitationId,createUserMeHeadlesCodeVerify,createUserMeMfaAuthenticatorKey,createUserMeMfaBackupCodeEnable,deleteUserMeMfaBackupCodeDisable,getUsersMeMfaBackupCodeDownload,postUserMeMfaAuthenticatorEnable,deleteUserMeMfaAuthenticatorDisable,'\n tagToSdkFunctionNamesRecord: Record<string, string>\n // 'Users V4': '\\n' +\n // ' \\n' +\n // ' /**\\n' +\n // ' * This endpoint is used to invite a game studio admin user with new namespace in multi tenant mode. It will return error if the service multi tenant mode is set to false. Request body details: - emailAddress: email address of the user to be invited - namespace: new namespace of the user to be created - namespaceDisplayName: display name of the new namespace The invited users will also be assigned with "User" role by default. \\n' +\n // ' */\\n' +\n // ' async function createUserInvite(data: PublicInviteUserRequestV4): Promise<InviteUserResponseV3> {\\n' +\n // ' const $ = new UsersV4$(Network.create(requestConfig), namespace, isZodEnabled)\\n' +\n // ' const resp = await $.createUserInvite(data,)\\n' +\n // ' if (resp.error) throw resp.error\\n' +\n // ' return resp.response.data\\n' +\n // ' }\\n' +\n // ' \\n' +\n // ' \\n' +\n // ' /**\\n' +\n tagToSdkClientRecord: Record<string, string>\n // 'Users V4': '\\n' +\n // ' /**\\n' +\n // ' * This endpoint is used to invite a game studio admin user with new namespace in multi tenant mode. It will return error if the service multi tenant mode is set to false. Request body details: - emailAddress: email address of the user to be invited - namespace: new namespace of the user to be created - namespaceDisplayName: display name of the new namespace The invited users will also be assigned with "User" role by default. \\n' +\n // ' */\\n' +\n // ' createUserInvite(data: PublicInviteUserRequestV4): Promise<IResponse<InviteUserResponseV3>> {\\n' +\n // ' const params = {} as SDKRequestConfig\\n' +\n // \" const url = '/iam/v4/public/users/invite' \\n\" +\n // ' const resultPromise = this.axiosInstance.post(url, data, {params})\\n' +\n // '\\n' +\n // \" return Validate.responseType(() => resultPromise, InviteUserResponseV3, 'InviteUserResponseV3')\\n\" +\n // ' }\\n' +\n // ' \\n' +\n // ' /**\\n'\n tagToEndpointClassesRecord: Record<string, string>\n // For example:\n // 'Users V4': [\n // \"import { UpgradeHeadlessAccountWithVerificationCodeRequestV4 } from '../definitions/UpgradeHeadlessAccountWithVerificationCodeRequestV4.js'\",\n // \"import { UserCreateFromInvitationRequestV4 } from '../definitions/UserCreateFromInvitationRequestV4.js'\",\n // \"import { UpgradeHeadlessAccountRequestV4 } from '../definitions/UpgradeHeadlessAccountRequestV4.js'\",\n // \"import { EmailUpdateRequestV4 } from '../definitions/EmailUpdateRequestV4.js'\",\n // \"import { CreateTestUserRequestV4 } from '../definitions/CreateTestUserRequestV4.js'\",\n // \"import { UserUpdateRequestV3 } from '../definitions/UserUpdateRequestV3.js'\",\n // \"import { CreateUserRequestV4 } from '../definitions/CreateUserRequestV4.js'\",\n // \"import { PublicInviteUserRequestV4 } from '../definitions/PublicInviteUserRequestV4.js'\"\n // ]\n tagToSdkImportsRecord: Record<string, string[]>\n // UsersV4: {\n // InviteUserResponseV3: \"import { InviteUserResponseV3 } from '../definitions/InviteUserResponseV3.js'\",\n // CreateUserResponseV4: \"import { CreateUserResponseV4 } from '../definitions/CreateUserResponseV4.js'\",\n // UserResponseV3: \"import { UserResponseV3 } from '../definitions/UserResponseV3.js'\",\n // EnabledFactorsResponseV4: \"import { EnabledFactorsResponseV4 } from '../definitions/EnabledFactorsResponseV4.js'\",\n // BackupCodesResponseV4: \"import { BackupCodesResponseV4 } from '../definitions/BackupCodesResponseV4.js'\",\n // UserResponseV4: \"import { UserResponseV4 } from '../definitions/UserResponseV4.js'\",\n // AuthenticatorKeyResponseV4: \"import { AuthenticatorKeyResponseV4 } from '../definitions/AuthenticatorKeyResponseV4.js'\"\n // }\n tagToClassImportsRecord: Record<string, Record<string, string>>\n // [ 'PublicThirdPartyPlatformInfoArray', 'GetUserMappingV3Array' ].\n arrayDefinitions: string[]\n // {\n // '/some/path': {\n // web: '',\n // shell: '',\n // webGit: ''\n // }\n // }\n snippetMap: Record<string, SnippetMap>\n}\n\nexport class SwaggerReaderHelpers {\n private static getServicePrefix = (servicePaths: string[]) => servicePaths[servicePaths.length - 1].split('/')[1]\n\n static parseAllEndpoints = async ({\n api,\n sdkName,\n serviceName\n }: {\n api: OpenApiSpec\n sdkName: string\n serviceName: string\n }): Promise<{\n admin: Result\n public: Result\n }> => {\n const result: {\n admin: Result\n public: Result\n } = {\n admin: {\n arrayDefinitions: [],\n snippetMap: {},\n tagToClassImportsRecord: {},\n tagToEndpointClassesRecord: {},\n tagToSdkClientRecord: {},\n tagToSdkFunctionNamesRecord: {},\n tagToSdkImportsRecord: {}\n },\n public: {\n arrayDefinitions: [],\n snippetMap: {},\n tagToClassImportsRecord: {},\n tagToEndpointClassesRecord: {},\n tagToSdkClientRecord: {},\n tagToSdkFunctionNamesRecord: {},\n tagToSdkImportsRecord: {}\n }\n }\n\n const sortedPathsByLength = new Map(\n Object.entries(api.paths).sort((a, b) => {\n if (a[0].length === b[0].length) {\n return a[0].localeCompare(b[0])\n } else {\n return a[0].length - b[0].length\n }\n })\n )\n const sortedKeys = Array.from(sortedPathsByLength.keys())\n const servicePrefix = SwaggerReaderHelpers.getServicePrefix(sortedKeys)\n\n // This is to detect multiple naming conflicts, so we can append it with something else.\n const tagToClassMethodsMap: {\n admin: Record<string, Record<string, string>>\n public: Record<string, Record<string, string>>\n } = {\n admin: {},\n public: {}\n }\n\n for (const [path, operation] of sortedPathsByLength) {\n if (path.indexOf('/healthz') >= 0) {\n continue\n }\n\n const isAdminEndpoint = path.indexOf('/admin/') > -1\n\n const picked = isAdminEndpoint ? result.admin : result.public\n const {\n arrayDefinitions,\n snippetMap,\n tagToClassImportsRecord,\n tagToEndpointClassesRecord,\n tagToSdkClientRecord,\n tagToSdkFunctionNamesRecord,\n tagToSdkImportsRecord\n } = picked\n\n const tagToClassMethodsMapByType = isAdminEndpoint ? tagToClassMethodsMap.admin : tagToClassMethodsMap.public\n const generatedMethods = {} // { path_get: 'fetchSomething' }\n\n const httpMethods = Object.keys(operation)\n for (const httpMethod of httpMethods) {\n const endpoint = await Endpoint.parseAsync(operation[httpMethod]).catch(error => {\n console.error(JSON.stringify({ path, httpMethod }, null, 2))\n throw error\n })\n if (!endpoint.tags) continue\n\n const [tag] = endpoint.tags\n const pathWithBase = `${api.basePath ?? ''}${path}`\n\n tagToClassMethodsMapByType[tag] = tagToClassMethodsMapByType[tag] ? tagToClassMethodsMapByType[tag] : {}\n const isForm = endpoint.consumes && endpoint.consumes[0] === 'application/x-www-form-urlencoded'\n const classMethod = ParserUtils.generateNaturalLangMethod({\n servicePrefix,\n path,\n httpMethod,\n isForm,\n existingMethods: tagToClassMethodsMapByType[tag]\n })\n tagToClassMethodsMapByType[tag][classMethod] = `${path} ${httpMethod}`\n generatedMethods[`${path} ${httpMethod}`] = `${classMethod}`\n\n if (!snippetMap[pathWithBase]) {\n // Initialize, if undefined.\n snippetMap[pathWithBase] = {}\n }\n\n const description = endpoint.description?.replace(/\\s+/g, ' ') || ''\n\n const responseClass = ParserUtils.get2xxResponse(endpoint.responses)\n const { className, classGenName } = ParserUtils.generateClassName(tag, isAdminEndpoint)\n tagToClassImportsRecord[className] = tagToClassImportsRecord[className] ? tagToClassImportsRecord[className] : {}\n if (responseClass) {\n const importTypeClass = ParserUtils.parseRefType(responseClass)\n tagToClassImportsRecord[className][\n importTypeClass\n ] = `import { ${importTypeClass} } from '../../generated-definitions/${importTypeClass}.js'`\n }\n if (responseClass && responseClass.endsWith('Array')) {\n arrayDefinitions.push(responseClass)\n }\n\n const queryParams = ParserUtils.filterQueryParameters(endpoint.parameters)\n const isFormUrlEncoded = ParserUtils.isFormUrlEncoded(httpMethod, endpoint.consumes)\n const pathParams = ParserUtils.filterPathParams(endpoint.parameters)\n let bodyParams = ParserUtils.filterBodyParams(endpoint.parameters)\n const deprecated = !!endpoint.deprecated\n\n // Handling requestBody in swagger v3 `templateMethod` expect `bodyParams` to be array, so for now we convert\n // requestBody format to array params\n if (endpoint.requestBody) {\n bodyParams = [\n {\n name: 'body',\n in: 'body',\n schema: endpoint.requestBody.content['application/json'].schema\n }\n ]\n }\n\n // -- classes\n const { methodImpl, methodParams, methodParamsNoTypes, importStatements } = templateMethod({\n classMethod,\n description,\n httpMethod,\n path: pathWithBase,\n pathParams,\n bodyParams,\n queryParams,\n isFormUrlEncoded,\n responseClass,\n deprecated\n })\n\n tagToEndpointClassesRecord[tag] = (tagToEndpointClassesRecord[tag] || '') + methodImpl\n\n // -- apis\n const { generatedMethodString, snippetApiArgs, snippetMethod, snippetShell } = templateApiMethod({\n classMethod,\n description,\n httpMethod,\n path: pathWithBase,\n pathParams,\n bodyParams,\n responseClass,\n classGenName,\n methodParams,\n methodParamsNoTypes,\n deprecated,\n xSecurity: endpoint['x-security']\n })\n tagToSdkClientRecord[tag] = (tagToSdkClientRecord[tag] || '') + generatedMethodString\n tagToSdkFunctionNamesRecord[tag] = (tagToSdkFunctionNamesRecord[tag] || '') + classMethod + ','\n\n // -- dependencies\n tagToSdkImportsRecord[tag] = tagToSdkImportsRecord[tag]\n ? [...new Set([...importStatements, ...tagToSdkImportsRecord[tag]])]\n : [...new Set(importStatements)]\n\n const serviceNameTitle = ParserUtils.convertDashesToTitleCase(serviceName)\n const { apiGenName } = ParserUtils.generateApiName(tag, isAdminEndpoint)\n const resultSnippet = templateSdkSnippet({ serviceNameTitle, apiName: apiGenName, snippetMethod, snippetApiArgs })\n\n // -- snippets\n const currentSnippetMap: SnippetMap[Methods] = {}\n snippetMap[pathWithBase][httpMethod as Methods] = currentSnippetMap\n currentSnippetMap.web = resultSnippet\n const generatedDirName = isAdminEndpoint ? 'generated-admin' : 'generated-public'\n currentSnippetMap.webGit = GIT_URL + `/sdk-${sdkName}/src/${generatedDirName}/${apiGenName}.ts`\n // Put this last to preserve the previous order.\n currentSnippetMap.shell = snippetShell\n }\n }\n\n for (const key in result) {\n // De-duplicate.\n result[key as keyof typeof result].arrayDefinitions = Array.from(new Set(result[key as keyof typeof result].arrayDefinitions))\n }\n\n return result\n }\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport SwaggerParser from '@apidevtools/swagger-parser'\nimport fs from 'fs'\nimport path from 'path'\nimport { CliParser } from './CliParser'\nimport { ParserUtils } from './ParserUtils'\nimport { Endpoint, OpenApiSpec } from './Swagger'\nimport { templateMethod } from './templates/template-method'\nimport { TemplateZod, TemplateZodArray } from './templates/template-zod'\nimport { templateApiMethod } from './templates/template-api-method'\nimport { templateApiIndex } from './templates/template-api-index'\nimport { templateSdkSnippet } from './templates/template-sdk-snippet'\nimport { SwaggerReaderHelpers } from './helpers/SwaggerReaderHelpers'\n\n// Patching is done in https://bitbucket.org/accelbyte/justice-codegen-sdk-spec\n\nexport class CodeGenerator {\n static srcFolder = () => CliParser.getOutputPath()\n\n static getGeneratedFolder = (isAdmin: boolean) =>\n isAdmin ? `${CodeGenerator.srcFolder()}/generated-admin` : `${CodeGenerator.srcFolder()}/generated-public`\n\n static getGeneratedSnippetsFolder = () => `${CliParser.getSnippetOutputPath()}/generated-snippets`\n\n static prepareDirs = (DIST_DEFINITION_DIR, DIST_DIR, DIST_DIR_ENDPOINTS) => {\n ParserUtils.mkdirIfNotExist(DIST_DEFINITION_DIR)\n ParserUtils.mkdirIfNotExist(DIST_DIR(true))\n ParserUtils.mkdirIfNotExist(DIST_DIR(false))\n ParserUtils.mkdirIfNotExist(DIST_DIR_ENDPOINTS(true))\n ParserUtils.mkdirIfNotExist(DIST_DIR_ENDPOINTS(false))\n }\n\n static main = async (nameArray: string[]): Promise<Set<string>> => {\n const serviceName = nameArray[0]\n const sdkName = nameArray[1]\n const swaggerFile = nameArray[2]\n const parser = new SwaggerParser()\n const swaggerFilePath = `${CliParser.getSwaggersOutputPath()}/${swaggerFile}`\n const api = await parser.parse(swaggerFilePath)\n const serviceNameTitle = ParserUtils.convertDashesToTitleCase(serviceName)\n\n const indexImportsSet: Set<string> = new Set()\n const apiInfo = { ...api.info, 'x-version': api['x-version']?.version }\n console.log('----------\\nGenerating API:', { title: apiInfo.title, version: apiInfo.version })\n\n ParserUtils.syncPackageVersion(apiInfo, CliParser.skipVersionSync(), process.env.PRERELEASE_ID)\n ParserUtils.writeXVersion(CodeGenerator.srcFolder(), api['x-version'], api.info)\n\n const parsedInformation = await SwaggerReaderHelpers.parseAllEndpoints({ api, sdkName, serviceName })\n\n if (CliParser.getSnippetOutputPath()) {\n try {\n ParserUtils.writeSnippetFile(\n CodeGenerator.getGeneratedSnippetsFolder(),\n api.info.title,\n JSON.stringify(\n {\n ...parsedInformation.public.snippetMap,\n ...parsedInformation.admin.snippetMap\n },\n null,\n 2\n )\n )\n } catch (err) {\n console.log('Generating snippets', err)\n }\n }\n\n const DIST_DIR = (isAdmin: boolean) => `${CodeGenerator.getGeneratedFolder(isAdmin)}`\n const DIST_DIR_ENDPOINTS = (isAdmin: boolean) => path.join(DIST_DIR(isAdmin), 'endpoints')\n const DIST_DEFINITION_DIR = path.join(CodeGenerator.srcFolder(), 'generated-definitions')\n const targetSrcFolder = `${CodeGenerator.srcFolder()}/`\n CodeGenerator.prepareDirs(DIST_DEFINITION_DIR, DIST_DIR, DIST_DIR_ENDPOINTS)\n\n const mainApiList = []\n\n // ----\n const generatePublicOrAdmin = isAdmin => {\n const parsedInformationByType = isAdmin ? parsedInformation.admin : parsedInformation.public\n const {\n arrayDefinitions,\n tagToClassImportsRecord,\n tagToEndpointClassesRecord,\n tagToSdkClientRecord,\n tagToSdkFunctionNamesRecord,\n tagToSdkImportsRecord\n } = parsedInformationByType\n\n // creates Api And Endpoint classes\n const writeApiEndpointFiles = (isAdminEndpoint: boolean) => {\n const apiList = []\n for (const tag in tagToEndpointClassesRecord) {\n const { className, classGenName } = ParserUtils.generateClassName(tag, isAdminEndpoint)\n const classBuffer = tagToEndpointClassesRecord[tag]\n const imports = [...new Set([...tagToSdkImportsRecord[tag], ...Object.values(tagToClassImportsRecord[className])])]\n const apiImports = [...new Set([...tagToSdkImportsRecord[tag], ...Object.values(tagToClassImportsRecord[className])])]\n apiImports.push(`import { ${classGenName} } from './endpoints/${classGenName}.js'`)\n\n ParserUtils.writeClassFile(DIST_DIR_ENDPOINTS(isAdminEndpoint), classGenName, classBuffer, imports)\n\n const apiBuffer = tagToSdkClientRecord[tag]\n const { apiGenName } = ParserUtils.generateApiName(tag, isAdminEndpoint)\n ParserUtils.writeApiFile(DIST_DIR(isAdminEndpoint), apiGenName, apiBuffer, apiImports, tagToSdkFunctionNamesRecord[tag])\n apiList.push(apiGenName)\n\n // For endpoint classes, we need to append `$`.\n indexImportsSet.add(\n ParserUtils.getRelativePathToWebSdkSrcFolder(path.join(DIST_DIR_ENDPOINTS(isAdminEndpoint), `${classGenName}`), targetSrcFolder)\n )\n indexImportsSet.add(\n ParserUtils.getRelativePathToWebSdkSrcFolder(path.join(DIST_DIR(isAdminEndpoint), `${apiGenName}`), targetSrcFolder)\n )\n }\n mainApiList.push(...apiList)\n indexImportsSet.add(\n ParserUtils.getRelativePathToWebSdkSrcFolder(path.join(CodeGenerator.srcFolder(), serviceNameTitle), targetSrcFolder)\n )\n } // end of writeApiEndpointFiles\n\n // creates the definition files\n const writeDefinitions = api => {\n const duplicates = new Map<string, string>()\n const definitions = api?.components?.schemas || api.definitions\n for (const ref in definitions) {\n const definition = definitions[ref]\n const fileName = ParserUtils.parseRefType(ref)\n const fileExist = fs.existsSync(path.join(DIST_DEFINITION_DIR, `${fileName}.ts`))\n if (fileExist) {\n const duplicateName = ParserUtils.toCamelCaseWord(ref).replace('.', '').replace('.', '')\n duplicates.set(ref, duplicateName)\n }\n const { buffer } = new TemplateZod().render(fileName, definition, new Map())\n ParserUtils.writeDefinitionFile(DIST_DEFINITION_DIR, fileName, buffer)\n indexImportsSet.add(ParserUtils.getRelativePathToWebSdkSrcFolder(path.join(DIST_DEFINITION_DIR, fileName), targetSrcFolder))\n }\n\n // TODO BROKEN DEFINITION, this pefix dups with Model<Name>.js causing NOT FOUND, commented out\n // rerun, find duplicates and write again the fixed dup name\n // for (const ref in definitions) {\n // const definition = definitions[ref]\n // const fileName = ParserUtils.parseRefType(ref)\n // const { buffer, duplicateFound } = new TemplateZod().render(fileName, definition, duplicates)\n // if (duplicateFound) {\n // ParserUtils.writeDefinitionFile(DIST_DEFINITION_DIR, fileName, buffer)\n // indexImportsSet.add(ParserUtils.getRelativePathToWebSdkSrcFolder(path.join(DIST_DEFINITION_DIR, fileName), targetSrcFolder))\n // }\n // }\n\n for (const arrayClass of arrayDefinitions) {\n const buffer = new TemplateZodArray().render(arrayClass)\n ParserUtils.writeDefinitionFile(DIST_DEFINITION_DIR, arrayClass, buffer)\n indexImportsSet.add(ParserUtils.getRelativePathToWebSdkSrcFolder(path.join(DIST_DEFINITION_DIR, arrayClass), targetSrcFolder))\n }\n } // end of writeDefinitions\n\n writeApiEndpointFiles(isAdmin)\n writeDefinitions(api)\n }\n\n generatePublicOrAdmin(true) // create Admin classes\n generatePublicOrAdmin(false) // create Public classes\n\n const apiIndexBuff = templateApiIndex(serviceName, serviceNameTitle, mainApiList)\n ParserUtils.writeApiMainFile(CodeGenerator.srcFolder(), serviceNameTitle, apiIndexBuff)\n\n console.log('\\nCOMPLETED\\n----------\\n\\n')\n return indexImportsSet\n } // end of main\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport * as https from 'https'\nimport * as fs from 'fs'\nimport * as path from 'path'\nimport { CliParser } from './CliParser'\n\n/**\n * This file iterates over intended API configs and downloads the swagger files to target location from --swaggersOutput argument\n *\n * e.g\n * /packages\n * /od-config\n * /codegen\n * /swaggers\n * serviceName.json --> example \"iam.json\"\n */\nexport class SwaggerDownloader {\n static getDestFile = (targetFileName: string) => {\n const destPath = CliParser.getResolvedSwaggersOutputPath()\n const destFile = path.join(destPath, targetFileName)\n if (fs.existsSync(destFile)) return destFile\n if (!fs.existsSync(destPath)) fs.mkdirSync(destPath)\n fs.writeFileSync(destFile, '')\n return destFile\n }\n\n // session-api.json contains illegal URL encoded character that breaks the codegen\n // e.g. \"$ref\": \"#/definitions/map%5Bstring%5Dinterface%20%7B%7D\"\n static postSanitizeDownloadedFile = filePath => {\n const searchStr = ['%5B', '%5D', '%20', '%7B', '%7D'] // url encoded\n fs.readFile(filePath, 'utf8', (err, data) => {\n if (err) throw err\n // Replace all occurrences of the search string with the replace string\n let result = data\n searchStr.forEach(s => {\n result = result.replace(new RegExp(s, 'g'), ' ')\n })\n // Write the updated contents to the file\n fs.writeFile(filePath, result, 'utf8', err => {\n if (err) throw err\n console.log('File updated successfully.')\n })\n })\n }\n\n static downloadFile = async (targetFileName: string, url: string) => {\n const destFile = SwaggerDownloader.getDestFile(targetFileName)\n let data = ''\n\n return new Promise(resolve => {\n const request = https.get(url, function (response) {\n response.on('data', chunk => {\n data += chunk\n })\n response.on('end', () => {\n if (response.statusCode !== 200) {\n console.log(`SwaggerDownload error with status code: ${response.statusCode}`)\n } else {\n fs.writeFileSync(destFile, JSON.stringify(JSON.parse(data), null, 2), 'utf-8')\n SwaggerDownloader.postSanitizeDownloadedFile(destFile)\n console.log(`SwaggerDownload ${url} completed with status code: ${response.statusCode}`)\n }\n\n resolve(undefined)\n })\n })\n request.on('error', (err: Error) => {\n console.log(`SwaggerDownloader failed for \"${targetFileName}\" and \"${url}\"`, err)\n })\n })\n }\n\n static main = async () => {\n const swaggers = CliParser.getConfigFile()\n for (const ref in swaggers) {\n const targetFileName = swaggers[ref][2]\n const url = swaggers[ref][3]\n await SwaggerDownloader.downloadFile(targetFileName, url)\n }\n }\n}\n","/*\n * Copyright (c) 2022-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\n\nimport yargs from 'yargs'\nimport { CliOption, CliParser } from './CliParser'\nimport { CodeGenerator } from './CodeGenerator'\nimport path from 'path'\nimport { ParserUtils } from './ParserUtils'\nimport { SwaggerDownloader } from './SwaggerDownloader'\n\nconst generateSdk = async () => {\n const arrayOfSets = await Promise.all(CliParser.getConfigFile().map(config => CodeGenerator.main(config)))\n const indexImportsSet = new Set<string>()\n const filenamesSet = new Set<string>()\n\n for (const set of arrayOfSets) {\n set.forEach(value => {\n const fileName = path.basename(value)\n\n if (!filenamesSet.has(fileName)) {\n indexImportsSet.add(value)\n filenamesSet.add(fileName)\n }\n })\n }\n\n const indexImportsArray = Array.from(indexImportsSet)\n const filesToImport = indexImportsArray.map(fileToImport => {\n return `export * from '${fileToImport.replace('\\\\', '/')}.js'`\n })\n ParserUtils.writeAllImportsFile(CliParser.getOutputPath(), filesToImport.join('\\n'))\n}\n\n// eslint-disable-next-line no-unused-expressions\nyargs\n .command('download-swaggers', 'Download swaggers JSON files', (yargs: CliOption) => {\n CliParser.createInstance(yargs)\n SwaggerDownloader.main()\n })\n .command('generate-code', 'Generate code based on downloaded swagger files', async (yargs: CliOption) => {\n // validate options\n yargs.check(({ output }) => {\n if (!output?.trim()) {\n throw new Error('output is required for generate-code')\n }\n return true\n })\n\n CliParser.createInstance(yargs)\n\n await generateSdk()\n })\n .option('config', {\n description: 'Config file providing backend services URL.',\n type: 'string',\n demandOption: true\n })\n .option('swaggersOutput', {\n description: 'Output path for downloaded swaggers JSON files.',\n type: 'string',\n demandOption: true\n })\n .option('output', {\n description: 'Output path for generated code. Required for generate-code',\n type: 'string'\n })\n .demandCommand(1)\n .help().argv\n"],"names":["fs","getImportableVarMap","makeNewImportVarMap","path"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"accelbyte-codegen.mjs","sources":["../src/CliParser.ts","../src/templates/template-class.ts","../src/templates/template-query.ts","../src/templates/template-api-class.ts","../src/helpers/VersionHelpers.ts","../src/ParserUtils.ts","../src/templates/template-zod.ts","../src/templates/template-api-index.ts","../src/Swagger.ts","../src/templates/template-method.ts","../src/templates/template-api-method.ts","../src/templates/template-sdk-snippet.ts","../src/templates/template-query-method.ts","../src/helpers/SwaggerReaderHelpers.ts","../src/CodeGenerator.ts","../src/SwaggerDownloader.ts","../src/cli.ts"],"sourcesContent":["/*\n * Copyright (c) 2022-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\n\nimport { Argv } from 'yargs'\nimport { z } from 'zod'\nimport fs from 'fs'\nimport * as path from 'path'\n\nconst SwaggersConfig = z.array(z.array(z.string()))\ntype SwaggersConfig = z.TypeOf<typeof SwaggersConfig>\n\nexport interface CliOption\n extends Argv<{\n config: string\n swaggersOutput: string\n output: string\n }> {}\n\nexport class CliParser {\n private static _instance: CliParser\n public argv\n constructor(yargs: CliOption) {\n this.argv = yargs.parse()\n }\n\n public static createInstance = (yargs: CliOption) => {\n CliParser._instance = new CliParser(yargs)\n return CliParser._instance\n }\n\n private static instance = (yargs?: CliOption) => {\n if (!CliParser._instance && yargs) {\n return CliParser.createInstance(yargs)\n }\n return CliParser._instance\n }\n\n public static getConfigPath = (): string => {\n return CliParser.instance().argv.config\n }\n\n public static getConfigFile = (): SwaggersConfig => {\n const configPath = CliParser.getConfigPath()\n if (!configPath) throw new Error('Missing config file')\n const config = JSON.parse(fs.readFileSync(configPath, 'utf8'))\n if (!SwaggersConfig.safeParse(config).success) {\n throw new Error('Wrong config file format')\n }\n return config\n }\n\n public static getOutputPath = (): string => {\n return CliParser.instance().argv.output\n }\n\n public static getSwaggersOutputPath = (): string => {\n return CliParser.instance().argv.swaggersOutput\n }\n\n public static getResolvedSwaggersOutputPath = (): string => {\n return path.resolve(CliParser.getSwaggersOutputPath())\n }\n\n public static getSnippetOutputPath = (): string => {\n return CliParser.instance().argv.snippetOutput\n }\n\n // TODO: remove this, since this is not used apparently.\n public static skipVersionSync = (): boolean => {\n return CliParser.instance().argv.skipVersionSync\n }\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nconst getImportableVarMap = () => ({\n '@accelbyte/sdk': ['CodeGenUtil', 'IResponse', 'Validate'],\n axios: ['AxiosRequestConfig', 'AxiosResponse'],\n zod: ['z']\n})\n\nconst makeNewImportVarMap = () => ({\n axios: ['AxiosInstance'],\n '@accelbyte/sdk': ['SDKRequestConfig']\n})\n\nexport const generateImports = (body: string, importStatements: string[], makeNewImportVarMap, getImportableVarMap) => {\n const usedImportVarMap = makeNewImportVarMap\n const importableVarMap = getImportableVarMap\n\n for (const [moduleSource, importableVars] of Object.entries(importableVarMap)) {\n // @ts-ignore\n for (const importableVar of importableVars) {\n const importVarRegex = new RegExp(`(?<![\\\\d\\\\w_])${importableVar}(?![\\\\d\\\\w_])`)\n if (body.match(importVarRegex)) {\n usedImportVarMap[moduleSource] = [...(usedImportVarMap[moduleSource] || []), importableVar]\n }\n }\n }\n\n const generatedImports = Object.keys(usedImportVarMap)\n .sort()\n .map((moduleSource: string) => {\n return `import { ${usedImportVarMap[moduleSource].sort().join(', ')} } from '${moduleSource}'`\n })\n .join('\\n')\n return `${generatedImports}\\n${importStatements.sort().join('\\n')}`\n}\n\nexport const templateClass = (className: string, body: string, importStatements: string[]): string => {\n return `/**\n * AUTO GENERATED\n */\n${generateImports(body, importStatements, makeNewImportVarMap(), getImportableVarMap())}\n\nexport class ${className} {\n // @ts-ignore\n constructor(private axiosInstance: AxiosInstance, private namespace: string, private useSchemaValidation = true) {}\n ${body}\n}\n `\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport { ParserUtils } from '../ParserUtils'\n\nexport const generateImports = (body: string, className: string) => {\n const generatedImports =\n '' +\n \"import { AccelbyteSDK, ApiArgs, ApiError } from '@accelbyte/sdk'\\n\" +\n \"import { AxiosError } from 'axios'\\n\" +\n '// @ts-ignore\\n' +\n \"import { useQuery, UseQueryOptions, UseQueryResult, useMutation, UseMutationOptions, UseMutationResult } from '@tanstack/react-query'\\n\" +\n `import { ${className} } from \"../${className}.js\"\\n`\n\n return generatedImports\n}\n\nexport const templateQuery = (\n className: string,\n body: string,\n importStatements: string[],\n serviceNameTitle: string,\n returnMethods: string,\n paramImports: string[]\n): string => {\n const classNameWithoutApi = className.replace('Api', '')\n const queryKeys = ParserUtils.createQueryKeys(classNameWithoutApi, returnMethods)\n const generatedImports = generateImports(body, className)\n\n return `/**\n * AUTO GENERATED\n */\n/* eslint-disable camelcase */\n${generatedImports}\n${filterUsedImports(paramImports, body)}\n\nexport enum Key_${classNameWithoutApi} {\n ${queryKeys}\n}\n\n ${body}\n `\n}\n\nfunction filterUsedImports(importArr, body) {\n return (\n importArr\n .filter(path => {\n const start = path.indexOf('{') + 1\n const end = path.indexOf('}')\n if (start > 0 && end > start) {\n const importName = path.slice(start, end).trim()\n // Check if the extracted className is used in the body\n return body.includes(importName)\n }\n return false\n })\n .map(path => path) // Direct mapping as there's no transformation needed\n .join('\\n') + '\\n'\n ) // Join the remaining imports with newlines\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport { generateImports } from './template-class'\nimport { ParserUtils } from '../ParserUtils'\n\nconst getImportableVarMap = () => ({\n '@accelbyte/sdk': ['CodeGenUtil', 'IResponse', 'Validate', 'ApiArgs', 'Network', 'AccelbyteSDK']\n})\n\nconst makeNewImportVarMap = () => ({\n '@accelbyte/sdk': ['AccelbyteSDK', 'ApiArgs', 'ApiUtils']\n})\n\n// TODO localStorage('ZodEnabled')=false disables Zod validation in browser only. TODO move to Featureflag instead\nexport const templateApiClass = (className: string, body: string, importStatements: string[], returnMethods: string): string => {\n\n const $className = className.replace('Api', '$')\n return `/**\n * AUTO GENERATED\n */\n/* eslint-disable camelcase */\n// @ts-ignore -> ts-expect-error TS6133\n${generateImports(body, importStatements, makeNewImportVarMap(), getImportableVarMap())}\n${`import { ${$className} } from './endpoints/${$className}.js'\\n`}\n\nexport function ${className}(sdk: AccelbyteSDK, args?: ApiArgs) {\n const sdkAssembly = sdk.assembly()\n \n const namespace = args?.namespace ? args?.namespace : sdkAssembly.namespace\n const requestConfig = ApiUtils.mergedConfigs(sdkAssembly.config, args)\n const useSchemaValidation = sdkAssembly.useSchemaValidation\n ${body}\n \n return {\n ${returnMethods}\n }\n}\n `\n}\n","/*\n * Copyright (c) 2023 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\n\nimport semver from 'semver'\nimport { z } from 'zod'\n\nexport const VersionBumpType = z.enum(['CUTOFF', 'RELEASE', 'HOTFIX', 'BREAKING'])\n\nexport class VersionHelpers {\n /**\n * This function calculates the next version, given 5 aspects:\n *\n * 1. The SDK version (prerelease)\n * 2. Prerelease ID\n *\n * Each of the component (major, minor, patch) will be added up, then the prerelease version will be matched with the prerelease ID.\n * If the current prerelease ID == next prerelease ID and there are no component changes, then bump the prerelease ID.\n *\n * For more examples, see the test file.\n *\n * @param param0\n * @returns\n */\n static getNextVersion = ({\n serviceVersion,\n versionBumpType,\n sdkVersion,\n nextPrereleaseId\n }: {\n serviceVersion: string\n versionBumpType?: string\n sdkVersion: string\n nextPrereleaseId: string\n }) => {\n // Validate the `versionBumpType`, if it's defined.\n if (versionBumpType !== undefined) {\n const parsed = VersionBumpType.safeParse(versionBumpType)\n if (!parsed.success) {\n throw new Error(`Invalid process.env.VERSION_BUMP_TYPE: ${versionBumpType}`)\n }\n\n // When `versionBumpType` is eitehr HOTFIX or RELEASE, `nextPrereleaseId` should not be set.\n // This is because official stable releases don't use prerelease versions.\n if ((parsed.data === 'HOTFIX' || parsed.data === 'RELEASE') && nextPrereleaseId) {\n throw new Error(`process.env.PRERELEASE_ID should be empty when process.env.VERSION_BUMP_TYPE is \"HOTFIX\" or \"PRELEASE\".`)\n }\n }\n\n // For reference, try this playground: https://codesandbox.io/s/dreamy-hopper-9drqcu?file=/src/App.js.\n const serviceSemvers = semver.parse(serviceVersion)\n const sdkSemvers = semver.parse(sdkVersion)\n\n if (serviceSemvers === null) {\n throw new Error(`Invalid service version: ${serviceVersion}`)\n }\n\n if (sdkSemvers === null) {\n throw new Error(`Invalid sdk version: ${sdkVersion}`)\n }\n\n const { major: currentMajor, minor: currentMinor, patch: currentPatch, prerelease: currentPrerelease } = sdkSemvers\n let nextMajor = currentMajor\n let nextMinor = currentMinor\n let nextPatch = currentPatch\n\n switch (versionBumpType) {\n // This only exist if we want to bump the sdk major versions\n // Probably, it'll be best if we manually bump it if it's an actual BREAKING CHANGE\n case VersionBumpType.Enum.BREAKING: {\n nextMajor++\n nextMinor = 0\n nextPatch = 0\n break\n }\n\n case VersionBumpType.Enum.CUTOFF: {\n nextMinor++\n nextPatch = 0\n break\n }\n case VersionBumpType.Enum.RELEASE:\n break\n case VersionBumpType.Enum.HOTFIX: {\n nextPatch++\n break\n }\n default:\n break\n }\n\n let nextVersion = [\n // For major version, we want to avoid false-positive breaking changes.\n // If we want to publish major version, we have to bump manually via\n // `predefinedMajorVersion` in the `sdk-*` that needs updating.\n nextMajor,\n nextMinor,\n nextPatch\n ].join('.')\n\n if (nextPrereleaseId) {\n if (nextMinor !== currentMinor) {\n // If minor/patch version is the same, then we want to keep the current prerelase version, e.g.\n // `-beta.5` to `-beta.6` instead of going back to 0.\n //\n // However, if it's different, we want to reset it to 0.\n nextVersion += `-${nextPrereleaseId}.0`\n } else {\n if (currentPrerelease.length) nextVersion += `-${currentPrerelease.join('.')}`\n nextVersion = semver.inc(nextVersion, 'prerelease', undefined, nextPrereleaseId)\n }\n }\n\n return nextVersion\n }\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport { applyPatch, Operation } from 'fast-json-patch'\nimport fs, { readFileSync, writeFileSync } from 'fs'\nimport _ from 'lodash'\nimport path from 'path'\nimport { Endpoint, EndpointParameters } from './Swagger'\nimport { templateClass } from './templates/template-class'\nimport { templateQuery } from './templates/template-query'\nimport { templateApiClass } from './templates/template-api-class'\nimport { VersionHelpers } from './helpers/VersionHelpers'\n\nconst UNDEFINED_SWAGGER_SEMVER = '0.0.0'\nconst REMOVED_KEYWORDS = [\n '/admin/',\n '/public/',\n '/v1/',\n '/v2/',\n '/v3/',\n '/v4/',\n '/v5/',\n '/namespace/' /* Note, it's not plural */,\n '/namespaces/',\n '/{namespace}/'\n]\n\nexport class ParserUtils {\n /**\n * convert csv 'aa,bb' into \"aa='aa', bb='bb'\"\n */\n static createQueryKeys(classNameWithoutApi, csvMethodNames: string): string {\n const keys = csvMethodNames.split(',')\n const processedKeys = new Set<string>()\n\n const enumString = keys.reduce((acc, key, index) => {\n const trimmedKey = key.trim()\n const isDeprecated = key.indexOf('_DEPRECATED') > 0\n if (trimmedKey && !isDeprecated) {\n // Remove known prefixes and any leading underscores or spaces\n const cleanedKey = trimmedKey.replace(/^(get|update|create|patch|delete)[_]?/, '')\n\n // Create the enum value only if it's not already added\n if (!processedKeys.has(cleanedKey)) {\n processedKeys.add(cleanedKey)\n acc += `${cleanedKey} = '${classNameWithoutApi}.${cleanedKey}'`\n if (index < keys.length - 1) {\n acc += ',\\n'\n }\n }\n }\n return acc\n }, '')\n\n return enumString\n }\n\n static addDeprecatedSuffix(isDeprecated, methodName) {\n if (isDeprecated) {\n return methodName + '_DEPRECATED'\n } else {\n return methodName\n }\n }\n\n static replaceAll = (text, search, replace) => {\n return text.split(search).join(replace)\n }\n\n static generateClassName = (tag: string, isAdmin: boolean) => {\n const className = _.upperFirst(_.camelCase(tag))\n const classGenName = isAdmin ? className + 'Admin$' : className + '$'\n return { className, classGenName }\n }\n\n static generateApiName = (tag: string, isAdmin: boolean) => {\n const apiName = _.upperFirst(_.camelCase(tag))\n const apiGenName = isAdmin ? apiName + 'AdminApi' : apiName + 'Api'\n return { apiName, apiGenName }\n }\n\n static parseQueryParamAttributeDefault = (definition: EndpointParameters) => {\n const attrName = definition.name.slice(definition.name.lastIndexOf('.') + 1)\n let defaultValue = definition.default\n\n if (definition.type === 'array' && Array.isArray(definition.default)) {\n const mappedDefaultValue = definition.default.map(defaultValue =>\n typeof defaultValue === 'string' ? `'${defaultValue}'` : defaultValue\n )\n defaultValue = `[${mappedDefaultValue.join(', ')}]`\n }\n\n if (definition.type === 'string') {\n defaultValue = `'${definition.default}'`\n }\n return `${attrName}: ${defaultValue}`\n }\n\n static parseType = (pathParam: EndpointParameters) => {\n if (isSwaggerIntegerType(pathParam.type || pathParam?.schema?.type)) return 'number'\n if (pathParam.type === 'array') {\n if (isSwaggerIntegerType(pathParam.items.type)) return 'number[]'\n return `${pathParam.items.type ?? 'any'}[]`\n }\n if (pathParam?.schema?.type === 'array') {\n if (isSwaggerIntegerType(pathParam.schema.items.type)) return 'number[]'\n return `${pathParam.schema.items.type ?? 'any'}[]`\n }\n if (pathParam?.schema?.type) return pathParam.schema.type\n return pathParam.type\n }\n\n static parseQueryParamsType = (queryParams: EndpointParameters[]) => {\n return queryParams.map(queryParam => ParserUtils.parseAttributeType(queryParam)).join(', ')\n }\n\n static isAnyQueryParamRequired = (queryParams: EndpointParameters[]) => {\n return queryParams.some(queryParam => queryParam.required)\n }\n\n static convertDashesToTitleCase = str => {\n const result = str\n .split('-') // split the string at the hyphen\n .map((word, index) => {\n // capitalize the first letter of each word\n if (index === 0) {\n return word.charAt(0).toUpperCase() + word.slice(1)\n }\n return word.charAt(0).toUpperCase() + word.slice(1).toLowerCase()\n })\n .join('') // join the words together without a separator\n return result\n }\n\n static parseQueryParamsDefault = (queryParams: EndpointParameters[]) => {\n const result = queryParams\n .filter(queryParam => !!queryParam.default && !queryParam.required)\n .map(ParserUtils.parseQueryParamAttributeDefault)\n .join(',')\n return result ? `${result},` : ''\n }\n\n static parseBodyParamsImports = (bodyParams: EndpointParameters[]) => {\n return bodyParams.map(bodyParams => ParserUtils.parseRefImport(bodyParams)).filter(Boolean)\n }\n\n static parseImportDir = ($ref: string) => {\n let ref = $ref.replace('.', '/')\n if (ref[ref.length - 1] === '.' || ref[ref.length - 1] === '/') {\n ref = ref.slice(0, -1)\n }\n if (!ref.includes('/')) {\n return ''\n } else {\n return ref.slice(0, ref.lastIndexOf('/')).replace('#', '.')\n }\n }\n\n static parseRefImport = (bodyParam: EndpointParameters) => {\n const $ref = bodyParam?.schema?.$ref || bodyParam?.schema?.items?.$ref\n if (!$ref) {\n return null\n }\n const type = ParserUtils.parseRefType($ref)\n return `import { ${type} } from '../../generated-definitions/${type}.js'`\n }\n\n static parseRefType = ($ref: string) => {\n let ref = $ref.replace('.', '/')\n if (ref[ref.length - 1] === '.' || ref[ref.length - 1] === '/') {\n ref = ref.slice(0, -1)\n }\n const val = ref.slice(ref.lastIndexOf('/') + 1)\n // Converting it to TitleCase breaks schema refs. E.g. UserDataURL schema is converted to UserDataUrl breaking refs\n return _.upperFirst(_.camelCase(val)).replace(/( \\w)/g, group => group.replace(' ', '').toUpperCase())\n }\n\n static parseAttributeType = (definition: EndpointParameters) => {\n const required = definition.required ? '' : '?'\n\n const attrName = definition.name.slice(definition.name.lastIndexOf('.') + 1)\n\n if (definition.enum) {\n const enums = definition.enum.map(enm => (definition.type === 'string' ? `'${enm}'` : enm)).join(' | ')\n return `${attrName}${required}: ${enums}`\n }\n\n if (definition.type && ParserUtils.parseType(definition) === 'number') {\n return `${attrName}${required}: number`\n }\n\n if (definition?.schema?.type && ParserUtils.parseType(definition) === 'number') {\n return `${attrName}${required}: number`\n }\n\n if (definition.type && definition.type === 'array') {\n return `${attrName}${required}: ${definition.items.type ?? 'any'}[]`\n }\n\n if (definition?.schema?.type && definition.schema.type === 'array') {\n return `${attrName}${required}: ${definition.schema.items.type ?? 'any'}[]`\n }\n\n if (definition.type && definition.type === 'file') {\n return `${attrName}${required}: File`\n }\n\n if (definition?.schema?.type && definition.schema.type === 'file') {\n return `${attrName}${required}: File`\n }\n\n if (definition.type && definition.type) {\n return `${attrName}${required}: ${definition.type} | null`\n }\n\n if (definition?.schema?.type && definition.schema.type) {\n return `${attrName}${required}: ${definition.schema.type} | null`\n }\n\n return `${attrName}${required}: any`\n }\n\n static parseBodyParamsType = (bodyParams: EndpointParameters[]): string => {\n const [bodyParam] = bodyParams\n\n if (!bodyParam) return null\n\n if (bodyParams.length > 0 && bodyParam?.name !== 'body' && !bodyParam?.schema) {\n let retBodyParams = `{${bodyParams.map(bodyParam => ParserUtils.parseAttributeType(bodyParam)).join(',')}}`\n retBodyParams = retBodyParams.replace('file?: file', 'file?: File') // fixed TS type File\n return retBodyParams\n }\n\n if (bodyParam?.schema?.type === 'array' && !bodyParam?.schema?.items?.$ref) {\n if (isSwaggerIntegerType(bodyParam.schema.items.type)) return 'number[]'\n return `${bodyParam.schema.items.type ?? 'any'}[]`\n }\n\n if (bodyParam?.schema?.type === 'array' && bodyParam?.schema?.items?.$ref) {\n return `${ParserUtils.parseRefType(bodyParam.schema.items.$ref)}[]`\n }\n\n if (bodyParam?.schema?.$ref) {\n return ParserUtils.parseRefType(bodyParam.schema.$ref)\n }\n\n if (bodyParam?.schema?.additionalProperties?.type === 'object') {\n return 'any'\n }\n\n return null\n }\n\n static get2xxResponse(methodEntity: Endpoint['responses']): string {\n const keys = Object.keys(methodEntity)\n let responseClass = null\n keys.forEach(key => {\n if (String(key).startsWith('2')) {\n const sch = methodEntity[key].schema\n const schV3 = methodEntity[key].content && methodEntity[key].content['application/json'].schema\n if (sch?.$ref) {\n responseClass = ParserUtils.parseRefType(sch.$ref)\n } else if (sch?.type === 'array' && sch.items?.$ref) {\n responseClass = ParserUtils.parseRefType(sch.items.$ref)\n responseClass = `${responseClass}Array` // Adds support for z.array() types\n } else if (schV3?.$ref) {\n responseClass = ParserUtils.parseRefType(schV3.$ref)\n } else {\n // TODO add support for non $ref types. E.g. { type: 'array', items: { type: 'string', enum: [ 'WALLET', 'XSOLLA', .. ] } }\n }\n }\n })\n\n return responseClass\n }\n\n static isFormUrlEncoded(httpMethod: string, contentTypes: string[]): boolean {\n if (!contentTypes || contentTypes.length < 1) {\n return false\n }\n if (!['post', 'put', 'patch'].includes(httpMethod)) {\n return false\n }\n return contentTypes.includes('application/x-www-form-urlencoded')\n }\n\n static filterPathParams(parameters?: EndpointParameters[]): EndpointParameters[] {\n if (!parameters) {\n return []\n }\n return parameters.filter(parameter => parameter.in === 'path')\n }\n\n /**\n * This method converts this\n * POST `/gdpr/public/namespaces/{namespace}/users/{userId}/requests/{requestDate}/generate`\n *\n * to this\n * `createGenerateByRequestIdByUserId`\n */\n static generateNaturalLangMethod = ({ servicePrefix, path, httpMethod, isForm, existingMethods }) => {\n let path_ = path\n path_ = path_.replace(`/${servicePrefix}/`, '/')\n REMOVED_KEYWORDS.forEach(prefix => {\n path_ = path_.replace(prefix, '/')\n })\n path_ = path_.substring(1) // remove first '/'\n\n // Example GET /xxx/yyy/{id}/items is \"fetchItems\" PLURAL\n // Example GET /xxx/yyy/{id}/items/{itemId} is \"fetchItem\" SINGULAR\n const isPlural = httpMethod === 'get' && !(path.slice(-1) === '}') // last char is '}'\n if (!isPlural) {\n path_ = ParserUtils.replaceAll(path_, 'ies/', 'y/') // parties, countries, policies\n path_ = ParserUtils.replaceAll(path_, 's/', '/')\n if (path_.indexOf('status') < 0) {\n path_ = path_.replace(/ies$/, 'y')\n path_ = path_.replace(/s$/, '')\n } // remove all tail end \"s\" -> /profiles, /users except /status\n } // make it non plural\n\n const arrLastWords = path_.split('}/')\n let lastWords = arrLastWords[arrLastWords.length - 1]\n\n const extractLastWord = lastWords_ => {\n let res = lastWords_\n res = res.split('/{')[0]\n return res\n }\n // convert \"/dlcs/latest/byGameAppId/{appId\" to \"/dlcs/latest/byGameAppId\" by dropping \"{appId\"\n lastWords = extractLastWord(lastWords)\n if (lastWords.indexOf('{') >= 0 && arrLastWords.length > 1) {\n lastWords = arrLastWords[arrLastWords.length - 2]\n lastWords = extractLastWord(lastWords)\n }\n\n const listBeforeLastWords = []\n let foundParam = false\n const listByParams = []\n\n // reverse iterate retrieving last words of the endpoint\n const pathElements = path_.split('/')\n pathElements\n .slice()\n .reverse()\n .forEach(item => {\n if (item.indexOf('}') >= 0) {\n foundParam = true\n let param = item.replace('{', '')\n param = param.replace('}', '')\n param = 'Byword' + _.upperFirst(param) + ''\n listByParams.push(param)\n } else if (!foundParam) {\n if (lastWords.indexOf(item) === -1) {\n listBeforeLastWords.push(item)\n }\n } else {\n foundParam = false\n }\n })\n\n const genPath = _.upperFirst(lastWords) + '/' + listBeforeLastWords.join('/') + listByParams.reverse().join('/')\n let generatedMethod = _.camelCase(mappedMethod(httpMethod, isForm) + genPath)\n generatedMethod = ParserUtils.replaceAll(generatedMethod, 'Byword', '_By') // lodash remvoes the '_'\n generatedMethod = resolveConflicts(path, generatedMethod, existingMethods)\n return generatedMethod\n }\n\n static filterBodyParams(parameters?: EndpointParameters[]) {\n if (Array.isArray(parameters) && parameters.length > 0) {\n return parameters.filter(parameter => parameter.in === 'body' || parameter.in === 'formData')\n }\n return []\n }\n\n static filterQueryParameters(parameters?: EndpointParameters[]): EndpointParameters[] {\n if (!parameters) {\n return []\n }\n return parameters.filter(parameter => parameter.in === 'query')\n }\n\n static mkdirIfNotExist(dirToCreate: string) {\n if (!fs.existsSync(dirToCreate)) {\n fs.mkdirSync(dirToCreate, { recursive: true })\n }\n }\n\n static writeClassFile(distDir: string, apiName: string, apiBuffer: string, imports?: string[]) {\n const fileContent = templateClass(apiName, apiBuffer, imports)\n fs.writeFileSync(`${distDir}/${apiName}.ts`, ParserUtils.prependCopyrightHeader(fileContent))\n }\n\n static writeAtomFile(distDir: string, apiName: string, fileContent: string) {\n ParserUtils.mkdirIfNotExist(distDir)\n fs.writeFileSync(`${distDir}/${apiName}.atom.ts`, ParserUtils.prependCopyrightHeader(fileContent))\n }\n\n static writeQueryFile(\n distDir: string,\n apiName: string,\n apiBuffer: string,\n imports: string[],\n serviceNameTitle: string,\n returnMethods: string,\n paramImports: string[]\n ) {\n if (apiBuffer.length < 1) {\n return null\n }\n const queryFileName = `${apiName.replace('Api', '')}.query`\n ParserUtils.mkdirIfNotExist(distDir)\n const fileContent = templateQuery(apiName, apiBuffer, imports, serviceNameTitle, returnMethods, paramImports)\n fs.writeFileSync(`${distDir}/${queryFileName}.ts`, ParserUtils.prependCopyrightHeader(fileContent))\n\n return queryFileName\n }\n\n static writeXVersion(distDir: string, xversionJson: string, apiInfo) {\n if (xversionJson) {\n console.log('x-version:', xversionJson)\n fs.writeFileSync(`${distDir}/version.json`, JSON.stringify(xversionJson, null, 2))\n } else {\n const customVersion = {\n ...apiInfo,\n gitHash: apiInfo.version\n }\n console.error('!!!! Missing x-version for ', distDir, customVersion)\n fs.writeFileSync(`${distDir}/version.json`, JSON.stringify(customVersion, null, 2))\n }\n }\n\n static writeApiFile(distDir: string, apiName: string, apiBuffer: string, imports: string[], returnMethods: string) {\n const newImports = []\n imports.forEach((el, index) => {\n newImports.push(el.replace('../../generated-definitions', '../generated-definitions'))\n })\n const fileContent = templateApiClass(apiName, apiBuffer, newImports, returnMethods)\n fs.writeFileSync(`${distDir}/${apiName}.ts`, ParserUtils.prependCopyrightHeader(fileContent))\n }\n\n static writeApiMainFile(distDir: string, serviceName: string, fileContent: string) {\n fs.writeFileSync(`${distDir}/${serviceName}.ts`, ParserUtils.prependCopyrightHeader(fileContent))\n }\n\n static writeSnippetFile(distDir: string, name: string, docBuffer: string) {\n let snippetFileName = ParserUtils.replaceAll(name, ' ', '-').toLowerCase()\n snippetFileName = snippetFileName.replace('justice-', '')\n snippetFileName = 'snippet-' + snippetFileName + '.json'\n fs.writeFileSync(`${distDir}/${snippetFileName}`, docBuffer)\n }\n\n static writeDefinitionFile(distDir: string, name: string, buffer: string) {\n ParserUtils.mkdirIfNotExist(distDir)\n fs.writeFileSync(path.join(distDir, `${name}.ts`), ParserUtils.prependCopyrightHeader(buffer))\n }\n\n static writeAllImportsFile(distDir: string, buffer: string) {\n ParserUtils.mkdirIfNotExist(distDir)\n fs.writeFileSync(path.join(distDir, 'all-imports.ts'), ParserUtils.prependCopyrightHeader(buffer))\n }\n\n static syncPackageVersion(apiInfo: any, skipVersionSync: boolean, prereleaseId: string) {\n if (skipVersionSync) return\n\n const currDir = process.cwd()\n const { packageJSON, pathToPackageJSON } = ParserUtils.getPackageJSONInfo(currDir)\n\n // Construct based on the Swagger minor version first.\n // Keep the major and patch untouched, which we will bump only by using `.inc()` for consistency purposes.\n const nextSemver = VersionHelpers.getNextVersion({\n serviceVersion: apiInfo['x-version'] || apiInfo.version || UNDEFINED_SWAGGER_SEMVER,\n versionBumpType: process.env.VERSION_BUMP_TYPE,\n sdkVersion: packageJSON.version,\n nextPrereleaseId: prereleaseId\n })\n\n packageJSON.version = nextSemver\n writeFileSync(pathToPackageJSON, JSON.stringify(packageJSON, null, 2))\n }\n\n static getPackageJSONInfo(dir) {\n const pathToPackageJSON = path.join(dir, './package.json')\n return { packageJSON: JSON.parse(readFileSync(pathToPackageJSON, 'utf-8')), pathToPackageJSON }\n }\n\n static toCamelCase(str: string) {\n return str\n .split('/')\n .map(function (word, index) {\n // If it is the first word make sure to lowercase all the chars.\n if (index === 0) {\n return word.toLowerCase()\n }\n // If it is not the first word only upper case the first char\n return ParserUtils.toCamelCaseWord(word)\n })\n .join('')\n }\n\n static toCamelCaseWord(word: string) {\n if (!word) {\n return ''\n }\n // convert hyphen separated case to camel case\n word = word.replace(/(-\\w)/g, m => m[1].toUpperCase())\n // capitalize first letter\n return word.charAt(0).toUpperCase() + word.slice(1)\n }\n\n static toTitleCaseWord(word: string) {\n if (!word) {\n return ''\n }\n return word.replace(/\\w\\S*/g, txt => {\n return txt.charAt(0).toUpperCase() + txt.substring(1).toLowerCase()\n })\n }\n\n static applyPatchIfExists(\n swaggerFilePath: string,\n possibleSwaggerPatchFilePath: string,\n swaggerPatchedFilePath: string,\n swaggerPatchedDir: string\n ) {\n if (!fs.existsSync(swaggerPatchedDir)) {\n fs.mkdirSync(swaggerPatchedDir, { recursive: true })\n }\n\n if (!fs.existsSync(possibleSwaggerPatchFilePath)) {\n fs.copyFileSync(swaggerFilePath, swaggerPatchedFilePath)\n return\n }\n const swaggerContent = JSON.parse(fs.readFileSync(swaggerFilePath, 'utf8'))\n const swaggerPatchFileContent: Operation[] = JSON.parse(fs.readFileSync(possibleSwaggerPatchFilePath, 'utf8'))\n\n // Check out the existence of the paths listed in the Swagger JSON patch.\n for (const patchEntry of swaggerPatchFileContent) {\n // Trim out empty string array elements.\n const segments = patchEntry.path.split('/').filter(Boolean)\n let currentNode = swaggerContent\n // This `aggregatedPath` is to pinpoint the erroring path, so that we can display the exact path where it errors\n // and not the entire `patchEntry.path`.\n let aggregatedPath = ''\n\n for (let i = 0; i < segments.length; i++) {\n const segment = segments[i]\n aggregatedPath += `/${segment}`\n\n // Replace the JSON pointers.\n // More on this: https://jsonpatch.com/#json-pointer.\n const effectiveSegment = segment.replace(/(~1)/g, '/').replace(/(~0)/g, '~')\n\n if (!currentNode[effectiveSegment]) {\n if (i + 1 === segments.length && patchEntry.op === 'add') {\n // Only allow missing node when we're adding a node and we're at the end of the segment array.\n // No-op.\n } else {\n // If it's not leaf node yet, then throw error.\n // If it's leaf node and the mode isn't \"add\", then throw error.\n throw new Error(\n [\n `JSON patch error: operation \"${patchEntry.op}\" on path \"${aggregatedPath}\" fails because the path doesn't exist in ${swaggerFilePath}. This may be caused by:\\n`,\n '1. The related service has patched the service, so patch is no longer needed.',\n '2. There is a breaking change on the service that causes the path to change.\\n',\n `In any case, revisit this file: \"${possibleSwaggerPatchFilePath}\", then try again.\\n`\n ].join('\\n')\n )\n }\n }\n\n currentNode = currentNode[effectiveSegment]\n }\n }\n\n const { newDocument } = applyPatch(swaggerContent, swaggerPatchFileContent)\n fs.writeFileSync(swaggerPatchedFilePath, JSON.stringify(newDocument, null, 2))\n }\n\n static getRelativePathToWebSdkSrcFolder(srcFolder: string, targetSrcFolder: string) {\n // For example:\n // Input: ../../accelbyte-web-sdk/packages/sdk/src/generated/...\n // Output: ./generated/...\n // Need to replace for Windows as `/` becomes `\\`.\n const replaced = srcFolder.replace(/\\\\/g, '/')\n return replaced.replace(/\\\\/g, '/').replace(targetSrcFolder, './')\n }\n\n static prependCopyrightHeader = (content: string): string => {\n const currentYear = new Date().getFullYear()\n return `/* \n * Copyright (c) 2022${currentYear > 2022 ? `-${currentYear}` : ''} AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\n${content}`\n }\n\n static sortPathParamsByPath = (pathParams: EndpointParameters[], path: string) => {\n const params = path.match(/{\\w*}/g) || []\n const cleanParams = params.map(param => param.replace('{', '').replace('}', ''))\n return pathParams.sort((a, b) => cleanParams.indexOf(a.name) - cleanParams.indexOf(b.name))\n }\n}\n\nconst mappedMethod = (httpMethod: string, isForm: boolean) => {\n if (httpMethod === 'get') {\n // return 'fetch'\n return 'get'\n } else if (httpMethod === 'post' && isForm) {\n return 'post'\n } else if (httpMethod === 'post') {\n return 'create'\n } else if (httpMethod === 'put') {\n return 'update'\n } else if (httpMethod === 'patch') {\n return 'patch'\n } else if (httpMethod === 'delete') {\n return 'delete'\n }\n}\n\nconst resolveConflicts = (path, generatedMethod, existingMethods) => {\n // generatedMethod = generatedMethod.replace('Namespaces', '')\n try {\n testConflict(path, generatedMethod, existingMethods)\n } catch (e) {\n if (path.indexOf('/namespaces/') >= 0) {\n generatedMethod += '_ByNS'\n }\n }\n\n try {\n testConflict(path, generatedMethod, existingMethods)\n } catch (e) {\n if (path.indexOf('/v4/') >= 0) {\n generatedMethod += '_v4'\n }\n }\n\n try {\n testConflict(path, generatedMethod, existingMethods)\n } catch (e) {\n if (path.indexOf('/v3/') >= 0) {\n generatedMethod += '_v3'\n }\n }\n\n try {\n testConflict(path, generatedMethod, existingMethods)\n } catch (e) {\n if (path.indexOf('/v2/') >= 0) {\n generatedMethod += '_v2'\n }\n }\n\n try {\n testConflict(path, generatedMethod, existingMethods)\n } catch (e) {\n if (path.indexOf('/admin/') >= 0) {\n generatedMethod += '_admin'\n }\n }\n\n // Still failed? dump it and fail the code gen build\n testConflict(path, generatedMethod, existingMethods)\n\n return generatedMethod\n}\n\nconst testConflict = (path, generatedMethod, existingMethods) => {\n if (existingMethods[generatedMethod]) {\n const conflictingMethod = { path, generatedMethod }\n throw Error(\n `Duplicate method conflict in ${JSON.stringify(conflictingMethod)},\\n existingMethods: ${JSON.stringify(existingMethods, null, 2)}`\n )\n }\n}\n\nconst isSwaggerIntegerType = (type: string) => {\n return type === 'integer' || type === 'int'\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport { ParserUtils } from '../ParserUtils'\nimport { Definition } from '../Swagger'\n\n// The expected output that we return from most of the functions below.\n// Normally, we will mostly use `schemaString`. In some unique cases\n// where there are recursive types, we cannot infer type. Hence, we need\n// to store the TypeScript syntax so we can write them manually.\ninterface ResultType {\n schemaString: string\n typeString: string\n}\n\nexport class TemplateZod {\n duplicates: Map<string, string>\n duplicateFound = false\n //\n private importClasses = new Set()\n\n // --\n render = (fileName: string, definition: Definition, duplicates: Map<string, string>) => {\n this.duplicates = duplicates\n const content = this.parseToZodSchema(definition, definition.required || [])\n\n // Prevent self-importing and handle recursive types.\n const containsRecursiveType = this.importClasses.has(fileName)\n if (containsRecursiveType) {\n this.importClasses.delete(fileName)\n }\n\n let imports = ''\n for (const cl of Array.from(this.importClasses).sort()) {\n imports += `import { ${cl} } from './${cl}.js'\\n`\n }\n\n // Modify export variable string, based on existence of recursive types.\n // Reference: https://github.com/colinhacks/zod#recursive-types.\n let exportedVariableString: string\n let exportedTypeString: string\n\n if (containsRecursiveType) {\n // If it contains recursive type, then we need to modify the exported variable in a way,\n // so that there are no TypeScript errors.\n exportedVariableString = `\nexport const ${fileName}: z.ZodType<${fileName}> = z.lazy(() =>\n ${content.schemaString}\n )\n `\n exportedTypeString = `\nexport interface ${fileName} {\n ${content.typeString}\n}\n`\n } else {\n // Export normally by writing the `z.ZodObject` and type inferring with `z.TypeOf`.\n exportedVariableString = `export const ${fileName} = ${content.schemaString}`\n exportedTypeString = `export interface ${fileName} extends z.TypeOf<typeof ${fileName}> {}`\n }\n\n const template = `import { z } from 'zod'\n${imports}\n\n${exportedVariableString}\n\n${exportedTypeString}\n `\n return { buffer: template, duplicateFound: this.duplicateFound }\n }\n\n // --\n parseToZodSchema = (definition, requiredAttrs): ResultType => {\n if (definition.additionalProperties) {\n return this.parseToZodAttribute('', definition, [])\n }\n\n let properties: [string, any]\n if (definition.properties) {\n properties = Object.entries(definition.properties) as [string, any]\n } else if (definition.items?.properties) {\n properties = Object.entries(definition.items.properties) as [string, any]\n } else {\n return {\n schemaString: 'z.any()',\n typeString: 'any'\n }\n }\n\n const schemaFields: string[] = []\n const typeFields: string[] = []\n\n for (const property of properties) {\n const [name, definition] = property\n const result = this.parseToZodAttribute(name, definition, requiredAttrs)\n\n schemaFields.push(result.schemaString)\n typeFields.push(result.typeString)\n }\n\n if (definition?.type === 'array') {\n return {\n schemaString: `z.array(z.object({${schemaFields.join(',')}}))`,\n typeString: typeFields.join(';')\n }\n }\n\n return {\n schemaString: `z.object({${schemaFields.join(',')}})`,\n typeString: typeFields.join(';')\n }\n }\n\n // --\n parseToZodAttribute = (name, definition, requiredAttrs): ResultType => {\n // Required field syntax.\n // Empty name check is required for fields with type records.\n const isRequired = requiredAttrs.includes(name) || name === ''\n const schemaRequired = isRequired ? '' : '.nullish()'\n const typeRequired = isRequired ? '' : '?'\n const typeNullishability = isRequired ? '' : ' | null | undefined'\n // Field name syntax.\n const schemaAttribute = name ? `'${name}':` : ''\n const typeAttribute = name ? `'${name}'${typeRequired}:` : ''\n\n const type = definition?.type\n\n if (definition.properties) {\n const result = this.parseToZodSchema(definition, requiredAttrs)\n return {\n schemaString: `${schemaAttribute} ${result.schemaString}${schemaRequired}`,\n typeString: `${typeAttribute} ${result.typeString}${typeNullishability}`\n }\n } else if (type) {\n if (type === 'object' && definition.additionalProperties) {\n const zodAttribute = this.parseToZodAttribute('', definition.additionalProperties, [''])\n return {\n schemaString: `${schemaAttribute} z.record(${zodAttribute.schemaString})${schemaRequired}`,\n typeString: `${typeAttribute} Record<string, ${zodAttribute.typeString}>${typeNullishability}`\n }\n }\n\n if (type === 'object' && !definition.additionalProperties && !name) {\n return {\n schemaString: `z.any()`,\n typeString: 'any'\n }\n }\n\n if (type === 'object' && !definition.additionalProperties) {\n return {\n schemaString: `${schemaAttribute} z.record(z.any())${schemaRequired}`,\n typeString: `${typeAttribute} Record<string, any>${typeNullishability}`\n }\n }\n\n if (type === 'integer' || type === 'number') {\n const effectiveType = getZodNumberType(type)\n return {\n schemaString: `${schemaAttribute} z.${effectiveType.schemaString}()${schemaRequired}`,\n typeString: `${typeAttribute} ${effectiveType.typeString}${typeNullishability}`\n }\n }\n\n if (type === 'array') {\n const items = definition.items\n const ref = items?.$ref\n let model: ResultType\n if (ref) {\n const refType = ParserUtils.parseRefType(ref)\n this.importClasses.add(refType)\n\n model = {\n schemaString: refType,\n typeString: refType\n }\n } else if (items) {\n if (items.type === 'array') {\n const ref = items.items?.$ref\n if (ref) {\n const refType = ParserUtils.parseRefType(ref)\n this.importClasses.add(refType)\n\n model = {\n schemaString: refType,\n typeString: refType\n }\n } else if (items.items) {\n model = this.parseEnumItems(items.items)\n }\n return {\n schemaString: `${schemaAttribute} z.array(z.array(${model.schemaString}))${schemaRequired}`,\n typeString: `${typeAttribute} ${model.typeString}[]${typeNullishability}`\n }\n } else {\n model = this.parseEnumItems(items)\n }\n } else {\n return {\n schemaString: `${schemaAttribute} z.array(z.any())${schemaRequired}`,\n typeString: `${typeAttribute} any[]${typeNullishability}`\n }\n }\n return {\n schemaString: `${schemaAttribute} z.array(${model.schemaString})${schemaRequired}`,\n typeString: `${typeAttribute} ${model.typeString}[]${typeNullishability}`\n }\n }\n\n if (type !== 'object') {\n const result = extractEnumObject(type, isRequired, definition.enum)\n return {\n schemaString: `${schemaAttribute} ${result.schemaString}`,\n typeString: `${typeAttribute} ${result.typeString}`\n }\n }\n }\n\n const ref = definition.$ref\n let model = `z.record(z.any())`\n\n if (ref) {\n model = ParserUtils.parseRefType(ref)\n\n const fullModelName = ref.replace('#/definitions/', '')\n this.duplicateFound = this.duplicates.has(fullModelName)\n if (this.duplicateFound) {\n model = this.duplicates.get(fullModelName)\n }\n this.importClasses.add(model)\n model = `${model}`\n }\n\n return {\n schemaString: `${schemaAttribute} ${model}${schemaRequired}`,\n typeString: `${typeAttribute} ${model}${typeNullishability}`\n }\n }\n\n parseEnumItems = (items): ResultType => {\n if (items.enum) {\n const enumStr = items.enum.map(e => {\n return `\"${e}\"`\n })\n return {\n schemaString: `z.enum([${enumStr}])`,\n typeString: `(${enumStr.join(' | ')})`\n }\n }\n\n if (items.type === 'object') {\n return this.parseToZodSchema(items, items.required)\n }\n\n let effectiveType: ResultType\n if (items.type === 'integer' || items.type === 'number') {\n effectiveType = getZodNumberType(items.type)\n } else {\n effectiveType = { typeString: items.type, schemaString: items.type }\n }\n\n return {\n schemaString: `z.${effectiveType.schemaString}()`,\n typeString: effectiveType.typeString\n }\n }\n}\n\nexport class TemplateZodArray {\n //\n render = name => {\n const cls = name.replace('Array', '')\n const template = `import { z } from 'zod'\nimport { ${cls} } from './${cls}.js'\n \nexport const ${name} = z.array(${cls})\n\nexport interface ${name} extends z.TypeOf<typeof ${name}> {}\n `\n return template\n }\n}\n\nconst getZodNumberType = (type: string) => {\n // In Swagger, integer and number are different types.\n // As such, we need to map them separately.\n // Example how to use:\n //\n // if (type === 'integer' || type === 'number') return getZodNumberType(type);\n //\n // Reference 1: https://swagger.io/docs/specification/data-models/data-types/.\n // Reference 2: https://github.com/colinhacks/zod#numbers.\n if (type === 'integer') {\n return {\n schemaString: 'number().int',\n typeString: 'number'\n }\n }\n\n return {\n schemaString: type,\n typeString: type\n }\n}\n\nconst extractEnumObject = (type: string, isRequired: boolean, enumArr?: string[]): ResultType => {\n const schemaRequired = isRequired ? '' : '.nullish()'\n const typeNullishability = isRequired ? '' : ' | null | undefined'\n if (enumArr) {\n const enumStr = enumArr.map(e => {\n return `\"${e}\"`\n })\n return {\n schemaString: `z.enum([${enumStr}])${schemaRequired}`,\n typeString: `(${enumStr.join(' | ')}${typeNullishability})`\n }\n }\n return {\n schemaString: `z.${type}()${schemaRequired}`,\n typeString: `${type}${typeNullishability}`\n }\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\n\nimport { ParserUtils } from '../ParserUtils'\n\nexport const templateApiIndex = (serviceName: string, serviceNameTitle: string, apiList: string[]): string => {\n let imports = ''\n let returnStatement = ''\n for (const cl of apiList) {\n // We have to exclude AdminApi as it was the title of the section\n // in swagger, but it has public/admin version of the endpoint too\n const dir = cl.toLowerCase().includes('admin') && cl !== 'AdminApi' ? 'generated-admin' : 'generated-public'\n imports += `\\nimport { ${cl} } from './${dir}/${cl}.js'`\n returnStatement += `\\n${cl}, `\n }\n\n return `/**\n * AUTO GENERATED\n */\n${imports}\n\nconst apis = {\n${returnStatement}\n}\n\nexport const ${serviceNameTitle} = apis\n `\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport { z } from 'zod'\n\nconst Schema = z.object({\n $ref: z.string().nullish(),\n type: z\n .union([z.literal('array'), z.literal('object'), z.literal('file'), z.literal('string'), z.literal('boolean'), z.literal('integer')])\n .nullish(),\n items: z\n .object({\n $ref: z.string().nullish(),\n type: z.string().nullish()\n })\n .nullish(),\n properties: z.union([z.array(z.string()).nullish(), z.record(z.object({ type: z.string() })).nullish()]),\n description: z.string().nullish(),\n additionalProperties: z\n .object({\n type: z.string().nullish()\n })\n .nullish()\n})\n\nexport type Schema = z.TypeOf<typeof Schema>\n\nexport const Definition = z.object({\n required: z.array(z.string()).nullish(),\n properties: z\n .record(\n z.object({\n type: z.string()\n })\n )\n .nullish()\n})\n\nexport type Definition = z.TypeOf<typeof Definition>\n\nexport const Definitions = z.record(Definition)\n\nexport type Definitions = z.TypeOf<typeof Definitions>\n\nconst EndpointParametersType = z.enum(['apiKey', 'boolean', 'int', 'integer', 'number', 'string', 'array', 'file'])\nconst EndpointParametersIn = z.enum(['body', 'formData', 'header', 'path', 'query'])\n\nconst EndpointParameters = z.object({\n type: EndpointParametersType.nullish(),\n description: z.string().nullish(),\n name: z.string(),\n in: EndpointParametersIn,\n required: z.boolean().nullish(),\n schema: Schema.nullish(),\n default: z.union([z.boolean(), z.string(), z.number(), z.array(z.any())]).nullish(),\n enum: z.array(z.union([z.boolean(), z.string(), z.number()])).nullish(),\n items: z\n .object({\n type: z.string(),\n enum: z.array(z.any()).nullish()\n })\n .nullish()\n})\n\nexport type EndpointParameters = z.TypeOf<typeof EndpointParameters>\n\nexport const Endpoint = z.object({\n description: z.string().nullish(),\n consumes: z.array(z.string()).nullish(),\n produces: z.array(z.string()).nullish(),\n tags: z.array(z.string()).nullish(),\n summary: z.string().nullish(),\n operationId: z.string(),\n deprecated: z.boolean().nullish(),\n responses: z.record(\n z.object({\n description: z.string().nullish(),\n schema: Schema.nullish(),\n content: z\n .object({\n 'application/json': z.object({\n schema: Schema.nullish()\n })\n })\n .nullish()\n })\n ),\n parameters: z.array(EndpointParameters).nullish(),\n requestBody: z\n .object({\n required: z.boolean().nullish(),\n content: z\n .object({\n 'application/json': z\n .object({\n schema: Schema.nullish()\n })\n .nullish()\n })\n .nullish()\n })\n .nullish(),\n // The proper type is z.array(z.record(z.array(z.string()))).nullish() but somehow there are endpoints with\n // an object type instead of an array type, so, yeah.\n //\n // Services with this error: sdk-iam, sdk-ugc.\n 'x-security': z.any().nullish()\n})\nexport type Endpoint = z.TypeOf<typeof Endpoint>\n\nconst Operation = z.object({\n get: Endpoint.nullish(),\n post: Endpoint.nullish(),\n patch: Endpoint.nullish(),\n delete: Endpoint.nullish(),\n put: Endpoint.nullish()\n})\nexport type Operation = z.TypeOf<typeof Operation>\nexport type HttpMethod = keyof Operation\n\nexport const Paths = z.record(Operation)\n\nexport const OpenApiSpec = z.object({\n paths: Paths,\n definitions: Definitions,\n basePath: z.string(),\n info: z.object({\n description: z.string(),\n title: z.string(),\n contact: z.object({\n name: z.string(),\n url: z.string(),\n email: z.string()\n }),\n version: z.string()\n }),\n schemes: z.array(z.string()).nullish(),\n components: z\n .object({\n schemas: Definitions\n })\n .nullish()\n})\n\nexport type OpenApiSpec = z.TypeOf<typeof OpenApiSpec>\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport { ParserUtils } from '../ParserUtils'\nimport { EndpointParameters } from '../Swagger'\n\nexport const templateMethod = ({\n classMethod,\n description,\n httpMethod,\n path,\n pathParams,\n bodyParams,\n queryParams,\n isFormUrlEncoded,\n responseClass,\n deprecated\n}: {\n classMethod: string\n description: string\n httpMethod: string\n path: string\n pathParams: EndpointParameters[]\n bodyParams: EndpointParameters[]\n queryParams: EndpointParameters[]\n isFormUrlEncoded: boolean\n responseClass: string\n deprecated: boolean\n}) => {\n let methodParams = ''\n let methodParamsNoTypes = ''\n let newPath = `'${path}'`\n let importStatements: string[] = []\n\n const sortedPathParams = ParserUtils.sortPathParamsByPath(pathParams, path)\n for (const pathParam of sortedPathParams) {\n const type = ParserUtils.parseType(pathParam)\n if (pathParam.name !== 'namespace') {\n methodParams += pathParam.name + `:${type}` + ', '\n methodParamsNoTypes += pathParam.name + ', '\n }\n const pName = pathParam.name === 'namespace' ? 'this.namespace' : pathParam.name\n if (path.match(`{${pathParam.name}}`)) {\n if (type === 'string') {\n newPath = `${newPath}.replace('{${pathParam.name}}', ${pName})`\n } else {\n newPath = `${newPath}.replace('{${pathParam.name}}', String(${pName}))`\n }\n }\n }\n\n let dataType = null\n if (httpMethod !== 'get') {\n dataType = ParserUtils.parseBodyParamsType(bodyParams)\n importStatements = ParserUtils.parseBodyParamsImports(bodyParams)\n methodParams += dataType ? `data: ${dataType},` : ''\n methodParamsNoTypes += dataType ? `data,` : ''\n }\n\n const isAnyRequired = ParserUtils.isAnyQueryParamRequired(queryParams)\n const queryParamsType = queryParams.length\n ? `queryParams${isAnyRequired ? '' : '?'}: {${ParserUtils.parseQueryParamsType(queryParams)}}`\n : ''\n\n const queryParamsDefault = queryParams.length\n ? `const params = {${ParserUtils.parseQueryParamsDefault(queryParams)} ...queryParams} as SDKRequestConfig`\n : 'const params = {} as SDKRequestConfig'\n\n const isPostPutPatch = ['post', 'put', 'patch'].includes(httpMethod)\n const isDelete = ['delete'].includes(httpMethod)\n let dataPayload = '{params}'\n\n const descriptionText = description\n ? `\n /**${deprecated ? '\\n * @deprecated' : ''}\n * ${description.replace(/\\n/g, '\\n * ')} \n */`\n : ''\n\n let formPayloadString = ''\n if (isFormUrlEncoded) {\n formPayloadString = ``\n const params = \"{ ...params, headers: { ...params.headers, 'content-type': 'application/x-www-form-urlencoded' } }\"\n\n dataPayload = dataType ? `CodeGenUtil.getFormUrlEncodedData(data), ${params}` : `null, ${params}`\n } else if (isPostPutPatch) {\n dataPayload = dataType ? `data, {params}` : 'null, {params}'\n } else if (isDelete) {\n dataPayload = dataType ? `{data, params}` : '{params}'\n }\n const isFileUpload = methodParams.indexOf('data: {file') > -1\n\n const resolvedResponseClass = responseClass || 'unknown'\n const resolvedResponseClassValidated = responseClass || 'z.unknown()'\n methodParams = (queryParamsType ? `${methodParams} ${queryParamsType}` : methodParams).replace(/,\\s*$/, '')\n methodParamsNoTypes = queryParamsType ? `${methodParamsNoTypes} queryParams` : methodParamsNoTypes\n\n let methodImpl = ''\n ? `/**\n * @deprecated Use \"${classMethod}()\" instead.\n */`\n : ''\n\n const isGuardInvoked = ['get', 'post', 'put', 'patch', 'delete'].includes(httpMethod)\n const responseType = resolvedResponseClass !== 'unknown' ? `${resolvedResponseClass}` : 'unknown'\n\n const generateMethodName = () => `${classMethod}(${methodParams}): Promise<${responseSyncType}<${responseType}>>`\n\n const responseSyncType = 'IResponse'\n methodImpl = `${descriptionText}\n ${generateMethodName()} {\n ${queryParamsDefault}\n const url = ${newPath} ${formPayloadString} ${isFileUpload ? '\\n// TODO file upload not implemented' : ''}\n const resultPromise = this.axiosInstance.${httpMethod}(url, ${dataPayload})\n\n${` return Validate.validateOrReturnResponse(this.useSchemaValidation, () => resultPromise, ${resolvedResponseClassValidated}, '${resolvedResponseClassValidated}')`}\n }\n `\n\n if (!isGuardInvoked) {\n methodImpl = ``\n }\n\n const res = {\n methodImpl,\n methodParams,\n methodParamsNoTypes,\n importStatements\n }\n return res\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport { ParserUtils } from '../ParserUtils'\nimport { EndpointParameters } from '../Swagger'\n\nexport const templateApiMethod = ({\n classMethod,\n description,\n httpMethod,\n path,\n pathParams,\n bodyParams,\n responseClass,\n classGenName,\n methodParams,\n methodParamsNoTypes,\n deprecated,\n xSecurity\n}: {\n classMethod: string\n description: string\n httpMethod: string\n path: string\n pathParams: EndpointParameters[]\n bodyParams: EndpointParameters[]\n responseClass: string\n classGenName: string\n methodParams: string\n methodParamsNoTypes: string\n deprecated: boolean\n // Reference: https://accelbyte.atlassian.net/wiki/spaces/CW/pages/2991423677/Draft+Swagger+validation+for+API+explorer+content+proposal.\n // Endpoint with `x-security` means it requires authentication.\n xSecurity: Array<Record<string, string[]>> | undefined\n}) => {\n let newPath = `'${path}'`\n let snippetMethod = ''\n\n for (const pathParam of pathParams) {\n const type = ParserUtils.parseType(pathParam)\n const pName = pathParam.name === 'namespace' ? 'this.namespace' : pathParam.name\n if (path.match(`{${pathParam.name}}`)) {\n if (type === 'string') {\n newPath = `${newPath}.replace('{${pathParam.name}}', ${pName})`\n } else {\n newPath = `${newPath}.replace('{${pathParam.name}}', String(${pName}))`\n }\n }\n }\n\n const snippetShellArgs: string[] = ['--location --request', `${httpMethod} '__DOMAIN__${path}'`, \"--header 'accept: application/json'\"]\n const snippetApiArgs: string[] = []\n\n // Admin paths _usually_ always require authentication.\n // If it's public, then it can't be helped, we need to rely on `x-security` that's provided from the domain service teams.\n if (xSecurity !== undefined || path.includes('/admin')) {\n snippetShellArgs.push(\"--header 'Authorization: Bearer {access_token}'\")\n snippetApiArgs.push(\"{ config: { headers: { Authorization: 'Bearer {access_token}' } }}\".trim())\n }\n\n if (httpMethod !== 'get') {\n const curlParams = bodyParams?.map(ob => {\n return ` \"${ob.name}\": \"\"`\n })\n\n // Prevent sending `--data-raw` in case of `DELETE` method without body.\n if (curlParams.length > 0) {\n snippetShellArgs.push(`--data-raw '{ ${curlParams}}'`)\n }\n }\n\n const snippetShell = `curl ${snippetShellArgs.join(' \\\\\\n ')}`\n\n const descriptionText = description\n ? `\n /**${deprecated ? '\\n * @deprecated' : ''}\n * ${description.replace(/\\n/g, '\\n * ')} \n */`\n : ''\n\n const resolvedResponseClass = responseClass || 'unknown'\n const responseType = resolvedResponseClass !== 'unknown' ? `${resolvedResponseClass}` : 'unknown'\n\n const methodImpl = `\n ${descriptionText}\n async function ${classMethod}(${methodParams}): Promise<${responseType}> {\n const $ = new ${classGenName}(Network.create(requestConfig), namespace, useSchemaValidation)\n const resp = await $.${classMethod}(${methodParamsNoTypes})\n if (resp.error) throw resp.error\n return resp.response.data\n }\n `\n const snippetPromiseString = responseType !== 'unknown' ? `Promise<${responseType}>` : 'Promise'\n snippetMethod += `${classMethod}(${methodParams}) \\n // return ${snippetPromiseString}`\n\n return {\n generatedMethodString: methodImpl,\n snippetApiArgs,\n snippetMethod,\n snippetShell\n }\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport { ParserUtils } from '../ParserUtils'\n\nexport const templateSdkSnippet = ({\n serviceNameTitle,\n apiName,\n snippetMethod,\n snippetApiArgs: snippetApiArgsParam\n}: {\n serviceNameTitle: string\n apiName: string\n snippetMethod: string\n snippetApiArgs: string[]\n}) => {\n const methodArr = snippetMethod.split('//')\n const snippetApiArgs = ['sdk', ...snippetApiArgsParam]\n\n let normMethod = normalizeMethodSnippet(methodArr[0].trim(), 'data:')\n normMethod = normalizeMethodSnippet(normMethod, 'queryParams:')\n normMethod = normalizeMethodSnippet(normMethod, 'queryParams?:')\n normMethod += '\\n\\n//' + methodArr[1]\n\n const sdkSnippet = `import { Accelbyte } from '@accelbyte/sdk'\nimport { ${serviceNameTitle} } from '@accelbyte/sdk-${serviceNameTitle.toLowerCase()}'\n\nconst sdk = Accelbyte.SDK({\n options: {\n baseURL: 'https://demo.accelbyte.io',\n clientId: '77f88506b6174c3ea4d925f5b4096ce8',\n namespace: 'accelbyte',\n redirectURI: 'http://localhost:3030'\n }\n})\n\n${serviceNameTitle}.${apiName}(${snippetApiArgs.join(', ')})\n .${normMethod}`\n return sdkSnippet\n}\n\nconst normalizeMethodSnippet = (methodInput: any, splitWord: string) => {\n const split1 = methodInput.split(splitWord)\n if (!split1[1]) {\n return methodInput\n }\n let split2 = split1[1].trim()\n split2 = ParserUtils.replaceAll(split2, '{', '')\n split2 = ParserUtils.replaceAll(split2, '})', '')\n split2 = split2.split(',')\n let params = ''\n split2.forEach(p => {\n params += '\\n ' + ParserUtils.replaceAll(p.trim(), ')', '') + ','\n })\n params = params.slice(0, -1) // remove last , char\n\n const result = split1[0] + splitWord + ' {' + params + '\\n })'\n return result\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport { ParserUtils } from '../ParserUtils'\nimport { EndpointParameters } from './../Swagger'\n\nexport const templateQueryMethod = ({\n classMethod,\n httpMethod,\n path,\n pathParams,\n responseClass,\n methodParams,\n apiGenName,\n isFormUrlEncoded,\n deprecated\n}: {\n classMethod: string\n httpMethod: string\n path: string\n pathParams: EndpointParameters[]\n responseClass: string\n methodParams: string\n apiGenName: string\n isFormUrlEncoded: boolean\n deprecated: boolean\n}) => {\n // skip method generation for \"Post x-www-form-urlencoded\" or @deprecated\n if (isFormUrlEncoded || deprecated) {\n return ''\n }\n const isPostFetch = httpMethod === 'post' && (path.includes('/table-query/') || path.endsWith('/list'))\n\n const isAdmin = path.indexOf('/admin/') > 0\n const isGet = httpMethod === 'get' || isPostFetch\n\n let queryMethod = isGet ? 'useQuery' : 'useMutation'\n let mParams = ''\n let mParamsNoTypes = ''\n let newPath = `'${path}'`\n\n const sortedPathParams = ParserUtils.sortPathParamsByPath(pathParams, path)\n for (const pathParam of sortedPathParams) {\n const type = ParserUtils.parseType(pathParam)\n if (pathParam.name !== 'namespace') {\n mParams += pathParam.name + `:${type}` + ', '\n mParamsNoTypes += pathParam.name + ', '\n }\n const pName = pathParam.name === 'namespace' ? 'this.namespace' : pathParam.name\n if (path.match(`{${pathParam.name}}`)) {\n if (type === 'string') {\n newPath = `${newPath}.replace('{${pathParam.name}}', ${pName})`\n } else {\n newPath = `${newPath}.replace('{${pathParam.name}}', String(${pName}))`\n }\n }\n }\n\n const resolvedResponseClass = responseClass || 'unknown'\n\n let _methodName = convertMethodName(classMethod, isPostFetch)\n _methodName = isAdmin ? _methodName.replace('use', 'useAdm') : _methodName\n const _responseType = resolvedResponseClass !== 'unknown' ? `${resolvedResponseClass}` : 'unknown'\n const _methodParams = methodParams && methodParams.length > 0 ? `& { ${methodParams} }` : ''\n const _methodParamsImpl = convertToMethodImplArgs(methodParams)\n\n const queryMethodImpl = `\\n\nexport const ${_methodName} = (\n sdk: AccelbyteSDK,\n input: ApiArgs ${_methodParams},\n options?: Omit<UseQueryOptions<${_responseType}, AxiosError<ApiError>>, 'queryKey'>,\n callback?: (data: ${_responseType}) => void\n ): UseQueryResult<${_responseType}, AxiosError<ApiError>> => { \n //\n const queryFn = (\n sdk: AccelbyteSDK, \n input: Parameters<typeof ${_methodName}>[1]\n ) => async () => {\n const data = \n (await ${apiGenName}(sdk, { namespace: input.namespace }).\n ${classMethod}(${_methodParamsImpl}))\n callback && callback(data)\n return data\n }\n \n return ${queryMethod}<${_responseType}, AxiosError<ApiError>>({\n queryKey: [${createQueryKey(apiGenName, classMethod)}, input],\n queryFn: queryFn(sdk, input),\n ...options\n })\n}\\n \n `\n\n const mutationMethodImpl = `\\n\nexport const ${_methodName} = (\n sdk: AccelbyteSDK,\n options?: Omit<UseMutationOptions<${_responseType}, AxiosError<ApiError>, ApiArgs ${_methodParams}>, 'mutationKey'>,\n callback?: (data: ${_responseType}) => void\n ): UseMutationResult<${_responseType}, AxiosError<ApiError>, ApiArgs ${_methodParams}> => { \n //\n const mutationFn = async (input: ApiArgs ${_methodParams}) => {\n const data = \n (await ${apiGenName}(sdk, { namespace: input.namespace, config: input.config }).\n ${classMethod}(${_methodParamsImpl}))\n callback && callback(data)\n return data\n }\n \n return useMutation({\n mutationKey: [${createQueryKey(apiGenName, classMethod)}],\n mutationFn,\n ...options\n })\n}\\n \n `\n\n return isGet ? queryMethodImpl : mutationMethodImpl\n}\n\n/*\n * Converts \"SomethingApi.get|post|etcWhatever\" to \"Something.Whatever\"\n */\nfunction createQueryKey(className, methodName) {\n // skip @deprecated\n if (methodName.indexOf('_DEPRECATED') > 0) {\n return ''\n }\n const prefixRegex = /^(get|create|update|delete|patch)[_]?/i\n const cleanedMethodName = methodName.replace(prefixRegex, '').trim()\n const finalMethodName = cleanedMethodName.charAt(0).toUpperCase() + cleanedMethodName.slice(1)\n return `Key_${className.replace('Api', '')}.${finalMethodName}`\n}\n\nconst prefixMappings = {\n get: 'use',\n create: 'useCreate',\n patch: 'usePatch',\n update: 'useUpdate',\n delete: 'useDelete'\n}\n\nfunction convertMethodName(classMethod, isPostFetch) {\n for (const [originalPrefix, newPrefix] of Object.entries(prefixMappings)) {\n if (classMethod.startsWith(originalPrefix)) {\n if (isPostFetch) {\n return classMethod.replace(originalPrefix, 'useFetch')\n }\n const newMethodName = classMethod.replace(originalPrefix, newPrefix)\n if (originalPrefix === 'get') {\n return newMethodName\n } else {\n return newMethodName + 'Mutation'\n }\n }\n }\n return classMethod\n}\n\n/**\n * Converts \"data: UpgradeHeadlessAccountV3Request, queryParams?: etc\"\n * To: \"input.data, input.queryParams\"\n */\nfunction convertToMethodImplArgs(methodArgs) {\n // Split the input string on commas to separate each property\n let properties = methodArgs\n .split(/,\\s*(?![^{}]*\\})/)\n .map(prop => prop.trim())\n .filter(Boolean)\n\n // Initialize an array to hold the formatted properties\n let formattedProperties = []\n\n // Process each property\n properties.forEach(prop => {\n // Check if the property includes an object (detecting a colon followed by a curly brace)\n if (prop.includes(': {')) {\n // Extract the property name, considering optional '?'\n const propertyName = prop.split(': {')[0].replace('?', '').trim()\n formattedProperties.push(`input.${propertyName}`)\n } else {\n // Regular property (no object)\n const colonIndex = prop.indexOf(':')\n const propertyName = prop.substring(0, colonIndex).replace('?', '').trim()\n formattedProperties.push(`input.${propertyName}`)\n }\n })\n\n // Join the formatted property names with ', '\n return formattedProperties.join(', ')\n}\n","/*\n * Copyright (c) 2023-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\n\nimport { ParserUtils } from '../ParserUtils'\nimport { Endpoint, OpenApiSpec } from '../Swagger'\nimport { templateMethod } from '../templates/template-method'\nimport { templateApiMethod } from '../templates/template-api-method'\nimport { templateSdkSnippet } from '../templates/template-sdk-snippet'\nimport { templateQueryMethod } from '../templates/template-query-method'\n\nconst GIT_URL = 'https://github.com/AccelByte/accelbyte-web-sdk/blob/main/packages'\n\nexport type Methods = 'get' | 'post' | 'put' | 'delete' | 'patch'\ntype SnippetMap = {\n [K in Methods]?: {\n web?: string\n webGit?: string\n shell?: string\n }\n}\n\ninterface Result {\n // 'Users V4': 'createUserInvite,createUser,patchUserMe,createTestUser,updateUserMeEmail,deleteUserMeMfaDevice,getUsersMeMfaFactor,postUserMeMfaFactor,getUsersMeMfaBackupCode,createUserMeMfaBackupCode,createUserMeMfaEmailCode,createUserMeHeadlesVerify,postUserMeMfaEmailEnable,createUserMeMfaEmailDisable,createUserInvite_ByInvitationId,createUserMeHeadlesCodeVerify,createUserMeMfaAuthenticatorKey,createUserMeMfaBackupCodeEnable,deleteUserMeMfaBackupCodeDisable,getUsersMeMfaBackupCodeDownload,postUserMeMfaAuthenticatorEnable,deleteUserMeMfaAuthenticatorDisable,'\n tagToSdkFunctionNamesRecord: Record<string, string>\n // 'Users V4': '\\n' +\n // ' \\n' +\n // ' /**\\n' +\n // ' * This endpoint is used to invite a game studio admin user with new namespace in multi tenant mode. It will return error if the service multi tenant mode is set to false. Request body details: - emailAddress: email address of the user to be invited - namespace: new namespace of the user to be created - namespaceDisplayName: display name of the new namespace The invited users will also be assigned with "User" role by default. \\n' +\n // ' */\\n' +\n // ' async function createUserInvite(data: PublicInviteUserRequestV4): Promise<InviteUserResponseV3> {\\n' +\n // ' const $ = new UsersV4$(Network.create(requestConfig), namespace, useSchemaValidation)\\n' +\n // ' const resp = await $.createUserInvite(data,)\\n' +\n // ' if (resp.error) throw resp.error\\n' +\n // ' return resp.response.data\\n' +\n // ' }\\n' +\n // ' \\n' +\n // ' \\n' +\n // ' /**\\n' +\n tagToSdkClientRecord: Record<string, string>\n // 'Users V4': '\\n' +\n // ' /**\\n' +\n // ' * This endpoint is used to invite a game studio admin user with new namespace in multi tenant mode. It will return error if the service multi tenant mode is set to false. Request body details: - emailAddress: email address of the user to be invited - namespace: new namespace of the user to be created - namespaceDisplayName: display name of the new namespace The invited users will also be assigned with "User" role by default. \\n' +\n // ' */\\n' +\n // ' createUserInvite(data: PublicInviteUserRequestV4): Promise<IResponse<InviteUserResponseV3>> {\\n' +\n // ' const params = {} as SDKRequestConfig\\n' +\n // \" const url = '/iam/v4/public/users/invite' \\n\" +\n // ' const resultPromise = this.axiosInstance.post(url, data, {params})\\n' +\n // '\\n' +\n // \" return Validate.responseType(() => resultPromise, InviteUserResponseV3, 'InviteUserResponseV3')\\n\" +\n // ' }\\n' +\n // ' \\n' +\n // ' /**\\n'\n tagToEndpointClassesRecord: Record<string, string>\n // For example:\n // 'Users V4': [\n // \"import { UpgradeHeadlessAccountWithVerificationCodeRequestV4 } from '../definitions/UpgradeHeadlessAccountWithVerificationCodeRequestV4.js'\",\n // \"import { UserCreateFromInvitationRequestV4 } from '../definitions/UserCreateFromInvitationRequestV4.js'\",\n // \"import { UpgradeHeadlessAccountRequestV4 } from '../definitions/UpgradeHeadlessAccountRequestV4.js'\",\n // \"import { EmailUpdateRequestV4 } from '../definitions/EmailUpdateRequestV4.js'\",\n // \"import { CreateTestUserRequestV4 } from '../definitions/CreateTestUserRequestV4.js'\",\n // \"import { UserUpdateRequestV3 } from '../definitions/UserUpdateRequestV3.js'\",\n // \"import { CreateUserRequestV4 } from '../definitions/CreateUserRequestV4.js'\",\n // \"import { PublicInviteUserRequestV4 } from '../definitions/PublicInviteUserRequestV4.js'\"\n // ]\n tagToSdkImportsRecord: Record<string, string[]>\n // UsersV4: {\n // InviteUserResponseV3: \"import { InviteUserResponseV3 } from '../definitions/InviteUserResponseV3.js'\",\n // CreateUserResponseV4: \"import { CreateUserResponseV4 } from '../definitions/CreateUserResponseV4.js'\",\n // UserResponseV3: \"import { UserResponseV3 } from '../definitions/UserResponseV3.js'\",\n // EnabledFactorsResponseV4: \"import { EnabledFactorsResponseV4 } from '../definitions/EnabledFactorsResponseV4.js'\",\n // BackupCodesResponseV4: \"import { BackupCodesResponseV4 } from '../definitions/BackupCodesResponseV4.js'\",\n // UserResponseV4: \"import { UserResponseV4 } from '../definitions/UserResponseV4.js'\",\n // AuthenticatorKeyResponseV4: \"import { AuthenticatorKeyResponseV4 } from '../definitions/AuthenticatorKeyResponseV4.js'\"\n // }\n tagToClassImportsRecord: Record<string, Record<string, string>>\n // [ 'PublicThirdPartyPlatformInfoArray', 'GetUserMappingV3Array' ].\n arrayDefinitions: string[]\n // {\n // '/some/path': {\n // web: '',\n // shell: '',\n // webGit: ''\n // }\n // }\n snippetMap: Record<string, SnippetMap>\n tagToEndpointQueryRecord: Record<string, string>\n}\n\nexport class SwaggerReaderHelpers {\n private static getServicePrefix = (servicePaths: string[]) => servicePaths[servicePaths.length - 1].split('/')[1]\n\n static parseAllEndpoints = async ({\n api,\n sdkName,\n serviceName\n }: {\n api: OpenApiSpec\n sdkName: string\n serviceName: string\n }): Promise<{\n admin: Result\n public: Result\n }> => {\n const result: {\n admin: Result\n public: Result\n } = {\n admin: {\n arrayDefinitions: [],\n snippetMap: {},\n tagToClassImportsRecord: {},\n tagToEndpointClassesRecord: {},\n tagToSdkClientRecord: {},\n tagToSdkFunctionNamesRecord: {},\n tagToSdkImportsRecord: {},\n tagToEndpointQueryRecord: {}\n },\n public: {\n arrayDefinitions: [],\n snippetMap: {},\n tagToClassImportsRecord: {},\n tagToEndpointClassesRecord: {},\n tagToSdkClientRecord: {},\n tagToSdkFunctionNamesRecord: {},\n tagToSdkImportsRecord: {},\n tagToEndpointQueryRecord: {}\n }\n }\n\n const sortedPathsByLength = new Map(\n Object.entries(api.paths).sort((a, b) => {\n if (a[0].length === b[0].length) {\n return a[0].localeCompare(b[0])\n } else {\n return a[0].length - b[0].length\n }\n })\n )\n const sortedKeys = Array.from(sortedPathsByLength.keys())\n const servicePrefix = SwaggerReaderHelpers.getServicePrefix(sortedKeys)\n\n // This is to detect multiple naming conflicts, so we can append it with something else.\n const tagToClassMethodsMap: {\n admin: Record<string, Record<string, string>>\n public: Record<string, Record<string, string>>\n } = {\n admin: {},\n public: {}\n }\n\n for (const [path, operation] of sortedPathsByLength) {\n if (path.indexOf('/healthz') >= 0) {\n continue\n }\n\n const isAdminEndpoint = path.indexOf('/admin/') > -1\n\n const picked = isAdminEndpoint ? result.admin : result.public\n const {\n arrayDefinitions,\n snippetMap,\n tagToClassImportsRecord,\n tagToEndpointClassesRecord,\n tagToSdkClientRecord,\n tagToSdkFunctionNamesRecord,\n tagToSdkImportsRecord,\n tagToEndpointQueryRecord\n } = picked\n\n const tagToClassMethodsMapByType = isAdminEndpoint ? tagToClassMethodsMap.admin : tagToClassMethodsMap.public\n const generatedMethods = {} // { path_get: 'fetchSomething' }\n\n const httpMethods = Object.keys(operation)\n for (const httpMethod of httpMethods) {\n const endpoint = await Endpoint.parseAsync(operation[httpMethod]).catch(error => {\n console.error(JSON.stringify({ path, httpMethod }, null, 2))\n throw error\n })\n if (!endpoint.tags) continue\n\n const [tag] = endpoint.tags\n const pathWithBase = `${api.basePath ?? ''}${path}`\n\n tagToClassMethodsMapByType[tag] = tagToClassMethodsMapByType[tag] ? tagToClassMethodsMapByType[tag] : {}\n const isForm = endpoint.consumes && endpoint.consumes[0] === 'application/x-www-form-urlencoded'\n const classMethod = ParserUtils.generateNaturalLangMethod({\n servicePrefix,\n path,\n httpMethod,\n isForm,\n existingMethods: tagToClassMethodsMapByType[tag]\n })\n tagToClassMethodsMapByType[tag][classMethod] = `${path} ${httpMethod}`\n generatedMethods[`${path} ${httpMethod}`] = `${classMethod}`\n\n if (!snippetMap[pathWithBase]) {\n // Initialize, if undefined.\n snippetMap[pathWithBase] = {}\n }\n\n const description = endpoint.description?.replace(/\\s+/g, ' ') || ''\n\n const responseClass = ParserUtils.get2xxResponse(endpoint.responses)\n const { className, classGenName } = ParserUtils.generateClassName(tag, isAdminEndpoint)\n tagToClassImportsRecord[className] = tagToClassImportsRecord[className] ? tagToClassImportsRecord[className] : {}\n if (responseClass) {\n const importTypeClass = ParserUtils.parseRefType(responseClass)\n tagToClassImportsRecord[className][\n importTypeClass\n ] = `import { ${importTypeClass} } from '../../generated-definitions/${importTypeClass}.js'`\n }\n if (responseClass && responseClass.endsWith('Array')) {\n arrayDefinitions.push(responseClass)\n }\n\n const queryParams = ParserUtils.filterQueryParameters(endpoint.parameters)\n const isFormUrlEncoded = ParserUtils.isFormUrlEncoded(httpMethod, endpoint.consumes)\n const pathParams = ParserUtils.filterPathParams(endpoint.parameters)\n let bodyParams = ParserUtils.filterBodyParams(endpoint.parameters)\n const deprecated = !!endpoint.deprecated\n\n // Handling requestBody in swagger v3 `templateMethod` expect `bodyParams` to be array, so for now we convert\n // requestBody format to array params\n if (endpoint.requestBody) {\n bodyParams = [\n {\n name: 'body',\n in: 'body',\n schema: endpoint.requestBody.content['application/json']?.schema\n }\n ]\n }\n\n // -- classes\n const { methodImpl, methodParams, methodParamsNoTypes, importStatements } = templateMethod({\n classMethod: ParserUtils.addDeprecatedSuffix(deprecated, classMethod),\n description,\n httpMethod,\n path: pathWithBase,\n pathParams,\n bodyParams,\n queryParams,\n isFormUrlEncoded,\n responseClass,\n deprecated\n })\n\n tagToEndpointClassesRecord[tag] = (tagToEndpointClassesRecord[tag] || '') + methodImpl\n const { apiGenName } = ParserUtils.generateApiName(tag, isAdminEndpoint)\n const queryMethodImpl = templateQueryMethod({\n classMethod: ParserUtils.addDeprecatedSuffix(deprecated, classMethod),\n httpMethod,\n path: pathWithBase,\n pathParams,\n responseClass,\n methodParams,\n apiGenName,\n isFormUrlEncoded,\n deprecated\n })\n tagToEndpointQueryRecord[tag] = (tagToEndpointQueryRecord[tag] || '') + queryMethodImpl\n\n // -- apis\n const { generatedMethodString, snippetApiArgs, snippetMethod, snippetShell } = templateApiMethod({\n classMethod: ParserUtils.addDeprecatedSuffix(deprecated, classMethod),\n description,\n httpMethod,\n path: pathWithBase,\n pathParams,\n bodyParams,\n responseClass,\n classGenName,\n methodParams,\n methodParamsNoTypes,\n deprecated,\n xSecurity: endpoint['x-security']\n })\n tagToSdkClientRecord[tag] = (tagToSdkClientRecord[tag] || '') + generatedMethodString\n tagToSdkFunctionNamesRecord[tag] =\n (tagToSdkFunctionNamesRecord[tag] || '') + ParserUtils.addDeprecatedSuffix(deprecated, classMethod) + ','\n\n // -- dependencies\n tagToSdkImportsRecord[tag] = tagToSdkImportsRecord[tag]\n ? [...new Set([...importStatements, ...tagToSdkImportsRecord[tag]])]\n : [...new Set(importStatements)]\n\n const serviceNameTitle = ParserUtils.convertDashesToTitleCase(serviceName)\n const resultSnippet = templateSdkSnippet({\n serviceNameTitle,\n apiName: apiGenName,\n snippetMethod,\n snippetApiArgs\n })\n\n // -- snippets\n const currentSnippetMap: SnippetMap[Methods] = {}\n snippetMap[pathWithBase][httpMethod as Methods] = currentSnippetMap\n currentSnippetMap.web = resultSnippet\n const generatedDirName = isAdminEndpoint ? 'generated-admin' : 'generated-public'\n currentSnippetMap.webGit = GIT_URL + `/sdk-${sdkName}/src/${generatedDirName}/${apiGenName}.ts`\n // Put this last to preserve the previous order.\n currentSnippetMap.shell = snippetShell\n }\n }\n\n for (const key in result) {\n // De-duplicate.\n result[key as keyof typeof result].arrayDefinitions = Array.from(new Set(result[key as keyof typeof result].arrayDefinitions))\n }\n\n return result\n }\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport SwaggerParser from '@apidevtools/swagger-parser'\nimport fs from 'fs'\nimport path from 'path'\nimport { CliParser } from './CliParser'\nimport { ParserUtils } from './ParserUtils'\nimport { TemplateZod, TemplateZodArray } from './templates/template-zod'\nimport { templateApiIndex } from './templates/template-api-index'\nimport { SwaggerReaderHelpers } from './helpers/SwaggerReaderHelpers'\n\n// Patching is done in https://bitbucket.org/accelbyte/justice-codegen-sdk-spec\n\nexport class CodeGenerator {\n static srcFolder = () => CliParser.getOutputPath()\n\n static getGeneratedFolder = (isAdmin: boolean) =>\n isAdmin ? `${CodeGenerator.srcFolder()}/generated-admin` : `${CodeGenerator.srcFolder()}/generated-public`\n\n static getGeneratedSnippetsFolder = () => `${CliParser.getSnippetOutputPath()}/generated-snippets`\n\n static prepareDirs = (DIST_DEFINITION_DIR, DIST_DIR, DIST_DIR_ENDPOINTS, DIST_DIR_QUERIES) => {\n ParserUtils.mkdirIfNotExist(DIST_DEFINITION_DIR)\n ParserUtils.mkdirIfNotExist(DIST_DIR(true))\n ParserUtils.mkdirIfNotExist(DIST_DIR(false))\n ParserUtils.mkdirIfNotExist(DIST_DIR_ENDPOINTS(true))\n ParserUtils.mkdirIfNotExist(DIST_DIR_ENDPOINTS(false))\n ParserUtils.mkdirIfNotExist(DIST_DIR_QUERIES(true))\n }\n\n static main = async (nameArray: string[]): Promise<Set<string>> => {\n const serviceName = nameArray[0]\n const sdkName = nameArray[1]\n const swaggerFile = nameArray[2]\n const parser = new SwaggerParser()\n const swaggerFilePath = `${CliParser.getSwaggersOutputPath()}/${swaggerFile}`\n const api = await parser.parse(swaggerFilePath)\n const serviceNameTitle = ParserUtils.convertDashesToTitleCase(serviceName)\n\n const indexImportsSet: Set<string> = new Set()\n const apiInfo = { ...api.info, 'x-version': api['x-version']?.version }\n console.log('----------\\nGenerating API:', { title: apiInfo.title, version: apiInfo.version })\n\n ParserUtils.syncPackageVersion(apiInfo, CliParser.skipVersionSync(), process.env.PRERELEASE_ID)\n ParserUtils.writeXVersion(CodeGenerator.srcFolder(), api['x-version'], api.info)\n\n const parsedInformation = await SwaggerReaderHelpers.parseAllEndpoints({ api, sdkName, serviceName })\n\n if (CliParser.getSnippetOutputPath()) {\n try {\n ParserUtils.writeSnippetFile(\n CodeGenerator.getGeneratedSnippetsFolder(),\n api.info.title,\n JSON.stringify(\n {\n ...parsedInformation.public.snippetMap,\n ...parsedInformation.admin.snippetMap\n },\n null,\n 2\n )\n )\n } catch (err) {\n console.log('Generating snippets', err)\n }\n }\n\n const DIST_DIR = (isAdmin: boolean) => `${CodeGenerator.getGeneratedFolder(isAdmin)}`\n const DIST_DIR_ENDPOINTS = (isAdmin: boolean) => path.join(DIST_DIR(isAdmin), 'endpoints')\n const DIST_DIR_QUERIES = (isAdmin: boolean) => path.join(DIST_DIR(isAdmin), 'queries')\n const DIST_DEFINITION_DIR = path.join(CodeGenerator.srcFolder(), 'generated-definitions')\n const targetSrcFolder = `${CodeGenerator.srcFolder()}/`\n CodeGenerator.prepareDirs(DIST_DEFINITION_DIR, DIST_DIR, DIST_DIR_ENDPOINTS, DIST_DIR_QUERIES)\n\n const mainApiList = []\n const generatedDefinitions = []\n // ----\n const generatePublicOrAdmin = isAdmin => {\n const parsedInformationByType = isAdmin ? parsedInformation.admin : parsedInformation.public\n const {\n arrayDefinitions,\n tagToClassImportsRecord,\n tagToEndpointClassesRecord,\n tagToSdkClientRecord,\n tagToSdkFunctionNamesRecord,\n tagToSdkImportsRecord,\n tagToEndpointQueryRecord\n } = parsedInformationByType\n\n // creates Api And Endpoint classes\n const writeApiEndpointFiles = (isAdminEndpoint: boolean) => {\n const apiList = []\n for (const tag in tagToEndpointClassesRecord) {\n const { className, classGenName } = ParserUtils.generateClassName(tag, isAdminEndpoint)\n const classBuffer = tagToEndpointClassesRecord[tag]\n const imports = [...new Set([...tagToSdkImportsRecord[tag], ...Object.values(tagToClassImportsRecord[className])])]\n const apiImports = [...new Set([...tagToSdkImportsRecord[tag], ...Object.values(tagToClassImportsRecord[className])])]\n apiImports.push(`import { ${classGenName} } from './endpoints/${classGenName}.js'`)\n\n ParserUtils.writeClassFile(DIST_DIR_ENDPOINTS(isAdminEndpoint), classGenName, classBuffer, imports)\n const { apiGenName } = ParserUtils.generateApiName(tag, isAdminEndpoint)\n const queryBuffer = tagToEndpointQueryRecord[tag]\n\n const queryFileName = ParserUtils.writeQueryFile(DIST_DIR_QUERIES(isAdminEndpoint), apiGenName, queryBuffer, apiImports, serviceNameTitle, tagToSdkFunctionNamesRecord[tag], imports)\n\n const apiBuffer = tagToSdkClientRecord[tag]\n\n ParserUtils.writeApiFile(DIST_DIR(isAdminEndpoint), apiGenName, apiBuffer, imports, tagToSdkFunctionNamesRecord[tag])\n apiList.push(apiGenName)\n\n // For endpoint classes, we need to append `$`.\n indexImportsSet.add(\n ParserUtils.getRelativePathToWebSdkSrcFolder(path.join(DIST_DIR_ENDPOINTS(isAdminEndpoint), `${classGenName}`), targetSrcFolder)\n )\n indexImportsSet.add(\n ParserUtils.getRelativePathToWebSdkSrcFolder(path.join(DIST_DIR(isAdminEndpoint), `${apiGenName}`), targetSrcFolder)\n )\n queryFileName && indexImportsSet.add(\n ParserUtils.getRelativePathToWebSdkSrcFolder(path.join(DIST_DIR(isAdminEndpoint), 'queries', `${queryFileName}`), targetSrcFolder)\n )\n }\n mainApiList.push(...apiList)\n indexImportsSet.add(\n ParserUtils.getRelativePathToWebSdkSrcFolder(path.join(CodeGenerator.srcFolder(), serviceNameTitle), targetSrcFolder)\n )\n } // end of writeApiEndpointFiles\n\n // creates the definition files\n const writeDefinitions = api => {\n const duplicates = new Map<string, string>()\n const definitions = api?.components?.schemas || api.definitions\n for (const ref in definitions) {\n const definition = definitions[ref]\n const fileName = ParserUtils.parseRefType(ref)\n const fileExist = fs.existsSync(path.join(DIST_DEFINITION_DIR, `${fileName}.ts`))\n if (fileExist) {\n const duplicateName = ParserUtils.toCamelCaseWord(ref).replace('.', '').replace('.', '')\n duplicates.set(ref, duplicateName)\n }\n const { buffer } = new TemplateZod().render(fileName, definition, new Map())\n generatedDefinitions.push(fileName)\n ParserUtils.writeDefinitionFile(DIST_DEFINITION_DIR, fileName, buffer)\n indexImportsSet.add(ParserUtils.getRelativePathToWebSdkSrcFolder(path.join(DIST_DEFINITION_DIR, fileName), targetSrcFolder))\n }\n\n // TODO BROKEN DEFINITION, this pefix dups with Model<Name>.js causing NOT FOUND, commented out\n // rerun, find duplicates and write again the fixed dup name\n // for (const ref in definitions) {\n // const definition = definitions[ref]\n // const fileName = ParserUtils.parseRefType(ref)\n // const { buffer, duplicateFound } = new TemplateZod().render(fileName, definition, duplicates)\n // if (duplicateFound) {\n // ParserUtils.writeDefinitionFile(DIST_DEFINITION_DIR, fileName, buffer)\n // indexImportsSet.add(ParserUtils.getRelativePathToWebSdkSrcFolder(path.join(DIST_DEFINITION_DIR, fileName), targetSrcFolder))\n // }\n // }\n\n for (const arrayClass of arrayDefinitions) {\n const buffer = new TemplateZodArray().render(arrayClass)\n generatedDefinitions.push(arrayClass)\n ParserUtils.writeDefinitionFile(DIST_DEFINITION_DIR, arrayClass, buffer)\n indexImportsSet.add(ParserUtils.getRelativePathToWebSdkSrcFolder(path.join(DIST_DEFINITION_DIR, arrayClass), targetSrcFolder))\n }\n } // end of writeDefinitions\n\n writeApiEndpointFiles(isAdmin)\n writeDefinitions(api)\n }\n\n generatePublicOrAdmin(true) // create Admin classes\n generatePublicOrAdmin(false) // create Public classes\n\n const apiIndexBuff = templateApiIndex(serviceName, serviceNameTitle, mainApiList)\n ParserUtils.writeApiMainFile(CodeGenerator.srcFolder(), serviceNameTitle, apiIndexBuff)\n\n console.log('\\nCOMPLETED\\n----------\\n\\n')\n return indexImportsSet\n } // end of main\n}\n","/*\n * Copyright (c) 2018-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\nimport * as https from 'https'\nimport * as fs from 'fs'\nimport * as path from 'path'\nimport { CliParser } from './CliParser'\n\n/**\n * This file iterates over intended API configs and downloads the swagger files to target location from --swaggersOutput argument\n *\n * e.g\n * /packages\n * /od-config\n * /codegen\n * /swaggers\n * serviceName.json --> example \"iam.json\"\n */\nexport class SwaggerDownloader {\n static getDestFile = (targetFileName: string) => {\n const destPath = CliParser.getResolvedSwaggersOutputPath()\n const destFile = path.join(destPath, targetFileName)\n if (fs.existsSync(destFile)) return destFile\n if (!fs.existsSync(destPath)) fs.mkdirSync(destPath)\n fs.writeFileSync(destFile, '')\n return destFile\n }\n\n // session-api.json contains illegal URL encoded character that breaks the codegen\n // e.g. \"$ref\": \"#/definitions/map%5Bstring%5Dinterface%20%7B%7D\"\n static postSanitizeDownloadedFile = filePath => {\n const searchStr = ['%5B', '%5D', '%20', '%7B', '%7D'] // url encoded\n fs.readFile(filePath, 'utf8', (err, data) => {\n if (err) throw err\n // Replace all occurrences of the search string with the replace string\n let result = data\n searchStr.forEach(s => {\n result = result.replace(new RegExp(s, 'g'), ' ')\n })\n // Write the updated contents to the file\n fs.writeFile(filePath, result, 'utf8', err => {\n if (err) throw err\n console.log('File updated successfully.')\n })\n })\n }\n\n static downloadFile = async (targetFileName: string, url: string) => {\n const destFile = SwaggerDownloader.getDestFile(targetFileName)\n let data = ''\n\n return new Promise(resolve => {\n const request = https.get(url, function (response) {\n response.on('data', chunk => {\n data += chunk\n })\n response.on('end', () => {\n if (response.statusCode !== 200) {\n console.log(`SwaggerDownload error with status code: ${response.statusCode}`)\n } else {\n fs.writeFileSync(destFile, JSON.stringify(JSON.parse(data), null, 2), 'utf-8')\n SwaggerDownloader.postSanitizeDownloadedFile(destFile)\n console.log(`SwaggerDownload ${url} completed with status code: ${response.statusCode}`)\n }\n\n resolve(undefined)\n })\n })\n request.on('error', (err: Error) => {\n console.log(`SwaggerDownloader failed for \"${targetFileName}\" and \"${url}\"`, err)\n })\n })\n }\n\n static main = async () => {\n const swaggers = CliParser.getConfigFile()\n for (const ref in swaggers) {\n const targetFileName = swaggers[ref][2]\n const url = swaggers[ref][3]\n await SwaggerDownloader.downloadFile(targetFileName, url)\n }\n }\n}\n","/*\n * Copyright (c) 2022-2024 AccelByte Inc. All Rights Reserved\n * This is licensed software from AccelByte Inc, for limitations\n * and restrictions contact your company contract manager.\n */\n\nimport yargs from 'yargs'\nimport { CliOption, CliParser } from './CliParser'\nimport { CodeGenerator } from './CodeGenerator'\nimport path from 'path'\nimport { ParserUtils } from './ParserUtils'\nimport { SwaggerDownloader } from './SwaggerDownloader'\n\nconst generateSdk = async () => {\n const arrayOfSets = await Promise.all(CliParser.getConfigFile().map(config => CodeGenerator.main(config)))\n const indexImportsSet = new Set<string>()\n const filenamesSet = new Set<string>()\n\n for (const set of arrayOfSets) {\n set.forEach(value => {\n const fileName = path.basename(value)\n\n if (!filenamesSet.has(fileName)) {\n indexImportsSet.add(value)\n filenamesSet.add(fileName)\n }\n })\n }\n\n const indexImportsArray = Array.from(indexImportsSet).sort()\n const filesToImport = indexImportsArray.map(fileToImport => {\n return `export * from '${fileToImport.replace('\\\\', '/')}.js'`\n })\n ParserUtils.writeAllImportsFile(CliParser.getOutputPath(), filesToImport.join('\\n'))\n}\n\n// eslint-disable-next-line no-unused-expressions\nyargs\n .command('download-swaggers', 'Download swaggers JSON files', (yargs: CliOption) => {\n CliParser.createInstance(yargs)\n SwaggerDownloader.main()\n })\n .command('generate-code', 'Generate code based on downloaded swagger files', async (yargs: CliOption) => {\n // validate options\n yargs.check(({ output }) => {\n if (!output?.trim()) {\n throw new Error('output is required for generate-code')\n }\n return true\n })\n\n CliParser.createInstance(yargs)\n\n await generateSdk()\n })\n .option('config', {\n description: 'Config file providing backend services URL.',\n type: 'string',\n demandOption: true\n })\n .option('swaggersOutput', {\n description: 'Output path for downloaded swaggers JSON files.',\n type: 'string',\n demandOption: true\n })\n .option('output', {\n description: 'Output path for generated code. Required for generate-code',\n type: 'string'\n })\n .demandCommand(1)\n .help().argv\n"],"names":["fs","getImportableVarMap","makeNewImportVarMap","generateImports","path"],"mappings":"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"}
|