Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

#75 Add back configurable access token creation plugin support #76

Open
wants to merge 9 commits into
base: master
Choose a base branch
from

Conversation

fmeschbe
Copy link
Collaborator

@fmeschbe fmeschbe commented Jul 7, 2021

Description

Implementing the feature proposal of issue #75:

  • Two methods setPlugins and getPlugins added to the Context class
  • Overwriting implementation in the ConfigCliContext class using the plugins configuration property for pesistence
  • StateActionContext does not overwrite these methods as configurable token creation plugins are not part of this proposal. They might be added in the future.
  • Updated token-helper.js to support configurable plugins:
    • Merge default plugins with configurable plugins
    • Lazy load all plugins only as required (also applied to the default plugins for consistency and marginal performance improvement)

Related Issue

#75 Add back configurable access token creation plugin support

Motivation and Context

I have use cases for different ways of creation access tokens beyond what the default plugins offer. Having configurable token creation plugins solves my needs for easy extensibility.

How Has This Been Tested?

Added test cases and tested with my own token creation plugins.

Screenshots (if appropriate):

n/a

Types of changes

  • Bug fix (non-breaking change which fixes an issue)
  • New feature (non-breaking change which adds functionality)
  • Breaking change (fix or feature that would cause existing functionality to change)

Checklist:

  • I have signed the Adobe Open Source CLA.
  • My code follows the code style of this project.
  • My change requires a change to the documentation.
  • I have updated the documentation accordingly.
  • I have read the CONTRIBUTING document.
  • I have added tests to cover my changes.
  • All new and existing tests passed.

fmeschbe added 8 commits July 6, 2021 15:31
* For now only in the CLI context not in the StateAction context
* Fully lazily load plugins on use
* Additional plugins are "labeled" after their location from
  where they are required as plugins are configured as an array
  rather than a map
only added in NodeJS 12 .. requiring NodeJS 12
@codecov
Copy link

codecov bot commented Jul 7, 2021

Codecov Report

Merging #76 (7aa6b7e) into master (a4839cc) will not change coverage.
The diff coverage is 100.00%.

Impacted file tree graph

@@            Coverage Diff            @@
##            master       #76   +/-   ##
=========================================
  Coverage   100.00%   100.00%           
=========================================
  Files            8         8           
  Lines          426       464   +38     
  Branches        56        62    +6     
=========================================
+ Hits           426       464   +38     
Impacted Files Coverage Δ
src/context.js 100.00% <100.00%> (ø)
src/ctx/ConfigCliContext.js 100.00% <100.00%> (ø)
src/ctx/Context.js 100.00% <100.00%> (ø)
src/token-helper.js 100.00% <100.00%> (ø)

Continue to review full report at Codecov.

Legend - Click here to learn more
Δ = absolute <relative> (impact), ø = not affected, ? = missing data
Powered by Codecov. Last update a4839cc...7aa6b7e. Read the comment docs.

@@ -13,7 +13,7 @@ governing permissions and limitations under the License.
const { Ims, ACCESS_TOKEN, REFRESH_TOKEN } = require('./ims')
const aioLogger = require('@adobe/aio-lib-core-logging')('@adobe/aio-lib-ims:token-helper', { provider: 'debug' })
const { getContext } = require('./context')
const imsJwtPlugin = require('@adobe/aio-lib-ims-jwt')
const imsJwtPlugin = '@adobe/aio-lib-ims-jwt'
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Have you had the chance to test the ims lib in a runtime action? Otherwise we will test it, the reason we do a static require is to let webpack optimizer know it has to include the '@adobe/aio-lib-ims-jwt' module when bundling/compiling the action code

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nope, only tested the CLI, actually.

That is a good point regarding web pack. Can web pack be instructed to consider this dependency also in another way ?

If not we could revert this to be a static import and adapt the loadPlugin function accordingly.

Copy link
Collaborator

@fe-lix- fe-lix- Feb 22, 2022

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm trying to understand better how web pack is working, but a quick and dirty solution to this issue would be :

diff --git a/src/token-helper.js b/src/token-helper.js
index c2c37ae..9b774a3 100644
--- a/src/token-helper.js
+++ b/src/token-helper.js
@@ -13,7 +13,7 @@ governing permissions and limitations under the License.
 const { Ims, ACCESS_TOKEN, REFRESH_TOKEN } = require('./ims')
 const aioLogger = require('@adobe/aio-lib-core-logging')('@adobe/aio-lib-ims:token-helper', { provider: 'debug' })
 const { getContext } = require('./context')
-const imsJwtPlugin = '@adobe/aio-lib-ims-jwt'
+const imsJwtPlugin = require('@adobe/aio-lib-ims-jwt')
 const { codes: errors } = require('./errors')
 
 /**
@@ -80,6 +80,10 @@ async function getMergedPlugins (context) {
 function loadPlugin (name, location) {
   aioLogger.debug('loadPlugin(%s, %s)', name, location)
 
+  if (name === 'jwt') {
+    return imsJwtPlugin
+  }
+
   try {
     return require(location)
   } catch (error) {

@purplecabbage
Copy link
Member

@fmeschbe Do you have pseudocode of how a plugin would be used here?

@fmeschbe
Copy link
Collaborator Author

fmeschbe commented Jul 14, 2021

Do you have pseudocode of how a plugin would be used here?

@purplecabbage I am not sure, where this question goes as the usage of plugins is here in the tokenhelper.js/_generateToken function and this looks pretty clear to me:

plugins = getMergedPlugins()
for plugin in plugins {
  pluginObject = loadPlugin(plugin)
  if (pluginObject.supports(config)) {
    try {
      return pluginObject.createToken(...)
    } catch {
      // log or fail
    }
  }
}

The main changes to existing code are (a) getting a merged list of plugins from the static configuration in the code and the dynamic configuration in the config and (b) on-demand loading the plugin as needed/required

@fe-lix-
Copy link
Collaborator

fe-lix- commented Feb 23, 2022

Updated the PR with current master branch.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants