Getting Started

To develop for Marina, install Marina on your development machine. Download here.


This guide assumes intermediate knowledge of HTML, CSS, and JavaScript.

Once Marina is installed and running, you should find that new browser tabs have a window.marina object available in the developer console. This is how your website will interact with Marina.

You can review the full API for that object here.

Browser detection#

To verify if the browser is running Marina, you can use the marina-provider package that provides a function detectProvider to inspect and fetch the window.marina provider.

import { detectProvider } from 'marina-provider';
try {
const marina = await detectProvider('marina');
// now the window.marina provider is available for use!
} catch (err) {
console.log('Please install Marina extension!');

You can review the full API for the window.marina object here.

Running in RegTest#

Don't be too reckless. You should develop your applications against a local testnet. Marina defaults to http://localhost:3001 wich is the REST API endpoint of the Electrs-compatible server exposed by Nigiri box. You can download and run an Electrs instance from here, but we strongly suggest Nigiri which setup a complete RegTest environment in one click. Moreover the Electrs-compatible server exposed adds nice features for developers suchs as /mint and /faucet endpoints with automatic block generation and a Liquid asset registry similar to what Blockstream maintains.

Install Nigiri#

curl | bash

Start Nigiri with Liquid#

nigiri start --liquid

On http://localhost:5001 you can see Esplora frontend

Choosing a JavaScript library#

Browser libraries will help you develop faster your apps that handle Liquid transactions and doing operations such as creating, funding and build unsigned transactions or decode transaction built from other parties.

We suggest using liquidjs-lib or LDK, a much more high level development kit, that uses liquidjs-lib under the hood.