🌻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 response

remove-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 response

server

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
}