1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
|
Return-Path: <earonesty@gmail.com>
Received: from silver.osuosl.org (smtp3.osuosl.org [140.211.166.136])
by lists.linuxfoundation.org (Postfix) with ESMTP id 08A90C0893
for <bitcoin-dev@lists.linuxfoundation.org>;
Wed, 23 Dec 2020 21:13:44 +0000 (UTC)
Received: from localhost (localhost [127.0.0.1])
by silver.osuosl.org (Postfix) with ESMTP id DE5CA2E106
for <bitcoin-dev@lists.linuxfoundation.org>;
Wed, 23 Dec 2020 21:13:43 +0000 (UTC)
X-Virus-Scanned: amavisd-new at osuosl.org
Received: from silver.osuosl.org ([127.0.0.1])
by localhost (.osuosl.org [127.0.0.1]) (amavisd-new, port 10024)
with ESMTP id VxAFnqsmw0Jk
for <bitcoin-dev@lists.linuxfoundation.org>;
Wed, 23 Dec 2020 21:13:42 +0000 (UTC)
X-Greylist: domain auto-whitelisted by SQLgrey-1.7.6
Received: from mail-pj1-f47.google.com (mail-pj1-f47.google.com
[209.85.216.47])
by silver.osuosl.org (Postfix) with ESMTPS id CB6C72E105
for <bitcoin-dev@lists.linuxfoundation.org>;
Wed, 23 Dec 2020 21:13:42 +0000 (UTC)
Received: by mail-pj1-f47.google.com with SMTP id lj6so54169pjb.0
for <bitcoin-dev@lists.linuxfoundation.org>;
Wed, 23 Dec 2020 13:13:42 -0800 (PST)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed;
d=q32-com.20150623.gappssmtp.com; s=20150623;
h=mime-version:references:in-reply-to:from:date:message-id:subject:to
:content-transfer-encoding;
bh=l9uamEOm25jPwWBCLFrc/x+AKGj0GqeNCa+doUK9ZVo=;
b=iU7NoMKQv+mMgpGSrrHmeZMClkdy/kitJMsFq2fwylBb4oUVwpvoRe//ivGuDHIhp5
Xg6WLsdU84Vw5ladBwTZEStMpv0HojDm4O8pXPNi/DzBbN7YOmJKTB5g5fQLrYJkBo9y
6ia6e+E//U3ld89IfJSFXoziWVr7khGo65I410UlCFl3lhuWJijlsuow7LyLk3y3xl73
KmfGQrqA+uW0ZHGXO++JsOumyj5fogui26sr19b2oZZQUPKgF0m7XHSZKiost3A0G4Xz
8PrEPCqd71kWUjx1w01nj36iYCmShbbkC+phCXrjONJtfYCy8CflwpAnu1GPOotIGD3O
3c+g==
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed;
d=1e100.net; s=20161025;
h=x-gm-message-state:mime-version:references:in-reply-to:from:date
:message-id:subject:to:content-transfer-encoding;
bh=l9uamEOm25jPwWBCLFrc/x+AKGj0GqeNCa+doUK9ZVo=;
b=tEvhXBL9H2BAhj297+lZ2CKDwlgnZZPZpxZ8LVpnMPVahyv4gugvCKAjDX44ueMPMK
ry6BayWlPuKSqkSJAPQSkzZDrMVIb/+W1S+OL/3PJyYpgms6xn8RZ8hk+kzhK+r1n9wd
rkVopu2UWZONMww+F1ebF+fLtt25U8HwcGy4ee1LDka0FFbv3yiHLqfSZOh29CdAa9yI
zsPC//KKl0eKC2vDGUsStKNdBflVll/bgmQXBxpdZdyjZokVMDqS+Nq9ANtAGxdWlGey
63zwzbHJSMpYZzQdRLnc2HeKeJILNccI+8dOfo5R3d/TyvSUmkMieQmykDqomUpWiwdd
7DqQ==
X-Gm-Message-State: AOAM532SMPNKZkBAoKwVvIK4zj+UzrE2DExaIrVhP6qASX4C67Lfr+WO
sMq48/BZPhmM1HDurauWlP/sK/hY+7yYCkMne5ZjcQ0=
X-Google-Smtp-Source: ABdhPJw634LfDgHaC6itLXb7dyKcQqNXkQ3Q1g0t7OrIzSvfvorTFviNNhfY84WFOIfTlLCsjmgYzk3t1OdEfOGRZ6w=
X-Received: by 2002:a17:902:6ac9:b029:dc:2fe7:d949 with SMTP id
i9-20020a1709026ac9b02900dc2fe7d949mr5003962plt.2.1608758022228; Wed, 23 Dec
2020 13:13:42 -0800 (PST)
MIME-Version: 1.0
References: <CAPvWj7H9hg8EMCvDzWiq=f59KojHEGCm_iAP+FBaB+25=CLt0A@mail.gmail.com>
In-Reply-To: <CAPvWj7H9hg8EMCvDzWiq=f59KojHEGCm_iAP+FBaB+25=CLt0A@mail.gmail.com>
From: Erik Aronesty <erik@q32.com>
Date: Wed, 23 Dec 2020 16:13:29 -0500
Message-ID: <CAJowKg+wE2SO5hcSbcNzPCtjetgBxXo5ejkFUV=mQrxxUh1-5w@mail.gmail.com>
To: monokh <mnokhb@gmail.com>,
Bitcoin Protocol Discussion <bitcoin-dev@lists.linuxfoundation.org>
Content-Type: text/plain; charset="UTF-8"
Content-Transfer-Encoding: quoted-printable
X-Mailman-Approved-At: Thu, 24 Dec 2020 02:15:26 +0000
Subject: Re: [bitcoin-dev] BIP Proposal: Wallet Interface
X-BeenThere: bitcoin-dev@lists.linuxfoundation.org
X-Mailman-Version: 2.1.15
Precedence: list
List-Id: Bitcoin Protocol Discussion <bitcoin-dev.lists.linuxfoundation.org>
List-Unsubscribe: <https://lists.linuxfoundation.org/mailman/options/bitcoin-dev>,
<mailto:bitcoin-dev-request@lists.linuxfoundation.org?subject=unsubscribe>
List-Archive: <http://lists.linuxfoundation.org/pipermail/bitcoin-dev/>
List-Post: <mailto:bitcoin-dev@lists.linuxfoundation.org>
List-Help: <mailto:bitcoin-dev-request@lists.linuxfoundation.org?subject=help>
List-Subscribe: <https://lists.linuxfoundation.org/mailman/listinfo/bitcoin-dev>,
<mailto:bitcoin-dev-request@lists.linuxfoundation.org?subject=subscribe>
X-List-Received-Date: Wed, 23 Dec 2020 21:13:44 -0000
Obviously Bitcoin has a wallet api, intermingled with other protocol APIs:
https://en.bitcoin.it/wiki/Original_Bitcoin_client/API_calls_list
For security, a standard wallet API should write a token/port to a
local file where the user can grab that token and use it (that's
basically how the existing bitcoind does it, with a username/password
living in a file... not as nice as a token/port, IMO)
Probably any such standards document should do its best to be
compatible with the existing APIs that so many are already familiar
with. Or maybe I misunderstand the proposal.
- Erik
On Tue, Dec 22, 2020 at 9:48 AM monokh via bitcoin-dev
<bitcoin-dev@lists.linuxfoundation.org> wrote:
>
> Hi
>
> This is a first draft of a BIP we intend to submit. The main intention is=
to define a simple interface that wallets and applications can agree on th=
at would cover the vast majority of use cases. This can enable writing bitc=
oin applications (e.g. time lock, multi sig) on the web that can be seamles=
sly used with any compatible wallets. We have implementations of such examp=
les but I don't want to turn this thread into a promotion and rather focus =
on the spec.
>
> Appreciate input from the list. Please share if there are existing effort=
s, relevant specs or use cases.
>
> ------------------------------
>
> A wallet interface specification for bitcoin applications
>
> ## Abstract
>
> This BIP describes an API for Bitcoin wallets and applications as a stand=
ard.
>
> ## Summary
>
> Bitcoin wallets should expose their address derivation and signing functi=
ons to external applications. The interface would be expressed as follows i=
n javascript:
>
> ```
> {
> // Wallet Metadata
> wallet: {
> name: 'Bitcoin Core'
> },
>
> // Request access to the wallet for the current host
> async enable: (),
>
> // Request addresses and signatures from wallet
> async request ({ method, params })
> }
> ```
>
> In the web context the interface could be exposed at the top level of a w=
ebpage, for example under `window.bitcoin`. However this spec does not inte=
nd to define any standards for how and where the interfaces should be expos=
ed.
>
> ## Motivation
>
> Due to the seldom available APIs exposed by wallets, applications (web or=
otherwise) are limited in how they are able to interact. Generally only si=
mple sends have been available. A more robust API that introduces other req=
uests will promote richer Bitcoin applications.
>
> Additionally, wallet APIs have frequently included inconsistencies in the=
ir interfaces and behaviour. This has required applications to build and ma=
intain a separate client for each wallet, increasing the risk of bugs and u=
nintended behaviour as well as being a limiting factor for the adoption of =
usable bitcoin applications.
>
> With a standardised wallet API:
>
> - Wallets have a clear API to implement
> - Applications have a clear expectation of wallet interface and behaviour
> - Applications become agnostic to the wallet specifics, increasing choice=
for users
>
> If more wallets implement the specification, applications will be develop=
ed more confidently by benefiting from the wallet interoperability. This cr=
eates a positive feedback loop.
>
> ## Specification
>
> For simplicity, the interface is defined in the context of web applicatio=
ns running in the browser (JS) however, they are simple enough to be easily=
implemented in other contexts.
>
> ### General Rules
>
> - For sensitive functions (e.g. signing), wallet software should always p=
rompt the user for confirmation
>
> ### Types
>
> **UserDeniedError**
> An error type indicating that the application's request has been denied b=
y the user
> Type: Error
>
> **Hex**
> Type: String
> Example: `"0000000000000000000a24677957d1e50d70e67c513d220dbe8868c4c3aefc=
08"`
>
> **Address**
> Address details
> Type: Object
> Example:
>
> ```
> {
> "address": "bc1qn0fqlzamcfuahq6xuujrq08ex7e26agt20gexs",
> "publicKey": "02ad58c0dced71a236f4073c3b6f0ee27dde6fe96978e9a9c9500172e3f=
1886e5a",
> "derivationPath": "84'/1'/0'/0/0"
> }
> ```
>
> ### API
>
> The wallet must implement the following methods.
>
> **enable**
>
> The enable call prompts the user for access to the wallet.
>
> If successful, it resolves to an address (`**Address**` type) of the wall=
et. Typically the first external address to be used as an identity.
>
> **`UserDeniedError`** will be thrown if the request is rejected.
>
> **request**
>
> The request method must take one parameter in the following format:
>
> ```
> {
> "method": "wallet_methodName",
> "params": ["foo", "bar", "baz"]
> }
> ```
>
> For a list of mandatory methods see Table
>
> The wallet should reject request calls unless `enable` has been resolved.
>
> Sensitive requests that involve signing should always prompt the user for=
confirmation
>
> On success the request should resolve to the response as defined in the m=
ethod table.
>
> **`UserDeniedError`** will be thrown if the request is rejected.
>
> **Mandatory methods**
>
> method: `wallet_getAddresses` params: [`index =3D 0, numAddresses =3D 1, =
change =3D false`]
> return: `[ Address ]`
> error: UserDeniedError
>
> method: `wallet_signMessage` params: `[ message, address ]`
> return: Signature `Hex`
> error: UserDeniedError
>
> method: `wallet_signPSBT` params: `[ [psbtBase64, inputIndex, address] ]`
> return: `psbtBase64`
> error: UserDeniedError
>
> method: `wallet_getConnectedNetwork` params: `[]`
> return: Network object `mainnet` | `testnet` | `regetst`
> error: UserDeniedError
>
> ## Rationale
>
> The purpose of the API is to expose a set of commonly used wallet operati=
ons. In addition, it should be flexible enough to serve for other requests =
such as node RPC calls.
>
> **Why is there a singular request call instead of named methods?**
> The transport layer for the requests cannot be assumed, therefore it is m=
uch more flexible to instead define an abstract format.
>
> **Why are the mandatory methods so primitive? Where is getBalance, getUtx=
os, ... ?**
> A wallet need not worry about providing every possible scenario for usage=
. The primitives of keys and signing can expose enough to applications to d=
o the rest. Applications should have flexibility in how they implement thes=
e functions. It is the role of a library rather than the wallet.
>
> ## Security Implications
>
> Great care should be taken when exposing wallet functionality externally =
as the security and privacy of the user is at risk.
>
> ### Signing
>
> Operations that trigger signing using private keys should be guarded behi=
nd confirmation screens where the user is fully aware of the nature of the =
transaction. In the example of a PSBT signature request, the outputs, the i=
nputs and which key is being used should be clearly marked.
>
> ### Privacy
>
> Some api methods expose metadata about the user, such as public keys. Dep=
ending on how privacy focused the wallet intends to be, the wallet could pr=
otect these behind a confirmation. Commonly the wallet just needs to give t=
he origin access to all of its public keys, however it could also allow the=
option to expose only selected derivation paths.
>
> -monokh
>
> _______________________________________________
> bitcoin-dev mailing list
> bitcoin-dev@lists.linuxfoundation.org
> https://lists.linuxfoundation.org/mailman/listinfo/bitcoin-dev
|