Create a Zelf Name

Creating a zelf name from the web extension (beta).


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

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

  • Method: POST

  • Content-Type: application/json

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.

Responses

{
    "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.

Frequently Asked Questions (FAQs)

Q: What happens if someone else tries to generate a ZelfProof using my face?

A: Zelf's algorithm ensures that each ZelfProof is unique and tied to the specific conditions (metadata, password) provided at the time of creation. Without the exact same inputs, a different ZelfProof will be generated, preventing unauthorized access. That without considering that we require a liveness detection on the encryption as one of the params of our SDK/API function.

Q: Can the Zelf be used across different wallets/platforms?

A: Yes, a ZelfProof can be used across various platforms for authentication, encryption, and verification purposes. The integration is seamless and designed to work in diverse environments.

Last updated