From 3756e67b6e46f2bacca7c8816d37737ec89f19e0 Mon Sep 17 00:00:00 2001 From: Lars Wirzenius Date: Wed, 12 Jul 2017 14:25:52 +0300 Subject: Add: script to create JWT tokens Tests will use this to run test using real tokens, without having to have access to an IDP. --- create-token | 42 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100755 create-token (limited to 'create-token') diff --git a/create-token b/create-token new file mode 100755 index 0000000..cf99c93 --- /dev/null +++ b/create-token @@ -0,0 +1,42 @@ +#!/usr/bin/python3 +# Copyright (C) 2017 Lars Wirzenius +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU Affero General Public License as +# published by the Free Software Foundation, either version 3 of the +# License, or (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Affero General Public License for more details. +# +# You should have received a copy of the GNU Affero General Public License +# along with this program. If not, see . + + +import sys +import time + +import Crypto.PublicKey.RSA + +import apifw + + +filename = sys.argv[1] +aud = sys.argv[2] + +key_text = open(filename, 'r').read() +key = Crypto.PublicKey.RSA.importKey(key_text) + +now = time.time() +claims = { + 'iss': 'https://idp.example.com', + 'sub': 'subject-uuid', + 'aud': aud, + 'exp': now + 3600, + 'scope': 'openid person_resource_id uapi_orgs_get uapi_orgs_post' +} + +token = apifw.create_token(claims, key) +sys.stdout.write(token.decode('ascii')) -- cgit v1.2.1