diff options
Diffstat (limited to 'create-token')
-rwxr-xr-x | create-token | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/create-token b/create-token new file mode 100755 index 0000000..4ccf29c --- /dev/null +++ b/create-token @@ -0,0 +1,56 @@ +#!/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 <http://www.gnu.org/licenses/>. + + +import sys +import time + +import Crypto.PublicKey.RSA +import jwt + + +JWT_SIGNING_ALGORITHM = 'RS512' + + + +def create_token(claims, signing_key): + return jwt.encode( + claims, + signing_key.exportKey('PEM'), + algorithm=JWT_SIGNING_ALGORITHM) + + +keyfile = sys.argv[1] +scopes = ' '.join(sys.argv[2].split()) + +iss = 'test.iss' +aud = 'test.aud' +sub = 'test.sub' + +key_text = open(keyfile, 'r').read() +key = Crypto.PublicKey.RSA.importKey(key_text) + +now = int(time.time()) +claims = { + 'iss': iss, + 'sub': sub, + 'aud': aud, + 'exp': now + 3600, + 'scope': scopes, +} + +token = create_token(claims, key) +sys.stdout.write(token.decode('ascii')) |