Payment gateway for PAW
paw-accept is a server program that helps you to accept PAW payments in a fast, secure and cost-efficient way.
You can use it independently or together with it's web client paw-accept-client.
There are several options:
- Download the latest binary from releases page
- Compile from source:
go get -u github.com/paw-digital/PawAccept
- You need a running PAW node (version >= 21) for communicating with PAW network.
- If you are going to setup your own, see instructions
"rpc_enable"
and"enable_control"
options must be enabled in node config
- If you don't want to setup your own, you can use a node proxy. There are several options. Some of them are:
- If you are going to setup your own, see instructions
- Create a config file for paw-accept. See Config section below.
- Run command:
paw-accept -config /path/to/the/config.toml
You can create a Docker container for paw-accept that works perfectly with your Docker Nano Node.
The configuration and database are stored at /opt/data
so you should map that folder to your host.
docker run -d -p 8080:8080 -v ~/paw-accept:/opt/data acceptnano/acceptnano
Example configuration with NANO node:
version: '3'
services:
paw-accept:
image: "acceptnano/acceptnano"
restart: "unless-stopped"
ports:
- "8080:8080"
volumes:
- "~/paw-accept:/opt/data"
node:
image: "paw-node/paw"
restart: "unless-stopped"
ports:
- "7045:7045/udp"
- "7045:7045"
- ":::7046:7046"
volumes:
- "~:/root"
- paw-accept is a HTTP server with 2 primary endpoints.
- /api/pay for creating a payment request.
- /api/verify for checking the status of a payment.
- From client, you create a payment request by posting the currency and amount.
- When paw-accept receives a payment request, it creates a random unique address for the payment and saves it in its database, then returns a unique token to the client.
- After the payment is created, paw-accept starts monitoring the destination account for incoming funds. It does this by sending a request to node and listening blocks from network via Websocket connection.
- While paw-accept is checking the payment, the client also checks by calling the verification endpoint. It does this continuously until the payment is verified.
- The customer has a limited amount of time to transfer the funds to the destination account. This duration can be set in paw-accept config.
- Then the customer pays the requested amount.
- If paw-accept sees a pending block at destination account, it sends a notification to the merchant and changes the status of the payment to "verified".
- At this point, the payment is received and the merchant is notified. The client can continue its flow.
- The server accepts pending blocks at the destination account.
- The server sends the funds in destination account to the merchants account defined in the config file.
- Config is written in TOML or YAML format.
- The structure of config file is defined in config.go. See comments for field descriptions.
- All of the configuration options can be overriden with
ACCEPTNANO_
prefixed environment variables. This makes configuring the Docker container easier.
DatabasePath = "./paw-accept.db"
ListenAddress = "127.0.0.1:8080"
NodeURL = "http://localhost:7076/"
# Don't forget to set your merchant account.
Account = "paw_1youraccount3fp9utkor5ixmxyg8kme8fnzc4zty145ibch8kf5jwpnzr3r"
# Generate a new random seed with "paw-accept -seed" command and keep it secret.
Seed = "12F36345AB0B10557F22B36B5FF241EF09AF7AEA00A40B3F52CCD34640040E92"
# Payment notifications will be sent to this URL (optional).
NotificationURL = "http://localhost:5000/"
# CoinMarketCap API key. Available from https://coinmarketcap.com/api/
CoinmarketcapAPIKey = "123ab456-cd78-90ef-ab12-34cd56ef7890"
- paw-accept does not need to know your merchant wallet seed. It takes payments from customers and sends them to your merchant account address defined in config file.
- paw-accept server is designed to be open to the Internet but you can run it in your internal network and control requests to it if you want to be extra safe.
- paw-accept does not keep funds itself and passes incoming payments to the merchant account immediately. So there is only a short period of time when the funds are held by paw-accept.
- Private keys are not saved in the database and derived from the seed defined in the config. So you are safe even if the database file is stolen.
- Key generation and block signing is done in paw-accept process. That means private keys does not leave the process in any circumstances.
- Please open an issue if you have a question or suggestion.
- Don't create a PR before discussing it first.
Please send a PR to list your site if paw-accept is helping you to receive PAW payments.