├── .gitignore ├── .java-version ├── CODE_OF_CONDUCT.md ├── CONTRIBUTING.md ├── LICENSE ├── README.md ├── auth-functions ├── pom.xml └── src │ ├── app.js │ ├── main │ └── java │ │ └── com │ │ └── auth │ │ ├── App.java │ │ ├── CustomLambdaAuth.java │ │ └── TrustedStoreCustomResourceHandler.java │ └── package.json ├── auth0-custom-auth-lambda ├── index.js ├── lib.js ├── package-lock.json └── package.json ├── events └── event.json ├── template-all-auth.yaml ├── template-auth0.yaml ├── template-cognito.yaml └── template.yaml /.gitignore: -------------------------------------------------------------------------------- 1 | backend-infrastructure/.aws-sam 2 | 3 | # Created by https://www.gitignore.io/api/osx,linux,python,windows,pycharm,visualstudiocode 4 | 5 | ### Linux ### 6 | *~ 7 | 8 | # temporary files which can be created if a process still has a handle open of a deleted file 9 | .fuse_hidden* 10 | 11 | # KDE directory preferences 12 | .directory 13 | 14 | # Linux trash folder which might appear on any partition or disk 15 | .Trash-* 16 | 17 | # .nfs files are created when an open file is removed but is still being accessed 18 | .nfs* 19 | 20 | ### OSX ### 21 | *.DS_Store 22 | .AppleDouble 23 | .LSOverride 24 | 25 | # Icon must end with two \r 26 | Icon 27 | 28 | # Thumbnails 29 | ._* 30 | 31 | # Files that might appear in the root of a volume 32 | .DocumentRevisions-V100 33 | .fseventsd 34 | .Spotlight-V100 35 | .TemporaryItems 36 | .Trashes 37 | .VolumeIcon.icns 38 | .com.apple.timemachine.donotpresent 39 | 40 | # Directories potentially created on remote AFP share 41 | .AppleDB 42 | .AppleDesktop 43 | Network Trash Folder 44 | Temporary Items 45 | .apdisk 46 | 47 | ### PyCharm ### 48 | # Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm, CLion, Android Studio and Webstorm 49 | # Reference: https://intellij-support.jetbrains.com/hc/en-us/articles/206544839 50 | 51 | # User-specific stuff: 52 | .idea/**/workspace.xml 53 | .idea/**/tasks.xml 54 | .idea/dictionaries 55 | .idea/ 56 | 57 | # Sensitive or high-churn files: 58 | .idea/**/dataSources/ 59 | .idea/**/dataSources.ids 60 | .idea/**/dataSources.xml 61 | .idea/**/dataSources.local.xml 62 | .idea/**/sqlDataSources.xml 63 | .idea/**/dynamic.xml 64 | .idea/**/uiDesigner.xml 65 | 66 | # Gradle: 67 | .idea/**/gradle.xml 68 | .idea/**/libraries 69 | 70 | # CMake 71 | cmake-build-debug/ 72 | 73 | # Mongo Explorer plugin: 74 | .idea/**/mongoSettings.xml 75 | 76 | ## File-based project format: 77 | *.iws 78 | 79 | ## Plugin-specific files: 80 | 81 | # IntelliJ 82 | /out/ 83 | 84 | # mpeltonen/sbt-idea plugin 85 | .idea_modules/ 86 | 87 | # JIRA plugin 88 | atlassian-ide-plugin.xml 89 | 90 | # Cursive Clojure plugin 91 | .idea/replstate.xml 92 | 93 | # Ruby plugin and RubyMine 94 | /.rakeTasks 95 | 96 | # Crashlytics plugin (for Android Studio and IntelliJ) 97 | com_crashlytics_export_strings.xml 98 | crashlytics.properties 99 | crashlytics-build.properties 100 | fabric.properties 101 | 102 | ### PyCharm Patch ### 103 | # Comment Reason: https://github.com/joeblau/gitignore.io/issues/186#issuecomment-215987721 104 | 105 | *.iml 106 | modules.xml 107 | .idea/misc.xml 108 | *.ipr 109 | 110 | # Sonarlint plugin 111 | .idea/sonarlint 112 | 113 | ### Python ### 114 | # Byte-compiled / optimized / DLL files 115 | __pycache__/ 116 | *.py[cod] 117 | *$py.class 118 | 119 | # C extensions 120 | *.so 121 | 122 | # Distribution / packaging 123 | .Python 124 | build/ 125 | develop-eggs/ 126 | dist/ 127 | downloads/ 128 | eggs/ 129 | .eggs/ 130 | lib/ 131 | lib64/ 132 | parts/ 133 | sdist/ 134 | var/ 135 | wheels/ 136 | *.egg-info/ 137 | .installed.cfg 138 | *.egg 139 | 140 | # PyInstaller 141 | # Usually these files are written by a python script from a template 142 | # before PyInstaller builds the exe, so as to inject date/other infos into it. 143 | *.manifest 144 | *.spec 145 | 146 | # Installer logs 147 | pip-log.txt 148 | pip-delete-this-directory.txt 149 | 150 | # Unit test / coverage reports 151 | htmlcov/ 152 | .tox/ 153 | .coverage 154 | .coverage.* 155 | .cache 156 | .pytest_cache/ 157 | nosetests.xml 158 | coverage.xml 159 | *.cover 160 | .hypothesis/ 161 | 162 | # Translations 163 | *.mo 164 | *.pot 165 | 166 | # Flask stuff: 167 | instance/ 168 | .webassets-cache 169 | 170 | # Scrapy stuff: 171 | .scrapy 172 | 173 | # Sphinx documentation 174 | docs/_build/ 175 | 176 | # PyBuilder 177 | target/ 178 | 179 | # Jupyter Notebook 180 | .ipynb_checkpoints 181 | 182 | # pyenv 183 | .python-version 184 | 185 | # celery beat schedule file 186 | celerybeat-schedule.* 187 | 188 | # SageMath parsed files 189 | *.sage.py 190 | 191 | # Environments 192 | .env 193 | .venv 194 | env/ 195 | venv/ 196 | ENV/ 197 | env.bak/ 198 | venv.bak/ 199 | 200 | # Spyder project settings 201 | .spyderproject 202 | .spyproject 203 | 204 | # Rope project settings 205 | .ropeproject 206 | 207 | # mkdocs documentation 208 | /site 209 | 210 | # mypy 211 | .mypy_cache/ 212 | 213 | ### VisualStudioCode ### 214 | .vscode/* 215 | !.vscode/settings.json 216 | !.vscode/tasks.json 217 | !.vscode/launch.json 218 | !.vscode/extensions.json 219 | .history 220 | 221 | ### Windows ### 222 | # Windows thumbnail cache files 223 | Thumbs.db 224 | ehthumbs.db 225 | ehthumbs_vista.db 226 | 227 | # Folder config file 228 | Desktop.ini 229 | 230 | # Recycle Bin used on file shares 231 | $RECYCLE.BIN/ 232 | 233 | # Windows Installer files 234 | *.cab 235 | *.msi 236 | *.msm 237 | *.msp 238 | 239 | # Windows shortcuts 240 | *.lnk 241 | 242 | # Build folder 243 | 244 | */build/* 245 | samconfig-api.toml 246 | samconfig-auth.toml 247 | .aws-sam 248 | .aws-sam/* 249 | 250 | /samconfig-apiauth.toml 251 | /samconfig-jwt-auth.toml 252 | /samconfig-auth0.toml 253 | /samconfig-mtls.toml 254 | /samconfig-jwt.toml 255 | auth0-custom-auth-lambda/node_modules/ 256 | -------------------------------------------------------------------------------- /.java-version: -------------------------------------------------------------------------------- 1 | 1.8 2 | -------------------------------------------------------------------------------- /CODE_OF_CONDUCT.md: -------------------------------------------------------------------------------- 1 | ## Code of Conduct 2 | This project has adopted the [Amazon Open Source Code of Conduct](https://aws.github.io/code-of-conduct). 3 | For more information see the [Code of Conduct FAQ](https://aws.github.io/code-of-conduct-faq) or contact 4 | opensource-codeofconduct@amazon.com with any additional questions or comments. 5 | -------------------------------------------------------------------------------- /CONTRIBUTING.md: -------------------------------------------------------------------------------- 1 | # Contributing Guidelines 2 | 3 | Thank you for your interest in contributing to our project. Whether it's a bug report, new feature, correction, or additional 4 | documentation, we greatly value feedback and contributions from our community. 5 | 6 | Please read through this document before submitting any issues or pull requests to ensure we have all the necessary 7 | information to effectively respond to your bug report or contribution. 8 | 9 | 10 | ## Reporting Bugs/Feature Requests 11 | 12 | We welcome you to use the GitHub issue tracker to report bugs or suggest features. 13 | 14 | When filing an issue, please check existing open, or recently closed, issues to make sure somebody else hasn't already 15 | reported the issue. Please try to include as much information as you can. Details like these are incredibly useful: 16 | 17 | * A reproducible test case or series of steps 18 | * The version of our code being used 19 | * Any modifications you've made relevant to the bug 20 | * Anything unusual about your environment or deployment 21 | 22 | 23 | ## Contributing via Pull Requests 24 | Contributions via pull requests are much appreciated. Before sending us a pull request, please ensure that: 25 | 26 | 1. You are working against the latest source on the *main* branch. 27 | 2. You check existing open, and recently merged, pull requests to make sure someone else hasn't addressed the problem already. 28 | 3. You open an issue to discuss any significant work - we would hate for your time to be wasted. 29 | 30 | To send us a pull request, please: 31 | 32 | 1. Fork the repository. 33 | 2. Modify the source; please focus on the specific change you are contributing. If you also reformat all the code, it will be hard for us to focus on your change. 34 | 3. Ensure local tests pass. 35 | 4. Commit to your fork using clear commit messages. 36 | 5. Send us a pull request, answering any default questions in the pull request interface. 37 | 6. Pay attention to any automated CI failures reported in the pull request, and stay involved in the conversation. 38 | 39 | GitHub provides additional document on [forking a repository](https://help.github.com/articles/fork-a-repo/) and 40 | [creating a pull request](https://help.github.com/articles/creating-a-pull-request/). 41 | 42 | 43 | ## Finding contributions to work on 44 | Looking at the existing issues is a great way to find something to contribute on. As our projects, by default, use the default GitHub issue labels (enhancement/bug/duplicate/help wanted/invalid/question/wontfix), looking at any 'help wanted' issues is a great place to start. 45 | 46 | 47 | ## Code of Conduct 48 | This project has adopted the [Amazon Open Source Code of Conduct](https://aws.github.io/code-of-conduct). 49 | For more information see the [Code of Conduct FAQ](https://aws.github.io/code-of-conduct-faq) or contact 50 | opensource-codeofconduct@amazon.com with any additional questions or comments. 51 | 52 | 53 | ## Security issue notifications 54 | If you discover a potential security issue in this project we ask that you notify AWS/Amazon Security via our [vulnerability reporting page](http://aws.amazon.com/security/vulnerability-reporting/). Please do **not** create a public github issue. 55 | 56 | 57 | ## Licensing 58 | 59 | See the [LICENSE](LICENSE) file for our project's licensing. We will ask you to confirm the licensing of your contribution. 60 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. 2 | 3 | Permission is hereby granted, free of charge, to any person obtaining a copy of 4 | this software and associated documentation files (the "Software"), to deal in 5 | the Software without restriction, including without limitation the rights to 6 | use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of 7 | the Software, and to permit persons to whom the Software is furnished to do so. 8 | 9 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 10 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS 11 | FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR 12 | COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER 13 | IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 14 | CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 15 | 16 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | ## api-gateway-auth 2 | 3 | **[Feature request](https://github.com/aws-samples/api-gateway-auth/issues/new)** | **[Detailed blog post](https://aws.amazon.com/blogs/compute/automating-mutual-tls-setup-for-amazon-api-gateway/)** 4 | 5 | This sample application showcases how to set up and automate different types of authentication supported by 6 | [Amazon API Gateway HTTP API](https://docs.aws.amazon.com/apigateway/latest/developerguide/http-api.html) via [AWS SAM](https://docs.aws.amazon.com/serverless-application-model/latest/developerguide/what-is-sam.html) 7 | 8 | - [Mutual TLS](https://docs.aws.amazon.com/apigateway/latest/developerguide/http-api-mutual-tls.html) 9 | - [JWT authorizers](https://docs.aws.amazon.com/apigateway/latest/developerguide/http-api-jwt-authorizer.html) 10 | - [AWS Lambda authorizers](https://docs.aws.amazon.com/apigateway/latest/developerguide/http-api-lambda-authorizer.html) 11 | - [IAM authorization](https://docs.aws.amazon.com/apigateway/latest/developerguide/http-api-access-control-iam.html) (Not supported via SAM. Ref [issue](https://github.com/aws/aws-sam-cli/issues/2233))] 12 | 13 | This SAM app uses java as language runtime for the lambda functions and custom resources. 14 | 15 | # Setup 16 | 17 | ## All authentications methods including mTLS: 18 | 19 | The main SAM [template-all-auth.yaml](template-all-auth.yaml) is used to set up HTTP API and different types of auth mentioned above. 20 | As a pre requisite step, in order to configure JWT authorizer, you will need to run [template-cognito.yaml](template-cognito.yaml) 21 | to setup [Amazon Cognito](https://aws.amazon.com/cognito/) as the JWT token provider. If you wish to have and 22 | HTTP API setup with only mTLS, follow section [Only mTLS with HTTP API setup](#Only mTLS with HTTP API setup). Lets begin. 23 | 24 | #### Setup JWT Token provider 25 | 26 | This will end up creating cognito user pool which we will use to set up our HTTP API with different auths. 27 | This is needed because we will use [Amazon Cognito](https://aws.amazon.com/cognito/) as the JWT token provider. 28 | You can skip this step if you are not going to configure JWT Authorizer for your HTTP API 29 | in [template-all-auth.yaml](template-all-auth.yaml#L174) 30 | 31 | ``` 32 | api-gateway-auth$ sam build -t template-cognito.yaml 33 | ``` 34 | 35 | ``` 36 | api-gateway-auth$ sam deploy -t .aws-sam/build/template.yaml -g 37 | 38 | Deploying with following values 39 | =============================== 40 | Stack name : jwt-auth 41 | Region : eu-west-1 42 | Confirm changeset : False 43 | Deployment s3 bucket : aws-sam-cli-managed-default-samclisourcebucket-randomhash 44 | Capabilities : ["CAPABILITY_IAM"] 45 | Parameter overrides : {'AppName': 'jwt-auth', 'ClientDomains': 'http://localhost:8080', 'AdminEmail': 'emailaddress@example.com', 'AddGroupsToScopes': 'true'} 46 | 47 | ``` 48 | 49 | #### Set up HTTP API 50 | 51 | ``` 52 | api-gateway-auth$ sam build -t template-all-auth.yaml 53 | ``` 54 | 55 | ``` 56 | api-gateway-auth$ sam deploy -t .aws-sam/build/template.yaml 57 | 58 | Deploying with following values 59 | =============================== 60 | Stack name : http-api-authdemo 61 | Region : eu-west-1 62 | Confirm changeset : False 63 | Deployment s3 bucket : aws-sam-cli-managed-default-samclisourcebucket-randomhash 64 | Capabilities : ["CAPABILITY_IAM"] 65 | Parameter overrides : {'UserPoolId': 'from previous stack output', 'Audience': 'from previous stack output', 'HostedZoneId': 'Hosted zone id for custom domain', 'DomainName': 'domain name for the http api', 'TruststoreKey': 'truststore.pem'} 66 | ``` 67 | 68 | ## Only mTLS with HTTP API setup 69 | 70 | #### Set up HTTP API 71 | 72 | ``` 73 | api-gateway-auth$ sam build 74 | ``` 75 | 76 | ``` 77 | api-gateway-auth$ sam deploy -t 78 | 79 | Deploying with following values 80 | =============================== 81 | Stack name : http-api-authdemo 82 | Region : eu-west-1 83 | Confirm changeset : False 84 | Deployment s3 bucket : aws-sam-cli-managed-default-samclisourcebucket-randomhash 85 | Capabilities : ["CAPABILITY_IAM"] 86 | Parameter overrides : {'HostedZoneId': 'Hosted zone id for custom domain', 'DomainName': 'domain name for the http api', 'TruststoreKey': 'truststore.pem'} 87 | ``` 88 | 89 | 90 | ## Testing and validation 91 | 92 | At this point, your stack should update successfully and you will have a HTTP API with Mutual TLS setup by default using 93 | [AWS Certificate Manager Private Certificate Authority](https://aws.amazon.com/certificate-manager/private-certificate-authority/). 94 | 95 | Stack will also generate one of the client certificates for you to validate the API and output its ARN as stack output 96 | 97 | ####Export certificate via Console: 98 | 99 | - Navigate to [AWS Certificate Manager console](https://console.aws.amazon.com/acm/home). You will find a private 100 | certificate already generated with Name as ClientOneCert. 101 | 102 | - Select the cert and under action choose `Export (Private certificates only)`. Enter passphrase on next screen which 103 | will be needed to decrypt the `Certificate private key` later. 104 | 105 | - `Export certificate body to a file` and `Export certificate private key to a file` 106 | 107 | #### Export certificate via CLI: 108 | 109 | ``` 110 | aws acm export-certificate --certificate-arn <> --passphrase $(echo -n 'your paraphrase' | base64) --no-cli-auto-prompt --region eu-west-1 | jq -r '"\(.Certificate)"' > client.pem 111 | ``` 112 | 113 | ``` 114 | aws acm export-certificate --certificate-arn <> --passphrase $(echo -n 'your paraphrase' | base64) --no-cli-auto-prompt --region eu-west-1 | jq -r '"\(.PrivateKey)"' > client.encrypted.key 115 | ``` 116 | 117 | #### Decrypt the private key 118 | 119 | - Decrypt private key downloaded using below command: 120 | 121 | ``` 122 | openssl rsa -in <> -out client.decrypted.key 123 | 124 | Enter pass phrase for client.encrypted.txt: 125 | writing RSA key 126 | ``` 127 | 128 | #### Call the HTTP API to validate mTLS 129 | 130 | - Now you should be able to access the configured api with different paths and auth methods using mutual TLS. 131 | 132 | ``` 133 | curl -v --cert client.pem --key client.decrypted.key https://<> 134 | ``` 135 | 136 | ## Auth0 setup for REST and HTTP API 137 | 138 | API gateway both REST and HTTP can be configured to work with [Auth0](https://auth0.com/). There is a sample template 139 | [template-auth0.yaml](template-auth0.yaml) which sets up sample REST and HTTP Api to work with Auth0. 140 | 141 | Template expects two parameters: 142 | 143 | - IssuerUrl: The issuer of the token. Use https://YOUR_DOMAIN/. Be sure to include the trailing slash. 144 | - APIAudience: The identifier value of the API you created in the Auth0 API. 145 | 146 | HTTP API will be set up using native [JWT Authorizers](https://docs.aws.amazon.com/apigateway/latest/developerguide/http-api-jwt-authorizer.html) 147 | while REST API will be set up using [Token based Lambda Authorizers](https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-use-lambda-authorizer.html) 148 | to integrate with Auth0. 149 | 150 | ### Setup 151 | 152 | ``` 153 | api-gateway-auth$ sam build -t template-auth0.yaml 154 | ``` 155 | 156 | ``` 157 | api-gateway-auth$ sam deploy -t .aws-sam/build/template.yaml 158 | ``` 159 | 160 | ## Credits 161 | 162 | Setting up of JWT authorizer is inspired from example in [sessions-with-aws-sam](https://github.com/aws-samples/sessions-with-aws-sam/tree/master/cognito) 163 | 164 | ## Security 165 | 166 | See [CONTRIBUTING](CONTRIBUTING.md#security-issue-notifications) for more information. 167 | 168 | ## License 169 | 170 | This library is licensed under the MIT-0 License. See the LICENSE file. 171 | 172 | -------------------------------------------------------------------------------- /auth-functions/pom.xml: -------------------------------------------------------------------------------- 1 | 3 | 4.0.0 4 | api-gateway 5 | auth-functions 6 | 1.0 7 | jar 8 | Auth functions 9 | 10 | 1.8 11 | 1.8 12 | 2.17.129 13 | 14 | 15 | 16 | 17 | 18 | software.amazon.awssdk 19 | bom 20 | ${aws.java.sdk.version} 21 | pom 22 | import 23 | 24 | 25 | 26 | 27 | 28 | 29 | com.amazonaws 30 | aws-lambda-java-core 31 | 1.2.1 32 | 33 | 34 | com.amazonaws 35 | aws-lambda-java-events 36 | 3.11.0 37 | 38 | 39 | com.fasterxml.jackson.core 40 | jackson-core 41 | 2.13.1 42 | 43 | 44 | com.fasterxml.jackson.core 45 | jackson-databind 46 | 2.13.2.1 47 | 48 | 49 | junit 50 | junit 51 | 4.13.2 52 | test 53 | 54 | 55 | org.json 56 | json 57 | 20200518 58 | 59 | 60 | software.amazon.awssdk 61 | s3 62 | ${aws.java.sdk.version} 63 | 64 | 65 | software.amazon.awssdk 66 | apache-client 67 | 2.17.124 68 | 69 | 70 | 71 | 72 | 73 | 74 | org.apache.maven.plugins 75 | maven-shade-plugin 76 | 3.2.2 77 | 78 | false 79 | 80 | 81 | 82 | package 83 | 84 | shade 85 | 86 | 87 | 88 | 89 | 90 | 91 | 92 | -------------------------------------------------------------------------------- /auth-functions/src/app.js: -------------------------------------------------------------------------------- 1 | exports.lambdaHandler = async (event, context, callback) => { 2 | const newScopes = event.request.groupConfiguration.groupsToOverride.map(item => `${item}-${event.callerContext.clientId}`); 3 | 4 | event.response = { 5 | "claimsOverrideDetails": { 6 | "claimsToAddOrOverride": { 7 | "scope": newScopes.join(" "), 8 | } 9 | } 10 | }; 11 | 12 | callback(null, event) 13 | } -------------------------------------------------------------------------------- /auth-functions/src/main/java/com/auth/App.java: -------------------------------------------------------------------------------- 1 | package com.auth; 2 | 3 | import java.util.HashMap; 4 | 5 | import com.amazonaws.services.lambda.runtime.Context; 6 | import com.amazonaws.services.lambda.runtime.RequestHandler; 7 | import com.amazonaws.services.lambda.runtime.events.APIGatewayV2HTTPEvent; 8 | import com.amazonaws.services.lambda.runtime.events.APIGatewayV2HTTPResponse; 9 | import com.fasterxml.jackson.core.JsonProcessingException; 10 | import com.fasterxml.jackson.databind.ObjectMapper; 11 | 12 | /** 13 | * Handler for requests to Lambda function. 14 | */ 15 | public class App implements RequestHandler { 16 | private static final ObjectMapper OBJECT_MAPPER = new ObjectMapper(); 17 | 18 | public APIGatewayV2HTTPResponse handleRequest(final Object input, final Context context) { 19 | try { 20 | HashMap headers = new HashMap<>(); 21 | headers.put("Content-Type", "application/json"); 22 | return APIGatewayV2HTTPResponse.builder() 23 | .withStatusCode(200) 24 | .withHeaders(headers) 25 | .withIsBase64Encoded(false) 26 | .withBody(OBJECT_MAPPER.writeValueAsString(input)) 27 | .build(); 28 | } catch (JsonProcessingException e) { 29 | throw new RuntimeException(e); 30 | } 31 | } 32 | } 33 | -------------------------------------------------------------------------------- /auth-functions/src/main/java/com/auth/CustomLambdaAuth.java: -------------------------------------------------------------------------------- 1 | package com.auth; 2 | 3 | import java.util.HashMap; 4 | import java.util.Map; 5 | 6 | import com.amazonaws.services.lambda.runtime.Context; 7 | import com.amazonaws.services.lambda.runtime.RequestHandler; 8 | import com.amazonaws.services.lambda.runtime.events.APIGatewayV2CustomAuthorizerEvent; 9 | 10 | public class CustomLambdaAuth implements RequestHandler { 11 | private static final String SECRET_TOKEN = "SECRET_TOKEN"; 12 | 13 | @Override 14 | public Object handleRequest(final APIGatewayV2CustomAuthorizerEvent input, 15 | final Context context) { 16 | context.getLogger().log(input.toString()); 17 | 18 | Map response = new HashMap<>(); 19 | response.put("isAuthorized", "false"); 20 | 21 | String authHeaderValue = input.getHeaders().getOrDefault("authorization", ""); 22 | 23 | if (SECRET_TOKEN.equals(authHeaderValue)) { 24 | response.put("isAuthorized", "true"); 25 | } 26 | 27 | return response; 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /auth-functions/src/main/java/com/auth/TrustedStoreCustomResourceHandler.java: -------------------------------------------------------------------------------- 1 | package com.auth; 2 | 3 | import java.io.IOException; 4 | import java.io.OutputStreamWriter; 5 | import java.net.HttpURLConnection; 6 | import java.net.URL; 7 | import java.util.List; 8 | import java.util.concurrent.ExecutionException; 9 | import java.util.concurrent.ExecutorService; 10 | import java.util.concurrent.Executors; 11 | import java.util.concurrent.Future; 12 | import java.util.concurrent.TimeUnit; 13 | import java.util.concurrent.TimeoutException; 14 | import java.util.stream.Collectors; 15 | 16 | import com.amazonaws.services.lambda.runtime.Context; 17 | import com.amazonaws.services.lambda.runtime.LambdaLogger; 18 | import com.amazonaws.services.lambda.runtime.RequestHandler; 19 | import com.amazonaws.services.lambda.runtime.events.CloudFormationCustomResourceEvent; 20 | import org.json.JSONObject; 21 | import software.amazon.awssdk.core.sync.RequestBody; 22 | import software.amazon.awssdk.services.s3.S3Client; 23 | import software.amazon.awssdk.services.s3.model.DeleteObjectRequest; 24 | import software.amazon.awssdk.services.s3.model.DeleteObjectResponse; 25 | import software.amazon.awssdk.services.s3.model.PutObjectRequest; 26 | import software.amazon.awssdk.services.s3.model.PutObjectResponse; 27 | 28 | import static java.util.Collections.emptyList; 29 | 30 | public class TrustedStoreCustomResourceHandler implements RequestHandler { 31 | private static final S3Client S3_CLIENT = S3Client.create(); 32 | 33 | @Override 34 | public Object handleRequest(CloudFormationCustomResourceEvent input, Context context) { 35 | LambdaLogger logger = context.getLogger(); 36 | logger.log("Input: " + input); 37 | 38 | final String requestType = input.getRequestType(); 39 | 40 | ExecutorService service = Executors.newSingleThreadExecutor(); 41 | JSONObject responseData = new JSONObject(); 42 | String bucket = (String) input.getResourceProperties().getOrDefault("TrustStoreBucket", ""); 43 | String key = (String) input.getResourceProperties().getOrDefault("TrustStoreKey", ""); 44 | String concatenatedCert = String.join("\n", ((List) input.getResourceProperties().getOrDefault("Certs", emptyList()))); 45 | 46 | try { 47 | if (requestType == null | concatenatedCert.isEmpty()) { 48 | throw new RuntimeException(); 49 | } 50 | 51 | Runnable r = () -> { 52 | switch (requestType) { 53 | case "Create": { 54 | logger.log("CREATE!"); 55 | 56 | responseData.put("Message", "Resource creation successful!"); 57 | PutObjectResponse putObjectResponse = S3_CLIENT.putObject(PutObjectRequest.builder() 58 | .bucket(bucket) 59 | .key(key) 60 | .build(), RequestBody.fromString(concatenatedCert)); 61 | context.getLogger().log(putObjectResponse.toString()); 62 | responseData.put("TrustStoreUri", String.format("s3://%s/%s", bucket, key)); 63 | responseData.put("ObjectVersion", putObjectResponse.versionId()); 64 | sendResponse(input, context, "SUCCESS", responseData); 65 | break; 66 | } 67 | 68 | case "Update": { 69 | logger.log("UPDATE!"); 70 | 71 | PutObjectResponse putObjectResponse = S3_CLIENT.putObject(PutObjectRequest.builder() 72 | .bucket(bucket) 73 | .key(key) 74 | .build(), RequestBody.fromString(concatenatedCert)); 75 | 76 | context.getLogger().log(putObjectResponse.toString()); 77 | responseData.put("Message", "Resource update successful!"); 78 | responseData.put("TrustStoreUri", String.format("s3://%s/%s", bucket, key)); 79 | responseData.put("ObjectVersion", putObjectResponse.versionId()); 80 | sendResponse(input, context, "SUCCESS", responseData); 81 | break; 82 | } 83 | 84 | case "Delete": { 85 | logger.log("DELETE!"); 86 | sendResponse(input, context, "SUCCESS", responseData); 87 | break; 88 | } 89 | 90 | default: { 91 | logger.log("FAILURE!"); 92 | sendResponse(input, context, "FAILED", responseData); 93 | } 94 | } 95 | }; 96 | Future f = service.submit(r); 97 | f.get(context.getRemainingTimeInMillis() - 1000, TimeUnit.MILLISECONDS); 98 | } catch (final TimeoutException | InterruptedException 99 | | ExecutionException e) { 100 | logger.log("FAILURE!"); 101 | sendResponse(input, context, "FAILED", responseData); 102 | // Took too long! 103 | } finally { 104 | service.shutdown(); 105 | } 106 | return null; 107 | } 108 | 109 | /** 110 | * Send a response to CloudFormation regarding progress in creating resource. 111 | */ 112 | public final Object sendResponse( 113 | final CloudFormationCustomResourceEvent input, 114 | final Context context, 115 | final String responseStatus, 116 | JSONObject responseData) { 117 | 118 | String responseUrl = input.getResponseUrl(); 119 | context.getLogger().log("ResponseURL: " + responseUrl); 120 | 121 | URL url; 122 | try { 123 | url = new URL(responseUrl); 124 | HttpURLConnection connection = (HttpURLConnection) url.openConnection(); 125 | connection.setDoOutput(true); 126 | connection.setRequestMethod("PUT"); 127 | 128 | JSONObject responseBody = new JSONObject(); 129 | responseBody.put("Status", responseStatus); 130 | responseBody.put("PhysicalResourceId", context.getLogStreamName()); 131 | responseBody.put("StackId", input.getStackId()); 132 | responseBody.put("RequestId", input.getRequestId()); 133 | responseBody.put("LogicalResourceId", input.getLogicalResourceId()); 134 | responseBody.put("Data", responseData); 135 | 136 | OutputStreamWriter response = new OutputStreamWriter(connection.getOutputStream()); 137 | response.write(responseBody.toString()); 138 | response.close(); 139 | context.getLogger().log("Response Code: " + connection.getResponseCode()); 140 | 141 | } catch (IOException e) { 142 | e.printStackTrace(); 143 | } 144 | 145 | return null; 146 | } 147 | } 148 | -------------------------------------------------------------------------------- /auth-functions/src/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "trigger", 3 | "version": "1.0.0" 4 | } -------------------------------------------------------------------------------- /auth0-custom-auth-lambda/index.js: -------------------------------------------------------------------------------- 1 | const lib = require('./lib'); 2 | let data; 3 | 4 | // Lambda function index.handler - thin wrapper around lib.authenticate 5 | module.exports.handler = async (event, context, callback) => { 6 | try { 7 | data = await lib.authenticate(event); 8 | } 9 | catch (err) { 10 | console.log(err); 11 | return context.fail("Unauthorized"); 12 | } 13 | return data; 14 | }; -------------------------------------------------------------------------------- /auth0-custom-auth-lambda/lib.js: -------------------------------------------------------------------------------- 1 | require('dotenv').config({ silent: true }); 2 | 3 | const jwksClient = require('jwks-rsa'); 4 | const jwt = require('jsonwebtoken'); 5 | const util = require('util'); 6 | 7 | const getPolicyDocument = (effect, resource) => { 8 | const policyDocument = { 9 | Version: '2012-10-17', // default version 10 | Statement: [{ 11 | Action: 'execute-api:Invoke', // default action 12 | Effect: effect, 13 | Resource: resource, 14 | }] 15 | }; 16 | return policyDocument; 17 | } 18 | 19 | 20 | // extract and return the Bearer Token from the Lambda event parameters 21 | const getToken = (params) => { 22 | if (!params.type || params.type !== 'TOKEN') { 23 | throw new Error('Expected "event.type" parameter to have value "TOKEN"'); 24 | } 25 | 26 | const tokenString = params.authorizationToken; 27 | if (!tokenString) { 28 | throw new Error('Expected "event.authorizationToken" parameter to be set'); 29 | } 30 | 31 | const match = tokenString.match(/^Bearer (.*)$/); 32 | if (!match || match.length < 2) { 33 | throw new Error(`Invalid Authorization token - ${tokenString} does not match "Bearer .*"`); 34 | } 35 | return match[1]; 36 | } 37 | 38 | const jwtOptions = { 39 | audience: process.env.AUDIENCE, 40 | issuer: process.env.TOKEN_ISSUER 41 | }; 42 | 43 | module.exports.authenticate = (params) => { 44 | console.log(params); 45 | const token = getToken(params); 46 | 47 | const decoded = jwt.decode(token, { complete: true }); 48 | if (!decoded || !decoded.header || !decoded.header.kid) { 49 | throw new Error('invalid token'); 50 | } 51 | 52 | const getSigningKey = util.promisify(client.getSigningKey); 53 | return getSigningKey(decoded.header.kid) 54 | .then((key) => { 55 | const signingKey = key.publicKey || key.rsaPublicKey; 56 | return jwt.verify(token, signingKey, jwtOptions); 57 | }) 58 | .then((decoded)=> ({ 59 | principalId: decoded.sub, 60 | policyDocument: getPolicyDocument('Allow', params.methodArn), 61 | context: { scope: decoded.scope }, 62 | })); 63 | } 64 | 65 | const client = jwksClient({ 66 | cache: true, 67 | rateLimit: true, 68 | jwksRequestsPerMinute: 10, // Default value 69 | jwksUri: process.env.JWKS_URI 70 | }); -------------------------------------------------------------------------------- /auth0-custom-auth-lambda/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "lambda-auth0-authenticator", 3 | "version": "0.1.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "lambda-auth0-authenticator", 9 | "version": "0.1.0", 10 | "license": "Apache-2.0", 11 | "dependencies": { 12 | "auth0": ">=2.37.0", 13 | "bluebird": "^3.4.6", 14 | "dotenv": "^5.0.1", 15 | "jsonwebtoken": "^8.2.1", 16 | "jwks-rsa": "^1.1.1" 17 | }, 18 | "devDependencies": { 19 | "aws-sdk": "^2.2.48", 20 | "lambda-local": "^1.4.8" 21 | } 22 | }, 23 | "node_modules/@dabh/diagnostics": { 24 | "version": "2.0.2", 25 | "resolved": "https://registry.npmjs.org/@dabh/diagnostics/-/diagnostics-2.0.2.tgz", 26 | "integrity": "sha512-+A1YivoVDNNVCdfozHSR8v/jyuuLTMXwjWuxPFlFlUapXoGc+Gj9mDlTDDfrwl7rXCl2tNZ0kE8sIBO6YOn96Q==", 27 | "dev": true, 28 | "dependencies": { 29 | "colorspace": "1.1.x", 30 | "enabled": "2.0.x", 31 | "kuler": "^2.0.0" 32 | } 33 | }, 34 | "node_modules/@tootallnate/once": { 35 | "version": "1.1.2", 36 | "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", 37 | "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", 38 | "engines": { 39 | "node": ">= 6" 40 | } 41 | }, 42 | "node_modules/@types/body-parser": { 43 | "version": "1.19.1", 44 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.1.tgz", 45 | "integrity": "sha512-a6bTJ21vFOGIkwM0kzh9Yr89ziVxq4vYH2fQ6N8AeipEzai/cFK6aGMArIkUeIdRIgpwQa+2bXiLuUJCpSf2Cg==", 46 | "dependencies": { 47 | "@types/connect": "*", 48 | "@types/node": "*" 49 | } 50 | }, 51 | "node_modules/@types/connect": { 52 | "version": "3.4.35", 53 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz", 54 | "integrity": "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==", 55 | "dependencies": { 56 | "@types/node": "*" 57 | } 58 | }, 59 | "node_modules/@types/express": { 60 | "version": "4.17.13", 61 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.13.tgz", 62 | "integrity": "sha512-6bSZTPaTIACxn48l50SR+axgrqm6qXFIxrdAKaG6PaJk3+zuUr35hBlgT7vOmJcum+OEaIBLtHV/qloEAFITeA==", 63 | "dependencies": { 64 | "@types/body-parser": "*", 65 | "@types/express-serve-static-core": "^4.17.18", 66 | "@types/qs": "*", 67 | "@types/serve-static": "*" 68 | } 69 | }, 70 | "node_modules/@types/express-jwt": { 71 | "version": "0.0.42", 72 | "resolved": "https://registry.npmjs.org/@types/express-jwt/-/express-jwt-0.0.42.tgz", 73 | "integrity": "sha512-WszgUddvM1t5dPpJ3LhWNH8kfNN8GPIBrAGxgIYXVCEGx6Bx4A036aAuf/r5WH9DIEdlmp7gHOYvSM6U87B0ag==", 74 | "dependencies": { 75 | "@types/express": "*", 76 | "@types/express-unless": "*" 77 | } 78 | }, 79 | "node_modules/@types/express-serve-static-core": { 80 | "version": "4.17.24", 81 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.24.tgz", 82 | "integrity": "sha512-3UJuW+Qxhzwjq3xhwXm2onQcFHn76frIYVbTu+kn24LFxI+dEhdfISDFovPB8VpEgW8oQCTpRuCe+0zJxB7NEA==", 83 | "dependencies": { 84 | "@types/node": "*", 85 | "@types/qs": "*", 86 | "@types/range-parser": "*" 87 | } 88 | }, 89 | "node_modules/@types/express-unless": { 90 | "version": "0.5.2", 91 | "resolved": "https://registry.npmjs.org/@types/express-unless/-/express-unless-0.5.2.tgz", 92 | "integrity": "sha512-Q74UyYRX/zIgl1HSp9tUX2PlG8glkVm+59r7aK4KGKzC5jqKIOX6rrVLRQrzpZUQ84VukHtRoeAuon2nIssHPQ==", 93 | "dependencies": { 94 | "@types/express": "*" 95 | } 96 | }, 97 | "node_modules/@types/mime": { 98 | "version": "1.3.2", 99 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.2.tgz", 100 | "integrity": "sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw==" 101 | }, 102 | "node_modules/@types/node": { 103 | "version": "16.4.6", 104 | "resolved": "https://registry.npmjs.org/@types/node/-/node-16.4.6.tgz", 105 | "integrity": "sha512-FKyawK3o5KL16AwbeFajen8G4K3mmqUrQsehn5wNKs8IzlKHE8TfnSmILXVMVziAEcnB23u1RCFU1NT6hSyr7Q==" 106 | }, 107 | "node_modules/@types/qs": { 108 | "version": "6.9.7", 109 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", 110 | "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==" 111 | }, 112 | "node_modules/@types/range-parser": { 113 | "version": "1.2.4", 114 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz", 115 | "integrity": "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==" 116 | }, 117 | "node_modules/@types/serve-static": { 118 | "version": "1.13.10", 119 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.10.tgz", 120 | "integrity": "sha512-nCkHGI4w7ZgAdNkrEu0bv+4xNV/XDqW+DydknebMOQwkpDGx8G+HTlj7R7ABI8i8nKxVw0wtKPi1D+lPOkh4YQ==", 121 | "dependencies": { 122 | "@types/mime": "^1", 123 | "@types/node": "*" 124 | } 125 | }, 126 | "node_modules/acorn": { 127 | "version": "8.7.0", 128 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.7.0.tgz", 129 | "integrity": "sha512-V/LGr1APy+PXIwKebEWrkZPwoeoF+w1jiOBUmuxuiUIaOHtob8Qc9BTrYo7VuI5fR8tqsy+buA2WFooR5olqvQ==", 130 | "peer": true, 131 | "bin": { 132 | "acorn": "bin/acorn" 133 | }, 134 | "engines": { 135 | "node": ">=0.4.0" 136 | } 137 | }, 138 | "node_modules/acorn-walk": { 139 | "version": "8.2.0", 140 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", 141 | "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", 142 | "peer": true, 143 | "engines": { 144 | "node": ">=0.4.0" 145 | } 146 | }, 147 | "node_modules/agent-base": { 148 | "version": "6.0.2", 149 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 150 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 151 | "dependencies": { 152 | "debug": "4" 153 | }, 154 | "engines": { 155 | "node": ">= 6.0.0" 156 | } 157 | }, 158 | "node_modules/ast-types": { 159 | "version": "0.13.4", 160 | "resolved": "https://registry.npmjs.org/ast-types/-/ast-types-0.13.4.tgz", 161 | "integrity": "sha512-x1FCFnFifvYDDzTaLII71vG5uvDwgtmDTEVWAxrgeiR8VjMONcCXJx7E+USjDtHlwFmt9MysbqgF9b9Vjr6w+w==", 162 | "peer": true, 163 | "dependencies": { 164 | "tslib": "^2.0.1" 165 | }, 166 | "engines": { 167 | "node": ">=4" 168 | } 169 | }, 170 | "node_modules/async": { 171 | "version": "3.2.4", 172 | "resolved": "https://registry.npmjs.org/async/-/async-3.2.4.tgz", 173 | "integrity": "sha512-iAB+JbDEGXhyIUavoDl9WP/Jj106Kz9DEn1DPgYw5ruDn0e3Wgi3sKFm55sASdGBNOQB8F59d9qQ7deqrHA8wQ==", 174 | "dev": true 175 | }, 176 | "node_modules/asynckit": { 177 | "version": "0.4.0", 178 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 179 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 180 | }, 181 | "node_modules/auth0": { 182 | "version": "2.37.0", 183 | "resolved": "https://registry.npmjs.org/auth0/-/auth0-2.37.0.tgz", 184 | "integrity": "sha512-6Kz/+7d3PRb1zKR6O7CVt0EHAu+dphLFbJcvCEn7z9mUyjM0kJp/RnkALfFLfVzmSsaWeBqQNi2uZmdjReCjzQ==", 185 | "dependencies": { 186 | "axios": "^0.21.4", 187 | "es6-promisify": "^6.1.1", 188 | "form-data": "^3.0.1", 189 | "jsonwebtoken": "^8.5.1", 190 | "jwks-rsa": "^1.12.1", 191 | "lru-memoizer": "^2.1.4", 192 | "rest-facade": "^1.13.1", 193 | "retry": "^0.13.1" 194 | } 195 | }, 196 | "node_modules/aws-sdk": { 197 | "version": "2.956.0", 198 | "resolved": "https://registry.npmjs.org/aws-sdk/-/aws-sdk-2.956.0.tgz", 199 | "integrity": "sha512-vSzL66tjeRSBPnLR2Pkx4qS7SPqADT7K9QBjWdMhVd9BF5spyMvJ9hReIEShILp3hq99sHI+MvO+uTUm5s023g==", 200 | "dev": true, 201 | "hasInstallScript": true, 202 | "dependencies": { 203 | "buffer": "4.9.2", 204 | "events": "1.1.1", 205 | "ieee754": "1.1.13", 206 | "jmespath": "0.15.0", 207 | "querystring": "0.2.0", 208 | "sax": "1.2.1", 209 | "url": "0.10.3", 210 | "uuid": "3.3.2", 211 | "xml2js": "0.4.19" 212 | }, 213 | "engines": { 214 | "node": ">= 0.8.0" 215 | } 216 | }, 217 | "node_modules/axios": { 218 | "version": "0.21.4", 219 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.21.4.tgz", 220 | "integrity": "sha512-ut5vewkiu8jjGBdqpM44XxjuCjq9LAKeHVmoVfHVzy8eHgxxq8SbAVQNovDA8mVi05kP0Ea/n/UzcSHcTJQfNg==", 221 | "dependencies": { 222 | "follow-redirects": "^1.14.0" 223 | } 224 | }, 225 | "node_modules/base64-js": { 226 | "version": "1.5.1", 227 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 228 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", 229 | "dev": true, 230 | "funding": [ 231 | { 232 | "type": "github", 233 | "url": "https://github.com/sponsors/feross" 234 | }, 235 | { 236 | "type": "patreon", 237 | "url": "https://www.patreon.com/feross" 238 | }, 239 | { 240 | "type": "consulting", 241 | "url": "https://feross.org/support" 242 | } 243 | ] 244 | }, 245 | "node_modules/bluebird": { 246 | "version": "3.7.2", 247 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz", 248 | "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==" 249 | }, 250 | "node_modules/buffer": { 251 | "version": "4.9.2", 252 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-4.9.2.tgz", 253 | "integrity": "sha512-xq+q3SRMOxGivLhBNaUdC64hDTQwejJ+H0T/NB1XMtTVEwNTrfFF3gAxiyW0Bu/xWEGhjVKgUcMhCrUy2+uCWg==", 254 | "dev": true, 255 | "dependencies": { 256 | "base64-js": "^1.0.2", 257 | "ieee754": "^1.1.4", 258 | "isarray": "^1.0.0" 259 | } 260 | }, 261 | "node_modules/buffer-equal-constant-time": { 262 | "version": "1.0.1", 263 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 264 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 265 | }, 266 | "node_modules/bytes": { 267 | "version": "3.1.0", 268 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 269 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==", 270 | "peer": true, 271 | "engines": { 272 | "node": ">= 0.8" 273 | } 274 | }, 275 | "node_modules/call-bind": { 276 | "version": "1.0.2", 277 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 278 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 279 | "dependencies": { 280 | "function-bind": "^1.1.1", 281 | "get-intrinsic": "^1.0.2" 282 | }, 283 | "funding": { 284 | "url": "https://github.com/sponsors/ljharb" 285 | } 286 | }, 287 | "node_modules/camel-case": { 288 | "version": "1.2.2", 289 | "resolved": "https://registry.npmjs.org/camel-case/-/camel-case-1.2.2.tgz", 290 | "integrity": "sha1-Gsp8TRlTWaLOmVV5NDPG5VQlEfI=", 291 | "dependencies": { 292 | "sentence-case": "^1.1.1", 293 | "upper-case": "^1.1.1" 294 | } 295 | }, 296 | "node_modules/change-case": { 297 | "version": "2.3.1", 298 | "resolved": "https://registry.npmjs.org/change-case/-/change-case-2.3.1.tgz", 299 | "integrity": "sha1-LE/ePwY7tB0AzWjg1aCdthy+iU8=", 300 | "dependencies": { 301 | "camel-case": "^1.1.1", 302 | "constant-case": "^1.1.0", 303 | "dot-case": "^1.1.0", 304 | "is-lower-case": "^1.1.0", 305 | "is-upper-case": "^1.1.0", 306 | "lower-case": "^1.1.1", 307 | "lower-case-first": "^1.0.0", 308 | "param-case": "^1.1.0", 309 | "pascal-case": "^1.1.0", 310 | "path-case": "^1.1.0", 311 | "sentence-case": "^1.1.1", 312 | "snake-case": "^1.1.0", 313 | "swap-case": "^1.1.0", 314 | "title-case": "^1.1.0", 315 | "upper-case": "^1.1.1", 316 | "upper-case-first": "^1.1.0" 317 | } 318 | }, 319 | "node_modules/color": { 320 | "version": "3.0.0", 321 | "resolved": "https://registry.npmjs.org/color/-/color-3.0.0.tgz", 322 | "integrity": "sha512-jCpd5+s0s0t7p3pHQKpnJ0TpQKKdleP71LWcA0aqiljpiuAkOSUFN/dyH8ZwF0hRmFlrIuRhufds1QyEP9EB+w==", 323 | "dev": true, 324 | "dependencies": { 325 | "color-convert": "^1.9.1", 326 | "color-string": "^1.5.2" 327 | } 328 | }, 329 | "node_modules/color-convert": { 330 | "version": "1.9.3", 331 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 332 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 333 | "dev": true, 334 | "dependencies": { 335 | "color-name": "1.1.3" 336 | } 337 | }, 338 | "node_modules/color-name": { 339 | "version": "1.1.3", 340 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 341 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 342 | "dev": true 343 | }, 344 | "node_modules/color-string": { 345 | "version": "1.6.0", 346 | "resolved": "https://registry.npmjs.org/color-string/-/color-string-1.6.0.tgz", 347 | "integrity": "sha512-c/hGS+kRWJutUBEngKKmk4iH3sD59MBkoxVapS/0wgpCz2u7XsNloxknyvBhzwEs1IbV36D9PwqLPJ2DTu3vMA==", 348 | "dev": true, 349 | "dependencies": { 350 | "color-name": "^1.0.0", 351 | "simple-swizzle": "^0.2.2" 352 | } 353 | }, 354 | "node_modules/colors": { 355 | "version": "1.4.0", 356 | "resolved": "https://registry.npmjs.org/colors/-/colors-1.4.0.tgz", 357 | "integrity": "sha512-a+UqTh4kgZg/SlGvfbzDHpgRu7AAQOmmqRHJnxhRZICKFUT91brVhNNt58CMWU9PsBbv3PDCZUHbVxuDiH2mtA==", 358 | "dev": true, 359 | "engines": { 360 | "node": ">=0.1.90" 361 | } 362 | }, 363 | "node_modules/colorspace": { 364 | "version": "1.1.2", 365 | "resolved": "https://registry.npmjs.org/colorspace/-/colorspace-1.1.2.tgz", 366 | "integrity": "sha512-vt+OoIP2d76xLhjwbBaucYlNSpPsrJWPlBTtwCpQKIu6/CSMutyzX93O/Do0qzpH3YoHEes8YEFXyZ797rEhzQ==", 367 | "dev": true, 368 | "dependencies": { 369 | "color": "3.0.x", 370 | "text-hex": "1.0.x" 371 | } 372 | }, 373 | "node_modules/combined-stream": { 374 | "version": "1.0.8", 375 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 376 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 377 | "dependencies": { 378 | "delayed-stream": "~1.0.0" 379 | }, 380 | "engines": { 381 | "node": ">= 0.8" 382 | } 383 | }, 384 | "node_modules/commander": { 385 | "version": "6.2.1", 386 | "resolved": "https://registry.npmjs.org/commander/-/commander-6.2.1.tgz", 387 | "integrity": "sha512-U7VdrJFnJgo4xjrHpTzu0yrHPGImdsmD95ZlgYSEajAn2JKzDhDTPG9kBTefmObL2w/ngeZnilk+OV9CG3d7UA==", 388 | "dev": true, 389 | "engines": { 390 | "node": ">= 6" 391 | } 392 | }, 393 | "node_modules/component-emitter": { 394 | "version": "1.3.0", 395 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz", 396 | "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==" 397 | }, 398 | "node_modules/constant-case": { 399 | "version": "1.1.2", 400 | "resolved": "https://registry.npmjs.org/constant-case/-/constant-case-1.1.2.tgz", 401 | "integrity": "sha1-jsLKW6ND4Aqjjb9OIA/VrJB+/WM=", 402 | "dependencies": { 403 | "snake-case": "^1.1.0", 404 | "upper-case": "^1.1.1" 405 | } 406 | }, 407 | "node_modules/cookiejar": { 408 | "version": "2.1.3", 409 | "resolved": "https://registry.npmjs.org/cookiejar/-/cookiejar-2.1.3.tgz", 410 | "integrity": "sha512-JxbCBUdrfr6AQjOXrxoTvAMJO4HBTUIlBzslcJPAz+/KT8yk53fXun51u+RenNYvad/+Vc2DIz5o9UxlCDymFQ==" 411 | }, 412 | "node_modules/core-util-is": { 413 | "version": "1.0.2", 414 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 415 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 416 | }, 417 | "node_modules/data-uri-to-buffer": { 418 | "version": "3.0.1", 419 | "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-3.0.1.tgz", 420 | "integrity": "sha512-WboRycPNsVw3B3TL559F7kuBUM4d8CgMEvk6xEJlOp7OBPjt6G7z8WMWlD2rOFZLk6OYfFIUGsCOWzcQH9K2og==", 421 | "peer": true, 422 | "engines": { 423 | "node": ">= 6" 424 | } 425 | }, 426 | "node_modules/debug": { 427 | "version": "4.3.2", 428 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", 429 | "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", 430 | "dependencies": { 431 | "ms": "2.1.2" 432 | }, 433 | "engines": { 434 | "node": ">=6.0" 435 | }, 436 | "peerDependenciesMeta": { 437 | "supports-color": { 438 | "optional": true 439 | } 440 | } 441 | }, 442 | "node_modules/debug/node_modules/ms": { 443 | "version": "2.1.2", 444 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 445 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 446 | }, 447 | "node_modules/deep-is": { 448 | "version": "0.1.4", 449 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 450 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 451 | "peer": true 452 | }, 453 | "node_modules/deepmerge": { 454 | "version": "3.3.0", 455 | "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-3.3.0.tgz", 456 | "integrity": "sha512-GRQOafGHwMHpjPx9iCvTgpu9NojZ49q794EEL94JVEw6VaeA8XTUyBKvAkOOjBX9oJNiV6G3P+T+tihFjo2TqA==", 457 | "engines": { 458 | "node": ">=0.10.0" 459 | } 460 | }, 461 | "node_modules/degenerator": { 462 | "version": "3.0.1", 463 | "resolved": "https://registry.npmjs.org/degenerator/-/degenerator-3.0.1.tgz", 464 | "integrity": "sha512-LFsIFEeLPlKvAKXu7j3ssIG6RT0TbI7/GhsqrI0DnHASEQjXQ0LUSYcjJteGgRGmZbl1TnMSxpNQIAiJ7Du5TQ==", 465 | "peer": true, 466 | "dependencies": { 467 | "ast-types": "^0.13.2", 468 | "escodegen": "^1.8.1", 469 | "esprima": "^4.0.0", 470 | "vm2": "^3.9.3" 471 | }, 472 | "engines": { 473 | "node": ">= 6" 474 | } 475 | }, 476 | "node_modules/delayed-stream": { 477 | "version": "1.0.0", 478 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 479 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 480 | "engines": { 481 | "node": ">=0.4.0" 482 | } 483 | }, 484 | "node_modules/depd": { 485 | "version": "1.1.2", 486 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 487 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=", 488 | "peer": true, 489 | "engines": { 490 | "node": ">= 0.6" 491 | } 492 | }, 493 | "node_modules/dot-case": { 494 | "version": "1.1.2", 495 | "resolved": "https://registry.npmjs.org/dot-case/-/dot-case-1.1.2.tgz", 496 | "integrity": "sha1-HnOCaQDeKNbeVIC8HeMdCEKwa+w=", 497 | "dependencies": { 498 | "sentence-case": "^1.1.2" 499 | } 500 | }, 501 | "node_modules/dotenv": { 502 | "version": "5.0.1", 503 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-5.0.1.tgz", 504 | "integrity": "sha512-4As8uPrjfwb7VXC+WnLCbXK7y+Ueb2B3zgNCePYfhxS1PYeaO1YTeplffTEcbfLhvFNGLAz90VvJs9yomG7bow==", 505 | "engines": { 506 | "node": ">=4.6.0" 507 | } 508 | }, 509 | "node_modules/ecdsa-sig-formatter": { 510 | "version": "1.0.11", 511 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 512 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 513 | "dependencies": { 514 | "safe-buffer": "^5.0.1" 515 | } 516 | }, 517 | "node_modules/enabled": { 518 | "version": "2.0.0", 519 | "resolved": "https://registry.npmjs.org/enabled/-/enabled-2.0.0.tgz", 520 | "integrity": "sha512-AKrN98kuwOzMIdAizXGI86UFBoo26CL21UM763y1h/GMSJ4/OHU9k2YlsmBpyScFo/wbLzWQJBMCW4+IO3/+OQ==", 521 | "dev": true 522 | }, 523 | "node_modules/es6-promisify": { 524 | "version": "6.1.1", 525 | "resolved": "https://registry.npmjs.org/es6-promisify/-/es6-promisify-6.1.1.tgz", 526 | "integrity": "sha512-HBL8I3mIki5C1Cc9QjKUenHtnG0A5/xA8Q/AllRcfiwl2CZFXGK7ddBiCoRwAix4i2KxcQfjtIVcrVbB3vbmwg==" 527 | }, 528 | "node_modules/escodegen": { 529 | "version": "1.14.3", 530 | "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.14.3.tgz", 531 | "integrity": "sha512-qFcX0XJkdg+PB3xjZZG/wKSuT1PnQWx57+TVSjIMmILd2yC/6ByYElPwJnslDsuWuSAp4AwJGumarAAmJch5Kw==", 532 | "peer": true, 533 | "dependencies": { 534 | "esprima": "^4.0.1", 535 | "estraverse": "^4.2.0", 536 | "esutils": "^2.0.2", 537 | "optionator": "^0.8.1" 538 | }, 539 | "bin": { 540 | "escodegen": "bin/escodegen.js", 541 | "esgenerate": "bin/esgenerate.js" 542 | }, 543 | "engines": { 544 | "node": ">=4.0" 545 | }, 546 | "optionalDependencies": { 547 | "source-map": "~0.6.1" 548 | } 549 | }, 550 | "node_modules/esprima": { 551 | "version": "4.0.1", 552 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 553 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 554 | "peer": true, 555 | "bin": { 556 | "esparse": "bin/esparse.js", 557 | "esvalidate": "bin/esvalidate.js" 558 | }, 559 | "engines": { 560 | "node": ">=4" 561 | } 562 | }, 563 | "node_modules/estraverse": { 564 | "version": "4.3.0", 565 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 566 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 567 | "peer": true, 568 | "engines": { 569 | "node": ">=4.0" 570 | } 571 | }, 572 | "node_modules/esutils": { 573 | "version": "2.0.3", 574 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 575 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 576 | "peer": true, 577 | "engines": { 578 | "node": ">=0.10.0" 579 | } 580 | }, 581 | "node_modules/events": { 582 | "version": "1.1.1", 583 | "resolved": "https://registry.npmjs.org/events/-/events-1.1.1.tgz", 584 | "integrity": "sha1-nr23Y1rQmccNzEwqH1AEKI6L2SQ=", 585 | "dev": true, 586 | "engines": { 587 | "node": ">=0.4.x" 588 | } 589 | }, 590 | "node_modules/fast-levenshtein": { 591 | "version": "2.0.6", 592 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 593 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 594 | "peer": true 595 | }, 596 | "node_modules/fast-safe-stringify": { 597 | "version": "2.0.8", 598 | "resolved": "https://registry.npmjs.org/fast-safe-stringify/-/fast-safe-stringify-2.0.8.tgz", 599 | "integrity": "sha512-lXatBjf3WPjmWD6DpIZxkeSsCOwqI0maYMpgDlx8g4U2qi4lbjA9oH/HD2a87G+KfsUmo5WbJFmqBZlPxtptag==" 600 | }, 601 | "node_modules/fecha": { 602 | "version": "4.2.1", 603 | "resolved": "https://registry.npmjs.org/fecha/-/fecha-4.2.1.tgz", 604 | "integrity": "sha512-MMMQ0ludy/nBs1/o0zVOiKTpG7qMbonKUzjJgQFEuvq6INZ1OraKPRAWkBq5vlKLOUMpmNYG1JoN3oDPUQ9m3Q==", 605 | "dev": true 606 | }, 607 | "node_modules/file-uri-to-path": { 608 | "version": "2.0.0", 609 | "resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-2.0.0.tgz", 610 | "integrity": "sha512-hjPFI8oE/2iQPVe4gbrJ73Pp+Xfub2+WI2LlXDbsaJBwT5wuMh35WNWVYYTpnz895shtwfyutMFLFywpQAFdLg==", 611 | "peer": true, 612 | "engines": { 613 | "node": ">= 6" 614 | } 615 | }, 616 | "node_modules/fn.name": { 617 | "version": "1.1.0", 618 | "resolved": "https://registry.npmjs.org/fn.name/-/fn.name-1.1.0.tgz", 619 | "integrity": "sha512-GRnmB5gPyJpAhTQdSZTSp9uaPSvl09KoYcMQtsB9rQoOmzs9dH6ffeccH+Z+cv6P68Hu5bC6JjRh4Ah/mHSNRw==", 620 | "dev": true 621 | }, 622 | "node_modules/follow-redirects": { 623 | "version": "1.14.9", 624 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.14.9.tgz", 625 | "integrity": "sha512-MQDfihBQYMcyy5dhRDJUHcw7lb2Pv/TuE6xP1vyraLukNDHKbDxDNaOE3NbCAdKQApno+GPRyo1YAp89yCjK4w==", 626 | "funding": [ 627 | { 628 | "type": "individual", 629 | "url": "https://github.com/sponsors/RubenVerborgh" 630 | } 631 | ], 632 | "engines": { 633 | "node": ">=4.0" 634 | }, 635 | "peerDependenciesMeta": { 636 | "debug": { 637 | "optional": true 638 | } 639 | } 640 | }, 641 | "node_modules/form-data": { 642 | "version": "3.0.1", 643 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-3.0.1.tgz", 644 | "integrity": "sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg==", 645 | "dependencies": { 646 | "asynckit": "^0.4.0", 647 | "combined-stream": "^1.0.8", 648 | "mime-types": "^2.1.12" 649 | }, 650 | "engines": { 651 | "node": ">= 6" 652 | } 653 | }, 654 | "node_modules/formidable": { 655 | "version": "1.2.2", 656 | "resolved": "https://registry.npmjs.org/formidable/-/formidable-1.2.2.tgz", 657 | "integrity": "sha512-V8gLm+41I/8kguQ4/o1D3RIHRmhYFG4pnNyonvua+40rqcEmT4+V71yaZ3B457xbbgCsCfjSPi65u/W6vK1U5Q==", 658 | "funding": { 659 | "url": "https://ko-fi.com/tunnckoCore/commissions" 660 | } 661 | }, 662 | "node_modules/fs-extra": { 663 | "version": "8.1.0", 664 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz", 665 | "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", 666 | "peer": true, 667 | "dependencies": { 668 | "graceful-fs": "^4.2.0", 669 | "jsonfile": "^4.0.0", 670 | "universalify": "^0.1.0" 671 | }, 672 | "engines": { 673 | "node": ">=6 <7 || >=8" 674 | } 675 | }, 676 | "node_modules/ftp": { 677 | "version": "0.3.10", 678 | "resolved": "https://registry.npmjs.org/ftp/-/ftp-0.3.10.tgz", 679 | "integrity": "sha1-kZfYYa2BQvPmPVqDv+TFn3MwiF0=", 680 | "peer": true, 681 | "dependencies": { 682 | "readable-stream": "1.1.x", 683 | "xregexp": "2.0.0" 684 | }, 685 | "engines": { 686 | "node": ">=0.8.0" 687 | } 688 | }, 689 | "node_modules/ftp/node_modules/isarray": { 690 | "version": "0.0.1", 691 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 692 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", 693 | "peer": true 694 | }, 695 | "node_modules/ftp/node_modules/readable-stream": { 696 | "version": "1.1.14", 697 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", 698 | "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", 699 | "peer": true, 700 | "dependencies": { 701 | "core-util-is": "~1.0.0", 702 | "inherits": "~2.0.1", 703 | "isarray": "0.0.1", 704 | "string_decoder": "~0.10.x" 705 | } 706 | }, 707 | "node_modules/ftp/node_modules/string_decoder": { 708 | "version": "0.10.31", 709 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 710 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", 711 | "peer": true 712 | }, 713 | "node_modules/function-bind": { 714 | "version": "1.1.1", 715 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 716 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 717 | }, 718 | "node_modules/get-intrinsic": { 719 | "version": "1.1.1", 720 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", 721 | "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", 722 | "dependencies": { 723 | "function-bind": "^1.1.1", 724 | "has": "^1.0.3", 725 | "has-symbols": "^1.0.1" 726 | }, 727 | "funding": { 728 | "url": "https://github.com/sponsors/ljharb" 729 | } 730 | }, 731 | "node_modules/get-uri": { 732 | "version": "3.0.2", 733 | "resolved": "https://registry.npmjs.org/get-uri/-/get-uri-3.0.2.tgz", 734 | "integrity": "sha512-+5s0SJbGoyiJTZZ2JTpFPLMPSch72KEqGOTvQsBqg0RBWvwhWUSYZFAtz3TPW0GXJuLBJPts1E241iHg+VRfhg==", 735 | "peer": true, 736 | "dependencies": { 737 | "@tootallnate/once": "1", 738 | "data-uri-to-buffer": "3", 739 | "debug": "4", 740 | "file-uri-to-path": "2", 741 | "fs-extra": "^8.1.0", 742 | "ftp": "^0.3.10" 743 | }, 744 | "engines": { 745 | "node": ">= 6" 746 | } 747 | }, 748 | "node_modules/graceful-fs": { 749 | "version": "4.2.8", 750 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.8.tgz", 751 | "integrity": "sha512-qkIilPUYcNhJpd33n0GBXTB1MMPp14TxEsEs0pTrsSVucApsYzW5V+Q8Qxhik6KU3evy+qkAAowTByymK0avdg==", 752 | "peer": true 753 | }, 754 | "node_modules/has": { 755 | "version": "1.0.3", 756 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 757 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 758 | "dependencies": { 759 | "function-bind": "^1.1.1" 760 | }, 761 | "engines": { 762 | "node": ">= 0.4.0" 763 | } 764 | }, 765 | "node_modules/has-symbols": { 766 | "version": "1.0.2", 767 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", 768 | "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==", 769 | "engines": { 770 | "node": ">= 0.4" 771 | }, 772 | "funding": { 773 | "url": "https://github.com/sponsors/ljharb" 774 | } 775 | }, 776 | "node_modules/http-errors": { 777 | "version": "1.7.3", 778 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.3.tgz", 779 | "integrity": "sha512-ZTTX0MWrsQ2ZAhA1cejAwDLycFsd7I7nVtnkT3Ol0aqodaKW+0CTZDQ1uBv5whptCnc8e8HeRRJxRs0kmm/Qfw==", 780 | "peer": true, 781 | "dependencies": { 782 | "depd": "~1.1.2", 783 | "inherits": "2.0.4", 784 | "setprototypeof": "1.1.1", 785 | "statuses": ">= 1.5.0 < 2", 786 | "toidentifier": "1.0.0" 787 | }, 788 | "engines": { 789 | "node": ">= 0.6" 790 | } 791 | }, 792 | "node_modules/http-proxy-agent": { 793 | "version": "4.0.1", 794 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", 795 | "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", 796 | "dependencies": { 797 | "@tootallnate/once": "1", 798 | "agent-base": "6", 799 | "debug": "4" 800 | }, 801 | "engines": { 802 | "node": ">= 6" 803 | } 804 | }, 805 | "node_modules/https-proxy-agent": { 806 | "version": "5.0.0", 807 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz", 808 | "integrity": "sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==", 809 | "dependencies": { 810 | "agent-base": "6", 811 | "debug": "4" 812 | }, 813 | "engines": { 814 | "node": ">= 6" 815 | } 816 | }, 817 | "node_modules/iconv-lite": { 818 | "version": "0.4.24", 819 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 820 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 821 | "peer": true, 822 | "dependencies": { 823 | "safer-buffer": ">= 2.1.2 < 3" 824 | }, 825 | "engines": { 826 | "node": ">=0.10.0" 827 | } 828 | }, 829 | "node_modules/ieee754": { 830 | "version": "1.1.13", 831 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.1.13.tgz", 832 | "integrity": "sha512-4vf7I2LYV/HaWerSo3XmlMkp5eZ83i+/CDluXi/IGTs/O1sejBNhTtnxzmRZfvOUqj7lZjqHkeTvpgSFDlWZTg==", 833 | "dev": true 834 | }, 835 | "node_modules/inherits": { 836 | "version": "2.0.4", 837 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 838 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 839 | }, 840 | "node_modules/ip": { 841 | "version": "1.1.5", 842 | "resolved": "https://registry.npmjs.org/ip/-/ip-1.1.5.tgz", 843 | "integrity": "sha1-vd7XARQpCCjAoDnnLvJfWq7ENUo=", 844 | "peer": true 845 | }, 846 | "node_modules/is-arrayish": { 847 | "version": "0.3.2", 848 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.3.2.tgz", 849 | "integrity": "sha512-eVRqCvVlZbuw3GrM63ovNSNAeA1K16kaR/LRY/92w0zxQ5/1YzwblUX652i4Xs9RwAGjW9d9y6X88t8OaAJfWQ==", 850 | "dev": true 851 | }, 852 | "node_modules/is-lower-case": { 853 | "version": "1.1.3", 854 | "resolved": "https://registry.npmjs.org/is-lower-case/-/is-lower-case-1.1.3.tgz", 855 | "integrity": "sha1-fhR75HaNxGbbO/shzGCzHmrWk5M=", 856 | "dependencies": { 857 | "lower-case": "^1.1.0" 858 | } 859 | }, 860 | "node_modules/is-stream": { 861 | "version": "2.0.1", 862 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", 863 | "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", 864 | "dev": true, 865 | "engines": { 866 | "node": ">=8" 867 | }, 868 | "funding": { 869 | "url": "https://github.com/sponsors/sindresorhus" 870 | } 871 | }, 872 | "node_modules/is-upper-case": { 873 | "version": "1.1.2", 874 | "resolved": "https://registry.npmjs.org/is-upper-case/-/is-upper-case-1.1.2.tgz", 875 | "integrity": "sha1-jQsfp+eTOh5YSDYA7H2WYcuvdW8=", 876 | "dependencies": { 877 | "upper-case": "^1.1.0" 878 | } 879 | }, 880 | "node_modules/isarray": { 881 | "version": "1.0.0", 882 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 883 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 884 | "dev": true 885 | }, 886 | "node_modules/jmespath": { 887 | "version": "0.15.0", 888 | "resolved": "https://registry.npmjs.org/jmespath/-/jmespath-0.15.0.tgz", 889 | "integrity": "sha1-o/Iiqarp+Wb10nx5ZRDigJF2Qhc=", 890 | "dev": true, 891 | "engines": { 892 | "node": ">= 0.6.0" 893 | } 894 | }, 895 | "node_modules/jsonfile": { 896 | "version": "4.0.0", 897 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", 898 | "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", 899 | "peer": true, 900 | "optionalDependencies": { 901 | "graceful-fs": "^4.1.6" 902 | } 903 | }, 904 | "node_modules/jsonwebtoken": { 905 | "version": "8.5.1", 906 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz", 907 | "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==", 908 | "dependencies": { 909 | "jws": "^3.2.2", 910 | "lodash.includes": "^4.3.0", 911 | "lodash.isboolean": "^3.0.3", 912 | "lodash.isinteger": "^4.0.4", 913 | "lodash.isnumber": "^3.0.3", 914 | "lodash.isplainobject": "^4.0.6", 915 | "lodash.isstring": "^4.0.1", 916 | "lodash.once": "^4.0.0", 917 | "ms": "^2.1.1", 918 | "semver": "^5.6.0" 919 | }, 920 | "engines": { 921 | "node": ">=4", 922 | "npm": ">=1.4.28" 923 | } 924 | }, 925 | "node_modules/jwa": { 926 | "version": "1.4.1", 927 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", 928 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", 929 | "dependencies": { 930 | "buffer-equal-constant-time": "1.0.1", 931 | "ecdsa-sig-formatter": "1.0.11", 932 | "safe-buffer": "^5.0.1" 933 | } 934 | }, 935 | "node_modules/jwks-rsa": { 936 | "version": "1.12.3", 937 | "resolved": "https://registry.npmjs.org/jwks-rsa/-/jwks-rsa-1.12.3.tgz", 938 | "integrity": "sha512-cFipFDeYYaO9FhhYJcZWX/IyZgc0+g316rcHnDpT2dNRNIE/lMOmWKKqp09TkJoYlNFzrEVODsR4GgXJMgWhnA==", 939 | "dependencies": { 940 | "@types/express-jwt": "0.0.42", 941 | "axios": "^0.21.1", 942 | "debug": "^4.1.0", 943 | "http-proxy-agent": "^4.0.1", 944 | "https-proxy-agent": "^5.0.0", 945 | "jsonwebtoken": "^8.5.1", 946 | "limiter": "^1.1.5", 947 | "lru-memoizer": "^2.1.2", 948 | "ms": "^2.1.2", 949 | "proxy-from-env": "^1.1.0" 950 | } 951 | }, 952 | "node_modules/jws": { 953 | "version": "3.2.2", 954 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", 955 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", 956 | "dependencies": { 957 | "jwa": "^1.4.1", 958 | "safe-buffer": "^5.0.1" 959 | } 960 | }, 961 | "node_modules/kuler": { 962 | "version": "2.0.0", 963 | "resolved": "https://registry.npmjs.org/kuler/-/kuler-2.0.0.tgz", 964 | "integrity": "sha512-Xq9nH7KlWZmXAtodXDDRE7vs6DU1gTU8zYDHDiWLSip45Egwq3plLHzPn27NgvzL2r1LMPC1vdqh98sQxtqj4A==", 965 | "dev": true 966 | }, 967 | "node_modules/lambda-local": { 968 | "version": "1.7.4", 969 | "resolved": "https://registry.npmjs.org/lambda-local/-/lambda-local-1.7.4.tgz", 970 | "integrity": "sha512-uLrFPGj2//glOgJGLZn8hNTNlhU+eGx0WFRLZxIoC39nfjLRZ1fncHcPK2t5gA2GcvgtGUT2dnw60M8vJAOIkQ==", 971 | "dev": true, 972 | "dependencies": { 973 | "aws-sdk": "^2.689.0", 974 | "commander": "^6.1.0", 975 | "dotenv": "^8.2.0", 976 | "winston": "^3.2.1" 977 | }, 978 | "bin": { 979 | "lambda-local": "build/cli.js" 980 | }, 981 | "engines": { 982 | "node": ">=6" 983 | } 984 | }, 985 | "node_modules/lambda-local/node_modules/dotenv": { 986 | "version": "8.6.0", 987 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.6.0.tgz", 988 | "integrity": "sha512-IrPdXQsk2BbzvCBGBOTmmSH5SodmqZNt4ERAZDmW4CT+tL8VtvinqywuANaFu4bOMWki16nqf0e4oC0QIaDr/g==", 989 | "dev": true, 990 | "engines": { 991 | "node": ">=10" 992 | } 993 | }, 994 | "node_modules/levn": { 995 | "version": "0.3.0", 996 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 997 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 998 | "peer": true, 999 | "dependencies": { 1000 | "prelude-ls": "~1.1.2", 1001 | "type-check": "~0.3.2" 1002 | }, 1003 | "engines": { 1004 | "node": ">= 0.8.0" 1005 | } 1006 | }, 1007 | "node_modules/limiter": { 1008 | "version": "1.1.5", 1009 | "resolved": "https://registry.npmjs.org/limiter/-/limiter-1.1.5.tgz", 1010 | "integrity": "sha512-FWWMIEOxz3GwUI4Ts/IvgVy6LPvoMPgjMdQ185nN6psJyBJ4yOpzqm695/h5umdLJg2vW3GR5iG11MAkR2AzJA==" 1011 | }, 1012 | "node_modules/lodash.clonedeep": { 1013 | "version": "4.5.0", 1014 | "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", 1015 | "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=" 1016 | }, 1017 | "node_modules/lodash.get": { 1018 | "version": "4.4.2", 1019 | "resolved": "https://registry.npmjs.org/lodash.get/-/lodash.get-4.4.2.tgz", 1020 | "integrity": "sha1-LRd/ZS+jHpObRDjVNBSZ36OCXpk=" 1021 | }, 1022 | "node_modules/lodash.includes": { 1023 | "version": "4.3.0", 1024 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", 1025 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8=" 1026 | }, 1027 | "node_modules/lodash.isboolean": { 1028 | "version": "3.0.3", 1029 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", 1030 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY=" 1031 | }, 1032 | "node_modules/lodash.isinteger": { 1033 | "version": "4.0.4", 1034 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", 1035 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M=" 1036 | }, 1037 | "node_modules/lodash.isnumber": { 1038 | "version": "3.0.3", 1039 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", 1040 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w=" 1041 | }, 1042 | "node_modules/lodash.isplainobject": { 1043 | "version": "4.0.6", 1044 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 1045 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs=" 1046 | }, 1047 | "node_modules/lodash.isstring": { 1048 | "version": "4.0.1", 1049 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", 1050 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE=" 1051 | }, 1052 | "node_modules/lodash.once": { 1053 | "version": "4.1.1", 1054 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 1055 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=" 1056 | }, 1057 | "node_modules/logform": { 1058 | "version": "2.2.0", 1059 | "resolved": "https://registry.npmjs.org/logform/-/logform-2.2.0.tgz", 1060 | "integrity": "sha512-N0qPlqfypFx7UHNn4B3lzS/b0uLqt2hmuoa+PpuXNYgozdJYAyauF5Ky0BWVjrxDlMWiT3qN4zPq3vVAfZy7Yg==", 1061 | "dev": true, 1062 | "dependencies": { 1063 | "colors": "^1.2.1", 1064 | "fast-safe-stringify": "^2.0.4", 1065 | "fecha": "^4.2.0", 1066 | "ms": "^2.1.1", 1067 | "triple-beam": "^1.3.0" 1068 | } 1069 | }, 1070 | "node_modules/lower-case": { 1071 | "version": "1.1.4", 1072 | "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-1.1.4.tgz", 1073 | "integrity": "sha1-miyr0bno4K6ZOkv31YdcOcQujqw=" 1074 | }, 1075 | "node_modules/lower-case-first": { 1076 | "version": "1.0.2", 1077 | "resolved": "https://registry.npmjs.org/lower-case-first/-/lower-case-first-1.0.2.tgz", 1078 | "integrity": "sha1-5dp8JvKacHO+AtUrrJmA5ZIq36E=", 1079 | "dependencies": { 1080 | "lower-case": "^1.1.2" 1081 | } 1082 | }, 1083 | "node_modules/lru-cache": { 1084 | "version": "4.0.2", 1085 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.0.2.tgz", 1086 | "integrity": "sha1-HRdnnAac2l0ECZGgnbwsDbN35V4=", 1087 | "dependencies": { 1088 | "pseudomap": "^1.0.1", 1089 | "yallist": "^2.0.0" 1090 | } 1091 | }, 1092 | "node_modules/lru-memoizer": { 1093 | "version": "2.1.4", 1094 | "resolved": "https://registry.npmjs.org/lru-memoizer/-/lru-memoizer-2.1.4.tgz", 1095 | "integrity": "sha512-IXAq50s4qwrOBrXJklY+KhgZF+5y98PDaNo0gi/v2KQBFLyWr+JyFvijZXkGKjQj/h9c0OwoE+JZbwUXce76hQ==", 1096 | "dependencies": { 1097 | "lodash.clonedeep": "^4.5.0", 1098 | "lru-cache": "~4.0.0" 1099 | } 1100 | }, 1101 | "node_modules/methods": { 1102 | "version": "1.1.2", 1103 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1104 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", 1105 | "engines": { 1106 | "node": ">= 0.6" 1107 | } 1108 | }, 1109 | "node_modules/mime": { 1110 | "version": "2.5.2", 1111 | "resolved": "https://registry.npmjs.org/mime/-/mime-2.5.2.tgz", 1112 | "integrity": "sha512-tqkh47FzKeCPD2PUiPB6pkbMzsCasjxAfC62/Wap5qrUWcb+sFasXUC5I3gYM5iBM8v/Qpn4UK0x+j0iHyFPDg==", 1113 | "bin": { 1114 | "mime": "cli.js" 1115 | }, 1116 | "engines": { 1117 | "node": ">=4.0.0" 1118 | } 1119 | }, 1120 | "node_modules/mime-db": { 1121 | "version": "1.50.0", 1122 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.50.0.tgz", 1123 | "integrity": "sha512-9tMZCDlYHqeERXEHO9f/hKfNXhre5dK2eE/krIvUjZbS2KPcqGDfNShIWS1uW9XOTKQKqK6qbeOci18rbfW77A==", 1124 | "engines": { 1125 | "node": ">= 0.6" 1126 | } 1127 | }, 1128 | "node_modules/mime-types": { 1129 | "version": "2.1.33", 1130 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.33.tgz", 1131 | "integrity": "sha512-plLElXp7pRDd0bNZHw+nMd52vRYjLwQjygaNg7ddJ2uJtTlmnTCjWuPKxVu6//AdaRuME84SvLW91sIkBqGT0g==", 1132 | "dependencies": { 1133 | "mime-db": "1.50.0" 1134 | }, 1135 | "engines": { 1136 | "node": ">= 0.6" 1137 | } 1138 | }, 1139 | "node_modules/ms": { 1140 | "version": "2.1.3", 1141 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1142 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1143 | }, 1144 | "node_modules/netmask": { 1145 | "version": "2.0.2", 1146 | "resolved": "https://registry.npmjs.org/netmask/-/netmask-2.0.2.tgz", 1147 | "integrity": "sha512-dBpDMdxv9Irdq66304OLfEmQ9tbNRFnFTuZiLo+bD+r332bBmMJ8GBLXklIXXgxd3+v9+KUnZaUR5PJMa75Gsg==", 1148 | "peer": true, 1149 | "engines": { 1150 | "node": ">= 0.4.0" 1151 | } 1152 | }, 1153 | "node_modules/object-inspect": { 1154 | "version": "1.11.0", 1155 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.11.0.tgz", 1156 | "integrity": "sha512-jp7ikS6Sd3GxQfZJPyH3cjcbJF6GZPClgdV+EFygjFLQ5FmW/dRUnTd9PQ9k0JhoNDabWFbpF1yCdSWCC6gexg==", 1157 | "funding": { 1158 | "url": "https://github.com/sponsors/ljharb" 1159 | } 1160 | }, 1161 | "node_modules/one-time": { 1162 | "version": "1.0.0", 1163 | "resolved": "https://registry.npmjs.org/one-time/-/one-time-1.0.0.tgz", 1164 | "integrity": "sha512-5DXOiRKwuSEcQ/l0kGCF6Q3jcADFv5tSmRaJck/OqkVFcOzutB134KRSfF0xDrL39MNnqxbHBbUUcjZIhTgb2g==", 1165 | "dev": true, 1166 | "dependencies": { 1167 | "fn.name": "1.x.x" 1168 | } 1169 | }, 1170 | "node_modules/optionator": { 1171 | "version": "0.8.3", 1172 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", 1173 | "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", 1174 | "peer": true, 1175 | "dependencies": { 1176 | "deep-is": "~0.1.3", 1177 | "fast-levenshtein": "~2.0.6", 1178 | "levn": "~0.3.0", 1179 | "prelude-ls": "~1.1.2", 1180 | "type-check": "~0.3.2", 1181 | "word-wrap": "~1.2.3" 1182 | }, 1183 | "engines": { 1184 | "node": ">= 0.8.0" 1185 | } 1186 | }, 1187 | "node_modules/pac-proxy-agent": { 1188 | "version": "5.0.0", 1189 | "resolved": "https://registry.npmjs.org/pac-proxy-agent/-/pac-proxy-agent-5.0.0.tgz", 1190 | "integrity": "sha512-CcFG3ZtnxO8McDigozwE3AqAw15zDvGH+OjXO4kzf7IkEKkQ4gxQ+3sdF50WmhQ4P/bVusXcqNE2S3XrNURwzQ==", 1191 | "peer": true, 1192 | "dependencies": { 1193 | "@tootallnate/once": "1", 1194 | "agent-base": "6", 1195 | "debug": "4", 1196 | "get-uri": "3", 1197 | "http-proxy-agent": "^4.0.1", 1198 | "https-proxy-agent": "5", 1199 | "pac-resolver": "^5.0.0", 1200 | "raw-body": "^2.2.0", 1201 | "socks-proxy-agent": "5" 1202 | }, 1203 | "engines": { 1204 | "node": ">= 8" 1205 | } 1206 | }, 1207 | "node_modules/pac-resolver": { 1208 | "version": "5.0.0", 1209 | "resolved": "https://registry.npmjs.org/pac-resolver/-/pac-resolver-5.0.0.tgz", 1210 | "integrity": "sha512-H+/A6KitiHNNW+bxBKREk2MCGSxljfqRX76NjummWEYIat7ldVXRU3dhRIE3iXZ0nvGBk6smv3nntxKkzRL8NA==", 1211 | "peer": true, 1212 | "dependencies": { 1213 | "degenerator": "^3.0.1", 1214 | "ip": "^1.1.5", 1215 | "netmask": "^2.0.1" 1216 | }, 1217 | "engines": { 1218 | "node": ">= 8" 1219 | } 1220 | }, 1221 | "node_modules/param-case": { 1222 | "version": "1.1.2", 1223 | "resolved": "https://registry.npmjs.org/param-case/-/param-case-1.1.2.tgz", 1224 | "integrity": "sha1-3LCRpDwlm5Io8cNB57akTqC/l0M=", 1225 | "dependencies": { 1226 | "sentence-case": "^1.1.2" 1227 | } 1228 | }, 1229 | "node_modules/pascal-case": { 1230 | "version": "1.1.2", 1231 | "resolved": "https://registry.npmjs.org/pascal-case/-/pascal-case-1.1.2.tgz", 1232 | "integrity": "sha1-Pl1kogBDgwp8STRMLXS0G+DJyZs=", 1233 | "dependencies": { 1234 | "camel-case": "^1.1.1", 1235 | "upper-case-first": "^1.1.0" 1236 | } 1237 | }, 1238 | "node_modules/path-case": { 1239 | "version": "1.1.2", 1240 | "resolved": "https://registry.npmjs.org/path-case/-/path-case-1.1.2.tgz", 1241 | "integrity": "sha1-UM5roNO+090LXCqcRVNpdDRAlRQ=", 1242 | "dependencies": { 1243 | "sentence-case": "^1.1.2" 1244 | } 1245 | }, 1246 | "node_modules/prelude-ls": { 1247 | "version": "1.1.2", 1248 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 1249 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 1250 | "peer": true, 1251 | "engines": { 1252 | "node": ">= 0.8.0" 1253 | } 1254 | }, 1255 | "node_modules/process-nextick-args": { 1256 | "version": "2.0.1", 1257 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 1258 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 1259 | "dev": true 1260 | }, 1261 | "node_modules/proxy-agent": { 1262 | "version": "5.0.0", 1263 | "resolved": "https://registry.npmjs.org/proxy-agent/-/proxy-agent-5.0.0.tgz", 1264 | "integrity": "sha512-gkH7BkvLVkSfX9Dk27W6TyNOWWZWRilRfk1XxGNWOYJ2TuedAv1yFpCaU9QSBmBe716XOTNpYNOzhysyw8xn7g==", 1265 | "peer": true, 1266 | "dependencies": { 1267 | "agent-base": "^6.0.0", 1268 | "debug": "4", 1269 | "http-proxy-agent": "^4.0.0", 1270 | "https-proxy-agent": "^5.0.0", 1271 | "lru-cache": "^5.1.1", 1272 | "pac-proxy-agent": "^5.0.0", 1273 | "proxy-from-env": "^1.0.0", 1274 | "socks-proxy-agent": "^5.0.0" 1275 | }, 1276 | "engines": { 1277 | "node": ">= 8" 1278 | } 1279 | }, 1280 | "node_modules/proxy-agent/node_modules/lru-cache": { 1281 | "version": "5.1.1", 1282 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", 1283 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 1284 | "peer": true, 1285 | "dependencies": { 1286 | "yallist": "^3.0.2" 1287 | } 1288 | }, 1289 | "node_modules/proxy-agent/node_modules/yallist": { 1290 | "version": "3.1.1", 1291 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 1292 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", 1293 | "peer": true 1294 | }, 1295 | "node_modules/proxy-from-env": { 1296 | "version": "1.1.0", 1297 | "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", 1298 | "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" 1299 | }, 1300 | "node_modules/pseudomap": { 1301 | "version": "1.0.2", 1302 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 1303 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" 1304 | }, 1305 | "node_modules/punycode": { 1306 | "version": "1.3.2", 1307 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", 1308 | "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=", 1309 | "dev": true 1310 | }, 1311 | "node_modules/qs": { 1312 | "version": "6.10.1", 1313 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.10.1.tgz", 1314 | "integrity": "sha512-M528Hph6wsSVOBiYUnGf+K/7w0hNshs/duGsNXPUCLH5XAqjEtiPGwNONLV0tBH8NoGb0mvD5JubnUTrujKDTg==", 1315 | "dependencies": { 1316 | "side-channel": "^1.0.4" 1317 | }, 1318 | "engines": { 1319 | "node": ">=0.6" 1320 | }, 1321 | "funding": { 1322 | "url": "https://github.com/sponsors/ljharb" 1323 | } 1324 | }, 1325 | "node_modules/querystring": { 1326 | "version": "0.2.0", 1327 | "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", 1328 | "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=", 1329 | "deprecated": "The querystring API is considered Legacy. new code should use the URLSearchParams API instead.", 1330 | "dev": true, 1331 | "engines": { 1332 | "node": ">=0.4.x" 1333 | } 1334 | }, 1335 | "node_modules/raw-body": { 1336 | "version": "2.4.1", 1337 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.1.tgz", 1338 | "integrity": "sha512-9WmIKF6mkvA0SLmA2Knm9+qj89e+j1zqgyn8aXGd7+nAduPoqgI9lO57SAZNn/Byzo5P7JhXTyg9PzaJbH73bA==", 1339 | "peer": true, 1340 | "dependencies": { 1341 | "bytes": "3.1.0", 1342 | "http-errors": "1.7.3", 1343 | "iconv-lite": "0.4.24", 1344 | "unpipe": "1.0.0" 1345 | }, 1346 | "engines": { 1347 | "node": ">= 0.8" 1348 | } 1349 | }, 1350 | "node_modules/readable-stream": { 1351 | "version": "3.6.0", 1352 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", 1353 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 1354 | "dependencies": { 1355 | "inherits": "^2.0.3", 1356 | "string_decoder": "^1.1.1", 1357 | "util-deprecate": "^1.0.1" 1358 | }, 1359 | "engines": { 1360 | "node": ">= 6" 1361 | } 1362 | }, 1363 | "node_modules/rest-facade": { 1364 | "version": "1.16.2", 1365 | "resolved": "https://registry.npmjs.org/rest-facade/-/rest-facade-1.16.2.tgz", 1366 | "integrity": "sha512-Vs038wYpPhdIQ7wBr2460jmyY6WXkPSKyVAYOIIbjGI8lnG/6q4fI+v/MEPRpDrNur1DRAopQU5vQ3uNm3RiKQ==", 1367 | "dependencies": { 1368 | "change-case": "^2.3.0", 1369 | "deepmerge": "^3.2.0", 1370 | "lodash.get": "^4.4.2", 1371 | "superagent": "^5.1.1" 1372 | }, 1373 | "peerDependencies": { 1374 | "superagent-proxy": "^3.0.0" 1375 | } 1376 | }, 1377 | "node_modules/rest-facade/node_modules/lru-cache": { 1378 | "version": "6.0.0", 1379 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1380 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1381 | "dependencies": { 1382 | "yallist": "^4.0.0" 1383 | }, 1384 | "engines": { 1385 | "node": ">=10" 1386 | } 1387 | }, 1388 | "node_modules/rest-facade/node_modules/semver": { 1389 | "version": "7.3.5", 1390 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 1391 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 1392 | "dependencies": { 1393 | "lru-cache": "^6.0.0" 1394 | }, 1395 | "bin": { 1396 | "semver": "bin/semver.js" 1397 | }, 1398 | "engines": { 1399 | "node": ">=10" 1400 | } 1401 | }, 1402 | "node_modules/rest-facade/node_modules/superagent": { 1403 | "version": "5.3.1", 1404 | "resolved": "https://registry.npmjs.org/superagent/-/superagent-5.3.1.tgz", 1405 | "integrity": "sha512-wjJ/MoTid2/RuGCOFtlacyGNxN9QLMgcpYLDQlWFIhhdJ93kNscFonGvrpAHSCVjRVj++DGCglocF7Aej1KHvQ==", 1406 | "dependencies": { 1407 | "component-emitter": "^1.3.0", 1408 | "cookiejar": "^2.1.2", 1409 | "debug": "^4.1.1", 1410 | "fast-safe-stringify": "^2.0.7", 1411 | "form-data": "^3.0.0", 1412 | "formidable": "^1.2.2", 1413 | "methods": "^1.1.2", 1414 | "mime": "^2.4.6", 1415 | "qs": "^6.9.4", 1416 | "readable-stream": "^3.6.0", 1417 | "semver": "^7.3.2" 1418 | }, 1419 | "engines": { 1420 | "node": ">= 7.0.0" 1421 | } 1422 | }, 1423 | "node_modules/rest-facade/node_modules/yallist": { 1424 | "version": "4.0.0", 1425 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1426 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 1427 | }, 1428 | "node_modules/retry": { 1429 | "version": "0.13.1", 1430 | "resolved": "https://registry.npmjs.org/retry/-/retry-0.13.1.tgz", 1431 | "integrity": "sha512-XQBQ3I8W1Cge0Seh+6gjj03LbmRFWuoszgK9ooCpwYIrhhoO80pfq4cUkU5DkknwfOfFteRwlZ56PYOGYyFWdg==", 1432 | "engines": { 1433 | "node": ">= 4" 1434 | } 1435 | }, 1436 | "node_modules/safe-buffer": { 1437 | "version": "5.2.1", 1438 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1439 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1440 | "funding": [ 1441 | { 1442 | "type": "github", 1443 | "url": "https://github.com/sponsors/feross" 1444 | }, 1445 | { 1446 | "type": "patreon", 1447 | "url": "https://www.patreon.com/feross" 1448 | }, 1449 | { 1450 | "type": "consulting", 1451 | "url": "https://feross.org/support" 1452 | } 1453 | ] 1454 | }, 1455 | "node_modules/safer-buffer": { 1456 | "version": "2.1.2", 1457 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1458 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1459 | "peer": true 1460 | }, 1461 | "node_modules/sax": { 1462 | "version": "1.2.1", 1463 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.1.tgz", 1464 | "integrity": "sha1-e45lYZCyKOgaZq6nSEgNgozS03o=", 1465 | "dev": true 1466 | }, 1467 | "node_modules/semver": { 1468 | "version": "5.7.1", 1469 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1470 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1471 | "bin": { 1472 | "semver": "bin/semver" 1473 | } 1474 | }, 1475 | "node_modules/sentence-case": { 1476 | "version": "1.1.3", 1477 | "resolved": "https://registry.npmjs.org/sentence-case/-/sentence-case-1.1.3.tgz", 1478 | "integrity": "sha1-gDSq/CFFdy06vhUJqkLJ4QQtwTk=", 1479 | "dependencies": { 1480 | "lower-case": "^1.1.1" 1481 | } 1482 | }, 1483 | "node_modules/setprototypeof": { 1484 | "version": "1.1.1", 1485 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 1486 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==", 1487 | "peer": true 1488 | }, 1489 | "node_modules/side-channel": { 1490 | "version": "1.0.4", 1491 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 1492 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 1493 | "dependencies": { 1494 | "call-bind": "^1.0.0", 1495 | "get-intrinsic": "^1.0.2", 1496 | "object-inspect": "^1.9.0" 1497 | }, 1498 | "funding": { 1499 | "url": "https://github.com/sponsors/ljharb" 1500 | } 1501 | }, 1502 | "node_modules/simple-swizzle": { 1503 | "version": "0.2.2", 1504 | "resolved": "https://registry.npmjs.org/simple-swizzle/-/simple-swizzle-0.2.2.tgz", 1505 | "integrity": "sha1-pNprY1/8zMoz9w0Xy5JZLeleVXo=", 1506 | "dev": true, 1507 | "dependencies": { 1508 | "is-arrayish": "^0.3.1" 1509 | } 1510 | }, 1511 | "node_modules/smart-buffer": { 1512 | "version": "4.2.0", 1513 | "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz", 1514 | "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==", 1515 | "peer": true, 1516 | "engines": { 1517 | "node": ">= 6.0.0", 1518 | "npm": ">= 3.0.0" 1519 | } 1520 | }, 1521 | "node_modules/snake-case": { 1522 | "version": "1.1.2", 1523 | "resolved": "https://registry.npmjs.org/snake-case/-/snake-case-1.1.2.tgz", 1524 | "integrity": "sha1-DC8l4wUVjZoY09l3BmGH/vilpmo=", 1525 | "dependencies": { 1526 | "sentence-case": "^1.1.2" 1527 | } 1528 | }, 1529 | "node_modules/socks": { 1530 | "version": "2.6.1", 1531 | "resolved": "https://registry.npmjs.org/socks/-/socks-2.6.1.tgz", 1532 | "integrity": "sha512-kLQ9N5ucj8uIcxrDwjm0Jsqk06xdpBjGNQtpXy4Q8/QY2k+fY7nZH8CARy+hkbG+SGAovmzzuauCpBlb8FrnBA==", 1533 | "peer": true, 1534 | "dependencies": { 1535 | "ip": "^1.1.5", 1536 | "smart-buffer": "^4.1.0" 1537 | }, 1538 | "engines": { 1539 | "node": ">= 10.13.0", 1540 | "npm": ">= 3.0.0" 1541 | } 1542 | }, 1543 | "node_modules/socks-proxy-agent": { 1544 | "version": "5.0.1", 1545 | "resolved": "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-5.0.1.tgz", 1546 | "integrity": "sha512-vZdmnjb9a2Tz6WEQVIurybSwElwPxMZaIc7PzqbJTrezcKNznv6giT7J7tZDZ1BojVaa1jvO/UiUdhDVB0ACoQ==", 1547 | "peer": true, 1548 | "dependencies": { 1549 | "agent-base": "^6.0.2", 1550 | "debug": "4", 1551 | "socks": "^2.3.3" 1552 | }, 1553 | "engines": { 1554 | "node": ">= 6" 1555 | } 1556 | }, 1557 | "node_modules/source-map": { 1558 | "version": "0.6.1", 1559 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1560 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1561 | "optional": true, 1562 | "peer": true, 1563 | "engines": { 1564 | "node": ">=0.10.0" 1565 | } 1566 | }, 1567 | "node_modules/stack-trace": { 1568 | "version": "0.0.10", 1569 | "resolved": "https://registry.npmjs.org/stack-trace/-/stack-trace-0.0.10.tgz", 1570 | "integrity": "sha1-VHxws0fo0ytOEI6hoqFZ5f3eGcA=", 1571 | "dev": true, 1572 | "engines": { 1573 | "node": "*" 1574 | } 1575 | }, 1576 | "node_modules/statuses": { 1577 | "version": "1.5.0", 1578 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 1579 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=", 1580 | "peer": true, 1581 | "engines": { 1582 | "node": ">= 0.6" 1583 | } 1584 | }, 1585 | "node_modules/string_decoder": { 1586 | "version": "1.3.0", 1587 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 1588 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 1589 | "dependencies": { 1590 | "safe-buffer": "~5.2.0" 1591 | } 1592 | }, 1593 | "node_modules/superagent": { 1594 | "version": "6.1.0", 1595 | "resolved": "https://registry.npmjs.org/superagent/-/superagent-6.1.0.tgz", 1596 | "integrity": "sha512-OUDHEssirmplo3F+1HWKUrUjvnQuA+nZI6i/JJBdXb5eq9IyEQwPyPpqND+SSsxf6TygpBEkUjISVRN4/VOpeg==", 1597 | "peer": true, 1598 | "dependencies": { 1599 | "component-emitter": "^1.3.0", 1600 | "cookiejar": "^2.1.2", 1601 | "debug": "^4.1.1", 1602 | "fast-safe-stringify": "^2.0.7", 1603 | "form-data": "^3.0.0", 1604 | "formidable": "^1.2.2", 1605 | "methods": "^1.1.2", 1606 | "mime": "^2.4.6", 1607 | "qs": "^6.9.4", 1608 | "readable-stream": "^3.6.0", 1609 | "semver": "^7.3.2" 1610 | }, 1611 | "engines": { 1612 | "node": ">= 7.0.0" 1613 | } 1614 | }, 1615 | "node_modules/superagent-proxy": { 1616 | "version": "3.0.0", 1617 | "resolved": "https://registry.npmjs.org/superagent-proxy/-/superagent-proxy-3.0.0.tgz", 1618 | "integrity": "sha512-wAlRInOeDFyd9pyonrkJspdRAxdLrcsZ6aSnS+8+nu4x1aXbz6FWSTT9M6Ibze+eG60szlL7JA8wEIV7bPWuyQ==", 1619 | "peer": true, 1620 | "dependencies": { 1621 | "debug": "^4.3.2", 1622 | "proxy-agent": "^5.0.0" 1623 | }, 1624 | "engines": { 1625 | "node": ">=6" 1626 | }, 1627 | "peerDependencies": { 1628 | "superagent": ">= 0.15.4 || 1 || 2 || 3" 1629 | } 1630 | }, 1631 | "node_modules/superagent/node_modules/lru-cache": { 1632 | "version": "6.0.0", 1633 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1634 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1635 | "peer": true, 1636 | "dependencies": { 1637 | "yallist": "^4.0.0" 1638 | }, 1639 | "engines": { 1640 | "node": ">=10" 1641 | } 1642 | }, 1643 | "node_modules/superagent/node_modules/semver": { 1644 | "version": "7.3.5", 1645 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 1646 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 1647 | "peer": true, 1648 | "dependencies": { 1649 | "lru-cache": "^6.0.0" 1650 | }, 1651 | "bin": { 1652 | "semver": "bin/semver.js" 1653 | }, 1654 | "engines": { 1655 | "node": ">=10" 1656 | } 1657 | }, 1658 | "node_modules/superagent/node_modules/yallist": { 1659 | "version": "4.0.0", 1660 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1661 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1662 | "peer": true 1663 | }, 1664 | "node_modules/swap-case": { 1665 | "version": "1.1.2", 1666 | "resolved": "https://registry.npmjs.org/swap-case/-/swap-case-1.1.2.tgz", 1667 | "integrity": "sha1-w5IDpFhzhfrTyFCgvRvK+ggZdOM=", 1668 | "dependencies": { 1669 | "lower-case": "^1.1.1", 1670 | "upper-case": "^1.1.1" 1671 | } 1672 | }, 1673 | "node_modules/text-hex": { 1674 | "version": "1.0.0", 1675 | "resolved": "https://registry.npmjs.org/text-hex/-/text-hex-1.0.0.tgz", 1676 | "integrity": "sha512-uuVGNWzgJ4yhRaNSiubPY7OjISw4sw4E5Uv0wbjp+OzcbmVU/rsT8ujgcXJhn9ypzsgr5vlzpPqP+MBBKcGvbg==", 1677 | "dev": true 1678 | }, 1679 | "node_modules/title-case": { 1680 | "version": "1.1.2", 1681 | "resolved": "https://registry.npmjs.org/title-case/-/title-case-1.1.2.tgz", 1682 | "integrity": "sha1-+uSmrlRr+iLQg6DuqRCkDRLtT1o=", 1683 | "dependencies": { 1684 | "sentence-case": "^1.1.1", 1685 | "upper-case": "^1.0.3" 1686 | } 1687 | }, 1688 | "node_modules/toidentifier": { 1689 | "version": "1.0.0", 1690 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 1691 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==", 1692 | "peer": true, 1693 | "engines": { 1694 | "node": ">=0.6" 1695 | } 1696 | }, 1697 | "node_modules/triple-beam": { 1698 | "version": "1.3.0", 1699 | "resolved": "https://registry.npmjs.org/triple-beam/-/triple-beam-1.3.0.tgz", 1700 | "integrity": "sha512-XrHUvV5HpdLmIj4uVMxHggLbFSZYIn7HEWsqePZcI50pco+MPqJ50wMGY794X7AOOhxOBAjbkqfAbEe/QMp2Lw==", 1701 | "dev": true 1702 | }, 1703 | "node_modules/tslib": { 1704 | "version": "2.3.1", 1705 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.1.tgz", 1706 | "integrity": "sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw==", 1707 | "peer": true 1708 | }, 1709 | "node_modules/type-check": { 1710 | "version": "0.3.2", 1711 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 1712 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 1713 | "peer": true, 1714 | "dependencies": { 1715 | "prelude-ls": "~1.1.2" 1716 | }, 1717 | "engines": { 1718 | "node": ">= 0.8.0" 1719 | } 1720 | }, 1721 | "node_modules/universalify": { 1722 | "version": "0.1.2", 1723 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", 1724 | "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", 1725 | "peer": true, 1726 | "engines": { 1727 | "node": ">= 4.0.0" 1728 | } 1729 | }, 1730 | "node_modules/unpipe": { 1731 | "version": "1.0.0", 1732 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1733 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=", 1734 | "peer": true, 1735 | "engines": { 1736 | "node": ">= 0.8" 1737 | } 1738 | }, 1739 | "node_modules/upper-case": { 1740 | "version": "1.1.3", 1741 | "resolved": "https://registry.npmjs.org/upper-case/-/upper-case-1.1.3.tgz", 1742 | "integrity": "sha1-9rRQHC7EzdJrp4vnIilh3ndiFZg=" 1743 | }, 1744 | "node_modules/upper-case-first": { 1745 | "version": "1.1.2", 1746 | "resolved": "https://registry.npmjs.org/upper-case-first/-/upper-case-first-1.1.2.tgz", 1747 | "integrity": "sha1-XXm+3P8UQZUY/S7bCgUHybaFkRU=", 1748 | "dependencies": { 1749 | "upper-case": "^1.1.1" 1750 | } 1751 | }, 1752 | "node_modules/url": { 1753 | "version": "0.10.3", 1754 | "resolved": "https://registry.npmjs.org/url/-/url-0.10.3.tgz", 1755 | "integrity": "sha1-Ah5NnHcF8hu/N9A861h2dAJ3TGQ=", 1756 | "dev": true, 1757 | "dependencies": { 1758 | "punycode": "1.3.2", 1759 | "querystring": "0.2.0" 1760 | } 1761 | }, 1762 | "node_modules/util-deprecate": { 1763 | "version": "1.0.2", 1764 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1765 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 1766 | }, 1767 | "node_modules/uuid": { 1768 | "version": "3.3.2", 1769 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.2.tgz", 1770 | "integrity": "sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA==", 1771 | "deprecated": "Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details.", 1772 | "dev": true, 1773 | "bin": { 1774 | "uuid": "bin/uuid" 1775 | } 1776 | }, 1777 | "node_modules/vm2": { 1778 | "version": "3.9.8", 1779 | "resolved": "https://registry.npmjs.org/vm2/-/vm2-3.9.8.tgz", 1780 | "integrity": "sha512-/1PYg/BwdKzMPo8maOZ0heT7DLI0DAFTm7YQaz/Lim9oIaFZsJs3EdtalvXuBfZwczNwsYhju75NW4d6E+4q+w==", 1781 | "peer": true, 1782 | "dependencies": { 1783 | "acorn": "^8.7.0", 1784 | "acorn-walk": "^8.2.0" 1785 | }, 1786 | "bin": { 1787 | "vm2": "bin/vm2" 1788 | }, 1789 | "engines": { 1790 | "node": ">=6.0" 1791 | } 1792 | }, 1793 | "node_modules/winston": { 1794 | "version": "3.3.3", 1795 | "resolved": "https://registry.npmjs.org/winston/-/winston-3.3.3.tgz", 1796 | "integrity": "sha512-oEXTISQnC8VlSAKf1KYSSd7J6IWuRPQqDdo8eoRNaYKLvwSb5+79Z3Yi1lrl6KDpU6/VWaxpakDAtb1oQ4n9aw==", 1797 | "dev": true, 1798 | "dependencies": { 1799 | "@dabh/diagnostics": "^2.0.2", 1800 | "async": "^3.1.0", 1801 | "is-stream": "^2.0.0", 1802 | "logform": "^2.2.0", 1803 | "one-time": "^1.0.0", 1804 | "readable-stream": "^3.4.0", 1805 | "stack-trace": "0.0.x", 1806 | "triple-beam": "^1.3.0", 1807 | "winston-transport": "^4.4.0" 1808 | }, 1809 | "engines": { 1810 | "node": ">= 6.4.0" 1811 | } 1812 | }, 1813 | "node_modules/winston-transport": { 1814 | "version": "4.4.0", 1815 | "resolved": "https://registry.npmjs.org/winston-transport/-/winston-transport-4.4.0.tgz", 1816 | "integrity": "sha512-Lc7/p3GtqtqPBYYtS6KCN3c77/2QCev51DvcJKbkFPQNoj1sinkGwLGFDxkXY9J6p9+EPnYs+D90uwbnaiURTw==", 1817 | "dev": true, 1818 | "dependencies": { 1819 | "readable-stream": "^2.3.7", 1820 | "triple-beam": "^1.2.0" 1821 | }, 1822 | "engines": { 1823 | "node": ">= 6.4.0" 1824 | } 1825 | }, 1826 | "node_modules/winston-transport/node_modules/readable-stream": { 1827 | "version": "2.3.7", 1828 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 1829 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 1830 | "dev": true, 1831 | "dependencies": { 1832 | "core-util-is": "~1.0.0", 1833 | "inherits": "~2.0.3", 1834 | "isarray": "~1.0.0", 1835 | "process-nextick-args": "~2.0.0", 1836 | "safe-buffer": "~5.1.1", 1837 | "string_decoder": "~1.1.1", 1838 | "util-deprecate": "~1.0.1" 1839 | } 1840 | }, 1841 | "node_modules/winston-transport/node_modules/safe-buffer": { 1842 | "version": "5.1.2", 1843 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1844 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 1845 | "dev": true 1846 | }, 1847 | "node_modules/winston-transport/node_modules/string_decoder": { 1848 | "version": "1.1.1", 1849 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 1850 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 1851 | "dev": true, 1852 | "dependencies": { 1853 | "safe-buffer": "~5.1.0" 1854 | } 1855 | }, 1856 | "node_modules/word-wrap": { 1857 | "version": "1.2.3", 1858 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 1859 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 1860 | "peer": true, 1861 | "engines": { 1862 | "node": ">=0.10.0" 1863 | } 1864 | }, 1865 | "node_modules/xml2js": { 1866 | "version": "0.4.19", 1867 | "resolved": "https://registry.npmjs.org/xml2js/-/xml2js-0.4.19.tgz", 1868 | "integrity": "sha512-esZnJZJOiJR9wWKMyuvSE1y6Dq5LCuJanqhxslH2bxM6duahNZ+HMpCLhBQGZkbX6xRf8x1Y2eJlgt2q3qo49Q==", 1869 | "dev": true, 1870 | "dependencies": { 1871 | "sax": ">=0.6.0", 1872 | "xmlbuilder": "~9.0.1" 1873 | } 1874 | }, 1875 | "node_modules/xmlbuilder": { 1876 | "version": "9.0.7", 1877 | "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-9.0.7.tgz", 1878 | "integrity": "sha1-Ey7mPS7FVlxVfiD0wi35rKaGsQ0=", 1879 | "dev": true, 1880 | "engines": { 1881 | "node": ">=4.0" 1882 | } 1883 | }, 1884 | "node_modules/xregexp": { 1885 | "version": "2.0.0", 1886 | "resolved": "https://registry.npmjs.org/xregexp/-/xregexp-2.0.0.tgz", 1887 | "integrity": "sha1-UqY+VsoLhKfzpfPWGHLxJq16WUM=", 1888 | "peer": true, 1889 | "engines": { 1890 | "node": "*" 1891 | } 1892 | }, 1893 | "node_modules/yallist": { 1894 | "version": "2.1.2", 1895 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 1896 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" 1897 | } 1898 | }, 1899 | "dependencies": { 1900 | "@dabh/diagnostics": { 1901 | "version": "2.0.2", 1902 | "resolved": "https://registry.npmjs.org/@dabh/diagnostics/-/diagnostics-2.0.2.tgz", 1903 | "integrity": "sha512-+A1YivoVDNNVCdfozHSR8v/jyuuLTMXwjWuxPFlFlUapXoGc+Gj9mDlTDDfrwl7rXCl2tNZ0kE8sIBO6YOn96Q==", 1904 | "dev": true, 1905 | "requires": { 1906 | "colorspace": "1.1.x", 1907 | "enabled": "2.0.x", 1908 | "kuler": "^2.0.0" 1909 | } 1910 | }, 1911 | "@tootallnate/once": { 1912 | "version": "1.1.2", 1913 | "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", 1914 | "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==" 1915 | }, 1916 | "@types/body-parser": { 1917 | "version": "1.19.1", 1918 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.1.tgz", 1919 | "integrity": "sha512-a6bTJ21vFOGIkwM0kzh9Yr89ziVxq4vYH2fQ6N8AeipEzai/cFK6aGMArIkUeIdRIgpwQa+2bXiLuUJCpSf2Cg==", 1920 | "requires": { 1921 | "@types/connect": "*", 1922 | "@types/node": "*" 1923 | } 1924 | }, 1925 | "@types/connect": { 1926 | "version": "3.4.35", 1927 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz", 1928 | "integrity": "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==", 1929 | "requires": { 1930 | "@types/node": "*" 1931 | } 1932 | }, 1933 | "@types/express": { 1934 | "version": "4.17.13", 1935 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.13.tgz", 1936 | "integrity": "sha512-6bSZTPaTIACxn48l50SR+axgrqm6qXFIxrdAKaG6PaJk3+zuUr35hBlgT7vOmJcum+OEaIBLtHV/qloEAFITeA==", 1937 | "requires": { 1938 | "@types/body-parser": "*", 1939 | "@types/express-serve-static-core": "^4.17.18", 1940 | "@types/qs": "*", 1941 | "@types/serve-static": "*" 1942 | } 1943 | }, 1944 | "@types/express-jwt": { 1945 | "version": "0.0.42", 1946 | "resolved": "https://registry.npmjs.org/@types/express-jwt/-/express-jwt-0.0.42.tgz", 1947 | "integrity": "sha512-WszgUddvM1t5dPpJ3LhWNH8kfNN8GPIBrAGxgIYXVCEGx6Bx4A036aAuf/r5WH9DIEdlmp7gHOYvSM6U87B0ag==", 1948 | "requires": { 1949 | "@types/express": "*", 1950 | "@types/express-unless": "*" 1951 | } 1952 | }, 1953 | "@types/express-serve-static-core": { 1954 | "version": "4.17.24", 1955 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.24.tgz", 1956 | "integrity": "sha512-3UJuW+Qxhzwjq3xhwXm2onQcFHn76frIYVbTu+kn24LFxI+dEhdfISDFovPB8VpEgW8oQCTpRuCe+0zJxB7NEA==", 1957 | "requires": { 1958 | "@types/node": "*", 1959 | "@types/qs": "*", 1960 | "@types/range-parser": "*" 1961 | } 1962 | }, 1963 | "@types/express-unless": { 1964 | "version": "0.5.2", 1965 | "resolved": "https://registry.npmjs.org/@types/express-unless/-/express-unless-0.5.2.tgz", 1966 | "integrity": "sha512-Q74UyYRX/zIgl1HSp9tUX2PlG8glkVm+59r7aK4KGKzC5jqKIOX6rrVLRQrzpZUQ84VukHtRoeAuon2nIssHPQ==", 1967 | "requires": { 1968 | "@types/express": "*" 1969 | } 1970 | }, 1971 | "@types/mime": { 1972 | "version": "1.3.2", 1973 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.2.tgz", 1974 | "integrity": "sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw==" 1975 | }, 1976 | "@types/node": { 1977 | "version": "16.4.6", 1978 | "resolved": "https://registry.npmjs.org/@types/node/-/node-16.4.6.tgz", 1979 | "integrity": "sha512-FKyawK3o5KL16AwbeFajen8G4K3mmqUrQsehn5wNKs8IzlKHE8TfnSmILXVMVziAEcnB23u1RCFU1NT6hSyr7Q==" 1980 | }, 1981 | "@types/qs": { 1982 | "version": "6.9.7", 1983 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", 1984 | "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==" 1985 | }, 1986 | "@types/range-parser": { 1987 | "version": "1.2.4", 1988 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz", 1989 | "integrity": "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==" 1990 | }, 1991 | "@types/serve-static": { 1992 | "version": "1.13.10", 1993 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.10.tgz", 1994 | "integrity": "sha512-nCkHGI4w7ZgAdNkrEu0bv+4xNV/XDqW+DydknebMOQwkpDGx8G+HTlj7R7ABI8i8nKxVw0wtKPi1D+lPOkh4YQ==", 1995 | "requires": { 1996 | "@types/mime": "^1", 1997 | "@types/node": "*" 1998 | } 1999 | }, 2000 | "acorn": { 2001 | "version": "8.7.0", 2002 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.7.0.tgz", 2003 | "integrity": "sha512-V/LGr1APy+PXIwKebEWrkZPwoeoF+w1jiOBUmuxuiUIaOHtob8Qc9BTrYo7VuI5fR8tqsy+buA2WFooR5olqvQ==", 2004 | "peer": true 2005 | }, 2006 | "acorn-walk": { 2007 | "version": "8.2.0", 2008 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", 2009 | "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", 2010 | "peer": true 2011 | }, 2012 | "agent-base": { 2013 | "version": "6.0.2", 2014 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 2015 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 2016 | "requires": { 2017 | "debug": "4" 2018 | } 2019 | }, 2020 | "ast-types": { 2021 | "version": "0.13.4", 2022 | "resolved": "https://registry.npmjs.org/ast-types/-/ast-types-0.13.4.tgz", 2023 | "integrity": "sha512-x1FCFnFifvYDDzTaLII71vG5uvDwgtmDTEVWAxrgeiR8VjMONcCXJx7E+USjDtHlwFmt9MysbqgF9b9Vjr6w+w==", 2024 | "peer": true, 2025 | "requires": { 2026 | "tslib": "^2.0.1" 2027 | } 2028 | }, 2029 | "async": { 2030 | "version": "3.2.4", 2031 | "resolved": "https://registry.npmjs.org/async/-/async-3.2.4.tgz", 2032 | "integrity": "sha512-iAB+JbDEGXhyIUavoDl9WP/Jj106Kz9DEn1DPgYw5ruDn0e3Wgi3sKFm55sASdGBNOQB8F59d9qQ7deqrHA8wQ==", 2033 | "dev": true 2034 | }, 2035 | "asynckit": { 2036 | "version": "0.4.0", 2037 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 2038 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 2039 | }, 2040 | "auth0": { 2041 | "version": "2.37.0", 2042 | "resolved": "https://registry.npmjs.org/auth0/-/auth0-2.37.0.tgz", 2043 | "integrity": "sha512-6Kz/+7d3PRb1zKR6O7CVt0EHAu+dphLFbJcvCEn7z9mUyjM0kJp/RnkALfFLfVzmSsaWeBqQNi2uZmdjReCjzQ==", 2044 | "requires": { 2045 | "axios": "^0.21.4", 2046 | "es6-promisify": "^6.1.1", 2047 | "form-data": "^3.0.1", 2048 | "jsonwebtoken": "^8.5.1", 2049 | "jwks-rsa": "^1.12.1", 2050 | "lru-memoizer": "^2.1.4", 2051 | "rest-facade": "^1.13.1", 2052 | "retry": "^0.13.1" 2053 | } 2054 | }, 2055 | "aws-sdk": { 2056 | "version": "2.956.0", 2057 | "resolved": "https://registry.npmjs.org/aws-sdk/-/aws-sdk-2.956.0.tgz", 2058 | "integrity": "sha512-vSzL66tjeRSBPnLR2Pkx4qS7SPqADT7K9QBjWdMhVd9BF5spyMvJ9hReIEShILp3hq99sHI+MvO+uTUm5s023g==", 2059 | "dev": true, 2060 | "requires": { 2061 | "buffer": "4.9.2", 2062 | "events": "1.1.1", 2063 | "ieee754": "1.1.13", 2064 | "jmespath": "0.15.0", 2065 | "querystring": "0.2.0", 2066 | "sax": "1.2.1", 2067 | "url": "0.10.3", 2068 | "uuid": "3.3.2", 2069 | "xml2js": "0.4.19" 2070 | } 2071 | }, 2072 | "axios": { 2073 | "version": "0.21.4", 2074 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.21.4.tgz", 2075 | "integrity": "sha512-ut5vewkiu8jjGBdqpM44XxjuCjq9LAKeHVmoVfHVzy8eHgxxq8SbAVQNovDA8mVi05kP0Ea/n/UzcSHcTJQfNg==", 2076 | "requires": { 2077 | "follow-redirects": "^1.14.0" 2078 | } 2079 | }, 2080 | "base64-js": { 2081 | "version": "1.5.1", 2082 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 2083 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", 2084 | "dev": true 2085 | }, 2086 | "bluebird": { 2087 | "version": "3.7.2", 2088 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz", 2089 | "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==" 2090 | }, 2091 | "buffer": { 2092 | "version": "4.9.2", 2093 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-4.9.2.tgz", 2094 | "integrity": "sha512-xq+q3SRMOxGivLhBNaUdC64hDTQwejJ+H0T/NB1XMtTVEwNTrfFF3gAxiyW0Bu/xWEGhjVKgUcMhCrUy2+uCWg==", 2095 | "dev": true, 2096 | "requires": { 2097 | "base64-js": "^1.0.2", 2098 | "ieee754": "^1.1.4", 2099 | "isarray": "^1.0.0" 2100 | } 2101 | }, 2102 | "buffer-equal-constant-time": { 2103 | "version": "1.0.1", 2104 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 2105 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 2106 | }, 2107 | "bytes": { 2108 | "version": "3.1.0", 2109 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 2110 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==", 2111 | "peer": true 2112 | }, 2113 | "call-bind": { 2114 | "version": "1.0.2", 2115 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 2116 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 2117 | "requires": { 2118 | "function-bind": "^1.1.1", 2119 | "get-intrinsic": "^1.0.2" 2120 | } 2121 | }, 2122 | "camel-case": { 2123 | "version": "1.2.2", 2124 | "resolved": "https://registry.npmjs.org/camel-case/-/camel-case-1.2.2.tgz", 2125 | "integrity": "sha1-Gsp8TRlTWaLOmVV5NDPG5VQlEfI=", 2126 | "requires": { 2127 | "sentence-case": "^1.1.1", 2128 | "upper-case": "^1.1.1" 2129 | } 2130 | }, 2131 | "change-case": { 2132 | "version": "2.3.1", 2133 | "resolved": "https://registry.npmjs.org/change-case/-/change-case-2.3.1.tgz", 2134 | "integrity": "sha1-LE/ePwY7tB0AzWjg1aCdthy+iU8=", 2135 | "requires": { 2136 | "camel-case": "^1.1.1", 2137 | "constant-case": "^1.1.0", 2138 | "dot-case": "^1.1.0", 2139 | "is-lower-case": "^1.1.0", 2140 | "is-upper-case": "^1.1.0", 2141 | "lower-case": "^1.1.1", 2142 | "lower-case-first": "^1.0.0", 2143 | "param-case": "^1.1.0", 2144 | "pascal-case": "^1.1.0", 2145 | "path-case": "^1.1.0", 2146 | "sentence-case": "^1.1.1", 2147 | "snake-case": "^1.1.0", 2148 | "swap-case": "^1.1.0", 2149 | "title-case": "^1.1.0", 2150 | "upper-case": "^1.1.1", 2151 | "upper-case-first": "^1.1.0" 2152 | } 2153 | }, 2154 | "color": { 2155 | "version": "3.0.0", 2156 | "resolved": "https://registry.npmjs.org/color/-/color-3.0.0.tgz", 2157 | "integrity": "sha512-jCpd5+s0s0t7p3pHQKpnJ0TpQKKdleP71LWcA0aqiljpiuAkOSUFN/dyH8ZwF0hRmFlrIuRhufds1QyEP9EB+w==", 2158 | "dev": true, 2159 | "requires": { 2160 | "color-convert": "^1.9.1", 2161 | "color-string": "^1.5.2" 2162 | } 2163 | }, 2164 | "color-convert": { 2165 | "version": "1.9.3", 2166 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 2167 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 2168 | "dev": true, 2169 | "requires": { 2170 | "color-name": "1.1.3" 2171 | } 2172 | }, 2173 | "color-name": { 2174 | "version": "1.1.3", 2175 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 2176 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 2177 | "dev": true 2178 | }, 2179 | "color-string": { 2180 | "version": "1.6.0", 2181 | "resolved": "https://registry.npmjs.org/color-string/-/color-string-1.6.0.tgz", 2182 | "integrity": "sha512-c/hGS+kRWJutUBEngKKmk4iH3sD59MBkoxVapS/0wgpCz2u7XsNloxknyvBhzwEs1IbV36D9PwqLPJ2DTu3vMA==", 2183 | "dev": true, 2184 | "requires": { 2185 | "color-name": "^1.0.0", 2186 | "simple-swizzle": "^0.2.2" 2187 | } 2188 | }, 2189 | "colors": { 2190 | "version": "1.4.0", 2191 | "resolved": "https://registry.npmjs.org/colors/-/colors-1.4.0.tgz", 2192 | "integrity": "sha512-a+UqTh4kgZg/SlGvfbzDHpgRu7AAQOmmqRHJnxhRZICKFUT91brVhNNt58CMWU9PsBbv3PDCZUHbVxuDiH2mtA==", 2193 | "dev": true 2194 | }, 2195 | "colorspace": { 2196 | "version": "1.1.2", 2197 | "resolved": "https://registry.npmjs.org/colorspace/-/colorspace-1.1.2.tgz", 2198 | "integrity": "sha512-vt+OoIP2d76xLhjwbBaucYlNSpPsrJWPlBTtwCpQKIu6/CSMutyzX93O/Do0qzpH3YoHEes8YEFXyZ797rEhzQ==", 2199 | "dev": true, 2200 | "requires": { 2201 | "color": "3.0.x", 2202 | "text-hex": "1.0.x" 2203 | } 2204 | }, 2205 | "combined-stream": { 2206 | "version": "1.0.8", 2207 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 2208 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 2209 | "requires": { 2210 | "delayed-stream": "~1.0.0" 2211 | } 2212 | }, 2213 | "commander": { 2214 | "version": "6.2.1", 2215 | "resolved": "https://registry.npmjs.org/commander/-/commander-6.2.1.tgz", 2216 | "integrity": "sha512-U7VdrJFnJgo4xjrHpTzu0yrHPGImdsmD95ZlgYSEajAn2JKzDhDTPG9kBTefmObL2w/ngeZnilk+OV9CG3d7UA==", 2217 | "dev": true 2218 | }, 2219 | "component-emitter": { 2220 | "version": "1.3.0", 2221 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz", 2222 | "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==" 2223 | }, 2224 | "constant-case": { 2225 | "version": "1.1.2", 2226 | "resolved": "https://registry.npmjs.org/constant-case/-/constant-case-1.1.2.tgz", 2227 | "integrity": "sha1-jsLKW6ND4Aqjjb9OIA/VrJB+/WM=", 2228 | "requires": { 2229 | "snake-case": "^1.1.0", 2230 | "upper-case": "^1.1.1" 2231 | } 2232 | }, 2233 | "cookiejar": { 2234 | "version": "2.1.3", 2235 | "resolved": "https://registry.npmjs.org/cookiejar/-/cookiejar-2.1.3.tgz", 2236 | "integrity": "sha512-JxbCBUdrfr6AQjOXrxoTvAMJO4HBTUIlBzslcJPAz+/KT8yk53fXun51u+RenNYvad/+Vc2DIz5o9UxlCDymFQ==" 2237 | }, 2238 | "core-util-is": { 2239 | "version": "1.0.2", 2240 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 2241 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 2242 | }, 2243 | "data-uri-to-buffer": { 2244 | "version": "3.0.1", 2245 | "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-3.0.1.tgz", 2246 | "integrity": "sha512-WboRycPNsVw3B3TL559F7kuBUM4d8CgMEvk6xEJlOp7OBPjt6G7z8WMWlD2rOFZLk6OYfFIUGsCOWzcQH9K2og==", 2247 | "peer": true 2248 | }, 2249 | "debug": { 2250 | "version": "4.3.2", 2251 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", 2252 | "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", 2253 | "requires": { 2254 | "ms": "2.1.2" 2255 | }, 2256 | "dependencies": { 2257 | "ms": { 2258 | "version": "2.1.2", 2259 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2260 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 2261 | } 2262 | } 2263 | }, 2264 | "deep-is": { 2265 | "version": "0.1.4", 2266 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 2267 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 2268 | "peer": true 2269 | }, 2270 | "deepmerge": { 2271 | "version": "3.3.0", 2272 | "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-3.3.0.tgz", 2273 | "integrity": "sha512-GRQOafGHwMHpjPx9iCvTgpu9NojZ49q794EEL94JVEw6VaeA8XTUyBKvAkOOjBX9oJNiV6G3P+T+tihFjo2TqA==" 2274 | }, 2275 | "degenerator": { 2276 | "version": "3.0.1", 2277 | "resolved": "https://registry.npmjs.org/degenerator/-/degenerator-3.0.1.tgz", 2278 | "integrity": "sha512-LFsIFEeLPlKvAKXu7j3ssIG6RT0TbI7/GhsqrI0DnHASEQjXQ0LUSYcjJteGgRGmZbl1TnMSxpNQIAiJ7Du5TQ==", 2279 | "peer": true, 2280 | "requires": { 2281 | "ast-types": "^0.13.2", 2282 | "escodegen": "^1.8.1", 2283 | "esprima": "^4.0.0", 2284 | "vm2": "^3.9.3" 2285 | } 2286 | }, 2287 | "delayed-stream": { 2288 | "version": "1.0.0", 2289 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 2290 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" 2291 | }, 2292 | "depd": { 2293 | "version": "1.1.2", 2294 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 2295 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=", 2296 | "peer": true 2297 | }, 2298 | "dot-case": { 2299 | "version": "1.1.2", 2300 | "resolved": "https://registry.npmjs.org/dot-case/-/dot-case-1.1.2.tgz", 2301 | "integrity": "sha1-HnOCaQDeKNbeVIC8HeMdCEKwa+w=", 2302 | "requires": { 2303 | "sentence-case": "^1.1.2" 2304 | } 2305 | }, 2306 | "dotenv": { 2307 | "version": "5.0.1", 2308 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-5.0.1.tgz", 2309 | "integrity": "sha512-4As8uPrjfwb7VXC+WnLCbXK7y+Ueb2B3zgNCePYfhxS1PYeaO1YTeplffTEcbfLhvFNGLAz90VvJs9yomG7bow==" 2310 | }, 2311 | "ecdsa-sig-formatter": { 2312 | "version": "1.0.11", 2313 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 2314 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 2315 | "requires": { 2316 | "safe-buffer": "^5.0.1" 2317 | } 2318 | }, 2319 | "enabled": { 2320 | "version": "2.0.0", 2321 | "resolved": "https://registry.npmjs.org/enabled/-/enabled-2.0.0.tgz", 2322 | "integrity": "sha512-AKrN98kuwOzMIdAizXGI86UFBoo26CL21UM763y1h/GMSJ4/OHU9k2YlsmBpyScFo/wbLzWQJBMCW4+IO3/+OQ==", 2323 | "dev": true 2324 | }, 2325 | "es6-promisify": { 2326 | "version": "6.1.1", 2327 | "resolved": "https://registry.npmjs.org/es6-promisify/-/es6-promisify-6.1.1.tgz", 2328 | "integrity": "sha512-HBL8I3mIki5C1Cc9QjKUenHtnG0A5/xA8Q/AllRcfiwl2CZFXGK7ddBiCoRwAix4i2KxcQfjtIVcrVbB3vbmwg==" 2329 | }, 2330 | "escodegen": { 2331 | "version": "1.14.3", 2332 | "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.14.3.tgz", 2333 | "integrity": "sha512-qFcX0XJkdg+PB3xjZZG/wKSuT1PnQWx57+TVSjIMmILd2yC/6ByYElPwJnslDsuWuSAp4AwJGumarAAmJch5Kw==", 2334 | "peer": true, 2335 | "requires": { 2336 | "esprima": "^4.0.1", 2337 | "estraverse": "^4.2.0", 2338 | "esutils": "^2.0.2", 2339 | "optionator": "^0.8.1", 2340 | "source-map": "~0.6.1" 2341 | } 2342 | }, 2343 | "esprima": { 2344 | "version": "4.0.1", 2345 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 2346 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 2347 | "peer": true 2348 | }, 2349 | "estraverse": { 2350 | "version": "4.3.0", 2351 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 2352 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 2353 | "peer": true 2354 | }, 2355 | "esutils": { 2356 | "version": "2.0.3", 2357 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2358 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 2359 | "peer": true 2360 | }, 2361 | "events": { 2362 | "version": "1.1.1", 2363 | "resolved": "https://registry.npmjs.org/events/-/events-1.1.1.tgz", 2364 | "integrity": "sha1-nr23Y1rQmccNzEwqH1AEKI6L2SQ=", 2365 | "dev": true 2366 | }, 2367 | "fast-levenshtein": { 2368 | "version": "2.0.6", 2369 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2370 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 2371 | "peer": true 2372 | }, 2373 | "fast-safe-stringify": { 2374 | "version": "2.0.8", 2375 | "resolved": "https://registry.npmjs.org/fast-safe-stringify/-/fast-safe-stringify-2.0.8.tgz", 2376 | "integrity": "sha512-lXatBjf3WPjmWD6DpIZxkeSsCOwqI0maYMpgDlx8g4U2qi4lbjA9oH/HD2a87G+KfsUmo5WbJFmqBZlPxtptag==" 2377 | }, 2378 | "fecha": { 2379 | "version": "4.2.1", 2380 | "resolved": "https://registry.npmjs.org/fecha/-/fecha-4.2.1.tgz", 2381 | "integrity": "sha512-MMMQ0ludy/nBs1/o0zVOiKTpG7qMbonKUzjJgQFEuvq6INZ1OraKPRAWkBq5vlKLOUMpmNYG1JoN3oDPUQ9m3Q==", 2382 | "dev": true 2383 | }, 2384 | "file-uri-to-path": { 2385 | "version": "2.0.0", 2386 | "resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-2.0.0.tgz", 2387 | "integrity": "sha512-hjPFI8oE/2iQPVe4gbrJ73Pp+Xfub2+WI2LlXDbsaJBwT5wuMh35WNWVYYTpnz895shtwfyutMFLFywpQAFdLg==", 2388 | "peer": true 2389 | }, 2390 | "fn.name": { 2391 | "version": "1.1.0", 2392 | "resolved": "https://registry.npmjs.org/fn.name/-/fn.name-1.1.0.tgz", 2393 | "integrity": "sha512-GRnmB5gPyJpAhTQdSZTSp9uaPSvl09KoYcMQtsB9rQoOmzs9dH6ffeccH+Z+cv6P68Hu5bC6JjRh4Ah/mHSNRw==", 2394 | "dev": true 2395 | }, 2396 | "follow-redirects": { 2397 | "version": "1.14.9", 2398 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.14.9.tgz", 2399 | "integrity": "sha512-MQDfihBQYMcyy5dhRDJUHcw7lb2Pv/TuE6xP1vyraLukNDHKbDxDNaOE3NbCAdKQApno+GPRyo1YAp89yCjK4w==" 2400 | }, 2401 | "form-data": { 2402 | "version": "3.0.1", 2403 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-3.0.1.tgz", 2404 | "integrity": "sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg==", 2405 | "requires": { 2406 | "asynckit": "^0.4.0", 2407 | "combined-stream": "^1.0.8", 2408 | "mime-types": "^2.1.12" 2409 | } 2410 | }, 2411 | "formidable": { 2412 | "version": "1.2.2", 2413 | "resolved": "https://registry.npmjs.org/formidable/-/formidable-1.2.2.tgz", 2414 | "integrity": "sha512-V8gLm+41I/8kguQ4/o1D3RIHRmhYFG4pnNyonvua+40rqcEmT4+V71yaZ3B457xbbgCsCfjSPi65u/W6vK1U5Q==" 2415 | }, 2416 | "fs-extra": { 2417 | "version": "8.1.0", 2418 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz", 2419 | "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", 2420 | "peer": true, 2421 | "requires": { 2422 | "graceful-fs": "^4.2.0", 2423 | "jsonfile": "^4.0.0", 2424 | "universalify": "^0.1.0" 2425 | } 2426 | }, 2427 | "ftp": { 2428 | "version": "0.3.10", 2429 | "resolved": "https://registry.npmjs.org/ftp/-/ftp-0.3.10.tgz", 2430 | "integrity": "sha1-kZfYYa2BQvPmPVqDv+TFn3MwiF0=", 2431 | "peer": true, 2432 | "requires": { 2433 | "readable-stream": "1.1.x", 2434 | "xregexp": "2.0.0" 2435 | }, 2436 | "dependencies": { 2437 | "isarray": { 2438 | "version": "0.0.1", 2439 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 2440 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", 2441 | "peer": true 2442 | }, 2443 | "readable-stream": { 2444 | "version": "1.1.14", 2445 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", 2446 | "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", 2447 | "peer": true, 2448 | "requires": { 2449 | "core-util-is": "~1.0.0", 2450 | "inherits": "~2.0.1", 2451 | "isarray": "0.0.1", 2452 | "string_decoder": "~0.10.x" 2453 | } 2454 | }, 2455 | "string_decoder": { 2456 | "version": "0.10.31", 2457 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 2458 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", 2459 | "peer": true 2460 | } 2461 | } 2462 | }, 2463 | "function-bind": { 2464 | "version": "1.1.1", 2465 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 2466 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 2467 | }, 2468 | "get-intrinsic": { 2469 | "version": "1.1.1", 2470 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", 2471 | "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", 2472 | "requires": { 2473 | "function-bind": "^1.1.1", 2474 | "has": "^1.0.3", 2475 | "has-symbols": "^1.0.1" 2476 | } 2477 | }, 2478 | "get-uri": { 2479 | "version": "3.0.2", 2480 | "resolved": "https://registry.npmjs.org/get-uri/-/get-uri-3.0.2.tgz", 2481 | "integrity": "sha512-+5s0SJbGoyiJTZZ2JTpFPLMPSch72KEqGOTvQsBqg0RBWvwhWUSYZFAtz3TPW0GXJuLBJPts1E241iHg+VRfhg==", 2482 | "peer": true, 2483 | "requires": { 2484 | "@tootallnate/once": "1", 2485 | "data-uri-to-buffer": "3", 2486 | "debug": "4", 2487 | "file-uri-to-path": "2", 2488 | "fs-extra": "^8.1.0", 2489 | "ftp": "^0.3.10" 2490 | } 2491 | }, 2492 | "graceful-fs": { 2493 | "version": "4.2.8", 2494 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.8.tgz", 2495 | "integrity": "sha512-qkIilPUYcNhJpd33n0GBXTB1MMPp14TxEsEs0pTrsSVucApsYzW5V+Q8Qxhik6KU3evy+qkAAowTByymK0avdg==", 2496 | "peer": true 2497 | }, 2498 | "has": { 2499 | "version": "1.0.3", 2500 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 2501 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 2502 | "requires": { 2503 | "function-bind": "^1.1.1" 2504 | } 2505 | }, 2506 | "has-symbols": { 2507 | "version": "1.0.2", 2508 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", 2509 | "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==" 2510 | }, 2511 | "http-errors": { 2512 | "version": "1.7.3", 2513 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.3.tgz", 2514 | "integrity": "sha512-ZTTX0MWrsQ2ZAhA1cejAwDLycFsd7I7nVtnkT3Ol0aqodaKW+0CTZDQ1uBv5whptCnc8e8HeRRJxRs0kmm/Qfw==", 2515 | "peer": true, 2516 | "requires": { 2517 | "depd": "~1.1.2", 2518 | "inherits": "2.0.4", 2519 | "setprototypeof": "1.1.1", 2520 | "statuses": ">= 1.5.0 < 2", 2521 | "toidentifier": "1.0.0" 2522 | } 2523 | }, 2524 | "http-proxy-agent": { 2525 | "version": "4.0.1", 2526 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", 2527 | "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", 2528 | "requires": { 2529 | "@tootallnate/once": "1", 2530 | "agent-base": "6", 2531 | "debug": "4" 2532 | } 2533 | }, 2534 | "https-proxy-agent": { 2535 | "version": "5.0.0", 2536 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz", 2537 | "integrity": "sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==", 2538 | "requires": { 2539 | "agent-base": "6", 2540 | "debug": "4" 2541 | } 2542 | }, 2543 | "iconv-lite": { 2544 | "version": "0.4.24", 2545 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 2546 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 2547 | "peer": true, 2548 | "requires": { 2549 | "safer-buffer": ">= 2.1.2 < 3" 2550 | } 2551 | }, 2552 | "ieee754": { 2553 | "version": "1.1.13", 2554 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.1.13.tgz", 2555 | "integrity": "sha512-4vf7I2LYV/HaWerSo3XmlMkp5eZ83i+/CDluXi/IGTs/O1sejBNhTtnxzmRZfvOUqj7lZjqHkeTvpgSFDlWZTg==", 2556 | "dev": true 2557 | }, 2558 | "inherits": { 2559 | "version": "2.0.4", 2560 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2561 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 2562 | }, 2563 | "ip": { 2564 | "version": "1.1.5", 2565 | "resolved": "https://registry.npmjs.org/ip/-/ip-1.1.5.tgz", 2566 | "integrity": "sha1-vd7XARQpCCjAoDnnLvJfWq7ENUo=", 2567 | "peer": true 2568 | }, 2569 | "is-arrayish": { 2570 | "version": "0.3.2", 2571 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.3.2.tgz", 2572 | "integrity": "sha512-eVRqCvVlZbuw3GrM63ovNSNAeA1K16kaR/LRY/92w0zxQ5/1YzwblUX652i4Xs9RwAGjW9d9y6X88t8OaAJfWQ==", 2573 | "dev": true 2574 | }, 2575 | "is-lower-case": { 2576 | "version": "1.1.3", 2577 | "resolved": "https://registry.npmjs.org/is-lower-case/-/is-lower-case-1.1.3.tgz", 2578 | "integrity": "sha1-fhR75HaNxGbbO/shzGCzHmrWk5M=", 2579 | "requires": { 2580 | "lower-case": "^1.1.0" 2581 | } 2582 | }, 2583 | "is-stream": { 2584 | "version": "2.0.1", 2585 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", 2586 | "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", 2587 | "dev": true 2588 | }, 2589 | "is-upper-case": { 2590 | "version": "1.1.2", 2591 | "resolved": "https://registry.npmjs.org/is-upper-case/-/is-upper-case-1.1.2.tgz", 2592 | "integrity": "sha1-jQsfp+eTOh5YSDYA7H2WYcuvdW8=", 2593 | "requires": { 2594 | "upper-case": "^1.1.0" 2595 | } 2596 | }, 2597 | "isarray": { 2598 | "version": "1.0.0", 2599 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 2600 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 2601 | "dev": true 2602 | }, 2603 | "jmespath": { 2604 | "version": "0.15.0", 2605 | "resolved": "https://registry.npmjs.org/jmespath/-/jmespath-0.15.0.tgz", 2606 | "integrity": "sha1-o/Iiqarp+Wb10nx5ZRDigJF2Qhc=", 2607 | "dev": true 2608 | }, 2609 | "jsonfile": { 2610 | "version": "4.0.0", 2611 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", 2612 | "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", 2613 | "peer": true, 2614 | "requires": { 2615 | "graceful-fs": "^4.1.6" 2616 | } 2617 | }, 2618 | "jsonwebtoken": { 2619 | "version": "8.5.1", 2620 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz", 2621 | "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==", 2622 | "requires": { 2623 | "jws": "^3.2.2", 2624 | "lodash.includes": "^4.3.0", 2625 | "lodash.isboolean": "^3.0.3", 2626 | "lodash.isinteger": "^4.0.4", 2627 | "lodash.isnumber": "^3.0.3", 2628 | "lodash.isplainobject": "^4.0.6", 2629 | "lodash.isstring": "^4.0.1", 2630 | "lodash.once": "^4.0.0", 2631 | "ms": "^2.1.1", 2632 | "semver": "^5.6.0" 2633 | } 2634 | }, 2635 | "jwa": { 2636 | "version": "1.4.1", 2637 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", 2638 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", 2639 | "requires": { 2640 | "buffer-equal-constant-time": "1.0.1", 2641 | "ecdsa-sig-formatter": "1.0.11", 2642 | "safe-buffer": "^5.0.1" 2643 | } 2644 | }, 2645 | "jwks-rsa": { 2646 | "version": "1.12.3", 2647 | "resolved": "https://registry.npmjs.org/jwks-rsa/-/jwks-rsa-1.12.3.tgz", 2648 | "integrity": "sha512-cFipFDeYYaO9FhhYJcZWX/IyZgc0+g316rcHnDpT2dNRNIE/lMOmWKKqp09TkJoYlNFzrEVODsR4GgXJMgWhnA==", 2649 | "requires": { 2650 | "@types/express-jwt": "0.0.42", 2651 | "axios": "^0.21.1", 2652 | "debug": "^4.1.0", 2653 | "http-proxy-agent": "^4.0.1", 2654 | "https-proxy-agent": "^5.0.0", 2655 | "jsonwebtoken": "^8.5.1", 2656 | "limiter": "^1.1.5", 2657 | "lru-memoizer": "^2.1.2", 2658 | "ms": "^2.1.2", 2659 | "proxy-from-env": "^1.1.0" 2660 | } 2661 | }, 2662 | "jws": { 2663 | "version": "3.2.2", 2664 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", 2665 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", 2666 | "requires": { 2667 | "jwa": "^1.4.1", 2668 | "safe-buffer": "^5.0.1" 2669 | } 2670 | }, 2671 | "kuler": { 2672 | "version": "2.0.0", 2673 | "resolved": "https://registry.npmjs.org/kuler/-/kuler-2.0.0.tgz", 2674 | "integrity": "sha512-Xq9nH7KlWZmXAtodXDDRE7vs6DU1gTU8zYDHDiWLSip45Egwq3plLHzPn27NgvzL2r1LMPC1vdqh98sQxtqj4A==", 2675 | "dev": true 2676 | }, 2677 | "lambda-local": { 2678 | "version": "1.7.4", 2679 | "resolved": "https://registry.npmjs.org/lambda-local/-/lambda-local-1.7.4.tgz", 2680 | "integrity": "sha512-uLrFPGj2//glOgJGLZn8hNTNlhU+eGx0WFRLZxIoC39nfjLRZ1fncHcPK2t5gA2GcvgtGUT2dnw60M8vJAOIkQ==", 2681 | "dev": true, 2682 | "requires": { 2683 | "aws-sdk": "^2.689.0", 2684 | "commander": "^6.1.0", 2685 | "dotenv": "^8.2.0", 2686 | "winston": "^3.2.1" 2687 | }, 2688 | "dependencies": { 2689 | "dotenv": { 2690 | "version": "8.6.0", 2691 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.6.0.tgz", 2692 | "integrity": "sha512-IrPdXQsk2BbzvCBGBOTmmSH5SodmqZNt4ERAZDmW4CT+tL8VtvinqywuANaFu4bOMWki16nqf0e4oC0QIaDr/g==", 2693 | "dev": true 2694 | } 2695 | } 2696 | }, 2697 | "levn": { 2698 | "version": "0.3.0", 2699 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 2700 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 2701 | "peer": true, 2702 | "requires": { 2703 | "prelude-ls": "~1.1.2", 2704 | "type-check": "~0.3.2" 2705 | } 2706 | }, 2707 | "limiter": { 2708 | "version": "1.1.5", 2709 | "resolved": "https://registry.npmjs.org/limiter/-/limiter-1.1.5.tgz", 2710 | "integrity": "sha512-FWWMIEOxz3GwUI4Ts/IvgVy6LPvoMPgjMdQ185nN6psJyBJ4yOpzqm695/h5umdLJg2vW3GR5iG11MAkR2AzJA==" 2711 | }, 2712 | "lodash.clonedeep": { 2713 | "version": "4.5.0", 2714 | "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", 2715 | "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=" 2716 | }, 2717 | "lodash.get": { 2718 | "version": "4.4.2", 2719 | "resolved": "https://registry.npmjs.org/lodash.get/-/lodash.get-4.4.2.tgz", 2720 | "integrity": "sha1-LRd/ZS+jHpObRDjVNBSZ36OCXpk=" 2721 | }, 2722 | "lodash.includes": { 2723 | "version": "4.3.0", 2724 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", 2725 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8=" 2726 | }, 2727 | "lodash.isboolean": { 2728 | "version": "3.0.3", 2729 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", 2730 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY=" 2731 | }, 2732 | "lodash.isinteger": { 2733 | "version": "4.0.4", 2734 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", 2735 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M=" 2736 | }, 2737 | "lodash.isnumber": { 2738 | "version": "3.0.3", 2739 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", 2740 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w=" 2741 | }, 2742 | "lodash.isplainobject": { 2743 | "version": "4.0.6", 2744 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 2745 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs=" 2746 | }, 2747 | "lodash.isstring": { 2748 | "version": "4.0.1", 2749 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", 2750 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE=" 2751 | }, 2752 | "lodash.once": { 2753 | "version": "4.1.1", 2754 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 2755 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=" 2756 | }, 2757 | "logform": { 2758 | "version": "2.2.0", 2759 | "resolved": "https://registry.npmjs.org/logform/-/logform-2.2.0.tgz", 2760 | "integrity": "sha512-N0qPlqfypFx7UHNn4B3lzS/b0uLqt2hmuoa+PpuXNYgozdJYAyauF5Ky0BWVjrxDlMWiT3qN4zPq3vVAfZy7Yg==", 2761 | "dev": true, 2762 | "requires": { 2763 | "colors": "^1.2.1", 2764 | "fast-safe-stringify": "^2.0.4", 2765 | "fecha": "^4.2.0", 2766 | "ms": "^2.1.1", 2767 | "triple-beam": "^1.3.0" 2768 | } 2769 | }, 2770 | "lower-case": { 2771 | "version": "1.1.4", 2772 | "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-1.1.4.tgz", 2773 | "integrity": "sha1-miyr0bno4K6ZOkv31YdcOcQujqw=" 2774 | }, 2775 | "lower-case-first": { 2776 | "version": "1.0.2", 2777 | "resolved": "https://registry.npmjs.org/lower-case-first/-/lower-case-first-1.0.2.tgz", 2778 | "integrity": "sha1-5dp8JvKacHO+AtUrrJmA5ZIq36E=", 2779 | "requires": { 2780 | "lower-case": "^1.1.2" 2781 | } 2782 | }, 2783 | "lru-cache": { 2784 | "version": "4.0.2", 2785 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.0.2.tgz", 2786 | "integrity": "sha1-HRdnnAac2l0ECZGgnbwsDbN35V4=", 2787 | "requires": { 2788 | "pseudomap": "^1.0.1", 2789 | "yallist": "^2.0.0" 2790 | } 2791 | }, 2792 | "lru-memoizer": { 2793 | "version": "2.1.4", 2794 | "resolved": "https://registry.npmjs.org/lru-memoizer/-/lru-memoizer-2.1.4.tgz", 2795 | "integrity": "sha512-IXAq50s4qwrOBrXJklY+KhgZF+5y98PDaNo0gi/v2KQBFLyWr+JyFvijZXkGKjQj/h9c0OwoE+JZbwUXce76hQ==", 2796 | "requires": { 2797 | "lodash.clonedeep": "^4.5.0", 2798 | "lru-cache": "~4.0.0" 2799 | } 2800 | }, 2801 | "methods": { 2802 | "version": "1.1.2", 2803 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 2804 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 2805 | }, 2806 | "mime": { 2807 | "version": "2.5.2", 2808 | "resolved": "https://registry.npmjs.org/mime/-/mime-2.5.2.tgz", 2809 | "integrity": "sha512-tqkh47FzKeCPD2PUiPB6pkbMzsCasjxAfC62/Wap5qrUWcb+sFasXUC5I3gYM5iBM8v/Qpn4UK0x+j0iHyFPDg==" 2810 | }, 2811 | "mime-db": { 2812 | "version": "1.50.0", 2813 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.50.0.tgz", 2814 | "integrity": "sha512-9tMZCDlYHqeERXEHO9f/hKfNXhre5dK2eE/krIvUjZbS2KPcqGDfNShIWS1uW9XOTKQKqK6qbeOci18rbfW77A==" 2815 | }, 2816 | "mime-types": { 2817 | "version": "2.1.33", 2818 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.33.tgz", 2819 | "integrity": "sha512-plLElXp7pRDd0bNZHw+nMd52vRYjLwQjygaNg7ddJ2uJtTlmnTCjWuPKxVu6//AdaRuME84SvLW91sIkBqGT0g==", 2820 | "requires": { 2821 | "mime-db": "1.50.0" 2822 | } 2823 | }, 2824 | "ms": { 2825 | "version": "2.1.3", 2826 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2827 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 2828 | }, 2829 | "netmask": { 2830 | "version": "2.0.2", 2831 | "resolved": "https://registry.npmjs.org/netmask/-/netmask-2.0.2.tgz", 2832 | "integrity": "sha512-dBpDMdxv9Irdq66304OLfEmQ9tbNRFnFTuZiLo+bD+r332bBmMJ8GBLXklIXXgxd3+v9+KUnZaUR5PJMa75Gsg==", 2833 | "peer": true 2834 | }, 2835 | "object-inspect": { 2836 | "version": "1.11.0", 2837 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.11.0.tgz", 2838 | "integrity": "sha512-jp7ikS6Sd3GxQfZJPyH3cjcbJF6GZPClgdV+EFygjFLQ5FmW/dRUnTd9PQ9k0JhoNDabWFbpF1yCdSWCC6gexg==" 2839 | }, 2840 | "one-time": { 2841 | "version": "1.0.0", 2842 | "resolved": "https://registry.npmjs.org/one-time/-/one-time-1.0.0.tgz", 2843 | "integrity": "sha512-5DXOiRKwuSEcQ/l0kGCF6Q3jcADFv5tSmRaJck/OqkVFcOzutB134KRSfF0xDrL39MNnqxbHBbUUcjZIhTgb2g==", 2844 | "dev": true, 2845 | "requires": { 2846 | "fn.name": "1.x.x" 2847 | } 2848 | }, 2849 | "optionator": { 2850 | "version": "0.8.3", 2851 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", 2852 | "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", 2853 | "peer": true, 2854 | "requires": { 2855 | "deep-is": "~0.1.3", 2856 | "fast-levenshtein": "~2.0.6", 2857 | "levn": "~0.3.0", 2858 | "prelude-ls": "~1.1.2", 2859 | "type-check": "~0.3.2", 2860 | "word-wrap": "~1.2.3" 2861 | } 2862 | }, 2863 | "pac-proxy-agent": { 2864 | "version": "5.0.0", 2865 | "resolved": "https://registry.npmjs.org/pac-proxy-agent/-/pac-proxy-agent-5.0.0.tgz", 2866 | "integrity": "sha512-CcFG3ZtnxO8McDigozwE3AqAw15zDvGH+OjXO4kzf7IkEKkQ4gxQ+3sdF50WmhQ4P/bVusXcqNE2S3XrNURwzQ==", 2867 | "peer": true, 2868 | "requires": { 2869 | "@tootallnate/once": "1", 2870 | "agent-base": "6", 2871 | "debug": "4", 2872 | "get-uri": "3", 2873 | "http-proxy-agent": "^4.0.1", 2874 | "https-proxy-agent": "5", 2875 | "pac-resolver": "^5.0.0", 2876 | "raw-body": "^2.2.0", 2877 | "socks-proxy-agent": "5" 2878 | } 2879 | }, 2880 | "pac-resolver": { 2881 | "version": "5.0.0", 2882 | "resolved": "https://registry.npmjs.org/pac-resolver/-/pac-resolver-5.0.0.tgz", 2883 | "integrity": "sha512-H+/A6KitiHNNW+bxBKREk2MCGSxljfqRX76NjummWEYIat7ldVXRU3dhRIE3iXZ0nvGBk6smv3nntxKkzRL8NA==", 2884 | "peer": true, 2885 | "requires": { 2886 | "degenerator": "^3.0.1", 2887 | "ip": "^1.1.5", 2888 | "netmask": "^2.0.1" 2889 | } 2890 | }, 2891 | "param-case": { 2892 | "version": "1.1.2", 2893 | "resolved": "https://registry.npmjs.org/param-case/-/param-case-1.1.2.tgz", 2894 | "integrity": "sha1-3LCRpDwlm5Io8cNB57akTqC/l0M=", 2895 | "requires": { 2896 | "sentence-case": "^1.1.2" 2897 | } 2898 | }, 2899 | "pascal-case": { 2900 | "version": "1.1.2", 2901 | "resolved": "https://registry.npmjs.org/pascal-case/-/pascal-case-1.1.2.tgz", 2902 | "integrity": "sha1-Pl1kogBDgwp8STRMLXS0G+DJyZs=", 2903 | "requires": { 2904 | "camel-case": "^1.1.1", 2905 | "upper-case-first": "^1.1.0" 2906 | } 2907 | }, 2908 | "path-case": { 2909 | "version": "1.1.2", 2910 | "resolved": "https://registry.npmjs.org/path-case/-/path-case-1.1.2.tgz", 2911 | "integrity": "sha1-UM5roNO+090LXCqcRVNpdDRAlRQ=", 2912 | "requires": { 2913 | "sentence-case": "^1.1.2" 2914 | } 2915 | }, 2916 | "prelude-ls": { 2917 | "version": "1.1.2", 2918 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 2919 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 2920 | "peer": true 2921 | }, 2922 | "process-nextick-args": { 2923 | "version": "2.0.1", 2924 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 2925 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 2926 | "dev": true 2927 | }, 2928 | "proxy-agent": { 2929 | "version": "5.0.0", 2930 | "resolved": "https://registry.npmjs.org/proxy-agent/-/proxy-agent-5.0.0.tgz", 2931 | "integrity": "sha512-gkH7BkvLVkSfX9Dk27W6TyNOWWZWRilRfk1XxGNWOYJ2TuedAv1yFpCaU9QSBmBe716XOTNpYNOzhysyw8xn7g==", 2932 | "peer": true, 2933 | "requires": { 2934 | "agent-base": "^6.0.0", 2935 | "debug": "4", 2936 | "http-proxy-agent": "^4.0.0", 2937 | "https-proxy-agent": "^5.0.0", 2938 | "lru-cache": "^5.1.1", 2939 | "pac-proxy-agent": "^5.0.0", 2940 | "proxy-from-env": "^1.0.0", 2941 | "socks-proxy-agent": "^5.0.0" 2942 | }, 2943 | "dependencies": { 2944 | "lru-cache": { 2945 | "version": "5.1.1", 2946 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", 2947 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 2948 | "peer": true, 2949 | "requires": { 2950 | "yallist": "^3.0.2" 2951 | } 2952 | }, 2953 | "yallist": { 2954 | "version": "3.1.1", 2955 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 2956 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", 2957 | "peer": true 2958 | } 2959 | } 2960 | }, 2961 | "proxy-from-env": { 2962 | "version": "1.1.0", 2963 | "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", 2964 | "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" 2965 | }, 2966 | "pseudomap": { 2967 | "version": "1.0.2", 2968 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 2969 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" 2970 | }, 2971 | "punycode": { 2972 | "version": "1.3.2", 2973 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", 2974 | "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=", 2975 | "dev": true 2976 | }, 2977 | "qs": { 2978 | "version": "6.10.1", 2979 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.10.1.tgz", 2980 | "integrity": "sha512-M528Hph6wsSVOBiYUnGf+K/7w0hNshs/duGsNXPUCLH5XAqjEtiPGwNONLV0tBH8NoGb0mvD5JubnUTrujKDTg==", 2981 | "requires": { 2982 | "side-channel": "^1.0.4" 2983 | } 2984 | }, 2985 | "querystring": { 2986 | "version": "0.2.0", 2987 | "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", 2988 | "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=", 2989 | "dev": true 2990 | }, 2991 | "raw-body": { 2992 | "version": "2.4.1", 2993 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.1.tgz", 2994 | "integrity": "sha512-9WmIKF6mkvA0SLmA2Knm9+qj89e+j1zqgyn8aXGd7+nAduPoqgI9lO57SAZNn/Byzo5P7JhXTyg9PzaJbH73bA==", 2995 | "peer": true, 2996 | "requires": { 2997 | "bytes": "3.1.0", 2998 | "http-errors": "1.7.3", 2999 | "iconv-lite": "0.4.24", 3000 | "unpipe": "1.0.0" 3001 | } 3002 | }, 3003 | "readable-stream": { 3004 | "version": "3.6.0", 3005 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", 3006 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 3007 | "requires": { 3008 | "inherits": "^2.0.3", 3009 | "string_decoder": "^1.1.1", 3010 | "util-deprecate": "^1.0.1" 3011 | } 3012 | }, 3013 | "rest-facade": { 3014 | "version": "1.16.2", 3015 | "resolved": "https://registry.npmjs.org/rest-facade/-/rest-facade-1.16.2.tgz", 3016 | "integrity": "sha512-Vs038wYpPhdIQ7wBr2460jmyY6WXkPSKyVAYOIIbjGI8lnG/6q4fI+v/MEPRpDrNur1DRAopQU5vQ3uNm3RiKQ==", 3017 | "requires": { 3018 | "change-case": "^2.3.0", 3019 | "deepmerge": "^3.2.0", 3020 | "lodash.get": "^4.4.2", 3021 | "superagent": "^5.1.1" 3022 | }, 3023 | "dependencies": { 3024 | "lru-cache": { 3025 | "version": "6.0.0", 3026 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 3027 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 3028 | "requires": { 3029 | "yallist": "^4.0.0" 3030 | } 3031 | }, 3032 | "semver": { 3033 | "version": "7.3.5", 3034 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 3035 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 3036 | "requires": { 3037 | "lru-cache": "^6.0.0" 3038 | } 3039 | }, 3040 | "superagent": { 3041 | "version": "5.3.1", 3042 | "resolved": "https://registry.npmjs.org/superagent/-/superagent-5.3.1.tgz", 3043 | "integrity": "sha512-wjJ/MoTid2/RuGCOFtlacyGNxN9QLMgcpYLDQlWFIhhdJ93kNscFonGvrpAHSCVjRVj++DGCglocF7Aej1KHvQ==", 3044 | "requires": { 3045 | "component-emitter": "^1.3.0", 3046 | "cookiejar": "^2.1.2", 3047 | "debug": "^4.1.1", 3048 | "fast-safe-stringify": "^2.0.7", 3049 | "form-data": "^3.0.0", 3050 | "formidable": "^1.2.2", 3051 | "methods": "^1.1.2", 3052 | "mime": "^2.4.6", 3053 | "qs": "^6.9.4", 3054 | "readable-stream": "^3.6.0", 3055 | "semver": "^7.3.2" 3056 | } 3057 | }, 3058 | "yallist": { 3059 | "version": "4.0.0", 3060 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3061 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 3062 | } 3063 | } 3064 | }, 3065 | "retry": { 3066 | "version": "0.13.1", 3067 | "resolved": "https://registry.npmjs.org/retry/-/retry-0.13.1.tgz", 3068 | "integrity": "sha512-XQBQ3I8W1Cge0Seh+6gjj03LbmRFWuoszgK9ooCpwYIrhhoO80pfq4cUkU5DkknwfOfFteRwlZ56PYOGYyFWdg==" 3069 | }, 3070 | "safe-buffer": { 3071 | "version": "5.2.1", 3072 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 3073 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 3074 | }, 3075 | "safer-buffer": { 3076 | "version": "2.1.2", 3077 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 3078 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 3079 | "peer": true 3080 | }, 3081 | "sax": { 3082 | "version": "1.2.1", 3083 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.1.tgz", 3084 | "integrity": "sha1-e45lYZCyKOgaZq6nSEgNgozS03o=", 3085 | "dev": true 3086 | }, 3087 | "semver": { 3088 | "version": "5.7.1", 3089 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 3090 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 3091 | }, 3092 | "sentence-case": { 3093 | "version": "1.1.3", 3094 | "resolved": "https://registry.npmjs.org/sentence-case/-/sentence-case-1.1.3.tgz", 3095 | "integrity": "sha1-gDSq/CFFdy06vhUJqkLJ4QQtwTk=", 3096 | "requires": { 3097 | "lower-case": "^1.1.1" 3098 | } 3099 | }, 3100 | "setprototypeof": { 3101 | "version": "1.1.1", 3102 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 3103 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==", 3104 | "peer": true 3105 | }, 3106 | "side-channel": { 3107 | "version": "1.0.4", 3108 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 3109 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 3110 | "requires": { 3111 | "call-bind": "^1.0.0", 3112 | "get-intrinsic": "^1.0.2", 3113 | "object-inspect": "^1.9.0" 3114 | } 3115 | }, 3116 | "simple-swizzle": { 3117 | "version": "0.2.2", 3118 | "resolved": "https://registry.npmjs.org/simple-swizzle/-/simple-swizzle-0.2.2.tgz", 3119 | "integrity": "sha1-pNprY1/8zMoz9w0Xy5JZLeleVXo=", 3120 | "dev": true, 3121 | "requires": { 3122 | "is-arrayish": "^0.3.1" 3123 | } 3124 | }, 3125 | "smart-buffer": { 3126 | "version": "4.2.0", 3127 | "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz", 3128 | "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==", 3129 | "peer": true 3130 | }, 3131 | "snake-case": { 3132 | "version": "1.1.2", 3133 | "resolved": "https://registry.npmjs.org/snake-case/-/snake-case-1.1.2.tgz", 3134 | "integrity": "sha1-DC8l4wUVjZoY09l3BmGH/vilpmo=", 3135 | "requires": { 3136 | "sentence-case": "^1.1.2" 3137 | } 3138 | }, 3139 | "socks": { 3140 | "version": "2.6.1", 3141 | "resolved": "https://registry.npmjs.org/socks/-/socks-2.6.1.tgz", 3142 | "integrity": "sha512-kLQ9N5ucj8uIcxrDwjm0Jsqk06xdpBjGNQtpXy4Q8/QY2k+fY7nZH8CARy+hkbG+SGAovmzzuauCpBlb8FrnBA==", 3143 | "peer": true, 3144 | "requires": { 3145 | "ip": "^1.1.5", 3146 | "smart-buffer": "^4.1.0" 3147 | } 3148 | }, 3149 | "socks-proxy-agent": { 3150 | "version": "5.0.1", 3151 | "resolved": "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-5.0.1.tgz", 3152 | "integrity": "sha512-vZdmnjb9a2Tz6WEQVIurybSwElwPxMZaIc7PzqbJTrezcKNznv6giT7J7tZDZ1BojVaa1jvO/UiUdhDVB0ACoQ==", 3153 | "peer": true, 3154 | "requires": { 3155 | "agent-base": "^6.0.2", 3156 | "debug": "4", 3157 | "socks": "^2.3.3" 3158 | } 3159 | }, 3160 | "source-map": { 3161 | "version": "0.6.1", 3162 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 3163 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 3164 | "optional": true, 3165 | "peer": true 3166 | }, 3167 | "stack-trace": { 3168 | "version": "0.0.10", 3169 | "resolved": "https://registry.npmjs.org/stack-trace/-/stack-trace-0.0.10.tgz", 3170 | "integrity": "sha1-VHxws0fo0ytOEI6hoqFZ5f3eGcA=", 3171 | "dev": true 3172 | }, 3173 | "statuses": { 3174 | "version": "1.5.0", 3175 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 3176 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=", 3177 | "peer": true 3178 | }, 3179 | "string_decoder": { 3180 | "version": "1.3.0", 3181 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 3182 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 3183 | "requires": { 3184 | "safe-buffer": "~5.2.0" 3185 | } 3186 | }, 3187 | "superagent": { 3188 | "version": "6.1.0", 3189 | "resolved": "https://registry.npmjs.org/superagent/-/superagent-6.1.0.tgz", 3190 | "integrity": "sha512-OUDHEssirmplo3F+1HWKUrUjvnQuA+nZI6i/JJBdXb5eq9IyEQwPyPpqND+SSsxf6TygpBEkUjISVRN4/VOpeg==", 3191 | "peer": true, 3192 | "requires": { 3193 | "component-emitter": "^1.3.0", 3194 | "cookiejar": "^2.1.2", 3195 | "debug": "^4.1.1", 3196 | "fast-safe-stringify": "^2.0.7", 3197 | "form-data": "^3.0.0", 3198 | "formidable": "^1.2.2", 3199 | "methods": "^1.1.2", 3200 | "mime": "^2.4.6", 3201 | "qs": "^6.9.4", 3202 | "readable-stream": "^3.6.0", 3203 | "semver": "^7.3.2" 3204 | }, 3205 | "dependencies": { 3206 | "lru-cache": { 3207 | "version": "6.0.0", 3208 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 3209 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 3210 | "peer": true, 3211 | "requires": { 3212 | "yallist": "^4.0.0" 3213 | } 3214 | }, 3215 | "semver": { 3216 | "version": "7.3.5", 3217 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 3218 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 3219 | "peer": true, 3220 | "requires": { 3221 | "lru-cache": "^6.0.0" 3222 | } 3223 | }, 3224 | "yallist": { 3225 | "version": "4.0.0", 3226 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3227 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 3228 | "peer": true 3229 | } 3230 | } 3231 | }, 3232 | "superagent-proxy": { 3233 | "version": "3.0.0", 3234 | "resolved": "https://registry.npmjs.org/superagent-proxy/-/superagent-proxy-3.0.0.tgz", 3235 | "integrity": "sha512-wAlRInOeDFyd9pyonrkJspdRAxdLrcsZ6aSnS+8+nu4x1aXbz6FWSTT9M6Ibze+eG60szlL7JA8wEIV7bPWuyQ==", 3236 | "peer": true, 3237 | "requires": { 3238 | "debug": "^4.3.2", 3239 | "proxy-agent": "^5.0.0" 3240 | } 3241 | }, 3242 | "swap-case": { 3243 | "version": "1.1.2", 3244 | "resolved": "https://registry.npmjs.org/swap-case/-/swap-case-1.1.2.tgz", 3245 | "integrity": "sha1-w5IDpFhzhfrTyFCgvRvK+ggZdOM=", 3246 | "requires": { 3247 | "lower-case": "^1.1.1", 3248 | "upper-case": "^1.1.1" 3249 | } 3250 | }, 3251 | "text-hex": { 3252 | "version": "1.0.0", 3253 | "resolved": "https://registry.npmjs.org/text-hex/-/text-hex-1.0.0.tgz", 3254 | "integrity": "sha512-uuVGNWzgJ4yhRaNSiubPY7OjISw4sw4E5Uv0wbjp+OzcbmVU/rsT8ujgcXJhn9ypzsgr5vlzpPqP+MBBKcGvbg==", 3255 | "dev": true 3256 | }, 3257 | "title-case": { 3258 | "version": "1.1.2", 3259 | "resolved": "https://registry.npmjs.org/title-case/-/title-case-1.1.2.tgz", 3260 | "integrity": "sha1-+uSmrlRr+iLQg6DuqRCkDRLtT1o=", 3261 | "requires": { 3262 | "sentence-case": "^1.1.1", 3263 | "upper-case": "^1.0.3" 3264 | } 3265 | }, 3266 | "toidentifier": { 3267 | "version": "1.0.0", 3268 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 3269 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==", 3270 | "peer": true 3271 | }, 3272 | "triple-beam": { 3273 | "version": "1.3.0", 3274 | "resolved": "https://registry.npmjs.org/triple-beam/-/triple-beam-1.3.0.tgz", 3275 | "integrity": "sha512-XrHUvV5HpdLmIj4uVMxHggLbFSZYIn7HEWsqePZcI50pco+MPqJ50wMGY794X7AOOhxOBAjbkqfAbEe/QMp2Lw==", 3276 | "dev": true 3277 | }, 3278 | "tslib": { 3279 | "version": "2.3.1", 3280 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.1.tgz", 3281 | "integrity": "sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw==", 3282 | "peer": true 3283 | }, 3284 | "type-check": { 3285 | "version": "0.3.2", 3286 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 3287 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 3288 | "peer": true, 3289 | "requires": { 3290 | "prelude-ls": "~1.1.2" 3291 | } 3292 | }, 3293 | "universalify": { 3294 | "version": "0.1.2", 3295 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", 3296 | "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", 3297 | "peer": true 3298 | }, 3299 | "unpipe": { 3300 | "version": "1.0.0", 3301 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 3302 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=", 3303 | "peer": true 3304 | }, 3305 | "upper-case": { 3306 | "version": "1.1.3", 3307 | "resolved": "https://registry.npmjs.org/upper-case/-/upper-case-1.1.3.tgz", 3308 | "integrity": "sha1-9rRQHC7EzdJrp4vnIilh3ndiFZg=" 3309 | }, 3310 | "upper-case-first": { 3311 | "version": "1.1.2", 3312 | "resolved": "https://registry.npmjs.org/upper-case-first/-/upper-case-first-1.1.2.tgz", 3313 | "integrity": "sha1-XXm+3P8UQZUY/S7bCgUHybaFkRU=", 3314 | "requires": { 3315 | "upper-case": "^1.1.1" 3316 | } 3317 | }, 3318 | "url": { 3319 | "version": "0.10.3", 3320 | "resolved": "https://registry.npmjs.org/url/-/url-0.10.3.tgz", 3321 | "integrity": "sha1-Ah5NnHcF8hu/N9A861h2dAJ3TGQ=", 3322 | "dev": true, 3323 | "requires": { 3324 | "punycode": "1.3.2", 3325 | "querystring": "0.2.0" 3326 | } 3327 | }, 3328 | "util-deprecate": { 3329 | "version": "1.0.2", 3330 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3331 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 3332 | }, 3333 | "uuid": { 3334 | "version": "3.3.2", 3335 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.2.tgz", 3336 | "integrity": "sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA==", 3337 | "dev": true 3338 | }, 3339 | "vm2": { 3340 | "version": "3.9.8", 3341 | "resolved": "https://registry.npmjs.org/vm2/-/vm2-3.9.8.tgz", 3342 | "integrity": "sha512-/1PYg/BwdKzMPo8maOZ0heT7DLI0DAFTm7YQaz/Lim9oIaFZsJs3EdtalvXuBfZwczNwsYhju75NW4d6E+4q+w==", 3343 | "peer": true, 3344 | "requires": { 3345 | "acorn": "^8.7.0", 3346 | "acorn-walk": "^8.2.0" 3347 | } 3348 | }, 3349 | "winston": { 3350 | "version": "3.3.3", 3351 | "resolved": "https://registry.npmjs.org/winston/-/winston-3.3.3.tgz", 3352 | "integrity": "sha512-oEXTISQnC8VlSAKf1KYSSd7J6IWuRPQqDdo8eoRNaYKLvwSb5+79Z3Yi1lrl6KDpU6/VWaxpakDAtb1oQ4n9aw==", 3353 | "dev": true, 3354 | "requires": { 3355 | "@dabh/diagnostics": "^2.0.2", 3356 | "async": "^3.1.0", 3357 | "is-stream": "^2.0.0", 3358 | "logform": "^2.2.0", 3359 | "one-time": "^1.0.0", 3360 | "readable-stream": "^3.4.0", 3361 | "stack-trace": "0.0.x", 3362 | "triple-beam": "^1.3.0", 3363 | "winston-transport": "^4.4.0" 3364 | } 3365 | }, 3366 | "winston-transport": { 3367 | "version": "4.4.0", 3368 | "resolved": "https://registry.npmjs.org/winston-transport/-/winston-transport-4.4.0.tgz", 3369 | "integrity": "sha512-Lc7/p3GtqtqPBYYtS6KCN3c77/2QCev51DvcJKbkFPQNoj1sinkGwLGFDxkXY9J6p9+EPnYs+D90uwbnaiURTw==", 3370 | "dev": true, 3371 | "requires": { 3372 | "readable-stream": "^2.3.7", 3373 | "triple-beam": "^1.2.0" 3374 | }, 3375 | "dependencies": { 3376 | "readable-stream": { 3377 | "version": "2.3.7", 3378 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 3379 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 3380 | "dev": true, 3381 | "requires": { 3382 | "core-util-is": "~1.0.0", 3383 | "inherits": "~2.0.3", 3384 | "isarray": "~1.0.0", 3385 | "process-nextick-args": "~2.0.0", 3386 | "safe-buffer": "~5.1.1", 3387 | "string_decoder": "~1.1.1", 3388 | "util-deprecate": "~1.0.1" 3389 | } 3390 | }, 3391 | "safe-buffer": { 3392 | "version": "5.1.2", 3393 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 3394 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 3395 | "dev": true 3396 | }, 3397 | "string_decoder": { 3398 | "version": "1.1.1", 3399 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 3400 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 3401 | "dev": true, 3402 | "requires": { 3403 | "safe-buffer": "~5.1.0" 3404 | } 3405 | } 3406 | } 3407 | }, 3408 | "word-wrap": { 3409 | "version": "1.2.3", 3410 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 3411 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 3412 | "peer": true 3413 | }, 3414 | "xml2js": { 3415 | "version": "0.4.19", 3416 | "resolved": "https://registry.npmjs.org/xml2js/-/xml2js-0.4.19.tgz", 3417 | "integrity": "sha512-esZnJZJOiJR9wWKMyuvSE1y6Dq5LCuJanqhxslH2bxM6duahNZ+HMpCLhBQGZkbX6xRf8x1Y2eJlgt2q3qo49Q==", 3418 | "dev": true, 3419 | "requires": { 3420 | "sax": ">=0.6.0", 3421 | "xmlbuilder": "~9.0.1" 3422 | } 3423 | }, 3424 | "xmlbuilder": { 3425 | "version": "9.0.7", 3426 | "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-9.0.7.tgz", 3427 | "integrity": "sha1-Ey7mPS7FVlxVfiD0wi35rKaGsQ0=", 3428 | "dev": true 3429 | }, 3430 | "xregexp": { 3431 | "version": "2.0.0", 3432 | "resolved": "https://registry.npmjs.org/xregexp/-/xregexp-2.0.0.tgz", 3433 | "integrity": "sha1-UqY+VsoLhKfzpfPWGHLxJq16WUM=", 3434 | "peer": true 3435 | }, 3436 | "yallist": { 3437 | "version": "2.1.2", 3438 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 3439 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" 3440 | } 3441 | } 3442 | } 3443 | -------------------------------------------------------------------------------- /auth0-custom-auth-lambda/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "lambda-auth0-authenticator", 3 | "version": "0.1.0", 4 | "description": "An AWS Lambda function to provide a Custom Authenticator for AWS API Gateway that verifies RS* signed tokens", 5 | "main": "index.js", 6 | "scripts": { 7 | "bundle": "rm -f custom-authorizer.zip ; zip custom-authorizer.zip -r *.js *.json node_modules/" 8 | }, 9 | "author": "Jason Haines", 10 | "license": "Apache-2.0", 11 | "dependencies": { 12 | "auth0": ">=2.37.0", 13 | "bluebird": "^3.4.6", 14 | "dotenv": "^5.0.1", 15 | "jsonwebtoken": "^8.2.1", 16 | "jwks-rsa": "^1.1.1" 17 | }, 18 | "devDependencies": { 19 | "aws-sdk": "^2.2.48", 20 | "lambda-local": "^1.4.8" 21 | }, 22 | "keywords": [ 23 | "aws", 24 | "api-gateway", 25 | "auth0", 26 | "custom-authorizer", 27 | "authentication", 28 | "lambda" 29 | ] 30 | } -------------------------------------------------------------------------------- /events/event.json: -------------------------------------------------------------------------------- 1 | { 2 | "body": "{\"message\": \"hello world\"}", 3 | "resource": "/{proxy+}", 4 | "path": "/path/to/resource", 5 | "httpMethod": "POST", 6 | "isBase64Encoded": false, 7 | "queryStringParameters": { 8 | "foo": "bar" 9 | }, 10 | "pathParameters": { 11 | "proxy": "/path/to/resource" 12 | }, 13 | "stageVariables": { 14 | "baz": "qux" 15 | }, 16 | "headers": { 17 | "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8", 18 | "Accept-Encoding": "gzip, deflate, sdch", 19 | "Accept-Language": "en-US,en;q=0.8", 20 | "Cache-Control": "max-age=0", 21 | "CloudFront-Forwarded-Proto": "https", 22 | "CloudFront-Is-Desktop-Viewer": "true", 23 | "CloudFront-Is-Mobile-Viewer": "false", 24 | "CloudFront-Is-SmartTV-Viewer": "false", 25 | "CloudFront-Is-Tablet-Viewer": "false", 26 | "CloudFront-Viewer-Country": "US", 27 | "Host": "1234567890.execute-api.us-east-1.amazonaws.com", 28 | "Upgrade-Insecure-Requests": "1", 29 | "User-Agent": "Custom User Agent String", 30 | "Via": "1.1 08f323deadbeefa7af34d5feb414ce27.cloudfront.net (CloudFront)", 31 | "X-Amz-Cf-Id": "cDehVQoZnx43VYQb9j2-nvCh-9z396Uhbp027Y2JvkCPNLmGJHqlaA==", 32 | "X-Forwarded-For": "127.0.0.1, 127.0.0.2", 33 | "X-Forwarded-Port": "443", 34 | "X-Forwarded-Proto": "https" 35 | }, 36 | "requestContext": { 37 | "accountId": "123456789012", 38 | "resourceId": "123456", 39 | "stage": "prod", 40 | "requestId": "c6af9ac6-7b61-11e6-9a41-93e8deadbeef", 41 | "requestTime": "09/Apr/2015:12:34:56 +0000", 42 | "requestTimeEpoch": 1428582896000, 43 | "identity": { 44 | "cognitoIdentityPoolId": null, 45 | "accountId": null, 46 | "cognitoIdentityId": null, 47 | "caller": null, 48 | "accessKey": null, 49 | "sourceIp": "127.0.0.1", 50 | "cognitoAuthenticationType": null, 51 | "cognitoAuthenticationProvider": null, 52 | "userArn": null, 53 | "userAgent": "Custom User Agent String", 54 | "user": null 55 | }, 56 | "path": "/prod/path/to/resource", 57 | "resourcePath": "/{proxy+}", 58 | "httpMethod": "POST", 59 | "apiId": "1234567890", 60 | "protocol": "HTTP/1.1" 61 | } 62 | } 63 | -------------------------------------------------------------------------------- /template-all-auth.yaml: -------------------------------------------------------------------------------- 1 | AWSTemplateFormatVersion: '2010-09-09' 2 | Transform: AWS::Serverless-2016-10-31 3 | Description: HTTP API 4 | 5 | Parameters: 6 | UserPoolId: 7 | Type: String 8 | Description: User poolID for Cognito provider 9 | Audience: 10 | Type: String 11 | Description: Client id for user pool 12 | HostedZoneId: 13 | Type: String 14 | Description: Hosted zone where record set needs to be created 15 | DomainName: 16 | Type: String 17 | Description: Custom domain name 18 | TruststoreKey: 19 | Type: String 20 | Description: Key for trust store file 21 | Default: truststore.pem 22 | 23 | Globals: 24 | Function: 25 | Timeout: 5 26 | MemorySize: 1536 27 | Runtime: java8.al2 28 | Handler: com.auth.App::handleRequest 29 | CodeUri: auth-functions 30 | 31 | Resources: 32 | TrustStoreBucket: 33 | Type: AWS::S3::Bucket 34 | Properties: 35 | VersioningConfiguration: 36 | Status: Enabled 37 | 38 | TrustedStoreCustomResourceFunction: 39 | Type: AWS::Serverless::Function 40 | Properties: 41 | FunctionName: TrustedStoreCustomResourceFunction 42 | Handler: com.auth.TrustedStoreCustomResourceHandler::handleRequest 43 | Timeout: 120 44 | Policies: 45 | - S3CrudPolicy: 46 | BucketName: !Ref TrustStoreBucket 47 | 48 | PrivateCA: 49 | Type: AWS::ACMPCA::CertificateAuthority 50 | Properties: 51 | KeyAlgorithm: RSA_2048 52 | SigningAlgorithm: SHA256WITHRSA 53 | Subject: 54 | CommonName: !Sub "${AWS::StackName}-rootca" 55 | Type: ROOT 56 | 57 | PrivateCACertificate: 58 | Type: AWS::ACMPCA::Certificate 59 | Properties: 60 | CertificateAuthorityArn: !Ref PrivateCA 61 | CertificateSigningRequest: !GetAtt PrivateCA.CertificateSigningRequest 62 | SigningAlgorithm: SHA256WITHRSA 63 | TemplateArn: 'arn:aws:acm-pca:::template/RootCACertificate/V1' 64 | Validity: 65 | Type: YEARS 66 | Value: 10 67 | 68 | PrivateCAActivation: 69 | Type: AWS::ACMPCA::CertificateAuthorityActivation 70 | Properties: 71 | Certificate: !GetAtt PrivateCACertificate.Certificate 72 | CertificateAuthorityArn: !Ref PrivateCA 73 | Status: ACTIVE 74 | 75 | MtlsCA: 76 | Type: AWS::ACMPCA::CertificateAuthority 77 | Properties: 78 | Type: SUBORDINATE 79 | KeyAlgorithm: RSA_2048 80 | SigningAlgorithm: SHA256WITHRSA 81 | Subject: 82 | CommonName: !Sub "${AWS::StackName}-mtlsca" 83 | 84 | MtlsCertificate: 85 | DependsOn: PrivateCAActivation 86 | Type: AWS::ACMPCA::Certificate 87 | Properties: 88 | CertificateAuthorityArn: !Ref PrivateCA 89 | CertificateSigningRequest: !GetAtt MtlsCA.CertificateSigningRequest 90 | SigningAlgorithm: SHA256WITHRSA 91 | TemplateArn: 'arn:aws:acm-pca:::template/SubordinateCACertificate_PathLen3/V1' 92 | Validity: 93 | Type: YEARS 94 | Value: 3 95 | 96 | MtlsActivation: 97 | Type: AWS::ACMPCA::CertificateAuthorityActivation 98 | Properties: 99 | CertificateAuthorityArn: !Ref MtlsCA 100 | Certificate: !GetAtt MtlsCertificate.Certificate 101 | CertificateChain: !GetAtt PrivateCAActivation.CompleteCertificateChain 102 | Status: ACTIVE 103 | 104 | ClientOneCert: 105 | DependsOn: MtlsActivation 106 | Type: AWS::CertificateManager::Certificate 107 | Properties: 108 | CertificateAuthorityArn: !Ref MtlsCA 109 | CertificateTransparencyLoggingPreference: ENABLED 110 | DomainName: !Ref DomainName 111 | Tags: 112 | - Key: Name 113 | Value: ClientOneCert 114 | 115 | CustomLambdaAuth: 116 | Type: AWS::Serverless::Function 117 | Properties: 118 | FunctionName: CustomLambdaAuth 119 | Handler: com.auth.CustomLambdaAuth::handleRequest 120 | 121 | LambdaAuthInvokeRole: 122 | Type: AWS::IAM::Role 123 | Properties: 124 | AssumeRolePolicyDocument: 125 | Version: '2012-10-17' 126 | Statement: 127 | - Effect: Allow 128 | Principal: 129 | Service: 130 | - apigateway.amazonaws.com 131 | Action: 132 | - sts:AssumeRole 133 | Path: "/service-role/" 134 | Policies: 135 | - PolicyName: InvokeAuthLambda 136 | PolicyDocument: 137 | Version: '2012-10-17' 138 | Statement: 139 | - Effect: Allow 140 | Action: 141 | - lambda:InvokeFunction 142 | Resource: !GetAtt CustomLambdaAuth.Arn 143 | 144 | TrustedStoreCustomResource: 145 | Type: Custom::TrustedStore 146 | Properties: 147 | ServiceToken: !GetAtt TrustedStoreCustomResourceFunction.Arn 148 | TrustStoreBucket: !Ref TrustStoreBucket 149 | TrustStoreKey: !Ref TruststoreKey 150 | Certs: 151 | - !GetAtt MtlsCertificate.Certificate 152 | - !GetAtt PrivateCACertificate.Certificate 153 | 154 | CustomDomainCert: 155 | Type: AWS::CertificateManager::Certificate 156 | Properties: 157 | CertificateTransparencyLoggingPreference: ENABLED 158 | DomainName: !Ref DomainName 159 | DomainValidationOptions: 160 | - DomainName: !Ref DomainName 161 | HostedZoneId: !Ref HostedZoneId 162 | ValidationMethod: DNS 163 | 164 | SampleHttpApi: 165 | Type: AWS::Serverless::HttpApi 166 | DependsOn: TrustedStoreCustomResource 167 | Properties: 168 | Auth: 169 | Authorizers: 170 | GeneralAuth: 171 | AuthorizationScopes: 172 | - email 173 | IdentitySource: "$request.header.Authorization" 174 | JwtConfiguration: 175 | issuer: !Sub https://cognito-idp.${AWS::Region}.amazonaws.com/${UserPoolId} 176 | audience: 177 | - !Ref Audience 178 | CustomLambdaAuthorizer: 179 | AuthorizerPayloadFormatVersion: 2.0 180 | EnableSimpleResponses: True 181 | FunctionInvokeRole: !GetAtt LambdaAuthInvokeRole.Arn 182 | FunctionArn: !GetAtt CustomLambdaAuth.Arn 183 | Identity: 184 | Headers: 185 | - Authorization 186 | ReauthorizeEvery: 5 187 | CorsConfiguration: 188 | AllowMethods: 189 | - GET 190 | AllowOrigins: 191 | - http://localhost:8080 192 | Domain: 193 | CertificateArn: !Ref CustomDomainCert 194 | DomainName: !Ref DomainName 195 | EndpointConfiguration: REGIONAL 196 | SecurityPolicy: TLS_1_2 197 | MutualTlsAuthentication: 198 | TruststoreUri: !GetAtt TrustedStoreCustomResource.TrustStoreUri 199 | TruststoreVersion: !GetAtt TrustedStoreCustomResource.ObjectVersion 200 | Route53: 201 | EvaluateTargetHealth: False 202 | HostedZoneId: !Ref HostedZoneId 203 | # https://github.com/aws/serverless-application-model/issues/1788 204 | #DisableExecuteApiEndpoint: true 205 | 206 | # Open route 207 | LambdaFunction: 208 | Type: AWS::Serverless::Function 209 | Properties: 210 | Events: 211 | RootGet: 212 | Type: HttpApi 213 | Properties: 214 | Path: / 215 | Method: get 216 | ApiId: !Ref SampleHttpApi 217 | 218 | # Basic auth 219 | SimpleAuthLambdaFunction: 220 | Type: AWS::Serverless::Function 221 | Properties: 222 | Events: 223 | RootGet: 224 | Type: HttpApi 225 | Properties: 226 | Auth: 227 | Authorizer: GeneralAuth 228 | Path: "/simple" 229 | Method: get 230 | ApiId: !Ref SampleHttpApi 231 | 232 | CustomLambdaAuthFunction: 233 | Type: AWS::Serverless::Function 234 | Properties: 235 | Events: 236 | RootGet: 237 | Type: HttpApi 238 | Properties: 239 | Auth: 240 | Authorizer: CustomLambdaAuthorizer 241 | Path: /custom 242 | Method: get 243 | ApiId: !Ref SampleHttpApi 244 | 245 | # Route for admins only: requires custom token (see cognito example) 246 | AdminLambdaFunction: 247 | Type: AWS::Serverless::Function 248 | Properties: 249 | Events: 250 | DosGet: 251 | Type: HttpApi 252 | Properties: 253 | Auth: 254 | Authorizer: GeneralAuth 255 | AuthorizationScopes: 256 | - Fn::Sub: 257 | Admins-${Audience} 258 | Path: /admin 259 | Method: get 260 | ApiId: !Ref SampleHttpApi 261 | 262 | # Route for SU only: requires custom token (see cognito example) 263 | SULambdaFunction: 264 | Type: AWS::Serverless::Function 265 | Properties: 266 | Events: 267 | DosGet: 268 | Type: HttpApi 269 | Properties: 270 | Auth: 271 | Authorizer: GeneralAuth 272 | AuthorizationScopes: 273 | - Fn::Sub: 274 | SU-${Audience} 275 | Path: /su 276 | Method: get 277 | ApiId: !Ref SampleHttpApi 278 | 279 | # Route for Admins and SU only: requires custom token (see cognito example) 280 | BothLambdaFunction: 281 | Type: AWS::Serverless::Function 282 | Properties: 283 | Events: 284 | DosGet: 285 | Type: HttpApi 286 | Properties: 287 | Auth: 288 | Authorizer: GeneralAuth 289 | AuthorizationScopes: 290 | - Fn::Sub: 291 | Admins-${Audience} 292 | - Fn::Sub: 293 | SU-${Audience} 294 | Path: /both 295 | Method: get 296 | ApiId: !Ref SampleHttpApi 297 | 298 | # $default route used as catchall 299 | CatchAllLambdaFunction: 300 | Type: AWS::Serverless::Function 301 | Properties: 302 | Events: 303 | RootGet: 304 | Type: HttpApi 305 | Properties: 306 | ApiId: !Ref SampleHttpApi 307 | 308 | Outputs: 309 | ApiEndpoint: 310 | Description: "HTTP API endpoint URL" 311 | Value: !Sub "https://${SampleHttpApi}.execute-api.${AWS::Region}.amazonaws.com" 312 | ClientOneCertArn: 313 | Description: "Arn for client certificate" 314 | Value: !Ref ClientOneCert 315 | 316 | -------------------------------------------------------------------------------- /template-auth0.yaml: -------------------------------------------------------------------------------- 1 | AWSTemplateFormatVersion: '2010-09-09' 2 | Transform: AWS::Serverless-2016-10-31 3 | Description: HTTP API 4 | 5 | Parameters: 6 | IssuerUrl: 7 | Type: String 8 | Description: Issuer URL for your Auth0 Api 9 | APIAudience: 10 | Type: String 11 | Description: The identifier value of the API you created in the Auth0 API 12 | 13 | Globals: 14 | Function: 15 | Timeout: 5 16 | MemorySize: 1536 17 | Runtime: java8.al2 18 | Handler: com.auth.App::handleRequest 19 | CodeUri: auth-functions 20 | 21 | Resources: 22 | 23 | CustomLambdaAuth: 24 | Type: AWS::Serverless::Function 25 | Properties: 26 | FunctionName: CustomLambdaAuth 27 | Handler: com.auth.CustomLambdaAuth::handleRequest 28 | 29 | Auth0CustomLambdaAuth: 30 | Type: AWS::Serverless::Function 31 | Properties: 32 | FunctionName: Auth0CustomLambdaAuth 33 | Handler: index.handler 34 | Runtime: nodejs12.x 35 | CodeUri: auth0-custom-auth-lambda 36 | Timeout: 15 37 | Environment: 38 | Variables: 39 | JWKS_URI: !Sub "${IssuerUrl}.well-known/jwks.json" 40 | TOKEN_ISSUER: !Ref IssuerUrl 41 | AUDIENCE: !Ref APIAudience 42 | 43 | LambdaAuthInvokeRole: 44 | Type: AWS::IAM::Role 45 | Properties: 46 | AssumeRolePolicyDocument: 47 | Version: '2012-10-17' 48 | Statement: 49 | - Effect: Allow 50 | Principal: 51 | Service: 52 | - apigateway.amazonaws.com 53 | Action: 54 | - sts:AssumeRole 55 | Path: "/service-role/" 56 | Policies: 57 | - PolicyName: InvokeAuthLambda 58 | PolicyDocument: 59 | Version: '2012-10-17' 60 | Statement: 61 | - Effect: Allow 62 | Action: 63 | - lambda:InvokeFunction 64 | Resource: !GetAtt CustomLambdaAuth.Arn 65 | - PolicyName: Auth0CustomLambdaInvoke 66 | PolicyDocument: 67 | Version: '2012-10-17' 68 | Statement: 69 | - Effect: Allow 70 | Action: 71 | - lambda:InvokeFunction 72 | Resource: !GetAtt Auth0CustomLambdaAuth.Arn 73 | 74 | 75 | SampleRestApi: 76 | Type: AWS::Serverless::Api 77 | Properties: 78 | StageName: prod 79 | Auth: 80 | Authorizers: 81 | Auth0CustomAuthorizer: 82 | FunctionInvokeRole: !GetAtt LambdaAuthInvokeRole.Arn 83 | FunctionArn: !GetAtt Auth0CustomLambdaAuth.Arn 84 | IdentitySource: "$request.header.Authorization" 85 | FunctionPayloadType: TOKEN 86 | 87 | SampleHttpApi: 88 | Type: AWS::Serverless::HttpApi 89 | Properties: 90 | Auth: 91 | Authorizers: 92 | GeneralAuth: 93 | AuthorizationScopes: 94 | - email 95 | IdentitySource: "$request.header.Authorization" 96 | JwtConfiguration: 97 | issuer: !Ref IssuerUrl 98 | audience: 99 | - !Ref APIAudience 100 | CustomLambdaAuthorizer: 101 | AuthorizerPayloadFormatVersion: 2.0 102 | EnableSimpleResponses: True 103 | FunctionInvokeRole: !GetAtt LambdaAuthInvokeRole.Arn 104 | FunctionArn: !GetAtt CustomLambdaAuth.Arn 105 | Identity: 106 | Headers: 107 | - Authorization 108 | ReauthorizeEvery: 5 109 | CorsConfiguration: 110 | AllowMethods: 111 | - GET 112 | AllowOrigins: 113 | - http://localhost:3000 114 | 115 | # Open route 116 | LambdaFunction: 117 | Type: AWS::Serverless::Function 118 | Properties: 119 | Events: 120 | RootGet: 121 | Type: HttpApi 122 | Properties: 123 | Path: / 124 | Method: get 125 | ApiId: !Ref SampleHttpApi 126 | RestRootGet: 127 | Type: Api 128 | Properties: 129 | Path: / 130 | Method: get 131 | RestApiId: !Ref SampleRestApi 132 | 133 | # Auth0 auth 134 | SimpleAuthLambdaFunction: 135 | Type: AWS::Serverless::Function 136 | Properties: 137 | Events: 138 | Auth0Get: 139 | Type: HttpApi 140 | Properties: 141 | Auth: 142 | Authorizer: GeneralAuth 143 | Path: "/auth0" 144 | Method: get 145 | ApiId: !Ref SampleHttpApi 146 | RestAuth0Get: 147 | Type: Api 148 | Properties: 149 | Auth: 150 | Authorizer: Auth0CustomAuthorizer 151 | Path: "/auth0" 152 | Method: get 153 | RestApiId: !Ref SampleRestApi 154 | 155 | CustomLambdaAuthFunction: 156 | Type: AWS::Serverless::Function 157 | Properties: 158 | Events: 159 | CustomAuth: 160 | Type: HttpApi 161 | Properties: 162 | Auth: 163 | Authorizer: CustomLambdaAuthorizer 164 | Path: /custom 165 | Method: get 166 | ApiId: !Ref SampleHttpApi 167 | 168 | # $default route used as catchall 169 | CatchAllLambdaFunction: 170 | Type: AWS::Serverless::Function 171 | Properties: 172 | Events: 173 | CatchAll: 174 | Type: HttpApi 175 | Properties: 176 | ApiId: !Ref SampleHttpApi 177 | RestCatchAll: 178 | Type: Api 179 | Properties: 180 | Path: /{all+} 181 | Method: get 182 | RestApiId: !Ref SampleRestApi 183 | 184 | 185 | Outputs: 186 | ApiEndpoint: 187 | Description: "HTTP API endpoint URL" 188 | Value: !Sub "https://${SampleHttpApi}.execute-api.${AWS::Region}.amazonaws.com" 189 | RestApiEndpoint: 190 | Description: "Rest API endpoint URL" 191 | Value: !Sub "https://${SampleRestApi}.execute-api.${AWS::Region}.amazonaws.com/prod" 192 | -------------------------------------------------------------------------------- /template-cognito.yaml: -------------------------------------------------------------------------------- 1 | AWSTemplateFormatVersion: '2010-09-09' 2 | Transform: AWS::Serverless-2016-10-31 3 | Description: Cognito user pool with hosted domain 4 | 5 | Parameters: 6 | AppName: 7 | Type: String 8 | Description: Name of the application 9 | ClientDomains: 10 | Type: CommaDelimitedList 11 | Description: Array of domains allowed to use this UserPool 12 | AdminEmail: 13 | Type: String 14 | Description: Email address for administrator 15 | AddGroupsToScopes: 16 | Type: String 17 | AllowedValues: 18 | - 'true' 19 | - 'false' 20 | Default: 'false' 21 | 22 | Conditions: 23 | ScopeGroups: 24 | !Equals [!Ref AddGroupsToScopes, 'true'] 25 | 26 | Resources: 27 | UserPool: 28 | Type: AWS::Cognito::UserPool 29 | Properties: 30 | UserPoolName: !Sub ${AppName}-UserPool 31 | Policies: 32 | PasswordPolicy: 33 | MinimumLength: 8 34 | AutoVerifiedAttributes: 35 | - email 36 | UsernameAttributes: 37 | - email 38 | Schema: 39 | - AttributeDataType: String 40 | Name: email 41 | Required: false 42 | 43 | UserPoolClient: 44 | Type: AWS::Cognito::UserPoolClient 45 | Properties: 46 | UserPoolId: !Ref UserPool 47 | ClientName: !Sub ${AppName}-UserPoolClient 48 | GenerateSecret: false # set to false for web clients 49 | SupportedIdentityProviders: 50 | - COGNITO 51 | CallbackURLs: !Ref ClientDomains 52 | LogoutURLs: !Ref ClientDomains 53 | AllowedOAuthFlowsUserPoolClient: true 54 | AllowedOAuthFlows: 55 | - code 56 | - implicit #for testing with postman 57 | AllowedOAuthScopes: 58 | - email 59 | - openid 60 | - profile 61 | 62 | UserPoolDomain: 63 | Type: AWS::Cognito::UserPoolDomain 64 | Properties: 65 | Domain: !Sub ${AppName}-${AWS::AccountId} 66 | UserPoolId: !Ref UserPool 67 | 68 | AdminUserGroup: 69 | Type: AWS::Cognito::UserPoolGroup 70 | Properties: 71 | GroupName: Admins 72 | Description: Admin user group 73 | Precedence: 0 74 | UserPoolId: !Ref UserPool 75 | 76 | AdminUser: 77 | Type: AWS::Cognito::UserPoolUser 78 | Properties: 79 | Username: !Ref AdminEmail 80 | DesiredDeliveryMediums: 81 | - EMAIL 82 | ForceAliasCreation: true 83 | UserAttributes: 84 | - Name: email 85 | Value: !Ref AdminEmail 86 | UserPoolId: !Ref UserPool 87 | 88 | TriggerFunction: 89 | Type: AWS::Serverless::Function 90 | Condition: ScopeGroups 91 | Properties: 92 | Timeout: 5 93 | Handler: app.lambdaHandler 94 | Runtime: nodejs12.x 95 | CodeUri: auth-functions/src/ 96 | Events: 97 | CognitoTrigger: 98 | Type: Cognito 99 | Properties: 100 | Trigger: PreTokenGeneration 101 | UserPool: !Ref UserPool 102 | 103 | AddUserToGroup: 104 | Type: AWS::Cognito::UserPoolUserToGroupAttachment 105 | Properties: 106 | GroupName: !Ref AdminUserGroup 107 | Username: !Ref AdminUser 108 | UserPoolId: !Ref UserPool 109 | 110 | Outputs: 111 | UserPoolId: 112 | Description: "User pool ID" 113 | Value: !Ref UserPool 114 | Export: 115 | Name: !Sub ${AppName}:UserPoolId 116 | 117 | UserPoolClientId: 118 | Description: "Application client ID" 119 | Value: !Ref UserPoolClient 120 | Export: 121 | Name: !Sub ${AppName}:UserPoolClientId 122 | 123 | AuthUrl: 124 | Description: "URL used for authentication" 125 | Value: !Sub https://${UserPoolDomain}.auth.${AWS::Region}.amazoncognito.com 126 | Export: 127 | Name: !Sub ${AppName}:AuthUrl -------------------------------------------------------------------------------- /template.yaml: -------------------------------------------------------------------------------- 1 | AWSTemplateFormatVersion: '2010-09-09' 2 | Transform: AWS::Serverless-2016-10-31 3 | Description: HTTP API 4 | 5 | Parameters: 6 | HostedZoneId: 7 | Type: String 8 | Description: Hosted zone where record set needs to be created 9 | DomainName: 10 | Type: String 11 | Description: Custom domain name 12 | TruststoreKey: 13 | Type: String 14 | Description: Key for trust store file 15 | Default: truststore.pem 16 | 17 | Globals: 18 | Function: 19 | Timeout: 5 20 | MemorySize: 1536 21 | Runtime: java8.al2 22 | Handler: com.auth.App::handleRequest 23 | CodeUri: auth-functions 24 | 25 | Resources: 26 | PrivateCA: 27 | Type: AWS::ACMPCA::CertificateAuthority 28 | Properties: 29 | KeyAlgorithm: RSA_2048 30 | SigningAlgorithm: SHA256WITHRSA 31 | Subject: 32 | CommonName: !Sub "${AWS::StackName}-rootca" 33 | Type: ROOT 34 | 35 | PrivateCACertificate: 36 | Type: AWS::ACMPCA::Certificate 37 | Properties: 38 | CertificateAuthorityArn: !Ref PrivateCA 39 | CertificateSigningRequest: !GetAtt PrivateCA.CertificateSigningRequest 40 | SigningAlgorithm: SHA256WITHRSA 41 | TemplateArn: 'arn:aws:acm-pca:::template/RootCACertificate/V1' 42 | Validity: 43 | Type: YEARS 44 | Value: 10 45 | 46 | PrivateCAActivation: 47 | Type: AWS::ACMPCA::CertificateAuthorityActivation 48 | Properties: 49 | Certificate: !GetAtt PrivateCACertificate.Certificate 50 | CertificateAuthorityArn: !Ref PrivateCA 51 | Status: ACTIVE 52 | 53 | MtlsCA: 54 | Type: AWS::ACMPCA::CertificateAuthority 55 | Properties: 56 | Type: SUBORDINATE 57 | KeyAlgorithm: RSA_2048 58 | SigningAlgorithm: SHA256WITHRSA 59 | Subject: 60 | CommonName: !Sub "${AWS::StackName}-mtlsca" 61 | 62 | MtlsCertificate: 63 | DependsOn: PrivateCAActivation 64 | Type: AWS::ACMPCA::Certificate 65 | Properties: 66 | CertificateAuthorityArn: !Ref PrivateCA 67 | CertificateSigningRequest: !GetAtt MtlsCA.CertificateSigningRequest 68 | SigningAlgorithm: SHA256WITHRSA 69 | TemplateArn: 'arn:aws:acm-pca:::template/SubordinateCACertificate_PathLen3/V1' 70 | Validity: 71 | Type: YEARS 72 | Value: 3 73 | 74 | MtlsActivation: 75 | Type: AWS::ACMPCA::CertificateAuthorityActivation 76 | Properties: 77 | CertificateAuthorityArn: !Ref MtlsCA 78 | Certificate: !GetAtt MtlsCertificate.Certificate 79 | CertificateChain: !GetAtt PrivateCAActivation.CompleteCertificateChain 80 | Status: ACTIVE 81 | 82 | ClientOneCert: 83 | DependsOn: MtlsActivation 84 | Type: AWS::CertificateManager::Certificate 85 | Properties: 86 | CertificateAuthorityArn: !Ref MtlsCA 87 | CertificateTransparencyLoggingPreference: ENABLED 88 | DomainName: !Ref DomainName 89 | Tags: 90 | - Key: Name 91 | Value: ClientOneCert 92 | 93 | TrustStoreBucket: 94 | Type: AWS::S3::Bucket 95 | Properties: 96 | VersioningConfiguration: 97 | Status: Enabled 98 | 99 | TrustedStoreCustomResourceFunction: 100 | Type: AWS::Serverless::Function 101 | Properties: 102 | FunctionName: TrustedStoreCustomResourceFunction 103 | Handler: com.auth.TrustedStoreCustomResourceHandler::handleRequest 104 | Timeout: 120 105 | Policies: 106 | - S3CrudPolicy: 107 | BucketName: !Ref TrustStoreBucket 108 | 109 | TrustedStoreCustomResource: 110 | Type: Custom::TrustedStore 111 | Properties: 112 | ServiceToken: !GetAtt TrustedStoreCustomResourceFunction.Arn 113 | TrustStoreBucket: !Ref TrustStoreBucket 114 | TrustStoreKey: !Ref TruststoreKey 115 | Certs: 116 | - !GetAtt MtlsCertificate.Certificate 117 | - !GetAtt PrivateCACertificate.Certificate 118 | 119 | CustomDomainCert: 120 | Type: AWS::CertificateManager::Certificate 121 | Properties: 122 | CertificateTransparencyLoggingPreference: ENABLED 123 | DomainName: !Ref DomainName 124 | DomainValidationOptions: 125 | - DomainName: !Ref DomainName 126 | HostedZoneId: !Ref HostedZoneId 127 | ValidationMethod: DNS 128 | 129 | SampleHttpApi: 130 | Type: AWS::Serverless::HttpApi 131 | DependsOn: TrustedStoreCustomResource 132 | Properties: 133 | CorsConfiguration: 134 | AllowMethods: 135 | - GET 136 | AllowOrigins: 137 | - http://localhost:8080 138 | Domain: 139 | CertificateArn: !Ref CustomDomainCert 140 | DomainName: !Ref DomainName 141 | EndpointConfiguration: REGIONAL 142 | SecurityPolicy: TLS_1_2 143 | MutualTlsAuthentication: 144 | TruststoreUri: !GetAtt TrustedStoreCustomResource.TrustStoreUri 145 | TruststoreVersion: !GetAtt TrustedStoreCustomResource.ObjectVersion 146 | Route53: 147 | EvaluateTargetHealth: False 148 | HostedZoneId: !Ref HostedZoneId 149 | # https://github.com/aws/serverless-application-model/issues/1788 150 | #DisableExecuteApiEndpoint: true 151 | 152 | # Open route 153 | LambdaFunction: 154 | Type: AWS::Serverless::Function 155 | Properties: 156 | Events: 157 | RootGet: 158 | Type: HttpApi 159 | Properties: 160 | Path: / 161 | Method: get 162 | ApiId: !Ref SampleHttpApi 163 | 164 | Outputs: 165 | ApiEndpoint: 166 | Description: "HTTP API endpoint URL" 167 | Value: !Sub "https://${SampleHttpApi}.execute-api.${AWS::Region}.amazonaws.com" 168 | ClientOneCertArn: 169 | Description: "Arn for client certificate" 170 | Value: !Ref ClientOneCert 171 | 172 | --------------------------------------------------------------------------------