Lease a Zelf Name

Creating a zelf name from the web extension or android online version(beta).

Endpoint

https://api.zelf.world/api/zelf-name-service/lease

This endpoint allows the creation of a new ZelfProof as raw bytes encoded in base64. These are the same bytes used to generate the QR code.

Before we get started, the web extension utilizes an additional encryption which is the PGP Encryption, that will enable us to communicate safely from the web extension to the server where we will generate the ZelfProof. This process is very simple, first we get the public key that we called it a session PGP Public Key, this key will be used to encrypt every message that we consider private with this key, each session (each user) gets a different key so decrypting the content will require to match the same secret key that we assigned to the session.

Retrieve public key

Request

  • Endpoint: /api/zelf-name-service/lease

  • Method: POST

  • Content-Type: application/json

Request

const axios = require('axios');

let data = JSON.stringify({
  "type": "create",
  "zelfName": "yourzelfnamehere.zelf",
  "wordsCount": 12,
  "removePGP": true,
  "faceBase64": "/9j/4AAQSkZJRgAB...p/9k="
});

let config = {
  method: 'post',
  maxBodyLength: Infinity,
  url: 'https://api.zelf.world/api/zelf-name-service/lease',
  headers: { 
    'Content-Type': 'application/json', 
    'Authorization': 'Bearer eyJhbGciVCJ9.eyJjbGll...qBtlFSNM'
  },
  data : data
};

axios.request(config)
.then((response) => {
  console.log(JSON.stringify(response.data));
})
.catch((error) => {
  console.log(error);
});

Body

The request body should be a JSON object containing the following fields:

{
  "type": "create", // it can be either 'create' or 'import' 
  "faceBase64": "<PGP_encrypted_message>",
  "wordsCount": "12",
  "mnemonic": "for import only > your 12 or 24 words go here",
  "os": "DESKTOP",
  "password": "(optional)<PGP_encrypted_message>",
  "addServerPassword": false,
  "removePGP": true
}

Fields:

  • type: string (Required) - Type of Zelf Name to be created, a new wallet or import an existing wallet. Allowed values [create, import]

  • faceBase64: string (Required) - PGP Encrypted message containing your selfie. We will perform a liveness test

  • wordsCount: number (Optional) - Specifies the total of words for your mnemonic phrase, e.g., 12

  • mnemonic: string (Optional) - PGP Encrypted message containing your mnemonic phrase (12/24 words). This is only required if you decide to import an existing wallet.

  • os: string (Optional) - The operating system where the request originates, e.g., "DESKTOP".

  • password: string (Optional) - PGP Encrypted message containing your password, which adds a second layer of security besides the liveness detection that is done prior the biometric encryption.

  • addServerPassword: Boolean (Optional) - An authentication key required for decrypting the ZelfProof if specified.

  • removePGP: Boolean(Optional) - If true, we are removing the decryption of the previous keys using PGP, all the variables are sent in plain text.

Response

{
    "data": {
        "zelfProof": "ArbLPVaOMlgL2ck0idcuVRYTMQg2NZnbxLRNy7NCKgk2OXx7CaDNaJMAyeJGgZOV7czgcWftUbicRZPhKl95beFRbHkVJI2WptnHLCi+7RsFYL7PiAjKrnDw8hh77jLPx9YGbBGEe30b1a+bBSfRe7+YITu9Tuc7+x4I3FKmvgpPK14JRQToAL+Jf905x5qm6LmK3+1lgP7G66dr7Ho+8jRAsJHYiIg0o+d9SI2+jaS1ZlD0HwmqE3mXVvJTrwX+uxW0DcTU0hrm/RUtBw9RXTLQ6UhJrd9LonScplazsMJORHxRwrD2ORH+DySPPwan11rX7UglDkQ/luup+gZi/Qt6eX8Rbf9XvCqIgTmZHO4e9efY5jeQZwOftBFe1tYV9YkffJo8FLLxKdkcHl5X8uAh3wYBsqtwXwSuyHr4A12n9eOBos47lnKeyWnskjyVHECNLs1HyHCGlRi4c5lhX8SjBVZwMv0pYkGZa9BtlrGus0vIoNmHJUjdqca1xx0Wp9ztPhqy2bcUaz3+qLZrswf0cnc9G1hO42CviZk0loKixwkIvk5scTD0kTjYIqRpEpofUHGY15KJYel1fP1mJwG8S1GiWcqmufuAhsh36BPX+zf0LV9pUs6NSl29u7J6I7W3Ph3U6zWlveVUP5erATVjr3biX1KzzobT4Av3VVjPOy2qQCIHW+ltVTT+DnwqmvbWtCkD1xpkc0trQcU1rTFuj5VMGR1aVpICvlcs2hLwpspEnDOexxdHuWhkonk6aIWLV06VhAS0p6/DF+H8KR/L3C/AwDnkWkgal+0ww2b3s35QAqHcbVgvA0VGK7E6CE7JK4nVTWJ4p1BjApeLwwWQrd4w+h+UFQqzrZVKuqWeZseL1V7X1kEO6XQuW4z6oUb/JIGZaokDp5Evyge5M/YrAdVahr0tlYIn4qO0elncluEubmYR5EMb0LDC42KXnGegh12EiHrnNvG7Mr7+82mN+kWI9haYIkng9Rv1/Y8wo+DuvXbQcAY5THZJlONAVPoCnuqFJDZUyllTCPuEn1dqNGAYvD9ccm0shnWaP3YRZof7TH9oUeP4wXT2Idg97xRqlp1mb0t6XO/au2K+ZULNsdk8MFIGzf3bUTO3/5eodFU=",
        "zelfName": "importtesttwo2.zelf",
        "publicData": {
            "ethAddress": "0x51791504D0E71261c908Cd85E915F36B7ead2026",
            "evm": "ETH,BNB,MATIC,AVAX,FTM,ARB,OP,CRO,ONE,KLAY,xDAI,GLMR,CELO,OKT,AURORA",
            "solanaAddress": "8dm6fQxfpR9ef4Z13ntVg4cVR8hnzNi9tJDTG9qH8Yc1",
            "btcAddress": "1DCe6a5DLmWaNLgUQg4mcbm7gGw5KtWg9U",
            "zelfName": "importtesttwo2.zelf",
            "leaseExpiresAt": "2025-11-15 19:51:41"
        },
        "ethAddress": "0x51791504D0E71261c908Cd85E915F36B7ead2026",
        "btcAddress": "1DCe6a5DLmWaNLgUQg4mcbm7gGw5KtWg9U",
        "solanaAddress": "8dm6fQxfpR9ef4Z13ntVg4cVR8hnzNi9tJDTG9qH8Yc1",
        "hasPassword": "false",
        "image": "",
        "leaseTransaction": {
            "id": "Irv89n76tXXlS2GQV0NHV5EwIex09RO6uUnwp_Njy-E",
            "timestamp": 1731718303631,
            "winc": "0",
            "version": "0.2.0",
            "deadlineHeight": 1548877,
            "dataCaches": [
                "arweave.net"
            ],
            "fastFinalityIndexes": [
                "arweave.net"
            ],
            "public": "wZgP9Rpfh0nXb5EdzBUg7y2LFMkBp2ADX3gdZhLXHYbz4srlYD6FUGn6Tt-WsSYj8faUyA7bNKj9zzcXiN-bsMC73e0yoQ05A_5I2QnBAgCTuzXePvUVCvSCOg1vdh07hSjvSBd1XiWDHw2J-Z7m6lG3l56PDSCp8t-s0PduONcsjqOePFejzkaJymJxMYp7d0g0GL1i1MrBAbf5ohIobyTYQz7bRHLLUpdSgiCiHbSBp092cIQnHYXGBeWb-lBEtMT9Am5GsHeVXq4eL8H83NBPIN4fIOtwpl7zzBUeaD5lTc3UcXliMjFuFJurVmNhqsP_osJMceybk3VIjdP0biqLqt_nRupdPwwJGQ09iyGv0wfzMBlx7zTZ9pp77ZBX3cDnYmWt2IR-mIgOStfiEHu5BuwNGBvGt7-tzHJp9e6IOofN10apfiuF9iQEQ3gFVQDZ7owQ_IrCq5yWLP7ePwYoB2e7ZbvCkd4JM8oOgEMZkywTOx3gLASGKS7wqUerdlYacWRukqg5MmkQRbzJIiY23pPwrhQSWon5q91jbImO6vTaHVDZnd2GoMFlePAsceNO1MaLS6GMuY-EAwOtaX-R1QZUpJmCzWfV-77AmBmaPDCR0mm3f7jy-3yYSCMAkti4idHVq5dIhOJnibd_LEfQtkTAQ5MQlE4uoa5lkJs",
            "signature": "B8nAS6PFbhKDVbcKMt74ddKLs6lIgj6j1JoLIBZhYbF2l_TKhDYEN_EYxCt4rXahTVZ3TCjcSv5k0FktQeK543DhyrlI3BbkCKbaJFt1UctObFhWKRlUm5bhcS-7DoIzLAptahKwiZaGouF-E1JlYVsMN322-_TC_-_dQwR374orvIv806fxmlt6eHWclFngyqK5Yxjxknya4dwQ-adstPJOKwife99RY6-3mJXymKQAkJzIwknPpt0JlOJdmjlOLjukke-WOU3-HKDeSMU1SaFydhMXZsxG5w5uLLgWiSlpWybcHuOPR2_kgmojirfk1y-9R2ADwRAgpZdGhzWK4jxMh8NB1eZCI8ZchB_IIC3iyGmdV6tb5BTE65cd4EMJQtd1JI9u9pdVXRJ8p2mIchEYYCKPpCdKAx0rXiN2LoEkqzQAjZA6YG0wNR9AuPhKj-6SpV7RM9QuqW9epckkq9Aer71lWhGLu6z6Sz8qNCoH59MxsBxgwEZ6imHx_tQnb8uU1lNZpxzxShHLnGHYlL-Ne4N0fZDCDwixFiPcBQqn3JzK3hd6iUT9qb1Bb0ZYopCesmC4AwlQju_PpJEsyfyq2h8cGE5TwaWZqD96pAkoXAGKk8BAzPdN_w6AwKuGjAqEcwhxYgZgynbx55B3TD-R6HA6yD2SyMFuxwmyjno",
            "owner": "vzrsUNMg17WFPmh73xZguPbn_cZzqnef3btvmn6-YDk",
            "url": "https://arweave.net/Irv89n76tXXlS2GQV0NHV5EwIex09RO6uUnwp_Njy-E",
            "explorerUrl": "https://viewblock.io/arweave/tx/Irv89n76tXXlS2GQV0NHV5EwIex09RO6uUnwp_Njy-E"
        },
        "ipfs": {
            "url": "https://blush-selective-earwig-920.mypinata.cloud/ipfs/bafkreihx4gedtunpwqt2dqhfvfsuimp5ksrpqgaqmmcvjpvwfekpenncea",
            "IpfsHash": "bafkreihx4gedtunpwqt2dqhfvfsuimp5ksrpqgaqmmcvjpvwfekpenncea",
            "PinSize": 18185,
            "Timestamp": "2024-11-16T00:51:44.106Z",
            "pinned": true,
            "web3": true,
            "name": "importtesttwo2.zelf",
            "metadata": {
                "ethAddress": "0x51791504D0E71261c908Cd85E915F36B7ead2026",
                "evm": "ETH,BNB,MATIC,AVAX,FTM,ARB,OP,CRO,ONE,KLAY,xDAI,GLMR,CELO,OKT,AURORA",
                "solanaAddress": "8dm6fQxfpR9ef4Z13ntVg4cVR8hnzNi9tJDTG9qH8Yc1",
                "btcAddress": "1DCe6a5DLmWaNLgUQg4mcbm7gGw5KtWg9U",
                "zelfName": "importtesttwo2.zelf",
                "leaseExpiresAt": "2025-11-15 19:51:41",
                "arweaveId": "Irv89n76tXXlS2GQV0NHV5EwIex09RO6uUnwp_Njy-E",
                "zelfProof": "ArbLPVaOMlgL2ck0idcuVRYTMQg2NZnbxLRNy7NCKgk2OXx7CaDNaJMAyeJGgZOV7czgcWftUbicRZPhKl95beFRbHkVJI2WptnHLCi+7RsFYL7PiAjKrnDw8hh77jLPx9YGbBGEe30b1a+bBSfRe7+YITu9Tuc7+x4I3FKmvgpPK14JRQToAL+Jf905x5qm6LmK3+1lgP7G66dr7Ho+8jRAsJHYiIg0o+d9SI2+jaS1ZlD0HwmqE3mXVvJTrwX+uxW0DcTU0hrm/RUtBw9RXTLQ6UhJrd9LonScplazsMJORHxRwrD2ORH+DySPPwan11rX7UglDkQ/luup+gZi/Qt6eX8Rbf9XvCqIgTmZHO4e9efY5jeQZwOftBFe1tYV9YkffJo8FLLxKdkcHl5X8uAh3wYBsqtwXwSuyHr4A12n9eOBos47lnKeyWnskjyVHECNLs1HyHCGlRi4c5lhX8SjBVZwMv0pYkGZa9BtlrGus0vIoNmHJUjdqca1xx0Wp9ztPhqy2bcUaz3+qLZrswf0cnc9G1hO42CviZk0loKixwkIvk5scTD0kTjYIqRpEpofUHGY15KJYel1fP1mJwG8S1GiWcqmufuAhsh36BPX+zf0LV9pUs6NSl29u7J6I7W3Ph3U6zWlveVUP5erATVjr3biX1KzzobT4Av3VVjPOy2qQCIHW+ltVTT+DnwqmvbWtCkD1xpkc0trQcU1rTFuj5VMGR1aVpICvlcs2hLwpspEnDOexxdHuWhkonk6aIWLV06VhAS0p6/DF+H8KR/L3C/AwDnkWkgal+0ww2b3s35QAqHcbVgvA0VGK7E6CE7JK4nVTWJ4p1BjApeLwwWQrd4w+h+UFQqzrZVKuqWeZseL1V7X1kEO6XQuW4z6oUb/JIGZaokDp5Evyge5M/YrAdVahr0tlYIn4qO0elncluEubmYR5EMb0LDC42KXnGegh12EiHrnNvG7Mr7+82mN+kWI9haYIkng9Rv1/Y8wo+DuvXbQcAY5THZJlONAVPoCnuqFJDZUyllTCPuEn1dqNGAYvD9ccm0shnWaP3YRZof7TH9oUeP4wXT2Idg97xRqlp1mb0t6XO/au2K+ZULNsdk8MFIGzf3bUTO3/5eodFU=",
                "hasPassword": "false"
            }
        }
    }
}
  • 403 Forbidden: The API Key is incorrect or there is an issue with licensing. Possible error codes include:

    • ERR_CANNOT_CONNECT_TO_TIME_SERVER: Cannot connect to the time server to verify license expiry.

    • ERR_CANNOT_CONNECT_TO_HOME_SERVER: Cannot connect to the home server to verify license expiry.

    • ERR_NUMBER_OF_AVAILABLE_INSTANCES_EXCEEDED: The number of available instances for this license has been exceeded.

  • 413 Payload Too Large: The request sent is too large. Reduce the size of the image or data.

  • 422 Un processable Entity: The request is invalid due to a specific error related to its content.

Error Codes

Here are some specific error codes that might be returned:

  • ERR_INVALID_IMAGE: Invalid base64 string for the face image.

  • ERR_NO_FACE_DETECTED: No face detected in the image.

  • ERR_MULTIPLE_FACES_DETECTED: Multiple faces detected in the image.

  • ERR_REF_FACE_NOT_MATCHED: Reference face does not match the input face.

  • ERR_LIVENESS_FAILED: Liveness check failed for the input face.

  • ERR_LIVENESS_FACE_ANGLE_TOO_LARGE: The face angle is too large, making liveness check impossible.

  • ERR_LIVENESS_FACE_IS_OCCLUDED: The face is occluded (e.g., by a mask).

  • ERR_LIVENESS_FACE_CLOSE_TO_BORDER: The face is too close to the border of the image.

  • ERR_LIVENESS_FACE_TOO_SMALL: The face is too small in the image.

  • ERR_LIVENESS_EYES_CLOSED: The eyes are closed in the image.

Last updated