Create function to generates a signed JWT Token

Priority

Environment

None

Template

None

Description

Purpose:
In order use the cost per use controller api, we will need a function to generate a signed JWT token. This Token gets passed as a header to api calls.

Plans are to call this function from APIGEE which in turn will call the Cost per Use Controller. JS, Node, Java, and Python are valid languages for the function with preferences for Node and/or Python

Inputs to function are customerownerid,(numeric) signing key (string)
Output is a signed JWT Token (string)

JSON structure for token
https://confluence.epnet.com/display/GSE/Cost+Per+Use+JWT+Token

Spike timeframe: 5 days

Development Team

Spitfire

Release

None

Story Points

Sprint

Attachments

2

Checklist

hide

TestRail: Results

Activity

Show:

Oleksii PetrenkoAugust 21, 2020 at 12:56 PM

Closing

maksym_dryhaAugust 19, 2020 at 12:15 PM

, , please, have a look at the final version of the service: https://github.com/MaksymDryha/jwt-service
And this is the zipped source code:

For this to work, jsrsasign, moment and uuid packages must be installed.

GET /jwt request must include the customerOwnerId query param and signingkey header

Sobha DuvvuriAugust 17, 2020 at 2:52 PM

: Heard from Adam of APIGEE and he needs it to be a simple web service.
His example code of how he is wrapping our function in a web service:

In order to use node, I have to do a "hosted service" which is just a proxy made entirely out of node. From there, I callout to this web service and get the JWT that way. He also mentioned that the code will be hosted by APIGEE itself.

maksym_dryhaAugust 14, 2020 at 12:59 PM

Usage:

APIGEE is using an old version of nodejs, so it's necessary to bundle the code with webpack and transpile it using babel.

Done

Details

Assignee

Reporter

Fix versions

TestRail: Cases

Open TestRail: Cases

TestRail: Runs

Open TestRail: Runs

Created August 6, 2020 at 9:17 PM
Updated September 15, 2020 at 8:31 AM
Resolved August 21, 2020 at 12:56 PM
TestRail: Cases
TestRail: Runs