The Magic JavaScript SDK empowers developers to provide frictionless web3 onboarding to their end-users while preserving their security and privacy using non-custodial wallets.
License · Changelog · Contributing Guide
- See the developer documentation to learn how you can master the Magic SDK in a matter of minutes.
- See the @magic-sdk/react-native-bareREADME for Bare React Native package specific information.
- See the @magic-sdk/react-native-expoREADME for Expo React Native package specific information.
Integrating your app with Magic will require our client-side NPM package:
# Via NPM:
npm install --save magic-sdk # If you're targeting web browsers
npm install --save @magic-sdk/react-native-bare # If you're targeting Bare React Native
npm install --save @magic-sdk/react-native-expo # If you're targeting Expo React Native
# Via Yarn:
yarn add magic-sdk # If you're targeting web browsers
yarn add @magic-sdk/react-native-bare # If you're targeting Bare React Native
yarn add @magic-sdk/react-native-expo # If you're targeting Expo React NativeAlternatively, you can load via CDN by adding a script tag to your app’s <head>:
<script src="https://cdn.jsdelivr.net/npm/magic-sdk/dist/magic.js"></script>Sign up or log in to the developer dashboard to receive API keys that will allow your application to interact with Magic's authentication APIs.
Then, you can start authenticating users with just one method! Magic works across all modern desktop, mobile Chrome, Safari and Firefox browsers.
import { Magic } from 'magic-sdk';
import { ethers } from 'ethers';
const magic = new Magic('YOUR_API_KEY', {
  network: 'sepolia',
});
const provider = new ethers.BrowserProvider(magic.rpcProvider);
const accounts = await magic.wallet.connectWithUI();With network switching:
Network switching is available on web SDK version 31.0.0+ and React Native SDKs version 32.0.0+
import { Magic } from 'magic-sdk';
import { SolanaExtension } from '@magic-ext/solana';
import { EVMExtension } from '@magic-ext/evm';
import { ethers } from 'ethers';
const customPolygonOptions = {
  rpcUrl: 'https://polygon-rpc.com/', // Polygon RPC URL
  chainId: 137, // Polygon chain id
  default: true, // Set as default network
};
const customOptimismOptions = {
  rpcUrl: 'https://mainnet.optimism.io',
  chainId: 10,
};
const magic = new Magic(API_KEY, {
  extensions: [
    new EVMExtension([customPolygonOptions, customOptimismOptions]),
    new SolanaExtension({
      rpcUrl: 'https://api.devnet.solana.com',
    }),
  ],
});
const provider = new ethers.BrowserProvider(magic.rpcProvider);
const network = await provider.getNetwork();
console.log(network.chainId); // => 137
magic.evm.switchChain(10);
const network = await provider.getNetwork();
console.log(network.chainId); // => 10
const solanaPublicAddress = await magic.solana.getPublicAddress();
console.log(solanaPublicAddress); // => "9WzDXwBbmkg8ZTbNMqUxvQRAyrZzDsGYdLVL9zYtAWWM"These are packages you can install to enable Magic JS SDK functionality for your client-side application.
| Package Name | Changelog | Description | 
|---|---|---|
| magic-sdk | CHANGELOG | Web/browser entry-point for Magic SDK. | 
| @magic-sdk/react-native-bare | CHANGELOG | Bare React Native entry-point for Magic SDK. | 
| @magic-sdk/react-native-expo | CHANGELOG | Expo React Native entry-point for Magic SDK. | 
Extend Magic JS SDK functionality for your use-case through @magic-ext/* packages.
These are packages Magic JS SDK uses internally to work seamlessly across platforms.
| Package Name | Changelog | Description | 
|---|---|---|
| @magic-sdk/types | CHANGELOG | Core typings shared between JavaScript entry-points of Magic SDK. | 
| @magic-sdk/provider | CHANGELOG | Core business logic shared between JavaScript entry-points of Magic SDK. | 
| @magic-sdk/types | CHANGELOG | Core typings for Magic SDK packages. | 
Run tests for all packages
yarn testTest an individual package
PKG=magic-sdk yarn test
PKG=@magic-sdk/react-native-bare yarn test
PKG=@magic-sdk/react-native-expo yarn testTest specific files
yarn test /test/**/constructor.spec.ts