Implement typescript strict mode and ESLint in ipld-eth-client and cache packages (#37)

* Set up typescript build.

* Setup eslint in cache package.

* Automatic lint fixes.

* Fix typescript return types.

* Fix typescript argument type warnings.

* Set up typescript build and eslint.

* Automatic lint fixes.

* Fix typescript explicit any warnings.

* Add argument types.

* Fix return type warnings.

* Fix typescript errors.

* Implement declaration in types directory.

Co-authored-by: nikugogoi <95nikass@gmail.com>
This commit is contained in:
Ashwin Phatak 2021-06-04 12:04:12 +05:30 committed by GitHub
parent 47ce52c112
commit 4e0ef7c852
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
18 changed files with 415 additions and 113 deletions

5
packages/cache/.eslintignore vendored Normal file
View File

@ -0,0 +1,5 @@
# Don't lint node_modules.
node_modules
# Don't lint build output.
dist

27
packages/cache/.eslintrc.json vendored Normal file
View File

@ -0,0 +1,27 @@
{
"env": {
"browser": true,
"es2021": true
},
"extends": [
"semistandard",
"plugin:@typescript-eslint/recommended"
],
"parser": "@typescript-eslint/parser",
"parserOptions": {
"ecmaVersion": 12,
"sourceType": "module"
},
"plugins": [
"@typescript-eslint"
],
"rules": {
"@typescript-eslint/no-explicit-any": "off",
"@typescript-eslint/explicit-module-boundary-types": [
"error",
{
"allowArgumentsExplicitlyTypedAsAny": true
}
]
}
}

View File

@ -1,45 +1,59 @@
{ {
"name": "@vulcanize/cache", "name": "@vulcanize/cache",
"version": "0.1.0", "version": "0.1.0",
"description": "Generic object cache", "description": "Generic object cache",
"private": true, "private": true,
"main": "index.ts", "main": "index.ts",
"scripts": { "scripts": {
"test": "mocha -r ts-node/register src/**/*.spec.ts" "test": "mocha -r ts-node/register src/**/*.spec.ts",
}, "build": "tsc",
"repository": { "lint": "eslint ."
"type": "git", },
"url": "git+https://github.com/vulcanize/erc20-watcher.git" "repository": {
}, "type": "git",
"author": "", "url": "git+https://github.com/vulcanize/erc20-watcher.git"
"license": "UNLICENSED", },
"bugs": { "author": "",
"url": "https://github.com/vulcanize/erc20-watcher/issues" "license": "UNLICENSED",
}, "bugs": {
"homepage": "https://github.com/vulcanize/erc20-watcher#readme", "url": "https://github.com/vulcanize/erc20-watcher/issues"
"dependencies": { },
"@types/lodash": "^4.14.168", "homepage": "https://github.com/vulcanize/erc20-watcher#readme",
"apollo-type-bigint": "^0.1.3", "dependencies": {
"canonical-json": "^0.0.4", "@types/lodash": "^4.14.168",
"debug": "^4.3.1", "apollo-type-bigint": "^0.1.3",
"ethers": "^5.2.0", "canonical-json": "^0.0.4",
"express": "^4.17.1", "debug": "^4.3.1",
"express-graphql": "^0.12.0", "ethers": "^5.2.0",
"fs-extra": "^10.0.0", "express": "^4.17.1",
"graphql": "^15.5.0", "express-graphql": "^0.12.0",
"graphql-import-node": "^0.0.4", "fs-extra": "^10.0.0",
"graphql-request": "^3.4.0", "graphql": "^15.5.0",
"graphql-tools": "^7.0.4", "graphql-import-node": "^0.0.4",
"left-pad": "^1.3.0", "graphql-request": "^3.4.0",
"level": "^7.0.0", "graphql-tools": "^7.0.4",
"lodash": "^4.17.21", "left-pad": "^1.3.0",
"toml": "^3.0.0", "level": "^7.0.0",
"yargs": "^17.0.1" "lodash": "^4.17.21",
}, "toml": "^3.0.0",
"devDependencies": { "yargs": "^17.0.1"
"@types/express": "^4.17.11", },
"@types/yargs": "^17.0.0", "devDependencies": {
"nodemon": "^2.0.7", "@types/debug": "^4.1.5",
"ts-node": "^10.0.0" "@types/express": "^4.17.11",
} "@types/fs-extra": "^9.0.11",
"@types/level": "^6.0.0",
"@types/yargs": "^17.0.0",
"@typescript-eslint/eslint-plugin": "^4.25.0",
"@typescript-eslint/parser": "^4.25.0",
"eslint": "^7.27.0",
"eslint-config-semistandard": "^15.0.1",
"eslint-config-standard": "^16.0.3",
"eslint-plugin-import": "^2.23.3",
"eslint-plugin-node": "^11.1.0",
"eslint-plugin-promise": "^5.1.0",
"eslint-plugin-standard": "^5.0.0",
"nodemon": "^2.0.7",
"ts-node": "^10.0.0"
} }
}

View File

@ -8,12 +8,18 @@ import debug from 'debug';
const log = debug('vulcanize:cache'); const log = debug('vulcanize:cache');
export const getCache = async (config) => { interface Config {
name: string;
enabled: boolean;
deleteOnStart: boolean;
}
export const getCache = async (config: Config): Promise<undefined | Cache> => {
let cache; let cache;
// Cache is optional. // Cache is optional.
if (config) { if (config) {
log("config", JSON.stringify(config, null, 2)); log('config', JSON.stringify(config, null, 2));
const { name, enabled, deleteOnStart } = config; const { name, enabled, deleteOnStart } = config;
@ -37,23 +43,22 @@ export const getCache = async (config) => {
}; };
export class Cache { export class Cache {
_db: any; _db: any;
_name: string; _name: string;
constructor(name, dirPath) { constructor (name: string, dirPath: string) {
assert(name); assert(name);
assert(dirPath); assert(dirPath);
this._name = name; this._name = name;
this._db = level(dirPath, { valueEncoding: 'json' });; this._db = level(dirPath, { valueEncoding: 'json' });
} }
key(obj) { key (obj: any): string {
return this._cacheKey(obj); return this._cacheKey(obj);
} }
async get(obj) { async get (obj: any): Promise<[any, boolean] | undefined> {
const key = this._cacheKey(obj); const key = this._cacheKey(obj);
try { try {
@ -66,16 +71,16 @@ export class Cache {
log(`${this._name}: cache miss ${key}`); log(`${this._name}: cache miss ${key}`);
if (err.notFound) { if (err.notFound) {
return [undefined, false] return [undefined, false];
} }
} }
} }
async put(obj, value) { async put (obj: any, value: any): Promise<void> {
await this._db.put(this._cacheKey(obj), value); await this._db.put(this._cacheKey(obj), value);
} }
_cacheKey(obj) { _cacheKey (obj: any): string {
return ethers.utils.keccak256(Buffer.from(canonicalStringify(obj))); return ethers.utils.keccak256(Buffer.from(canonicalStringify(obj)));
} }
} }

75
packages/cache/tsconfig.json vendored Normal file
View File

@ -0,0 +1,75 @@
{
"compilerOptions": {
/* Visit https://aka.ms/tsconfig.json to read more about this file */
/* Basic Options */
// "incremental": true, /* Enable incremental compilation */
"target": "es5", /* 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": "dist", /* Redirect output structure to the directory. */
// "rootDir": "./", /* 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'. */
// "downlevelIteration": true, /* Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'. */
// "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": "node", /* 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": [
"./types"
], /* 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": "", /* 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. */
},
"exclude": ["src/**/*.test.ts", "dist"]
}

2
packages/cache/types/common/main.d.ts vendored Normal file
View File

@ -0,0 +1,2 @@
// https://medium.com/@steveruiz/using-a-javascript-library-without-type-declarations-in-a-typescript-project-3643490015f3
declare module 'canonical-json'

View File

@ -0,0 +1,5 @@
{
"name": "common",
"version": "0.1.0",
"typings": "main.d.ts"
}

View File

@ -0,0 +1,5 @@
# Don't lint node_modules.
node_modules
# Don't lint build output.
dist

View File

@ -0,0 +1,27 @@
{
"env": {
"browser": true,
"es2021": true
},
"extends": [
"semistandard",
"plugin:@typescript-eslint/recommended"
],
"parser": "@typescript-eslint/parser",
"parserOptions": {
"ecmaVersion": 12,
"sourceType": "module"
},
"plugins": [
"@typescript-eslint"
],
"rules": {
"@typescript-eslint/no-explicit-any": "off",
"@typescript-eslint/explicit-module-boundary-types": [
"warn",
{
"allowArgumentsExplicitlyTypedAsAny": true
}
]
}
}

View File

@ -1,46 +1,56 @@
{ {
"name": "@vulcanize/ipld-eth-client", "name": "@vulcanize/ipld-eth-client",
"version": "0.1.0", "version": "0.1.0",
"description": "IPLD ETH Client", "description": "IPLD ETH Client",
"private": true, "private": true,
"main": "index.ts", "main": "index.ts",
"scripts": { "scripts": {
"test": "mocha -r ts-node/register src/**/*.spec.ts" "test": "mocha -r ts-node/register src/**/*.spec.ts",
}, "build": "tsc",
"repository": { "lint": "eslint ."
"type": "git", },
"url": "git+https://github.com/vulcanize/erc20-watcher.git" "repository": {
}, "type": "git",
"author": "", "url": "git+https://github.com/vulcanize/erc20-watcher.git"
"license": "UNLICENSED", },
"bugs": { "author": "",
"url": "https://github.com/vulcanize/erc20-watcher/issues" "license": "UNLICENSED",
}, "bugs": {
"homepage": "https://github.com/vulcanize/erc20-watcher#readme", "url": "https://github.com/vulcanize/erc20-watcher/issues"
"dependencies": { },
"@types/lodash": "^4.14.168", "homepage": "https://github.com/vulcanize/erc20-watcher#readme",
"@vulcanize/cache": "^0.1.0", "dependencies": {
"apollo-type-bigint": "^0.1.3", "@types/lodash": "^4.14.168",
"canonical-json": "^0.0.4", "@vulcanize/cache": "^0.1.0",
"debug": "^4.3.1", "apollo-type-bigint": "^0.1.3",
"ethers": "^5.2.0", "debug": "^4.3.1",
"express": "^4.17.1", "ethers": "^5.2.0",
"express-graphql": "^0.12.0", "express": "^4.17.1",
"fs-extra": "^10.0.0", "express-graphql": "^0.12.0",
"graphql": "^15.5.0", "fs-extra": "^10.0.0",
"graphql-import-node": "^0.0.4", "graphql": "^15.5.0",
"graphql-request": "^3.4.0", "graphql-import-node": "^0.0.4",
"graphql-tools": "^7.0.4", "graphql-request": "^3.4.0",
"left-pad": "^1.3.0", "graphql-tools": "^7.0.4",
"level": "^7.0.0", "left-pad": "^1.3.0",
"lodash": "^4.17.21", "level": "^7.0.0",
"toml": "^3.0.0", "lodash": "^4.17.21",
"yargs": "^17.0.1" "toml": "^3.0.0",
}, "yargs": "^17.0.1"
"devDependencies": { },
"@types/express": "^4.17.11", "devDependencies": {
"@types/yargs": "^17.0.0", "@types/express": "^4.17.11",
"nodemon": "^2.0.7", "@types/yargs": "^17.0.0",
"ts-node": "^10.0.0" "@typescript-eslint/eslint-plugin": "^4.25.0",
} "@typescript-eslint/parser": "^4.25.0",
"eslint": "^7.27.0",
"eslint-config-semistandard": "^15.0.1",
"eslint-config-standard": "^16.0.3",
"eslint-plugin-import": "^2.23.3",
"eslint-plugin-node": "^11.1.0",
"eslint-plugin-promise": "^5.1.0",
"eslint-plugin-standard": "^5.0.0",
"nodemon": "^2.0.7",
"ts-node": "^10.0.0"
} }
}

View File

@ -6,13 +6,23 @@ import { Cache } from '@vulcanize/cache';
import ethQueries from './eth-queries'; import ethQueries from './eth-queries';
import { padKey } from './utils'; import { padKey } from './utils';
export class EthClient { interface Config {
gqlEndpoint: string;
cache: Cache;
}
_config: any; interface Vars {
_client: any; blockHash: string;
contract: string;
slot?: string;
}
export class EthClient {
_config: Config;
_client: GraphQLClient;
_cache: Cache; _cache: Cache;
constructor(config) { constructor (config: Config) {
this._config = config; this._config = config;
const { gqlEndpoint, cache } = config; const { gqlEndpoint, cache } = config;
@ -22,7 +32,7 @@ export class EthClient {
this._cache = cache; this._cache = cache;
} }
async getStorageAt({ blockHash, contract, slot }) { async getStorageAt ({ blockHash, contract, slot }: { blockHash: string, contract: string, slot: string }): Promise<{ value: string, proof: { data: string } }> {
slot = `0x${padKey(slot)}`; slot = `0x${padKey(slot)}`;
const result = await this._getCachedOrFetch('getStorageAt', { blockHash, contract, slot }); const result = await this._getCachedOrFetch('getStorageAt', { blockHash, contract, slot });
@ -46,14 +56,14 @@ export class EthClient {
}; };
} }
async getLogs(vars) { async getLogs (vars: Vars): Promise<any> {
const result = await this._getCachedOrFetch('getLogs', vars); const result = await this._getCachedOrFetch('getLogs', vars);
const { getLogs: logs } = result; const { getLogs: logs } = result;
return logs; return logs;
} }
async _getCachedOrFetch(queryName, vars) { async _getCachedOrFetch (queryName: keyof typeof ethQueries, vars: Vars): Promise<any> {
const keyObj = { const keyObj = {
queryName, queryName,
vars vars
@ -61,7 +71,7 @@ export class EthClient {
// Check if request cached in db, if cache is enabled. // Check if request cached in db, if cache is enabled.
if (this._cache) { if (this._cache) {
const [value, found] = await this._cache.get(keyObj); const [value, found] = await this._cache.get(keyObj) || [undefined, false];
if (found) { if (found) {
return value; return value;
} }

View File

@ -1,21 +1,21 @@
import leftPad from 'left-pad'; import leftPad from 'left-pad';
import { ethers } from 'ethers'; import { ethers } from 'ethers';
export const padKey = input => export const padKey = (input: string): string =>
leftPad(ethers.utils.hexlify(input).replace('0x', ''), 64, '0'); leftPad(ethers.utils.hexlify(input).replace('0x', ''), 64, '0');
export const getMappingSlot = (mappingSlot, key) => { export const getMappingSlot = (mappingSlot: string, key: string): string => {
const mappingSlotPadded = padKey(mappingSlot); const mappingSlotPadded = padKey(mappingSlot);
const keyPadded = padKey(key); const keyPadded = padKey(key);
const fullKey = keyPadded.concat(mappingSlotPadded); const fullKey = keyPadded.concat(mappingSlotPadded);
const slot = ethers.utils.keccak256(`0x${fullKey}`); const slot = ethers.utils.keccak256(`0x${fullKey}`);
return slot return slot;
}; };
export const getStorageLeafKey = (slot) => ethers.utils.keccak256(slot); export const getStorageLeafKey = (slot: string): string => ethers.utils.keccak256(slot);
export const topictoAddress = (topic) => { export const topictoAddress = (topic: string): string => {
return ethers.utils.getAddress( return ethers.utils.getAddress(
ethers.utils.hexZeroPad( ethers.utils.hexZeroPad(
ethers.utils.hexStripZeros(topic), 20 ethers.utils.hexStripZeros(topic), 20

View File

@ -0,0 +1,75 @@
{
"compilerOptions": {
/* Visit https://aka.ms/tsconfig.json to read more about this file */
/* Basic Options */
// "incremental": true, /* Enable incremental compilation */
"target": "es5", /* 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": "dist", /* Redirect output structure to the directory. */
// "rootDir": "./", /* 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'. */
// "downlevelIteration": true, /* Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'. */
// "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": "node", /* 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": [
"./types"
], /* 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": "", /* 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. */
},
"exclude": ["src/**/*.test.ts", "dist", "**/node_modules"]
}

View File

@ -0,0 +1,2 @@
// https://medium.com/@steveruiz/using-a-javascript-library-without-type-declarations-in-a-typescript-project-3643490015f3
declare module 'canonical-json'

View File

@ -0,0 +1,5 @@
{
"name": "common",
"version": "0.1.0",
"typings": "main.d.ts"
}

View File

@ -46,6 +46,7 @@
"devDependencies": { "devDependencies": {
"@types/es6-shim": "^0.31.41", "@types/es6-shim": "^0.31.41",
"@types/express": "^4.17.11", "@types/express": "^4.17.11",
"@types/fs-extra": "^9.0.11",
"@types/yargs": "^17.0.0", "@types/yargs": "^17.0.0",
"nodemon": "^2.0.7", "nodemon": "^2.0.7",
"ts-node": "^10.0.0" "ts-node": "^10.0.0"

View File

@ -24,12 +24,12 @@ export const createServer = async () => {
const configFile = argv['configFile']; const configFile = argv['configFile'];
const configFilePath = path.resolve(configFile); const configFilePath = path.resolve(configFile);
const fileExists = await fs.exists(configFilePath); const fileExists = await fs.pathExists(configFilePath);
if (!fileExists) { if (!fileExists) {
throw new Error(`Config file not found: ${configFilePath}`); throw new Error(`Config file not found: ${configFilePath}`);
} }
var config = toml.parse(await fs.readFile(configFilePath)); var config = toml.parse(await fs.readFile(configFilePath, 'utf8'));
log("config", JSON.stringify(config, null, 2)); log("config", JSON.stringify(config, null, 2));
assert(config.server, 'Missing server config'); assert(config.server, 'Missing server config');

View File

@ -1506,6 +1506,19 @@
dependencies: dependencies:
"@types/node" "*" "@types/node" "*"
"@types/debug@^4.1.5":
version "4.1.5"
resolved "https://registry.yarnpkg.com/@types/debug/-/debug-4.1.5.tgz#b14efa8852b7768d898906613c23f688713e02cd"
integrity sha512-Q1y515GcOdTHgagaVFhHnIFQ38ygs/kmxdNpvpou+raI9UO3YZcHDngBSYKQklcKlvA7iuQlmIKbzvmxcOE9CQ==
"@types/encoding-down@*":
version "5.0.0"
resolved "https://registry.yarnpkg.com/@types/encoding-down/-/encoding-down-5.0.0.tgz#0b5b90b93ac3aa75148f19508044e7bd36463557"
integrity sha512-G0MlS/+/U2RIQLcSEhhAcoMrXw3hXUCFSKbhbeEljoKMra2kq+NPX6tfOveSWQLX2hJXBo+YrvKgAGe+tFL1Aw==
dependencies:
"@types/abstract-leveldown" "*"
"@types/level-codec" "*"
"@types/es6-shim@^0.31.41": "@types/es6-shim@^0.31.41":
version "0.31.41" version "0.31.41"
resolved "https://registry.yarnpkg.com/@types/es6-shim/-/es6-shim-0.31.41.tgz#6c0610500de36a4be69c734335a2997f6ff79e51" resolved "https://registry.yarnpkg.com/@types/es6-shim/-/es6-shim-0.31.41.tgz#6c0610500de36a4be69c734335a2997f6ff79e51"
@ -1530,6 +1543,13 @@
"@types/qs" "*" "@types/qs" "*"
"@types/serve-static" "*" "@types/serve-static" "*"
"@types/fs-extra@^9.0.11":
version "9.0.11"
resolved "https://registry.yarnpkg.com/@types/fs-extra/-/fs-extra-9.0.11.tgz#8cc99e103499eab9f347dbc6ca4e99fb8d2c2b87"
integrity sha512-mZsifGG4QeQ7hlkhO56u7zt/ycBgGxSVsFI/6lGTU34VtwkiqrrSDgw0+ygs8kFGWcXnFQWMrzF2h7TtDFNixA==
dependencies:
"@types/node" "*"
"@types/json-schema@^7.0.3": "@types/json-schema@^7.0.3":
version "7.0.7" version "7.0.7"
resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.7.tgz#98a993516c859eb0d5c4c8f098317a9ea68db9ad" resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.7.tgz#98a993516c859eb0d5c4c8f098317a9ea68db9ad"
@ -1540,7 +1560,21 @@
resolved "https://registry.yarnpkg.com/@types/json5/-/json5-0.0.29.tgz#ee28707ae94e11d2b827bcbe5270bcea7f3e71ee" resolved "https://registry.yarnpkg.com/@types/json5/-/json5-0.0.29.tgz#ee28707ae94e11d2b827bcbe5270bcea7f3e71ee"
integrity sha1-7ihweulOEdK4J7y+UnC86n8+ce4= integrity sha1-7ihweulOEdK4J7y+UnC86n8+ce4=
"@types/levelup@^4.3.0": "@types/level-codec@*":
version "9.0.0"
resolved "https://registry.yarnpkg.com/@types/level-codec/-/level-codec-9.0.0.tgz#9f1dc7f9017b6fba094a450602ec0b91cc384059"
integrity sha512-SWYkVJylo1dqblkhrr7UtmsQh4wdZA9bV1y3QJSywMPSqGfW0p1w37N1EayZtKbg1dGReIIQEEOtxk4wZvGrWQ==
"@types/level@^6.0.0":
version "6.0.0"
resolved "https://registry.yarnpkg.com/@types/level/-/level-6.0.0.tgz#0bc0aaf1106598e1774e1dc5b69f0d58885d9d34"
integrity sha512-NjaUpukKfCvnV4Wk0jUaodFi2/66HxgpYghc2aV8iP+zk2NMt/9ps1eVlifqOU/+eLzMlDIY69NWkbPaAstukQ==
dependencies:
"@types/abstract-leveldown" "*"
"@types/encoding-down" "*"
"@types/levelup" "*"
"@types/levelup@*", "@types/levelup@^4.3.0":
version "4.3.1" version "4.3.1"
resolved "https://registry.yarnpkg.com/@types/levelup/-/levelup-4.3.1.tgz#7a53b9fd510716e11b2065332790fdf5f9b950b9" resolved "https://registry.yarnpkg.com/@types/levelup/-/levelup-4.3.1.tgz#7a53b9fd510716e11b2065332790fdf5f9b950b9"
integrity sha512-n//PeTpbHLjMLTIgW5B/g06W/6iuTBHuvUka2nFL9APMSVMNe2r4enADfu3CIE9IyV9E+uquf9OEQQqrDeg24A== integrity sha512-n//PeTpbHLjMLTIgW5B/g06W/6iuTBHuvUka2nFL9APMSVMNe2r4enADfu3CIE9IyV9E+uquf9OEQQqrDeg24A==