Setup · deployuseMutation Curated

useRegister

First-time setup for a deployer — singleton creates the two ERC-1167 subwallets.

Import
@tokenops/sdk/fhe-disperse/react
Return
{ mutate, mutateAsync, isPending, error, data }
Lifecycle
Setup · deploy

Description

Deploy the caller's dedicated wallet pair via register(token) and parse the resulting UserRegistered event to return both subwallet addresses.

Can only be called once per user — subsequent calls revert with UserAlreadyRegistered. Use useIsRegistered to gate this in your UI.

Throws `DisperseSubwalletNotFoundError` if the receipt has no UserRegistered event from the singleton — typically means the tx reverted silently or you're reading the wrong singleton address.

After success, invalidate every disperse query for this user:

const queryClient = useQueryClient();
const register = useRegister();
register.mutate({ token }, {
  onSuccess: () => {
    queryClient.invalidateQueries({ queryKey: ["tokenops-sdk", "fhe-disperse"] });
  },
});

Signature

@tokenops/sdk/fhe-disperse/react
ts
function useRegister(options?: DisperseHookOptions): UseMutationResult<RegisterResult, Error, UseRegisterArgs>;

Parameters

Shape of the object you pass to .mutate(args).

PropertyTypeDescription
tokenrequiredAddressERC-7984 token to approve the new subwallets for.
accountAccount | AddressOverride signer account. Falls back to walletClient.account.

Run it

Connect your wallet and click Register subwallets — this dispatches a real Sepolia transaction through the same runner the stories use.

Interactive · live Sepolia tx
Loading editor…
Edit any input above, then press to run.
Console0 lines
No output yet. Run the snippet to see logs stream in.

Example

@tokenops/sdk/fhe-disperse/react · @example
tsx
const register = useRegister();
register.mutate({ token });
// register.data → { hash, wallets: [wallet0, wallet1] }

Pulled directly from the hook's TSDoc block — the same snippet your IDE shows on hover.

Errors

This mutation can reject with SDK-level, product-level, or viem-passthrough errors. Product classes carry the offending value as fields — render them inline instead of a generic "transaction failed." See Disperse › Errors for the per-class recovery table.

Invalidation recipe

After this mutation succeeds, invalidate the queries it affects so consumer UI re-fetches fresh state. The SDK never auto-invalidates — that's a consumer decision (different apps cache different shapes).

patterns/invalidation.ts
ts
import { useQueryClient } from "@tanstack/react-query";

const queryClient = useQueryClient();
const register = useRegister(/* options */);

register.mutate(args, {
  onSuccess() {
    // Coarse invalidation: refresh every cached read on this product surface.
    queryClient.invalidateQueries({
      queryKey: ["tokenops-sdk", "fhe-disperse"],
    });
  },
});

See also

Other Setup · deploy hooks in disperse: