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

wip(controller): browser bindings & interop #90

Open
wants to merge 2 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
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
34,046 changes: 34,046 additions & 0 deletions Assets/WebGLTemplates/Dojo/TemplateData/controller/index.cjs

Large diffs are not rendered by default.

33,896 changes: 33,896 additions & 0 deletions Assets/WebGLTemplates/Dojo/TemplateData/controller/index.js

Large diffs are not rendered by default.

Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
"type": "module"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
import { InvokeFunctionResponse, TypedData, WalletAccount, Call, AllowArray } from "starknet";
import { SPEC } from "@starknet-io/types-js";
import { Keychain, KeychainOptions, Modal } from "./types";
import { AsyncMethodReturns } from "@cartridge/penpal";
import BaseProvider from "./provider";
declare class ControllerAccount extends WalletAccount {
address: string;
private keychain;
private modal;
private options?;
constructor(provider: BaseProvider, rpcUrl: string, address: string, keychain: AsyncMethodReturns<Keychain>, options: KeychainOptions, modal: Modal);
/**
* Invoke execute function in account contract
*
* @param calls the invocation object or an array of them, containing:
* - contractAddress - the address of the contract
* - entrypoint - the entrypoint of the contract
* - calldata - (defaults to []) the calldata
* - signature - (defaults to []) the signature
* @param abis (optional) the abi of the contract for better displaying
*
* @returns response from addTransaction
*/
execute(calls: AllowArray<Call>): Promise<InvokeFunctionResponse>;
/**
* Sign an JSON object for off-chain usage with the starknet private key and return the signature
* This adds a message prefix so it cant be interchanged with transactions
*
* @param json - JSON object to be signed
* @returns the signature of the JSON object
* @throws {Error} if the JSON object is not a valid JSON
*/
signMessage(typedData: TypedData): Promise<SPEC.SIGNATURE>;
}
export default ControllerAccount;
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
export declare const KEYCHAIN_URL = "https://x.cartridge.gg";
export declare const PROFILE_URL = "https://profile.cartridge.gg";
export declare const API_URL = "https://api.cartridge.gg";
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
import { ControllerOptions, ProfileContextTypeVariant } from "./types";
import BaseProvider from "./provider";
import { WalletAccount } from "starknet";
import { Policy } from "@cartridge/presets";
import { AddStarknetChainParameters } from "@starknet-io/types-js";
export default class ControllerProvider extends BaseProvider {
private keychain?;
private profile?;
private options;
private iframes;
private selectedChain;
private chains;
constructor(options: ControllerOptions);
probe(): Promise<WalletAccount | undefined>;
connect(): Promise<WalletAccount | undefined>;
switchStarknetChain(chainId: string): Promise<boolean>;
addStarknetChain(_chain: AddStarknetChainParameters): Promise<boolean>;
disconnect(): Promise<void>;
openProfile(tab?: ProfileContextTypeVariant): Promise<void>;
openProfileTo(to: string): Promise<void>;
openProfileAt(at: string): Promise<void>;
openSettings(): Promise<boolean | null>;
revoke(origin: string, _policy: Policy[]): Promise<void> | null;
rpcUrl(): string;
username(): Promise<string> | undefined;
openPurchaseCredits(): void;
openExecute(calls: any, chainId?: string): Promise<boolean | undefined>;
delegateAccount(): Promise<string | null>;
private waitForKeychain;
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
export declare class NotReadyToConnect extends Error {
constructor();
}
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
export declare const icon = "";
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
import { AsyncMethodReturns } from "@cartridge/penpal";
import { ControllerOptions, Modal } from "../types";
export type IFrameOptions<CallSender> = Omit<ConstructorParameters<typeof IFrame>[0], "id" | "url" | "onConnect"> & {
url?: string;
onConnect: (child: AsyncMethodReturns<CallSender>) => void;
};
export declare class IFrame<CallSender extends {}> implements Modal {
url?: URL;
private iframe?;
private container?;
private onClose?;
constructor({ id, url, preset, onClose, onConnect, methods, }: Pick<ControllerOptions, "preset"> & {
id: string;
url: URL;
onClose?: () => void;
onConnect: (child: AsyncMethodReturns<CallSender>) => void;
methods?: {
[key: string]: (...args: any[]) => void;
};
});
open(): void;
close(): void;
sendBackward(): void;
sendForward(): void;
private resize;
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
export * from "./base";
export * from "./keychain";
export * from "./profile";
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
import { Keychain, KeychainOptions } from "../types";
import { IFrame, IFrameOptions } from "./base";
type KeychainIframeOptions = IFrameOptions<Keychain> & KeychainOptions;
export declare class KeychainIFrame extends IFrame<Keychain> {
constructor({ url, policies, ...iframeOptions }: KeychainIframeOptions);
}
export {};
Loading