auth0 / node-jws

JSON Web Signatures
http://self-issued.info/docs/draft-ietf-jose-json-web-signature.html
MIT License
704 stars 106 forks source link

x5c support #79

Open apowers313 opened 6 years ago

apowers313 commented 6 years ago

I have a couple JWTs that use x5c in the headers (Android SafetyNet attestation, FIDO Metadata Service). Would it be possible to add validation of JWS that's using x5c?

Here's the Android SafetyNet JWS:

eyJhbGciOiJSUzI1NiIsIng1YyI6WyJNSUlFaWpDQ0EzS2dBd0lCQWdJSVlrWW81RjBnODZrd0RRWUpLb1pJaHZjTkFRRUxCUUF3VkRFTE1Ba0dBMVVFQmhNQ1ZWTXhIakFjQmdOVkJBb1RGVWR2YjJkc1pTQlVjblZ6ZENCVFpYSjJhV05sY3pFbE1DTUdBMVVFQXhNY1IyOXZaMnhsSUVsdWRHVnlibVYwSUVGMWRHaHZjbWwwZVNCSE16QWVGdzB4TnpFeU1EUXhNekU0TkROYUZ3MHhPREV5TURNd01EQXdNREJhTUd3eEN6QUpCZ05WQkFZVEFsVlRNUk13RVFZRFZRUUlEQXBEWVd4cFptOXlibWxoTVJZd0ZBWURWUVFIREExTmIzVnVkR0ZwYmlCV2FXVjNNUk13RVFZRFZRUUtEQXBIYjI5bmJHVWdTVzVqTVJzd0dRWURWUVFEREJKaGRIUmxjM1F1WVc1a2NtOXBaQzVqYjIwd2dnRWlNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0SUJEd0F3Z2dFS0FvSUJBUUNVajh3WW9QaXhLYmJWOHNnWWd2TVRmWCtkSXNGVE9rZ0tPbGhUMGkwYmNERlpLMnJPeEpaMnVTTFNWaFl2aXBaTkUzSEpRWXV1WXdGaml5K3lrZmF0QUdTalJ6RjFiMzF1NDMvN29HNWpNaDNTMzdhbHdqVWI4Q1dpVHhvaXBWT1l3S0t6dVV5a3FFQ3RqbGhKNEFrV2FEUytaeEtFcU9hZTl0bkNnZUhsbFpFL09SZ2VNYXgyWE5Db0g2c3JURVJja3NqelpackFXeEtzZGZ2VnJYTnpDUjlEeFZBU3VJNkx6d2g4RFNsMkVPb2tic2FuWisrL0pxTWVBQkZmUHdqeXdyYjBwckVVeTBwYWVWc3VkKzBwZWV4Sy81K0U2a3BZR0s0WksybmtvVkx1Z0U1dGFIckFqODNRK1BPYmJ2T3pXY0ZrcG5WS3lqbzZLUUFtWDZXSkFnTUJBQUdqZ2dGR01JSUJRakFUQmdOVkhTVUVEREFLQmdnckJnRUZCUWNEQVRBZEJnTlZIUkVFRmpBVWdoSmhkSFJsYzNRdVlXNWtjbTlwWkM1amIyMHdhQVlJS3dZQkJRVUhBUUVFWERCYU1DMEdDQ3NHQVFVRkJ6QUNoaUZvZEhSd09pOHZjR3RwTG1kdmIyY3ZaM055TWk5SFZGTkhTVUZITXk1amNuUXdLUVlJS3dZQkJRVUhNQUdHSFdoMGRIQTZMeTl2WTNOd0xuQnJhUzVuYjI5bkwwZFVVMGRKUVVjek1CMEdBMVVkRGdRV0JCUUc4SXJRdEZSNkNVU2tpa2IzYWltc20yNmNCVEFNQmdOVkhSTUJBZjhFQWpBQU1COEdBMVVkSXdRWU1CYUFGSGZDdUZDYVozWjJzUzNDaHRDRG9INm1mcnBMTUNFR0ExVWRJQVFhTUJnd0RBWUtLd1lCQkFIV2VRSUZBekFJQmdabmdRd0JBZ0l3TVFZRFZSMGZCQ293S0RBbW9DU2dJb1lnYUhSMGNEb3ZMMk55YkM1d2Eya3VaMjl2Wnk5SFZGTkhTVUZITXk1amNtd3dEUVlKS29aSWh2Y05BUUVMQlFBRGdnRUJBRi9Sek5uQzVEekJVQnRuaDJudEpMV0VRaDl6RWVGWmZQTDlRb2tybEFvWGdqV2dOOHBTUlUxbFZHSXB0ek14R2h5My9PUlJaVGE2RDJEeThodkNEckZJMytsQ1kwMU1MNVE2WE5FNVJzMmQxUmlacE1zekQ0S1FaTkczaFowQkZOUS9janJDbUxCT0dLa0VVMWRtQVhzRkpYSmlPcjJDTlRCT1R1OUViTFdoUWZkQ0YxYnd6eXUrVzZiUVN2OFFEbjVPZE1TL1BxRTFkRWdldC82RUlSQjc2MUtmWlErL0RFNkxwM1RyWlRwT0ZERGdYaCtMZ0dPc3doRWxqOWMzdlpIR0puaGpwdDhya2Jpci8ydUxHZnhsVlo0SzF4NURSTjBQVUxkOXlQU21qZythajErdEh3STFtUW1aVlk3cXZPNURnaE94aEpNR2x6NmxMaVptem9nPSIsIk1JSUVYRENDQTBTZ0F3SUJBZ0lOQWVPcE1CejhjZ1k0UDVwVEhUQU5CZ2txaGtpRzl3MEJBUXNGQURCTU1TQXdIZ1lEVlFRTEV4ZEhiRzlpWVd4VGFXZHVJRkp2YjNRZ1EwRWdMU0JTTWpFVE1CRUdBMVVFQ2hNS1IyeHZZbUZzVTJsbmJqRVRNQkVHQTFVRUF4TUtSMnh2WW1Gc1UybG5iakFlRncweE56QTJNVFV3TURBd05ESmFGdzB5TVRFeU1UVXdNREF3TkRKYU1GUXhDekFKQmdOVkJBWVRBbFZUTVI0d0hBWURWUVFLRXhWSGIyOW5iR1VnVkhKMWMzUWdVMlZ5ZG1salpYTXhKVEFqQmdOVkJBTVRIRWR2YjJkc1pTQkpiblJsY201bGRDQkJkWFJvYjNKcGRIa2dSek13Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRREtVa3ZxSHYvT0pHdW8ybklZYU5WV1hRNUlXaTAxQ1haYXo2VElITEdwL2xPSis2MDAvNGhibjd2bjZBQUIzRFZ6ZFFPdHM3RzVwSDBySm5uT0ZVQUs3MUc0bnpLTWZIQ0dVa3NXL21vbmErWTJlbUpRMk4rYWljd0pLZXRQS1JTSWdBdVBPQjZBYWhoOEhiMlhPM2g5UlVrMlQwSE5vdUIyVnp4b01YbGt5VzdYVVI1bXc2SmtMSG5BNTJYRFZvUlRXa050eTVvQ0lOTHZHbW5Sc0oxem91QXFZR1ZRTWMvN3N5Ky9FWWhBTHJWSkVBOEtidHlYK3I4c253VTVDMWhVcndhVzZNV09BUmE4cUJwTlFjV1RrYUllb1l2eS9zR0lKRW1qUjB2RkV3SGRwMWNTYVdJcjYvNGc3Mm43T3FYd2ZpbnU3WllXOTdFZm9PU1FKZUF6QWdNQkFBR2pnZ0V6TUlJQkx6QU9CZ05WSFE4QkFmOEVCQU1DQVlZd0hRWURWUjBsQkJZd0ZBWUlLd1lCQlFVSEF3RUdDQ3NHQVFVRkJ3TUNNQklHQTFVZEV3RUIvd1FJTUFZQkFmOENBUUF3SFFZRFZSME9CQllFRkhmQ3VGQ2FaM1oyc1MzQ2h0Q0RvSDZtZnJwTE1COEdBMVVkSXdRWU1CYUFGSnZpQjFkbkhCN0FhZ2JlV2JTYUxkL2NHWVl1TURVR0NDc0dBUVVGQndFQkJDa3dKekFsQmdnckJnRUZCUWN3QVlZWmFIUjBjRG92TDI5amMzQXVjR3RwTG1kdmIyY3ZaM055TWpBeUJnTlZIUjhFS3pBcE1DZWdKYUFqaGlGb2RIUndPaTh2WTNKc0xuQnJhUzVuYjI5bkwyZHpjakl2WjNOeU1pNWpjbXd3UHdZRFZSMGdCRGd3TmpBMEJnWm5nUXdCQWdJd0tqQW9CZ2dyQmdFRkJRY0NBUlljYUhSMGNITTZMeTl3YTJrdVoyOXZaeTl5WlhCdmMybDBiM0o1THpBTkJna3Foa2lHOXcwQkFRc0ZBQU9DQVFFQUhMZUpsdVJUN2J2czI2Z3lBWjhzbzgxdHJVSVNkN080NXNrRFVtQWdlMWNueGhHMVAyY05tU3hiV3NvaUN0MmV1eDlMU0QrUEFqMkxJWVJGSFczMS82eG9pYzFrNHRiV1hrRENqaXIzN3hUVE5xUkFNUFV5RlJXU2R2dCtubFBxd25iOE9hMkkvbWFTSnVrY3hEak5TZnBEaC9CZDFsWk5nZGQvOGNMZHNFMyt3eXB1Zko5dVhPMWlRcG5oOXpidUZJd3NJT05HbDFwM0E4Q2d4a3FJL1VBaWgzSmFHT3FjcGNkYUNJemtCYVI5dVlRMVg0azJWZzVBUFJMb3V6Vnk3YThJVms2d3V5NnBtK1Q3SFQ0TFk4aWJTNUZFWmxmQUZMU1c4TndzVno5U0JLMlZxbjFOMFBJTW41eEE2TlpWYzdvODM1RExBRnNoRVdmQzdUSWUzZz09Il19.eyJub25jZSI6ImxXa0lqeDdPNHlNcFZBTmR2UkRYeXVPUk1Gb25VYlZadTQvWHk3SXB2ZFJBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQVFLZ2x4SHlmblJLQVpWcWlKZElxdHFmNEk5ZHgwb082L3pBTzhUbkRvanZFWkFxMkRaa0J5STFmY29XVlFFcS9PM0ZMSDVhT3d6YnJyeHJKNjVVNWRZcWxBUUlESmlBQklWZ2doNU9KZllSRHpWR0lvd0txVTU3QW5vVmpqZG1takdpOXpsTWtqQVZWOURBaVdDRHIwaVNpMHZpSUtOUE1USWROMjhnV05ta2N3T3I2RFF4NjZNUGZmM09kbSt1NmVKcUxCbDFIMlMydHJBQkhMaW5rbnN5Vk1QbS9CTlVWWjJKRmxyODAiLCJ0aW1lc3RhbXBNcyI6MTUyODkxMTYzNDM4NSwiYXBrUGFja2FnZU5hbWUiOiJjb20uZ29vZ2xlLmFuZHJvaWQuZ21zIiwiYXBrRGlnZXN0U2hhMjU2IjoiSk9DM1Vrc2xzdVZ6MTNlT3BuRkk5QnBMb3FCZzlrMUY2T2ZhUHRCL0dqTT0iLCJjdHNQcm9maWxlTWF0Y2giOmZhbHNlLCJhcGtDZXJ0aWZpY2F0ZURpZ2VzdFNoYTI1NiI6WyJHWFd5OFhGM3ZJbWwzL01mbm1TbXl1S0JwVDNCMGRXYkhSUi80Y2dxK2dBPSJdLCJiYXNpY0ludGVncml0eSI6ZmFsc2UsImFkdmljZSI6IlJFU1RPUkVfVE9fRkFDVE9SWV9ST00sTE9DS19CT09UTE9BREVSIn0.iCF6D2os8DYuDVOnt3zDJB2mSXnZjtWJtl_jzSDx5MrRC9A2fmFBZ6z5kpQZ2MiQ7ootj9WkHMgxqIhrX3dlh2POHAwkIS34ySjLVNsSPprE84eZgqSFLMEYT0GR2eVLHAMPN8n5R8K6buDOGF3nSi6GKzG57Zll8CSob2yiAS9r7spdA6H0TDH-NGzSdbMIId8fZD1dzFKNQr77b6lbIAFgQbRZBrnp-e-H4iH6d21oN2NAYRnR5YURacP6kGGj2cFxswE2908wxv9hiYNKNojeeu8Xc4It7PbhlAuO7ywhQFA81iPCCFm11B8cfUXbWA8l_2ttNPBEMGM6-Z6VyQ

And the FIDO MDS JWT:

eyJhbGciOiAiRVMyNTYiLCAidHlwIjogIkpXVCIsICJ4NWMiOiBbIk1JSUNuVENDQWtPZ0F3SUJBZ0lPUnZDTTFhdVU2RllWWFVlYkpIY3dDZ1lJS29aSXpqMEVBd0l3VXpFTE1Ba0dBMVVFQmhNQ1ZWTXhGakFVQmdOVkJBb1REVVpKUkU4Z1FXeHNhV0Z1WTJVeEhUQWJCZ05WQkFzVEZFMWxkR0ZrWVhSaElGUlBReUJUYVdkdWFXNW5NUTB3Q3dZRFZRUURFd1JEUVMweE1CNFhEVEUxTURneE9UQXdNREF3TUZvWERURTRNRGd4T1RBd01EQXdNRm93WkRFTE1Ba0dBMVVFQmhNQ1ZWTXhGakFVQmdOVkJBb1REVVpKUkU4Z1FXeHNhV0Z1WTJVeEhUQWJCZ05WQkFzVEZFMWxkR0ZrWVhSaElGUlBReUJUYVdkdWFXNW5NUjR3SEFZRFZRUURFeFZOWlhSaFpHRjBZU0JVVDBNZ1UybG5ibVZ5SURNd1dUQVRCZ2NxaGtqT1BRSUJCZ2dxaGtqT1BRTUJCd05DQUFTS1grcDNXMmoxR1Y0bFF3bjdIWE5qNGxoOWUyd0FhNko5dEJJUWhiUVRrcU12TlpHbkh4T243eVRaM05wWU81WkdWZ3IvWEM2NnFsaTdCV0E4amdUZm80SHBNSUhtTUE0R0ExVWREd0VCL3dRRUF3SUd3REFNQmdOVkhSTUJBZjhFQWpBQU1CMEdBMVVkRGdRV0JCUmNrTkYrenp4TXVMdm0rcVJqTGVKUWYwRHd5ekFmQmdOVkhTTUVHREFXZ0JScEVWNHRhV1NGblphNDF2OWN6Yjg4ZGM5TUdEQTFCZ05WSFI4RUxqQXNNQ3FnS0tBbWhpUm9kSFJ3T2k4dmJXUnpMbVpwWkc5aGJHeHBZVzVqWlM1dmNtY3ZRMEV0TVM1amNtd3dUd1lEVlIwZ0JFZ3dSakJFQmdzckJnRUVBWUxsSEFFREFUQTFNRE1HQ0NzR0FRVUZCd0lCRmlkb2RIUndjem92TDIxa2N5NW1hV1J2WVd4c2FXRnVZMlV1YjNKbkwzSmxjRzl6YVhSdmNua3dDZ1lJS29aSXpqMEVBd0lEU0FBd1JRSWhBTExiWWpCcmJoUGt3cm4zbVFqQ0VSSXdrTU5OVC9sZmtwTlhIKzR6alVYRUFpQmFzMmxQNmpwNDRCaDRYK3RCWHFZN3k2MWlqR1JJWkNhQUYxS0lsZ3ViMGc9PSIsICJNSUlDc2pDQ0FqaWdBd0lCQWdJT1JxbXhrOE5RdUpmQ0VOVllhMVF3Q2dZSUtvWkl6ajBFQXdNd1V6RUxNQWtHQTFVRUJoTUNWVk14RmpBVUJnTlZCQW9URFVaSlJFOGdRV3hzYVdGdVkyVXhIVEFiQmdOVkJBc1RGRTFsZEdGa1lYUmhJRlJQUXlCVGFXZHVhVzVuTVEwd0N3WURWUVFERXdSU2IyOTBNQjRYRFRFMU1EWXhOekF3TURBd01Gb1hEVFF3TURZeE56QXdNREF3TUZvd1V6RUxNQWtHQTFVRUJoTUNWVk14RmpBVUJnTlZCQW9URFVaSlJFOGdRV3hzYVdGdVkyVXhIVEFiQmdOVkJBc1RGRTFsZEdGa1lYUmhJRlJQUXlCVGFXZHVhVzVuTVEwd0N3WURWUVFERXdSRFFTMHhNRmt3RXdZSEtvWkl6ajBDQVFZSUtvWkl6ajBEQVFjRFFnQUU5c0RnQzhQekJZbC93S3FwWGZhOThqT0lvNzhsOXB6NHhPekdER0l6MHpFWE1Yc0JZNmtBaHlVNEdSbVQwd280dHlVdng1Qlk4T0tsc0xNemxiS01SYU9CN3pDQjdEQU9CZ05WSFE4QkFmOEVCQU1DQVFZd0VnWURWUjBUQVFIL0JBZ3dCZ0VCL3dJQkFEQWRCZ05WSFE0RUZnUVVhUkZlTFdsa2haMld1TmIvWE0yL1BIWFBUQmd3SHdZRFZSMGpCQmd3Rm9BVTBxVWZDNmYyWXNoQTFOaTl1ZGVPMFZTN3ZFWXdOUVlEVlIwZkJDNHdMREFxb0NpZ0pvWWthSFIwY0RvdkwyMWtjeTVtYVdSdllXeHNhV0Z1WTJVdWIzSm5MMUp2YjNRdVkzSnNNRThHQTFVZElBUklNRVl3UkFZTEt3WUJCQUdDNVJ3QkF3RXdOVEF6QmdnckJnRUZCUWNDQVJZbmFIUjBjSE02THk5dFpITXVabWxrYjJGc2JHbGhibU5sTG05eVp5OXlaWEJ2YzJsMGIzSjVNQW9HQ0NxR1NNNDlCQU1EQTJnQU1HVUNNQkxWcTBKZFd2MnlZNFJwMUlpeUlWV0VLRzFQVHoxcFBBRnFFbmFrUHR3NFJNUlRHd0hkYjJpZmNEYlBvRWtmWVFJeEFPTGtmRVBqMjJmQm5lajF3dGd5eWxzdTczcktMVXY0eGhEeTlUQWVWVW1sMGlEQk04U3RFNERpVnMvNGVqRmhxUT09Il19.{"nextUpdate": "2018-06-18", "no": 62, "entries": [{"url": "https://mds.fidoalliance.org/metadata/0013%230001", "timeOfLastStatusChange": "2015-05-20", "hash": "06LZxJ5mNuNZj48IZLV816bfp3A7GVtO2O-EeQ1pkTY=", "aaid": "0013#0001", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2015-05-20"}]}, {"url": "https://mds.fidoalliance.org/metadata/0013%230061", "timeOfLastStatusChange": "2015-12-22", "hash": "gW89T1g92RfWTn2jXaPo-sNSimg4ypjghog0GnMDP5c=", "aaid": "0013#0061", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2015-12-22"}]}, {"url": "https://mds.fidoalliance.org/metadata/0013%230071", "timeOfLastStatusChange": "2015-12-22", "hash": "naDBoNwd4A1xbKgqmIPIo34DcroNOibj2L-QAtlN4MM=", "aaid": "0013#0071", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2015-12-22"}]}, {"url": "https://mds.fidoalliance.org/metadata/0013%230084", "timeOfLastStatusChange": "2015-12-22", "hash": "c7-gOx1NAaL_kquWEiwWuVX4-hhkd3Me64DJwxXPEpo=", "aaid": "0013#0084", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2015-12-22"}]}, {"url": "https://mds.fidoalliance.org/metadata/0014%23FFF1", "timeOfLastStatusChange": "2016-11-22", "hash": "VUtIkPXyhkmFFc1GjTrgFX0gZqd_WxPvsi2gcs9T_3I=", "aaid": "0014#FFF1", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2015-09-25"}, {"status": "REVOKED", "url": "", "certificate": "", "effectiveDate": "2016-11-22"}]}, {"url": "https://mds.fidoalliance.org/metadata/0014%23FFF2", "timeOfLastStatusChange": "2016-11-22", "hash": "uH2hE1T8uIBhnF7Frn3qK8KB8JKI-ZJbpsRPmycHffs=", "aaid": "0014#FFF2", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2015-09-30"}, {"status": "REVOKED", "url": "", "certificate": "", "effectiveDate": "2016-11-22"}]}, {"url": "https://mds.fidoalliance.org/metadata/0014%23FFF3", "timeOfLastStatusChange": "2016-11-22", "hash": "maQyhIodIijkYi2Hysv-hhVp-jS2H-NkZ0nfZeDIoPs=", "aaid": "0014#FFF3", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2015-10-31"}, {"status": "REVOKED", "url": "", "certificate": "", "effectiveDate": "2016-11-22"}]}, {"url": "https://mds.fidoalliance.org/metadata/0015%230002", "timeOfLastStatusChange": "2016-01-08", "hash": "i8_wcw1aWDRiFUQek_lb068EuLUcShLjrxcJW0B8OvY=", "aaid": "0015#0002", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-01-08"}]}, {"url": "https://mds.fidoalliance.org/metadata/0015%230005", "timeOfLastStatusChange": "2017-02-08", "hash": "Q1dqUrMpStpBA2jrtrRzFKyjlVsdiIgrMOmx5tu_bZw=", "aaid": "0015#0005", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-02-08"}]}, {"url": "https://mds.fidoalliance.org/metadata/0016%230001", "timeOfLastStatusChange": "2015-07-21", "hash": "uyjDJpNJoKN9C2hq8I-wgUxkduwAWXQQC9uqkTuGzNk=", "aaid": "0016#0001", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2015-07-21"}]}, {"url": "https://mds.fidoalliance.org/metadata/0016%230003", "timeOfLastStatusChange": "2016-02-10", "hash": "tTeheLD3GKGjxfbvV2doO_nUlgy4qycJ42xGBZTNvxY=", "aaid": "0016#0003", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-02-10"}]}, {"url": "https://mds.fidoalliance.org/metadata/0016%230010", "timeOfLastStatusChange": "2016-02-10", "hash": "Ryk4zzGHEt3Ha8nOCRwZZ4U8zTWJyxqNqB4zSpdGGy4=", "aaid": "0016#0010", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-02-10"}]}, {"url": "https://mds.fidoalliance.org/metadata/0016%230020", "timeOfLastStatusChange": "2016-02-10", "hash": "pXAY-CNDWKbT-fU-GrQFAdrxDCns7GU5CrZ-QDnnSdA=", "aaid": "0016#0020", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-02-10"}]}, {"url": "https://mds.fidoalliance.org/metadata/0017%230400", "timeOfLastStatusChange": "2015-12-27", "hash": "9H57fGLa2f1aCMpH-qsYtWMT_iUUHtc8d8SYonAnTo8=", "aaid": "0017#0400", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2015-12-27"}]}, {"url": "https://mds.fidoalliance.org/metadata/0019%230005", "timeOfLastStatusChange": "2015-07-22", "hash": "lfJkNaAGAebZzoNz_0IZQwxVUgPuXSUI2pb3BlNlYvk=", "aaid": "0019#0005", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2015-07-22"}]}, {"url": "https://mds.fidoalliance.org/metadata/0019%231005", "timeOfLastStatusChange": "2017-02-10", "hash": "_ZtbhNsskXud6mra28yOTyjLDzQUvGl9In-FZb2Xi44=", "aaid": "0019#1005", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-02-10"}]}, {"url": "https://mds.fidoalliance.org/metadata/0019%231009", "timeOfLastStatusChange": "2017-02-10", "hash": "KBtnvu3JccYtCCIfduW1HWzuLVerZ9RRBYgrMaBjB24=", "aaid": "0019#1009", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-02-10"}]}, {"url": "https://mds.fidoalliance.org/metadata/001B%230001", "timeOfLastStatusChange": "2016-01-01", "hash": "pQV2bR9-IMDaGFZJC6BKatf93tIPTfSvklTvGLjn8DA=", "aaid": "001B#0001", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-01-01"}]}, {"url": "https://mds.fidoalliance.org/metadata/001D%230001", "timeOfLastStatusChange": "2017-03-31", "hash": "XHc32UXefvsPOZz-CNaN_dSXPPXinDCbQzJjE6ZYjRw=", "aaid": "001D#0001", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-03-31"}]}, {"url": "https://mds.fidoalliance.org/metadata/001D%230002", "timeOfLastStatusChange": "2017-05-04", "hash": "ascUXlpw7C0rctQFhCR5EbKnc-sVNLOPYqwP13N96i8=", "aaid": "001D#0002", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-05-04"}]}, {"url": "https://mds.fidoalliance.org/metadata/001D%231001", "timeOfLastStatusChange": "2017-03-28", "hash": "brYb6k7ZrKdc7Ax1QTC8dwzCw9rV1Jx1ZIxkwkDBOQ8=", "aaid": "001D#1001", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-03-28"}]}, {"url": "https://mds.fidoalliance.org/metadata/001E%230001", "timeOfLastStatusChange": "2016-03-31", "hash": "6yrrrgNdbivZ7I-F4BRpDxVY7XsDq9XBVtLrv1PwgqQ=", "aaid": "001E#0001", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-03-31"}]}, {"url": "https://mds.fidoalliance.org/metadata/001E%230002", "timeOfLastStatusChange": "2016-01-18", "hash": "6v7IC3k2MnQsr4XcXXwW_sNpQi-UZnK5lkueHuyJpdE=", "aaid": "001E#0002", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-01-18"}]}, {"url": "https://mds.fidoalliance.org/metadata/001E%230003", "timeOfLastStatusChange": "2016-02-04", "hash": "6HeScxAZZ_u0AgO7dmgo088GFoylNBWtTb3AcT-C2hk=", "aaid": "001E#0003", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-02-04"}]}, {"url": "https://mds.fidoalliance.org/metadata/001E%230004", "timeOfLastStatusChange": "2016-02-04", "hash": "7fZDc0ERq4FuSWzpI1Lkpry98Yebzt5NyU8myEuMlh0=", "aaid": "001E#0004", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-02-04"}]}, {"url": "https://mds.fidoalliance.org/metadata/001E%230005", "timeOfLastStatusChange": "2016-02-04", "hash": "xoZsBh5svvicjp7l85EHGrrDcRAHyXGyfrTZW6ig1Yw=", "aaid": "001E#0005", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-02-04"}]}, {"url": "https://mds.fidoalliance.org/metadata/001E%230006", "timeOfLastStatusChange": "2016-02-04", "hash": "kqa_-9q8SmDYJfy4FoqSfjHYDiZa7DXNJ4OKxkRqqHs=", "aaid": "001E#0006", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-02-04"}]}, {"url": "https://mds.fidoalliance.org/metadata/001E%230007", "timeOfLastStatusChange": "2016-03-21", "hash": "84vdt0Rz4TD_s6aBJIhSmCVOJWtSghK8fEzJruR09tM=", "aaid": "001E#0007", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-03-21"}]}, {"url": "https://mds.fidoalliance.org/metadata/0020%23A111", "timeOfLastStatusChange": "2016-11-22", "hash": "xIE5Teo_NRwpk15ALIDkTXTucwtoe1yRzxXS5BbCsXU=", "aaid": "0020#A111", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-11-22"}]}, {"url": "https://mds.fidoalliance.org/metadata/0020%23A201", "timeOfLastStatusChange": "2016-02-12", "hash": "hWG6xG20tN6GNu6sCHf0g5Z6XtkE3fEakk5pAyjP0YM=", "aaid": "0020#A201", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-02-12"}]}, {"url": "https://mds.fidoalliance.org/metadata/0020%23A202", "timeOfLastStatusChange": "2016-02-12", "hash": "yK4jTMAJQY2l-WWI6mBZgfBZZNJKg17VxSrofOLEXHQ=", "aaid": "0020#A202", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-02-12"}]}, {"url": "https://mds.fidoalliance.org/metadata/0020%23A203", "timeOfLastStatusChange": "2016-02-12", "hash": "0bK_CCfCMgtiayjem9e7qkYCqbhl9sr0ph3mdyIJ_DA=", "aaid": "0020#A203", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-02-12"}]}, {"url": "https://mds.fidoalliance.org/metadata/0020%23A204", "timeOfLastStatusChange": "2015-12-22", "hash": "eh7V4piN_U5Bc_flPY386FchRw5W3uAxu0j83qB2Y1o=", "aaid": "0020#A204", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2015-12-22"}]}, {"url": "https://mds.fidoalliance.org/metadata/0020%23A205", "timeOfLastStatusChange": "2016-02-12", "hash": "XeFOiMk6j1hhNa2mxXGUh2rzq-QfvNpQ6wEp6VhSMZc=", "aaid": "0020#A205", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-02-12"}]}, {"url": "https://mds.fidoalliance.org/metadata/0020%23A206", "timeOfLastStatusChange": "2016-02-12", "hash": "-74n1J2am5djXatYoHTkyvxapiQXKU1MC4Hn_5F0FQI=", "aaid": "0020#A206", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-02-12"}]}, {"url": "https://mds.fidoalliance.org/metadata/0020%23B204", "timeOfLastStatusChange": "2015-12-22", "hash": "UB96twC_HvqJPXCNB1aXwylsgOFrWgTb-yhOJ-nYI2k=", "aaid": "0020#B204", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2015-12-22"}]}, {"url": "https://mds.fidoalliance.org/metadata/0028%230001", "timeOfLastStatusChange": "2016-03-21", "hash": "CfY8r-OS66kX4BMRAYnBUqQGS74lI6W-7H4sCaZlE8g=", "aaid": "0028#0001", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-03-21"}]}, {"url": "https://mds.fidoalliance.org/metadata/0031%230001", "timeOfLastStatusChange": "2017-03-22", "hash": "daRyZ1HJB1mvV0hKDIlt9LoqhgSTpjj9cvpOcfVwV5Q=", "aaid": "0031#0001", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-03-22"}]}, {"url": "https://mds.fidoalliance.org/metadata/0031%230002", "timeOfLastStatusChange": "2017-03-22", "hash": "UPAhTy5FxELFMuGNNm38V1tEDW5ZqW82jV1dc--6T1k=", "aaid": "0031#0002", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-03-22"}]}, {"url": "https://mds.fidoalliance.org/metadata/0037%230001", "timeOfLastStatusChange": "2017-11-28", "hash": "D4aSBma2_LWdWfiJHgmnv8Tc1ER6ftAGUqqTohEgZHg=", "aaid": "0037#0001", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-11-28"}]}, {"url": "https://mds.fidoalliance.org/metadata/096E%230004", "timeOfLastStatusChange": "2017-01-04", "hash": "AgN2UlIKA4W01ngWDdyYYsXV43_W0qhBTd1aCZLgOIE=", "aaid": "096E#0004", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-01-04"}]}, {"url": "https://mds.fidoalliance.org/metadata/1EA8%238081", "timeOfLastStatusChange": "2017-04-07", "hash": "jTVAVSWGfN63yK6GBAd5xgNMDaavx4ytfl7A-R85ATk=", "aaid": "1EA8#8081", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-04-07"}]}, {"url": "https://mds.fidoalliance.org/metadata/4746%233208", "timeOfLastStatusChange": "2016-06-07", "hash": "DuuG4hxBhe-JoxOn8SzOcfW0m5O6MXNB3tVhsOqu1c8=", "aaid": "4746#3208", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-06-07"}]}, {"url": "https://mds.fidoalliance.org/metadata/4746%235206", "timeOfLastStatusChange": "2017-03-09", "hash": "olC6zN12P1i_7UqFpLnfHXAzUmmka1YyUk_V_EwZr8c=", "aaid": "4746#5206", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-03-09"}]}, {"url": "https://mds.fidoalliance.org/metadata/4746%23F816", "timeOfLastStatusChange": "2015-10-12", "hash": "PwhcRAxwjQxlwqoWoLhkEa-5uvOm4IDPMwFGL5kLDCs=", "aaid": "4746#F816", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2015-10-12"}]}, {"url": "https://mds.fidoalliance.org/metadata/4e4e%234005", "timeOfLastStatusChange": "2015-09-15", "hash": "jIFRspPdFbB6moFByGbzSuk_H2MPiqaOzdT1gzfnBOc=", "aaid": "4e4e#4005", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2015-09-15"}]}, {"url": "https://mds.fidoalliance.org/metadata/4e4e%234006", "timeOfLastStatusChange": "2016-03-14", "hash": "O2j4C7Flrtw-ddVGl1VcCjfvXaqCcw9nPwB0H0XzPJ8=", "aaid": "4e4e#4006", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-03-14"}]}, {"url": "https://mds.fidoalliance.org/metadata/4e4e%234009", "timeOfLastStatusChange": "2016-03-14", "hash": "eyLMF445cPL_TKscfYGeYrb-bYX02DnAdilw0KLGMLo=", "aaid": "4e4e#4009", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-03-14"}]}, {"url": "https://mds.fidoalliance.org/metadata/4e4e%23400a", "timeOfLastStatusChange": "2016-03-14", "hash": "VYqidG8Y8d9D6F7AreQiirOUUwKZj157EjDdUigFCos=", "aaid": "4e4e#400a", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-03-14"}]}, {"url": "https://mds.fidoalliance.org/metadata/4e4e%23400b", "timeOfLastStatusChange": "2016-03-14", "hash": "DSe_Ge8BJ-exVWDQx4PS_eddEebyNn0QKfFR1eTSBSw=", "aaid": "4e4e#400b", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-03-14"}]}, {"url": "https://mds.fidoalliance.org/metadata/4e4e%234010", "timeOfLastStatusChange": "2016-03-14", "hash": "0hIIbR4jegPdXCV3Ff-blc0u-RmYZzARuj4AUbKTGqw=", "aaid": "4e4e#4010", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-03-14"}]}, {"url": "https://mds.fidoalliance.org/metadata/4e4e%234011", "timeOfLastStatusChange": "2016-03-14", "hash": "mUK8rUDkGASjp5C61PQCEmSxRoNI5iY2cZCnD0zy9gg=", "aaid": "4e4e#4011", "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2016-03-14"}]}, {"url": "https://mds.fidoalliance.org/metadata/9zMUFaoTE82iWu9uJ4NxZ8", "hash": "ECS-jtrrH2h2JLFxq1HeI7et2WWE8tV6GsR3U9vskqs=", "timeOfLastStatusChange": "2017-11-28", "attestationCertificateKeyIdentifiers": ["923881fe2f214ee465484371aeb72e97f5a58e0a"], "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-11-28"}]}, {"url": "https://mds.fidoalliance.org/metadata/bbEPmd36hrosiVbxBZcG7f", "hash": "GWAKlKfVl10-h2iPB_nchbefarrbd1fToXIv1Y8cKWY=", "timeOfLastStatusChange": "2017-02-11", "attestationCertificateKeyIdentifiers": ["941b67384ff03330b70dcca58f721632f04726d2"], "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-02-11"}]}, {"url": "https://mds.fidoalliance.org/metadata/Bz2DLGtxPc4dSDFkeZ6BTC", "hash": "Yi727IE-ERdlBHOerPNxra1i6kNrjjPZ_hw5Dd_qQBo=", "timeOfLastStatusChange": "2017-01-24", "attestationCertificateKeyIdentifiers": ["418377e213db14abc6509db5e10c9598b42f92ea"], "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-01-24"}]}, {"url": "https://mds.fidoalliance.org/metadata/DAB8%230011", "timeOfLastStatusChange": "2015-10-02", "hash": "y4iOJZuKLv1EXkuWAQkXQuAx3nb8LvBtWx9JLqiVB68=", "aaid": "DAB8#0011", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2015-10-02"}]}, {"url": "https://mds.fidoalliance.org/metadata/DAB8%231011", "timeOfLastStatusChange": "2015-12-23", "hash": "anuMQhZzKRzFHJ2wZiYUvG1rQqm87uaNCxRMPxwDVyI=", "aaid": "DAB8#1011", "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2015-12-23"}]}, {"url": "https://mds.fidoalliance.org/metadata/eS7v8sum4jxp7kgLQ5Qqcg", "hash": "RDzwtYClWUyarU-7YsKc87SbJRKrtn8CzHuia23PFnw=", "timeOfLastStatusChange": "2017-03-14", "attestationCertificateKeyIdentifiers": ["d5db4dd48fe46afd8af8f1f7cfbdee61640bbbcc", "55464d5bea84e7073074b21d1204934358c7db4d"], "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-03-14"}]}, {"url": "https://mds.fidoalliance.org/metadata/FbFZ2KFvi9BCrUdSsZJDRe", "hash": "UlKtQIyhiuw4Tz2Hs_U70DiboFsV-AbVKNxKTNUMjsI=", "timeOfLastStatusChange": "2017-02-08", "attestationCertificateKeyIdentifiers": ["d3a1598c09dcd51142973f1bb7c8bd652e93b105"], "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-02-08"}]}, {"url": "https://mds.fidoalliance.org/metadata/JKP5CiDehdMMPwtG5i7to5", "hash": "BMb6U9KIlALenQBo2KF_3IgM5ddiOKfIO0IW5S_r83w=", "timeOfLastStatusChange": "2017-03-02", "attestationCertificateKeyIdentifiers": ["a5a3530e03a0f2118399ac0b6c3c9d552a0d34f8"], "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-03-02"}]}, {"url": "https://mds.fidoalliance.org/metadata/mNSPLuzgyDaVAzUG7HAEN9", "hash": "ecZcxIXp24XyYbGIdbmu7NhJg4G3p6qxQTaQW08nwrc=", "timeOfLastStatusChange": "2018-04-13", "attestationCertificateKeyIdentifiers": ["2d0188b9e2552fee0ab6a612641de966841ebe2b", "1ea89c916d2ac3cf262b7832299c48d8b48ce323"], "statusReports": [{"status": "NOT_FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2018-04-13"}]}, {"url": "https://mds.fidoalliance.org/metadata/N9Uo7W4cNnva72LqwGJRnd", "hash": "eVdKElX2jex4_RhEeq1uib18FpOpf0QCP48rQX1bENc=", "timeOfLastStatusChange": "2017-02-20", "attestationCertificateKeyIdentifiers": ["6bab19c6c097f19060ce5404000380c32fa6a8e6"], "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-02-20"}]}, {"url": "https://mds.fidoalliance.org/metadata/uPTfqAPbaZsCt2vyeuTjzK", "hash": "vSQ2lVgA6J1o80It1C-yo5YXi3KAmmyFRrVdoIb5L_c=", "timeOfLastStatusChange": "2017-11-28", "attestationCertificateKeyIdentifiers": ["6cd99d8b0abfa6a4378138a1475f7e46df217a25", "7a8fe37a42bbf2a5b3e6574d6f04bdbc55e59047", "c10bc4c6f614b63371d929596ededde3e458404d", "76e47b47e32814aaa6a87c280cfcbd527881a404"], "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-11-28"}]}, {"url": "https://mds.fidoalliance.org/metadata/V4fzAdVFDjQ8xgy4vk2DsQ", "hash": "D0Lkw8H6_A6PU6HiR7cnVvlI7NvAoSID9ZFtYO0bpms=", "timeOfLastStatusChange": "2017-02-08", "attestationCertificateKeyIdentifiers": ["c88871a438ef97c4d83207d6f16113927af8ef3a"], "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-02-08"}]}, {"url": "https://mds.fidoalliance.org/metadata/WRD8z2WRy9Le4NemGUK6vA", "hash": "2bzCVBePcHuwk17cnt5UqBKojdaJbYUKijF4tmEq3Ws=", "timeOfLastStatusChange": "2018-02-09", "attestationCertificateKeyIdentifiers": ["5fbc4ba753052187aab3c741d1f9ec6fb3c4d875", "2eb9ff3572f67628d1291a3b57924f818aad9e72"], "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2018-02-09"}]}, {"url": "https://mds.fidoalliance.org/metadata/yMUFCP2qzjsYsbHgEYZSV9", "hash": "6JnYkz4TD8uwsHeQSp8-_YFmhdA-p0kaNH_7mqB_0cs=", "timeOfLastStatusChange": "2017-03-23", "attestationCertificateKeyIdentifiers": ["fbec12c428774d31be4d77236758ea3c041a2ed0"], "statusReports": [{"status": "FIDO_CERTIFIED", "url": "", "certificate": "", "effectiveDate": "2017-03-23"}]}]}.XUDpXgWFEy2r2vvJVsk3pxADqu53nGsiF36F6q9aZFqJ_0b6X0eTS_xUggV61vFgX3_FLYtxpwJlBSSdw1__yQ

See also: auth0/node-jsonwebtoken#314

pocketcolin commented 2 years ago

Apple's new notification system is using x5c as well. This post is from 2018, but the docs have X.509 support listed under TODO; any idea when that might happen?

Atduyar commented 1 year ago

+1

dankantor commented 1 year ago

You can do this with Node 15+ -

import {X509Certificate} from 'node:crypto';

// create an x509 Certficate
const x509 = new X509Certificate(`-----BEGIN CERTIFICATE-----
          ${x5c[0]}
-----END CERTIFICATE-----`);
let verified = await jwt.verify(encodedToken, x509.publicKey);

If you need to verify a chain -

import {X509Certificate} from 'node:crypto';

// create an x509 Certficate
const x5091 = new X509Certificate(`-----BEGIN CERTIFICATE-----
          ${x5c[1]}
-----END CERTIFICATE-----`);

// create the second x509 Certificate
const x5090 = new X509Certificate(`-----BEGIN CERTIFICATE-----
          ${x5[0]}
-----END CERTIFICATE-----`);
if (x5090.verify(x5091.publicKey) === true) {
    let verified = await jwt.verify(response.signedTransactionInfo, x5090.publicKey);
}