From ce3e1b6b0733a3566643721ca85a84b472e9ddc4 Mon Sep 17 00:00:00 2001 From: Yaroslav Grishajev Date: Tue, 14 May 2024 11:53:33 +0200 Subject: [PATCH] chore(examples): make sure create_deployment.ts example work Also update types in other examples refs akash-network/akashjs#184 --- .commitlintrc.json | 2 +- examples/README.md | 9 +++ examples/create_deployment.ts | 58 +++++++++--------- examples/details_of_single_provider.ts | 2 +- examples/estimate_gas.ts | 6 +- examples/fixtures/example.sdl.yaml | 64 ++++++++++++------- examples/get_deployments.ts | 2 +- examples/get_lease_status.ts | 2 +- examples/list_all_providers.ts | 2 +- examples/take_down_deployment.ts | 6 +- examples/tsconfig.json | 8 +++ package-lock.json | 32 ++++++++-- package.json | 85 +++++++++++++------------- tsconfig.build.json | 72 ++++++++++++++++++++++ tsconfig.json | 71 +-------------------- 15 files changed, 240 insertions(+), 181 deletions(-) create mode 100644 examples/tsconfig.json create mode 100644 tsconfig.build.json diff --git a/.commitlintrc.json b/.commitlintrc.json index 01089c7..ec0c518 100644 --- a/.commitlintrc.json +++ b/.commitlintrc.json @@ -1,6 +1,6 @@ { "extends": ["@commitlint/config-conventional"], "rules": { - "scope-enum": [2, "always", ["certificates", "network", "wallet", "api", "stargate", "sdl"]] + "scope-enum": [2, "always", ["certificates", "network", "wallet", "api", "stargate", "sdl", "examples"]] } } diff --git a/examples/README.md b/examples/README.md index 40ba30f..046dc7b 100644 --- a/examples/README.md +++ b/examples/README.md @@ -273,4 +273,13 @@ When sending transactions, it can be useful to get an estimate of the gas requir ); console.log(gas); +``` + +## Running an example + +To run an example, you need to make the required changes to the code and use typescript compiler. You can use the following command to run the example. E.g. to run the `create_deployment.ts` example: + +```bash +cd examples +ts-node -r tsconfig-paths/register create_deployment.ts ``` \ No newline at end of file diff --git a/examples/create_deployment.ts b/examples/create_deployment.ts index 4f17a90..c666500 100644 --- a/examples/create_deployment.ts +++ b/examples/create_deployment.ts @@ -1,25 +1,24 @@ import fs from "fs"; +import path from "path"; import https from "https"; - import { SigningStargateClient } from "@cosmjs/stargate"; import { DirectSecp256k1HdWallet, Registry } from "cosmwasm"; - -// these imports should point to @akashnetwork/akashjs node module in your project -import * as cert from "../build/certificates"; -import { getRpc } from "../build/rpc"; -import { SDL } from "../build/sdl"; -import { getAkashTypeRegistry } from "../build/stargate"; -import { QueryBidsRequest, QueryClientImpl as QueryMarketClient } from "../build/protobuf/akash/market/v1beta4/query"; -import { QueryClientImpl as QueryProviderClient, QueryProviderRequest } from "../build/protobuf/akash/provider/v1beta3/query"; -import { MsgCreateDeployment } from "../build/protobuf/akash/deployment/v1beta3/deploymentmsg"; -import { MsgCreateLease } from "../build/protobuf/akash/market/v1beta4/lease"; -import { BidID } from "../build/protobuf/akash/market/v1beta4/bid"; +import { MsgCreateDeployment } from "@akashnetwork/akash-api/akash/deployment/v1beta3"; +import { QueryClientImpl as QueryProviderClient, QueryProviderRequest } from "@akashnetwork/akash-api/akash/provider/v1beta3"; +import { QueryBidsRequest, QueryClientImpl as QueryMarketClient, MsgCreateLease, BidID } from "@akashnetwork/akash-api/akash/market/v1beta4"; +import * as cert from "@akashnetwork/akashjs/build/certificates"; +import { getRpc } from "@akashnetwork/akashjs/build/rpc"; +import { SDL } from "@akashnetwork/akashjs/build/sdl"; +import { getAkashTypeRegistry } from "@akashnetwork/akashjs/build/stargate"; +import { CertificatePem } from "@akashnetwork/akashjs/build/certificates/certificate-manager/CertificateManager"; +import { certificateManager } from "@akashnetwork/akashjs/build/certificates/certificate-manager"; // update this with your wallet mnemonic -const rpcEndpoint = "https://rpc.akashnet.net:443"; -const mnemonic = fs.readFileSync("./fixtures/mnemonic.txt", "utf8").trim(); -const rawSDL = fs.readFileSync("./fixtures/example.sdl.yaml", "utf8"); -const certificatePath = "./fixtures/cert.json"; +const rpcEndpoint = "https://rpc.sandbox-01.aksh.pw"; +// const rpcEndpoint = "https://rpc.akashnet.net:443"; +const mnemonic = fs.readFileSync(path.resolve(__dirname, "./fixtures/mnemonic.txt"), "utf8").trim(); +const rawSDL = fs.readFileSync(path.resolve(__dirname, "./fixtures/example.sdl.yaml"), "utf8"); +const certificatePath = path.resolve(__dirname, "./fixtures/cert.json"); type Deployment = { id: { @@ -38,12 +37,6 @@ type Lease = { }; }; -type Certificate = { - csr: string; - privateKey: string; - publicKey: string; -}; - // you can set this to a specific deployment sequence number to skip the deployment creation const dseq = 0; @@ -67,12 +60,12 @@ async function loadPrerequisites() { } // saves the certificate into the fixtures folder -function saveCertificate(certificate: { privateKey: string; publicKey: string; csr: string }) { +function saveCertificate(certificate: CertificatePem) { const json = JSON.stringify(certificate); fs.writeFileSync(certificatePath, json); } -function loadCertificate(path: string): { csr: string; privateKey: string; publicKey: string } { +function loadCertificate(path: string): CertificatePem { const json = fs.readFileSync(path, "utf8"); try { @@ -91,7 +84,7 @@ async function loadOrCreateCertificate(wallet: DirectSecp256k1HdWallet, client: } // if not, create a new one - const certificate = await cert.createCertificate(accounts[0].address); + const certificate = certificateManager.generatePEM(accounts[0].address); const result = await cert.broadcastCertificate(certificate, accounts[0].address, client); if (result.code !== undefined && result.code === 0) { @@ -104,7 +97,12 @@ async function loadOrCreateCertificate(wallet: DirectSecp256k1HdWallet, client: } async function walletFromMnemonic(mnemonic: string) { - return DirectSecp256k1HdWallet.fromMnemonic(mnemonic, { prefix: "akash" }); + try { + return await DirectSecp256k1HdWallet.fromMnemonic(mnemonic, { prefix: "akash" }); + } catch (error) { + console.error('Could not create wallet from mnemonic, have you updated "examples/fixtures/mnemonic.txt?"'); + throw error; + } } async function createDeployment(sdl: SDL, wallet: DirectSecp256k1HdWallet, client: SigningStargateClient) { @@ -243,7 +241,7 @@ async function createLease(deployment: Deployment, wallet: DirectSecp256k1HdWall throw new Error(`Could not create lease: ${tx.rawLog} `); } -async function queryLeaseStatus(lease: Lease, providerUri: string, certificate: Certificate) { +async function queryLeaseStatus(lease: Lease, providerUri: string, certificate: CertificatePem) { const id = lease.id; if (id === undefined) { @@ -253,7 +251,7 @@ async function queryLeaseStatus(lease: Lease, providerUri: string, certificate: const leasePath = `/lease/${id.dseq}/${id.gseq}/${id.oseq}/status`; const agent = new https.Agent({ - cert: certificate.csr, + cert: certificate.cert, key: certificate.privateKey, rejectUnauthorized: false }); @@ -290,7 +288,7 @@ async function queryLeaseStatus(lease: Lease, providerUri: string, certificate: }); } -async function sendManifest(sdl: SDL, lease: Lease, wallet: DirectSecp256k1HdWallet, certificate: { csr: string; privateKey: string; publicKey: string }) { +async function sendManifest(sdl: SDL, lease: Lease, wallet: DirectSecp256k1HdWallet, certificate: { cert: string; privateKey: string; publicKey: string }) { if (lease.id === undefined) { throw new Error("Lease ID is undefined"); } @@ -314,7 +312,7 @@ async function sendManifest(sdl: SDL, lease: Lease, wallet: DirectSecp256k1HdWal const uri = new URL(providerInfo.hostUri); const agent = new https.Agent({ - cert: certificate.csr, + cert: certificate.cert, key: certificate.privateKey, rejectUnauthorized: false }); diff --git a/examples/details_of_single_provider.ts b/examples/details_of_single_provider.ts index d7f2579..4b10c6a 100644 --- a/examples/details_of_single_provider.ts +++ b/examples/details_of_single_provider.ts @@ -1,4 +1,4 @@ -import { QueryClientImpl, QueryProviderRequest, QueryProviderResponse } from "@akashnetwork/akashjs/build/protobuf/akash/provider/v1beta3/query"; +import { QueryClientImpl, QueryProviderRequest, QueryProviderResponse } from "@akashnetwork/akash-api/akash/provider/v1beta3"; import { getRpc } from "@akashnetwork/akashjs/build/rpc"; async function main() { diff --git a/examples/estimate_gas.ts b/examples/estimate_gas.ts index 27edb78..db822af 100644 --- a/examples/estimate_gas.ts +++ b/examples/estimate_gas.ts @@ -1,9 +1,7 @@ import { DirectSecp256k1HdWallet, Registry } from "@cosmjs/proto-signing"; import { SigningStargateClient } from "@cosmjs/stargate"; - -// import the required message type from akashjs -import { getAkashTypeRegistry, getTypeUrl } from "@akashnetwork/akashjs/build/stargate/index"; -import { MsgCloseDeployment } from "@akashnetwork/akashjs/build/protobuf/akash/deployment/v1beta3/deploymentmsg"; +import { MsgCloseDeployment } from "@akashnetwork/akash-api/akash/deployment/v1beta3"; +import { getAkashTypeRegistry, getTypeUrl } from "@akashnetwork/akashjs/build/stargate"; async function main() { const mnemonic = "your wallet mnemonic"; diff --git a/examples/fixtures/example.sdl.yaml b/examples/fixtures/example.sdl.yaml index 9bb1173..b322f8e 100644 --- a/examples/fixtures/example.sdl.yaml +++ b/examples/fixtures/example.sdl.yaml @@ -1,38 +1,58 @@ -version: '2.0' +# Welcome to the Akash Network! 🚀☁ +# This file is called a Stack Definition Laguage (SDL) +# SDL is a human friendly data standard for declaring deployment attributes. +# The SDL file is a "form" to request resources from the Network. +# SDL is compatible with the YAML standard and similar to Docker Compose files. + +--- +# Indicates version of Akash configuration file. Currently only "2.0" is accepted. +version: "2.0" + +# The top-level services entry contains a map of workloads to be ran on the Akash deployment. Each key is a service name; values are a map containing the following keys: +# https://akash.network/docs/getting-started/stack-definition-language/#services services: - tetris: - image: bsord/tetris + # The name of the service "web" + web: + # The docker container image with version. You must specify a version, the "latest" tag doesn't work. + image: akashlytics/hello-akash-world:0.2.0 + # You can map ports here https://akash.network/docs/getting-started/stack-definition-language/#servicesexpose expose: - - port: 80 + - port: 3000 as: 80 to: - global: true + +# The profiles section contains named compute and placement profiles to be used in the deployment. +# https://akash.network/docs/getting-started/stack-definition-language/#profiles profiles: + # profiles.compute is map of named compute profiles. Each profile specifies compute resources to be leased for each service instance uses uses the profile. + # https://akash.network/docs/getting-started/stack-definition-language/#profilescompute compute: - tetris: + # The name of the service + web: resources: cpu: - units: 1 + units: 0.5 memory: size: 512Mi storage: - - size: 512Mi - gpu: - units: 0 + size: 512Mi + + # profiles.placement is map of named datacenter profiles. Each profile specifies required datacenter attributes and pricing configuration for each compute profile that will be used within the datacenter. It also specifies optional list of signatures of which tenants expects audit of datacenter attributes. + # https://akash.network/docs/getting-started/stack-definition-language/#profilesplacement placement: - akash: - attributes: - host: akash - signedBy: - anyOf: - - akash1365yvmc4s7awdyj3n2sav7xfx76adc6dnmlx63 - - akash18qa2a2ltfyvkyj0ggj3hkvuj6twzyumuaru9s4 + dcloud: pricing: - tetris: + # The name of the service + web: denom: uakt - amount: 10000 + amount: 1000 + +# The deployment section defines how to deploy the services. It is a mapping of service name to deployment configuration. +# https://akash.network/docs/getting-started/stack-definition-language/#deployment deployment: - tetris: - akash: - profile: tetris - count: 1 \ No newline at end of file + # The name of the service + web: + dcloud: + profile: web + count: 1 diff --git a/examples/get_deployments.ts b/examples/get_deployments.ts index 623a9b9..50f1a2c 100644 --- a/examples/get_deployments.ts +++ b/examples/get_deployments.ts @@ -1,4 +1,4 @@ -import { QueryDeploymentsResponse, QueryDeploymentsRequest, QueryClientImpl } from "@akashnetwork/akashjs/build/protobuf/akash/deployment/v1beta3/query"; +import { QueryDeploymentsResponse, QueryDeploymentsRequest, QueryClientImpl } from "@akashnetwork/akash-api/akash/deployment/v1beta3"; import { getRpc } from "@akashnetwork/akashjs/build/rpc"; async function main() { diff --git a/examples/get_lease_status.ts b/examples/get_lease_status.ts index c713c06..2bba035 100644 --- a/examples/get_lease_status.ts +++ b/examples/get_lease_status.ts @@ -1,4 +1,4 @@ -import { QueryClientImpl, QueryLeaseRequest, QueryLeaseResponse } from "@akashnetwork/akashjs/build/protobuf/akash/market/v1beta3/query"; +import { QueryClientImpl, QueryLeaseRequest, QueryLeaseResponse } from "@akashnetwork/akash-api/akash/market/v1beta3"; import { getRpc } from "@akashnetwork/akashjs/build/rpc"; async function main() { diff --git a/examples/list_all_providers.ts b/examples/list_all_providers.ts index f318192..9ea1d1f 100644 --- a/examples/list_all_providers.ts +++ b/examples/list_all_providers.ts @@ -1,4 +1,4 @@ -import { QueryClientImpl, QueryProvidersRequest, QueryProvidersResponse } from "@akashnetwork/akashjs/build/protobuf/akash/provider/v1beta3/query"; +import { QueryClientImpl, QueryProvidersRequest, QueryProvidersResponse } from "@akashnetwork/akash-api/akash/provider/v1beta3"; import { getRpc } from "@akashnetwork/akashjs/build/rpc"; async function main() { diff --git a/examples/take_down_deployment.ts b/examples/take_down_deployment.ts index 2bd34aa..fad6c31 100644 --- a/examples/take_down_deployment.ts +++ b/examples/take_down_deployment.ts @@ -1,9 +1,7 @@ import { DirectSecp256k1HdWallet, Registry } from "@cosmjs/proto-signing"; import { SigningStargateClient } from "@cosmjs/stargate"; - -// import the required message type from akashjs -import { getAkashTypeRegistry, getTypeUrl } from "@akashnetwork/akashjs/build/stargate/index"; -import { MsgCloseDeployment } from "@akashnetwork/akashjs/build/protobuf/akash/deployment/v1beta3/deploymentmsg"; +import { getAkashTypeRegistry, getTypeUrl } from "@akashnetwork/akashjs/build/stargate"; +import { MsgCloseDeployment } from "@akashnetwork/akash-api/akash/deployment/v1beta3"; async function main() { const mnemonic = "your wallet mnemonic"; diff --git a/examples/tsconfig.json b/examples/tsconfig.json new file mode 100644 index 0000000..8f5481c --- /dev/null +++ b/examples/tsconfig.json @@ -0,0 +1,8 @@ +{ + "extends": "../tsconfig.build.json", + "compilerOptions": { + "paths": { + "@akashnetwork/akashjs/build/*": ["../src/*"] + } + } +} diff --git a/package-lock.json b/package-lock.json index d53e43b..1d3735f 100644 --- a/package-lock.json +++ b/package-lock.json @@ -9,7 +9,7 @@ "version": "0.9.1", "license": "Apache-2.0", "dependencies": { - "@akashnetwork/akash-api": "^1.3.0", + "@akashnetwork/akash-api": "^1.4.0", "@cosmjs/launchpad": "^0.27.0", "@cosmjs/proto-signing": "^0.28.11", "@cosmjs/stargate": "^0.28.0", @@ -63,6 +63,7 @@ "ts-loader": "^9.2.3", "ts-node": "^10.0.0", "ts-proto": "^1.104.0", + "tsconfig-paths": "^4.2.0", "typescript": "^4.7.4", "webpack": "^5.41.1", "webpack-cli": "^4.7.2" @@ -82,9 +83,9 @@ } }, "node_modules/@akashnetwork/akash-api": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/@akashnetwork/akash-api/-/akash-api-1.3.0.tgz", - "integrity": "sha512-sZSMg4KsL6vpPs+c6ejcYqyKehTrfasrYEa9Leg/iPPcllSqaFI9EfiP+UQs0Ku2PpMWAZ1Z+c/Pnfr823AEKw==", + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@akashnetwork/akash-api/-/akash-api-1.4.0.tgz", + "integrity": "sha512-xJTHjkSLHQRk2z1s+pk/fSTXQrJCTyzUzWHn+TvvJapjEsDPT0+AW2YhrmYLOpS0n4s/8GnoGB9swRuzgYYLbg==", "dependencies": { "rxjs": "^7.8.1" }, @@ -20201,6 +20202,29 @@ "protobufjs": "^6.8.8" } }, + "node_modules/tsconfig-paths": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-4.2.0.tgz", + "integrity": "sha512-NoZ4roiN7LnbKn9QqE1amc9DJfzvZXxF4xDavcOWt1BPkdx+m+0gJuPM+S0vCe7zTJMYUP0R8pO2XMr+Y8oLIg==", + "dev": true, + "dependencies": { + "json5": "^2.2.2", + "minimist": "^1.2.6", + "strip-bom": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/tsconfig-paths/node_modules/strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", + "dev": true, + "engines": { + "node": ">=4" + } + }, "node_modules/tslib": { "version": "2.6.2", "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", diff --git a/package.json b/package.json index 365920f..814f82f 100644 --- a/package.json +++ b/package.json @@ -1,12 +1,52 @@ { + "name": "@akashnetwork/akashjs", + "version": "0.9.1", + "description": "Akash Network JS SDK", + "repository": { + "url": "https://github.com/akash-network/akashjs" + }, + "license": "Apache-2.0", "author": "", + "main": "build/index.js", "browser": { "fs": false, "os": false, "path": false }, + "types": "build/", + "files": [ + "umd/", + "build/**/*.d.ts", + "build/**/*.js" + ], + "scripts": { + "build": "rimraf build && npm run build:tsc && npm run build:build", + "build:build": "webpack", + "build:production": "NODE_ENV=production npm run build:tsc && npm run build:build", + "build:tsc": "rimraf build && tsc", + "commitlint": "commitlint --edit", + "dev:watch": "tsc -- --watch", + "format": "prettier --write './**/*.{js,ts,json}' --config ./.prettierrc", + "lint": "eslint . --ext .js,.ts,.json -c .eslintrc.json", + "lint:fix": "npm run lint -- --fix", + "prepublishOnly": "npm run build:production", + "setup-git-hooks": "husky", + "test": "npm run test:unit", + "test:cov": "jest --selectProjects unit functional --coverage", + "test:unit": "tap --ts tests/test_*.ts && jest --selectProjects unit", + "test:unit-snapshot": "tap --ts --snapshot tests/test_*.ts", + "test:unit:cov": "jest --selectProjects unit --coverage", + "test:unit:watch": "jest --selectProjects unit --watch" + }, + "lint-staged": { + "*.{js,jsx,ts,tsx}": [ + "npm run test", + "npm run lint:fix", + "npm run format" + ] + }, "dependencies": { - "@akashnetwork/akash-api": "^1.3.0", + "@akashnetwork/akash-api": "^1.4.0", "@cosmjs/launchpad": "^0.27.0", "@cosmjs/proto-signing": "^0.28.11", "@cosmjs/stargate": "^0.28.0", @@ -27,7 +67,6 @@ "simple-jsonrpc-js": "^1.2.0", "sort-json": "^2.0.1" }, - "description": "Akash Network JS SDK", "devDependencies": { "@commitlint/cli": "^19.2.2", "@commitlint/config-conventional": "^19.2.2", @@ -61,50 +100,12 @@ "ts-loader": "^9.2.3", "ts-node": "^10.0.0", "ts-proto": "^1.104.0", + "tsconfig-paths": "^4.2.0", "typescript": "^4.7.4", "webpack": "^5.41.1", "webpack-cli": "^4.7.2" }, "engines": { "node": ">18.0.0" - }, - "files": [ - "umd/", - "build/**/*.d.ts", - "build/**/*.js" - ], - "license": "Apache-2.0", - "lint-staged": { - "*.{js,jsx,ts,tsx}": [ - "npm run test", - "npm run lint:fix", - "npm run format" - ] - }, - "main": "build/index.js", - "name": "@akashnetwork/akashjs", - "repository": { - "url": "https://github.com/akash-network/akashjs" - }, - "scripts": { - "build": "rimraf build && npm run build:tsc && npm run build:build", - "build:build": "webpack", - "build:production": "NODE_ENV=production npm run build:tsc && npm run build:build", - "build:tsc": "rimraf build && tsc", - "commitlint": "commitlint --edit", - "dev:watch": "tsc -- --watch", - "format": "prettier --write './**/*.{js,ts,json}' --config ./.prettierrc", - "lint": "eslint . --ext .js,.ts,.json -c .eslintrc.json", - "lint:fix": "npm run lint -- --fix", - "prepublishOnly": "npm run build:production", - "setup-git-hooks": "husky", - "test": "npm run test:unit", - "test:cov": "jest --selectProjects unit functional --coverage", - "test:unit": "tap --ts tests/test_*.ts && jest --selectProjects unit", - "test:unit-snapshot": "tap --ts --snapshot tests/test_*.ts", - "test:unit:cov": "jest --selectProjects unit --coverage", - "test:unit:watch": "jest --selectProjects unit --watch" - }, - "types": "build/", - "version": "0.9.1" + } } diff --git a/tsconfig.build.json b/tsconfig.build.json new file mode 100644 index 0000000..a6a133f --- /dev/null +++ b/tsconfig.build.json @@ -0,0 +1,72 @@ +{ + "compilerOptions": { + /* Visit https://aka.ms/tsconfig.json to read more about this file */ + + /* Basic Options */ + // "incremental": true, /* Enable incremental compilation */ + "target": "es2021" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', 'ES2021', or 'ESNEXT'. */, + "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */, + // "lib": [], /* Specify library files to be included in the compilation. */ + "allowJs": true /* Allow javascript files to be compiled. */, + // "checkJs": true, /* Report errors in .js files. */ + // "jsx": "preserve", /* Specify JSX code generation: 'preserve', 'react-native', 'react', 'react-jsx' or 'react-jsxdev'. */ + "declaration": true /* Generates corresponding '.d.ts' file. */, + // "declarationMap": true, /* Generates a sourcemap for each corresponding '.d.ts' file. */ + // "sourceMap": true, /* Generates corresponding '.map' file. */ + // "outFile": "./", /* Concatenate and emit output to single file. */ + "outDir": "./build" /* Redirect output structure to the directory. */, + // "rootDir": "./src", /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */ + // "composite": true, /* Enable project compilation */ + // "tsBuildInfoFile": "./", /* Specify file to store incremental compilation information */ + // "removeComments": true, /* Do not emit comments to output. */ + // "noEmit": true, /* Do not emit outputs. */ + // "importHelpers": true, /* Import emit helpers from 'tslib'. */ + // "isolatedModules": true, /* Transpile each file as a separate module (similar to 'ts.transpileModule'). */ + + /* Strict Type-Checking Options */ + "strict": true /* Enable all strict type-checking options. */, + // "noImplicitAny": true, /* Raise error on expressions and declarations with an implied 'any' type. */ + // "strictNullChecks": true, /* Enable strict null checks. */ + // "strictFunctionTypes": true, /* Enable strict checking of function types. */ + // "strictBindCallApply": true, /* Enable strict 'bind', 'call', and 'apply' methods on functions. */ + // "strictPropertyInitialization": true, /* Enable strict checking of property initialization in classes. */ + // "noImplicitThis": true, /* Raise error on 'this' expressions with an implied 'any' type. */ + // "alwaysStrict": true, /* Parse in strict mode and emit "use strict" for each source file. */ + + /* Additional Checks */ + // "noUnusedLocals": true, /* Report errors on unused locals. */ + // "noUnusedParameters": true, /* Report errors on unused parameters. */ + // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ + // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ + // "noUncheckedIndexedAccess": true, /* Include 'undefined' in index signature results */ + // "noImplicitOverride": true, /* Ensure overriding members in derived classes are marked with an 'override' modifier. */ + // "noPropertyAccessFromIndexSignature": true, /* Require undeclared properties from index signatures to use element accesses. */ + + /* Module Resolution Options */ + "moduleResolution": "Node16" /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */, + // "baseUrl": "./", /* Base directory to resolve non-absolute module names. */ + // "paths": {}, /* A series of entries which re-map imports to lookup locations relative to the 'baseUrl'. */ + // "rootDirs": [], /* List of root folders whose combined content represents the structure of the project at runtime. */ + // "typeRoots": [], /* List of folders to include type definitions from. */ + // "types": [], /* Type declaration files to be included in compilation. */ + // "allowSyntheticDefaultImports": true, /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */ + "esModuleInterop": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */, + // "preserveSymlinks": true, /* Do not resolve the real path of symlinks. */ + // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ + + /* Source Map Options */ + // "sourceRoot": "./src", /* Specify the location where debugger should locate TypeScript files instead of source locations. */ + // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ + // "inlineSourceMap": true, /* Emit a single file with source maps instead of having a separate file. */ + // "inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */ + + /* Experimental Options */ + // "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */ + // "emitDecoratorMetadata": true, /* Enables experimental support for emitting type metadata for decorators. */ + + /* Advanced Options */ + "skipLibCheck": true /* Skip type checking of declaration files. */, + "forceConsistentCasingInFileNames": true /* Disallow inconsistently-cased references to the same file. */, + "resolveJsonModule": true + } +} diff --git a/tsconfig.json b/tsconfig.json index d106ee7..621f6ca 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -1,74 +1,5 @@ { - "compilerOptions": { - /* Visit https://aka.ms/tsconfig.json to read more about this file */ - - /* Basic Options */ - // "incremental": true, /* Enable incremental compilation */ - "target": "es2021" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', 'ES2021', or 'ESNEXT'. */, - "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */, - // "lib": [], /* Specify library files to be included in the compilation. */ - "allowJs": true /* Allow javascript files to be compiled. */, - // "checkJs": true, /* Report errors in .js files. */ - // "jsx": "preserve", /* Specify JSX code generation: 'preserve', 'react-native', 'react', 'react-jsx' or 'react-jsxdev'. */ - "declaration": true /* Generates corresponding '.d.ts' file. */, - // "declarationMap": true, /* Generates a sourcemap for each corresponding '.d.ts' file. */ - // "sourceMap": true, /* Generates corresponding '.map' file. */ - // "outFile": "./", /* Concatenate and emit output to single file. */ - "outDir": "./build" /* Redirect output structure to the directory. */, - // "rootDir": "./src", /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */ - // "composite": true, /* Enable project compilation */ - // "tsBuildInfoFile": "./", /* Specify file to store incremental compilation information */ - // "removeComments": true, /* Do not emit comments to output. */ - // "noEmit": true, /* Do not emit outputs. */ - // "importHelpers": true, /* Import emit helpers from 'tslib'. */ - // "isolatedModules": true, /* Transpile each file as a separate module (similar to 'ts.transpileModule'). */ - - /* Strict Type-Checking Options */ - "strict": true /* Enable all strict type-checking options. */, - // "noImplicitAny": true, /* Raise error on expressions and declarations with an implied 'any' type. */ - // "strictNullChecks": true, /* Enable strict null checks. */ - // "strictFunctionTypes": true, /* Enable strict checking of function types. */ - // "strictBindCallApply": true, /* Enable strict 'bind', 'call', and 'apply' methods on functions. */ - // "strictPropertyInitialization": true, /* Enable strict checking of property initialization in classes. */ - // "noImplicitThis": true, /* Raise error on 'this' expressions with an implied 'any' type. */ - // "alwaysStrict": true, /* Parse in strict mode and emit "use strict" for each source file. */ - - /* Additional Checks */ - // "noUnusedLocals": true, /* Report errors on unused locals. */ - // "noUnusedParameters": true, /* Report errors on unused parameters. */ - // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ - // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ - // "noUncheckedIndexedAccess": true, /* Include 'undefined' in index signature results */ - // "noImplicitOverride": true, /* Ensure overriding members in derived classes are marked with an 'override' modifier. */ - // "noPropertyAccessFromIndexSignature": true, /* Require undeclared properties from index signatures to use element accesses. */ - - /* Module Resolution Options */ - "moduleResolution": "Node16" /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */, - // "baseUrl": "./", /* Base directory to resolve non-absolute module names. */ - // "paths": {}, /* A series of entries which re-map imports to lookup locations relative to the 'baseUrl'. */ - // "rootDirs": [], /* List of root folders whose combined content represents the structure of the project at runtime. */ - // "typeRoots": [], /* List of folders to include type definitions from. */ - // "types": [], /* Type declaration files to be included in compilation. */ - // "allowSyntheticDefaultImports": true, /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */ - "esModuleInterop": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */, - // "preserveSymlinks": true, /* Do not resolve the real path of symlinks. */ - // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ - - /* Source Map Options */ - // "sourceRoot": "./src", /* Specify the location where debugger should locate TypeScript files instead of source locations. */ - // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ - // "inlineSourceMap": true, /* Emit a single file with source maps instead of having a separate file. */ - // "inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */ - - /* Experimental Options */ - // "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */ - // "emitDecoratorMetadata": true, /* Enables experimental support for emitting type metadata for decorators. */ - - /* Advanced Options */ - "skipLibCheck": true /* Skip type checking of declaration files. */, - "forceConsistentCasingInFileNames": true /* Disallow inconsistently-cased references to the same file. */, - "resolveJsonModule": true - }, + "extends": "./tsconfig.build.json", "include": ["./src/**/*"], "exclude": ["./examples", "./tests", "./test", "./src/**/*.spec.ts"] }