This repository has been archived by the owner on Mar 8, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 17
/
self-sov-verifiable-payid-protocol.txt
896 lines (580 loc) · 29.8 KB
/
self-sov-verifiable-payid-protocol.txt
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
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
Network Working Group A. Malhotra
Internet-Draft D. Schwartz
Intended status: Standards Track Ripple
Expires: February 5, 2021 August 04, 2020
Self-Sovereign Verifiable PayID
draft-aanchal-self-sov-verifiable-payid-protocol
Abstract
This specification defines one of the extensions of the Basic PayID
protocol [PAYID-PROTOCOL] that aims to enable trust-minimized PayID
service. Specifically, this extension of Basic PayID protocol
eliminates the trust requirement between the PayID owner and their
PayID service provider by allowing PayID server operators (such as
wallets/exchanges) to send payment account(s) address information
associated with a PayID [PAYID-URI] that is digitally signed with the
PayID private key of the PayID owner along with PayID owner's
"identity" information and other meta-data needed to verify the
signature. As a result, Self-Sovereign Verifiable PayID enables
PayID service providers to match the security model of applications
such as non-custodial digital wallets.
Feedback
This specification is a draft proposal, and is part of the PayID
Protocol [1] initiative. Feedback related to this document should be
sent in the form of a Github issue at: https://github.com/payid-
org/rfcs/issues.
Status of This Memo
This Internet-Draft is submitted in full conformance with the
provisions of BCP 78 and BCP 79.
Internet-Drafts are working documents of the Internet Engineering
Task Force (IETF). Note that other groups may also distribute
working documents as Internet-Drafts. The list of current Internet-
Drafts is at https://datatracker.ietf.org/drafts/current/.
Internet-Drafts are draft documents valid for a maximum of six months
and may be updated, replaced, or obsoleted by other documents at any
time. It is inappropriate to use Internet-Drafts as reference
material or to cite them other than as "work in progress."
This Internet-Draft will expire on February 5, 2021.
Malhotra & Schwartz Expires February 5, 2021 [Page 1]
Internet-Draft Self-Sovereign Verifiable PayID August 2020
Copyright Notice
Copyright (c) 2020 IETF Trust and the persons identified as the
document authors. All rights reserved.
This document is subject to BCP 78 and the IETF Trust's Legal
Provisions Relating to IETF Documents
(https://trustee.ietf.org/license-info) in effect on the date of
publication of this document. Please review these documents
carefully, as they describe your rights and restrictions with respect
to this document. Code Components extracted from this document must
include Simplified BSD License text as described in Section 4.e of
the Trust Legal Provisions and are provided without warranty as
described in the Simplified BSD License.
Table of Contents
1. Terminology . . . . . . . . . . . . . . . . . . . . . . . . . 3
2. Motivation . . . . . . . . . . . . . . . . . . . . . . . . . 3
3. Self-Sovereign Verifiable PayID Protocol Specification . . . 4
3.1. PaymentInformation Resource as JSON Web Signatures . . . 4
3.1.1. JOSE Protected Header . . . . . . . . . . . . . . . . 4
3.1.2. JWS Payload . . . . . . . . . . . . . . . . . . . . . 6
3.1.3. JWS signature . . . . . . . . . . . . . . . . . . . . 8
3.2. End-to-End Self-Sovereign Verifiable PayID protocol Flow 8
3.2.1. Generating PayID Key-pair . . . . . . . . . . . . . . 8
3.2.2. Generating JWS Token . . . . . . . . . . . . . . . . 8
3.2.3. Posting signed response to non-custodial PayID
service Provider's server . . . . . . . . . . . . . . 10
3.3. Basic Operations . . . . . . . . . . . . . . . . . . . . 10
3.3.1. PayID Client Requesting the PaymentInformation
Resource . . . . . . . . . . . . . . . . . . . . . . 10
3.3.2. PayID Server Responding to the PaymentInformation
Resource Request . . . . . . . . . . . . . . . . . . 10
3.3.3. Parsing the PaymentInformation Response . . . . . . . 11
4. Example Use of Self-Sovereign Verifiable PayID Protocol . . . 11
4.1. Verifiable PayID Protocol by a Non-Custodial Wallet as
PayID Server . . . . . . . . . . . . . . . . . . . . . . 11
5. Security Considerations . . . . . . . . . . . . . . . . . . . 13
5.1. Security Model for Non-Custodial PayID Service Providers 13
5.2. Using JSON Web Signatures . . . . . . . . . . . . . . . . 13
5.3. Using addresses Array . . . . . . . . . . . . . . . . . . 14
6. Privacy Considerations . . . . . . . . . . . . . . . . . . . 14
7. References . . . . . . . . . . . . . . . . . . . . . . . . . 14
7.1. Normative References . . . . . . . . . . . . . . . . . . 14
7.2. Informative References . . . . . . . . . . . . . . . . . 15
7.3. URIs . . . . . . . . . . . . . . . . . . . . . . . . . . 15
Authors' Addresses . . . . . . . . . . . . . . . . . . . . . . . 15
Malhotra & Schwartz Expires February 5, 2021 [Page 2]
Internet-Draft Self-Sovereign Verifiable PayID August 2020
1. Terminology
This protocol can be referred to as "Self-Sovereign Verifiable
PayID". It uses the following terminology.
o Endpoint: either the client or the server of a connection.
o Sender: individual or entity originating a transaction.
o PayID client: the endpoint that initiates PayID protocol/sending
side of the transaction.
o PayID server: the endpoint that returns payment account(s) address
information in response to a PayID protocol request (non-custodial
wallets, exchanges, etc).
o PayID owner: individual or entity receiving a transaction.
o Digital Signature: As defined in [RFC4949].
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
"SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and
"OPTIONAL" in this document are to be interpreted as described in
[RFC2119] and [RFC9174][].
2. Motivation
While Self-Sovereign Verifiable PayID can be used in any context, its
most immediate use case is to enable non-custodial service providers
to provide hosted PayID service while preserving the existing trust
assumptions between themselves and their users.
Providers of PayID-enabled payment services can be broadly
categorized as custodial and non-custodial, each of which operate
under different security models. Non-custodial wallets/exchanges do
not store their customers' on-ledger private keys on their servers.
Instead, these customers hold their private keys and hence are in
full control of their funds. As such, there is no trust requirement
between non-custodial wallets/exchanges and their customers, and
these services are not responsible for any for lost, compromised or
stolen private keys of their customers. Likewise, customers of non-
custodial wallets/exchanges do not need to worry if the servers of
those wallets/exchanges are compromised.
Basic PayID protocol [PAYID-PROTOCOL] specifies a protocol to
interact with a PayID server and retrieve a payment account(s)
address information resource along with other meta-data corresponding
to the queried PayID. One of the security assumptions made by the
Malhotra & Schwartz Expires February 5, 2021 [Page 3]
Internet-Draft Self-Sovereign Verifiable PayID August 2020
basic PayID protocol that may be less desirable for some applications
is that the owner of the PayID must trust their PayID server to
provide correct and untampered responses. Under this model, the
PayID server has full control over the contents of any PayID response
message, with potentially adverse effects if the server goes rogue or
is compromised. The PayID owner has no way of knowing if the PayID
server behaves maliciously. This implicit trust assumption between
the PayID owner and their PayID server is often unacceptable in a
non-custodial setting.
Self-Sovereign Verifiable PayID protocol allows a PayID owner to
digitally sign a PayID response using a local application/device with
their PayID private key (which never leaves their device). This
signed PayID response can then be securely transferred to the non-
custodial PayID service provider's server who can then send this as a
response to a PayID query along with PayID owner's "identity"
information. PayID clients can use this information to verify if a
PayID response is signed by the PayID owner and then decide whether
to proceed with any particular transaction. Consequently, the trust
between a PayID owner and their PayID server to serve the correct
mappings is removed.
3. Self-Sovereign Verifiable PayID Protocol Specification
The Self-Sovereign Verifiable PayID protocol is designed along the
same design principles as [PAYID-PROTOCOL].
3.1. PaymentInformation Resource as JSON Web Signatures
The PayID Protocol [PAYID-PROTOCOL] defines a Payment Account(s)
Information Resource that contains information about a particular
PayID. This document further refines this definition to allow this
information to be digitally signed, and then represented as a JSON
Web Signature (JWS) [RFC7515] using JWS JSON Serialization.
Below, this document further defines the structure of each JWS
component, for the purposes of Self-Sovereign Verifiable PayID
protocol.
3.1.1. JOSE Protected Header
For JWS, the members of the JSON object represented by the JOSE
Header describe the cryptographic operations applied to the JWS
Protected header and the JWS payload and optionally additional
properties of the JWS.
For a complete list of members of this object, refer to [RFC7515].
Following is a decoded JSON payload representing an example of JOSE
Malhotra & Schwartz Expires February 5, 2021 [Page 4]
Internet-Draft Self-Sovereign Verifiable PayID August 2020
protected header parameters as defined by the JWS JSON Serialization
syntax.
{
"name": "identityKey",
"alg" : "ES256K",
"typ" : "JOSE+JSON",
"b64" : false,
"crit": ["b64"],
"jwk" : {
"kty": "EC",
"use": "sig",
"crv": "secp256k1",
"x" : "0",
"y" : "0",
},
}
3.1.1.1. name
The "name" Header Parameter identifies the type of signature. It is
a new OPTIONAL header parameter that is not defined in the IANA JSON
Web Signature and Encryption Header Parameters Registry.
3.1.1.2. alg
The "alg" (algorithm) Header Parameter identifies the cryptographic
algorithm used to secure the JWS. This is a required field as
described in [RFC7515]. We RECOMMEND using "ES256K" which is
Elliptic Curve Digital Signature Algorithm (ECDSA) using secp256k1
curve-type and SHA-256 hash-type as defined in IANA JSON Web
Signature and Encryption Header Parameters Registry.
3.1.1.3. typ
The "typ" (type) Header Parameter is used by JWS applications to
declare the media type of the complete JWS as described in [RFC7515].
If used, the value of "typ" field SHOULD be set to "JOSE+JSON".
3.1.1.4. b64
The "b64" (base64url-encode) Header Parameter is an extension to JWS
specification that determines how a payload is represented in the JWS
and the JWS signing input. When the "b64" value is "false", the
payload is represented simply as the JWS Payload value with no
encoding; otherwise, it is represented as ASCII(BASE64URL(JWS
Payload)). This is an optional field as described in [RFC7797].
Malhotra & Schwartz Expires February 5, 2021 [Page 5]
Internet-Draft Self-Sovereign Verifiable PayID August 2020
3.1.1.5. crit
The "crit" (critical) Header Parameter indicates that extensions to
JWS specification are being used that MUST be understood and
processed. This is a required field to be used with "b64" parameter
as described in [RFC7797].
3.1.1.6. jwk
The "jwk" (JSON Web Key) Header Parameter represents the public key
that is used to digitally sign the JOSE header and JWS payload. This
parameter is represented as a JSON Web Key as specified in [RFC7517].
In the header above, members of "jwk" represent the properties of the
public key, including its value that corresponds to the algorithm
"ES256K".
o "kty": Identifies the cryptographic algorithm family used with the
key, such as "EC" for Elliptic Curve.
o "use": Identifies the intended use of the public key, such as
"sig" for signature.
o "crv" : Indicates the elliptic curve and the hash type (e.g.,
"secp256k1" represents curve-type "secp256k1" and the hash-type
"SHA-256").
o "x" : Indicates the X-coordinate of the corresponding public key.
For "alg" parameter values of "ES256K" (which is from the ECDSA
family), "x" contains the X-coordinate of the corresponding public
key.
o "y" : Indicates the Y-coordinate of the corresponding public key.
For "alg" parameter values of "ES256K" (which is from the ECDSA
family), "y" contains the Y-coordinate of the corresponding public
key.
Note: "jwk" is one way way of embedding public key in the JOSE
header. For more details on other possible options for "alg" and
representing public keys refer to [RFC7515].
3.1.2. JWS Payload
The JWS payload is the message that needs to be signed.
Malhotra & Schwartz Expires February 5, 2021 [Page 6]
Internet-Draft Self-Sovereign Verifiable PayID August 2020
{
"exp" : 1596496501,
"payId": "bob$wallet.com",
"payIdAddress": {
"expTime": 34874613475,
"paymentNetwork": "XRPL",
"environment": "TESTNET",
"addressDetailsType": "CryptoAddressDetails",
"addressDetails": {
"address": "rnzBSt9ZCJSh4RxC9f1v6oS9WZtEYJa8B9",
"tag": "12345"
}
}
}
3.1.2.1. exp
The "exp" field is an optional field as described in [RFC7519]. If
used, it SHOULD be set to the expiration time of the cryptographic
key used to generate the digital signature.
3.1.2.2. payId
The "payId" field is a required field. The value of "payId" field is
the PayID URI in the client request that identifies the payment
account information that the JSON object describes.
3.1.2.3. PayIDAddress
The "PayIDAddress" is a required field. The value of "PayIDAddress"
field is a JSON object with the following keys:
o "expTime": This is an optional field and follows the same
structure as described for "exp" field in [RFC7519]. If used, the
value of "expTime" SHOULD be set to the maximum time upto which
the payment address in the "address" field is valid.
o "paymentNetwork": The value of the "paymentNetwork" is the value
of payment-network string as specified in the client request's
"Accept" header.
o "environment": The value of "environment" string is the value of
environment as specified in the client request's "Accept" header.
o "addressDetailsType": The value of "addressDetailsType" is one of
the following strings as described in [PAYID-PROTOCOL]:
* CryptoAddressDetails
Malhotra & Schwartz Expires February 5, 2021 [Page 7]
Internet-Draft Self-Sovereign Verifiable PayID August 2020
* FiatAddressDetails
o "addressDetails": The value of "addressDetails" is the address
information necessary to send payment on a specific
"paymentNetwork" and "environment".
The "address" field MUST be present in the JWS payload.
3.1.3. JWS signature
The JWS signature is the digital signature which is calculated over
the JOSE header and the JWS payload.
"signature": "{base64Signature}"
3.1.3.1. signature
The value of "signature" is computed as described in [RFC7515].
3.2. End-to-End Self-Sovereign Verifiable PayID protocol Flow
A pre-requisite for this protocol requires the PayID owner to
transfer signed "PaymentInformation" to the PayID server. This
document specifies one such way of doing this.
The following are the pre-steps that a PayID owner's device should
perform locally:
3.2.1. Generating PayID Key-pair
We RECOMMEND using elliptic curve (EC) key type with Elliptic Curve
Digital Signature Algorithm (ECDSA) with secp256k1 curve for creating
JWS content.
3.2.2. Generating JWS Token
For each "payment-network" and "environment" that the PayID owner has
a payment address for, generate the JOSE header, JWS Payload and JWS
Signature as described above. A complete "PaymentInformation"
response might look like:
{
Malhotra & Schwartz Expires February 5, 2021 [Page 8]
Internet-Draft Self-Sovereign Verifiable PayID August 2020
"payId": "bob$wallet.com",
"addresses": [],
"verifiedAddresses": [
{
"signatures": [
{
"protected": {
"name": "identityKey",
"alg": "ES256K",
"typ": "JOSE+JSON",
"b64": "false",
"crit": ["b64"],
"jwk": {
"kty": "EC",
"use": "sig",
"crv": "secp256k1",
"x": "b8w36l6eCf7GyD5fvXp0Xj7ugdFuvYYcnmb1VRjBl5g=",
"y": "Tp8RPAf4dWkd+K/BApSW/Ey5UJs53NOPJRqDNZzItPc=",
},
},
"signature": "{base64Signature}",
}
]
"payload": {
"exp" : 34874613475,
"payId": "bob$wallet.com",
"payIdAddress": {
"expTime":
"paymentNetwork": "XRPL",
"environment": "TESTNET",
"addressDetailsType": "CryptoAddressDetails",
"addressDetails": {
"address": "rnzBSt9ZCJSh4RxC9f1v6oS9WZtEYJa8B9",
"tag": "12345"
}
}
}
}
]
}
o addresses: The "addresses" array is an OPTIONAL field. The
implementations MAY choose to populate this field with payment
address(es) information as per [PAYID-PROTOCOL]. The
implementations SHOULD refer to Security Considerations sections
for the possible security trade-offs while using this field.
Malhotra & Schwartz Expires February 5, 2021 [Page 9]
Internet-Draft Self-Sovereign Verifiable PayID August 2020
o VerifiedAddresses: The "VerifiedAddresses" property is a required
field.
3.2.3. Posting signed response to non-custodial PayID service
Provider's server
Implementations SHOULD use a secure communication channel to transfer
these resources to the PayID server.
3.3. Basic Operations
Following are the basic operations performed by a Self-Sovereign
Verifiable PayID client and server to retrieve "PaymentInformation"
resource corresponding to a PayID.
3.3.1. PayID Client Requesting the PaymentInformation Resource
When requesting the "PaymentInformation" resource, a Self-Sovereign
Verifiable PayID client MAY use the same HTTP "GET" method as in
[PAYID-PROTOCOL] to the PayID URL without any query parameters and
body.
The PayID client MUST query the PayID server using HTTPS only.
[RFC2818] defines how HTTPS verifies the PayID server's identity. If
the HTTPS connection cannot be established for any reason, then the
PayID client MUST accept that the PayID request has failed and MUST
NOT attempt to reissue the PayID request using HTTP over a non-secure
connection.
3.3.2. PayID Server Responding to the PaymentInformation Resource
Request
Upon receiving a "GET" request for a payment accounts(s) information
resource or a "PaymentInformation" resource, a PayID server that
supports Self-Sovereign Verifiable PayID protocol returns the
"PaymentInformation" resource for the "payment-network" and
"environment" requested by the PayID client in the request "Accept"
header field, along with other required and/or optional metadata.
However, if the PayID server does not support the Self-Sovereign
Verifiable PayID protocol, the PayID server sends back a response as
described in [PAYID-PROTOCOL].
If the PayID server does not contain the payment accounts(s)
information resource or a "PaymentInformation" resource resource
corresponding to the request, the PayID server MUST respond with an
appropriate error message.
Malhotra & Schwartz Expires February 5, 2021 [Page 10]
Internet-Draft Self-Sovereign Verifiable PayID August 2020
3.3.3. Parsing the PaymentInformation Response
The PayID client MUST conform to the verification of JWS as specified
in [RFC7515].
4. Example Use of Self-Sovereign Verifiable PayID Protocol
This section shows sample use of this extension of Basic PayID
protocol in a hypothetical scenario.
4.1. Verifiable PayID Protocol by a Non-Custodial Wallet as PayID
Server
Suppose Alice wishes to send a friend some XRP from a web-based
wallet provider that Alice has an account on. Alice would log-in to
the wallet provider and enter Bob's PayID (say, "bob$wallet.com")
into the wallet UI to start the payment. The Wallet application
would first discover the PayID URL for the PayID service-provider
using one of the mechanisms described in PayID discovery
[PAYID-DISCOVERY] protocol.
The Wallet application would then issue an HTTPS GET request:
GET /users/bob HTTP/1.1
Host: www.wallet.com
Accept: application/xrpl-testnet+json
PayID-version: 1.0
Bob's wallet (e.g., a non-custodial wallet operating a PayID server)
might respond like this:
Malhotra & Schwartz Expires February 5, 2021 [Page 11]
Internet-Draft Self-Sovereign Verifiable PayID August 2020
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: 403
PayID-Version: 1.0
Cache-Control: "no-store"
Server: Apache/1.3.11
{
"payId": "bob$wallet.com",
"addresses": [],
"verifiedAddresses": [
{
"signatures": [
{
"protected": {
"name": "identityKey",
"alg": "ES256K",
"typ": "JOSE+JSON",
"b64": "false",
"crit": ["b64"],
"jwk": {
"kty": "EC",
"use": "sig",
"crv": "secp256k1",
"x": "b8w36l6eCf7GyD5fvXp0Xj7ugdFuvYYcnmb1VRjBl5g=",
"y": "Tp8RPAf4dWkd+K/BApSW/Ey5UJs53NOPJRqDNZzItPc=",
},
},
"signature": "base64Signature",
}
]
"payload": {
"exp" : 1234574940,
"payId": "bob$wallet.com",
"payIdAddress": {
"expTime": 34874613475,
"paymentNetwork": "XRPL",
"environment": "TESTNET",
"addressDetailsType": "CryptoAddressDetails",
"addressDetails": {
"address": "T7CKYKhRujaxEs9fSxQwJApHsQVPKUgD7EtLWCGTAFBwTha"
}
}
}
}
]
}
Malhotra & Schwartz Expires February 5, 2021 [Page 12]
Internet-Draft Self-Sovereign Verifiable PayID August 2020
In the above example, the "PaymentInformation" resource is a pre-
signed message with the PayID private keys of the PayID owner Bob.
Bob's non-custodial wallet retrieves this response and sends it to
the PayID client.
5. Security Considerations
This security considerations section only considers PayID clients and
servers bound to implementations as defined in this document.
The security guarantees mentioned in [PAYID-PROTOCOL] apply to this
protocol. In this section, we discuss the security model for Self-
Sovereign Verifiable PayID protocol for non-custodial service
providers.
5.1. Security Model for Non-Custodial PayID Service Providers
In the current security model, non-custodial wallets do not store
their customers' keys. Instead, wallet customers hold their private
keys on their own device(s). There is a no trust requirement between
the service provided by a non-custodial wallets and its customers.
Because customers in this scenario hold the private keys: * Wallets
are not liable for any consequences coming from the loss, compromise
or theft of customers' private keys. * The non-custodial wallets do
not require their customers to trust their servers in case wallets
servers go malicious or are compromised.
This extension of Basic PayID protocol preserves this trust model.
Rather than requiring the PayID server to provide accurate PayID
response for their customers, the PayID owners can generate these
signed mappings with their own PayID private key locally on their
app/device. The sender of the payment (PayID client wallet's
customer) can easily verify these signatures out-of-band with the
receiver (i.e., PayID owner). This eliminates any risk of the non-
custodial PayID server wallet losing its private keys, going
malicious, getting hacked, or becoming otherwise compromised in a way
that customers might lose funds.
5.2. Using JSON Web Signatures
The implementations of this extension of Basic PayID protocol MUST
refer to the Security Considerations sections of [RFC7515] and
[RFC7519].
Malhotra & Schwartz Expires February 5, 2021 [Page 13]
Internet-Draft Self-Sovereign Verifiable PayID August 2020
5.3. Using addresses Array
The "addresses" array in the PayID response is an array of unsigned
payment addresses. Implementations of this extension of Basic PayID
that choose to populate this array along with the "verifiedAddresses"
array MAY be vulnerable to downgrade attacks. We RECOMMEND against
populating this array unless absolutely necessary depending on the
use-case. Also, note that this approach is not backwards-compatible
with the PayID clients that do not understand Self-Sovereign
Verifiable PayID protocol.
6. Privacy Considerations
All privacy guarantees in the Privacy Considerations section of
[PAYID-PROTOCOL] apply to this extension of Basic PayID protocol.
7. References
7.1. Normative References
[PAYID-DISCOVERY]
Fuelling, D., "PayID Discovery", n.d..
[PAYID-PROTOCOL]
Schwartz, D., "PayID Protocol", n.d..
[PAYID-URI]
Fuelling, D., "The 'payid' URI Scheme", n.d.,
<https://tbd.example.com/>.
[RFC2119] Bradner, S., "Key words for use in RFCs to Indicate
Requirement Levels", BCP 14, RFC 2119,
DOI 10.17487/RFC2119, March 1997,
<https://www.rfc-editor.org/info/rfc2119>.
[RFC2818] Rescorla, E., "HTTP Over TLS", RFC 2818,
DOI 10.17487/RFC2818, May 2000,
<https://www.rfc-editor.org/info/rfc2818>.
[RFC4949] Shirey, R., "Internet Security Glossary, Version 2",
FYI 36, RFC 4949, DOI 10.17487/RFC4949, August 2007,
<https://www.rfc-editor.org/info/rfc4949>.
[RFC5280] Cooper, D., Santesson, S., Farrell, S., Boeyen, S.,
Housley, R., and W. Polk, "Internet X.509 Public Key
Infrastructure Certificate and Certificate Revocation List
(CRL) Profile", RFC 5280, DOI 10.17487/RFC5280, May 2008,
<https://www.rfc-editor.org/info/rfc5280>.
Malhotra & Schwartz Expires February 5, 2021 [Page 14]
Internet-Draft Self-Sovereign Verifiable PayID August 2020
[RFC6979] Pornin, T., "Deterministic Usage of the Digital Signature
Algorithm (DSA) and Elliptic Curve Digital Signature
Algorithm (ECDSA)", RFC 6979, DOI 10.17487/RFC6979, August
2013, <https://www.rfc-editor.org/info/rfc6979>.
[RFC7515] Jones, M., Bradley, J., and N. Sakimura, "JSON Web
Signature (JWS)", RFC 7515, DOI 10.17487/RFC7515, May
2015, <https://www.rfc-editor.org/info/rfc7515>.
[RFC7517] Jones, M., "JSON Web Key (JWK)", RFC 7517,
DOI 10.17487/RFC7517, May 2015,
<https://www.rfc-editor.org/info/rfc7517>.
[RFC7519] Jones, M., Bradley, J., and N. Sakimura, "JSON Web Token
(JWT)", RFC 7519, DOI 10.17487/RFC7519, May 2015,
<https://www.rfc-editor.org/info/rfc7519>.
[RFC7797] Jones, M., "JSON Web Signature (JWS) Unencoded Payload
Option", RFC 7797, DOI 10.17487/RFC7797, February 2016,
<https://www.rfc-editor.org/info/rfc7797>.
7.2. Informative References
[RFC4732] Handley, M., Ed., Rescorla, E., Ed., and IAB, "Internet
Denial-of-Service Considerations", RFC 4732,
DOI 10.17487/RFC4732, December 2006,
<https://www.rfc-editor.org/info/rfc4732>.
7.3. URIs
[1] https://payid.org/
Authors' Addresses
Aanchal Malhotra
Ripple
315 Montgomery Street
San Francisco, CA 94104
US
Phone: -----------------
Email: [email protected]
URI: https://www.ripple.com
Malhotra & Schwartz Expires February 5, 2021 [Page 15]
Internet-Draft Self-Sovereign Verifiable PayID August 2020
David Schwartz
Ripple
315 Montgomery Street
San Francisco, CA 94104
US
Phone: -----------------
Email: [email protected]
URI: https://www.ripple.com
Malhotra & Schwartz Expires February 5, 2021 [Page 16]