Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/crossmint/solana-auth

Sign-in with Solana wallet, with server+client side authentication and persistent sessions
https://github.com/crossmint/solana-auth

auth login oauth2 sign-in solana wallet

Last synced: 3 months ago
JSON representation

Sign-in with Solana wallet, with server+client side authentication and persistent sessions

Awesome Lists containing this project

README

        

# `@crossmint/solana-auth`

CrossMint's solana-auth provides developers with the tools to configure their applications to allow users to authenticate with their Solana wallets.

This package currently provides support for Firebase out of the box but allows developers to configure it to work with any backend/database.
- [`@crossmint/solana-auth`](#crossmintsolana-auth)
- [🚀 Quick Setup (Next.js Example)](#-quick-setup-nextjs-example)
- [Install](#install)
- [🛠 Setup (React + Firebase)](#-setup-react--firebase)
- [Install](#install-1)
- [Configure domain](#configure-domain)
- [Define auth functions](#define-auth-functions)
- [Use the serverless functions.](#use-the-serverless-functions)
- [Custom Configuration](#custom-configuration)
- [Defining a database adapter](#defining-a-database-adapter)
- [Custom Adapter Template](#custom-adapter-template)
- [Support](#support)
- [Caveats](#caveats)

## 🚀 Quick Setup (Next.js Example)

### Install

```sh
npx create-next-app crossmint-solana-auth --example "https://github.com/crossmint/solana-auth/tree/main/packages/examples/nextjs-starter"

cd crossmint-solana-auth && yarn install
yarn dev
```

## 🛠 Setup (React + Firebase)

## Install
**If you are adding to an existing Next.js project, please see [Caveat #3](#caveats)

```sh
yarn add @crossmint/solana-auth-base@beta \
@crossmint/solana-auth-react-ui@beta
```

### Configure domain

You must configure which domain you're using with Solana Auth in two places:

1. The AUTH_DOMAIN env variable on the server (in your `.env` file)
```sh
#/.env
AUTH_DOMAIN=example.xyz
```
2. The authDomain property from SolanaAuthProvider
```js

```

## Define auth functions

Define what happens when a user is signed in and signed out by implementing `signIn` and `signOut`.

You can define this in a util file or in `/pages/_app.tsx` where they are used by the ``

Here we use those events to handle a session using firebase-auth by using [custom auth](https://firebase.google.com/docs/auth/web/custom-auth).

```ts
// utils/firebaseClient.ts
export async function signIn(data: Record) {
const userCredential = await signInWithCustomToken(auth, data.token);
return userCredential;
}

export const signOut = () => {
return auth.signOut();
};
```

Wrap your app in `SolanaAuthProvider`. Make sure to pass it a domain, your auth functions (defined above), and your serverless endpoints (defined below).

```tsx
// _app.tsx
import { AppProps } from "next/app";
import { FC } from "react";
import { signIn, signOut } from "../utils/firebaseClient"; // DEFINED ABOVE

import { SolanaAuthProvider } from "@crossmint/solana-auth-react-ui";

require("../styles/globals.css");

const App: FC = ({ Component, pageProps }) => {
return (



);
};

export default App;
```

Use the `SolanaAuthButtonFirebase` component to render the signin button in your app.

```tsx
import { SolanaAuthButtonFirebase } from "@crossmint/solana-auth-react-ui";
import { auth } from "../utils/firebaseClient";
const Index = () => {
return (



Sign in with Solana






);
};

export default Index;
```

## Use the serverless functions.

```js
import { FirebaseAdapter, SolanaAuth } from "@crossmint/solana-auth-base";
import firebaseApp from "../../../utils/firebase";

export default SolanaAuth({ adapter: FirebaseAdapter(firebaseApp) });
```

This object exposes `getAuthChallenge` and `completeAuthChallenge`. These functions take a request and response like vercel or firebase functions and return `Promise`.

> **These functions must be used on the api routes defined in above in the `SolanaAuthProvider`**

## Custom Configuration

### Defining a database adapter

Database adapters are needed in order to store transient log-in attempt information. We provide a built-in adapter for Firebase Firestore, or you can implement your own.

**If you are using Firebase, we have built a database adapter for you, accesible with `@crossmint/solana-auth-base`**

Database adapters must fit the `Adapter` interface

```ts
type SignInAttempt = {
nonce: string;
ttl: number;
pubkey: string;
};

interface Adapter {
saveSigninAttempt(attempt: SignInAttempt): Promise;
getNonce(pubkey: string): Promise;
generateToken(pubkey: string): Promise;
getTLL(pubkey: string): Promise;
}
```

### Custom Adapter Template

```ts
const CustomAdapter = (): Adapter => ({
saveSigninAttempt(attempt: SignInAttempt): Promise {
// TODO: save attempt object into persistent storage. Use the as primary key
// and replace any existing entry with the same key
},
getNonce(pubkey: string): Promise {
// TODO: retrieve the nonce of the most recent sign-in attempt for a public key and return the nonce or undefined
},
generateToken(pubkey: string): Promise {
// TODO: create an authentication token for the user and return the token
},
getTLL(pubkey: string): Promise {
// TODO: get the Time To Live from a SignInAttempt from the database
},
});
```

A custom database adapter can be passed to the `SolanaAuth` constructor like so:

```js
SolanaAuth({ adapter: CustomAdapter() });
```

## Support
If you encounter any issues, please join our Discord!



## Caveats
1. This package is provided as-is. We have done our best to reduce security vulnerabilities; however, we cannot guarantee that we have complete coverage.
2. This library **does not** yet support Ledger wallets. This is due to an [unresolved issue between Ledger and Solana](https://github.com/solana-labs/solana/issues/21366).
3. If you are adding this to an existing Next.js project, you will need to install `next-transpile-modules` and include the following in your `next.config.js`

```js
const withTM = require("next-transpile-modules")([
"@crossmint/solana-auth-react-ui",
]);
module.exports = withTM({
reactStrictMode: true,
});
```