summaryrefslogtreecommitdiff
path: root/create-token
diff options
context:
space:
mode:
Diffstat (limited to 'create-token')
-rwxr-xr-xcreate-token56
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'))