Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Abstract App Module Plugin #112

Draft
wants to merge 25 commits into
base: main
Choose a base branch
from
Draft
Changes from 1 commit
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
28335f3
Initial abstract-app class
adairrr Apr 14, 2023
1b9cf55
Abstract App query interface
adairrr Apr 15, 2023
e380fee
Add query factory to abstract app
adairrr Apr 16, 2023
8f87074
Abstract app types
adairrr Apr 16, 2023
e7eaf04
Abstract app query clients
adairrr May 21, 2023
c926307
AppExecuteInterface
adairrr May 21, 2023
fe66c65
Missing extends in IAppClient
adairrr May 21, 2023
cbb72b9
Abstract app execute client
adairrr May 21, 2023
17557cb
App execute client
adairrr May 21, 2023
6ebed01
Lint the message composer
adairrr May 21, 2023
97d5ab0
Update message builder with abstract
adairrr May 21, 2023
67195cb
Merge 'main'
adairrr May 21, 2023
3777a4b
Clean up abstract app client
adairrr May 21, 2023
3172021
Merge branch 'underscoreFunds' into feature/abstractApp
adairrr May 21, 2023
a3a62aa
Merge branch 'underscoreFunds' into feature/abstractApp
adairrr May 21, 2023
c04b24c
Update react query generation with abstract app
adairrr May 21, 2023
22a40f1
Rely on msg builder for abstract-app
adairrr May 21, 2023
9880c32
Abstract app readme
adairrr May 21, 2023
814b353
Extract from execute msg in appclient
adairrr May 21, 2023
9d3e56b
Update ts-codegen tests
adairrr May 21, 2023
2898bf5
Union _moduleAddress with undefined
adairrr May 21, 2023
2d1640b
Add clientPrefix option to abstractApp
adairrr May 30, 2023
3dd3d78
Merge branch 'main' into feature/abstractApp
NoahSaso Jul 10, 2023
338bbed
Changed wasm-ast-types package name back to npm.
NoahSaso Jul 10, 2023
ea8122e
number to AbstractAccountId and update tests
adairrr Oct 11, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Abstract app types
adairrr committed Apr 16, 2023
commit 8f87074d1f454cb7555a3e7209e11d726121ad4d
102 changes: 102 additions & 0 deletions packages/ts-codegen/src/generators/abstract-app.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
import { pascal } from "case";
import { header } from '../utils/header';
import { join } from "path";
import { sync as mkdirp } from "mkdirp";
import * as w from 'wasm-ast-types';
import { RenderContext } from 'wasm-ast-types';
import * as t from '@babel/types';
import { writeFileSync } from 'fs';
import generate from "@babel/generator";
import { findAndParseTypes, findExecuteMsg, findQueryMsg } from '../utils';
import { getMessageProperties, AbstractAppOptions, ContractInfo } from "wasm-ast-types";
import { BuilderFile } from "../builder";

export default async (
contractName: string,
contractInfo: ContractInfo,
outPath: string,
abstractAppOptions?: AbstractAppOptions
): Promise<BuilderFile[]> => {
const { schemas } = contractInfo;
const context = new RenderContext(contractInfo, {
abstractApp: abstractAppOptions ?? {}
});
const options = context.options.abstractApp;

const localname = pascal(`${contractName}`) + '.react-query.ts';
const ContractFile = pascal(`${contractName}`) + '.client';
const TypesFile = pascal(`${contractName}`) + '.types';

const QueryMsg = findQueryMsg(schemas);
const ExecuteMsg = findExecuteMsg(schemas);
const typeHash = await findAndParseTypes(schemas);

const ExecuteClient = pascal(`${contractName}Client`);
const QueryClient = pascal(`${contractName}QueryClient`);

const body = [];

const clientImports = []

QueryMsg && clientImports.push(QueryClient)

// check that there are commands within the exec msg
const shouldGenerateMutationHooks = ExecuteMsg && options?.version === 'v4' && options?.mutations && getMessageProperties(ExecuteMsg).length > 0

if (shouldGenerateMutationHooks) {
clientImports.push(ExecuteClient)
}

// general contract imports
body.push(w.importStmt(Object.keys(typeHash), `./${TypesFile}`));

// client imports
body.push(w.importStmt(clientImports, `./${ContractFile}`));

// query messages
if (QueryMsg) {
[].push.apply(body,
w.createReactQueryHooks({
context,
queryMsg: QueryMsg,
contractName: contractName,
QueryClient
})
);
}

if (shouldGenerateMutationHooks) {
[].push.apply(body,
w.createReactQueryMutationHooks({
context,
execMsg: ExecuteMsg,
contractName: contractName,
ExecuteClient
})
);
}

if (typeHash.hasOwnProperty('Coin')) {
// @ts-ignore
delete context.utils.Coin;
}
const imports = context.getImports();
const code = header + generate(
t.program([
...imports,
...body
])
).code;

mkdirp(outPath);
writeFileSync(join(outPath, localname), code);

return [
{
type: 'react-query',
contract: contractName,
localname,
filename: join(outPath, localname),
}
]
};
115 changes: 115 additions & 0 deletions packages/ts-codegen/src/plugins/abstract-app.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,115 @@
import { pascal } from 'case';
import * as w from 'wasm-ast-types';
import { findAndParseTypes, findExecuteMsg, findQueryMsg } from '../utils';
import {
getMessageProperties,
ContractInfo,
RenderOptions,
RenderContextBase,
RenderContext
} from 'wasm-ast-types';
import { BuilderFileType } from '../builder';
import { BuilderPluginBase } from './plugin-base';

export class AbstractAppPlugin extends BuilderPluginBase<RenderOptions> {
initContext(
contract: ContractInfo,
options?: RenderOptions
): RenderContextBase<RenderOptions> {
return new RenderContext(contract, options);
}

async doRender(
name: string,
context: RenderContext
): Promise<
{
type: BuilderFileType;
pluginType?: string;
localname: string;
body: any[];
}[]
> {
const options = this.option.abstractApp;

const { enabled } = options;

if (!enabled) {
return;
}

const { schemas } = context.contract;

const localname = pascal(`${name}`) + '.react-query.ts';
const ContractFile = pascal(`${name}`) + '.client';
const TypesFile = pascal(`${name}`) + '.types';

const QueryMsg = findQueryMsg(schemas);
const ExecuteMsg = findExecuteMsg(schemas);
const typeHash = await findAndParseTypes(schemas);

const ExecuteClient = pascal(`${name}Client`);
const QueryClient = pascal(`${name}QueryClient`);

const body = [];

const clientImports = [];

QueryMsg && clientImports.push(QueryClient);

// check that there are commands within the exec msg
const shouldGenerateMutationHooks =
ExecuteMsg &&
options?.version === 'v4' &&
options?.mutations &&
getMessageProperties(ExecuteMsg).length > 0;

if (shouldGenerateMutationHooks) {
clientImports.push(ExecuteClient);
}

// general contract imports
body.push(w.importStmt(Object.keys(typeHash), `./${TypesFile}`));

// client imports
body.push(w.importStmt(clientImports, `./${ContractFile}`));

// query messages
if (QueryMsg) {
[].push.apply(
body,
w.createReactQueryHooks({
context,
queryMsg: QueryMsg,
contractName: name,
QueryClient
})
);
}

if (shouldGenerateMutationHooks) {
[].push.apply(
body,
w.createReactQueryMutationHooks({
context,
execMsg: ExecuteMsg,
contractName: name,
ExecuteClient
})
);
}

if (typeHash.hasOwnProperty('Coin')) {
// @ts-ignore
delete context.utils.Coin;
}

return [
{
type: 'react-query',
localname,
body
}
];
}
}
9 changes: 9 additions & 0 deletions packages/ts-codegen/types/src/generators/abstract-app.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
import { ContractInfo, AbstractAppOptions } from 'wasm-ast-types';
import { BuilderFile } from '../builder';
declare const _default: (
contractName: string,
contractInfo: ContractInfo,
outPath: string,
abstractAppOptions?: AbstractAppOptions
) => Promise<BuilderFile[]>;
export default _default;
12 changes: 12 additions & 0 deletions packages/ts-codegen/types/src/plugins/abstract-app.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
import { ContractInfo, RenderOptions, RenderContextBase, RenderContext } from 'wasm-ast-types';
import { BuilderFileType } from '../builder';
import { BuilderPluginBase } from './plugin-base';
export declare class AbstractAppPlugin extends BuilderPluginBase<RenderOptions> {
initContext(contract: ContractInfo, options?: RenderOptions): RenderContextBase<RenderOptions>;
doRender(name: string, context: RenderContext): Promise<{
type: BuilderFileType;
pluginType?: string;
localname: string;
body: any[];
}[]>;
}
6 changes: 6 additions & 0 deletions packages/wasm-ast-types/src/context/context.ts
Original file line number Diff line number Diff line change
@@ -14,6 +14,11 @@ export interface ReactQueryOptions {
queryFactory?: boolean
}

export interface AbstractAppOptions {
enabled?: boolean;
queryFactory?: boolean;
}

export interface TSClientOptions {
enabled?: boolean;
execExtendsQuery?: boolean;
@@ -63,6 +68,7 @@ export interface RenderOptions {
msgBuilder?: MsgBuilderOptions;
client?: TSClientOptions;
reactQuery?: ReactQueryOptions;
abstractApp?: AbstractAppOptions
}


6 changes: 5 additions & 1 deletion packages/wasm-ast-types/src/context/imports.ts
Original file line number Diff line number Diff line change
@@ -48,6 +48,10 @@ export const UTILS = {
CosmWasmClient: '@cosmjs/cosmwasm-stargate',
ExecuteResult: '@cosmjs/cosmwasm-stargate',
SigningCosmWasmClient: '@cosmjs/cosmwasm-stargate',
AbstractClient: '@abstract-money/abstract.js',
AbstractQueryClient: '@abstract-money/abstract.js',
AbstractAccountClient: '@abstract-money/abstract.js',
AbstractAccountQueryClient: '@abstract-money/abstract.js',

// react-query
useQuery: makeReactQuerySwitch('useQuery'),
@@ -157,4 +161,4 @@ export const getImportStatements = (list: ImportObj[]) => {
}
return m;
}, [])
};
};
7 changes: 7 additions & 0 deletions packages/wasm-ast-types/types/context/context.d.ts
Original file line number Diff line number Diff line change
@@ -9,6 +9,12 @@ export interface ReactQueryOptions {
queryKeys?: boolean;
queryFactory?: boolean;
}

export interface AbstractAppOptions {
enabled?: boolean;
queryFactory?: boolean;
}

export interface TSClientOptions {
enabled?: boolean;
execExtendsQuery?: boolean;
@@ -54,6 +60,7 @@ export interface RenderOptions {
msgBuilder?: MsgBuilderOptions;
client?: TSClientOptions;
reactQuery?: ReactQueryOptions;
abstractApp?: AbstractAppOptions;
}
export interface IContext {
refLookup($ref: string): any;