Skip to content

lacrypta/checkout-1satoshi1peso

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Simple Ticket Checkout

This is a simple ticket checkout system to pay with SATS.

It use Lightning Network to pay tickets, NOSTR to comunication, Sendy to mailing service and SQLite to database.

Table of Contents

  1. Introduction
  2. Getting Started
  3. Endpoints

Getting Started

  1. Copy the .env.example file to .env and fill in the required values.
cp .env.example .env
  1. Install dependencies
pnmp install
  1. Use the correct node version
nvm use
  1. Create database
pnpm prisma migrate dev --init
  1. Start the server
pnpm dev

Endpoints

Create a new order

Order is a collection of tickets with information about the payment. (Can contain one or more tickets)

your_ticketing_domain/api/ticket/request

  • Validate the request with zod
  • Validate zap receipt
  • Create user in the database (If the email is not already in the database)
  • Create a new ticket in the database
  • Add email to Sendy list (If is subscribed to newsletter)

Parameters:

{
  "fullname": <string>,
  "email": <string>,
  "ticketQuantity": <number>,
  "totalMiliSats": <number>,
  "newsletter": <boolean>,
  "code": <string, optional, discount code>
}

Response:

Valid

{
	"status": <boolean>,
	"data": {
		"pr": <string, invoice to pay>,
		"verify": <string, url to verify the payment (LUD-21)>,
		"eveventReferenceId": <64-character lowercase hex value, tag e of zap request>
	}
}

Invalid

{
	"status": <boolean>,
	"errors": <array of json objects, each one object describe one error>
}

Create invite tickets

Create tickets without payment, for admin use.

your_ticketing_domain/api/admin/invite

  • Validate the request with zod
  • Validate if you are an authorized admin
  • Create tickets in the database
  • Send email with the ticket information

Parameters:

{
    "authEvent": <json object>,
}

Auth Event:

Nostr Event signed with your SIGNER_PRIVATE_KEY

{
  "id": <32-bytes lowercase hex-encoded sha256 of the serialized event data>,
  "pubkey": <32-bytes lowercase hex-encoded public key of the event creator>,
  "created_at": <unix timestamp in seconds>,
  "kind": 27243,
  "tags": [],
  "content": <string>,
  "sig":  <64-bytes lowercase hex of the signature of the sha256 hash of the serialized event data>
}

Content:

Stringified json with the action and the list of emails and fullname.

{
    "action": <string, "add" or "remove">,
    "list": <array of arrays, [[fullname, email], ...]>
}

Response:

Valid

{
	"status": <boolean>,
	"data": {
		"message": <string>
	}
}

Invalid

{
	"status": <boolean>,
	"errors": <string>
}

Claim ticket

Ticket is a single ticket for an event, only emmit when the order is paid.

your_ticketing_domain/api/ticket/claim

  • Validate the request with zod
  • Validate zap receipt and zap request
  • Update database to mark the ticket as paid
  • Send email with the ticket information

Parameters:

{
    "fullname": <string>,
    "email": <string>,
    "zapReceipt": <json object zap receipt nostr eveventReferenceId>,
}

Response:

Valid

{
	"status": <boolean>,
	"data": {
		"claim": <boolean>
	}
}

Invalid

{
	"status": <boolean>,
	"errors": <array of json objects, each one object describe one error>
}

Get tickets

Get all tickets with your filter.

your_ticketing_domain/api/ticket/tickets

  • Validate the request with zod
  • Validate if you are an authorized admin
  • Get all tickets with your filter

Parameters:

{
    "authEvent": <json object>,
}

Auth Event:

Nostr Event signed with your ADMIN_PRIVATE_KEY

{
  "id": <32-bytes lowercase hex-encoded sha256 of the serialized event data>,
  "pubkey": <32-bytes lowercase hex-encoded public key of the event creator>,
  "created_at": <unix timestamp in seconds>,
  "kind": 27242,
  "tags": [],
  "content": <string>,
  "sig":  <64-bytes lowercase hex of the signature of the sha256 hash of the serialized event data>
}

Content (filter):

{
  "limit": <number, 0 for all or specify te quantity>,
  "checked_in": <boolean, optional, not passed means both>
  "ticket_id": <string, optional, not passed means all orders>
  "email":  <string, optional, not passed means all orders>
}

You can combine that you prefer. ei. all orders checked in of X email, only order with X ticket ID.

Response:

Valid

Data is an array of objects with order information.

{
	"status": <boolean>,
	"data": [
		{
			"user": {
				"fullname": <string>,
				"email": <string>
			},
			"ticketId": <string>,
			"checkIn": <boolean>
		},
		...
	]
}

Invalid

{
	"status": <boolean>,
	"errors": <string>
}

Check In ticket

Check in the ticket with the ticket ID.

your_ticketing_domain/api/ticket/checkin

  • Validate the request with zod
  • Validate if you are an authorized admin
  • Check ticket and flag if it was already checked in

Parameters:

{
    "authEvent": <json object>,
}

Auth Event:

Nostr Event signed with your ADMIN_PRIVATE_KEY

{
  "id": <32-bytes lowercase hex-encoded sha256 of the serialized event data>,
  "pubkey": <32-bytes lowercase hex-encoded public key of the event creator>,
  "created_at": <unix timestamp in seconds>,
  "kind": 27242,
  "tags": [],
  "content": <string>,
  "sig":  <64-bytes lowercase hex of the signature of the sha256 hash of the serialized event data>
}

Content:

{
  "ticket_id": <string>,
}

Response:

Valid

{
	"status": <boolean>,
	"data": {
    "alreadyCheckedIn": <boolean, true if the order already checked>,
    "checkIn": <boolean>
  }
}

Invalid

{
	"status": <boolean>,
	"errors": <string>
}

Admin login

Validate if the user is an admin and access the admin panel.

your_ticketing_domain/api/admin/login

  • Validate the public key

Parameters:

{
  "publicKey": <string, 32-bytes lowercase hex-encoded public key>
}

Response:

Valid

{
	"status": <boolean>,
	"data": {
    "message": <string>
  }
}

Invalid

{
	"status": <boolean>,
	"errors": <string>
}

About

Frontend del checkout 1satoshi1peso

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages