mirror of
https://github.com/monero-project/meta.git
synced 2025-01-10 04:44:31 +00:00
Add support for subaddresses in lightwallet API
This commit is contained in:
parent
37b5fc40ea
commit
4091a2e5ef
1 changed files with 48 additions and 22 deletions
|
@ -51,7 +51,15 @@ concept - a public key or hash.
|
||||||
|
|
||||||
**base58-address**
|
**base58-address**
|
||||||
|
|
||||||
A standard Monero public address encoded as a string in JSON.
|
A Monero public address encoded as a string in JSON.
|
||||||
|
|
||||||
|
**address_meta** object
|
||||||
|
|
||||||
|
| Field | Type | Description |
|
||||||
|
|---------------|------------------|------------------------|
|
||||||
|
| `address` | `base58-address` | Monero public address |
|
||||||
|
| `major_index` | `uint32` | Subaddress major index |
|
||||||
|
| `minor_index` | `uint32` | Subaddress minor index |
|
||||||
|
|
||||||
**output** object
|
**output** object
|
||||||
|
|
||||||
|
@ -71,6 +79,7 @@ Information needed to spend an output.
|
||||||
| spend_key_images | array of `binary` objects | Bytes of key images |
|
| spend_key_images | array of `binary` objects | Bytes of key images |
|
||||||
| timestamp | `timestamp` | Timestamp of containing block |
|
| timestamp | `timestamp` | Timestamp of containing block |
|
||||||
| height | `uint64` | Containing block height |
|
| height | `uint64` | Containing block height |
|
||||||
|
| recipient | `address_meta` object | Address data of the recipient |
|
||||||
|
|
||||||
> `tx_id` is determined by the monero daemon. It is the offset that a
|
> `tx_id` is determined by the monero daemon. It is the offset that a
|
||||||
> transaction appears in the blockchain from the genesis block.
|
> transaction appears in the blockchain from the genesis block.
|
||||||
|
@ -122,12 +131,13 @@ Information needed to spend an output.
|
||||||
**spend** object
|
**spend** object
|
||||||
|
|
||||||
| Field | Type | Description |
|
| Field | Type | Description |
|
||||||
|------------|-----------------|----------------------------|
|
|------------|-----------------------|----------------------------|
|
||||||
| amount | `uint64-string` | XMR possibly being spent |
|
| amount | `uint64-string` | XMR possibly being spent |
|
||||||
| key_image | `binary` | Bytes of the key image |
|
| key_image | `binary` | Bytes of the key image |
|
||||||
| tx_pub_key | `binary` | Bytes of the tx public key |
|
| tx_pub_key | `binary` | Bytes of the tx public key |
|
||||||
| out_index | `uint16` | Index of source output |
|
| out_index | `uint16` | Index of source output |
|
||||||
| mixin | `uint32` | Mixin of the spend |
|
| mixin | `uint32` | Mixin of the spend |
|
||||||
|
| sender | `address_meta` object | Address data of the sender |
|
||||||
|
|
||||||
> `out_index` is a zero-based offset from the original received output. The
|
> `out_index` is a zero-based offset from the original received output. The
|
||||||
> variable within the monero codebase is the `vout` array, this is the index
|
> variable within the monero codebase is the `vout` array, this is the index
|
||||||
|
@ -210,20 +220,23 @@ Randomly selected outputs for use in a ring signature.
|
||||||
|
|
||||||
### Methods
|
### Methods
|
||||||
#### `get_address_info`
|
#### `get_address_info`
|
||||||
Returns the minimal set of information needed to calculate a wallet balance.
|
Returns the minimal set of information needed to calculate a wallet balance,
|
||||||
The server cannot calculate when a spend occurs without the spend key, so a
|
including the balance of subaddresses. The server cannot calculate when a spend
|
||||||
list of candidate spends is returned.
|
occurs without the spend key, so a list of candidate spends is returned.
|
||||||
|
|
||||||
**Request** object
|
**Request** object
|
||||||
|
|
||||||
| Field | Type | Description |
|
| Field | Type | Description |
|
||||||
|-----------|------------------|---------------------------------------|
|
|-----------|------------------|---------------------------------------|
|
||||||
| address | `base58-address` | Address to retrieve |
|
| address | `base58-address` | Standard address of the wallet |
|
||||||
| view_key | `binary` | View key bytes for authorization |
|
| view_key | `binary` | View key bytes for authorization |
|
||||||
|
|
||||||
> If `address` is not authorized, the server must return a HTTP 403
|
> If `address` is not authorized, the server must return a HTTP 403
|
||||||
> "Forbidden" error.
|
> "Forbidden" error.
|
||||||
|
|
||||||
|
> If `address` is not a standard address, the server must return a HTTP 400
|
||||||
|
> "Bad Request" error.
|
||||||
|
|
||||||
**Response** object
|
**Response** object
|
||||||
|
|
||||||
| Field | Type | Description |
|
| Field | Type | Description |
|
||||||
|
@ -244,18 +257,22 @@ list of candidate spends is returned.
|
||||||
#### `get_address_txs`
|
#### `get_address_txs`
|
||||||
Returns information needed to show transaction history. The server cannot
|
Returns information needed to show transaction history. The server cannot
|
||||||
calculate when a spend occurs without the spend key, so a list of candidate
|
calculate when a spend occurs without the spend key, so a list of candidate
|
||||||
spends is returned.
|
spends is returned. The response should show a wallet's entire history,
|
||||||
|
including transactions to and from subaddresses.
|
||||||
|
|
||||||
**Request** object
|
**Request** object
|
||||||
|
|
||||||
| Field | Type | Description |
|
| Field | Type | Description |
|
||||||
|----------|------------------|---------------------------------------|
|
|----------|------------------|---------------------------------------|
|
||||||
| address | `base58-address` | Address to retrieve |
|
| address | `base58-address` | Standard address of the wallet |
|
||||||
| view_key | `binary` | View key bytes for authorization |
|
| view_key | `binary` | View key bytes for authorization |
|
||||||
|
|
||||||
> If `address` is not authorized, the server must return a HTTP 403
|
> If `address` is not authorized, the server must return a HTTP 403
|
||||||
> "Forbidden" error.
|
> "Forbidden" error.
|
||||||
|
|
||||||
|
> If `address` is not a standard address, the server must return a HTTP 400
|
||||||
|
> "Bad Request" error.
|
||||||
|
|
||||||
**Response** object
|
**Response** object
|
||||||
|
|
||||||
| Field | Type | Description |
|
| Field | Type | Description |
|
||||||
|
@ -300,14 +317,14 @@ locally select outputs using a triangular distribution
|
||||||
> shall omit the `outputs` field in `amount_outs`.
|
> shall omit the `outputs` field in `amount_outs`.
|
||||||
|
|
||||||
#### `get_unspent_outs`
|
#### `get_unspent_outs`
|
||||||
Returns a list of received outputs. The client must determine when the output
|
Returns a list of received outputs to the wallet, including to subaddresses.
|
||||||
was actually spent.
|
The client must determine when the output was actually spent.
|
||||||
|
|
||||||
**Request** object
|
**Request** object
|
||||||
|
|
||||||
| Field | Type | Description |
|
| Field | Type | Description |
|
||||||
|------------------|------------------|----------------------------------|
|
|------------------|------------------|----------------------------------|
|
||||||
| address | `base58-address` | Address to create/probe |
|
| address | `base58-address` | Standard address of the wallet |
|
||||||
| view_key | `binary` | View key bytes |
|
| view_key | `binary` | View key bytes |
|
||||||
| amount | `uint64-string` | XMR send amount |
|
| amount | `uint64-string` | XMR send amount |
|
||||||
| mixin | `uint32` | Minimum mixin for source output |
|
| mixin | `uint32` | Minimum mixin for source output |
|
||||||
|
@ -317,6 +334,9 @@ was actually spent.
|
||||||
> If the total received outputs for the address is less than `amount`, the
|
> If the total received outputs for the address is less than `amount`, the
|
||||||
> server shall return a HTTP 400 "Bad Request" error code.
|
> server shall return a HTTP 400 "Bad Request" error code.
|
||||||
|
|
||||||
|
> If `address` is not a standard address, the server must return a HTTP 400
|
||||||
|
> "Bad Request" error.
|
||||||
|
|
||||||
**Response** object
|
**Response** object
|
||||||
|
|
||||||
| Field | Type | Description |
|
| Field | Type | Description |
|
||||||
|
@ -332,8 +352,8 @@ Request an account scan from the genesis block.
|
||||||
**Request** object
|
**Request** object
|
||||||
|
|
||||||
| Field | Type | Description |
|
| Field | Type | Description |
|
||||||
|----------|------------------|-------------------------|
|
|----------|------------------|--------------------------------|
|
||||||
| address | `base58-address` | Address to create/probe |
|
| address | `base58-address` | Standard address of the wallet |
|
||||||
| view_key | `binary` | View key bytes |
|
| view_key | `binary` | View key bytes |
|
||||||
|
|
||||||
**Response** object
|
**Response** object
|
||||||
|
@ -350,6 +370,9 @@ Request an account scan from the genesis block.
|
||||||
> `payment_id`, `import_fee`, and `payment_address` may be omitted if the
|
> `payment_id`, `import_fee`, and `payment_address` may be omitted if the
|
||||||
> client does not need to send XMR to complete the request.
|
> client does not need to send XMR to complete the request.
|
||||||
|
|
||||||
|
> If `address` is not a standard address, the server must return a HTTP 400
|
||||||
|
> "Bad Request" error.
|
||||||
|
|
||||||
#### `login`
|
#### `login`
|
||||||
Check for the existence of an account or create a new one.
|
Check for the existence of an account or create a new one.
|
||||||
|
|
||||||
|
@ -357,7 +380,7 @@ Check for the existence of an account or create a new one.
|
||||||
|
|
||||||
| Field | Type | Description |
|
| Field | Type | Description |
|
||||||
|-------------------|------------------|----------------------------------|
|
|-------------------|------------------|----------------------------------|
|
||||||
| address | `base58-address` | Address to create/probe |
|
| address | `base58-address` | Standard address of the wallet |
|
||||||
| view_key | `binary` | View key bytes |
|
| view_key | `binary` | View key bytes |
|
||||||
| create_account | `boolean` | Try to create new account |
|
| create_account | `boolean` | Try to create new account |
|
||||||
| generated_locally | `boolean` | Indicate that the address is new |
|
| generated_locally | `boolean` | Indicate that the address is new |
|
||||||
|
@ -372,6 +395,9 @@ Check for the existence of an account or create a new one.
|
||||||
> must be returned. Subsequent requests shall be HTTP 403 "Forbidden" until
|
> must be returned. Subsequent requests shall be HTTP 403 "Forbidden" until
|
||||||
> account is approved.
|
> account is approved.
|
||||||
|
|
||||||
|
> If `address` is not a standard address, the server must return a HTTP 400
|
||||||
|
> "Bad Request" error.
|
||||||
|
|
||||||
**Response** object
|
**Response** object
|
||||||
|
|
||||||
| Field | Type | Description |
|
| Field | Type | Description |
|
||||||
|
|
Loading…
Reference in a new issue