5. Import a Wallet

Endpoint: Import Wallet

POST /api/wallets/import

This endpoint is used to import a wallet by decrypting the provided data (such as password, mnemonic, and face) and creating a wallet on multiple blockchain platforms (e.g., Ethereum and Solana). The imported wallet is then securely stored and associated with the authenticated user.

Request

  • Endpoint: /api/wallets/import

  • Method: POST

  • Content-Type: application/json

Request Body

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

{
  "password": "PGP_encrypted_password_here",
  "phrase": "PGP_encrypted_mnemonic_phrase_here",
  "faceBase64": "PGP_encrypted_face_base64_here",
  "addServerPassword": true,
  "preview": true, // optional
  "removePGP": false // not recommended to remove it, only if you want to use this endpoint outside the extension
}

Fields:

  • password: string (Optional) - The PGP encrypted password for the wallet. It will be decrypted on the server side.

  • phrase: string (Optional) - The PGP encrypted mnemonic phrase used to generate the wallet addresses. It will be decrypted on the server side.

  • faceBase64: string (Optional) - The PGP encrypted Base64-encoded facial data used for additional security or biometric verification. It will be decrypted on the server side.

  • addServerPassword: Boolean (Optional) - If true, a server-side password will be added to enhance security.

  • preview: Boolean(Optional) - If true, we return to you the ZelfProof without PGP encryption but in our servers will be added with the PGP Encryption to enhance security.

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

Example Request

POST /api/wallets/import
Content-Type: application/json

{
  "password": "encrypted_password_here",
  "phrase": "encrypted_mnemonic_phrase_here",
  "faceBase64": "encrypted_face_base64_here",
  "addServerPassword": true
}

Response

  • 200 OK: The request was successful, and the wallet has been imported. The response contains details about the created wallet.

    • Response Body:

      {
          "data": {
              "anonymous": true,
              "image": "",
              "hasPassword": false,
              "_id": "66d0c0dadb9486e043a3b990",
              "publicData": {
                  "ethAddress": "0x13901AE0F17E2875E86C86721f9943598601b0C4",
                  "solanaAddress": "7PEBTVnsabjvKCVkfwpNoobL8rtFc94Y8wGsWUBCzhJL",
                  "_id": "66d0c0dadb9486e043a3b990"
              },
              "zkProof": "12707847629149040977521395823329402223532494818827739213474645465059279103659",
              "ethAddress": "0x13901AE0F17E2875E86C86721f9943598601b0C4",
              "solanaAddress": "7PEBTVnsabjvKCVkfwpNoobL8rtFc94Y8wGsWUBCzhJL",
              "zelfProof": "-----BEGIN PGP MESSAGE-----\n\nwV4D+9l2F3wlFIoSAQdAzc6RNzoHGUC1j3ESZddVuLB1nI+d/heeRrqczvk/\nOwMwJMgVcUng8QeePOV3CdQs2MIydpxHHIKFUGOt7bZ0w1r97EXJ7EmJEPld\nMcdl9zl/0sLCATYkBRp/ys2BmNGo6lyl9VN6h93LyXvYz2oi3MOnu3XVGb4y\n8Y/XS9A1WXi+e1j4SMAbD74K8bR7DXfXIXDfJs4AVbB6pL0R1FBFWG4W1YdJ\nXV7jxOUQWoRCfTsbqeJeFQ9ZYIyoQ+QfFip7KkM72P6/WtMbAFw6oZXfnPxS\nPy+PgVwR8rNNn8vrW9dtlyU4/P+VsdHmyxjfFN5ufK9qTr+gfgNfZobc8mrz\nArbXOZ7PFSbbVWUCdQdbDLgPfE1PfoekN/G6svsyKguQsAw4qVq5SrFnNSF7\notiOwwtqkleHVZzDkAxk0LrXHEOwq0uiYw0S8gj/skdc03BSnX/9hfEyowJR\nDfJu/WgE74EzyNP+sMTOsxWyjZJKByRT4TZuMKoDQkbCYoA8TinXkaTX7VJV\noF99AY8H7oE6fDPbUjaiBoFTIMMxqtycWQHW8mH3pQlgdUtc5V8tWqrNsGeW\nAJJvJlpfXF6jH2aM+cRLwrWN/Dz10XNqvvpFkT5xZrHk2L1vJ35ahFme94Ko\n4zWQNcV+qniXwYPHCBC+Nk1oyb2HZCh3YugH6390mm6GE/KC7i1/NRStupQv\neP4dRwSGJ7wKTQ1PHse7wzYewIQw9TKEZmjpB0UrB8Y9Km8O1NWHstMYJVZW\nNIxy3jOM/zU4fMxchiTQBlKqUUrCEarfpjsNrKn37N8SfKxTvDO/RbVifC8F\nXVjw9gVcPMnqxLLcvYpuuY5Lsjy7rWo3OGvqFQz3o/9UrHQiZ0h6XqRS6NfK\noP3Vvqkfu9QMhweORnFZOn8oGR3m+1D+qQqsgb62FgEvf2Rg64hDuHLGuPw6\nfjm1LLBCPp8jtUgi1swZp+HihCffBrYscQfZopmODJ70XmW3yU5CjXAiE+/i\nZC2GPSIAMph/y+n8zZ6El1A91kulXH3Z5lyM21R/idueDrpCgmJlldgfclhj\nt+iZrI2FNbQtXNz+e4zFxdSwNTe6jw7L/5TX2HsGP6PdBDZIPv6FB0aw5gu0\n80zpEWVBpECQVJKEMFitqI+ejmeDbIeYF2ZSuuvbLZnCWqQY6TvBGBXICyH0\nJ/bby/rengQ7IaXI5iJdZZ3s8KacPrQ/nZn+GbSs0bd5vKXgl9s9lZogkVij\ndySKxpny7KhmOLaN4i0dn3dCZ+y+nZeG25MRGcN5i88GESMPD6AkOasJ/TAE\n6aV4KESqLA==\n=lpLM\n-----END PGP MESSAGE-----\n",
              "updatedAt": "2024-08-29T18:41:33.479Z",
              "createdAt": "2024-08-29T18:41:33.479Z",
              "__v": 0
          }
      }

Internal Workflow Explanation

  1. Decryption of Parameters:

    • The server receives encrypted data (password, mnemonic, faceBase64) and uses the _decryptParams function to decrypt these values. The decryption is performed using the authenticated user's private key, which is securely retrieved using the _getPrivateKey function.

  2. Wallet Creation:

    • Once the mnemonic phrase is decrypted, it is used to generate wallet addresses for different blockchains. The example provided shows the creation of Ethereum (ethAddress) and Solana (solanaAddress) wallets using the createEthWallet and createSolanaWallet functions respectively.

  3. Data Encryption for Storage:

    • The wallet data, including the blockchain addresses and decrypted mnemonic, is prepared for storage. This data is encrypted using the user’s face, password, and other parameters to ensure that it remains secure even when stored.

  4. Saving the Wallet:

    • The final step is saving the imported wallet using the _saveImportedWallet function, which securely stores the wallet data in the database, ensuring that it is associated with the authenticated user.

Use Cases

  • Multi-Blockchain Wallet Management: Users can import wallets that work across multiple blockchains (e.g., Ethereum, Solana) using a single mnemonic phrase, all while ensuring that their sensitive data remains encrypted and secure.

  • Biometric Security Integration: This endpoint allows the use of facial recognition as part of the encryption and decryption process, adding an extra layer of security for wallet management.

Error Handling

  • 409 Conflict: Returned if the user is not passing the required params.

  • 500 Internal Server Error: Returned if there is an issue on the server side while processing the request, such as failed wallet creation or saving.

Security Considerations

  • Encryption and Decryption:

    • All sensitive data (password, mnemonic, face) is encrypted before being sent to the server and is decrypted securely on the server side using the authenticated user’s private key. This ensures that no sensitive information is exposed in transit or at rest.

  • PGP Key Management:

    • The decryption process relies on the server securely retrieving and using the user’s PGP private key. This key is never exposed or transmitted insecurely, ensuring that the decryption of sensitive data is handled securely.

  • Biometric Integration:

    • The use of facial data as part of the encryption process ensures that the wallet can only be imported and accessed by the rightful owner, adding an additional layer of biometric security.

Last updated