Skip to content

A drop-in library to implement an OAuth-like sign up experience for Nostr apps.

License

Notifications You must be signed in to change notification settings

coracle-social/nostr-ignition

 
 

Repository files navigation

Nostr Ignition

A standalone, drop-in library to help new users to Nostr create accounts with an OAuth-like flow using Nsecbunker.

Demo

Watch the demo

Get started

First, add the JS file from CDN in your Layout file or HTML. You want to make sure that this is loaded on all pages of your app where users can't log in.

<script src="https://cdn.jsdelivr.net/npm/nostr-ignition@latest/dist/index.js"></script>

Then, initialize the library once the DOM is ready to go.

<script>
    document.addEventListener("DOMContentLoaded", function () {
        NostrIgnition.init({
            appName: "DemoApp",
            redirectUri: "https://myapp.com",
            relays: ["wss://relay1.com", "wss://relay2.com"],
        });
    });
</script>

The init method takes an options argument. Options are an object that looks like the following.

options = {
    appName: `<The name of your app>`,
    redirectUri: `<Where you want to redirect to after account creation>`,
    relays: `<An array of relay urls>`,
};

appName is required, both redirectUri and relays are optional.

Contributing

To install dependencies:

bun install

To develop:

bun run dev

This will open the demo.html file and build the project in watch mode. You can use the demo page to view your changes as you work.

To check formatting & linting:

bun run lint

This will check both prettier formatting and use eslint to check the code.

To run tests:

bun run test

Please run both these commands before creating a PR.

About

A drop-in library to implement an OAuth-like sign up experience for Nostr apps.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 77.0%
  • CSS 13.1%
  • HTML 8.2%
  • JavaScript 1.7%