├── .gitignore ├── alexa ├── lambda │ ├── cdk.json │ ├── .npmignore │ ├── .gitignore │ ├── bin │ │ └── lambda.js │ ├── README.md │ ├── lib │ │ ├── functions │ │ │ └── aws-sap-alexa-scp-solo │ │ │ │ ├── rfcrequest.js │ │ │ │ ├── package.json │ │ │ │ ├── index.js │ │ │ │ └── package-lock.json │ │ ├── appConfig.json │ │ └── lambda-stack.js │ ├── test │ │ └── lambda.test.js │ ├── package.json │ └── package-lock.json └── skill.json ├── scp-odata-proxy-ui ├── odataproxyui │ ├── .npmrc │ ├── xs-app.json │ └── package.json └── manifest.yml ├── scp-odata-proxy-api ├── package-lock.json ├── manifest.yml ├── xs-security.json └── odataproxyapi │ ├── package.json │ ├── start.js │ └── package-lock.json ├── NOTICE ├── .DS_Store ├── CODE_OF_CONDUCT.md ├── CONTRIBUTING.md ├── LICENSE └── README.md /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/ 2 | local/ 3 | -------------------------------------------------------------------------------- /alexa/lambda/cdk.json: -------------------------------------------------------------------------------- 1 | { 2 | "app": "node bin/lambda.js" 3 | } 4 | -------------------------------------------------------------------------------- /scp-odata-proxy-ui/odataproxyui/.npmrc: -------------------------------------------------------------------------------- 1 | @sap:registry=https://npm.sap.com/ -------------------------------------------------------------------------------- /scp-odata-proxy-api/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "lockfileVersion": 1 3 | } 4 | -------------------------------------------------------------------------------- /NOTICE: -------------------------------------------------------------------------------- 1 | Copyright 2019 Amazon.com, Inc. or its affiliates. All Rights Reserved. 2 | -------------------------------------------------------------------------------- /alexa/lambda/.npmignore: -------------------------------------------------------------------------------- 1 | # CDK asset staging directory 2 | .cdk.staging 3 | cdk.out 4 | -------------------------------------------------------------------------------- /.DS_Store: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aws-samples/alexa-skill-with-sap-data-and-scp/master/.DS_Store -------------------------------------------------------------------------------- /alexa/lambda/.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | 3 | # CDK asset staging directory 4 | .cdk.staging 5 | cdk.out 6 | -------------------------------------------------------------------------------- /scp-odata-proxy-ui/manifest.yml: -------------------------------------------------------------------------------- 1 | --- 2 | applications: 3 | - name: odataproxyui 4 | host: awscf-odataproxy-ui 5 | path: odataproxyui 6 | memory: 128M 7 | services: 8 | - odataproxy-uaa 9 | - destination-lite -------------------------------------------------------------------------------- /scp-odata-proxy-ui/odataproxyui/xs-app.json: -------------------------------------------------------------------------------- 1 | { 2 | "routes": [ 3 | { 4 | "source": "^/(.*)$", 5 | "target": "$1", 6 | "destination": "odataproxy-api" 7 | } 8 | ] 9 | } -------------------------------------------------------------------------------- /scp-odata-proxy-api/manifest.yml: -------------------------------------------------------------------------------- 1 | --- 2 | applications: 3 | - name: odataproxyapi 4 | host: awscf-odataproxy-api 5 | path: odataproxyapi 6 | memory: 128M 7 | services: 8 | - odataproxy-uaa 9 | - destination-lite 10 | - connectivity-lite -------------------------------------------------------------------------------- /alexa/lambda/bin/lambda.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | const cdk = require('@aws-cdk/core'); 4 | const { LambdaStack } = require('../lib/lambda-stack'); 5 | const AppConfig = require('../lib/appConfig.json') 6 | 7 | const app = new cdk.App(); 8 | new LambdaStack(app, AppConfig.stackName, { env: AppConfig.env }); 9 | -------------------------------------------------------------------------------- /alexa/lambda/README.md: -------------------------------------------------------------------------------- 1 | # Useful commands 2 | 3 | * `npm run test` perform the jest unit tests 4 | * `cdk deploy` deploy this stack to your default AWS account/region 5 | * `cdk diff` compare deployed stack with current state 6 | * `cdk synth` emits the synthesized CloudFormation template 7 | -------------------------------------------------------------------------------- /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 | -------------------------------------------------------------------------------- /alexa/lambda/lib/functions/aws-sap-alexa-scp-solo/rfcrequest.js: -------------------------------------------------------------------------------- 1 | module.exports = ` 2 | 3 | 4 | 5 | 6 | 7 | 8 | ` -------------------------------------------------------------------------------- /alexa/lambda/lib/functions/aws-sap-alexa-scp-solo/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "aws-sap-alexa-scp-solo", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "", 10 | "license": "MIT-0", 11 | "dependencies": { 12 | "ask-sdk": "^2.7.0", 13 | "request": "^2.88.0", 14 | "xml2js": "^0.4.22" 15 | } 16 | } 17 | -------------------------------------------------------------------------------- /alexa/lambda/test/lambda.test.js: -------------------------------------------------------------------------------- 1 | const { expect, matchTemplate, MatchStyle } = require('@aws-cdk/assert'); 2 | const cdk = require('@aws-cdk/core'); 3 | const Lambda = require('../lib/lambda-stack'); 4 | 5 | test('Empty Stack', () => { 6 | const app = new cdk.App(); 7 | // WHEN 8 | const stack = new Lambda.LambdaStack(app, 'MyTestStack'); 9 | // THEN 10 | expect(stack).to(matchTemplate({ 11 | "Resources": {} 12 | }, MatchStyle.EXACT)) 13 | }); -------------------------------------------------------------------------------- /scp-odata-proxy-ui/odataproxyui/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "odataproxyui", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "start": "node node_modules/@sap/approuter/approuter.js", 8 | "test": "echo \"Error: no test specified\" && exit 1" 9 | }, 10 | "engines": { 11 | "node": "10.x.x" 12 | }, 13 | "author": "", 14 | "license": "ISC", 15 | "dependencies": { 16 | "@sap/approuter": "^6.2.0" 17 | } 18 | } -------------------------------------------------------------------------------- /alexa/lambda/lib/appConfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "env" : { 3 | "account" : "", 4 | "region" : "" 5 | }, 6 | "stackName" : "aws_sap_alexa_scp", 7 | 8 | "scp" : { 9 | "odataProxyAPIUrl" : "" 10 | }, 11 | 12 | "alexaskill" : { 13 | "name" : "solo", 14 | "arn": "" 15 | }, 16 | 17 | "cfexports":{ 18 | "AlexaSkillLambdaFunctionArn" : "SkillLambdaFunctionArn" 19 | } 20 | } -------------------------------------------------------------------------------- /alexa/lambda/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "lambda", 3 | "version": "0.1.0", 4 | "bin": { 5 | "lambda": "bin/lambda.js" 6 | }, 7 | "scripts": { 8 | "build": "echo \"The build step is not required when using JavaScript!\" && exit 0", 9 | "cdk": "cdk", 10 | "test": "jest" 11 | }, 12 | "devDependencies": { 13 | "aws-cdk": "^1.42.0" 14 | }, 15 | "dependencies": { 16 | "@aws-cdk/aws-iam": "^1.42.0", 17 | "@aws-cdk/aws-lambda": "^1.42.0", 18 | "@aws-cdk/core": "^1.42.0" 19 | } 20 | } 21 | -------------------------------------------------------------------------------- /scp-odata-proxy-api/xs-security.json: -------------------------------------------------------------------------------- 1 | { 2 | "xsappname" : "odataproxy", 3 | "tenant-mode" : "dedicated", 4 | "oauth2-configuration": { 5 | "token-validity": 900, 6 | "redirect-uris": [ 7 | "https://**.hana.ondemand.com/login/callback", 8 | "https://www.getpostman.com/oauth2/callback", 9 | "https://pitangui.amazon.com/api/skill/link/**", 10 | "https://alexa.amazon.co.jp/api/skill/link/**", 11 | "https://layla.amazon.com/api/skill/link/**" 12 | ] 13 | } 14 | } -------------------------------------------------------------------------------- /scp-odata-proxy-api/odataproxyapi/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "odataproxyapi", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "start.js", 6 | "scripts": { 7 | "start": "node start.js", 8 | "test": "echo \"Error: no test specified\" && exit 1" 9 | }, 10 | "engines": { 11 | "node": "10.x.x" 12 | }, 13 | "author": "KK Ramamoorthy", 14 | "license": "MIT", 15 | "dependencies": { 16 | "@sap/xssec": "^2.2.3", 17 | "body-parser": "^1.19.0", 18 | "express": "^4.17.1", 19 | "passport": "^0.4.0", 20 | "request": "^2.88.0" 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /alexa/lambda/lib/lambda-stack.js: -------------------------------------------------------------------------------- 1 | const cdk = require('@aws-cdk/core'); 2 | const iam = require('@aws-cdk/aws-iam') 3 | const lambda = require('@aws-cdk/aws-lambda') 4 | const AppConfig = require('./appConfig.json') 5 | const path = require('path') 6 | 7 | class LambdaStack extends cdk.Stack { 8 | /** 9 | * 10 | * @param {cdk.Construct} scope 11 | * @param {string} id 12 | * @param {cdk.StackProps=} props 13 | */ 14 | constructor(scope, id, props) { 15 | super(scope, id, props); 16 | 17 | //Lambda role 18 | const lambdaRole = new iam.Role(this, 'SCPAlexaLambdaRole', { 19 | assumedBy: new iam.ServicePrincipal('lambda.amazonaws.com'), 20 | }) 21 | 22 | //Add basic execution and VPC execution roles 23 | lambdaRole.addManagedPolicy(iam.ManagedPolicy.fromAwsManagedPolicyName('AWSLambdaExecute')) 24 | 25 | //Create the skill lambda function 26 | const skillHandler = new lambda.Function(this, 'AlexaSkillHandler', { 27 | code: lambda.Code.fromAsset(path.join(__dirname, 'functions/aws-sap-alexa-scp-solo')), 28 | runtime: lambda.Runtime.NODEJS_10_X, 29 | handler: 'index.handler', 30 | description: 'Sample Lambda function for alexa skill through SCP', 31 | role: lambdaRole, 32 | timeout: cdk.Duration.seconds(29), 33 | memorySize: 1024, 34 | environment: { 35 | APIURL: AppConfig.scp.odataProxyAPIUrl, 36 | SKILLNAME: AppConfig.alexaskill.name 37 | } 38 | }) 39 | 40 | skillHandler.addPermission('AlexaSkillPermission',{ 41 | principal: new iam.ServicePrincipal('alexa-appkit.amazon.com'), 42 | action: "lambda:InvokeFunction", 43 | eventSourceToken: AppConfig.alexaskill.id 44 | }) 45 | 46 | //Outputs 47 | new cdk.CfnOutput(this,'AlexaSkillLambdaFunctionArn',{ 48 | value: skillHandler.functionArn, 49 | description: "Alexa skill hander Lambda function ARN", 50 | exportName: AppConfig.cfexports.AlexaSkillLambdaFunctionArn 51 | }) 52 | 53 | } 54 | } 55 | 56 | module.exports = { 57 | LambdaStack 58 | } -------------------------------------------------------------------------------- /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 *master* 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 | 61 | We may ask you to sign a [Contributor License Agreement (CLA)](http://en.wikipedia.org/wiki/Contributor_License_Agreement) for larger changes. 62 | -------------------------------------------------------------------------------- /alexa/skill.json: -------------------------------------------------------------------------------- 1 | { 2 | "interactionModel": { 3 | "languageModel": { 4 | "invocationName": "solo", 5 | "intents": [ 6 | { 7 | "name": "AMAZON.CancelIntent", 8 | "samples": [] 9 | }, 10 | { 11 | "name": "AMAZON.HelpIntent", 12 | "samples": [] 13 | }, 14 | { 15 | "name": "AMAZON.StopIntent", 16 | "samples": [] 17 | }, 18 | { 19 | "name": "AMAZON.NavigateHomeIntent", 20 | "samples": [] 21 | }, 22 | { 23 | "name": "GetCustomerCount", 24 | "slots": [], 25 | "samples": [ 26 | "What is the number of customers I have", 27 | "How many customers do I have" 28 | ] 29 | }, 30 | { 31 | "name": "CreateContact", 32 | "slots": [ 33 | { 34 | "name": "FirstName", 35 | "type": "AMAZON.FirstName" 36 | }, 37 | { 38 | "name": "LastName", 39 | "type": "AMAZON.FirstName" 40 | }, 41 | { 42 | "name": "Customer", 43 | "type": "AMAZON.PostalAddress" 44 | } 45 | ], 46 | "samples": [ 47 | "Add a contact with {FirstName} {LastName} in the account ID {Customer}", 48 | "Add a contact with first name {FirstName} and last name {LastName} in the account ID {Customer}", 49 | "Add a contact with first name {FirstName} and last name {LastName} in the account with ID {Customer}", 50 | "Add a contact", 51 | "Create a contact" 52 | ] 53 | }, 54 | { 55 | "name": "GetUserDetails", 56 | "slots": [], 57 | "samples": [ 58 | "Get my user id", 59 | "What is my user Id" 60 | ] 61 | } 62 | ], 63 | "types": [] 64 | }, 65 | "dialog": { 66 | "intents": [ 67 | { 68 | "name": "CreateContact", 69 | "confirmationRequired": false, 70 | "prompts": {}, 71 | "slots": [ 72 | { 73 | "name": "FirstName", 74 | "type": "AMAZON.FirstName", 75 | "confirmationRequired": false, 76 | "elicitationRequired": true, 77 | "prompts": { 78 | "elicitation": "Elicit.Slot.525598253026.45770141604" 79 | } 80 | }, 81 | { 82 | "name": "LastName", 83 | "type": "AMAZON.FirstName", 84 | "confirmationRequired": false, 85 | "elicitationRequired": true, 86 | "prompts": { 87 | "elicitation": "Elicit.Slot.525598253026.1292115365729" 88 | } 89 | }, 90 | { 91 | "name": "Customer", 92 | "type": "AMAZON.PostalAddress", 93 | "confirmationRequired": false, 94 | "elicitationRequired": true, 95 | "prompts": { 96 | "elicitation": "Elicit.Slot.632024915453.1462455217753" 97 | } 98 | } 99 | ] 100 | } 101 | ], 102 | "delegationStrategy": "ALWAYS" 103 | }, 104 | "prompts": [ 105 | { 106 | "id": "Elicit.Slot.525598253026.45770141604", 107 | "variations": [ 108 | { 109 | "type": "PlainText", 110 | "value": "What is the first name?" 111 | } 112 | ] 113 | }, 114 | { 115 | "id": "Elicit.Slot.525598253026.1292115365729", 116 | "variations": [ 117 | { 118 | "type": "PlainText", 119 | "value": "What is the last name?" 120 | } 121 | ] 122 | }, 123 | { 124 | "id": "Elicit.Slot.632024915453.1462455217753", 125 | "variations": [ 126 | { 127 | "type": "PlainText", 128 | "value": "What is the customer ID" 129 | } 130 | ] 131 | } 132 | ] 133 | } 134 | } -------------------------------------------------------------------------------- /scp-odata-proxy-api/odataproxyapi/start.js: -------------------------------------------------------------------------------- 1 | const request = require('request') 2 | const express = require('express'); 3 | const bodyParser = require('body-parser') 4 | const passport = require('passport'); 5 | const xsenv = require('@sap/xsenv'); 6 | const JWTStrategy = require('@sap/xssec').JWTStrategy; 7 | 8 | const app = express(); 9 | 10 | // Cloud Connector Virutal host details available in destination service 11 | const abapDest = 'sapgwdemo' 12 | 13 | // Get access to Connectivity, Destination and XSUAA services 14 | const services = xsenv.getServices({ 15 | uaa: 'odataproxy-uaa', 16 | dest: 'destination-lite', 17 | conn: 'connectivity-lite' 18 | }); 19 | 20 | 21 | const uaa = services.uaa 22 | const dest = services.dest 23 | const conn = services.conn 24 | 25 | const allowedHeadersInToSAP = ["accept", "accept-language", "dataserviceversion", "maxdataserviceversion", "content-type", "x-csrf-token", "cookie"] 26 | const allowedHeadersOutOfSAP = ["content-type", "content-length", "x-csrf-token", "set-cookie"] 27 | 28 | // Authentication strategy for this API. Will accecpt only JWT (access tokens) from XSUAA 29 | passport.use(new JWTStrategy(uaa)); 30 | app.use(bodyParser.raw({type:'*/*'})); 31 | // app.use(bodyParser.urlencoded({ 32 | // extended: false 33 | // })) 34 | // app.use(bodyParser.json()) 35 | app.use(passport.initialize()); 36 | app.use(passport.authenticate('JWT', { 37 | session: false 38 | })); 39 | 40 | // Everything fails all the time, so debug capability is needed.. 41 | app.use('/debug', (req, res, next) => { 42 | proxyToBackend(req, res, true) 43 | }) 44 | 45 | 46 | app.use('/*', (req, res, next) => { 47 | proxyToBackend(req, res, false) 48 | }); 49 | 50 | const port = process.env.PORT || 3000; 51 | app.listen(port, function () { 52 | console.log('App is listening on port ' + port); 53 | }); 54 | 55 | // Here is where the magic happens - proxy whatever http data comes in to the backend 56 | async function proxyToBackend(req, res, debug) { 57 | try { 58 | // Get the JWT token issued by XSUAA (Alexa app will provide this in the header based on account linking) 59 | const uaaToken = req.headers.authorization 60 | // Get access token to access destination service 61 | const destToken = await getToken(dest.url, dest.clientid, dest.clientsecret) 62 | // Get destination data using destination token from destination service. This contains the connection details of cloud connector 63 | const destData = await getDestinationDetails(dest, destToken) 64 | // Now also get an access token to access connecitivity serveice 65 | const connToken = await getToken(conn.url, conn.clientid, conn.clientsecret) 66 | 67 | // Filter unwanted headers.. too much junk gets added to http headers these days 68 | const inHeadersSAP = filterAllowedHeaders(cloneObject(req.headers), allowedHeadersInToSAP) 69 | 70 | var jsonBody = false 71 | var options = { 72 | // Connect to the destination url - cloud connector in this case 73 | url: destData.URL + req.originalUrl, 74 | method: req.method, 75 | // Proxy the connection to cloud connector through connectivity service 76 | proxy: 'http://' + conn.onpremise_proxy_host + ':' + conn.onpremise_proxy_port, 77 | headers: inHeadersSAP 78 | } 79 | 80 | console.log("Request url is : ", options.url) 81 | console.log("Proxy url is : ", options.proxy) 82 | // console.log("HC_ACCOUNT is :", process.env.HC_ACCOUNT) 83 | 84 | // This is a special header for passing the UAA access token which contains the user details. This is inturn used by principal propogation in cloud connector 85 | options.headers['SAP-Connectivity-Authentication'] = uaaToken 86 | //options.headers['SAP-Connectivity-ConsumerAccount'] = "xxxxxx" 87 | // This is a special header for passing the connectivity service access token to tunnel the http connection through connectivity service 88 | options.headers['Proxy-Authorization'] = 'Bearer ' + connToken 89 | 90 | // Some more stuff for the code to work... 91 | options.headers['accept-encoding'] = 'deflate br' 92 | if (options.headers['content-type'] === 'application/json') { 93 | jsonBody = true 94 | options.json = true 95 | } 96 | if (req.method === 'PATCH' || req.method === 'POST' || req.method === 'PUT') { 97 | if (req.body) { 98 | var reqBody = req.body.toString('utf8') 99 | var contentLengh = 0 100 | if(jsonBody){ 101 | reqBody = JSON.parse(reqBody) 102 | contentLengh = JSON.stringify(reqBody).length 103 | options.body = reqBody 104 | }else{ 105 | options.body = reqBody 106 | contentLengh = Buffer.byteLength(reqBody,'UTF-8') 107 | } 108 | options.headers['content-length'] = contentLengh 109 | //options.headers['content-length'] = Buffer.byteLength(req.body,'UTF-8') 110 | } 111 | } 112 | 113 | var body = {} 114 | body.uaa = uaa 115 | body.dest = dest 116 | body.conn = conn 117 | body.uaaToken = uaaToken 118 | body.destData = destData 119 | body.connToken = connToken 120 | body.userId = req.user.id 121 | body.url = req.url 122 | body.originalUrl = req.originalUrl 123 | body.method = req.method 124 | body.path = req.path 125 | body.query = req.query 126 | body.params = req.params 127 | body.headers = req.headers 128 | body.inHeadersSAP = inHeadersSAP 129 | body.body = req.body 130 | body.env = process.env 131 | body.options = options 132 | 133 | if (debug) { 134 | res.send(body) 135 | } else { 136 | //Finally I can call the cloud connector! Phew! 137 | request(options, (err, resp, body) => { 138 | if (err) { 139 | console.log('Error err is : ', err) 140 | res.send('Error in calling backend ') 141 | } else { 142 | res.set(filterAllowedHeaders(cloneObject(resp.headers), allowedHeadersOutOfSAP)) 143 | if(typeof body != "object"){ 144 | res.send(body + '') 145 | }else{ 146 | res.send(body) 147 | } 148 | } 149 | }) 150 | } 151 | } catch (e) { 152 | console.log('Error e is ', e) 153 | res.send('Error is calling backend: ' + JSON.stringify(e)) 154 | } 155 | 156 | } 157 | 158 | //** Shallow clone object */ 159 | function cloneObject(src) { 160 | return JSON.parse(JSON.stringify(src)); 161 | } 162 | 163 | //** Filter allowed headers */ 164 | function filterAllowedHeaders(headers, allowedHeaders) { 165 | for (var prop in headers) { 166 | if (!allowedHeaders.includes(prop)) { 167 | delete headers[prop] 168 | } 169 | } 170 | return headers 171 | } 172 | 173 | /** Get Destination Details */ 174 | function getDestinationDetails(dest, token) { 175 | return new Promise((resolve, reject) => { 176 | try { 177 | const get_options = { 178 | url: dest.uri + '/destination-configuration/v1/destinations/' + abapDest, 179 | headers: { 180 | 'Authorization': 'Bearer ' + token 181 | } 182 | } 183 | request(get_options, (err, res, data) => { 184 | if (res.statusCode === 200) { 185 | resolve(JSON.parse(data).destinationConfiguration) 186 | } else { 187 | if (err) { 188 | reject(err) 189 | } else { 190 | reject(data) 191 | } 192 | 193 | } 194 | }) 195 | } catch (e) { 196 | reject(e) 197 | } 198 | }) 199 | } 200 | 201 | //** Get Token */ 202 | function getToken(url, clientid, clientsecret) { 203 | return new Promise((resolve, reject) => { 204 | try { 205 | const post_options = { 206 | url: url + '/oauth/token', 207 | method: 'POST', 208 | headers: { 209 | 'Authorization': 'Basic ' + Buffer.from(clientid + ':' + clientsecret).toString('base64'), 210 | 'Content-type': 'application/x-www-form-urlencoded' 211 | }, 212 | form: { 213 | 'client_id': clientid, 214 | 'grant_type': 'client_credentials' 215 | } 216 | } 217 | 218 | request(post_options, (err, res, data) => { 219 | if (res.statusCode === 200) { 220 | resolve(JSON.parse(data).access_token) 221 | } else { 222 | if (err) { 223 | reject(err) 224 | } else { 225 | reject(data) 226 | } 227 | } 228 | }) 229 | 230 | } catch (e) { 231 | reject(e) 232 | } 233 | 234 | }) 235 | } -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | 2 | Apache License 3 | Version 2.0, January 2004 4 | http://www.apache.org/licenses/ 5 | 6 | TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION 7 | 8 | 1. Definitions. 9 | 10 | "License" shall mean the terms and conditions for use, reproduction, 11 | and distribution as defined by Sections 1 through 9 of this document. 12 | 13 | "Licensor" shall mean the copyright owner or entity authorized by 14 | the copyright owner that is granting the License. 15 | 16 | "Legal Entity" shall mean the union of the acting entity and all 17 | other entities that control, are controlled by, or are under common 18 | control with that entity. For the purposes of this definition, 19 | "control" means (i) the power, direct or indirect, to cause the 20 | direction or management of such entity, whether by contract or 21 | otherwise, or (ii) ownership of fifty percent (50%) or more of the 22 | outstanding shares, or (iii) beneficial ownership of such entity. 23 | 24 | "You" (or "Your") shall mean an individual or Legal Entity 25 | exercising permissions granted by this License. 26 | 27 | "Source" form shall mean the preferred form for making modifications, 28 | including but not limited to software source code, documentation 29 | source, and configuration files. 30 | 31 | "Object" form shall mean any form resulting from mechanical 32 | transformation or translation of a Source form, including but 33 | not limited to compiled object code, generated documentation, 34 | and conversions to other media types. 35 | 36 | "Work" shall mean the work of authorship, whether in Source or 37 | Object form, made available under the License, as indicated by a 38 | copyright notice that is included in or attached to the work 39 | (an example is provided in the Appendix below). 40 | 41 | "Derivative Works" shall mean any work, whether in Source or Object 42 | form, that is based on (or derived from) the Work and for which the 43 | editorial revisions, annotations, elaborations, or other modifications 44 | represent, as a whole, an original work of authorship. For the purposes 45 | of this License, Derivative Works shall not include works that remain 46 | separable from, or merely link (or bind by name) to the interfaces of, 47 | the Work and Derivative Works thereof. 48 | 49 | "Contribution" shall mean any work of authorship, including 50 | the original version of the Work and any modifications or additions 51 | to that Work or Derivative Works thereof, that is intentionally 52 | submitted to Licensor for inclusion in the Work by the copyright owner 53 | or by an individual or Legal Entity authorized to submit on behalf of 54 | the copyright owner. For the purposes of this definition, "submitted" 55 | means any form of electronic, verbal, or written communication sent 56 | to the Licensor or its representatives, including but not limited to 57 | communication on electronic mailing lists, source code control systems, 58 | and issue tracking systems that are managed by, or on behalf of, the 59 | Licensor for the purpose of discussing and improving the Work, but 60 | excluding communication that is conspicuously marked or otherwise 61 | designated in writing by the copyright owner as "Not a Contribution." 62 | 63 | "Contributor" shall mean Licensor and any individual or Legal Entity 64 | on behalf of whom a Contribution has been received by Licensor and 65 | subsequently incorporated within the Work. 66 | 67 | 2. Grant of Copyright License. Subject to the terms and conditions of 68 | this License, each Contributor hereby grants to You a perpetual, 69 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable 70 | copyright license to reproduce, prepare Derivative Works of, 71 | publicly display, publicly perform, sublicense, and distribute the 72 | Work and such Derivative Works in Source or Object form. 73 | 74 | 3. Grant of Patent License. Subject to the terms and conditions of 75 | this License, each Contributor hereby grants to You a perpetual, 76 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable 77 | (except as stated in this section) patent license to make, have made, 78 | use, offer to sell, sell, import, and otherwise transfer the Work, 79 | where such license applies only to those patent claims licensable 80 | by such Contributor that are necessarily infringed by their 81 | Contribution(s) alone or by combination of their Contribution(s) 82 | with the Work to which such Contribution(s) was submitted. If You 83 | institute patent litigation against any entity (including a 84 | cross-claim or counterclaim in a lawsuit) alleging that the Work 85 | or a Contribution incorporated within the Work constitutes direct 86 | or contributory patent infringement, then any patent licenses 87 | granted to You under this License for that Work shall terminate 88 | as of the date such litigation is filed. 89 | 90 | 4. Redistribution. You may reproduce and distribute copies of the 91 | Work or Derivative Works thereof in any medium, with or without 92 | modifications, and in Source or Object form, provided that You 93 | meet the following conditions: 94 | 95 | (a) You must give any other recipients of the Work or 96 | Derivative Works a copy of this License; and 97 | 98 | (b) You must cause any modified files to carry prominent notices 99 | stating that You changed the files; and 100 | 101 | (c) You must retain, in the Source form of any Derivative Works 102 | that You distribute, all copyright, patent, trademark, and 103 | attribution notices from the Source form of the Work, 104 | excluding those notices that do not pertain to any part of 105 | the Derivative Works; and 106 | 107 | (d) If the Work includes a "NOTICE" text file as part of its 108 | distribution, then any Derivative Works that You distribute must 109 | include a readable copy of the attribution notices contained 110 | within such NOTICE file, excluding those notices that do not 111 | pertain to any part of the Derivative Works, in at least one 112 | of the following places: within a NOTICE text file distributed 113 | as part of the Derivative Works; within the Source form or 114 | documentation, if provided along with the Derivative Works; or, 115 | within a display generated by the Derivative Works, if and 116 | wherever such third-party notices normally appear. The contents 117 | of the NOTICE file are for informational purposes only and 118 | do not modify the License. You may add Your own attribution 119 | notices within Derivative Works that You distribute, alongside 120 | or as an addendum to the NOTICE text from the Work, provided 121 | that such additional attribution notices cannot be construed 122 | as modifying the License. 123 | 124 | You may add Your own copyright statement to Your modifications and 125 | may provide additional or different license terms and conditions 126 | for use, reproduction, or distribution of Your modifications, or 127 | for any such Derivative Works as a whole, provided Your use, 128 | reproduction, and distribution of the Work otherwise complies with 129 | the conditions stated in this License. 130 | 131 | 5. Submission of Contributions. Unless You explicitly state otherwise, 132 | any Contribution intentionally submitted for inclusion in the Work 133 | by You to the Licensor shall be under the terms and conditions of 134 | this License, without any additional terms or conditions. 135 | Notwithstanding the above, nothing herein shall supersede or modify 136 | the terms of any separate license agreement you may have executed 137 | with Licensor regarding such Contributions. 138 | 139 | 6. Trademarks. This License does not grant permission to use the trade 140 | names, trademarks, service marks, or product names of the Licensor, 141 | except as required for reasonable and customary use in describing the 142 | origin of the Work and reproducing the content of the NOTICE file. 143 | 144 | 7. Disclaimer of Warranty. Unless required by applicable law or 145 | agreed to in writing, Licensor provides the Work (and each 146 | Contributor provides its Contributions) on an "AS IS" BASIS, 147 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or 148 | implied, including, without limitation, any warranties or conditions 149 | of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A 150 | PARTICULAR PURPOSE. You are solely responsible for determining the 151 | appropriateness of using or redistributing the Work and assume any 152 | risks associated with Your exercise of permissions under this License. 153 | 154 | 8. Limitation of Liability. In no event and under no legal theory, 155 | whether in tort (including negligence), contract, or otherwise, 156 | unless required by applicable law (such as deliberate and grossly 157 | negligent acts) or agreed to in writing, shall any Contributor be 158 | liable to You for damages, including any direct, indirect, special, 159 | incidental, or consequential damages of any character arising as a 160 | result of this License or out of the use or inability to use the 161 | Work (including but not limited to damages for loss of goodwill, 162 | work stoppage, computer failure or malfunction, or any and all 163 | other commercial damages or losses), even if such Contributor 164 | has been advised of the possibility of such damages. 165 | 166 | 9. Accepting Warranty or Additional Liability. While redistributing 167 | the Work or Derivative Works thereof, You may choose to offer, 168 | and charge a fee for, acceptance of support, warranty, indemnity, 169 | or other liability obligations and/or rights consistent with this 170 | License. However, in accepting such obligations, You may act only 171 | on Your own behalf and on Your sole responsibility, not on behalf 172 | of any other Contributor, and only if You agree to indemnify, 173 | defend, and hold each Contributor harmless for any liability 174 | incurred by, or claims asserted against, such Contributor by reason 175 | of your accepting any such warranty or additional liability. 176 | -------------------------------------------------------------------------------- /alexa/lambda/lib/functions/aws-sap-alexa-scp-solo/index.js: -------------------------------------------------------------------------------- 1 | const Alexa = require('ask-sdk-core'); 2 | const request = require("request") 3 | const xml2js = require('xml2js'); 4 | const parser = new xml2js.Parser(); 5 | 6 | let skill; 7 | 8 | //All allowed intents 9 | exports.handler = async function (event, context) { 10 | console.log(`REQUEST++++${JSON.stringify(event)}`); 11 | if (!skill) { 12 | skill = Alexa.SkillBuilders.custom() 13 | .addRequestHandlers( 14 | LaunchRequestHandler, 15 | CustomerCountHandler, 16 | CreateContactHanlder, 17 | GetUserHandler, 18 | HelpIntentHandler, 19 | CancelAndStopIntentHandler, 20 | SessionEndedRequestHandler, 21 | IntentReflectorHandler 22 | ) 23 | .addErrorHandlers(ErrorHandler) 24 | .create(); 25 | } 26 | 27 | const response = await skill.invoke(event, context); 28 | console.log(`RESPONSE++++${JSON.stringify(response)}`); 29 | 30 | return response; 31 | } 32 | 33 | //Get the logged on user details 34 | const GetUserHandler = { 35 | canHandle(handlerInput) { 36 | return Alexa.getRequestType(handlerInput.requestEnvelope) === 'IntentRequest' 37 | && Alexa.getIntentName(handlerInput.requestEnvelope) === 'GetUserDetails'; 38 | }, 39 | async handle(handlerInput) { 40 | var speakOutput = 'Error getting user details. Please check logs' 41 | try{ 42 | var path = '/sap/bc/soap/rfc' 43 | var body = require('./rfcrequest.js') 44 | var response = await getDataFromSAP(handlerInput,path,'POST',body,null,'text/xml') 45 | console.log('response is', response.body) 46 | parser.parseString(response.body,(parserError,result)=>{ 47 | if(parserError){ 48 | console.log('Error in parsing ', parserError) 49 | }else{ 50 | try{ 51 | console.log('Result is ', JSON.stringify(result)) 52 | const userId = result['SOAP-ENV:Envelope']['SOAP-ENV:Body'][0]['urn:ME_GET_CURRENT_USER_ID.Response'][0]['USERNAME'][0] 53 | console.log('User ID is ', userId) 54 | speakOutput = 'Your user name is ' + userId 55 | 56 | }catch(err){ 57 | console.log('Error in getting the result is ', err) 58 | } 59 | } 60 | }) 61 | 62 | }catch(e){ 63 | console.log('Error is ', e.message) 64 | } 65 | return handlerInput.responseBuilder 66 | .speak(speakOutput) 67 | .reprompt(speakOutput) 68 | .getResponse(); 69 | } 70 | } 71 | 72 | 73 | // Get the customer count 74 | const CustomerCountHandler = { 75 | canHandle(handlerInput) { 76 | return Alexa.getRequestType(handlerInput.requestEnvelope) === 'IntentRequest' 77 | && Alexa.getIntentName(handlerInput.requestEnvelope) === 'GetCustomerCount'; 78 | }, 79 | async handle(handlerInput) { 80 | var speakOutput = 'Error getting customer count. Please check logs' 81 | try{ 82 | var path = '/sap/opu/odata/IWBEP/GWSAMPLE_BASIC/BusinessPartnerSet/$count' 83 | var response = await getDataFromSAP(handlerInput,path,'GET',null,null,'application/json') 84 | speakOutput = 'You have a total of ' + response.body + 'customers' ; 85 | }catch(e){ 86 | speakOutput = 'Error getting customer count. Please check logs' 87 | } 88 | return handlerInput.responseBuilder 89 | .speak(speakOutput) 90 | .reprompt(speakOutput) 91 | .getResponse(); 92 | } 93 | } 94 | 95 | //Create Contact 96 | const CreateContactHanlder = { 97 | canHandle(handlerInput) { 98 | return Alexa.getRequestType(handlerInput.requestEnvelope) === 'IntentRequest' 99 | && Alexa.getIntentName(handlerInput.requestEnvelope) === 'CreateContact' 100 | }, 101 | async handle(handlerInput) { 102 | var speakOutput = 'Error creating contact. Please check logs' 103 | try{ 104 | const firstName = handlerInput.requestEnvelope.request.intent.slots.FirstName.value 105 | const lastName = handlerInput.requestEnvelope.request.intent.slots.LastName.value 106 | const customer = handlerInput.requestEnvelope.request.intent.slots.Customer.value 107 | var path = '/sap/opu/odata/IWBEP/GWSAMPLE_BASIC/ContactSet' 108 | var csrftoken = await getCsrfToken(handlerInput) 109 | var body = { 110 | "BusinessPartnerID" : customer, 111 | "FirstName" : firstName, 112 | "LastName" : lastName, 113 | "Sex" : "M", 114 | "EmailAddress" : "sap-on-aws@amazon.com", 115 | "PhoneNumber" : "555-555-5555", 116 | "Address" : { 117 | "Building" : "1800", 118 | "Street" : "Terry Avenue", 119 | "City" : "Seattle", 120 | "PostalCode" : "98101", 121 | "Country" : "US", 122 | "AddressType" : "02" 123 | } 124 | } 125 | var path = '/sap/opu/odata/IWBEP/GWSAMPLE_BASIC/ContactSet' 126 | var response = await getDataFromSAP(handlerInput,path,'POST',body,csrftoken,'application/json') 127 | console.log('Response contact creation ' , response) 128 | speakOutput = 'Error creating contact. Please check your logs' 129 | try{ 130 | var contactGuid = response.d.ContactGuid 131 | speakOutput = 'Contact successfully created' 132 | }catch(err){} 133 | }catch(e){ 134 | console.log('Error is ', e.message) 135 | speakOutput = 'Error creating contact. Please check logs' 136 | } 137 | return handlerInput.responseBuilder 138 | .speak(speakOutput) 139 | .reprompt(speakOutput) 140 | .getResponse(); 141 | } 142 | } 143 | 144 | //Get CSRF token 145 | function getCsrfToken(handlerInput){ 146 | return new Promise((resolve,reject)=>{ 147 | try{ 148 | var path = '/sap/opu/odata/IWBEP/GWSAMPLE_BASIC/BusinessPartnerSet/$count' 149 | getDataFromSAP(handlerInput,path,null,null,'application/json').then((response)=>{ 150 | resolve(response.headers['x-csrf-token']) 151 | }) 152 | 153 | }catch(e){ 154 | console.log('unable to get csrf token ', e.message) 155 | reject(e) 156 | } 157 | }) 158 | 159 | 160 | } 161 | 162 | //Get or Post data to/from SAP 163 | function getDataFromSAP(handlerInput,path,method,body,csrftoken,contentType){ 164 | return new Promise((resolve,reject)=>{ 165 | try{ 166 | var options = {} 167 | options.uri = process.env.APIURL + path 168 | options.method = method 169 | options.headers = { 170 | "Accept":"application/json", 171 | "Authorization": "Bearer " + handlerInput.requestEnvelope.context.System.user.accessToken, 172 | "X-CSRF-Token": "Fetch", 173 | } 174 | if(method=='PUT' || method=='PATCH' || method=='POST'){ 175 | options.headers['X-CSRF-Token'] = csrftoken 176 | options.body = body 177 | } 178 | options.jar = true 179 | options.headers['Content-Type'] = contentType 180 | if(contentType == 'application/json'){ 181 | options.json = true 182 | } 183 | 184 | request(options,(err,resp,body)=>{ 185 | if(err){ 186 | reject(err) 187 | }else{ 188 | resolve(resp) 189 | } 190 | }) 191 | }catch(e){ 192 | reject(e) 193 | } 194 | }) 195 | } 196 | 197 | const LaunchRequestHandler = { 198 | canHandle(handlerInput) { 199 | return Alexa.getRequestType(handlerInput.requestEnvelope) === 'LaunchRequest'; 200 | }, 201 | handle(handlerInput) { 202 | const speakOutput = 'Welcome to ' + process.env.SKILLNAME + ' created by AWS. How can I help?'; 203 | return handlerInput.responseBuilder 204 | .speak(speakOutput) 205 | .reprompt(speakOutput) 206 | .getResponse(); 207 | } 208 | } 209 | 210 | const HelpIntentHandler = { 211 | canHandle(handlerInput) { 212 | return Alexa.getRequestType(handlerInput.requestEnvelope) === 'IntentRequest' 213 | && Alexa.getIntentName(handlerInput.requestEnvelope) === 'AMAZON.HelpIntent'; 214 | }, 215 | handle(handlerInput) { 216 | const speakOutput = 'You can ask about your user ID or get data from SAP! How can I help?'; 217 | 218 | return handlerInput.responseBuilder 219 | .speak(speakOutput) 220 | .reprompt(speakOutput) 221 | .getResponse(); 222 | } 223 | }; 224 | const CancelAndStopIntentHandler = { 225 | canHandle(handlerInput) { 226 | return Alexa.getRequestType(handlerInput.requestEnvelope) === 'IntentRequest' 227 | && (Alexa.getIntentName(handlerInput.requestEnvelope) === 'AMAZON.CancelIntent' 228 | || Alexa.getIntentName(handlerInput.requestEnvelope) === 'AMAZON.StopIntent'); 229 | }, 230 | handle(handlerInput) { 231 | const speakOutput = 'Goodbye!'; 232 | return handlerInput.responseBuilder 233 | .speak(speakOutput) 234 | .getResponse(); 235 | } 236 | }; 237 | const SessionEndedRequestHandler = { 238 | canHandle(handlerInput) { 239 | return Alexa.getRequestType(handlerInput.requestEnvelope) === 'SessionEndedRequest'; 240 | }, 241 | handle(handlerInput) { 242 | const speakOutput = 'Goodbye!'; 243 | // Any cleanup logic goes here. 244 | return handlerInput.responseBuilder 245 | .speak(speakOutput) 246 | .getResponse(); 247 | } 248 | }; 249 | 250 | // The intent reflector is used for interaction model testing and debugging. 251 | // It will simply repeat the intent the user said. You can create custom handlers 252 | // for your intents by defining them above, then also adding them to the request 253 | // handler chain below. 254 | const IntentReflectorHandler = { 255 | canHandle(handlerInput) { 256 | return Alexa.getRequestType(handlerInput.requestEnvelope) === 'IntentRequest'; 257 | }, 258 | handle(handlerInput) { 259 | const intentName = Alexa.getIntentName(handlerInput.requestEnvelope); 260 | const speakOutput = `You just triggered ${intentName}`; 261 | 262 | return handlerInput.responseBuilder 263 | .speak(speakOutput) 264 | //.reprompt('add a reprompt if you want to keep the session open for the user to respond') 265 | .getResponse(); 266 | } 267 | }; 268 | 269 | // Generic error handling to capture any syntax or routing errors. If you receive an error 270 | // stating the request handler chain is not found, you have not implemented a handler for 271 | // the intent being invoked or included it in the skill builder below. 272 | const ErrorHandler = { 273 | canHandle() { 274 | return true; 275 | }, 276 | handle(handlerInput, error) { 277 | console.log(`Error handled: ${error.stack}`); 278 | const speakOutput = `Sorry, I had trouble doing what you asked. Please try again.`; 279 | 280 | return handlerInput.responseBuilder 281 | .speak(speakOutput) 282 | .reprompt(speakOutput) 283 | .getResponse(); 284 | } 285 | }; 286 | 287 | 288 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | ## alexa-skill-with-sap-data-and-scp 2 | 3 | This is a sample Alexa skill that integrates to a backend SAP application using SAP Cloud Platform and SAP Cloud Connector. This repository contains a sample SAP Cloud Platform (CloudFoundry) app that acts as an API endpoint to access backend SAP developer edition application through cloud connector. The backend SAP application and cloud connector can be in your on-premise or hosted on Amazon EC2 instances. SAP Cloud platform account can be in any region where CloudFoundry environment is supported. 4 | 5 | ## Requirements 6 | * [AWS CLI already configured with Administrator permission](https://docs.aws.amazon.com/cli/latest/userguide/cli-chap-welcome.html) 7 | * [NodeJS 10.x installed](https://nodejs.org/en/download/) 8 | * [AWS CDK installed](https://docs.aws.amazon.com/cdk/latest/guide/getting_started.html) 9 | * [SAP Cloud Platform Trial Account](https://developers.sap.com/tutorials/hcp-create-trial-account.html) 10 | * SAP application (ABAP stack). If required, you can create an SAP ABAP developer edition using cloud formation template [here](https://github.com/aws-samples/aws-cloudformation-sap-abap-dev) or create one using [SAP Cloud application library](https://cal.sap.com) 11 | * SAP Cloud Connector installed. Check [this](https://developers.sap.com/tutorials/cp-connectivity-install-cloud-connector.html) tutorial for more information. For testing purposes, you can install cloud connector on Amazon linux as well. 12 | * [SAP Cloud Foundry Command Line installed and setup](https://developers.sap.com/tutorials/cp-cf-download-cli.html) 13 | * [Alexa Developer Account](https://developer.amazon.com/en-US/alexa) 14 | 15 | ## Setup Process 16 | Note: This process creates various resources in your AWS account. Check the resources created section for more information on what gets created. You incur charges for using the resources created and you are responsible for those charges. 17 | 18 | ### SAP Cloud Platform setup 19 | 20 | * Setup secure tunnel between ABAP System and SAP Cloud Platform through Cloud Connector - [Set up Secure Tunnel between ABAP System and SAP Cloud Platform (CF)](https://developers.sap.com/tutorials/cp-connectivity-create-secure-tunnel.html) 21 | NOTE: In the tutorial above, under Step 3: Allow access to ABAP resources, use URL path as '/' instead of '/sap/opu/odata'. This will allow SCP to access all URL paths in the backend ABAP system 22 | 23 | * Configure SAP Cloud Connector for Principal propagation. Check [How to Guide – Principal Propagation in an HTTPS Scenario](https://blogs.sap.com/2017/06/22/how-to-guide-principal-propagation-in-an-https-scenario/) blog for setup steps. 24 | 25 | NOTE: 26 | 1. In the above blog, the author uses their SCP user ID to create a dummy user certificate in cloud connector for using in CERTRULE transaction. Since you will be using your SCP, I suggest you use your email ID that was used for the SCP account to generate the dummy certificate 27 | 2. In CERTRULE transaction, the author is mapping the 'User Name' to the 'Login As' attribute. Here again, use email ID for 'Login As' attribute. 28 | 3. Map the email ID to an available user ID in the SAP ABAP developer edition using SU01 transaction. 29 | 4. The content under 'Create Destination' is outdated in this blog. Use the steps detailed below instead 30 | 31 | * Activate '/sap/bc/soap/rfc' in SICF transaction in SAP application 32 | 33 | * Create a destination with name 'sapgwdemo' for the ABAP virtual system in SAP Cloud Platform. See [Managing Destinations](https://help.sap.com/viewer/cca91383641e40ffbe03bdc78f00f681/Cloud/en-US/84e45e071c7646c88027fffc6a7bb787.html) for more more information on how to access the 'Create destination editor' and creating HTTP destinations using the destination editor. 34 | 35 | ### SAP Cloud Platform deployment 36 | 37 | * Clone this repo to a folder of your choice 38 | 39 | * Navigate to the foloder that has the SAP Cloud Platform app and install dependecies 40 | ```bash 41 | cd aws-sap-alexa-scp/sap-odata-proxy-api/odataproxyapi 42 | npm install 43 | ``` 44 | * Navigate one level up 45 | ```bash 46 | cd .. 47 | ``` 48 | * Login to your SAP Cloud Platform account. Check (this)[https://developers.sap.com/tutorials/cp-cf-download-cli.html)] for more information on which URL you should choose for logging in 49 | ```bash 50 | cf login -a 51 | ``` 52 | 53 | * Create a connectivity service 54 | ```bash 55 | cf create-service connectivity lite connectivity-lite -t alexademo_conn 56 | ``` 57 | 58 | * Create a destination service 59 | ```bash 60 | cf create-service destination lite destination-lite -t alexademo_dest 61 | ``` 62 | 63 | * Create a XSUAA service 64 | ```bash 65 | cf create-service xsuaa application odataproxy-uaa -c xs-security.json 66 | ``` 67 | NOTE: 68 | 1. If you changed the name for connectivity, destination or XSUAA service about, then open the manifest.yml in a text editor and replace them as such under 'services' 69 | 2. If you use a destination name is other than 'sapgwdemo' in the SAP Cloud Platform setup, then go to 'odataproxyapi' folder, open the start.js file and update the destination name for 'abapDest' constant. 70 | ```bash 71 | const abapDest = '[replace this with your destination name if you used anything other than sapgwdemo]' 72 | ``` 73 | Similarly update the value for uaa, dest and conn variables under services. 74 | 75 | * Open the manifest.yml file and update the host field to something unique. For e.g. change it from awscf-odataproxy-api to -odataproxy-api. Otherwise, the deployment of the app could fail 76 | 77 | * Push the app to SAP Cloud Platform 78 | ```bash 79 | cf push 80 | ``` 81 | * Once the application is deployed successfully 82 | 1. Log on the SAP Cloud Platform console using your web browswer, go to subaccounts -> spaces->[YOUR SPACE NAME]. 83 | 2. Then go to Service Instances -> [Your XSUAA instance, for e.g. odataproxy-uaa] -> Show Sensitive data. 84 | 3. Note down the values for the following fields : 85 | * url 86 | * clientid 87 | * clientsecret 88 | 89 | You will need to use them when you create an Alexa skill later. 90 | 91 | ### Alexa skill deployment 92 | * Log on to your Alexa developer account and create a custom skill from scratch. Check [Quick Reference: Create a custom skill for Alexa](https://developer.amazon.com/docs/quick-reference/custom-skill-quick-reference.html) for more information on how to create a custom skill 93 | 94 | * Once inside the skill build console, go to the 'JSON Editor' in the left navigation and upload (or drag and drop) the skills.json file from the 'alexa' folder in this project. 95 | 96 | * The skills.json uses 'solo' as the invocation name. If want to use a different invocation name, update the value for 'invocationName' variable in the skills.json file. 97 | 98 | * Go to 'Endpoint' in the left navigation and choose 'AWS Lambda ARN' as the 'Service Endpoint Type'. Copy the 'Your Skill ID' to clipboard 99 | 100 | * Go to 'Account Linking' in the left navigation, enable 'Do you allow users to create an account or link to an existing account with you?' 101 | 102 | * Choose 'Auth Code Grant' and update the following fields. Leave other values as-is 103 | * Authorization URI = + /oauth/authorize. For e.g. https://yourscpaccount.authentication.us10.hana.ondemand.com/oauth/authorize 104 | * Access Token URI = + /oauth/authorize. For e.g. https://yourscpaccount.authentication.us10.hana.ondemand.com/oauth/token 105 | * Your Client ID = 'clientid' from your XSUAA service in SAP Cloud Platform 106 | * Your Secret = 'clientsecret' from your XSUAA service in SAP Cloud Platform 107 | 108 | ### AWS Lambda deployment 109 | 110 | * Navigate to the alexa/lambda/ folder and install dependencies 111 | ```bash 112 | cd aws-sap-alexa-scp/alexa/lambda 113 | npm install 114 | ``` 115 | 116 | * Navigate to the alexa/lambda/lib folder 117 | ```bash 118 | cd aws-sap-alexa-scp/alexa/lambda/lib 119 | ``` 120 | 121 | * Open appConfig.json and update the following fields 122 | 123 | - account = [Your AWS Account ID] 124 | - region = [Your AWS region where you want the Lambda function to be deployed] 125 | - odataProxyAPIUrl = [Your odataproxyapi url from SAP cloud platform]. You can get this url by navigating to subaccount -> spaces -> [Your space] -> Applications -> odataproxyapi -> Application Routes. For e.g. https://mycf-odataproxy-api.cfapps.us10.hana.ondemand.com 126 | - alexaskill.name = [Your Alexa skill name. For e.g. solo] 127 | - alexaskill.id = [Your Alexa skill ID copied earlier from Alexa developer console. For e.g. amzn1.ask.skill.96d02cbf-ffda-4567-3454a-58222c9f9b50] 128 | 129 | 130 | * Navitage to alexa/lambda/lib/functions/aws-sap-alexa-scp-solo folder and install dependencies 131 | ```bash 132 | cd aws-sap-alexa-scp/alexa/lambda/lib/functions/aws-sap-alexa-scp-solo 133 | npm install 134 | ``` 135 | 136 | * Navigate back to the lambda directory and deploy the resources to your AWS account. Make sure you AWS CLI is setup for accessing the correct AWS account 137 | ```bash 138 | cd aws-sap-alexa-scp/alexa/lambda/ 139 | cdk synth 140 | cdk deploy 141 | ``` 142 | * Once the resources are successfully deployed, note down the Lambda ARN from the output. It is available as 'AlexaSkillLambdaFunctionArn' output field in cloud formation 143 | 144 | ### Alexa Skill Build 145 | 146 | * Go back to your Alexa skill in the Alexa developer console, navigate to 'Endpoint' and update the Lambda ARN from above under 'Default Region' field. 147 | 148 | * Navigate to 'Invocation', 'Save Mode' and then 'Build Model' 149 | 150 | ### Testing 151 | 152 | * First, test if you are able to able to access the SAP Cloud Platform service using a tool like Postman. For Authentication/Authorization, you can use 'OAuth2.0' type and get an access token. You can use the following fields to generate token 153 | 154 | * Grant Type = Authorization Code 155 | * Callback URL = https://www.getpostman.com/oauth2/callback 156 | * Auth URL = + /oauth/authorize. For e.g. https://yourscpaccount.authentication.us10.hana.ondemand.com/oauth/authorize 157 | * Access Token URL = + /oauth/authorize. For e.g. https://yourscpaccount.authentication.us10.hana.ondemand.com/oauth/token 158 | * Client ID = 'clientid' from your XSUAA service in SAP Cloud Platform 159 | * Client Secret = 'clientsecret' from your XSUAA service in SAP Cloud Platform 160 | * Client Authentication = Send as Basic Auth Header 161 | 162 | * Once you have the token, send a 'GET' call to your SAP Cloud Platform app end point. You can get your end point url by navigating to subaccount -> spaces -> [Your space] -> Applications -> odataproxyapi -> Application Routes. For e.g. https://mycf-odataproxy-api.cfapps.us10.hana.ondemand.com. With this end point URL, you will be calling a backend OData service. If you are using ABAP developer edition, the url path can be /sap/opu/odata/IWBEP/GWSAMPLE_BASIC/BusinessPartnerSet?$format=json. So, the full URL for the postman get request will be something like this - https://mycf-odataproxy-api.cfapps.us10.hana.ondemand.com/sap/opu/odata/IWBEP/GWSAMPLE_BASIC/BusinessPartnerSet?$format=json 163 | 164 | * If all works fine, you should get back list of busienss partners as JSON document as response 165 | 166 | * Now, test you Alexa skill. Launch https://alexa.amazon.com/ and log in using your Alexa developer account. Then navigate to Skills -> Your Skills -> Dev Skills -> [Your Skill Name; for e.g. solo] -> Enable Skill 167 | 168 | * Once skill is enabled, click on Settings -> Link Account -> Log in to SAP Cloud Platform account. This step will link your SAP Cloud Platform account with Alexa skill 169 | 170 | * Now, go back to Alexa developer console and test the skill by typing the following commands in the 'Alexa Simulator' 171 | * Launch solo (or whatever invocation name you used for your skill) 172 | * What is my user ID? (the response should display your SAP user ID if the SSO worked correctly) 173 | * 174 | 175 | ### Error Handling 176 | * Check the Lambda logs in case of skill response issues. 177 | 178 | * Check SAP Cloud platform application logs if the lambda is failing with an error response from SAP Cloud Platform 179 | 180 | * If you are hitting authorization errors, check if you client ID and secret is correct. If those are correct, increase the tracelevel in SMICM transaction in backend SAP and check if the SSO was successful. Check [this](https://wiki.scn.sap.com/wiki/display/ASJAVA/How+to+troubleshoot+Cloud+Connector+principal+propagation+over+HTTPS) wiki page on how to trouble shoot Cloud connector principal propagation over HTTPs 181 | 182 | * Make sure you have activated '/sap/bc/soap/rfc' for the 'What is my user ID?' question to work. 183 | 184 | ## Created Resources by CDK/CloudFormation 185 | * Lambda function for handling Skill request/response and integrating with SAP Cloud Platform 186 | * A new role for Lambda execution 187 | * A new Lambda permission for the Alexa Skill 188 | 189 | ## Cleanup 190 | * Delete all the AWS resources created 191 | ```bash 192 | cd aws-sap-alexa-scp/alexa/lambda/ 193 | cdk destroy 194 | ``` 195 | * Log on to SAP Cloud Platform and 'stop' the applications if required or delete them 196 | 197 | * Delete the Alexa skill if required 198 | 199 | ## License 200 | This project is licensed under the Apache-2.0 License. 201 | -------------------------------------------------------------------------------- /alexa/lambda/lib/functions/aws-sap-alexa-scp-solo/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "aws-sap-alexa-scp-solo", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "ajv": { 8 | "version": "6.10.2", 9 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.2.tgz", 10 | "integrity": "sha512-TXtUUEYHuaTEbLZWIKUr5pmBuhDLy+8KYtPYdcV8qC+pOZL+NKqYwvWSRrVXHn+ZmRRAu8vJTAznH7Oag6RVRw==", 11 | "requires": { 12 | "fast-deep-equal": "^2.0.1", 13 | "fast-json-stable-stringify": "^2.0.0", 14 | "json-schema-traverse": "^0.4.1", 15 | "uri-js": "^4.2.2" 16 | } 17 | }, 18 | "ask-sdk": { 19 | "version": "2.7.0", 20 | "resolved": "https://registry.npmjs.org/ask-sdk/-/ask-sdk-2.7.0.tgz", 21 | "integrity": "sha512-BMCD810Y7E/DlHmqQ8Ginvobrs69pgEzCWSyCDUhaLnDUIduf+BmqZpxc0zQ/8ABBOjNtzhJ8/mV7USQijk6iw==", 22 | "requires": { 23 | "ask-sdk-core": "^2.7.0", 24 | "ask-sdk-dynamodb-persistence-adapter": "^2.7.0", 25 | "ask-sdk-model": "^1.9.0" 26 | } 27 | }, 28 | "ask-sdk-core": { 29 | "version": "2.7.0", 30 | "resolved": "https://registry.npmjs.org/ask-sdk-core/-/ask-sdk-core-2.7.0.tgz", 31 | "integrity": "sha512-XEuoQOH8B+fQqdVRtEeLWtNL46yjKxwIpbXg042ZaCNYwwmJaVmbvmnR5p0UXgKjULqWm1QEXjYL5INQlfrK7w==", 32 | "requires": { 33 | "ask-sdk-runtime": "^2.7.0" 34 | } 35 | }, 36 | "ask-sdk-dynamodb-persistence-adapter": { 37 | "version": "2.7.0", 38 | "resolved": "https://registry.npmjs.org/ask-sdk-dynamodb-persistence-adapter/-/ask-sdk-dynamodb-persistence-adapter-2.7.0.tgz", 39 | "integrity": "sha512-LbwdNLFaUXfy6Wt6Hs4wrZfeopbpZT90SuYT5oo+/g0m8JQNTVVH3Kn4R4K7PTwYFGdHuppvHC1bIu9emt5zZw==", 40 | "requires": { 41 | "aws-sdk": "^2.163.0" 42 | } 43 | }, 44 | "ask-sdk-model": { 45 | "version": "1.23.1", 46 | "resolved": "https://registry.npmjs.org/ask-sdk-model/-/ask-sdk-model-1.23.1.tgz", 47 | "integrity": "sha512-XvrjsJ9NR1toKz/mZDC64aXqgrKgcjss7amV6GJHaVLyw03Q3gZFVgQcWlIu69hfKDBZtHgy1zWglrya6Iu8qg==" 48 | }, 49 | "ask-sdk-runtime": { 50 | "version": "2.7.0", 51 | "resolved": "https://registry.npmjs.org/ask-sdk-runtime/-/ask-sdk-runtime-2.7.0.tgz", 52 | "integrity": "sha512-l2YxzibbTc8Ld5Rpy/Kg3oASiCGKHxgbZnKYrywZStlDPF5tEAGpRBhdtVd+yBSRikl/9fgcetb2wMewtoZF2g==" 53 | }, 54 | "asn1": { 55 | "version": "0.2.4", 56 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", 57 | "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", 58 | "requires": { 59 | "safer-buffer": "~2.1.0" 60 | } 61 | }, 62 | "assert-plus": { 63 | "version": "1.0.0", 64 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 65 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" 66 | }, 67 | "asynckit": { 68 | "version": "0.4.0", 69 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 70 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 71 | }, 72 | "aws-sdk": { 73 | "version": "2.564.0", 74 | "resolved": "https://registry.npmjs.org/aws-sdk/-/aws-sdk-2.564.0.tgz", 75 | "integrity": "sha512-X5MbcebjQ3iPNBvZ27WZyMEVCleBLqot2hqVz2M9XvMDR4B8qqPuteWrtbLu+DVjENvVD7Oj0BOIjrYEVWacFA==", 76 | "requires": { 77 | "buffer": "^4.9.1", 78 | "events": "^1.1.1", 79 | "ieee754": "^1.1.13", 80 | "jmespath": "^0.15.0", 81 | "querystring": "^0.2.0", 82 | "sax": "^1.2.1", 83 | "url": "^0.10.3", 84 | "uuid": "^3.3.2", 85 | "xml2js": "^0.4.19" 86 | } 87 | }, 88 | "aws-sign2": { 89 | "version": "0.7.0", 90 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 91 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=" 92 | }, 93 | "aws4": { 94 | "version": "1.8.0", 95 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.8.0.tgz", 96 | "integrity": "sha512-ReZxvNHIOv88FlT7rxcXIIC0fPt4KZqZbOlivyWtXLt8ESx84zd3kMC6iK5jVeS2qt+g7ftS7ye4fi06X5rtRQ==" 97 | }, 98 | "base64-js": { 99 | "version": "1.3.1", 100 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.3.1.tgz", 101 | "integrity": "sha512-mLQ4i2QO1ytvGWFWmcngKO//JXAQueZvwEKtjgQFM4jIK0kU+ytMfplL8j+n5mspOfjHwoAg+9yhb7BwAHm36g==" 102 | }, 103 | "bcrypt-pbkdf": { 104 | "version": "1.0.2", 105 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 106 | "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", 107 | "requires": { 108 | "tweetnacl": "^0.14.3" 109 | } 110 | }, 111 | "buffer": { 112 | "version": "4.9.1", 113 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-4.9.1.tgz", 114 | "integrity": "sha1-bRu2AbB6TvztlwlBMgkwJ8lbwpg=", 115 | "requires": { 116 | "base64-js": "^1.0.2", 117 | "ieee754": "^1.1.4", 118 | "isarray": "^1.0.0" 119 | } 120 | }, 121 | "caseless": { 122 | "version": "0.12.0", 123 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 124 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=" 125 | }, 126 | "combined-stream": { 127 | "version": "1.0.8", 128 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 129 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 130 | "requires": { 131 | "delayed-stream": "~1.0.0" 132 | } 133 | }, 134 | "core-util-is": { 135 | "version": "1.0.2", 136 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 137 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 138 | }, 139 | "dashdash": { 140 | "version": "1.14.1", 141 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 142 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 143 | "requires": { 144 | "assert-plus": "^1.0.0" 145 | } 146 | }, 147 | "define-properties": { 148 | "version": "1.1.3", 149 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 150 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 151 | "requires": { 152 | "object-keys": "^1.0.12" 153 | } 154 | }, 155 | "delayed-stream": { 156 | "version": "1.0.0", 157 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 158 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" 159 | }, 160 | "ecc-jsbn": { 161 | "version": "0.1.2", 162 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 163 | "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", 164 | "requires": { 165 | "jsbn": "~0.1.0", 166 | "safer-buffer": "^2.1.0" 167 | } 168 | }, 169 | "es-abstract": { 170 | "version": "1.16.0", 171 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.16.0.tgz", 172 | "integrity": "sha512-xdQnfykZ9JMEiasTAJZJdMWCQ1Vm00NBw79/AWi7ELfZuuPCSOMDZbT9mkOfSctVtfhb+sAAzrm+j//GjjLHLg==", 173 | "requires": { 174 | "es-to-primitive": "^1.2.0", 175 | "function-bind": "^1.1.1", 176 | "has": "^1.0.3", 177 | "has-symbols": "^1.0.0", 178 | "is-callable": "^1.1.4", 179 | "is-regex": "^1.0.4", 180 | "object-inspect": "^1.6.0", 181 | "object-keys": "^1.1.1", 182 | "string.prototype.trimleft": "^2.1.0", 183 | "string.prototype.trimright": "^2.1.0" 184 | } 185 | }, 186 | "es-to-primitive": { 187 | "version": "1.2.0", 188 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz", 189 | "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==", 190 | "requires": { 191 | "is-callable": "^1.1.4", 192 | "is-date-object": "^1.0.1", 193 | "is-symbol": "^1.0.2" 194 | } 195 | }, 196 | "events": { 197 | "version": "1.1.1", 198 | "resolved": "https://registry.npmjs.org/events/-/events-1.1.1.tgz", 199 | "integrity": "sha1-nr23Y1rQmccNzEwqH1AEKI6L2SQ=" 200 | }, 201 | "extend": { 202 | "version": "3.0.2", 203 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 204 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==" 205 | }, 206 | "extsprintf": { 207 | "version": "1.3.0", 208 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 209 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=" 210 | }, 211 | "fast-deep-equal": { 212 | "version": "2.0.1", 213 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 214 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=" 215 | }, 216 | "fast-json-stable-stringify": { 217 | "version": "2.0.0", 218 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 219 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=" 220 | }, 221 | "forever-agent": { 222 | "version": "0.6.1", 223 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 224 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=" 225 | }, 226 | "form-data": { 227 | "version": "2.3.3", 228 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 229 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 230 | "requires": { 231 | "asynckit": "^0.4.0", 232 | "combined-stream": "^1.0.6", 233 | "mime-types": "^2.1.12" 234 | } 235 | }, 236 | "function-bind": { 237 | "version": "1.1.1", 238 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 239 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 240 | }, 241 | "getpass": { 242 | "version": "0.1.7", 243 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 244 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 245 | "requires": { 246 | "assert-plus": "^1.0.0" 247 | } 248 | }, 249 | "har-schema": { 250 | "version": "2.0.0", 251 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 252 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=" 253 | }, 254 | "har-validator": { 255 | "version": "5.1.3", 256 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz", 257 | "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==", 258 | "requires": { 259 | "ajv": "^6.5.5", 260 | "har-schema": "^2.0.0" 261 | } 262 | }, 263 | "has": { 264 | "version": "1.0.3", 265 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 266 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 267 | "requires": { 268 | "function-bind": "^1.1.1" 269 | } 270 | }, 271 | "has-symbols": { 272 | "version": "1.0.0", 273 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", 274 | "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=" 275 | }, 276 | "http-signature": { 277 | "version": "1.2.0", 278 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 279 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 280 | "requires": { 281 | "assert-plus": "^1.0.0", 282 | "jsprim": "^1.2.2", 283 | "sshpk": "^1.7.0" 284 | } 285 | }, 286 | "ieee754": { 287 | "version": "1.1.13", 288 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.1.13.tgz", 289 | "integrity": "sha512-4vf7I2LYV/HaWerSo3XmlMkp5eZ83i+/CDluXi/IGTs/O1sejBNhTtnxzmRZfvOUqj7lZjqHkeTvpgSFDlWZTg==" 290 | }, 291 | "is-callable": { 292 | "version": "1.1.4", 293 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz", 294 | "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==" 295 | }, 296 | "is-date-object": { 297 | "version": "1.0.1", 298 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 299 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=" 300 | }, 301 | "is-regex": { 302 | "version": "1.0.4", 303 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 304 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 305 | "requires": { 306 | "has": "^1.0.1" 307 | } 308 | }, 309 | "is-symbol": { 310 | "version": "1.0.2", 311 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.2.tgz", 312 | "integrity": "sha512-HS8bZ9ox60yCJLH9snBpIwv9pYUAkcuLhSA1oero1UB5y9aiQpRA8y2ex945AOtCZL1lJDeIk3G5LthswI46Lw==", 313 | "requires": { 314 | "has-symbols": "^1.0.0" 315 | } 316 | }, 317 | "is-typedarray": { 318 | "version": "1.0.0", 319 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 320 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" 321 | }, 322 | "isarray": { 323 | "version": "1.0.0", 324 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 325 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 326 | }, 327 | "isstream": { 328 | "version": "0.1.2", 329 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 330 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" 331 | }, 332 | "jmespath": { 333 | "version": "0.15.0", 334 | "resolved": "https://registry.npmjs.org/jmespath/-/jmespath-0.15.0.tgz", 335 | "integrity": "sha1-o/Iiqarp+Wb10nx5ZRDigJF2Qhc=" 336 | }, 337 | "jsbn": { 338 | "version": "0.1.1", 339 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 340 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=" 341 | }, 342 | "json-schema": { 343 | "version": "0.2.3", 344 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 345 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=" 346 | }, 347 | "json-schema-traverse": { 348 | "version": "0.4.1", 349 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 350 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==" 351 | }, 352 | "json-stringify-safe": { 353 | "version": "5.0.1", 354 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 355 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=" 356 | }, 357 | "jsprim": { 358 | "version": "1.4.1", 359 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 360 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 361 | "requires": { 362 | "assert-plus": "1.0.0", 363 | "extsprintf": "1.3.0", 364 | "json-schema": "0.2.3", 365 | "verror": "1.10.0" 366 | } 367 | }, 368 | "mime-db": { 369 | "version": "1.40.0", 370 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.40.0.tgz", 371 | "integrity": "sha512-jYdeOMPy9vnxEqFRRo6ZvTZ8d9oPb+k18PKoYNYUe2stVEBPPwsln/qWzdbmaIvnhZ9v2P+CuecK+fpUfsV2mA==" 372 | }, 373 | "mime-types": { 374 | "version": "2.1.24", 375 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.24.tgz", 376 | "integrity": "sha512-WaFHS3MCl5fapm3oLxU4eYDw77IQM2ACcxQ9RIxfaC3ooc6PFuBMGZZsYpvoXS5D5QTWPieo1jjLdAm3TBP3cQ==", 377 | "requires": { 378 | "mime-db": "1.40.0" 379 | } 380 | }, 381 | "oauth-sign": { 382 | "version": "0.9.0", 383 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", 384 | "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==" 385 | }, 386 | "object-inspect": { 387 | "version": "1.6.0", 388 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.6.0.tgz", 389 | "integrity": "sha512-GJzfBZ6DgDAmnuaM3104jR4s1Myxr3Y3zfIyN4z3UdqN69oSRacNK8UhnobDdC+7J2AHCjGwxQubNJfE70SXXQ==" 390 | }, 391 | "object-keys": { 392 | "version": "1.1.1", 393 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 394 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==" 395 | }, 396 | "object.getownpropertydescriptors": { 397 | "version": "2.0.3", 398 | "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.0.3.tgz", 399 | "integrity": "sha1-h1jIRvW0B62rDyNuCYbxSwUcqhY=", 400 | "requires": { 401 | "define-properties": "^1.1.2", 402 | "es-abstract": "^1.5.1" 403 | } 404 | }, 405 | "performance-now": { 406 | "version": "2.1.0", 407 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 408 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=" 409 | }, 410 | "psl": { 411 | "version": "1.4.0", 412 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.4.0.tgz", 413 | "integrity": "sha512-HZzqCGPecFLyoRj5HLfuDSKYTJkAfB5thKBIkRHtGjWwY7p1dAyveIbXIq4tO0KYfDF2tHqPUgY9SDnGm00uFw==" 414 | }, 415 | "punycode": { 416 | "version": "2.1.1", 417 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 418 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==" 419 | }, 420 | "qs": { 421 | "version": "6.5.2", 422 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 423 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==" 424 | }, 425 | "querystring": { 426 | "version": "0.2.0", 427 | "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", 428 | "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=" 429 | }, 430 | "request": { 431 | "version": "2.88.0", 432 | "resolved": "https://registry.npmjs.org/request/-/request-2.88.0.tgz", 433 | "integrity": "sha512-NAqBSrijGLZdM0WZNsInLJpkJokL72XYjUpnB0iwsRgxh7dB6COrHnTBNwN0E+lHDAJzu7kLAkDeY08z2/A0hg==", 434 | "requires": { 435 | "aws-sign2": "~0.7.0", 436 | "aws4": "^1.8.0", 437 | "caseless": "~0.12.0", 438 | "combined-stream": "~1.0.6", 439 | "extend": "~3.0.2", 440 | "forever-agent": "~0.6.1", 441 | "form-data": "~2.3.2", 442 | "har-validator": "~5.1.0", 443 | "http-signature": "~1.2.0", 444 | "is-typedarray": "~1.0.0", 445 | "isstream": "~0.1.2", 446 | "json-stringify-safe": "~5.0.1", 447 | "mime-types": "~2.1.19", 448 | "oauth-sign": "~0.9.0", 449 | "performance-now": "^2.1.0", 450 | "qs": "~6.5.2", 451 | "safe-buffer": "^5.1.2", 452 | "tough-cookie": "~2.4.3", 453 | "tunnel-agent": "^0.6.0", 454 | "uuid": "^3.3.2" 455 | } 456 | }, 457 | "safe-buffer": { 458 | "version": "5.2.0", 459 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.0.tgz", 460 | "integrity": "sha512-fZEwUGbVl7kouZs1jCdMLdt95hdIv0ZeHg6L7qPeciMZhZ+/gdesW4wgTARkrFWEpspjEATAzUGPG8N2jJiwbg==" 461 | }, 462 | "safer-buffer": { 463 | "version": "2.1.2", 464 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 465 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 466 | }, 467 | "sax": { 468 | "version": "1.2.4", 469 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", 470 | "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" 471 | }, 472 | "sshpk": { 473 | "version": "1.16.1", 474 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", 475 | "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", 476 | "requires": { 477 | "asn1": "~0.2.3", 478 | "assert-plus": "^1.0.0", 479 | "bcrypt-pbkdf": "^1.0.0", 480 | "dashdash": "^1.12.0", 481 | "ecc-jsbn": "~0.1.1", 482 | "getpass": "^0.1.1", 483 | "jsbn": "~0.1.0", 484 | "safer-buffer": "^2.0.2", 485 | "tweetnacl": "~0.14.0" 486 | } 487 | }, 488 | "string.prototype.trimleft": { 489 | "version": "2.1.0", 490 | "resolved": "https://registry.npmjs.org/string.prototype.trimleft/-/string.prototype.trimleft-2.1.0.tgz", 491 | "integrity": "sha512-FJ6b7EgdKxxbDxc79cOlok6Afd++TTs5szo+zJTUyow3ycrRfJVE2pq3vcN53XexvKZu/DJMDfeI/qMiZTrjTw==", 492 | "requires": { 493 | "define-properties": "^1.1.3", 494 | "function-bind": "^1.1.1" 495 | } 496 | }, 497 | "string.prototype.trimright": { 498 | "version": "2.1.0", 499 | "resolved": "https://registry.npmjs.org/string.prototype.trimright/-/string.prototype.trimright-2.1.0.tgz", 500 | "integrity": "sha512-fXZTSV55dNBwv16uw+hh5jkghxSnc5oHq+5K/gXgizHwAvMetdAJlHqqoFC1FSDVPYWLkAKl2cxpUT41sV7nSg==", 501 | "requires": { 502 | "define-properties": "^1.1.3", 503 | "function-bind": "^1.1.1" 504 | } 505 | }, 506 | "tough-cookie": { 507 | "version": "2.4.3", 508 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.4.3.tgz", 509 | "integrity": "sha512-Q5srk/4vDM54WJsJio3XNn6K2sCG+CQ8G5Wz6bZhRZoAe/+TxjWB/GlFAnYEbkYVlON9FMk/fE3h2RLpPXo4lQ==", 510 | "requires": { 511 | "psl": "^1.1.24", 512 | "punycode": "^1.4.1" 513 | }, 514 | "dependencies": { 515 | "punycode": { 516 | "version": "1.4.1", 517 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 518 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=" 519 | } 520 | } 521 | }, 522 | "tunnel-agent": { 523 | "version": "0.6.0", 524 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 525 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 526 | "requires": { 527 | "safe-buffer": "^5.0.1" 528 | } 529 | }, 530 | "tweetnacl": { 531 | "version": "0.14.5", 532 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 533 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=" 534 | }, 535 | "uri-js": { 536 | "version": "4.2.2", 537 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 538 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 539 | "requires": { 540 | "punycode": "^2.1.0" 541 | } 542 | }, 543 | "url": { 544 | "version": "0.10.3", 545 | "resolved": "https://registry.npmjs.org/url/-/url-0.10.3.tgz", 546 | "integrity": "sha1-Ah5NnHcF8hu/N9A861h2dAJ3TGQ=", 547 | "requires": { 548 | "punycode": "1.3.2", 549 | "querystring": "0.2.0" 550 | }, 551 | "dependencies": { 552 | "punycode": { 553 | "version": "1.3.2", 554 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", 555 | "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=" 556 | } 557 | } 558 | }, 559 | "util.promisify": { 560 | "version": "1.0.0", 561 | "resolved": "https://registry.npmjs.org/util.promisify/-/util.promisify-1.0.0.tgz", 562 | "integrity": "sha512-i+6qA2MPhvoKLuxnJNpXAGhg7HphQOSUq2LKMZD0m15EiskXUkMvKdF4Uui0WYeCUGea+o2cw/ZuwehtfsrNkA==", 563 | "requires": { 564 | "define-properties": "^1.1.2", 565 | "object.getownpropertydescriptors": "^2.0.3" 566 | } 567 | }, 568 | "uuid": { 569 | "version": "3.3.3", 570 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.3.tgz", 571 | "integrity": "sha512-pW0No1RGHgzlpHJO1nsVrHKpOEIxkGg1xB+v0ZmdNH5OAeAwzAVrCnI2/6Mtx+Uys6iaylxa+D3g4j63IKKjSQ==" 572 | }, 573 | "verror": { 574 | "version": "1.10.0", 575 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 576 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 577 | "requires": { 578 | "assert-plus": "^1.0.0", 579 | "core-util-is": "1.0.2", 580 | "extsprintf": "^1.2.0" 581 | } 582 | }, 583 | "xml2js": { 584 | "version": "0.4.22", 585 | "resolved": "https://registry.npmjs.org/xml2js/-/xml2js-0.4.22.tgz", 586 | "integrity": "sha512-MWTbxAQqclRSTnehWWe5nMKzI3VmJ8ltiJEco8akcC6j3miOhjjfzKum5sId+CWhfxdOs/1xauYr8/ZDBtQiRw==", 587 | "requires": { 588 | "sax": ">=0.6.0", 589 | "util.promisify": "~1.0.0", 590 | "xmlbuilder": "~11.0.0" 591 | } 592 | }, 593 | "xmlbuilder": { 594 | "version": "11.0.1", 595 | "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-11.0.1.tgz", 596 | "integrity": "sha512-fDlsI/kFEx7gLvbecc0/ohLG50fugQp8ryHzMTuW9vSa1GJ0XYWKnhsUx7oie3G98+r56aTQIUB4kht42R3JvA==" 597 | } 598 | } 599 | } 600 | -------------------------------------------------------------------------------- /scp-odata-proxy-api/odataproxyapi/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "odataproxyapi", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@sap/node-jwt": { 8 | "version": "1.6.4", 9 | "resolved": "https://npm.sap.com/@sap/node-jwt/-/node-jwt-1.6.4.tgz", 10 | "integrity": "sha512-ad43OLExRalG36fFy0JfCi7FvfoX31THK2BSmdVb5CSaWERwn8N85AqQU6oE1ugp9OAPe3SLI5PejupliSqMrA==" 11 | }, 12 | "@sap/xsenv": { 13 | "version": "2.0.0", 14 | "resolved": "https://npm.sap.com/@sap/xsenv/-/xsenv-2.0.0.tgz", 15 | "integrity": "sha512-SvHZ2IaLfvTPf1PMCVzSFUIBqHOCRC3megKiGAyPAv9nxW+X/MIKEaVvp1D/C7Mmm/sVB2wXAJZ2meNGxY28MQ==", 16 | "requires": { 17 | "debug": "3.1.0", 18 | "verror": "1.10.0" 19 | }, 20 | "dependencies": { 21 | "assert-plus": { 22 | "version": "1.0.0", 23 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 24 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" 25 | }, 26 | "core-util-is": { 27 | "version": "1.0.2", 28 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 29 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 30 | }, 31 | "debug": { 32 | "version": "3.1.0", 33 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 34 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 35 | "requires": { 36 | "ms": "2.0.0" 37 | } 38 | }, 39 | "extsprintf": { 40 | "version": "1.4.0", 41 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.4.0.tgz", 42 | "integrity": "sha1-4mifjzVvrWLMplo6kcXfX5VRaS8=" 43 | }, 44 | "ms": { 45 | "version": "2.0.0", 46 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 47 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 48 | }, 49 | "verror": { 50 | "version": "1.10.0", 51 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 52 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 53 | "requires": { 54 | "assert-plus": "^1.0.0", 55 | "core-util-is": "1.0.2", 56 | "extsprintf": "^1.2.0" 57 | } 58 | } 59 | } 60 | }, 61 | "@sap/xssec": { 62 | "version": "2.2.3", 63 | "resolved": "https://npm.sap.com/@sap/xssec/-/xssec-2.2.3.tgz", 64 | "integrity": "sha512-ILPxpw2D6iVVuP82ZNy8y1UUG1BwcWhrAu0VemaMQT5TcSRng1iKREb2NMT11w1XvV2kkbJJ7tZzUp89eyVfqg==", 65 | "requires": { 66 | "@sap/node-jwt": "^1.5.2", 67 | "@sap/xsenv": "^2.0.0", 68 | "debug": "4.1.1", 69 | "lru-cache": "5.1.1", 70 | "request": "2.88.0", 71 | "requestretry": "4.0.0", 72 | "valid-url": "1.0.9" 73 | }, 74 | "dependencies": { 75 | "debug": { 76 | "version": "4.1.1", 77 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 78 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 79 | "requires": { 80 | "ms": "^2.1.1" 81 | } 82 | }, 83 | "ms": { 84 | "version": "2.1.2", 85 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 86 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 87 | } 88 | } 89 | }, 90 | "accepts": { 91 | "version": "1.3.7", 92 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 93 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 94 | "requires": { 95 | "mime-types": "~2.1.24", 96 | "negotiator": "0.6.2" 97 | } 98 | }, 99 | "ajv": { 100 | "version": "6.10.2", 101 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.2.tgz", 102 | "integrity": "sha512-TXtUUEYHuaTEbLZWIKUr5pmBuhDLy+8KYtPYdcV8qC+pOZL+NKqYwvWSRrVXHn+ZmRRAu8vJTAznH7Oag6RVRw==", 103 | "requires": { 104 | "fast-deep-equal": "^2.0.1", 105 | "fast-json-stable-stringify": "^2.0.0", 106 | "json-schema-traverse": "^0.4.1", 107 | "uri-js": "^4.2.2" 108 | } 109 | }, 110 | "array-flatten": { 111 | "version": "1.1.1", 112 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 113 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 114 | }, 115 | "asn1": { 116 | "version": "0.2.4", 117 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", 118 | "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", 119 | "requires": { 120 | "safer-buffer": "~2.1.0" 121 | } 122 | }, 123 | "assert-plus": { 124 | "version": "1.0.0", 125 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 126 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" 127 | }, 128 | "asynckit": { 129 | "version": "0.4.0", 130 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 131 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 132 | }, 133 | "aws-sign2": { 134 | "version": "0.7.0", 135 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 136 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=" 137 | }, 138 | "aws4": { 139 | "version": "1.8.0", 140 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.8.0.tgz", 141 | "integrity": "sha512-ReZxvNHIOv88FlT7rxcXIIC0fPt4KZqZbOlivyWtXLt8ESx84zd3kMC6iK5jVeS2qt+g7ftS7ye4fi06X5rtRQ==" 142 | }, 143 | "bcrypt-pbkdf": { 144 | "version": "1.0.2", 145 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 146 | "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", 147 | "requires": { 148 | "tweetnacl": "^0.14.3" 149 | } 150 | }, 151 | "body-parser": { 152 | "version": "1.19.0", 153 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 154 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 155 | "requires": { 156 | "bytes": "3.1.0", 157 | "content-type": "~1.0.4", 158 | "debug": "2.6.9", 159 | "depd": "~1.1.2", 160 | "http-errors": "1.7.2", 161 | "iconv-lite": "0.4.24", 162 | "on-finished": "~2.3.0", 163 | "qs": "6.7.0", 164 | "raw-body": "2.4.0", 165 | "type-is": "~1.6.17" 166 | } 167 | }, 168 | "bytes": { 169 | "version": "3.1.0", 170 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 171 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" 172 | }, 173 | "caseless": { 174 | "version": "0.12.0", 175 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 176 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=" 177 | }, 178 | "combined-stream": { 179 | "version": "1.0.8", 180 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 181 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 182 | "requires": { 183 | "delayed-stream": "~1.0.0" 184 | } 185 | }, 186 | "content-disposition": { 187 | "version": "0.5.3", 188 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 189 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 190 | "requires": { 191 | "safe-buffer": "5.1.2" 192 | } 193 | }, 194 | "content-type": { 195 | "version": "1.0.4", 196 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 197 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 198 | }, 199 | "cookie": { 200 | "version": "0.4.0", 201 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 202 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==" 203 | }, 204 | "cookie-signature": { 205 | "version": "1.0.6", 206 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 207 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 208 | }, 209 | "core-util-is": { 210 | "version": "1.0.2", 211 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 212 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 213 | }, 214 | "dashdash": { 215 | "version": "1.14.1", 216 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 217 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 218 | "requires": { 219 | "assert-plus": "^1.0.0" 220 | } 221 | }, 222 | "debug": { 223 | "version": "2.6.9", 224 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 225 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 226 | "requires": { 227 | "ms": "2.0.0" 228 | } 229 | }, 230 | "delayed-stream": { 231 | "version": "1.0.0", 232 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 233 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" 234 | }, 235 | "depd": { 236 | "version": "1.1.2", 237 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 238 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 239 | }, 240 | "destroy": { 241 | "version": "1.0.4", 242 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 243 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 244 | }, 245 | "ecc-jsbn": { 246 | "version": "0.1.2", 247 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 248 | "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", 249 | "requires": { 250 | "jsbn": "~0.1.0", 251 | "safer-buffer": "^2.1.0" 252 | } 253 | }, 254 | "ee-first": { 255 | "version": "1.1.1", 256 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 257 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 258 | }, 259 | "encodeurl": { 260 | "version": "1.0.2", 261 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 262 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 263 | }, 264 | "escape-html": { 265 | "version": "1.0.3", 266 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 267 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 268 | }, 269 | "etag": { 270 | "version": "1.8.1", 271 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 272 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 273 | }, 274 | "express": { 275 | "version": "4.17.1", 276 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 277 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 278 | "requires": { 279 | "accepts": "~1.3.7", 280 | "array-flatten": "1.1.1", 281 | "body-parser": "1.19.0", 282 | "content-disposition": "0.5.3", 283 | "content-type": "~1.0.4", 284 | "cookie": "0.4.0", 285 | "cookie-signature": "1.0.6", 286 | "debug": "2.6.9", 287 | "depd": "~1.1.2", 288 | "encodeurl": "~1.0.2", 289 | "escape-html": "~1.0.3", 290 | "etag": "~1.8.1", 291 | "finalhandler": "~1.1.2", 292 | "fresh": "0.5.2", 293 | "merge-descriptors": "1.0.1", 294 | "methods": "~1.1.2", 295 | "on-finished": "~2.3.0", 296 | "parseurl": "~1.3.3", 297 | "path-to-regexp": "0.1.7", 298 | "proxy-addr": "~2.0.5", 299 | "qs": "6.7.0", 300 | "range-parser": "~1.2.1", 301 | "safe-buffer": "5.1.2", 302 | "send": "0.17.1", 303 | "serve-static": "1.14.1", 304 | "setprototypeof": "1.1.1", 305 | "statuses": "~1.5.0", 306 | "type-is": "~1.6.18", 307 | "utils-merge": "1.0.1", 308 | "vary": "~1.1.2" 309 | } 310 | }, 311 | "extend": { 312 | "version": "3.0.2", 313 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 314 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==" 315 | }, 316 | "extsprintf": { 317 | "version": "1.3.0", 318 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 319 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=" 320 | }, 321 | "fast-deep-equal": { 322 | "version": "2.0.1", 323 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 324 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=" 325 | }, 326 | "fast-json-stable-stringify": { 327 | "version": "2.0.0", 328 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 329 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=" 330 | }, 331 | "finalhandler": { 332 | "version": "1.1.2", 333 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 334 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 335 | "requires": { 336 | "debug": "2.6.9", 337 | "encodeurl": "~1.0.2", 338 | "escape-html": "~1.0.3", 339 | "on-finished": "~2.3.0", 340 | "parseurl": "~1.3.3", 341 | "statuses": "~1.5.0", 342 | "unpipe": "~1.0.0" 343 | } 344 | }, 345 | "forever-agent": { 346 | "version": "0.6.1", 347 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 348 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=" 349 | }, 350 | "form-data": { 351 | "version": "2.3.3", 352 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 353 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 354 | "requires": { 355 | "asynckit": "^0.4.0", 356 | "combined-stream": "^1.0.6", 357 | "mime-types": "^2.1.12" 358 | } 359 | }, 360 | "forwarded": { 361 | "version": "0.1.2", 362 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 363 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 364 | }, 365 | "fresh": { 366 | "version": "0.5.2", 367 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 368 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 369 | }, 370 | "getpass": { 371 | "version": "0.1.7", 372 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 373 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 374 | "requires": { 375 | "assert-plus": "^1.0.0" 376 | } 377 | }, 378 | "har-schema": { 379 | "version": "2.0.0", 380 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 381 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=" 382 | }, 383 | "har-validator": { 384 | "version": "5.1.3", 385 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz", 386 | "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==", 387 | "requires": { 388 | "ajv": "^6.5.5", 389 | "har-schema": "^2.0.0" 390 | } 391 | }, 392 | "http-errors": { 393 | "version": "1.7.2", 394 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 395 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 396 | "requires": { 397 | "depd": "~1.1.2", 398 | "inherits": "2.0.3", 399 | "setprototypeof": "1.1.1", 400 | "statuses": ">= 1.5.0 < 2", 401 | "toidentifier": "1.0.0" 402 | } 403 | }, 404 | "http-signature": { 405 | "version": "1.2.0", 406 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 407 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 408 | "requires": { 409 | "assert-plus": "^1.0.0", 410 | "jsprim": "^1.2.2", 411 | "sshpk": "^1.7.0" 412 | } 413 | }, 414 | "iconv-lite": { 415 | "version": "0.4.24", 416 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 417 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 418 | "requires": { 419 | "safer-buffer": ">= 2.1.2 < 3" 420 | } 421 | }, 422 | "inherits": { 423 | "version": "2.0.3", 424 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 425 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 426 | }, 427 | "ipaddr.js": { 428 | "version": "1.9.0", 429 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.0.tgz", 430 | "integrity": "sha512-M4Sjn6N/+O6/IXSJseKqHoFc+5FdGJ22sXqnjTpdZweHK64MzEPAyQZyEU3R/KRv2GLoa7nNtg/C2Ev6m7z+eA==" 431 | }, 432 | "is-typedarray": { 433 | "version": "1.0.0", 434 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 435 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" 436 | }, 437 | "isstream": { 438 | "version": "0.1.2", 439 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 440 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" 441 | }, 442 | "jsbn": { 443 | "version": "0.1.1", 444 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 445 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=" 446 | }, 447 | "json-schema": { 448 | "version": "0.2.3", 449 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 450 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=" 451 | }, 452 | "json-schema-traverse": { 453 | "version": "0.4.1", 454 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 455 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==" 456 | }, 457 | "json-stringify-safe": { 458 | "version": "5.0.1", 459 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 460 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=" 461 | }, 462 | "jsprim": { 463 | "version": "1.4.1", 464 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 465 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 466 | "requires": { 467 | "assert-plus": "1.0.0", 468 | "extsprintf": "1.3.0", 469 | "json-schema": "0.2.3", 470 | "verror": "1.10.0" 471 | } 472 | }, 473 | "lodash": { 474 | "version": "4.17.21", 475 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 476 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 477 | }, 478 | "lru-cache": { 479 | "version": "5.1.1", 480 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", 481 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 482 | "requires": { 483 | "yallist": "^3.0.2" 484 | } 485 | }, 486 | "media-typer": { 487 | "version": "0.3.0", 488 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 489 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 490 | }, 491 | "merge-descriptors": { 492 | "version": "1.0.1", 493 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 494 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 495 | }, 496 | "methods": { 497 | "version": "1.1.2", 498 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 499 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 500 | }, 501 | "mime": { 502 | "version": "1.6.0", 503 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 504 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 505 | }, 506 | "mime-db": { 507 | "version": "1.40.0", 508 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.40.0.tgz", 509 | "integrity": "sha512-jYdeOMPy9vnxEqFRRo6ZvTZ8d9oPb+k18PKoYNYUe2stVEBPPwsln/qWzdbmaIvnhZ9v2P+CuecK+fpUfsV2mA==" 510 | }, 511 | "mime-types": { 512 | "version": "2.1.24", 513 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.24.tgz", 514 | "integrity": "sha512-WaFHS3MCl5fapm3oLxU4eYDw77IQM2ACcxQ9RIxfaC3ooc6PFuBMGZZsYpvoXS5D5QTWPieo1jjLdAm3TBP3cQ==", 515 | "requires": { 516 | "mime-db": "1.40.0" 517 | } 518 | }, 519 | "ms": { 520 | "version": "2.0.0", 521 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 522 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 523 | }, 524 | "negotiator": { 525 | "version": "0.6.2", 526 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 527 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" 528 | }, 529 | "oauth-sign": { 530 | "version": "0.9.0", 531 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", 532 | "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==" 533 | }, 534 | "on-finished": { 535 | "version": "2.3.0", 536 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 537 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 538 | "requires": { 539 | "ee-first": "1.1.1" 540 | } 541 | }, 542 | "parseurl": { 543 | "version": "1.3.3", 544 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 545 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 546 | }, 547 | "passport": { 548 | "version": "0.4.0", 549 | "resolved": "https://registry.npmjs.org/passport/-/passport-0.4.0.tgz", 550 | "integrity": "sha1-xQlWkTR71a07XhgCOMORTRbwWBE=", 551 | "requires": { 552 | "passport-strategy": "1.x.x", 553 | "pause": "0.0.1" 554 | } 555 | }, 556 | "passport-strategy": { 557 | "version": "1.0.0", 558 | "resolved": "https://registry.npmjs.org/passport-strategy/-/passport-strategy-1.0.0.tgz", 559 | "integrity": "sha1-tVOaqPwiWj0a0XlHbd8ja0QPUuQ=" 560 | }, 561 | "path-to-regexp": { 562 | "version": "0.1.7", 563 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 564 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 565 | }, 566 | "pause": { 567 | "version": "0.0.1", 568 | "resolved": "https://registry.npmjs.org/pause/-/pause-0.0.1.tgz", 569 | "integrity": "sha1-HUCLP9t2kjuVQ9lvtMnf1TXZy10=" 570 | }, 571 | "performance-now": { 572 | "version": "2.1.0", 573 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 574 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=" 575 | }, 576 | "proxy-addr": { 577 | "version": "2.0.5", 578 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.5.tgz", 579 | "integrity": "sha512-t/7RxHXPH6cJtP0pRG6smSr9QJidhB+3kXu0KgXnbGYMgzEnUxRQ4/LDdfOwZEMyIh3/xHb8PX3t+lfL9z+YVQ==", 580 | "requires": { 581 | "forwarded": "~0.1.2", 582 | "ipaddr.js": "1.9.0" 583 | } 584 | }, 585 | "psl": { 586 | "version": "1.3.1", 587 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.3.1.tgz", 588 | "integrity": "sha512-2KLd5fKOdAfShtY2d/8XDWVRnmp3zp40Qt6ge2zBPFARLXOGUf2fHD5eg+TV/5oxBtQKVhjUaKFsAaE4HnwfSA==" 589 | }, 590 | "punycode": { 591 | "version": "2.1.1", 592 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 593 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==" 594 | }, 595 | "qs": { 596 | "version": "6.7.0", 597 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 598 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" 599 | }, 600 | "range-parser": { 601 | "version": "1.2.1", 602 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 603 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 604 | }, 605 | "raw-body": { 606 | "version": "2.4.0", 607 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 608 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 609 | "requires": { 610 | "bytes": "3.1.0", 611 | "http-errors": "1.7.2", 612 | "iconv-lite": "0.4.24", 613 | "unpipe": "1.0.0" 614 | } 615 | }, 616 | "request": { 617 | "version": "2.88.0", 618 | "resolved": "https://registry.npmjs.org/request/-/request-2.88.0.tgz", 619 | "integrity": "sha512-NAqBSrijGLZdM0WZNsInLJpkJokL72XYjUpnB0iwsRgxh7dB6COrHnTBNwN0E+lHDAJzu7kLAkDeY08z2/A0hg==", 620 | "requires": { 621 | "aws-sign2": "~0.7.0", 622 | "aws4": "^1.8.0", 623 | "caseless": "~0.12.0", 624 | "combined-stream": "~1.0.6", 625 | "extend": "~3.0.2", 626 | "forever-agent": "~0.6.1", 627 | "form-data": "~2.3.2", 628 | "har-validator": "~5.1.0", 629 | "http-signature": "~1.2.0", 630 | "is-typedarray": "~1.0.0", 631 | "isstream": "~0.1.2", 632 | "json-stringify-safe": "~5.0.1", 633 | "mime-types": "~2.1.19", 634 | "oauth-sign": "~0.9.0", 635 | "performance-now": "^2.1.0", 636 | "qs": "~6.5.2", 637 | "safe-buffer": "^5.1.2", 638 | "tough-cookie": "~2.4.3", 639 | "tunnel-agent": "^0.6.0", 640 | "uuid": "^3.3.2" 641 | }, 642 | "dependencies": { 643 | "qs": { 644 | "version": "6.5.2", 645 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 646 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==" 647 | } 648 | } 649 | }, 650 | "requestretry": { 651 | "version": "4.0.0", 652 | "resolved": "https://registry.npmjs.org/requestretry/-/requestretry-4.0.0.tgz", 653 | "integrity": "sha512-ST8m0+5FQH2FA+gbzUQyOQjUwHf22kbPQnd6TexveR0p+2UV1YYBg+Roe7BnKQ1Bb/+LtJwwm0QzxK2NA20Cug==", 654 | "requires": { 655 | "extend": "^3.0.2", 656 | "lodash": "^4.17.10", 657 | "when": "^3.7.7" 658 | } 659 | }, 660 | "safe-buffer": { 661 | "version": "5.1.2", 662 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 663 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 664 | }, 665 | "safer-buffer": { 666 | "version": "2.1.2", 667 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 668 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 669 | }, 670 | "send": { 671 | "version": "0.17.1", 672 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 673 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 674 | "requires": { 675 | "debug": "2.6.9", 676 | "depd": "~1.1.2", 677 | "destroy": "~1.0.4", 678 | "encodeurl": "~1.0.2", 679 | "escape-html": "~1.0.3", 680 | "etag": "~1.8.1", 681 | "fresh": "0.5.2", 682 | "http-errors": "~1.7.2", 683 | "mime": "1.6.0", 684 | "ms": "2.1.1", 685 | "on-finished": "~2.3.0", 686 | "range-parser": "~1.2.1", 687 | "statuses": "~1.5.0" 688 | }, 689 | "dependencies": { 690 | "ms": { 691 | "version": "2.1.1", 692 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 693 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 694 | } 695 | } 696 | }, 697 | "serve-static": { 698 | "version": "1.14.1", 699 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 700 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 701 | "requires": { 702 | "encodeurl": "~1.0.2", 703 | "escape-html": "~1.0.3", 704 | "parseurl": "~1.3.3", 705 | "send": "0.17.1" 706 | } 707 | }, 708 | "setprototypeof": { 709 | "version": "1.1.1", 710 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 711 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 712 | }, 713 | "sshpk": { 714 | "version": "1.16.1", 715 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", 716 | "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", 717 | "requires": { 718 | "asn1": "~0.2.3", 719 | "assert-plus": "^1.0.0", 720 | "bcrypt-pbkdf": "^1.0.0", 721 | "dashdash": "^1.12.0", 722 | "ecc-jsbn": "~0.1.1", 723 | "getpass": "^0.1.1", 724 | "jsbn": "~0.1.0", 725 | "safer-buffer": "^2.0.2", 726 | "tweetnacl": "~0.14.0" 727 | } 728 | }, 729 | "statuses": { 730 | "version": "1.5.0", 731 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 732 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 733 | }, 734 | "toidentifier": { 735 | "version": "1.0.0", 736 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 737 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" 738 | }, 739 | "tough-cookie": { 740 | "version": "2.4.3", 741 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.4.3.tgz", 742 | "integrity": "sha512-Q5srk/4vDM54WJsJio3XNn6K2sCG+CQ8G5Wz6bZhRZoAe/+TxjWB/GlFAnYEbkYVlON9FMk/fE3h2RLpPXo4lQ==", 743 | "requires": { 744 | "psl": "^1.1.24", 745 | "punycode": "^1.4.1" 746 | }, 747 | "dependencies": { 748 | "punycode": { 749 | "version": "1.4.1", 750 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 751 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=" 752 | } 753 | } 754 | }, 755 | "tunnel-agent": { 756 | "version": "0.6.0", 757 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 758 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 759 | "requires": { 760 | "safe-buffer": "^5.0.1" 761 | } 762 | }, 763 | "tweetnacl": { 764 | "version": "0.14.5", 765 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 766 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=" 767 | }, 768 | "type-is": { 769 | "version": "1.6.18", 770 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 771 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 772 | "requires": { 773 | "media-typer": "0.3.0", 774 | "mime-types": "~2.1.24" 775 | } 776 | }, 777 | "unpipe": { 778 | "version": "1.0.0", 779 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 780 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 781 | }, 782 | "uri-js": { 783 | "version": "4.2.2", 784 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 785 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 786 | "requires": { 787 | "punycode": "^2.1.0" 788 | } 789 | }, 790 | "utils-merge": { 791 | "version": "1.0.1", 792 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 793 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 794 | }, 795 | "uuid": { 796 | "version": "3.3.3", 797 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.3.tgz", 798 | "integrity": "sha512-pW0No1RGHgzlpHJO1nsVrHKpOEIxkGg1xB+v0ZmdNH5OAeAwzAVrCnI2/6Mtx+Uys6iaylxa+D3g4j63IKKjSQ==" 799 | }, 800 | "valid-url": { 801 | "version": "1.0.9", 802 | "resolved": "https://registry.npmjs.org/valid-url/-/valid-url-1.0.9.tgz", 803 | "integrity": "sha1-HBRHm0DxOXp1eC8RXkCGRHQzogA=" 804 | }, 805 | "vary": { 806 | "version": "1.1.2", 807 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 808 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 809 | }, 810 | "verror": { 811 | "version": "1.10.0", 812 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 813 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 814 | "requires": { 815 | "assert-plus": "^1.0.0", 816 | "core-util-is": "1.0.2", 817 | "extsprintf": "^1.2.0" 818 | } 819 | }, 820 | "when": { 821 | "version": "3.7.8", 822 | "resolved": "https://registry.npmjs.org/when/-/when-3.7.8.tgz", 823 | "integrity": "sha1-xxMLan6gRpPoQs3J56Hyqjmjn4I=" 824 | }, 825 | "yallist": { 826 | "version": "3.0.3", 827 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.0.3.tgz", 828 | "integrity": "sha512-S+Zk8DEWE6oKpV+vI3qWkaK+jSbIK86pCwe2IF/xwIpQ8jEuxpw9NyaGjmp9+BoJv5FV2piqCDcoCtStppiq2A==" 829 | } 830 | } 831 | } 832 | -------------------------------------------------------------------------------- /alexa/lambda/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "lambda", 3 | "version": "0.1.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@aws-cdk/assets": { 8 | "version": "1.42.0", 9 | "resolved": "https://registry.npmjs.org/@aws-cdk/assets/-/assets-1.42.0.tgz", 10 | "integrity": "sha512-hKeON4f4J2CrIOMX9uzHI3tvNiWaCikZVon/+zQWAk5my4gVcZSApahHzSe5cKP4yqv0WW53dpBVKpHuOabBWw==", 11 | "requires": { 12 | "@aws-cdk/core": "1.42.0", 13 | "@aws-cdk/cx-api": "1.42.0", 14 | "constructs": "^3.0.2" 15 | } 16 | }, 17 | "@aws-cdk/aws-cloudwatch": { 18 | "version": "1.42.0", 19 | "resolved": "https://registry.npmjs.org/@aws-cdk/aws-cloudwatch/-/aws-cloudwatch-1.42.0.tgz", 20 | "integrity": "sha512-i8YQExCRp9XldhzN2+XDc4vVXSCsGC6llz/gnE60MRxOx2SISN4Ln56ec86Rgi/rm8bv8+LN9WfSSqZJE04XBg==", 21 | "requires": { 22 | "@aws-cdk/aws-iam": "1.42.0", 23 | "@aws-cdk/core": "1.42.0", 24 | "constructs": "^3.0.2" 25 | } 26 | }, 27 | "@aws-cdk/aws-ec2": { 28 | "version": "1.42.0", 29 | "resolved": "https://registry.npmjs.org/@aws-cdk/aws-ec2/-/aws-ec2-1.42.0.tgz", 30 | "integrity": "sha512-81jXjm7bC+RI0qnb+nHE5DQvcoh7kxMYWLGHT3hcxQAN/w7Hf5jpgEADVqkeAMah2YkpDoQJrvh5vwNF3+zmjQ==", 31 | "requires": { 32 | "@aws-cdk/aws-cloudwatch": "1.42.0", 33 | "@aws-cdk/aws-iam": "1.42.0", 34 | "@aws-cdk/aws-logs": "1.42.0", 35 | "@aws-cdk/aws-s3": "1.42.0", 36 | "@aws-cdk/aws-ssm": "1.42.0", 37 | "@aws-cdk/cloud-assembly-schema": "1.42.0", 38 | "@aws-cdk/core": "1.42.0", 39 | "@aws-cdk/cx-api": "1.42.0", 40 | "@aws-cdk/region-info": "1.42.0", 41 | "constructs": "^3.0.2" 42 | } 43 | }, 44 | "@aws-cdk/aws-events": { 45 | "version": "1.42.0", 46 | "resolved": "https://registry.npmjs.org/@aws-cdk/aws-events/-/aws-events-1.42.0.tgz", 47 | "integrity": "sha512-iuh6xRRvH3PUtQVW7GfyMxtz+QYSR1hAF8fS6QgnhgtkCaxoEFSM7Pm6s8EKnqOK6Llpmq2OJm4xiJgt1NxQ1Q==", 48 | "requires": { 49 | "@aws-cdk/aws-iam": "1.42.0", 50 | "@aws-cdk/core": "1.42.0", 51 | "constructs": "^3.0.2" 52 | } 53 | }, 54 | "@aws-cdk/aws-iam": { 55 | "version": "1.42.0", 56 | "resolved": "https://registry.npmjs.org/@aws-cdk/aws-iam/-/aws-iam-1.42.0.tgz", 57 | "integrity": "sha512-qNgD5UayjxMlwPT37cYplmOOMFiZgrzcyEm/cdIEChI0hrnLMEEWBD23TcE579p/8HaD72Jw9h0qAQCgmiY6JQ==", 58 | "requires": { 59 | "@aws-cdk/core": "1.42.0", 60 | "@aws-cdk/region-info": "1.42.0", 61 | "constructs": "^3.0.2" 62 | } 63 | }, 64 | "@aws-cdk/aws-kms": { 65 | "version": "1.42.0", 66 | "resolved": "https://registry.npmjs.org/@aws-cdk/aws-kms/-/aws-kms-1.42.0.tgz", 67 | "integrity": "sha512-SFPrmGwhR4k64pbKgGa54JhfkrAgauhdZ0ONwpIbq3bwu4bX5UIOawyLw0NAYutg/tDE287Ny/ed3HsWpoImfQ==", 68 | "requires": { 69 | "@aws-cdk/aws-iam": "1.42.0", 70 | "@aws-cdk/core": "1.42.0", 71 | "constructs": "^3.0.2" 72 | } 73 | }, 74 | "@aws-cdk/aws-lambda": { 75 | "version": "1.42.0", 76 | "resolved": "https://registry.npmjs.org/@aws-cdk/aws-lambda/-/aws-lambda-1.42.0.tgz", 77 | "integrity": "sha512-bBwUYPkbU1TXv4hFEJ/DwoFNIFEh4c22xj500d5pgLhw7hbgx2aeoRheO8ACZoc4bk1/4Q8OXuTrUUZyIIGaNw==", 78 | "requires": { 79 | "@aws-cdk/aws-cloudwatch": "1.42.0", 80 | "@aws-cdk/aws-ec2": "1.42.0", 81 | "@aws-cdk/aws-events": "1.42.0", 82 | "@aws-cdk/aws-iam": "1.42.0", 83 | "@aws-cdk/aws-logs": "1.42.0", 84 | "@aws-cdk/aws-s3": "1.42.0", 85 | "@aws-cdk/aws-s3-assets": "1.42.0", 86 | "@aws-cdk/aws-sqs": "1.42.0", 87 | "@aws-cdk/core": "1.42.0", 88 | "@aws-cdk/cx-api": "1.42.0", 89 | "constructs": "^3.0.2" 90 | } 91 | }, 92 | "@aws-cdk/aws-logs": { 93 | "version": "1.42.0", 94 | "resolved": "https://registry.npmjs.org/@aws-cdk/aws-logs/-/aws-logs-1.42.0.tgz", 95 | "integrity": "sha512-7j9q3FgEAuckcWhoJgYGKieBKOXOfvSoNCS300+tOtZDd33iKt0/Kp88c38BnudO0yK/d2e5DZvw4u6vByKzSQ==", 96 | "requires": { 97 | "@aws-cdk/aws-cloudwatch": "1.42.0", 98 | "@aws-cdk/aws-iam": "1.42.0", 99 | "@aws-cdk/core": "1.42.0", 100 | "constructs": "^3.0.2" 101 | } 102 | }, 103 | "@aws-cdk/aws-s3": { 104 | "version": "1.42.0", 105 | "resolved": "https://registry.npmjs.org/@aws-cdk/aws-s3/-/aws-s3-1.42.0.tgz", 106 | "integrity": "sha512-bszXLLIfLTM7tHt2RhOjFy3rNui4PIcf6+bwlKrz+XBD7O0lj6bl2LhLHLTre0pwEim4BHKjYI9ivYuVz4fvlw==", 107 | "requires": { 108 | "@aws-cdk/aws-events": "1.42.0", 109 | "@aws-cdk/aws-iam": "1.42.0", 110 | "@aws-cdk/aws-kms": "1.42.0", 111 | "@aws-cdk/core": "1.42.0", 112 | "constructs": "^3.0.2" 113 | } 114 | }, 115 | "@aws-cdk/aws-s3-assets": { 116 | "version": "1.42.0", 117 | "resolved": "https://registry.npmjs.org/@aws-cdk/aws-s3-assets/-/aws-s3-assets-1.42.0.tgz", 118 | "integrity": "sha512-nCYkdkPXkYOK9WAqbkOdvFpKsvuWWDQNIxN5yE5SdnPwVW6LgBESC5Zbonu1RQbBt2VambUpct82oXWinfIbcQ==", 119 | "requires": { 120 | "@aws-cdk/assets": "1.42.0", 121 | "@aws-cdk/aws-iam": "1.42.0", 122 | "@aws-cdk/aws-s3": "1.42.0", 123 | "@aws-cdk/core": "1.42.0", 124 | "@aws-cdk/cx-api": "1.42.0", 125 | "constructs": "^3.0.2" 126 | } 127 | }, 128 | "@aws-cdk/aws-sqs": { 129 | "version": "1.42.0", 130 | "resolved": "https://registry.npmjs.org/@aws-cdk/aws-sqs/-/aws-sqs-1.42.0.tgz", 131 | "integrity": "sha512-GMOi8+zIqhdYmso4Xw1be43mp7MOYQHVfpmSm981hyPbiol2nZ8708qcGdTTHbQuF7hql4p8H5ZyIrEXcHRgAQ==", 132 | "requires": { 133 | "@aws-cdk/aws-cloudwatch": "1.42.0", 134 | "@aws-cdk/aws-iam": "1.42.0", 135 | "@aws-cdk/aws-kms": "1.42.0", 136 | "@aws-cdk/core": "1.42.0", 137 | "constructs": "^3.0.2" 138 | } 139 | }, 140 | "@aws-cdk/aws-ssm": { 141 | "version": "1.42.0", 142 | "resolved": "https://registry.npmjs.org/@aws-cdk/aws-ssm/-/aws-ssm-1.42.0.tgz", 143 | "integrity": "sha512-UpJMgKKvJBEpgV7mUygiKwGMo68zs2bmDjSOnNCxIhypFGAAJDIfabw1mn32ESQwm0N+80Q/bnnx1rxnXVfAeA==", 144 | "requires": { 145 | "@aws-cdk/aws-iam": "1.42.0", 146 | "@aws-cdk/aws-kms": "1.42.0", 147 | "@aws-cdk/cloud-assembly-schema": "1.42.0", 148 | "@aws-cdk/core": "1.42.0", 149 | "constructs": "^3.0.2" 150 | } 151 | }, 152 | "@aws-cdk/cdk-assets-schema": { 153 | "version": "1.42.0", 154 | "resolved": "https://registry.npmjs.org/@aws-cdk/cdk-assets-schema/-/cdk-assets-schema-1.42.0.tgz", 155 | "integrity": "sha512-dKBKLKN1Z0HSe0lO1OOdr3m9WGYRNs+PJ0WrcFMlEHsgei+4VSvIhLozJwQFcEJd8BYTPEgAofM7mcXyJjKf/A==", 156 | "requires": { 157 | "semver": "^7.2.2" 158 | }, 159 | "dependencies": { 160 | "semver": { 161 | "version": "7.3.2", 162 | "bundled": true 163 | } 164 | } 165 | }, 166 | "@aws-cdk/cloud-assembly-schema": { 167 | "version": "1.42.0", 168 | "resolved": "https://registry.npmjs.org/@aws-cdk/cloud-assembly-schema/-/cloud-assembly-schema-1.42.0.tgz", 169 | "integrity": "sha512-2HX1dAvNc9eUSwJ1uXZofH5ulwPj6LeeX3vJ6plwuHBDIgmp9o3Ziaavfpk6gn2AFoiIpDdotNbKQkmKw7dDPA==", 170 | "requires": { 171 | "jsonschema": "^1.2.5", 172 | "semver": "^7.2.2" 173 | }, 174 | "dependencies": { 175 | "jsonschema": { 176 | "version": "1.2.6", 177 | "bundled": true 178 | }, 179 | "semver": { 180 | "version": "7.3.2", 181 | "bundled": true 182 | } 183 | } 184 | }, 185 | "@aws-cdk/core": { 186 | "version": "1.42.0", 187 | "resolved": "https://registry.npmjs.org/@aws-cdk/core/-/core-1.42.0.tgz", 188 | "integrity": "sha512-UJxkMLyGWRuIoyUvbU18QhUIS0HpxdGEkj0zYEQ0W4IHQz2a/SpZyvkpo/D/brderj22cViAq7ap8CZBBLSzqg==", 189 | "requires": { 190 | "@aws-cdk/cdk-assets-schema": "1.42.0", 191 | "@aws-cdk/cloud-assembly-schema": "1.42.0", 192 | "@aws-cdk/cx-api": "1.42.0", 193 | "constructs": "^3.0.2", 194 | "minimatch": "^3.0.4" 195 | }, 196 | "dependencies": { 197 | "balanced-match": { 198 | "version": "1.0.0", 199 | "bundled": true 200 | }, 201 | "brace-expansion": { 202 | "version": "1.1.11", 203 | "bundled": true, 204 | "requires": { 205 | "balanced-match": "^1.0.0", 206 | "concat-map": "0.0.1" 207 | } 208 | }, 209 | "concat-map": { 210 | "version": "0.0.1", 211 | "bundled": true 212 | }, 213 | "minimatch": { 214 | "version": "3.0.4", 215 | "bundled": true, 216 | "requires": { 217 | "brace-expansion": "^1.1.7" 218 | } 219 | } 220 | } 221 | }, 222 | "@aws-cdk/cx-api": { 223 | "version": "1.42.0", 224 | "resolved": "https://registry.npmjs.org/@aws-cdk/cx-api/-/cx-api-1.42.0.tgz", 225 | "integrity": "sha512-yOa/AXhWuF1nXSxho8PrWfFOAUEr9qSZ2n+8hggZDDbUq8f5P1mhUARY7cNOVxW8GCtNfUmG1Wbo2NrNYtM8qw==", 226 | "requires": { 227 | "@aws-cdk/cloud-assembly-schema": "1.42.0", 228 | "semver": "^7.2.2" 229 | }, 230 | "dependencies": { 231 | "semver": { 232 | "version": "7.3.2", 233 | "bundled": true 234 | } 235 | } 236 | }, 237 | "@aws-cdk/region-info": { 238 | "version": "1.42.0", 239 | "resolved": "https://registry.npmjs.org/@aws-cdk/region-info/-/region-info-1.42.0.tgz", 240 | "integrity": "sha512-IFeIZY9s+1phWsAzUA7FLSEFIQ2Yoxw93wPMBzUfULKXImp9KM0FM4qwPamXxNmRpY/9+ZXBTlsYq9U29bmOig==" 241 | }, 242 | "aws-cdk": { 243 | "version": "1.42.0", 244 | "resolved": "https://registry.npmjs.org/aws-cdk/-/aws-cdk-1.42.0.tgz", 245 | "integrity": "sha512-S4ISTiJGuuLEK1JXd/vbOrkmZ6psUFWp4ml1F3JAfMyAntPRXx2J6VVOPex90X6+NCYDEY00eic3MCOlNQMgFw==", 246 | "dev": true, 247 | "requires": { 248 | "@aws-cdk/cdk-assets-schema": "1.42.0", 249 | "@aws-cdk/cloud-assembly-schema": "1.42.0", 250 | "@aws-cdk/cloudformation-diff": "1.42.0", 251 | "@aws-cdk/cx-api": "1.42.0", 252 | "@aws-cdk/region-info": "1.42.0", 253 | "archiver": "^4.0.1", 254 | "aws-sdk": "^2.681.0", 255 | "camelcase": "^6.0.0", 256 | "cdk-assets": "1.42.0", 257 | "colors": "^1.4.0", 258 | "decamelize": "^4.0.0", 259 | "fs-extra": "^8.1.0", 260 | "glob": "^7.1.6", 261 | "json-diff": "^0.5.4", 262 | "minimatch": ">=3.0", 263 | "promptly": "^3.0.3", 264 | "proxy-agent": "^3.1.1", 265 | "semver": "^7.2.2", 266 | "source-map-support": "^0.5.19", 267 | "table": "^5.4.6", 268 | "uuid": "^8.1.0", 269 | "yaml": "^1.10.0", 270 | "yargs": "^15.3.1" 271 | }, 272 | "dependencies": { 273 | "@aws-cdk/cdk-assets-schema": { 274 | "version": "1.42.0", 275 | "resolved": "https://registry.npmjs.org/@aws-cdk/cdk-assets-schema/-/cdk-assets-schema-1.42.0.tgz", 276 | "integrity": "sha512-dKBKLKN1Z0HSe0lO1OOdr3m9WGYRNs+PJ0WrcFMlEHsgei+4VSvIhLozJwQFcEJd8BYTPEgAofM7mcXyJjKf/A==", 277 | "dev": true, 278 | "requires": { 279 | "semver": "^7.2.2" 280 | } 281 | }, 282 | "@aws-cdk/cfnspec": { 283 | "version": "1.42.0", 284 | "resolved": "https://registry.npmjs.org/@aws-cdk/cfnspec/-/cfnspec-1.42.0.tgz", 285 | "integrity": "sha512-HS8Crs0/bvT6d2STd5P6hTCjmr0b7eCse5XIHS6fqUozlD2OxG+TwxpinS+j+9qhz5QHVnSQ/q7N/D0SP3VTzg==", 286 | "dev": true, 287 | "requires": { 288 | "md5": "^2.2.1" 289 | } 290 | }, 291 | "@aws-cdk/cloud-assembly-schema": { 292 | "version": "1.42.0", 293 | "resolved": "https://registry.npmjs.org/@aws-cdk/cloud-assembly-schema/-/cloud-assembly-schema-1.42.0.tgz", 294 | "integrity": "sha512-2HX1dAvNc9eUSwJ1uXZofH5ulwPj6LeeX3vJ6plwuHBDIgmp9o3Ziaavfpk6gn2AFoiIpDdotNbKQkmKw7dDPA==", 295 | "dev": true, 296 | "requires": { 297 | "jsonschema": "^1.2.5", 298 | "semver": "^7.2.2" 299 | } 300 | }, 301 | "@aws-cdk/cloudformation-diff": { 302 | "version": "1.42.0", 303 | "resolved": "https://registry.npmjs.org/@aws-cdk/cloudformation-diff/-/cloudformation-diff-1.42.0.tgz", 304 | "integrity": "sha512-F/IUxzD2tFxQy0QERR9kPurnWqELMrVEJZE1i0CDN3O9RqKqv/2K1p9IPd8sTESB6dWem2Tqvnj9jHoCR0L30A==", 305 | "dev": true, 306 | "requires": { 307 | "@aws-cdk/cfnspec": "1.42.0", 308 | "colors": "^1.4.0", 309 | "diff": "^4.0.2", 310 | "fast-deep-equal": "^3.1.1", 311 | "string-width": "^4.2.0", 312 | "table": "^5.4.6" 313 | } 314 | }, 315 | "@aws-cdk/cx-api": { 316 | "version": "1.42.0", 317 | "resolved": "https://registry.npmjs.org/@aws-cdk/cx-api/-/cx-api-1.42.0.tgz", 318 | "integrity": "sha512-yOa/AXhWuF1nXSxho8PrWfFOAUEr9qSZ2n+8hggZDDbUq8f5P1mhUARY7cNOVxW8GCtNfUmG1Wbo2NrNYtM8qw==", 319 | "dev": true, 320 | "requires": { 321 | "@aws-cdk/cloud-assembly-schema": "1.42.0", 322 | "semver": "^7.2.2" 323 | } 324 | }, 325 | "@aws-cdk/region-info": { 326 | "version": "1.42.0", 327 | "resolved": "https://registry.npmjs.org/@aws-cdk/region-info/-/region-info-1.42.0.tgz", 328 | "integrity": "sha512-IFeIZY9s+1phWsAzUA7FLSEFIQ2Yoxw93wPMBzUfULKXImp9KM0FM4qwPamXxNmRpY/9+ZXBTlsYq9U29bmOig==", 329 | "dev": true 330 | }, 331 | "@types/color-name": { 332 | "version": "1.1.1", 333 | "resolved": "https://registry.yarnpkg.com/@types/color-name/-/color-name-1.1.1.tgz#1c1261bbeaa10a8055bbc5d8ab84b7b2afc846a0", 334 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==", 335 | "dev": true 336 | }, 337 | "agent-base": { 338 | "version": "4.3.0", 339 | "resolved": "https://registry.yarnpkg.com/agent-base/-/agent-base-4.3.0.tgz#8165f01c436009bccad0b1d122f05ed770efc6ee", 340 | "integrity": "sha512-salcGninV0nPrwpGNn4VTXBb1SOuXQBiqbrNXoeizJsHrsL6ERFM2Ne3JUSBWRE6aeNJI2ROP/WEEIDUiDe3cg==", 341 | "dev": true, 342 | "requires": { 343 | "es6-promisify": "^5.0.0" 344 | } 345 | }, 346 | "ajv": { 347 | "version": "6.12.2", 348 | "resolved": "https://registry.yarnpkg.com/ajv/-/ajv-6.12.2.tgz#c629c5eced17baf314437918d2da88c99d5958cd", 349 | "integrity": "sha512-k+V+hzjm5q/Mr8ef/1Y9goCmlsK4I6Sm74teeyGvFk1XrOsbsKLjEdrvny42CZ+a8sXbk8KWpY/bDwS+FLL2UQ==", 350 | "dev": true, 351 | "requires": { 352 | "fast-deep-equal": "^3.1.1", 353 | "fast-json-stable-stringify": "^2.0.0", 354 | "json-schema-traverse": "^0.4.1", 355 | "uri-js": "^4.2.2" 356 | } 357 | }, 358 | "ansi-regex": { 359 | "version": "5.0.0", 360 | "resolved": "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.0.tgz#388539f55179bf39339c81af30a654d69f87cb75", 361 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 362 | "dev": true 363 | }, 364 | "ansi-styles": { 365 | "version": "3.2.1", 366 | "resolved": "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.1.tgz#41fbb20243e50b12be0f04b8dedbf07520ce841d", 367 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 368 | "dev": true, 369 | "requires": { 370 | "color-convert": "^1.9.0" 371 | } 372 | }, 373 | "archiver": { 374 | "version": "4.0.1", 375 | "resolved": "https://registry.yarnpkg.com/archiver/-/archiver-4.0.1.tgz#3f722b121777e361ca9fad374ecda38e77e63c7f", 376 | "integrity": "sha512-/YV1pU4Nhpf/rJArM23W6GTUjT0l++VbjykrCRua1TSXrn+yM8Qs7XvtwSiRse0iCe49EPNf7ktXnPsWuSb91Q==", 377 | "dev": true, 378 | "requires": { 379 | "archiver-utils": "^2.1.0", 380 | "async": "^2.6.3", 381 | "buffer-crc32": "^0.2.1", 382 | "glob": "^7.1.6", 383 | "readable-stream": "^3.6.0", 384 | "tar-stream": "^2.1.2", 385 | "zip-stream": "^3.0.1" 386 | }, 387 | "dependencies": { 388 | "readable-stream": { 389 | "version": "3.6.0", 390 | "resolved": "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.0.tgz#337bbda3adc0706bd3e024426a286d4b4b2c9198", 391 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 392 | "dev": true, 393 | "requires": { 394 | "inherits": "^2.0.3", 395 | "string_decoder": "^1.1.1", 396 | "util-deprecate": "^1.0.1" 397 | } 398 | }, 399 | "safe-buffer": { 400 | "version": "5.2.0", 401 | "resolved": "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.0.tgz#b74daec49b1148f88c64b68d49b1e815c1f2f519", 402 | "integrity": "sha512-fZEwUGbVl7kouZs1jCdMLdt95hdIv0ZeHg6L7qPeciMZhZ+/gdesW4wgTARkrFWEpspjEATAzUGPG8N2jJiwbg==", 403 | "dev": true 404 | }, 405 | "string_decoder": { 406 | "version": "1.3.0", 407 | "resolved": "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e", 408 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 409 | "dev": true, 410 | "requires": { 411 | "safe-buffer": "~5.2.0" 412 | } 413 | } 414 | } 415 | }, 416 | "archiver-utils": { 417 | "version": "2.1.0", 418 | "resolved": "https://registry.yarnpkg.com/archiver-utils/-/archiver-utils-2.1.0.tgz#e8a460e94b693c3e3da182a098ca6285ba9249e2", 419 | "integrity": "sha512-bEL/yUb/fNNiNTuUz979Z0Yg5L+LzLxGJz8x79lYmR54fmTIb6ob/hNQgkQnIUDWIFjZVQwl9Xs356I6BAMHfw==", 420 | "dev": true, 421 | "requires": { 422 | "glob": "^7.1.4", 423 | "graceful-fs": "^4.2.0", 424 | "lazystream": "^1.0.0", 425 | "lodash.defaults": "^4.2.0", 426 | "lodash.difference": "^4.5.0", 427 | "lodash.flatten": "^4.4.0", 428 | "lodash.isplainobject": "^4.0.6", 429 | "lodash.union": "^4.6.0", 430 | "normalize-path": "^3.0.0", 431 | "readable-stream": "^2.0.0" 432 | } 433 | }, 434 | "ast-types": { 435 | "version": "0.13.3", 436 | "resolved": "https://registry.yarnpkg.com/ast-types/-/ast-types-0.13.3.tgz#50da3f28d17bdbc7969a3a2d83a0e4a72ae755a7", 437 | "integrity": "sha512-XTZ7xGML849LkQP86sWdQzfhwbt3YwIO6MqbX9mUNYY98VKaaVZP7YNNm70IpwecbkkxmfC5IYAzOQ/2p29zRA==", 438 | "dev": true 439 | }, 440 | "astral-regex": { 441 | "version": "1.0.0", 442 | "resolved": "https://registry.yarnpkg.com/astral-regex/-/astral-regex-1.0.0.tgz#6c8c3fb827dd43ee3918f27b82782ab7658a6fd9", 443 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 444 | "dev": true 445 | }, 446 | "async": { 447 | "version": "2.6.3", 448 | "resolved": "https://registry.yarnpkg.com/async/-/async-2.6.3.tgz#d72625e2344a3656e3a3ad4fa749fa83299d82ff", 449 | "integrity": "sha512-zflvls11DCy+dQWzTW2dzuilv8Z5X/pjfmZOWba6TNIVDm+2UDaJmXSOXlasHKfNBs8oo3M0aT50fDEWfKZjXg==", 450 | "dev": true, 451 | "requires": { 452 | "lodash": "^4.17.14" 453 | } 454 | }, 455 | "aws-sdk": { 456 | "version": "2.681.0", 457 | "resolved": "https://registry.yarnpkg.com/aws-sdk/-/aws-sdk-2.681.0.tgz#09eeedb5ca49813dfc637908abe408ae114a6824", 458 | "integrity": "sha512-/p8CDJ7LZvB1i4WrJrb32FUbbPdiZFZSN6FI2lv7s/scKypmuv/iJ9kpx6QWSWQZ72kJ3Njk/0o7GuVlw0jHXw==", 459 | "dev": true, 460 | "requires": { 461 | "buffer": "4.9.1", 462 | "events": "1.1.1", 463 | "ieee754": "1.1.13", 464 | "jmespath": "0.15.0", 465 | "querystring": "0.2.0", 466 | "sax": "1.2.1", 467 | "url": "0.10.3", 468 | "uuid": "3.3.2", 469 | "xml2js": "0.4.19" 470 | }, 471 | "dependencies": { 472 | "buffer": { 473 | "version": "4.9.1", 474 | "resolved": "https://registry.yarnpkg.com/buffer/-/buffer-4.9.1.tgz#6d1bb601b07a4efced97094132093027c95bc298", 475 | "integrity": "sha1-bRu2AbB6TvztlwlBMgkwJ8lbwpg=", 476 | "dev": true, 477 | "requires": { 478 | "base64-js": "^1.0.2", 479 | "ieee754": "^1.1.4", 480 | "isarray": "^1.0.0" 481 | } 482 | }, 483 | "uuid": { 484 | "version": "3.3.2", 485 | "resolved": "https://registry.yarnpkg.com/uuid/-/uuid-3.3.2.tgz#1b4af4955eb3077c501c23872fc6513811587131", 486 | "integrity": "sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA==", 487 | "dev": true 488 | } 489 | } 490 | }, 491 | "balanced-match": { 492 | "version": "1.0.0", 493 | "resolved": "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.0.tgz#89b4d199ab2bee49de164ea02b89ce462d71b767", 494 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 495 | "dev": true 496 | }, 497 | "base64-js": { 498 | "version": "1.3.1", 499 | "resolved": "https://registry.yarnpkg.com/base64-js/-/base64-js-1.3.1.tgz#58ece8cb75dd07e71ed08c736abc5fac4dbf8df1", 500 | "integrity": "sha512-mLQ4i2QO1ytvGWFWmcngKO//JXAQueZvwEKtjgQFM4jIK0kU+ytMfplL8j+n5mspOfjHwoAg+9yhb7BwAHm36g==", 501 | "dev": true 502 | }, 503 | "bl": { 504 | "version": "4.0.2", 505 | "resolved": "https://registry.yarnpkg.com/bl/-/bl-4.0.2.tgz#52b71e9088515d0606d9dd9cc7aa48dc1f98e73a", 506 | "integrity": "sha512-j4OH8f6Qg2bGuWfRiltT2HYGx0e1QcBTrK9KAHNMwMZdQnDZFk0ZSYIpADjYCB3U12nicC5tVJwSIhwOWjb4RQ==", 507 | "dev": true, 508 | "requires": { 509 | "buffer": "^5.5.0", 510 | "inherits": "^2.0.4", 511 | "readable-stream": "^3.4.0" 512 | }, 513 | "dependencies": { 514 | "readable-stream": { 515 | "version": "3.6.0", 516 | "resolved": "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.0.tgz#337bbda3adc0706bd3e024426a286d4b4b2c9198", 517 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 518 | "dev": true, 519 | "requires": { 520 | "inherits": "^2.0.3", 521 | "string_decoder": "^1.1.1", 522 | "util-deprecate": "^1.0.1" 523 | } 524 | }, 525 | "safe-buffer": { 526 | "version": "5.2.0", 527 | "resolved": "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.0.tgz#b74daec49b1148f88c64b68d49b1e815c1f2f519", 528 | "integrity": "sha512-fZEwUGbVl7kouZs1jCdMLdt95hdIv0ZeHg6L7qPeciMZhZ+/gdesW4wgTARkrFWEpspjEATAzUGPG8N2jJiwbg==", 529 | "dev": true 530 | }, 531 | "string_decoder": { 532 | "version": "1.3.0", 533 | "resolved": "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e", 534 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 535 | "dev": true, 536 | "requires": { 537 | "safe-buffer": "~5.2.0" 538 | } 539 | } 540 | } 541 | }, 542 | "brace-expansion": { 543 | "version": "1.1.11", 544 | "resolved": "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd", 545 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 546 | "dev": true, 547 | "requires": { 548 | "balanced-match": "^1.0.0", 549 | "concat-map": "0.0.1" 550 | } 551 | }, 552 | "buffer": { 553 | "version": "5.6.0", 554 | "resolved": "https://registry.yarnpkg.com/buffer/-/buffer-5.6.0.tgz#a31749dc7d81d84db08abf937b6b8c4033f62786", 555 | "integrity": "sha512-/gDYp/UtU0eA1ys8bOs9J6a+E/KWIY+DZ+Q2WESNUA0jFRsJOc0SNUO6xJ5SGA1xueg3NL65W6s+NY5l9cunuw==", 556 | "dev": true, 557 | "requires": { 558 | "base64-js": "^1.0.2", 559 | "ieee754": "^1.1.4" 560 | } 561 | }, 562 | "buffer-crc32": { 563 | "version": "0.2.13", 564 | "resolved": "https://registry.yarnpkg.com/buffer-crc32/-/buffer-crc32-0.2.13.tgz#0d333e3f00eac50aa1454abd30ef8c2a5d9a7242", 565 | "integrity": "sha1-DTM+PwDqxQqhRUq9MO+MKl2ackI=", 566 | "dev": true 567 | }, 568 | "buffer-from": { 569 | "version": "1.1.1", 570 | "resolved": "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.1.tgz#32713bc028f75c02fdb710d7c7bcec1f2c6070ef", 571 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", 572 | "dev": true 573 | }, 574 | "bytes": { 575 | "version": "3.1.0", 576 | "resolved": "https://registry.yarnpkg.com/bytes/-/bytes-3.1.0.tgz#f6cf7933a360e0588fa9fde85651cdc7f805d1f6", 577 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==", 578 | "dev": true 579 | }, 580 | "camelcase": { 581 | "version": "6.0.0", 582 | "resolved": "https://registry.yarnpkg.com/camelcase/-/camelcase-6.0.0.tgz#5259f7c30e35e278f1bdc2a4d91230b37cad981e", 583 | "integrity": "sha512-8KMDF1Vz2gzOq54ONPJS65IvTUaB1cHJ2DMM7MbPmLZljDH1qpzzLsWdiN9pHh6qvkRVDTi/07+eNGch/oLU4w==", 584 | "dev": true 585 | }, 586 | "cdk-assets": { 587 | "version": "1.42.0", 588 | "resolved": "https://registry.npmjs.org/cdk-assets/-/cdk-assets-1.42.0.tgz", 589 | "integrity": "sha512-nav0MbB3ReNj3ipwOlnrCIhmLyeomhjxku8hFi7inrfIZgXueuH9S54ylQgXcIpEofIK09Bx5ijcMT2fdjAKFQ==", 590 | "dev": true, 591 | "requires": { 592 | "@aws-cdk/cdk-assets-schema": "1.42.0", 593 | "@aws-cdk/cx-api": "1.42.0", 594 | "archiver": "^4.0.1", 595 | "aws-sdk": "^2.681.0", 596 | "glob": "^7.1.6", 597 | "yargs": "^15.3.1" 598 | } 599 | }, 600 | "charenc": { 601 | "version": "0.0.2", 602 | "resolved": "https://registry.yarnpkg.com/charenc/-/charenc-0.0.2.tgz#c0a1d2f3a7092e03774bfa83f14c0fc5790a8667", 603 | "integrity": "sha1-wKHS86cJLgN3S/qD8UwPxXkKhmc=", 604 | "dev": true 605 | }, 606 | "cli-color": { 607 | "version": "0.1.7", 608 | "resolved": "https://registry.yarnpkg.com/cli-color/-/cli-color-0.1.7.tgz#adc3200fa471cc211b0da7f566b71e98b9d67347", 609 | "integrity": "sha1-rcMgD6RxzCEbDaf1ZrcemLnWc0c=", 610 | "dev": true, 611 | "requires": { 612 | "es5-ext": "0.8.x" 613 | } 614 | }, 615 | "cliui": { 616 | "version": "6.0.0", 617 | "resolved": "https://registry.yarnpkg.com/cliui/-/cliui-6.0.0.tgz#511d702c0c4e41ca156d7d0e96021f23e13225b1", 618 | "integrity": "sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ==", 619 | "dev": true, 620 | "requires": { 621 | "string-width": "^4.2.0", 622 | "strip-ansi": "^6.0.0", 623 | "wrap-ansi": "^6.2.0" 624 | } 625 | }, 626 | "co": { 627 | "version": "4.6.0", 628 | "resolved": "https://registry.yarnpkg.com/co/-/co-4.6.0.tgz#6ea6bdf3d853ae54ccb8e47bfa0bf3f9031fb184", 629 | "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=", 630 | "dev": true 631 | }, 632 | "color-convert": { 633 | "version": "1.9.3", 634 | "resolved": "https://registry.yarnpkg.com/color-convert/-/color-convert-1.9.3.tgz#bb71850690e1f136567de629d2d5471deda4c1e8", 635 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 636 | "dev": true, 637 | "requires": { 638 | "color-name": "1.1.3" 639 | } 640 | }, 641 | "color-name": { 642 | "version": "1.1.3", 643 | "resolved": "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25", 644 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 645 | "dev": true 646 | }, 647 | "colors": { 648 | "version": "1.4.0", 649 | "resolved": "https://registry.yarnpkg.com/colors/-/colors-1.4.0.tgz#c50491479d4c1bdaed2c9ced32cf7c7dc2360f78", 650 | "integrity": "sha512-a+UqTh4kgZg/SlGvfbzDHpgRu7AAQOmmqRHJnxhRZICKFUT91brVhNNt58CMWU9PsBbv3PDCZUHbVxuDiH2mtA==", 651 | "dev": true 652 | }, 653 | "compress-commons": { 654 | "version": "3.0.0", 655 | "resolved": "https://registry.yarnpkg.com/compress-commons/-/compress-commons-3.0.0.tgz#833944d84596e537224dd91cf92f5246823d4f1d", 656 | "integrity": "sha512-FyDqr8TKX5/X0qo+aVfaZ+PVmNJHJeckFBlq8jZGSJOgnynhfifoyl24qaqdUdDIBe0EVTHByN6NAkqYvE/2Xg==", 657 | "dev": true, 658 | "requires": { 659 | "buffer-crc32": "^0.2.13", 660 | "crc32-stream": "^3.0.1", 661 | "normalize-path": "^3.0.0", 662 | "readable-stream": "^2.3.7" 663 | } 664 | }, 665 | "concat-map": { 666 | "version": "0.0.1", 667 | "resolved": "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b", 668 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 669 | "dev": true 670 | }, 671 | "core-util-is": { 672 | "version": "1.0.2", 673 | "resolved": "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7", 674 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 675 | "dev": true 676 | }, 677 | "crc": { 678 | "version": "3.8.0", 679 | "resolved": "https://registry.yarnpkg.com/crc/-/crc-3.8.0.tgz#ad60269c2c856f8c299e2c4cc0de4556914056c6", 680 | "integrity": "sha512-iX3mfgcTMIq3ZKLIsVFAbv7+Mc10kxabAGQb8HvjA1o3T1PIYprbakQ65d3I+2HGHt6nSKkM9PYjgoJO2KcFBQ==", 681 | "dev": true, 682 | "requires": { 683 | "buffer": "^5.1.0" 684 | } 685 | }, 686 | "crc32-stream": { 687 | "version": "3.0.1", 688 | "resolved": "https://registry.yarnpkg.com/crc32-stream/-/crc32-stream-3.0.1.tgz#cae6eeed003b0e44d739d279de5ae63b171b4e85", 689 | "integrity": "sha512-mctvpXlbzsvK+6z8kJwSJ5crm7yBwrQMTybJzMw1O4lLGJqjlDCXY2Zw7KheiA6XBEcBmfLx1D88mjRGVJtY9w==", 690 | "dev": true, 691 | "requires": { 692 | "crc": "^3.4.4", 693 | "readable-stream": "^3.4.0" 694 | }, 695 | "dependencies": { 696 | "readable-stream": { 697 | "version": "3.6.0", 698 | "resolved": "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.0.tgz#337bbda3adc0706bd3e024426a286d4b4b2c9198", 699 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 700 | "dev": true, 701 | "requires": { 702 | "inherits": "^2.0.3", 703 | "string_decoder": "^1.1.1", 704 | "util-deprecate": "^1.0.1" 705 | } 706 | }, 707 | "safe-buffer": { 708 | "version": "5.2.0", 709 | "resolved": "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.0.tgz#b74daec49b1148f88c64b68d49b1e815c1f2f519", 710 | "integrity": "sha512-fZEwUGbVl7kouZs1jCdMLdt95hdIv0ZeHg6L7qPeciMZhZ+/gdesW4wgTARkrFWEpspjEATAzUGPG8N2jJiwbg==", 711 | "dev": true 712 | }, 713 | "string_decoder": { 714 | "version": "1.3.0", 715 | "resolved": "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e", 716 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 717 | "dev": true, 718 | "requires": { 719 | "safe-buffer": "~5.2.0" 720 | } 721 | } 722 | } 723 | }, 724 | "crypt": { 725 | "version": "0.0.2", 726 | "resolved": "https://registry.yarnpkg.com/crypt/-/crypt-0.0.2.tgz#88d7ff7ec0dfb86f713dc87bbb42d044d3e6c41b", 727 | "integrity": "sha1-iNf/fsDfuG9xPch7u0LQRNPmxBs=", 728 | "dev": true 729 | }, 730 | "data-uri-to-buffer": { 731 | "version": "1.2.0", 732 | "resolved": "https://registry.yarnpkg.com/data-uri-to-buffer/-/data-uri-to-buffer-1.2.0.tgz#77163ea9c20d8641b4707e8f18abdf9a78f34835", 733 | "integrity": "sha512-vKQ9DTQPN1FLYiiEEOQ6IBGFqvjCa5rSK3cWMy/Nespm5d/x3dGFT9UBZnkLxCwua/IXBi2TYnwTEpsOvhC4UQ==", 734 | "dev": true 735 | }, 736 | "debug": { 737 | "version": "4.1.1", 738 | "resolved": "https://registry.yarnpkg.com/debug/-/debug-4.1.1.tgz#3b72260255109c6b589cee050f1d516139664791", 739 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 740 | "dev": true, 741 | "requires": { 742 | "ms": "^2.1.1" 743 | } 744 | }, 745 | "decamelize": { 746 | "version": "4.0.0", 747 | "resolved": "https://registry.yarnpkg.com/decamelize/-/decamelize-4.0.0.tgz#aa472d7bf660eb15f3494efd531cab7f2a709837", 748 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 749 | "dev": true 750 | }, 751 | "deep-is": { 752 | "version": "0.1.3", 753 | "resolved": "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.3.tgz#b369d6fb5dbc13eecf524f91b070feedc357cf34", 754 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 755 | "dev": true 756 | }, 757 | "degenerator": { 758 | "version": "1.0.4", 759 | "resolved": "https://registry.yarnpkg.com/degenerator/-/degenerator-1.0.4.tgz#fcf490a37ece266464d9cc431ab98c5819ced095", 760 | "integrity": "sha1-/PSQo37OJmRk2cxDGrmMWBnO0JU=", 761 | "dev": true, 762 | "requires": { 763 | "ast-types": "0.x.x", 764 | "escodegen": "1.x.x", 765 | "esprima": "3.x.x" 766 | } 767 | }, 768 | "depd": { 769 | "version": "1.1.2", 770 | "resolved": "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9", 771 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=", 772 | "dev": true 773 | }, 774 | "diff": { 775 | "version": "4.0.2", 776 | "resolved": "https://registry.yarnpkg.com/diff/-/diff-4.0.2.tgz#60f3aecb89d5fae520c11aa19efc2bb982aade7d", 777 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 778 | "dev": true 779 | }, 780 | "difflib": { 781 | "version": "0.2.4", 782 | "resolved": "https://registry.yarnpkg.com/difflib/-/difflib-0.2.4.tgz#b5e30361a6db023176d562892db85940a718f47e", 783 | "integrity": "sha1-teMDYabbAjF21WKJLbhZQKcY9H4=", 784 | "dev": true, 785 | "requires": { 786 | "heap": ">= 0.2.0" 787 | } 788 | }, 789 | "dreamopt": { 790 | "version": "0.6.0", 791 | "resolved": "https://registry.yarnpkg.com/dreamopt/-/dreamopt-0.6.0.tgz#d813ccdac8d39d8ad526775514a13dda664d6b4b", 792 | "integrity": "sha1-2BPM2sjTnYrVJndVFKE92mZNa0s=", 793 | "dev": true, 794 | "requires": { 795 | "wordwrap": ">=0.0.2" 796 | } 797 | }, 798 | "emoji-regex": { 799 | "version": "8.0.0", 800 | "resolved": "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37", 801 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 802 | "dev": true 803 | }, 804 | "end-of-stream": { 805 | "version": "1.4.4", 806 | "resolved": "https://registry.yarnpkg.com/end-of-stream/-/end-of-stream-1.4.4.tgz#5ae64a5f45057baf3626ec14da0ca5e4b2431eb0", 807 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 808 | "dev": true, 809 | "requires": { 810 | "once": "^1.4.0" 811 | } 812 | }, 813 | "es5-ext": { 814 | "version": "0.8.2", 815 | "resolved": "https://registry.yarnpkg.com/es5-ext/-/es5-ext-0.8.2.tgz#aba8d9e1943a895ac96837a62a39b3f55ecd94ab", 816 | "integrity": "sha1-q6jZ4ZQ6iVrJaDemKjmz9V7NlKs=", 817 | "dev": true 818 | }, 819 | "es6-promise": { 820 | "version": "4.2.8", 821 | "resolved": "https://registry.yarnpkg.com/es6-promise/-/es6-promise-4.2.8.tgz#4eb21594c972bc40553d276e510539143db53e0a", 822 | "integrity": "sha512-HJDGx5daxeIvxdBxvG2cb9g4tEvwIk3i8+nhX0yGrYmZUzbkdg8QbDevheDB8gd0//uPj4c1EQua8Q+MViT0/w==", 823 | "dev": true 824 | }, 825 | "es6-promisify": { 826 | "version": "5.0.0", 827 | "resolved": "https://registry.yarnpkg.com/es6-promisify/-/es6-promisify-5.0.0.tgz#5109d62f3e56ea967c4b63505aef08291c8a5203", 828 | "integrity": "sha1-UQnWLz5W6pZ8S2NQWu8IKRyKUgM=", 829 | "dev": true, 830 | "requires": { 831 | "es6-promise": "^4.0.3" 832 | } 833 | }, 834 | "escodegen": { 835 | "version": "1.14.1", 836 | "resolved": "https://registry.yarnpkg.com/escodegen/-/escodegen-1.14.1.tgz#ba01d0c8278b5e95a9a45350142026659027a457", 837 | "integrity": "sha512-Bmt7NcRySdIfNPfU2ZoXDrrXsG9ZjvDxcAlMfDUgRBjLOWTuIACXPBFJH7Z+cLb40JeQco5toikyc9t9P8E9SQ==", 838 | "dev": true, 839 | "requires": { 840 | "esprima": "^4.0.1", 841 | "estraverse": "^4.2.0", 842 | "esutils": "^2.0.2", 843 | "optionator": "^0.8.1", 844 | "source-map": "~0.6.1" 845 | }, 846 | "dependencies": { 847 | "esprima": { 848 | "version": "4.0.1", 849 | "resolved": "https://registry.yarnpkg.com/esprima/-/esprima-4.0.1.tgz#13b04cdb3e6c5d19df91ab6987a8695619b0aa71", 850 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 851 | "dev": true 852 | } 853 | } 854 | }, 855 | "esprima": { 856 | "version": "3.1.3", 857 | "resolved": "https://registry.yarnpkg.com/esprima/-/esprima-3.1.3.tgz#fdca51cee6133895e3c88d535ce49dbff62a4633", 858 | "integrity": "sha1-/cpRzuYTOJXjyI1TXOSdv/YqRjM=", 859 | "dev": true 860 | }, 861 | "estraverse": { 862 | "version": "4.3.0", 863 | "resolved": "https://registry.yarnpkg.com/estraverse/-/estraverse-4.3.0.tgz#398ad3f3c5a24948be7725e83d11a7de28cdbd1d", 864 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 865 | "dev": true 866 | }, 867 | "esutils": { 868 | "version": "2.0.3", 869 | "resolved": "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64", 870 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 871 | "dev": true 872 | }, 873 | "events": { 874 | "version": "1.1.1", 875 | "resolved": "https://registry.yarnpkg.com/events/-/events-1.1.1.tgz#9ebdb7635ad099c70dcc4c2a1f5004288e8bd924", 876 | "integrity": "sha1-nr23Y1rQmccNzEwqH1AEKI6L2SQ=", 877 | "dev": true 878 | }, 879 | "extend": { 880 | "version": "3.0.2", 881 | "resolved": "https://registry.yarnpkg.com/extend/-/extend-3.0.2.tgz#f8b1136b4071fbd8eb140aff858b1019ec2915fa", 882 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 883 | "dev": true 884 | }, 885 | "fast-deep-equal": { 886 | "version": "3.1.1", 887 | "resolved": "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.1.tgz#545145077c501491e33b15ec408c294376e94ae4", 888 | "integrity": "sha512-8UEa58QDLauDNfpbrX55Q9jrGHThw2ZMdOky5Gl1CDtVeJDPVrG4Jxx1N8jw2gkWaff5UUuX1KJd+9zGe2B+ZA==", 889 | "dev": true 890 | }, 891 | "fast-json-stable-stringify": { 892 | "version": "2.1.0", 893 | "resolved": "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633", 894 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 895 | "dev": true 896 | }, 897 | "fast-levenshtein": { 898 | "version": "2.0.6", 899 | "resolved": "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917", 900 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 901 | "dev": true 902 | }, 903 | "file-uri-to-path": { 904 | "version": "1.0.0", 905 | "resolved": "https://registry.yarnpkg.com/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz#553a7b8446ff6f684359c445f1e37a05dacc33dd", 906 | "integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==", 907 | "dev": true 908 | }, 909 | "find-up": { 910 | "version": "4.1.0", 911 | "resolved": "https://registry.yarnpkg.com/find-up/-/find-up-4.1.0.tgz#97afe7d6cdc0bc5928584b7c8d7b16e8a9aa5d19", 912 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 913 | "dev": true, 914 | "requires": { 915 | "locate-path": "^5.0.0", 916 | "path-exists": "^4.0.0" 917 | } 918 | }, 919 | "fs-constants": { 920 | "version": "1.0.0", 921 | "resolved": "https://registry.yarnpkg.com/fs-constants/-/fs-constants-1.0.0.tgz#6be0de9be998ce16af8afc24497b9ee9b7ccd9ad", 922 | "integrity": "sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow==", 923 | "dev": true 924 | }, 925 | "fs-extra": { 926 | "version": "8.1.0", 927 | "resolved": "https://registry.yarnpkg.com/fs-extra/-/fs-extra-8.1.0.tgz#49d43c45a88cd9677668cb7be1b46efdb8d2e1c0", 928 | "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", 929 | "dev": true, 930 | "requires": { 931 | "graceful-fs": "^4.2.0", 932 | "jsonfile": "^4.0.0", 933 | "universalify": "^0.1.0" 934 | } 935 | }, 936 | "fs.realpath": { 937 | "version": "1.0.0", 938 | "resolved": "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f", 939 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 940 | "dev": true 941 | }, 942 | "ftp": { 943 | "version": "0.3.10", 944 | "resolved": "https://registry.yarnpkg.com/ftp/-/ftp-0.3.10.tgz#9197d861ad8142f3e63d5a83bfe4c59f7330885d", 945 | "integrity": "sha1-kZfYYa2BQvPmPVqDv+TFn3MwiF0=", 946 | "dev": true, 947 | "requires": { 948 | "readable-stream": "1.1.x", 949 | "xregexp": "2.0.0" 950 | }, 951 | "dependencies": { 952 | "isarray": { 953 | "version": "0.0.1", 954 | "resolved": "https://registry.yarnpkg.com/isarray/-/isarray-0.0.1.tgz#8a18acfca9a8f4177e09abfc6038939b05d1eedf", 955 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", 956 | "dev": true 957 | }, 958 | "readable-stream": { 959 | "version": "1.1.14", 960 | "resolved": "https://registry.yarnpkg.com/readable-stream/-/readable-stream-1.1.14.tgz#7cf4c54ef648e3813084c636dd2079e166c081d9", 961 | "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", 962 | "dev": true, 963 | "requires": { 964 | "core-util-is": "~1.0.0", 965 | "inherits": "~2.0.1", 966 | "isarray": "0.0.1", 967 | "string_decoder": "~0.10.x" 968 | } 969 | }, 970 | "string_decoder": { 971 | "version": "0.10.31", 972 | "resolved": "https://registry.yarnpkg.com/string_decoder/-/string_decoder-0.10.31.tgz#62e203bc41766c6c28c9fc84301dab1c5310fa94", 973 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", 974 | "dev": true 975 | } 976 | } 977 | }, 978 | "get-caller-file": { 979 | "version": "2.0.5", 980 | "resolved": "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-2.0.5.tgz#4f94412a82db32f36e3b0b9741f8a97feb031f7e", 981 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 982 | "dev": true 983 | }, 984 | "get-uri": { 985 | "version": "2.0.4", 986 | "resolved": "https://registry.yarnpkg.com/get-uri/-/get-uri-2.0.4.tgz#d4937ab819e218d4cb5ae18e4f5962bef169cc6a", 987 | "integrity": "sha512-v7LT/s8kVjs+Tx0ykk1I+H/rbpzkHvuIq87LmeXptcf5sNWm9uQiwjNAt94SJPA1zOlCntmnOlJvVWKmzsxG8Q==", 988 | "dev": true, 989 | "requires": { 990 | "data-uri-to-buffer": "1", 991 | "debug": "2", 992 | "extend": "~3.0.2", 993 | "file-uri-to-path": "1", 994 | "ftp": "~0.3.10", 995 | "readable-stream": "2" 996 | }, 997 | "dependencies": { 998 | "debug": { 999 | "version": "2.6.9", 1000 | "resolved": "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f", 1001 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1002 | "dev": true, 1003 | "requires": { 1004 | "ms": "2.0.0" 1005 | } 1006 | }, 1007 | "ms": { 1008 | "version": "2.0.0", 1009 | "resolved": "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8", 1010 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1011 | "dev": true 1012 | } 1013 | } 1014 | }, 1015 | "glob": { 1016 | "version": "7.1.6", 1017 | "resolved": "https://registry.yarnpkg.com/glob/-/glob-7.1.6.tgz#141f33b81a7c2492e125594307480c46679278a6", 1018 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 1019 | "dev": true, 1020 | "requires": { 1021 | "fs.realpath": "^1.0.0", 1022 | "inflight": "^1.0.4", 1023 | "inherits": "2", 1024 | "minimatch": "^3.0.4", 1025 | "once": "^1.3.0", 1026 | "path-is-absolute": "^1.0.0" 1027 | } 1028 | }, 1029 | "graceful-fs": { 1030 | "version": "4.2.3", 1031 | "resolved": "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.3.tgz#4a12ff1b60376ef09862c2093edd908328be8423", 1032 | "integrity": "sha512-a30VEBm4PEdx1dRB7MFK7BejejvCvBronbLjht+sHuGYj8PHs7M/5Z+rt5lw551vZ7yfTCj4Vuyy3mSJytDWRQ==", 1033 | "dev": true 1034 | }, 1035 | "heap": { 1036 | "version": "0.2.6", 1037 | "resolved": "https://registry.yarnpkg.com/heap/-/heap-0.2.6.tgz#087e1f10b046932fc8594dd9e6d378afc9d1e5ac", 1038 | "integrity": "sha1-CH4fELBGky/IWU3Z5tN4r8nR5aw=", 1039 | "dev": true 1040 | }, 1041 | "http-errors": { 1042 | "version": "1.7.3", 1043 | "resolved": "https://registry.yarnpkg.com/http-errors/-/http-errors-1.7.3.tgz#6c619e4f9c60308c38519498c14fbb10aacebb06", 1044 | "integrity": "sha512-ZTTX0MWrsQ2ZAhA1cejAwDLycFsd7I7nVtnkT3Ol0aqodaKW+0CTZDQ1uBv5whptCnc8e8HeRRJxRs0kmm/Qfw==", 1045 | "dev": true, 1046 | "requires": { 1047 | "depd": "~1.1.2", 1048 | "inherits": "2.0.4", 1049 | "setprototypeof": "1.1.1", 1050 | "statuses": ">= 1.5.0 < 2", 1051 | "toidentifier": "1.0.0" 1052 | } 1053 | }, 1054 | "http-proxy-agent": { 1055 | "version": "2.1.0", 1056 | "resolved": "https://registry.yarnpkg.com/http-proxy-agent/-/http-proxy-agent-2.1.0.tgz#e4821beef5b2142a2026bd73926fe537631c5405", 1057 | "integrity": "sha512-qwHbBLV7WviBl0rQsOzH6o5lwyOIvwp/BdFnvVxXORldu5TmjFfjzBcWUWS5kWAZhmv+JtiDhSuQCp4sBfbIgg==", 1058 | "dev": true, 1059 | "requires": { 1060 | "agent-base": "4", 1061 | "debug": "3.1.0" 1062 | }, 1063 | "dependencies": { 1064 | "debug": { 1065 | "version": "3.1.0", 1066 | "resolved": "https://registry.yarnpkg.com/debug/-/debug-3.1.0.tgz#5bb5a0672628b64149566ba16819e61518c67261", 1067 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 1068 | "dev": true, 1069 | "requires": { 1070 | "ms": "2.0.0" 1071 | } 1072 | }, 1073 | "ms": { 1074 | "version": "2.0.0", 1075 | "resolved": "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8", 1076 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1077 | "dev": true 1078 | } 1079 | } 1080 | }, 1081 | "https-proxy-agent": { 1082 | "version": "3.0.1", 1083 | "resolved": "https://registry.yarnpkg.com/https-proxy-agent/-/https-proxy-agent-3.0.1.tgz#b8c286433e87602311b01c8ea34413d856a4af81", 1084 | "integrity": "sha512-+ML2Rbh6DAuee7d07tYGEKOEi2voWPUGan+ExdPbPW6Z3svq+JCqr0v8WmKPOkz1vOVykPCBSuobe7G8GJUtVg==", 1085 | "dev": true, 1086 | "requires": { 1087 | "agent-base": "^4.3.0", 1088 | "debug": "^3.1.0" 1089 | }, 1090 | "dependencies": { 1091 | "debug": { 1092 | "version": "3.2.6", 1093 | "resolved": "https://registry.yarnpkg.com/debug/-/debug-3.2.6.tgz#e83d17de16d8a7efb7717edbe5fb10135eee629b", 1094 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 1095 | "dev": true, 1096 | "requires": { 1097 | "ms": "^2.1.1" 1098 | } 1099 | } 1100 | } 1101 | }, 1102 | "iconv-lite": { 1103 | "version": "0.4.24", 1104 | "resolved": "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz#2022b4b25fbddc21d2f524974a474aafe733908b", 1105 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1106 | "dev": true, 1107 | "requires": { 1108 | "safer-buffer": ">= 2.1.2 < 3" 1109 | } 1110 | }, 1111 | "ieee754": { 1112 | "version": "1.1.13", 1113 | "resolved": "https://registry.yarnpkg.com/ieee754/-/ieee754-1.1.13.tgz#ec168558e95aa181fd87d37f55c32bbcb6708b84", 1114 | "integrity": "sha512-4vf7I2LYV/HaWerSo3XmlMkp5eZ83i+/CDluXi/IGTs/O1sejBNhTtnxzmRZfvOUqj7lZjqHkeTvpgSFDlWZTg==", 1115 | "dev": true 1116 | }, 1117 | "inflight": { 1118 | "version": "1.0.6", 1119 | "resolved": "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9", 1120 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1121 | "dev": true, 1122 | "requires": { 1123 | "once": "^1.3.0", 1124 | "wrappy": "1" 1125 | } 1126 | }, 1127 | "inherits": { 1128 | "version": "2.0.4", 1129 | "resolved": "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c", 1130 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1131 | "dev": true 1132 | }, 1133 | "ip": { 1134 | "version": "1.1.5", 1135 | "resolved": "https://registry.yarnpkg.com/ip/-/ip-1.1.5.tgz#bdded70114290828c0a039e72ef25f5aaec4354a", 1136 | "integrity": "sha1-vd7XARQpCCjAoDnnLvJfWq7ENUo=", 1137 | "dev": true 1138 | }, 1139 | "is-buffer": { 1140 | "version": "1.1.6", 1141 | "resolved": "https://registry.yarnpkg.com/is-buffer/-/is-buffer-1.1.6.tgz#efaa2ea9daa0d7ab2ea13a97b2b8ad51fefbe8be", 1142 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", 1143 | "dev": true 1144 | }, 1145 | "is-fullwidth-code-point": { 1146 | "version": "3.0.0", 1147 | "resolved": "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d", 1148 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1149 | "dev": true 1150 | }, 1151 | "isarray": { 1152 | "version": "1.0.0", 1153 | "resolved": "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11", 1154 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1155 | "dev": true 1156 | }, 1157 | "jmespath": { 1158 | "version": "0.15.0", 1159 | "resolved": "https://registry.yarnpkg.com/jmespath/-/jmespath-0.15.0.tgz#a3f222a9aae9f966f5d27c796510e28091764217", 1160 | "integrity": "sha1-o/Iiqarp+Wb10nx5ZRDigJF2Qhc=", 1161 | "dev": true 1162 | }, 1163 | "json-diff": { 1164 | "version": "0.5.4", 1165 | "resolved": "https://registry.yarnpkg.com/json-diff/-/json-diff-0.5.4.tgz#7bc8198c441756632aab66c7d9189d365a7a035a", 1166 | "integrity": "sha512-q5Xmx9QXNOzOzIlMoYtLrLiu4Jl/Ce2bn0CNcv54PhyH89CI4GWlGVDye8ei2Ijt9R3U+vsWPsXpLUNob8bs8Q==", 1167 | "dev": true, 1168 | "requires": { 1169 | "cli-color": "~0.1.6", 1170 | "difflib": "~0.2.1", 1171 | "dreamopt": "~0.6.0" 1172 | } 1173 | }, 1174 | "json-schema-traverse": { 1175 | "version": "0.4.1", 1176 | "resolved": "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660", 1177 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1178 | "dev": true 1179 | }, 1180 | "jsonfile": { 1181 | "version": "4.0.0", 1182 | "resolved": "https://registry.yarnpkg.com/jsonfile/-/jsonfile-4.0.0.tgz#8771aae0799b64076b76640fca058f9c10e33ecb", 1183 | "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", 1184 | "dev": true, 1185 | "requires": { 1186 | "graceful-fs": "^4.1.6" 1187 | } 1188 | }, 1189 | "jsonschema": { 1190 | "version": "1.2.6", 1191 | "resolved": "https://registry.yarnpkg.com/jsonschema/-/jsonschema-1.2.6.tgz#52b0a8e9dc06bbae7295249d03e4b9faee8a0c0b", 1192 | "integrity": "sha512-SqhURKZG07JyKKeo/ir24QnS4/BV7a6gQy93bUSe4lUdNp0QNpIz2c9elWJQ9dpc5cQYY6cvCzgRwy0MQCLyqA==", 1193 | "dev": true 1194 | }, 1195 | "lazystream": { 1196 | "version": "1.0.0", 1197 | "resolved": "https://registry.yarnpkg.com/lazystream/-/lazystream-1.0.0.tgz#f6995fe0f820392f61396be89462407bb77168e4", 1198 | "integrity": "sha1-9plf4PggOS9hOWvolGJAe7dxaOQ=", 1199 | "dev": true, 1200 | "requires": { 1201 | "readable-stream": "^2.0.5" 1202 | } 1203 | }, 1204 | "levn": { 1205 | "version": "0.3.0", 1206 | "resolved": "https://registry.yarnpkg.com/levn/-/levn-0.3.0.tgz#3b09924edf9f083c0490fdd4c0bc4421e04764ee", 1207 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 1208 | "dev": true, 1209 | "requires": { 1210 | "prelude-ls": "~1.1.2", 1211 | "type-check": "~0.3.2" 1212 | } 1213 | }, 1214 | "locate-path": { 1215 | "version": "5.0.0", 1216 | "resolved": "https://registry.yarnpkg.com/locate-path/-/locate-path-5.0.0.tgz#1afba396afd676a6d42504d0a67a3a7eb9f62aa0", 1217 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 1218 | "dev": true, 1219 | "requires": { 1220 | "p-locate": "^4.1.0" 1221 | } 1222 | }, 1223 | "lodash": { 1224 | "version": "4.17.15", 1225 | "resolved": "https://registry.yarnpkg.com/lodash/-/lodash-4.17.15.tgz#b447f6670a0455bbfeedd11392eff330ea097548", 1226 | "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==", 1227 | "dev": true 1228 | }, 1229 | "lodash.defaults": { 1230 | "version": "4.2.0", 1231 | "resolved": "https://registry.yarnpkg.com/lodash.defaults/-/lodash.defaults-4.2.0.tgz#d09178716ffea4dde9e5fb7b37f6f0802274580c", 1232 | "integrity": "sha1-0JF4cW/+pN3p5ft7N/bwgCJ0WAw=", 1233 | "dev": true 1234 | }, 1235 | "lodash.difference": { 1236 | "version": "4.5.0", 1237 | "resolved": "https://registry.yarnpkg.com/lodash.difference/-/lodash.difference-4.5.0.tgz#9ccb4e505d486b91651345772885a2df27fd017c", 1238 | "integrity": "sha1-nMtOUF1Ia5FlE0V3KIWi3yf9AXw=", 1239 | "dev": true 1240 | }, 1241 | "lodash.flatten": { 1242 | "version": "4.4.0", 1243 | "resolved": "https://registry.yarnpkg.com/lodash.flatten/-/lodash.flatten-4.4.0.tgz#f31c22225a9632d2bbf8e4addbef240aa765a61f", 1244 | "integrity": "sha1-8xwiIlqWMtK7+OSt2+8kCqdlph8=", 1245 | "dev": true 1246 | }, 1247 | "lodash.isplainobject": { 1248 | "version": "4.0.6", 1249 | "resolved": "https://registry.yarnpkg.com/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz#7c526a52d89b45c45cc690b88163be0497f550cb", 1250 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs=", 1251 | "dev": true 1252 | }, 1253 | "lodash.union": { 1254 | "version": "4.6.0", 1255 | "resolved": "https://registry.yarnpkg.com/lodash.union/-/lodash.union-4.6.0.tgz#48bb5088409f16f1821666641c44dd1aaae3cd88", 1256 | "integrity": "sha1-SLtQiECfFvGCFmZkHETdGqrjzYg=", 1257 | "dev": true 1258 | }, 1259 | "lru-cache": { 1260 | "version": "5.1.1", 1261 | "resolved": "https://registry.yarnpkg.com/lru-cache/-/lru-cache-5.1.1.tgz#1da27e6710271947695daf6848e847f01d84b920", 1262 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 1263 | "dev": true, 1264 | "requires": { 1265 | "yallist": "^3.0.2" 1266 | } 1267 | }, 1268 | "md5": { 1269 | "version": "2.2.1", 1270 | "resolved": "https://registry.yarnpkg.com/md5/-/md5-2.2.1.tgz#53ab38d5fe3c8891ba465329ea23fac0540126f9", 1271 | "integrity": "sha1-U6s41f48iJG6RlMp6iP6wFQBJvk=", 1272 | "dev": true, 1273 | "requires": { 1274 | "charenc": "~0.0.1", 1275 | "crypt": "~0.0.1", 1276 | "is-buffer": "~1.1.1" 1277 | } 1278 | }, 1279 | "minimatch": { 1280 | "version": "3.0.4", 1281 | "resolved": "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083", 1282 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1283 | "dev": true, 1284 | "requires": { 1285 | "brace-expansion": "^1.1.7" 1286 | } 1287 | }, 1288 | "ms": { 1289 | "version": "2.1.2", 1290 | "resolved": "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009", 1291 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1292 | "dev": true 1293 | }, 1294 | "mute-stream": { 1295 | "version": "0.0.8", 1296 | "resolved": "https://registry.yarnpkg.com/mute-stream/-/mute-stream-0.0.8.tgz#1630c42b2251ff81e2a283de96a5497ea92e5e0d", 1297 | "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==", 1298 | "dev": true 1299 | }, 1300 | "netmask": { 1301 | "version": "1.0.6", 1302 | "resolved": "https://registry.yarnpkg.com/netmask/-/netmask-1.0.6.tgz#20297e89d86f6f6400f250d9f4f6b4c1945fcd35", 1303 | "integrity": "sha1-ICl+idhvb2QA8lDZ9Pa0wZRfzTU=", 1304 | "dev": true 1305 | }, 1306 | "normalize-path": { 1307 | "version": "3.0.0", 1308 | "resolved": "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65", 1309 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1310 | "dev": true 1311 | }, 1312 | "once": { 1313 | "version": "1.4.0", 1314 | "resolved": "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1", 1315 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1316 | "dev": true, 1317 | "requires": { 1318 | "wrappy": "1" 1319 | } 1320 | }, 1321 | "optionator": { 1322 | "version": "0.8.3", 1323 | "resolved": "https://registry.yarnpkg.com/optionator/-/optionator-0.8.3.tgz#84fa1d036fe9d3c7e21d99884b601167ec8fb495", 1324 | "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", 1325 | "dev": true, 1326 | "requires": { 1327 | "deep-is": "~0.1.3", 1328 | "fast-levenshtein": "~2.0.6", 1329 | "levn": "~0.3.0", 1330 | "prelude-ls": "~1.1.2", 1331 | "type-check": "~0.3.2", 1332 | "word-wrap": "~1.2.3" 1333 | } 1334 | }, 1335 | "p-limit": { 1336 | "version": "2.3.0", 1337 | "resolved": "https://registry.yarnpkg.com/p-limit/-/p-limit-2.3.0.tgz#3dd33c647a214fdfffd835933eb086da0dc21db1", 1338 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 1339 | "dev": true, 1340 | "requires": { 1341 | "p-try": "^2.0.0" 1342 | } 1343 | }, 1344 | "p-locate": { 1345 | "version": "4.1.0", 1346 | "resolved": "https://registry.yarnpkg.com/p-locate/-/p-locate-4.1.0.tgz#a3428bb7088b3a60292f66919278b7c297ad4f07", 1347 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 1348 | "dev": true, 1349 | "requires": { 1350 | "p-limit": "^2.2.0" 1351 | } 1352 | }, 1353 | "p-try": { 1354 | "version": "2.2.0", 1355 | "resolved": "https://registry.yarnpkg.com/p-try/-/p-try-2.2.0.tgz#cb2868540e313d61de58fafbe35ce9004d5540e6", 1356 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 1357 | "dev": true 1358 | }, 1359 | "pac-proxy-agent": { 1360 | "version": "3.0.1", 1361 | "resolved": "https://registry.yarnpkg.com/pac-proxy-agent/-/pac-proxy-agent-3.0.1.tgz#115b1e58f92576cac2eba718593ca7b0e37de2ad", 1362 | "integrity": "sha512-44DUg21G/liUZ48dJpUSjZnFfZro/0K5JTyFYLBcmh9+T6Ooi4/i4efwUiEy0+4oQusCBqWdhv16XohIj1GqnQ==", 1363 | "dev": true, 1364 | "requires": { 1365 | "agent-base": "^4.2.0", 1366 | "debug": "^4.1.1", 1367 | "get-uri": "^2.0.0", 1368 | "http-proxy-agent": "^2.1.0", 1369 | "https-proxy-agent": "^3.0.0", 1370 | "pac-resolver": "^3.0.0", 1371 | "raw-body": "^2.2.0", 1372 | "socks-proxy-agent": "^4.0.1" 1373 | } 1374 | }, 1375 | "pac-resolver": { 1376 | "version": "3.0.0", 1377 | "resolved": "https://registry.yarnpkg.com/pac-resolver/-/pac-resolver-3.0.0.tgz#6aea30787db0a891704deb7800a722a7615a6f26", 1378 | "integrity": "sha512-tcc38bsjuE3XZ5+4vP96OfhOugrX+JcnpUbhfuc4LuXBLQhoTthOstZeoQJBDnQUDYzYmdImKsbz0xSl1/9qeA==", 1379 | "dev": true, 1380 | "requires": { 1381 | "co": "^4.6.0", 1382 | "degenerator": "^1.0.4", 1383 | "ip": "^1.1.5", 1384 | "netmask": "^1.0.6", 1385 | "thunkify": "^2.1.2" 1386 | } 1387 | }, 1388 | "path-exists": { 1389 | "version": "4.0.0", 1390 | "resolved": "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3", 1391 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1392 | "dev": true 1393 | }, 1394 | "path-is-absolute": { 1395 | "version": "1.0.1", 1396 | "resolved": "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f", 1397 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1398 | "dev": true 1399 | }, 1400 | "pify": { 1401 | "version": "3.0.0", 1402 | "resolved": "https://registry.yarnpkg.com/pify/-/pify-3.0.0.tgz#e5a4acd2c101fdf3d9a4d07f0dbc4db49dd28176", 1403 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", 1404 | "dev": true 1405 | }, 1406 | "prelude-ls": { 1407 | "version": "1.1.2", 1408 | "resolved": "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.1.2.tgz#21932a549f5e52ffd9a827f570e04be62a97da54", 1409 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 1410 | "dev": true 1411 | }, 1412 | "process-nextick-args": { 1413 | "version": "2.0.1", 1414 | "resolved": "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.1.tgz#7820d9b16120cc55ca9ae7792680ae7dba6d7fe2", 1415 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 1416 | "dev": true 1417 | }, 1418 | "promptly": { 1419 | "version": "3.0.3", 1420 | "resolved": "https://registry.yarnpkg.com/promptly/-/promptly-3.0.3.tgz#e178f722e73d82c60d019462044bccfdd9872f42", 1421 | "integrity": "sha512-EWnzOsxVKUjqKeE6SStH1/cO4+DE44QolaoJ4ojGd9z6pcNkpgfJKr1ncwxrOFHSTIzoudo7jG8y0re30/LO1g==", 1422 | "dev": true, 1423 | "requires": { 1424 | "pify": "^3.0.0", 1425 | "read": "^1.0.4" 1426 | } 1427 | }, 1428 | "proxy-agent": { 1429 | "version": "3.1.1", 1430 | "resolved": "https://registry.yarnpkg.com/proxy-agent/-/proxy-agent-3.1.1.tgz#7e04e06bf36afa624a1540be247b47c970bd3014", 1431 | "integrity": "sha512-WudaR0eTsDx33O3EJE16PjBRZWcX8GqCEeERw1W3hZJgH/F2a46g7jty6UGty6NeJ4CKQy8ds2CJPMiyeqaTvw==", 1432 | "dev": true, 1433 | "requires": { 1434 | "agent-base": "^4.2.0", 1435 | "debug": "4", 1436 | "http-proxy-agent": "^2.1.0", 1437 | "https-proxy-agent": "^3.0.0", 1438 | "lru-cache": "^5.1.1", 1439 | "pac-proxy-agent": "^3.0.1", 1440 | "proxy-from-env": "^1.0.0", 1441 | "socks-proxy-agent": "^4.0.1" 1442 | } 1443 | }, 1444 | "proxy-from-env": { 1445 | "version": "1.1.0", 1446 | "resolved": "https://registry.yarnpkg.com/proxy-from-env/-/proxy-from-env-1.1.0.tgz#e102f16ca355424865755d2c9e8ea4f24d58c3e2", 1447 | "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==", 1448 | "dev": true 1449 | }, 1450 | "punycode": { 1451 | "version": "1.3.2", 1452 | "resolved": "https://registry.yarnpkg.com/punycode/-/punycode-1.3.2.tgz#9653a036fb7c1ee42342f2325cceefea3926c48d", 1453 | "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=", 1454 | "dev": true 1455 | }, 1456 | "querystring": { 1457 | "version": "0.2.0", 1458 | "resolved": "https://registry.yarnpkg.com/querystring/-/querystring-0.2.0.tgz#b209849203bb25df820da756e747005878521620", 1459 | "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=", 1460 | "dev": true 1461 | }, 1462 | "raw-body": { 1463 | "version": "2.4.1", 1464 | "resolved": "https://registry.yarnpkg.com/raw-body/-/raw-body-2.4.1.tgz#30ac82f98bb5ae8c152e67149dac8d55153b168c", 1465 | "integrity": "sha512-9WmIKF6mkvA0SLmA2Knm9+qj89e+j1zqgyn8aXGd7+nAduPoqgI9lO57SAZNn/Byzo5P7JhXTyg9PzaJbH73bA==", 1466 | "dev": true, 1467 | "requires": { 1468 | "bytes": "3.1.0", 1469 | "http-errors": "1.7.3", 1470 | "iconv-lite": "0.4.24", 1471 | "unpipe": "1.0.0" 1472 | } 1473 | }, 1474 | "read": { 1475 | "version": "1.0.7", 1476 | "resolved": "https://registry.yarnpkg.com/read/-/read-1.0.7.tgz#b3da19bd052431a97671d44a42634adf710b40c4", 1477 | "integrity": "sha1-s9oZvQUkMal2cdRKQmNK33ELQMQ=", 1478 | "dev": true, 1479 | "requires": { 1480 | "mute-stream": "~0.0.4" 1481 | } 1482 | }, 1483 | "readable-stream": { 1484 | "version": "2.3.7", 1485 | "resolved": "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.7.tgz#1eca1cf711aef814c04f62252a36a62f6cb23b57", 1486 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 1487 | "dev": true, 1488 | "requires": { 1489 | "core-util-is": "~1.0.0", 1490 | "inherits": "~2.0.3", 1491 | "isarray": "~1.0.0", 1492 | "process-nextick-args": "~2.0.0", 1493 | "safe-buffer": "~5.1.1", 1494 | "string_decoder": "~1.1.1", 1495 | "util-deprecate": "~1.0.1" 1496 | } 1497 | }, 1498 | "require-directory": { 1499 | "version": "2.1.1", 1500 | "resolved": "https://registry.yarnpkg.com/require-directory/-/require-directory-2.1.1.tgz#8c64ad5fd30dab1c976e2344ffe7f792a6a6df42", 1501 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 1502 | "dev": true 1503 | }, 1504 | "require-main-filename": { 1505 | "version": "2.0.0", 1506 | "resolved": "https://registry.yarnpkg.com/require-main-filename/-/require-main-filename-2.0.0.tgz#d0b329ecc7cc0f61649f62215be69af54aa8989b", 1507 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", 1508 | "dev": true 1509 | }, 1510 | "safe-buffer": { 1511 | "version": "5.1.2", 1512 | "resolved": "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d", 1513 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 1514 | "dev": true 1515 | }, 1516 | "safer-buffer": { 1517 | "version": "2.1.2", 1518 | "resolved": "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a", 1519 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1520 | "dev": true 1521 | }, 1522 | "sax": { 1523 | "version": "1.2.1", 1524 | "resolved": "https://registry.yarnpkg.com/sax/-/sax-1.2.1.tgz#7b8e656190b228e81a66aea748480d828cd2d37a", 1525 | "integrity": "sha1-e45lYZCyKOgaZq6nSEgNgozS03o=", 1526 | "dev": true 1527 | }, 1528 | "semver": { 1529 | "version": "7.3.2", 1530 | "resolved": "https://registry.yarnpkg.com/semver/-/semver-7.3.2.tgz#604962b052b81ed0786aae84389ffba70ffd3938", 1531 | "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", 1532 | "dev": true 1533 | }, 1534 | "set-blocking": { 1535 | "version": "2.0.0", 1536 | "resolved": "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7", 1537 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", 1538 | "dev": true 1539 | }, 1540 | "setprototypeof": { 1541 | "version": "1.1.1", 1542 | "resolved": "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.1.1.tgz#7e95acb24aa92f5885e0abef5ba131330d4ae683", 1543 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==", 1544 | "dev": true 1545 | }, 1546 | "slice-ansi": { 1547 | "version": "2.1.0", 1548 | "resolved": "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-2.1.0.tgz#cacd7693461a637a5788d92a7dd4fba068e81636", 1549 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 1550 | "dev": true, 1551 | "requires": { 1552 | "ansi-styles": "^3.2.0", 1553 | "astral-regex": "^1.0.0", 1554 | "is-fullwidth-code-point": "^2.0.0" 1555 | }, 1556 | "dependencies": { 1557 | "is-fullwidth-code-point": { 1558 | "version": "2.0.0", 1559 | "resolved": "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz#a3b30a5c4f199183167aaab93beefae3ddfb654f", 1560 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1561 | "dev": true 1562 | } 1563 | } 1564 | }, 1565 | "smart-buffer": { 1566 | "version": "4.1.0", 1567 | "resolved": "https://registry.yarnpkg.com/smart-buffer/-/smart-buffer-4.1.0.tgz#91605c25d91652f4661ea69ccf45f1b331ca21ba", 1568 | "integrity": "sha512-iVICrxOzCynf/SNaBQCw34eM9jROU/s5rzIhpOvzhzuYHfJR/DhZfDkXiZSgKXfgv26HT3Yni3AV/DGw0cGnnw==", 1569 | "dev": true 1570 | }, 1571 | "socks": { 1572 | "version": "2.3.3", 1573 | "resolved": "https://registry.yarnpkg.com/socks/-/socks-2.3.3.tgz#01129f0a5d534d2b897712ed8aceab7ee65d78e3", 1574 | "integrity": "sha512-o5t52PCNtVdiOvzMry7wU4aOqYWL0PeCXRWBEiJow4/i/wr+wpsJQ9awEu1EonLIqsfGd5qSgDdxEOvCdmBEpA==", 1575 | "dev": true, 1576 | "requires": { 1577 | "ip": "1.1.5", 1578 | "smart-buffer": "^4.1.0" 1579 | } 1580 | }, 1581 | "socks-proxy-agent": { 1582 | "version": "4.0.2", 1583 | "resolved": "https://registry.yarnpkg.com/socks-proxy-agent/-/socks-proxy-agent-4.0.2.tgz#3c8991f3145b2799e70e11bd5fbc8b1963116386", 1584 | "integrity": "sha512-NT6syHhI9LmuEMSK6Kd2V7gNv5KFZoLE7V5udWmn0de+3Mkj3UMA/AJPLyeNUVmElCurSHtUdM3ETpR3z770Wg==", 1585 | "dev": true, 1586 | "requires": { 1587 | "agent-base": "~4.2.1", 1588 | "socks": "~2.3.2" 1589 | }, 1590 | "dependencies": { 1591 | "agent-base": { 1592 | "version": "4.2.1", 1593 | "resolved": "https://registry.yarnpkg.com/agent-base/-/agent-base-4.2.1.tgz#d89e5999f797875674c07d87f260fc41e83e8ca9", 1594 | "integrity": "sha512-JVwXMr9nHYTUXsBFKUqhJwvlcYU/blreOEUkhNR2eXZIvwd+c+o5V4MgDPKWnMS/56awN3TRzIP+KoPn+roQtg==", 1595 | "dev": true, 1596 | "requires": { 1597 | "es6-promisify": "^5.0.0" 1598 | } 1599 | } 1600 | } 1601 | }, 1602 | "source-map": { 1603 | "version": "0.6.1", 1604 | "resolved": "https://registry.yarnpkg.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263", 1605 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1606 | "dev": true 1607 | }, 1608 | "source-map-support": { 1609 | "version": "0.5.19", 1610 | "resolved": "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.19.tgz#a98b62f86dcaf4f67399648c085291ab9e8fed61", 1611 | "integrity": "sha512-Wonm7zOCIJzBGQdB+thsPar0kYuCIzYvxZwlBa87yi/Mdjv7Tip2cyVbLj5o0cFPN4EVkuTwb3GDDyUx2DGnGw==", 1612 | "dev": true, 1613 | "requires": { 1614 | "buffer-from": "^1.0.0", 1615 | "source-map": "^0.6.0" 1616 | } 1617 | }, 1618 | "statuses": { 1619 | "version": "1.5.0", 1620 | "resolved": "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c", 1621 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=", 1622 | "dev": true 1623 | }, 1624 | "string-width": { 1625 | "version": "4.2.0", 1626 | "resolved": "https://registry.yarnpkg.com/string-width/-/string-width-4.2.0.tgz#952182c46cc7b2c313d1596e623992bd163b72b5", 1627 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 1628 | "dev": true, 1629 | "requires": { 1630 | "emoji-regex": "^8.0.0", 1631 | "is-fullwidth-code-point": "^3.0.0", 1632 | "strip-ansi": "^6.0.0" 1633 | } 1634 | }, 1635 | "string_decoder": { 1636 | "version": "1.1.1", 1637 | "resolved": "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.1.1.tgz#9cf1611ba62685d7030ae9e4ba34149c3af03fc8", 1638 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 1639 | "dev": true, 1640 | "requires": { 1641 | "safe-buffer": "~5.1.0" 1642 | } 1643 | }, 1644 | "strip-ansi": { 1645 | "version": "6.0.0", 1646 | "resolved": "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.0.tgz#0b1571dd7669ccd4f3e06e14ef1eed26225ae532", 1647 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1648 | "dev": true, 1649 | "requires": { 1650 | "ansi-regex": "^5.0.0" 1651 | } 1652 | }, 1653 | "table": { 1654 | "version": "5.4.6", 1655 | "resolved": "https://registry.yarnpkg.com/table/-/table-5.4.6.tgz#1292d19500ce3f86053b05f0e8e7e4a3bb21079e", 1656 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", 1657 | "dev": true, 1658 | "requires": { 1659 | "ajv": "^6.10.2", 1660 | "lodash": "^4.17.14", 1661 | "slice-ansi": "^2.1.0", 1662 | "string-width": "^3.0.0" 1663 | }, 1664 | "dependencies": { 1665 | "ansi-regex": { 1666 | "version": "4.1.0", 1667 | "resolved": "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-4.1.0.tgz#8b9f8f08cf1acb843756a839ca8c7e3168c51997", 1668 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 1669 | "dev": true 1670 | }, 1671 | "emoji-regex": { 1672 | "version": "7.0.3", 1673 | "resolved": "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-7.0.3.tgz#933a04052860c85e83c122479c4748a8e4c72156", 1674 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 1675 | "dev": true 1676 | }, 1677 | "is-fullwidth-code-point": { 1678 | "version": "2.0.0", 1679 | "resolved": "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz#a3b30a5c4f199183167aaab93beefae3ddfb654f", 1680 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1681 | "dev": true 1682 | }, 1683 | "string-width": { 1684 | "version": "3.1.0", 1685 | "resolved": "https://registry.yarnpkg.com/string-width/-/string-width-3.1.0.tgz#22767be21b62af1081574306f69ac51b62203961", 1686 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1687 | "dev": true, 1688 | "requires": { 1689 | "emoji-regex": "^7.0.1", 1690 | "is-fullwidth-code-point": "^2.0.0", 1691 | "strip-ansi": "^5.1.0" 1692 | } 1693 | }, 1694 | "strip-ansi": { 1695 | "version": "5.2.0", 1696 | "resolved": "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-5.2.0.tgz#8c9a536feb6afc962bdfa5b104a5091c1ad9c0ae", 1697 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1698 | "dev": true, 1699 | "requires": { 1700 | "ansi-regex": "^4.1.0" 1701 | } 1702 | } 1703 | } 1704 | }, 1705 | "tar-stream": { 1706 | "version": "2.1.2", 1707 | "resolved": "https://registry.yarnpkg.com/tar-stream/-/tar-stream-2.1.2.tgz#6d5ef1a7e5783a95ff70b69b97455a5968dc1325", 1708 | "integrity": "sha512-UaF6FoJ32WqALZGOIAApXx+OdxhekNMChu6axLJR85zMMjXKWFGjbIRe+J6P4UnRGg9rAwWvbTT0oI7hD/Un7Q==", 1709 | "dev": true, 1710 | "requires": { 1711 | "bl": "^4.0.1", 1712 | "end-of-stream": "^1.4.1", 1713 | "fs-constants": "^1.0.0", 1714 | "inherits": "^2.0.3", 1715 | "readable-stream": "^3.1.1" 1716 | }, 1717 | "dependencies": { 1718 | "readable-stream": { 1719 | "version": "3.6.0", 1720 | "resolved": "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.0.tgz#337bbda3adc0706bd3e024426a286d4b4b2c9198", 1721 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 1722 | "dev": true, 1723 | "requires": { 1724 | "inherits": "^2.0.3", 1725 | "string_decoder": "^1.1.1", 1726 | "util-deprecate": "^1.0.1" 1727 | } 1728 | }, 1729 | "safe-buffer": { 1730 | "version": "5.2.0", 1731 | "resolved": "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.0.tgz#b74daec49b1148f88c64b68d49b1e815c1f2f519", 1732 | "integrity": "sha512-fZEwUGbVl7kouZs1jCdMLdt95hdIv0ZeHg6L7qPeciMZhZ+/gdesW4wgTARkrFWEpspjEATAzUGPG8N2jJiwbg==", 1733 | "dev": true 1734 | }, 1735 | "string_decoder": { 1736 | "version": "1.3.0", 1737 | "resolved": "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e", 1738 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 1739 | "dev": true, 1740 | "requires": { 1741 | "safe-buffer": "~5.2.0" 1742 | } 1743 | } 1744 | } 1745 | }, 1746 | "thunkify": { 1747 | "version": "2.1.2", 1748 | "resolved": "https://registry.yarnpkg.com/thunkify/-/thunkify-2.1.2.tgz#faa0e9d230c51acc95ca13a361ac05ca7e04553d", 1749 | "integrity": "sha1-+qDp0jDFGsyVyhOjYawFyn4EVT0=", 1750 | "dev": true 1751 | }, 1752 | "toidentifier": { 1753 | "version": "1.0.0", 1754 | "resolved": "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.0.tgz#7e1be3470f1e77948bc43d94a3c8f4d7752ba553", 1755 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==", 1756 | "dev": true 1757 | }, 1758 | "type-check": { 1759 | "version": "0.3.2", 1760 | "resolved": "https://registry.yarnpkg.com/type-check/-/type-check-0.3.2.tgz#5884cab512cf1d355e3fb784f30804b2b520db72", 1761 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 1762 | "dev": true, 1763 | "requires": { 1764 | "prelude-ls": "~1.1.2" 1765 | } 1766 | }, 1767 | "universalify": { 1768 | "version": "0.1.2", 1769 | "resolved": "https://registry.yarnpkg.com/universalify/-/universalify-0.1.2.tgz#b646f69be3942dabcecc9d6639c80dc105efaa66", 1770 | "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", 1771 | "dev": true 1772 | }, 1773 | "unpipe": { 1774 | "version": "1.0.0", 1775 | "resolved": "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec", 1776 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=", 1777 | "dev": true 1778 | }, 1779 | "uri-js": { 1780 | "version": "4.2.2", 1781 | "resolved": "https://registry.yarnpkg.com/uri-js/-/uri-js-4.2.2.tgz#94c540e1ff772956e2299507c010aea6c8838eb0", 1782 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 1783 | "dev": true, 1784 | "requires": { 1785 | "punycode": "^2.1.0" 1786 | }, 1787 | "dependencies": { 1788 | "punycode": { 1789 | "version": "2.1.1", 1790 | "resolved": "https://registry.yarnpkg.com/punycode/-/punycode-2.1.1.tgz#b58b010ac40c22c5657616c8d2c2c02c7bf479ec", 1791 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1792 | "dev": true 1793 | } 1794 | } 1795 | }, 1796 | "url": { 1797 | "version": "0.10.3", 1798 | "resolved": "https://registry.yarnpkg.com/url/-/url-0.10.3.tgz#021e4d9c7705f21bbf37d03ceb58767402774c64", 1799 | "integrity": "sha1-Ah5NnHcF8hu/N9A861h2dAJ3TGQ=", 1800 | "dev": true, 1801 | "requires": { 1802 | "punycode": "1.3.2", 1803 | "querystring": "0.2.0" 1804 | } 1805 | }, 1806 | "util-deprecate": { 1807 | "version": "1.0.2", 1808 | "resolved": "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf", 1809 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 1810 | "dev": true 1811 | }, 1812 | "uuid": { 1813 | "version": "8.1.0", 1814 | "resolved": "https://registry.yarnpkg.com/uuid/-/uuid-8.1.0.tgz#6f1536eb43249f473abc6bd58ff983da1ca30d8d", 1815 | "integrity": "sha512-CI18flHDznR0lq54xBycOVmphdCYnQLKn8abKn7PXUiKUGdEd+/l9LWNJmugXel4hXq7S+RMNl34ecyC9TntWg==", 1816 | "dev": true 1817 | }, 1818 | "which-module": { 1819 | "version": "2.0.0", 1820 | "resolved": "https://registry.yarnpkg.com/which-module/-/which-module-2.0.0.tgz#d9ef07dce77b9902b8a3a8fa4b31c3e3f7e6e87a", 1821 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", 1822 | "dev": true 1823 | }, 1824 | "word-wrap": { 1825 | "version": "1.2.3", 1826 | "resolved": "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.3.tgz#610636f6b1f703891bd34771ccb17fb93b47079c", 1827 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 1828 | "dev": true 1829 | }, 1830 | "wordwrap": { 1831 | "version": "1.0.0", 1832 | "resolved": "https://registry.yarnpkg.com/wordwrap/-/wordwrap-1.0.0.tgz#27584810891456a4171c8d0226441ade90cbcaeb", 1833 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 1834 | "dev": true 1835 | }, 1836 | "wrap-ansi": { 1837 | "version": "6.2.0", 1838 | "resolved": "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-6.2.0.tgz#e9393ba07102e6c91a3b221478f0257cd2856e53", 1839 | "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", 1840 | "dev": true, 1841 | "requires": { 1842 | "ansi-styles": "^4.0.0", 1843 | "string-width": "^4.1.0", 1844 | "strip-ansi": "^6.0.0" 1845 | }, 1846 | "dependencies": { 1847 | "ansi-styles": { 1848 | "version": "4.2.1", 1849 | "resolved": "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.2.1.tgz#90ae75c424d008d2624c5bf29ead3177ebfcf359", 1850 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 1851 | "dev": true, 1852 | "requires": { 1853 | "@types/color-name": "^1.1.1", 1854 | "color-convert": "^2.0.1" 1855 | } 1856 | }, 1857 | "color-convert": { 1858 | "version": "2.0.1", 1859 | "resolved": "https://registry.yarnpkg.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3", 1860 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1861 | "dev": true, 1862 | "requires": { 1863 | "color-name": "~1.1.4" 1864 | } 1865 | }, 1866 | "color-name": { 1867 | "version": "1.1.4", 1868 | "resolved": "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2", 1869 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1870 | "dev": true 1871 | } 1872 | } 1873 | }, 1874 | "wrappy": { 1875 | "version": "1.0.2", 1876 | "resolved": "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f", 1877 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1878 | "dev": true 1879 | }, 1880 | "xml2js": { 1881 | "version": "0.4.19", 1882 | "resolved": "https://registry.yarnpkg.com/xml2js/-/xml2js-0.4.19.tgz#686c20f213209e94abf0d1bcf1efaa291c7827a7", 1883 | "integrity": "sha512-esZnJZJOiJR9wWKMyuvSE1y6Dq5LCuJanqhxslH2bxM6duahNZ+HMpCLhBQGZkbX6xRf8x1Y2eJlgt2q3qo49Q==", 1884 | "dev": true, 1885 | "requires": { 1886 | "sax": ">=0.6.0", 1887 | "xmlbuilder": "~9.0.1" 1888 | }, 1889 | "dependencies": { 1890 | "sax": { 1891 | "version": "1.2.4", 1892 | "resolved": "https://registry.yarnpkg.com/sax/-/sax-1.2.4.tgz#2816234e2378bddc4e5354fab5caa895df7100d9", 1893 | "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==", 1894 | "dev": true 1895 | } 1896 | } 1897 | }, 1898 | "xmlbuilder": { 1899 | "version": "9.0.7", 1900 | "resolved": "https://registry.yarnpkg.com/xmlbuilder/-/xmlbuilder-9.0.7.tgz#132ee63d2ec5565c557e20f4c22df9aca686b10d", 1901 | "integrity": "sha1-Ey7mPS7FVlxVfiD0wi35rKaGsQ0=", 1902 | "dev": true 1903 | }, 1904 | "xregexp": { 1905 | "version": "2.0.0", 1906 | "resolved": "https://registry.yarnpkg.com/xregexp/-/xregexp-2.0.0.tgz#52a63e56ca0b84a7f3a5f3d61872f126ad7a5943", 1907 | "integrity": "sha1-UqY+VsoLhKfzpfPWGHLxJq16WUM=", 1908 | "dev": true 1909 | }, 1910 | "y18n": { 1911 | "version": "4.0.0", 1912 | "resolved": "https://registry.yarnpkg.com/y18n/-/y18n-4.0.0.tgz#95ef94f85ecc81d007c264e190a120f0a3c8566b", 1913 | "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==", 1914 | "dev": true 1915 | }, 1916 | "yallist": { 1917 | "version": "3.1.1", 1918 | "resolved": "https://registry.yarnpkg.com/yallist/-/yallist-3.1.1.tgz#dbb7daf9bfd8bac9ab45ebf602b8cbad0d5d08fd", 1919 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", 1920 | "dev": true 1921 | }, 1922 | "yaml": { 1923 | "version": "1.10.0", 1924 | "resolved": "https://registry.yarnpkg.com/yaml/-/yaml-1.10.0.tgz#3b593add944876077d4d683fee01081bd9fff31e", 1925 | "integrity": "sha512-yr2icI4glYaNG+KWONODapy2/jDdMSDnrONSjblABjD9B4Z5LgiircSt8m8sRZFNi08kG9Sm0uSHtEmP3zaEGg==", 1926 | "dev": true 1927 | }, 1928 | "yargs": { 1929 | "version": "15.3.1", 1930 | "resolved": "https://registry.yarnpkg.com/yargs/-/yargs-15.3.1.tgz#9505b472763963e54afe60148ad27a330818e98b", 1931 | "integrity": "sha512-92O1HWEjw27sBfgmXiixJWT5hRBp2eobqXicLtPBIDBhYB+1HpwZlXmbW2luivBJHBzki+7VyCLRtAkScbTBQA==", 1932 | "dev": true, 1933 | "requires": { 1934 | "cliui": "^6.0.0", 1935 | "decamelize": "^1.2.0", 1936 | "find-up": "^4.1.0", 1937 | "get-caller-file": "^2.0.1", 1938 | "require-directory": "^2.1.1", 1939 | "require-main-filename": "^2.0.0", 1940 | "set-blocking": "^2.0.0", 1941 | "string-width": "^4.2.0", 1942 | "which-module": "^2.0.0", 1943 | "y18n": "^4.0.0", 1944 | "yargs-parser": "^18.1.1" 1945 | }, 1946 | "dependencies": { 1947 | "decamelize": { 1948 | "version": "1.2.0", 1949 | "resolved": "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290", 1950 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", 1951 | "dev": true 1952 | } 1953 | } 1954 | }, 1955 | "yargs-parser": { 1956 | "version": "18.1.3", 1957 | "resolved": "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-18.1.3.tgz#be68c4975c6b2abf469236b0c870362fab09a7b0", 1958 | "integrity": "sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==", 1959 | "dev": true, 1960 | "requires": { 1961 | "camelcase": "^5.0.0", 1962 | "decamelize": "^1.2.0" 1963 | }, 1964 | "dependencies": { 1965 | "camelcase": { 1966 | "version": "5.3.1", 1967 | "resolved": "https://registry.yarnpkg.com/camelcase/-/camelcase-5.3.1.tgz#e3c9b31569e106811df242f715725a1f4c494320", 1968 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 1969 | "dev": true 1970 | }, 1971 | "decamelize": { 1972 | "version": "1.2.0", 1973 | "resolved": "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290", 1974 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", 1975 | "dev": true 1976 | } 1977 | } 1978 | }, 1979 | "zip-stream": { 1980 | "version": "3.0.1", 1981 | "resolved": "https://registry.yarnpkg.com/zip-stream/-/zip-stream-3.0.1.tgz#cb8db9d324a76c09f9b76b31a12a48638b0b9708", 1982 | "integrity": "sha512-r+JdDipt93ttDjsOVPU5zaq5bAyY+3H19bDrThkvuVxC0xMQzU1PJcS6D+KrP3u96gH9XLomcHPb+2skoDjulQ==", 1983 | "dev": true, 1984 | "requires": { 1985 | "archiver-utils": "^2.1.0", 1986 | "compress-commons": "^3.0.0", 1987 | "readable-stream": "^3.6.0" 1988 | }, 1989 | "dependencies": { 1990 | "readable-stream": { 1991 | "version": "3.6.0", 1992 | "resolved": "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.0.tgz#337bbda3adc0706bd3e024426a286d4b4b2c9198", 1993 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 1994 | "dev": true, 1995 | "requires": { 1996 | "inherits": "^2.0.3", 1997 | "string_decoder": "^1.1.1", 1998 | "util-deprecate": "^1.0.1" 1999 | } 2000 | }, 2001 | "safe-buffer": { 2002 | "version": "5.2.0", 2003 | "resolved": "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.0.tgz#b74daec49b1148f88c64b68d49b1e815c1f2f519", 2004 | "integrity": "sha512-fZEwUGbVl7kouZs1jCdMLdt95hdIv0ZeHg6L7qPeciMZhZ+/gdesW4wgTARkrFWEpspjEATAzUGPG8N2jJiwbg==", 2005 | "dev": true 2006 | }, 2007 | "string_decoder": { 2008 | "version": "1.3.0", 2009 | "resolved": "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e", 2010 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 2011 | "dev": true, 2012 | "requires": { 2013 | "safe-buffer": "~5.2.0" 2014 | } 2015 | } 2016 | } 2017 | } 2018 | } 2019 | }, 2020 | "constructs": { 2021 | "version": "3.0.3", 2022 | "resolved": "https://registry.npmjs.org/constructs/-/constructs-3.0.3.tgz", 2023 | "integrity": "sha512-JrYLpTlz92Un1jxkwoGiOiGoDjzIWtxo64sLC5FD4mQN1H9mAqZNvgxWYWaJIiWUXNkl5L5sO3GFf6peTj7UMQ==" 2024 | } 2025 | } 2026 | } 2027 | --------------------------------------------------------------------------------