🌻Infrastructure And OperationsNjalla
NJALLA API Documentation
Copy pasted from njal.la/api/ because they require you to login to view the docs and that is dumb.
As of 2023-05-05 the domains managed by Njalla are: 
- cyberia.top
- cyberia.tube
- cyberia.social
API Endpoint: njal.la/api/1/ 
Requests follow the JSON-RPC 2.0 protocol.
You can use session cookies or token based authentication.
POST JSON body to the API Endpoint:
{
    "jsonrpc": "2.0",
    "method": "...",
    "params": {...},
    "id": "123"
}and you will get a JSON response. Success:
{
    "jsonrpc": "2.0",
    "result": {}.
    "id": "123"
}or error:
{
    "jsonrpc": "2.0",
    "error": {
        "code": 0
        "message": ""
    },
    "id": "123"
}Example using python requests
import requests
def njalla(method, **params):
    url = 'https://njal.la/api/1/'
    token = '<your-api-token>'
    headers = {
        'Authorization': 'Njalla ' + token
    }
    response = requests.post(url, json={
        'method': method,
        'params': params
    }, headers=headers).json()
    if 'result' not in response:
        raise Exception('API Error', response)
    return response['result']
print(njalla('list-domains'))
print(njalla('get-domain', domain='example.com'))Example using curl
NJALLA_TOKEN='<your-api-token>'
curl -s \
    -H "Accept: application/json" \
    -H "Content-Type: application/json" \
    -H "Authorization: Njalla ${NJALLA_TOKEN}" \
    --data '{"method":"get-domain", "params": {"domain": "exampe.com"}}' \
    https://njal.la/api/1/api
add-token
Add a new API token
params: {
    comment: string (optional)
    from: [string] (optional) array of IPv4 or IPv6 IPs or networks
                              that are allowed to use the token.
                              i.e.: ['8.8.8.8', '192.168.0.0/24']
}
returns: {
}check-task
Check status of a long running task
params: {
    id: string
}
returns: {
    id: string
    status: object
}edit-token
Edit API token
params: {
    key: string
    comment: string (optional)
    from: [string] (optional) array of IPv4 or IPv6 IPs or networks
                              that are allowed to use the token.
                              i.e.: ['8.8.8.8', '192.168.0.0/24']
}
returns: {
}list-tokens
List existing API autorization tokens.
params: {
}
returns: {
    tokens: [...]
}remove-token
Remove an existing API token
params: {
    key: string
}
returns: {
}domain
add-dnssec
Add DNSSEC record for domain
params: {
    domain: string
    algorithm: integer
    digest: string
    digest_type: integer
    key_tag: integer
    or
    public_key: string
}
returns: {
}add-forward
Add email forward
params: {
    domain: string
    from: string
    to: string
}
returns: {
    domain: string
    from: string
    to: string
}add-glue
Add glue record for the domain, name is the subdomain
params: {
    domain: string
    name: string
    address4: string
    address6: string
}
returns: {
}add-record
Add new DNS Record to domain
params: {
    domain: string
    name: string
    content: string
    ttl: int
    type: string
    ...
}
returns: {
    id: int
    content: string
    domain: string
    name: string
    ttl: int
    type: string
}edit-domain
Edit domain configuration
params: {
    domain: string
    ...
}
possible keys:
    mailforwarding: boolean
    dnssec: boolean
    lock: boolean
    contacts: custom whois contact ids
    nameservers: list of custom nameservers or empty list to use our nameservers
returns: {
    name: string,
    ...
}edit-glue
Edit glue record
params: {
    domain: string
    name: string
    address4: string
    address6: string
}
returns: {
}edit-record
Edit DNS Record
params: {
    domain: string
    id: int
    content: string
}
returns: {
}find-domains
Find new domains
params: {
    query: string
}
returns: {
    domains: [
        {price: int, status: string, name: string}
    ]
}get-domain
Get information about one of your domains
params: {
    domain: string
}
returns: {
    name: string,
    ...
}get-tlds
Get list of supported TLDs
params: {
}
returns: {
    tld: {price: int, max_year: int, dnssec: boolean},
}import-zone
Import BIND zone file
params: {
    domain: string
    zone: string
}
returns: {
}list-dnssec
List DNSSEC records for domain
params: {
    domain: string
}
returns: {
    dnssec: list
}list-domains
Get list of your domains
params: {
}
returns: {
    domains: list
}list-forwards
List existing email forwards
params: {
    domain: string
}
returns: {
    forwards: list
}list-glue
List glue records for domain
params: {
    domain: string
}
returns: {
    glue: list
}list-records
List DNS records for given domain
params: {
    domain: string
}
returns: {
    records: list
}register-domain
Register a new domain
params: {
    domain: string
    years: int (default: 1)
}
returns: {
    task: string
}
use check-task for responseremove-dnssec
Remove DNSSEC record from domain
params: {
    domain: string
    id: string
}
returns: {
}remove-forward
Remove email forward
params: {
    domain: string
    from: string
    to: string
}
returns: {
}remove-glue
Remove glue record
params: {
    domain: string
    name: string
}
returns: {
}remove-record
Remove DNS Record
params: {
    domain: string
    id: int
}
returns: {
}renew-domain
Renew one of your domains
params: {
    domain: string
    years: int (default: 1)
}
returns: {
    task: string
}
use check-task for responseserver
add-server
Create a new server with the given name, type, os and ssh_key. Returns an id of the newly created server
params: {
    name: string,
    type: string
    os: string
    ssh_key: string
}
returns: {
    id: string
    ...
}edit-server
Edit an existing server identified by id
params: {
    id: string
    name: string,
    type: string
    ssh_key: string
    reverse_name: string
}
returns: {
    ...
}get-server
Returns information about one of your servers
params: {
    id: string
}
returns: {
    ...
}list-server-images
Returns a list of server images that can be used for new servers
params: {
}
returns: {
    images: list
}list-server-types
Returns a list of server types that can be used for new servers
params: {
}
returns: {
    types: list
}list-servers
Retuns a list of your servers
params: {
}
returns: {
    servers: list
}remove-server
Remote an existing server, your server will be stopped and all data deleted.
params: {
    id: string
}
returns: {
    ...
}renew-server
Renew an existing server identified by id, your wallet must have enough credit to complete this operation.
params: {
    id: string
    months: int
}
returns: {
    ...
}reset-server
Reset existing server and reinstall the given os. All data will be lost. Required field: id
params: {
    id: string
    os: string
    ssh_key: string
}
returns: {
    ...
}restart-server
Restart existing server
params: {
    id: string
}
returns: {
    ...
}start-server
Start existing server
params: {
    id: string
}
returns: {
    ...
}stop-server
Stop existing server
params: {
    id: string
}
returns: {
    ...
}user
login
Login into an existing account (cookie based session). Consider using API tokens instead
params: {
    email: string [or] xmpp: string
    password: string
}
returns: {
}logout
Logout and end your current session
params: {
}
returns: {
}vpn
add-vpn
Add a new VPN client Returns an id
params: {
    name: string,
    autorenew: boolean
}
returns: {
    id: string
    ...
}edit-vpn
Edit an existing VPN identified by id
params: {
    id: string
    name: string,
    autorenew: boolean
    backend: wireguard|openvpn
    publickey: WireGuard PublicKey, set to your public key or null to genrate a new one
}
returns: {
    ...
}get-vpn
Returns information about VPN
params: {
    id: string
}
returns: {
    ...
}list-vpns
Retuns a list of your VPNs
params: {
}
returns: {
    vpns: list
}remove-vpn
Remote an existing VPN
params: {
    id: string
}
returns: {
    ...
}renew-vpn
Renew an existing VPN identified by id, your wallet must have enough credit to complete this operation.
params: {
    id: string
    months: int
}
returns: {
    ...
}wallet
add-payment
Refill your wallet
params: {
    amount: int (5 or multiple of 15, max: 300)
    via: string (options: paypal, bitcoin, litecoin, dash, monero, zcash, bitcoin-cash, ethereum, lightning-btc, transferwise-eur, transferwise-usd)
}
returns: {
    amount: int
    address: string (payment address)
    url: string (paypal url to process payment)
}get-balance
params: {
}
returns: {
    balance: int (in euros)
}get-payment
Get details about a payment
params: {
    id: string
}
returns: {
    id: string
    amount: int
    status: string
    address: string
    url: string
}list-transactions
List transactions (payments, registrations, renewals, etc..) of the last 90 days
params: {
}
returns: {
    transactions: list
}