useCreateSessionWithDistributedKey
@biconomy/use-aa • Hook
@biconomy/use-aa / useCreateSessionWithDistributedKey
info
These hooks are a beta feature and are subject to change. To use this feature use our beta package @biconomy-devx/use-aa instead of @biconomy/use-aa, add the following bunfig.toml configuration:
[install.scopes]
silencelaboratories = { token = "$VITE_SILENCE_LABS_NPM_TOKEN", url = "https://registry.npmjs.org" }
And obtain the VITE_SILENCE_LABS_NPM_TOKEN from our support team, and add it to your .env file.
Description
Creates a session to be used when submitting tx in the context of a users smart account.
Please carefully read this information regarding Rules and how they should be constructed before building your Policy.
Parameters
type SessionEpoch = {
  /** The time at which the session is no longer valid */
  validUntil?: number;
  /** The time at which the session becomes valid */
  validAfter?: number;
};
type Policy = {
  /** The address of the contract to be included in the policy */
  contractAddress: Hex;
  /** The address of the sessionKey upon which the policy is to be imparted */
  sessionKeyAddress?: Hex;
  /** The specific function selector from the contract to be included in the policy */
  functionSelector: string | AbiFunction;
  /** The rules  to be included in the policy */
  rules: Rule[];
  /** The time interval within which the session is valid. If left unset the session will remain invalid indefinitely */
  interval?: SessionEpoch;
  /** The maximum value that can be transferred in a single transaction */
  valueLimit: bigint;
};
type UseCreateSessionWithDistributedKeyProps = {
  /** The array of policy elements to be applied to the session. */
  policy: Policy[];
  /** The BuildUserOpOptions options. See https://bcnmy.github.io/biconomy-client-sdk/types/BuildUserOpOptions.html for further detail */
  options?: BuildUserOpOptions;
};
Returns
type UserOpResponse = {
  userOpHash: string;
  wait(_confirmations?: number): Promise<UserOpReceipt>;
  waitForTxHash(): Promise<UserOpStatus>;
};
Example
import { useCreateSessionWithDistributedKey, useUserOpWait, Options } from "@biconomy-devx/useAA";
import { polygonAmoy } from "viem/chains";
import { encodeFunctionData, parseAbi } from "wagmi";
const CreateSessionWithDistributedKey = ({ userSmartAccountAddress }) => {
  const policy = [
    {
      contractAddress: "0x1758f42Af7026fBbB559Dc60EcE0De3ef81f665e",
      functionSelector: "safeMint(address)",
      rules: [
        {
          offset: 0,
          condition: 0,
          referenceValue: userSmartAccountAddress,
        },
      ],
      interval: {
        validUntil: 0,
        validAfter: 0,
      },
      valueLimit: 0n,
    },
  ];
  const { mutate, data: userOpResponse, error, isPending } = useCreateSessionWithDistributedKey();
  const {
    isLoading: waitIsLoading,
    isSuccess: waitIsSuccess,
    error: waitError,
    data: waitData,
  } = useUserOpWait(userOpResponse);
  useEffect(() => {
    if (waitData?.success === "true") {
      console.log(waitData?.receipt?.transactionHash);
    }
  }, [waitData]);
  const createSessionWithDistributedKeyHandler = () =>
    mutate({
      policy,
      options: Options.Sponsored,
    });
  return (
    <ErrorGuard errors={[error, waitError]}>
      <Button
        title="Create a Distributed session"
        onClickFunc={createSessionWithDistributedKeyHandler}
        isLoading={isPending || waitIsLoading}
      />
    </ErrorGuard>
  );
};