mirror of
https://github.com/cerc-io/watcher-ts
synced 2025-01-23 11:39:05 +00:00
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:
parent
47ce52c112
commit
4e0ef7c852
5
packages/cache/.eslintignore
vendored
Normal file
5
packages/cache/.eslintignore
vendored
Normal 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
27
packages/cache/.eslintrc.json
vendored
Normal 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
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
100
packages/cache/package.json
vendored
100
packages/cache/package.json
vendored
@ -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"
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
25
packages/cache/src/cache.ts
vendored
25
packages/cache/src/cache.ts
vendored
@ -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
75
packages/cache/tsconfig.json
vendored
Normal 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
2
packages/cache/types/common/main.d.ts
vendored
Normal 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'
|
5
packages/cache/types/common/package.json
vendored
Normal file
5
packages/cache/types/common/package.json
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
{
|
||||||
|
"name": "common",
|
||||||
|
"version": "0.1.0",
|
||||||
|
"typings": "main.d.ts"
|
||||||
|
}
|
5
packages/ipld-eth-client/.eslintignore
Normal file
5
packages/ipld-eth-client/.eslintignore
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
# Don't lint node_modules.
|
||||||
|
node_modules
|
||||||
|
|
||||||
|
# Don't lint build output.
|
||||||
|
dist
|
27
packages/ipld-eth-client/.eslintrc.json
Normal file
27
packages/ipld-eth-client/.eslintrc.json
Normal 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
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
@ -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"
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
75
packages/ipld-eth-client/tsconfig.json
Normal file
75
packages/ipld-eth-client/tsconfig.json
Normal 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"]
|
||||||
|
}
|
2
packages/ipld-eth-client/types/common/main.d.ts
vendored
Normal file
2
packages/ipld-eth-client/types/common/main.d.ts
vendored
Normal 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'
|
5
packages/ipld-eth-client/types/common/package.json
Normal file
5
packages/ipld-eth-client/types/common/package.json
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
{
|
||||||
|
"name": "common",
|
||||||
|
"version": "0.1.0",
|
||||||
|
"typings": "main.d.ts"
|
||||||
|
}
|
@ -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"
|
||||||
|
@ -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');
|
||||||
|
36
yarn.lock
36
yarn.lock
@ -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==
|
||||||
|
Loading…
Reference in New Issue
Block a user