Skip to content

Commit

Permalink
Revert "Skip CreateSession if no policy is provided (#592)"
Browse files Browse the repository at this point in the history
This reverts commit a91431d.
  • Loading branch information
broody committed Aug 20, 2024
1 parent a91431d commit dfff582
Show file tree
Hide file tree
Showing 9 changed files with 62 additions and 83 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,8 @@ const ETH_TOKEN_ADDRESS =
// const PAPER_TOKEN_ADDRESS =
// "0x0410466536b5ae074f7fea81e5533b8134a9fa08b3dd077dd9db08f64997d113";

const cartridge = new CartridgeConnector({
policies: [
const cartridge = new CartridgeConnector(
[
{
target: ETH_TOKEN_ADDRESS,
method: "approve",
Expand All @@ -50,34 +50,35 @@ const cartridge = new CartridgeConnector({
method: "allowance",
},
],
url:
!process.env.NEXT_PUBLIC_VERCEL_BRANCH_URL ||
process.env.NEXT_PUBLIC_VERCEL_BRANCH_URL.split(".")[0] ===
"cartridge-starknet-react-next"
? process.env.XFRAME_URL
: "https://" +
(process.env.NEXT_PUBLIC_VERCEL_BRANCH_URL ?? "").replace(
"cartridge-starknet-react-next",
"keychain",
),

rpc: process.env.NEXT_PUBLIC_RPC_SEPOLIA,
paymaster: {
caller: shortString.encodeShortString("ANY_CALLER"),
{
url:
!process.env.NEXT_PUBLIC_VERCEL_BRANCH_URL ||
process.env.NEXT_PUBLIC_VERCEL_BRANCH_URL.split(".")[0] ===
"cartridge-starknet-react-next"
? process.env.XFRAME_URL
: "https://" +
(process.env.NEXT_PUBLIC_VERCEL_BRANCH_URL ?? "").replace(
"cartridge-starknet-react-next",
"keychain",
),
rpc: process.env.NEXT_PUBLIC_RPC_SEPOLIA,
paymaster: {
caller: shortString.encodeShortString("ANY_CALLER"),
},
// theme: "dope-wars",
// colorMode: "light"
// prefunds: [
// {
// address: ETH_TOKEN_ADDRESS,
// min: "300000000000000",
// },
// {
// address: PAPER_TOKEN_ADDRESS,
// min: "100",
// },
// ],
},
// theme: "dope-wars",
// colorMode: "light"
// prefunds: [
// {
// address: ETH_TOKEN_ADDRESS,
// min: "300000000000000",
// },
// {
// address: PAPER_TOKEN_ADDRESS,
// min: "100",
// },
// ],
});
);

function provider(chain: Chain) {
switch (chain) {
Expand Down
6 changes: 3 additions & 3 deletions packages/connector/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
import { Connector } from "@starknet-react/core";
import Controller, { ControllerOptions } from "@cartridge/controller";
import Controller, { Policy, ControllerOptions } from "@cartridge/controller";
import { AccountInterface } from "starknet";

class ControllerConnector extends Connector {
public controller: Controller;
private _account: AccountInterface | undefined;

constructor(options?: ControllerOptions) {
constructor(policies?: Policy[], options?: ControllerOptions) {
super();
this.controller = new Controller(options);
this.controller = new Controller(policies, options);
}

readonly id = "cartridge";
Expand Down
48 changes: 18 additions & 30 deletions packages/controller/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,41 +30,29 @@ import { KEYCHAIN_URL, RPC_SEPOLIA } from "./constants";

class Controller {
private url: URL;
private policies?: Policy[];
private policies: Policy[];
private paymaster?: PaymasterOptions;
private connection?: Connection<Keychain>;
private modal?: Modal;
public keychain?: AsyncMethodReturns<Keychain>;
public rpc: URL;
public account?: AccountInterface;

constructor({
policies,
url,
rpc,
paymaster,
theme,
config,
colorMode,
prefunds,
}: ControllerOptions = {}) {
this.url = new URL(url || KEYCHAIN_URL);
this.rpc = new URL(rpc || RPC_SEPOLIA);
this.paymaster = paymaster;

if (policies?.length) {
this.policies = policies.map((policy) => ({
...policy,
target: addAddressPadding(policy.target),
}));
}
constructor(policies: Policy[] = [], options: ControllerOptions = {}) {
this.url = new URL(options?.url || KEYCHAIN_URL);
this.rpc = new URL(options?.rpc || RPC_SEPOLIA);
this.paymaster = options.paymaster;
this.policies = policies.map((policy) => ({
...policy,
target: addAddressPadding(policy.target),
}));

this.setTheme(theme, config?.presets);
if (colorMode) {
this.setColorMode(colorMode);
this.setTheme(options?.theme, options?.config?.presets);
if (options?.colorMode) {
this.setColorMode(options.colorMode);
}
if (prefunds?.length) {
this.setPrefunds(prefunds);
if (options?.prefunds?.length) {
this.setPrefunds(options.prefunds);
}

this.initModal();
Expand Down Expand Up @@ -189,10 +177,10 @@ class Controller {
this.modal.open();

try {
let response = await this.keychain.connect({
rpcUrl: this.rpc.toString(),
policies: this.policies,
});
let response = await this.keychain.connect(
this.policies,
this.rpc.toString(),
);
if (response.code !== ResponseCodes.SUCCESS) {
throw new Error(response.message);
}
Expand Down
9 changes: 4 additions & 5 deletions packages/controller/src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -61,10 +61,10 @@ export type ProbeReply = {

export interface Keychain {
probe(rpcUrl?: string): Promise<ProbeReply | ConnectError>;
connect(args: {
rpcUrl: string;
policies?: Policy[];
}): Promise<ConnectReply | ConnectError>;
connect(
policies: Policy[],
rpcUrl: string,
): Promise<ConnectReply | ConnectError>;
disconnect(): void;

reset(): void;
Expand Down Expand Up @@ -119,7 +119,6 @@ export interface Modal {
* Options for configuring the controller
*/
export type ControllerOptions = {
policies?: Policy[];
/** The URL of keychain */
url?: string;
/** The URL of the RPC */
Expand Down
4 changes: 2 additions & 2 deletions packages/keychain/src/components/connect/Login.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -86,8 +86,8 @@ function Form({
await doLogin(usernameField.value, credentialId);
break;
case LoginMode.Controller:
if (policies?.length === 0) {
break;
if (policies.length === 0) {
throw new Error("Policies required for controller ");
}

await controller.approve(origin, expiresAt, policies);
Expand Down
2 changes: 1 addition & 1 deletion packages/keychain/src/hooks/connection.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ type ConnectionContextValue = {
rpcUrl: string;
chainId: string;
chainName: string;
policies?: Policy[];
policies: Policy[];
prefunds: Prefund[];
hasPrefundRequest: boolean;
error: Error;
Expand Down
2 changes: 1 addition & 1 deletion packages/keychain/src/pages/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ function Home() {
switch (context.type) {
case "connect": {
// TODO: show missing policies if mismatch
if (!context.policies?.length || controller.account.sessionJson()) {
if (controller.account.sessionJson()) {
context.resolve({
code: ResponseCodes.SUCCESS,
address: controller.address,
Expand Down
13 changes: 2 additions & 11 deletions packages/keychain/src/utils/connection/connect.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,19 +14,10 @@ export function connectFactory({
setContext: (context: ConnectionCtx) => void;
}) {
return (origin: string) =>
({
rpcUrl,
policies,
}: {
rpcUrl: string;
policies?: Policy[];
}): Promise<ConnectReply> => {
(policies: Policy[], rpcUrl: string): Promise<ConnectReply> => {
setOrigin(origin);
setRpcUrl(rpcUrl);

if (policies?.length) {
setPolicies(policies);
}
setPolicies(policies);

return new Promise((resolve, reject) => {
setContext({
Expand Down
2 changes: 1 addition & 1 deletion packages/keychain/src/utils/connection/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ export type ConnectionCtx =
export type ConnectCtx = {
origin: string;
type: "connect";
policies?: Policy[];
policies: Policy[];
resolve: (res: ConnectReply | ConnectError) => void;
reject: (reason?: unknown) => void;
};
Expand Down

0 comments on commit dfff582

Please sign in to comment.