-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
cece0c8
commit ae1a19d
Showing
3 changed files
with
107 additions
and
15 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,5 +2,4 @@ dist | |
|
||
node_modules | ||
tsconfig*.tsbuildinfo | ||
.DS_Store | ||
README.md | ||
.DS_Store |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,107 @@ | ||
# zksync-sso | ||
# zksync-sso SDK | ||
|
||
ZKsync SSO SDK | ||
[![License](https://img.shields.io/badge/license-MIT-blue)](LICENSE-MIT) | ||
[![CI](https://github.com/matter-labs/zksync-account-sdk/actions/workflows/ci.yml/badge.svg)](https://github.com/matter-labs/zksync-account-sdk/actions/workflows/ci.yml) | ||
|
||
A user & developer friendly modular smart account implementation on ZKsync; | ||
simplifying user authentication, session management, and transaction processing. | ||
|
||
## Features and Goals | ||
|
||
<!-- prettier-ignore --> | ||
> [!CAUTION] | ||
> ZKsync SSO is under active development and is not yet feature | ||
> complete. Use it to improve your development applications and tooling. Please | ||
> do not use it in production environments. | ||
- 🧩 Modular smart accounts based on | ||
[ERC-7579](https://eips.ethereum.org/EIPS/eip-7579#modules) | ||
- 🔑 Passkey authentication (no seed phrases) | ||
- ⏰ Sessions w/ easy configuration and management | ||
- 💰 Integrated paymaster support | ||
- ❤️🩹 Account recovery _(Coming Soon)_ | ||
- 💻 Simple SDKs : JavaScript, iOS/Android _(Coming Soon)_ | ||
- 🤝 Open-source authentication server | ||
- 🎓 Examples to get started quickly | ||
|
||
## Getting started | ||
|
||
Install the ZKsync SSO SDK package: | ||
|
||
```sh | ||
npm i zksync-sso | ||
``` | ||
|
||
Add ZKsync SSO connector to your app (using `wagmi`): | ||
|
||
```ts | ||
import { zksyncSepoliaTestnet } from "viem/chains"; | ||
import { createConfig, connect } from "@wagmi/core"; | ||
import { zksyncSsoConnector } from "zksync-sso/connector"; | ||
|
||
const ssoConnector = zksyncSsoConnector({ | ||
// Optional session configuration, | ||
// if omitted user will have to sign every transaction via Auth Server | ||
session: { | ||
// Allow up to 0.1 ETH to be spend in gas fees | ||
feeLimit: parseEther("0.1"), | ||
|
||
transfers: [ | ||
// Allow ETH transfers of up to 0.1 ETH to specific address | ||
{ | ||
to: "0x188bd99cd7D4d78d4E605Aeea12C17B32CC3135A", | ||
valueLimit: parseEther("0.1"), | ||
}, | ||
|
||
// Allow ETH transfers to specific address with a limit of 0.1 ETH per hour | ||
// until the session expires | ||
{ | ||
to: "0x188bd99cd7D4d78d4E605Aeea12C17B32CC3135A", | ||
valueLimit: { | ||
limit: parseEther("0.1"), | ||
period: BigInt(60 * 60), // 1 hour in seconds | ||
}, | ||
}, | ||
], | ||
|
||
// Allow calling specific smart contracts (e.g. ERC20 transfer): | ||
contractCalls: [ | ||
{ | ||
address: "0xa1cf087DB965Ab02Fb3CFaCe1f5c63935815f044", | ||
function: "transfer(address,uint256)", | ||
|
||
// Optional call constraints (unconstrained otherwise): | ||
constraints: [ | ||
|
||
// Only allow transfers to this address | ||
{ | ||
index: 0, | ||
condition: "Equal", | ||
refValue: pad("0x6cC8cf7f6b488C58AA909B77E6e65c631c204784"), | ||
}, | ||
|
||
// Transfer up to 0.2 tokens | ||
{ | ||
index: 1, | ||
limit: parseUnits("0.2", TOKEN.decimals), // Unlimited if omitted | ||
}, | ||
], | ||
}, | ||
], | ||
}, | ||
}); | ||
|
||
const wagmiConfig = createConfig({ | ||
connectors: [ssoConnector], | ||
..., // your wagmi config https://wagmi.sh/core/api/createConfig | ||
}); | ||
|
||
const connectWithSSO = () => { | ||
connect(wagmiConfig, { | ||
connector: ssoConnector, | ||
chainId: zksyncSepoliaTestnet.id, // or another chain id that has SSO support | ||
}); | ||
}; | ||
``` | ||
|
||
[Find more information here in our docs.](https://docs.zksync.io/build/zksync-sso) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters