├── releases └── .gitignore ├── .gitignore ├── docs └── images │ ├── GitHubTepapaLambda.png │ ├── GitHubTepapaOutput.png │ ├── GitHubTepapaKeyIcon.jpg │ └── GitHubTepapaToolchain.png ├── LICENSE ├── grunt ├── scripts │ ├── createZipPackage.sh │ ├── createLambdaFunction.sh │ ├── createScheduledEvent.sh │ └── createLambdaAccessKeyRotationPolicy.sh ├── package.json ├── Gruntfile.js └── package-lock.json ├── lambda └── src │ └── RotateAccessKey.py └── readme.md /releases/.gitignore: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | grunt/node_modules/* 2 | lambda/build/* 3 | releases/* 4 | grunt/package.*.json 5 | -------------------------------------------------------------------------------- /docs/images/GitHubTepapaLambda.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/te-papa/aws-key-disabler/HEAD/docs/images/GitHubTepapaLambda.png -------------------------------------------------------------------------------- /docs/images/GitHubTepapaOutput.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/te-papa/aws-key-disabler/HEAD/docs/images/GitHubTepapaOutput.png -------------------------------------------------------------------------------- /docs/images/GitHubTepapaKeyIcon.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/te-papa/aws-key-disabler/HEAD/docs/images/GitHubTepapaKeyIcon.jpg -------------------------------------------------------------------------------- /docs/images/GitHubTepapaToolchain.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/te-papa/aws-key-disabler/HEAD/docs/images/GitHubTepapaToolchain.png -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | Copyright (c) 2016, Museum of New Zealand Te Papa Tongarewa 2 | 3 | Permission to use, copy, modify, and/or distribute this software for any 4 | purpose with or without fee is hereby granted, provided that the above 5 | copyright notice and this permission notice appear in all copies. 6 | 7 | THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 8 | WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 9 | MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR 10 | ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 11 | WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 12 | ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 13 | OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 14 | -------------------------------------------------------------------------------- /grunt/scripts/createZipPackage.sh: -------------------------------------------------------------------------------- 1 | echo 2 | echo "**************************************************" 3 | echo "**************************************************" 4 | echo "CREATING ZIP PACKAGE for deployment..." 5 | echo "**************************************************" 6 | echo "**************************************************" 7 | echo 8 | SCRIPT=`basename "$0"` 9 | 10 | echo "STEP1: [${SCRIPT}]" 11 | echo starting ZIP packaging... 12 | 13 | PACKAGE_NAME=AccessKeyRotationPackage.zip 14 | echo PACKAGE_NAME=$PACKAGE_NAME 15 | echo 16 | 17 | CURRENT_DIR=`pwd` 18 | echo CURRENT_DIR=$CURRENT_DIR 19 | 20 | cd $CURRENT_DIR/../releases 21 | zip -j $PACKAGE_NAME ../lambda/build/RotateAccessKey.py 22 | 23 | echo 24 | echo "**************************************************" 25 | echo "**************************************************" 26 | echo "SUCCESSFULLY created LAMBDA ZIP PACKAGE!!" 27 | echo "**************************************************" 28 | echo "**************************************************" 29 | echo 30 | sleep 5 31 | -------------------------------------------------------------------------------- /grunt/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "key_disabler", 3 | "version": "1.1.3", 4 | "description": "Lambda helper functions", 5 | "main": "Gruntfile.js", 6 | "dependencies": { 7 | "grunt": "^1.4.1", 8 | "grunt-cli": "^1.4.3", 9 | "grunt-contrib-jshint": "^3.0.0", 10 | "grunt-contrib-watch": "^1.1.0", 11 | "grunt-exec": "^0.4.6", 12 | "grunt-jsbeautifier": "^0.2.7" 13 | }, 14 | "devDependencies": { 15 | "grunt-bumpup": "^0.6.3", 16 | "grunt-contrib-rename": "^0.2.0", 17 | "grunt-replace": "^2.0.2" 18 | }, 19 | "scripts": { 20 | "test": "echo \"Error: no test specified\" && exit 1" 21 | }, 22 | "license": "ISC", 23 | "key_disabler": { 24 | "aws_account_number": "123456789012", 25 | "keystates": { 26 | "young": { 27 | "message": "key is still young" 28 | }, 29 | "first_warning": { 30 | "days": 23, 31 | "message": "key is due to expire in 1 week (7 days)" 32 | }, 33 | "last_warning": { 34 | "days": 29, 35 | "message": "key is due to expire in 1 day (tomorrow)" 36 | }, 37 | "expired": { 38 | "days": 30, 39 | "message": "key is now EXPIRED! Changing key to INACTIVE state" 40 | } 41 | }, 42 | "email": { 43 | "email_region": "us-west-2", 44 | "report_to": "receipient@example.com", 45 | "report_from": "sender@example.com", 46 | "send_completion_report": "False" 47 | }, 48 | "iam": { 49 | "serviceaccount": "IAM_USERNAME_TO_EXCLUDE_IF_ANY", 50 | "exclusiongroup": "group_name", 51 | "lambda": { 52 | "rolename": "LambdaAccessKeyRotationRole", 53 | "policyname": "LambdaAccessKeyRotationPolicy" 54 | } 55 | }, 56 | "lambda": { 57 | "function_name": "AccessKeyRotation", 58 | "memory": "128", 59 | "timeout": "60", 60 | "deployment_region": "ap-southeast-2", 61 | "schedule": { 62 | "rulename": "EveryDay4amNZT", 63 | "description": "Runs every day at 4am NZT", 64 | "expression": "cron(0 16 * * ? *)" 65 | } 66 | }, 67 | "mask_accesskey_length": "16" 68 | } 69 | } -------------------------------------------------------------------------------- /grunt/scripts/createLambdaFunction.sh: -------------------------------------------------------------------------------- 1 | echo 2 | echo "**************************************************" 3 | echo "**************************************************" 4 | echo "DEPLOYING LAMBDA Function..." 5 | echo "**************************************************" 6 | echo "**************************************************" 7 | echo 8 | SCRIPT=`basename "$0"` 9 | 10 | LAMBDA_ZIP_PACKAGE_NAME=$1 11 | BUILD_VERSION=$2 12 | FUNCTION_NAME=$3 13 | LAMBDA_ROLE_NAME=$4 14 | LAMBDA_TIMEOUT=$5 15 | LAMBDA_MEMORY=$6 16 | REGION=$7 17 | 18 | echo running script with inputs: 19 | echo LAMBDA_ZIP_PACKAGE_NAME=$LAMBDA_ZIP_PACKAGE_NAME 20 | echo BUILD_VERSION=$BUILD_VERSION 21 | echo FUNCTION_NAME=$FUNCTION_NAME 22 | echo LAMBDA_ROLE_NAME=$LAMBDA_ROLE_NAME 23 | echo LAMBDA_TIMEOUT=$LAMBDA_TIMEOUT 24 | echo LAMBDA_MEMORY=$LAMBDA_MEMORY 25 | echo REGION=$REGION 26 | echo 27 | 28 | echo "STEP1: [${SCRIPT}]" 29 | echo deploying $LAMBDA_ZIP_PACKAGE_NAME version $BUILD_VERSION lambda ZIP package... 30 | echo 31 | 32 | LAMBDA_HANDLER=RotateAccessKey.lambda_handler 33 | 34 | EXISTS=$(aws lambda list-functions --region $REGION --query "length(Functions[?FunctionName=='$FUNCTION_NAME'])") 35 | if [[ $EXISTS -eq 1 ]]; then 36 | echo existing lambda function $FUNCTION_NAME found, deleting first... 37 | echo 38 | aws lambda delete-function --function-name $FUNCTION_NAME --region $REGION 39 | fi 40 | 41 | echo creating lambda function $FUNCTION_NAME... 42 | echo 43 | 44 | LAMBDA_ACCESS_KEY_ROTATION_ROLEARN=$(aws iam get-role --role-name $LAMBDA_ROLE_NAME --output text --query Role.Arn) 45 | echo LAMBDA_ACCESS_KEY_ROTATION_ROLEARN=$LAMBDA_ACCESS_KEY_ROTATION_ROLEARN 46 | 47 | LAMBDA_FUNCTION_ARN=$(aws lambda create-function \ 48 | --region $REGION \ 49 | --runtime python2.7 \ 50 | --role $LAMBDA_ACCESS_KEY_ROTATION_ROLEARN \ 51 | --description "Deactivates old IAM Access Keys - ${BUILD_VERSION}" \ 52 | --timeout $LAMBDA_TIMEOUT \ 53 | --memory-size $LAMBDA_MEMORY \ 54 | --handler $LAMBDA_HANDLER \ 55 | --zip-file fileb://../releases/$LAMBDA_ZIP_PACKAGE_NAME \ 56 | --function-name $FUNCTION_NAME \ 57 | --output text \ 58 | --query 'FunctionArn') 59 | 60 | echo LAMBDA_FUNCTION_ARN=$LAMBDA_FUNCTION_ARN 61 | 62 | echo 63 | 64 | echo "**************************************************" 65 | echo "**************************************************" 66 | echo "SUCCESSFULLY deployed LAMBDA Function ZIP Package!!" 67 | echo "**************************************************" 68 | echo "**************************************************" 69 | echo 70 | sleep 5 71 | -------------------------------------------------------------------------------- /grunt/scripts/createScheduledEvent.sh: -------------------------------------------------------------------------------- 1 | echo 2 | echo "**************************************************" 3 | echo "**************************************************" 4 | echo "DEPLOYING LAMBDA CRON Schedule Pattern..." 5 | echo "**************************************************" 6 | echo "**************************************************" 7 | echo 8 | SCRIPT=`basename "$0"` 9 | 10 | FUNCTION_NAME=$1 11 | SCHEDULE_RULE_NAME="$2" 12 | SCHEDULE_RULE_DESC="$3" 13 | SCHEDULE_EXPRESSION="$4" 14 | AWS_ACCOUNT_NUMBER=$5 15 | REGION=$6 16 | 17 | echo running script with inputs: 18 | echo FUNCTION_NAME=$FUNCTION_NAME 19 | echo SCHEDULE_RULE_NAME="${SCHEDULE_RULE_NAME}" 20 | echo SCHEDULE_RULE_DESC="${SCHEDULE_RULE_DESC}" 21 | echo SCHEDULE_EXPRESSION="${SCHEDULE_EXPRESSION}" 22 | echo AWS_ACCOUNT_NUMBER=$AWS_ACCOUNT_NUMBER 23 | echo REGION=$REGION 24 | echo 25 | 26 | echo "STEP1: [${SCRIPT}]" 27 | echo creating event rule with CRON pattern... 28 | echo 29 | 30 | EXISTS=$(aws events list-rules --region $REGION --output text --query "length(Rules[?Name=='$SCHEDULE_RULE_NAME'])") 31 | if [[ $EXISTS -eq 0 ]]; then 32 | EVENT_RULE_ARN=$(aws events put-rule \ 33 | --name "${SCHEDULE_RULE_NAME}" \ 34 | --description "${SCHEDULE_RULE_DESC}" \ 35 | --schedule-expression "${SCHEDULE_EXPRESSION}" \ 36 | --region $REGION \ 37 | --output text \ 38 | --query 'RuleArn') 39 | 40 | echo EVENT_RULE_ARN=$EVENT_RULE_ARN 41 | else 42 | EVENT_RULE_ARN=$(aws events list-rules --region $REGION --output text --query "Rules[?Name=='$SCHEDULE_RULE_NAME'].Arn") 43 | echo events rule $SCHEDULE_RULE_NAME already exists: 44 | echo $EVENT_RULE_ARN 45 | fi 46 | 47 | echo 48 | echo "STEP2: [${SCRIPT}]" 49 | echo giving InvokeFunction permission to new EventRule... 50 | echo 51 | 52 | aws lambda add-permission \ 53 | --function-name $FUNCTION_NAME \ 54 | --statement-id $FUNCTION_NAME \ 55 | --action 'lambda:InvokeFunction' \ 56 | --principal events.amazonaws.com \ 57 | --source-arn $EVENT_RULE_ARN \ 58 | --region $REGION 59 | 60 | echo 61 | echo "STEP3: [${SCRIPT}]" 62 | echo binding new CRON schedule to new Lambda Function... 63 | echo 64 | 65 | aws events put-targets \ 66 | --rule $SCHEDULE_RULE_NAME \ 67 | --targets "{\"Id\" : \"1\", \"Arn\": \"arn:aws:lambda:${REGION}:${AWS_ACCOUNT_NUMBER}:function:${FUNCTION_NAME}\"}" \ 68 | --region $REGION 69 | 70 | echo 71 | 72 | echo "**************************************************" 73 | echo "**************************************************" 74 | echo "SUCCESSFULLY deployed LAMBDA CRON Schedule Pattern!!" 75 | echo "**************************************************" 76 | echo "**************************************************" 77 | echo 78 | sleep 5 79 | -------------------------------------------------------------------------------- /grunt/scripts/createLambdaAccessKeyRotationPolicy.sh: -------------------------------------------------------------------------------- 1 | echo 2 | echo "**************************************************" 3 | echo "**************************************************" 4 | echo "DEPLOYING LAMBDA IAM Policy and Role..." 5 | echo "**************************************************" 6 | echo "**************************************************" 7 | echo 8 | SCRIPT=`basename "$0"` 9 | 10 | LAMBDA_POLICY_NAME=$1 11 | LAMBDA_ROLE_NAME=$2 12 | REGION=$3 13 | 14 | echo running script with inputs: 15 | echo LAMBDA_POLICY_NAME=$LAMBDA_POLICY_NAME 16 | echo LAMBDA_ROLE_NAME=$LAMBDA_ROLE_NAME 17 | echo REGION=$REGION 18 | 19 | #============================================= 20 | 21 | echo 22 | echo "STEP1: [${SCRIPT}]" 23 | echo creating IAM $LAMBDA_POLICY_NAME policy... 24 | 25 | EXISTS=$(aws iam list-policies --query "length(Policies[?PolicyName=='$LAMBDA_POLICY_NAME'])") 26 | if [[ $EXISTS -eq 0 ]]; then 27 | LAMBDA_ACCESS_KEY_ROTATION_POLICY=$(python -c """import json; print json.dumps({ 28 | 'Version': '2012-10-17', 29 | 'Statement': [ 30 | { 31 | 'Effect': 'Allow', 32 | 'Action': [ 33 | 'logs:CreateLogGroup', 34 | 'logs:CreateLogStream', 35 | 'logs:PutLogEvents' 36 | ], 37 | 'Resource': 'arn:aws:logs:*:*:*' 38 | }, 39 | { 40 | 'Effect': 'Allow', 41 | 'Action': [ 42 | 'iam:ListUsers', 43 | 'iam:ListGroupsForUser', 44 | 'iam:ListAccessKeys', 45 | 'iam:UpdateAccessKey' 46 | ], 47 | 'Resource': '*' 48 | }, 49 | { 50 | 'Effect': 'Allow', 51 | 'Action': [ 52 | 'ses:SendEmail' 53 | ], 54 | 'Resource': '*' 55 | } 56 | ] 57 | })""") 58 | 59 | # create the execution role and save its ARN for later: 60 | LAMBDA_ACCESS_KEY_ROTATION_POLICY_ARN=$(aws iam create-policy \ 61 | --region $REGION \ 62 | --policy-name $LAMBDA_POLICY_NAME \ 63 | --policy-document "$LAMBDA_ACCESS_KEY_ROTATION_POLICY" \ 64 | --output text \ 65 | --query 'Policy.Arn') 66 | 67 | echo LAMBDA_ACCESS_KEY_ROTATION_POLICY_ARN=$LAMBDA_ACCESS_KEY_ROTATION_POLICY_ARN 68 | else 69 | LAMBDA_ACCESS_KEY_ROTATION_POLICY_ARN=$(aws iam list-policies --output text --query "Policies[?PolicyName=='$LAMBDA_POLICY_NAME'].Arn") 70 | echo policy $LAMBDA_POLICY_NAME already exists: 71 | echo $LAMBDA_ACCESS_KEY_ROTATION_POLICY_ARN 72 | fi 73 | 74 | #============================================= 75 | 76 | echo 77 | echo "STEP2: [${SCRIPT}]" 78 | echo creating IAM $LAMBDA_ROLE_NAME role... 79 | 80 | EXISTS=$(aws iam list-roles --query "length(Roles[?RoleName=='$LAMBDA_ROLE_NAME'])") 81 | if [[ $EXISTS -eq 0 ]]; then 82 | ASSUME_ROLE_POLICY=$(python -c """import json; print json.dumps({ 83 | 'Version': '2012-10-17', 84 | 'Statement': [ 85 | { 86 | 'Effect': 'Allow', 87 | 'Principal': { 88 | 'Service': 'lambda.amazonaws.com' 89 | }, 90 | 'Action': 'sts:AssumeRole' 91 | } 92 | ] 93 | })""") 94 | 95 | # create the execution role and save its ARN for later: 96 | LAMBDA_ACCESS_KEY_ROTATION_ROLE_ARN=$(aws iam create-role \ 97 | --region $REGION \ 98 | --role-name "$LAMBDA_ROLE_NAME" \ 99 | --assume-role-policy-document "$ASSUME_ROLE_POLICY" \ 100 | --output text \ 101 | --query 'Role.Arn') 102 | 103 | echo LAMBDA_ACCESS_KEY_ROTATION_ROLE_ARN=$LAMBDA_ACCESS_KEY_ROTATION_ROLE_ARN 104 | else 105 | LAMBDA_ACCESS_KEY_ROTATION_POLICY_ARN=$(aws iam list-roles --output text --query "Roles[?RoleName=='$LAMBDA_ROLE_NAME'].Arn") 106 | echo role $LAMBDA_ROLE_NAME already exists: 107 | echo $LAMBDA_ACCESS_KEY_ROTATION_POLICY_ARN 108 | fi 109 | 110 | #============================================= 111 | 112 | echo 113 | echo "STEP3: [${SCRIPT}]" 114 | echo attaching IAM $LAMBDA_POLICY_NAME policy to $LAMBDA_ROLE_NAME role... 115 | 116 | ATTACHED=$(aws iam list-attached-role-policies --role-name $LAMBDA_ROLE_NAME --query "length(AttachedPolicies[?PolicyName=='$LAMBDA_POLICY_NAME'])") 117 | if [[ $ATTACHED -eq 0 ]]; then 118 | aws iam attach-role-policy \ 119 | --region $REGION \ 120 | --policy-arn "$LAMBDA_ACCESS_KEY_ROTATION_POLICY_ARN" \ 121 | --role-name "$LAMBDA_ROLE_NAME" 122 | else 123 | ATTACHMENT=$(aws iam list-attached-role-policies --role-name $LAMBDA_ROLE_NAME --query "AttachedPolicies[?PolicyName=='$LAMBDA_POLICY_NAME']") 124 | echo policy $LAMBDA_POLICY_NAME already attached to role $LAMBDA_ROLE_NAME: 125 | echo $ATTACHMENT 126 | fi 127 | 128 | echo 129 | 130 | echo "**************************************************" 131 | echo "**************************************************" 132 | echo "SUCCESSFULLY deployed LAMBDA IAM Policy and Role!!" 133 | echo "**************************************************" 134 | echo "**************************************************" 135 | echo 136 | sleep 5 137 | -------------------------------------------------------------------------------- /grunt/Gruntfile.js: -------------------------------------------------------------------------------- 1 | /*global module:false*/ 2 | module.exports = function(grunt) { 3 | 4 | grunt.initConfig({ 5 | pkg: grunt.file.readJSON('package.json'), 6 | 7 | bumpup: { 8 | file: 'package.json' 9 | }, 10 | 11 | replace: { 12 | dist: { 13 | options: { 14 | patterns: [ 15 | { 16 | match: 'buildversion', 17 | replacement: '<%= pkg.version %>' 18 | }, 19 | { 20 | match: 'deploymentregion', 21 | replacement: '<%= pkg.key_disabler.lambda.deployment_region %>' 22 | }, 23 | { 24 | match: 'serviceaccount', 25 | replacement: '<%= pkg.key_disabler.iam.serviceaccount %>' 26 | }, 27 | { 28 | match: 'exclusiongroup', 29 | replacement: '<%= pkg.key_disabler.iam.exclusiongroup %>' 30 | 31 | }, 32 | { 33 | match: 'emailreportto', 34 | replacement: '<%= pkg.key_disabler.email.report_to %>' 35 | }, 36 | { 37 | match: 'emailregion', 38 | replacement: '<%= pkg.key_disabler.email.email_region %>' 39 | }, 40 | { 41 | match: 'emailreportfrom', 42 | replacement: '<%= pkg.key_disabler.email.report_from %>' 43 | }, 44 | { 45 | match: 'emailsendcompletionreport', 46 | replacement: '<%= pkg.key_disabler.email.send_completion_report %>' 47 | }, 48 | { 49 | match: 'maskaccesskeylength', 50 | replacement: '<%= pkg.key_disabler.mask_accesskey_length %>' 51 | }, 52 | { 53 | match: 'first_warning_num_days', 54 | replacement: '<%= pkg.key_disabler.keystates.first_warning.days %>' 55 | }, 56 | { 57 | match: 'first_warning_message', 58 | replacement: '<%= pkg.key_disabler.keystates.first_warning.message %>' 59 | }, 60 | { 61 | match: 'last_warning_num_days', 62 | replacement: '<%= pkg.key_disabler.keystates.last_warning.days %>' 63 | }, 64 | { 65 | match: 'last_warning_message', 66 | replacement: '<%= pkg.key_disabler.keystates.last_warning.message %>' 67 | }, 68 | { 69 | match: 'key_max_age_in_days', 70 | replacement: '<%= pkg.key_disabler.keystates.expired.days %>' 71 | }, 72 | { 73 | match: 'key_expired_message', 74 | replacement: '<%= pkg.key_disabler.keystates.expired.message %>' 75 | }, 76 | { 77 | match: 'key_young_message', 78 | replacement: '<%= pkg.key_disabler.keystates.young.message %>' 79 | } 80 | ] 81 | }, 82 | files: [ 83 | {expand: true, flatten: true, src: ['../lambda/src/RotateAccessKey.py'], dest: '../lambda/build/'} 84 | ] 85 | } 86 | }, 87 | 88 | rename: { 89 | release: { 90 | files: [{ 91 | src: ['../releases/AccessKeyRotationPackage.zip'], 92 | dest: '../releases/AccessKeyRotationPackage.<%= pkg.version %>.zip' 93 | }] 94 | } 95 | }, 96 | 97 | exec: { 98 | create_lambda_policy: { 99 | cmd: './scripts/createLambdaAccessKeyRotationPolicy.sh "<%= pkg.key_disabler.iam.lambda.policyname %>" "<%= pkg.key_disabler.iam.lambda.rolename %>" <%= pkg.key_disabler.lambda.deployment_region %>' 100 | }, 101 | package_lambda_function: { 102 | cmd: './scripts/createZipPackage.sh' 103 | }, 104 | create_lambda_function: { 105 | cmd: './scripts/createLambdaFunction.sh AccessKeyRotationPackage.<%= pkg.version %>.zip <%= pkg.version %> "<%= pkg.key_disabler.lambda.function_name %>" "<%= pkg.key_disabler.iam.lambda.rolename %>" <%= pkg.key_disabler.lambda.timeout %> <%= pkg.key_disabler.lambda.memory %> <%= pkg.key_disabler.lambda.deployment_region %>' 106 | }, 107 | create_scheduled_event: { 108 | cmd: './scripts/createScheduledEvent.sh "<%=pkg.key_disabler.lambda.function_name %>" "<%= pkg.key_disabler.lambda.schedule.rulename %>" "<%= pkg.key_disabler.lambda.schedule.description %>" "<%= pkg.key_disabler.lambda.schedule.expression %>" <%= pkg.key_disabler.aws_account_number %> <%= pkg.key_disabler.lambda.deployment_region %>' 109 | }, 110 | } 111 | 112 | }); 113 | 114 | // Load NPM grunt tasks 115 | grunt.loadNpmTasks('grunt-contrib-watch'); 116 | grunt.loadNpmTasks('grunt-exec'); 117 | grunt.loadNpmTasks('grunt-replace'); 118 | grunt.loadNpmTasks('grunt-contrib-rename'); 119 | grunt.loadNpmTasks('grunt-bumpup'); 120 | 121 | // Default task. 122 | //grunt.registerTask('default', 'watch'); 123 | 124 | grunt.registerTask('build', ['replace']); 125 | grunt.registerTask('renamePackage', 'rename:release'); 126 | 127 | grunt.registerTask('createLambdaPolicy', 'exec:create_lambda_policy'); 128 | grunt.registerTask('packageLambdaFunction', 'exec:package_lambda_function'); 129 | grunt.registerTask('createLambdaFunction', 'exec:create_lambda_function'); 130 | grunt.registerTask('createScheduledEvent', 'exec:create_scheduled_event'); 131 | 132 | grunt.registerTask('deployLambda', ['build', 'exec:package_lambda_function', 'renamePackage', 'exec:create_lambda_policy', 'exec:create_lambda_function', 'exec:create_scheduled_event']); 133 | }; 134 | -------------------------------------------------------------------------------- /lambda/src/RotateAccessKey.py: -------------------------------------------------------------------------------- 1 | import boto3 2 | from datetime import datetime 3 | import dateutil.tz 4 | import json 5 | import ast 6 | 7 | BUILD_VERSION = '@@buildversion' 8 | AWS_REGION = '@@deploymentregion' 9 | AWS_EMAIL_REGION = '@@emailregion' 10 | SERVICE_ACCOUNT_NAME = '@@serviceaccount' 11 | EMAIL_TO_ADMIN = '@@emailreportto' 12 | EMAIL_FROM = '@@emailreportfrom' 13 | EMAIL_SEND_COMPLETION_REPORT = ast.literal_eval('@@emailsendcompletionreport') 14 | GROUP_LIST = "@@exclusiongroup" 15 | 16 | # Length of mask over the IAM Access Key 17 | MASK_ACCESS_KEY_LENGTH = ast.literal_eval('@@maskaccesskeylength') 18 | 19 | # First email warning 20 | FIRST_WARNING_NUM_DAYS = @@first_warning_num_days 21 | FIRST_WARNING_MESSAGE = '@@first_warning_message' 22 | # Last email warning 23 | LAST_WARNING_NUM_DAYS = @@last_warning_num_days 24 | LAST_WARNING_MESSAGE = '@@last_warning_message' 25 | 26 | # Max AGE days of key after which it is considered EXPIRED (deactivated) 27 | KEY_MAX_AGE_IN_DAYS = @@key_max_age_in_days 28 | KEY_EXPIRED_MESSAGE = '@@key_expired_message' 29 | 30 | KEY_YOUNG_MESSAGE = '@@key_young_message' 31 | 32 | # ========================================================== 33 | 34 | # Character length of an IAM Access Key 35 | ACCESS_KEY_LENGTH = 20 36 | KEY_STATE_ACTIVE = "Active" 37 | KEY_STATE_INACTIVE = "Inactive" 38 | 39 | # ========================================================== 40 | 41 | #check to see if the MASK_ACCESS_KEY_LENGTH has been misconfigured 42 | if MASK_ACCESS_KEY_LENGTH > ACCESS_KEY_LENGTH: 43 | MASK_ACCESS_KEY_LENGTH = 16 44 | 45 | # ========================================================== 46 | def tzutc(): 47 | return dateutil.tz.tzutc() 48 | 49 | 50 | def key_age(key_created_date): 51 | tz_info = key_created_date.tzinfo 52 | age = datetime.now(tz_info) - key_created_date 53 | 54 | print 'key age %s' % age 55 | 56 | key_age_str = str(age) 57 | if 'days' not in key_age_str: 58 | return 0 59 | 60 | days = int(key_age_str.split(',')[0].split(' ')[0]) 61 | 62 | return days 63 | 64 | 65 | def send_deactivate_email(email_to, username, age, access_key_id): 66 | client = boto3.client('ses', region_name=AWS_EMAIL_REGION) 67 | data = 'The Access Key [%s] belonging to User [%s] has been automatically ' \ 68 | 'deactivated due to it being %s days old' % (access_key_id, username, age) 69 | response = client.send_email( 70 | Source=EMAIL_FROM, 71 | Destination={ 72 | 'ToAddresses': [email_to] 73 | }, 74 | Message={ 75 | 'Subject': { 76 | 'Data': 'AWS IAM Access Key Rotation - Deactivation of Access Key: %s' % access_key_id 77 | }, 78 | 'Body': { 79 | 'Text': { 80 | 'Data': data 81 | } 82 | } 83 | }) 84 | 85 | 86 | def send_completion_email(email_to, finished, deactivated_report): 87 | client = boto3.client('ses', region_name=AWS_EMAIL_REGION) 88 | data = 'AWS IAM Access Key Rotation Lambda Function (cron job) finished successfully at %s \n \n ' \ 89 | 'Deactivation Report:\n%s' % (finished, json.dumps(deactivated_report, indent=4, sort_keys=True)) 90 | response = client.send_email( 91 | Source=EMAIL_FROM, 92 | Destination={ 93 | 'ToAddresses': [email_to] 94 | }, 95 | Message={ 96 | 'Subject': { 97 | 'Data': 'AWS IAM Access Key Rotation - Lambda Function' 98 | }, 99 | 'Body': { 100 | 'Text': { 101 | 'Data': data 102 | } 103 | } 104 | }) 105 | 106 | 107 | def mask_access_key(access_key): 108 | return access_key[-(ACCESS_KEY_LENGTH-MASK_ACCESS_KEY_LENGTH):].rjust(len(access_key), "*") 109 | 110 | 111 | def lambda_handler(event, context): 112 | print '*****************************' 113 | print 'RotateAccessKey (%s): starting...' % BUILD_VERSION 114 | print '*****************************' 115 | # Connect to AWS APIs 116 | client = boto3.client('iam') 117 | 118 | users = {} 119 | data = client.list_users() 120 | print data 121 | 122 | userindex = 0 123 | 124 | for user in data['Users']: 125 | userid = user['UserId'] 126 | username = user['UserName'] 127 | users[userid] = username 128 | 129 | users_report1 = [] 130 | users_report2 = [] 131 | 132 | for user in users: 133 | userindex += 1 134 | user_keys = [] 135 | 136 | print '---------------------' 137 | print 'userindex %s' % userindex 138 | print 'user %s' % user 139 | username = users[user] 140 | print 'username %s' % username 141 | 142 | # test is a user belongs to a specific list of groups. If they do, do not invalidate the access key 143 | print "Test if the user belongs to the exclusion group" 144 | user_groups = client.list_groups_for_user(UserName=username) 145 | skip = False 146 | for groupName in user_groups['Groups']: 147 | if groupName['GroupName'] == GROUP_LIST: 148 | print 'Detected that user belongs to ', GROUP_LIST 149 | skip = True 150 | continue 151 | 152 | if skip: 153 | print "Do invalidate Access Key" 154 | continue 155 | 156 | 157 | # check to see if the current user is a special service account 158 | if username == SERVICE_ACCOUNT_NAME: 159 | print 'detected special service account %s, skipping account...', username 160 | continue 161 | 162 | access_keys = client.list_access_keys(UserName=username)['AccessKeyMetadata'] 163 | for access_key in access_keys: 164 | print access_key 165 | access_key_id = access_key['AccessKeyId'] 166 | 167 | masked_access_key_id = mask_access_key(access_key_id) 168 | 169 | print 'AccessKeyId %s' % masked_access_key_id 170 | 171 | existing_key_status = access_key['Status'] 172 | print existing_key_status 173 | 174 | key_created_date = access_key['CreateDate'] 175 | print 'key_created_date %s' % key_created_date 176 | 177 | age = key_age(key_created_date) 178 | print 'age %s' % age 179 | 180 | # we only need to examine the currently Active and about to expire keys 181 | if existing_key_status == "Inactive": 182 | key_state = 'key is already in an INACTIVE state' 183 | key_info = {'accesskeyid': masked_access_key_id, 'age': age, 'state': key_state, 'changed': False} 184 | user_keys.append(key_info) 185 | continue 186 | 187 | key_state = '' 188 | key_state_changed = False 189 | if age < FIRST_WARNING_NUM_DAYS: 190 | key_state = KEY_YOUNG_MESSAGE 191 | elif age == FIRST_WARNING_NUM_DAYS: 192 | key_state = FIRST_WARNING_MESSAGE 193 | elif age == LAST_WARNING_NUM_DAYS: 194 | key_state = LAST_WARNING_MESSAGE 195 | elif age >= KEY_MAX_AGE_IN_DAYS: 196 | key_state = KEY_EXPIRED_MESSAGE 197 | client.update_access_key(UserName=username, AccessKeyId=access_key_id, Status=KEY_STATE_INACTIVE) 198 | send_deactivate_email(EMAIL_TO_ADMIN, username, age, masked_access_key_id) 199 | key_state_changed = True 200 | 201 | print 'key_state %s' % key_state 202 | 203 | key_info = {'accesskeyid': masked_access_key_id, 'age': age, 'state': key_state, 'changed': key_state_changed} 204 | user_keys.append(key_info) 205 | 206 | user_info_with_username = {'userid': userindex, 'username': username, 'keys': user_keys} 207 | user_info_without_username = {'userid': userindex, 'keys': user_keys} 208 | 209 | users_report1.append(user_info_with_username) 210 | users_report2.append(user_info_without_username) 211 | 212 | finished = str(datetime.now()) 213 | deactivated_report1 = {'reportdate': finished, 'users': users_report1} 214 | print 'deactivated_report1 %s ' % deactivated_report1 215 | 216 | if EMAIL_SEND_COMPLETION_REPORT: 217 | deactivated_report2 = {'reportdate': finished, 'users': users_report2} 218 | send_completion_email(EMAIL_TO_ADMIN, finished, deactivated_report2) 219 | 220 | print '*****************************' 221 | print 'Completed (%s): %s' % (BUILD_VERSION, finished) 222 | print '*****************************' 223 | return deactivated_report1 224 | 225 | #if __name__ == "__main__": 226 | # event = 1 227 | # context = 1 228 | # lambda_handler(event, context) 229 | -------------------------------------------------------------------------------- /readme.md: -------------------------------------------------------------------------------- 1 | 2 | 3 | # AWS Lambda - IAM Access Key Disabler 4 | 5 | ![Image of KeyIcon](/docs/images/GitHubTepapaKeyIcon.jpg) 6 | 7 | The AWS Key disabler is a Lambda Function that disables AWS IAM User Access Keys after a set amount of time in order to reduce the risk associated with old access keys. 8 | 9 | ## AWS Lambda Architecture 10 | 11 | ![Image of Arch](/docs/images/GitHubTepapaLambda.png) 12 | 13 | ## SysOps Output for EndUser 14 | 15 | ![Image of iPhoneEmail](/docs/images/GitHubTepapaOutput.png) 16 | 17 | ## Developer Toolchain 18 | 19 | ![Image of Toolchain](/docs/images/GitHubTepapaToolchain.png) 20 | 21 | ## Current Limitations 22 | 23 | * A report containing the output (json) of scan will be sent to a single defined sysadmin account, refer to the `report_to` attribute in the `/grunt/package.json` build configuration file. 24 | * Keys are only disabled, not deleted nor replaced 25 | 26 | ## Prerequisites 27 | 28 | This script requires the following components to run. 29 | * Node.js with NPM installed https://nodejs.org/en/ 30 | * Gruntjs installed http://gruntjs.com/ 31 | * AWSCLI commandline tool installed https://aws.amazon.com/cli/ 32 | 33 | It also assumes that you have an AWS account with SES enabled, ie domain verified and sandbox mode removed. 34 | 35 | ## Installation instructions 36 | 37 | These instructions are for OSX. Your mileage may vary on Windows and other \*nix. 38 | 39 | 1. Grab yourself a copy of this script 40 | 2. Navigate into the `/grunt` folder 41 | 3. Setup the Grunt task runner, e.g. install its deps: `npm install` 42 | 4. Fill in the following information in `/grunt/package.json` 43 | 1. Set the `aws_account_number` value to your AWS account id found on https://portal.aws.amazon.com/gp/aws/manageYourAccount 44 | 2. Set the `first_warning` and `last_warning` to the age that the key has to be in days to trigger a warning. These limits trigger an email send to `report_to` 45 | 3. Set the `expiry` to the age in days when the key expires. At this age the key is disabled and an email is triggered to `report_to` notifying this change 46 | 4. Set the `serviceaccount` to the account username you want the script to ignore 47 | 5. Set the `exclusiongroup` to the name of a group assigned to users you want the script to ignore. 48 | 6. Set the `send_completion_report` value to `True` to enable email delivery via SES 49 | 7. Set the `report_to` value to the email address you'd like to receive deletion reports to 50 | 8. Set the `report_from` value to the email address you'd like to use as the sender address for deletion reports. Note that the domain for this needs to be verified in AWS SES. 51 | 9. Set the `deployment_region` to a region that supports Lambda. 52 | 10 Set the `email_region` to the region that supports SES. Also ensure that the region has SES sandbox mode disabled. 53 | * See the AWS Region table for support https://aws.amazon.com/about-aws/global-infrastructure/regional-product-services/ 54 | 5. Ensure you can successfully connect to AWS from the CLI, eg run `aws iam get-user` to verify successful connection 55 | 6. from the `/grunt` directory run `grunt bumpup && grunt deployLambda` to bump your version number and perform a build/deploy of the Lambda function to the selected region 56 | 57 | ## Invoke the Lambda Function manually from the commandline using the AWSCLI 58 | 59 | Execute the lambda function by name, `AccessKeyRotation`, logging the output of the scan to a file called `scan.report.log`: 60 | 61 | `aws lambda invoke --function-name AccessKeyRotation scan.report.log --region us-east-1` 62 | ```javascript 63 | { 64 | "StatusCode": 200 65 | } 66 | ``` 67 | 68 | Use `jq` to render the contents of the `scan.report.log` to the console: 69 | 70 | `jq '.' scan.report.log` 71 | ```javascript 72 | { 73 | "reportdate": "2016-06-26 10:37:24.071091", 74 | "users": [ 75 | { 76 | "username": "TestS3User", 77 | "userid": "1", 78 | "keys": [ 79 | { 80 | "age": 72, 81 | "changed": false, 82 | "state": "key is already in an INACTIVE state", 83 | "accesskeyid": "**************Q3GA1" 84 | }, 85 | { 86 | "age": 12, 87 | "changed": false, 88 | "state": "key is still young", 89 | "accesskeyid": "**************F3AA2" 90 | } 91 | ] 92 | }, 93 | { 94 | "username": "BlahUser22", 95 | "userid": "2", 96 | "keys": [] 97 | }, 98 | { 99 | "username": "LambdaFake1", 100 | "userid": "3", 101 | "keys": [ 102 | { 103 | "age": 23, 104 | "changed": false, 105 | "state": "key is due to expire in 1 week (7 days)", 106 | "accesskeyid": "**************DFG12" 107 | }, 108 | { 109 | "age": 296, 110 | "changed": false, 111 | "state": "key is already in an INACTIVE state", 112 | "accesskeyid": "**************4ZASD" 113 | } 114 | ] 115 | }, 116 | { 117 | "username": "apiuser49", 118 | "userid": "4", 119 | "keys": [ 120 | { 121 | "age": 30, 122 | "changed": true, 123 | "state": "key is now EXPIRED! Changing key to INACTIVE state", 124 | "accesskeyid": "**************ER2E2" 125 | }, 126 | { 127 | "age": 107, 128 | "changed": false, 129 | "state": "key is already in an INACTIVE state", 130 | "accesskeyid": "**************AWQ4K" 131 | } 132 | ] 133 | }, 134 | { 135 | "username": "UserEMRKinesis", 136 | "userid": "5", 137 | "keys": [ 138 | { 139 | "age": 30, 140 | "changed": false, 141 | "state": "key is now EXPIRED! Changing key to INACTIVE state", 142 | "accesskeyid": "**************MGB41A" 143 | } 144 | ] 145 | }, 146 | { 147 | "username": "CDN-Drupal", 148 | "userid": "6", 149 | "keys": [ 150 | { 151 | "age": 10, 152 | "changed": false, 153 | "state": "key is still young", 154 | "accesskeyid": "**************ZDSQ5A" 155 | }, 156 | { 157 | "age": 5, 158 | "changed": false, 159 | "state": "key is still young", 160 | "accesskeyid": "**************E3ODA" 161 | } 162 | ] 163 | }, 164 | { 165 | "username": "ChocDonutUser1", 166 | "userid": "7", 167 | "keys": [ 168 | { 169 | "age": 59, 170 | "changed": false, 171 | "state": "key is already in an INACTIVE state", 172 | "accesskeyid": "**************CSA123" 173 | } 174 | ] 175 | }, 176 | { 177 | "username": "ChocDonut2", 178 | "userid": "8", 179 | "keys": [ 180 | { 181 | "age": 60, 182 | "changed": false, 183 | "state": "key is already in an INACTIVE state", 184 | "accesskeyid": "**************FDGD2" 185 | } 186 | ] 187 | }, 188 | { 189 | "username": "admin.skynet@cyberdyne.systems.com", 190 | "userid": "9", 191 | "keys": [ 192 | { 193 | "age": 45, 194 | "changed": false, 195 | "state": "key is already in an INACTIVE state", 196 | "accesskeyid": "**************BLQ5GJ" 197 | }, 198 | { 199 | "age": 71, 200 | "changed": false, 201 | "state": "key is already in an INACTIVE state", 202 | "accesskeyid": "**************GJFF53" 203 | } 204 | ] 205 | } 206 | ] 207 | } 208 | ``` 209 | 210 | ## Additional configuration option 211 | 212 | * You can choose to set the message used for each warning and the final disabling by changing the values under `key_disabler.keystates..message` 213 | * You can change the length of masking under `key_disabler.mask_accesskey_length`. The access keys are 20 characters in length. 214 | 215 | ## Troubleshooting 216 | 217 | This script is provided as is. We are happy to answer questions as time allows but can't give any promises. 218 | 219 | If things don't work ensure that: 220 | * You can authenticate successfully against AWS using the AWSCLI commandline tool 221 | * SES is not in sandbox mode and the sender domain has been verified 222 | * The selected region provides both Lambda and SES https://aws.amazon.com/about-aws/global-infrastructure/regional-product-services/ 223 | 224 | ## Bonus Points 225 | 226 | Once the Lambda Function has been successfully deployed - the following commands can be performed: 227 | 228 | 1. `aws lambda list-functions` 229 | 2. `openssl dgst -binary -sha256 ..\Releases\AccessKeyRotationPackage.1.0.18.zip | openssl base64` 230 | 3. `aws lambda invoke --function-name AccessKeyRotation report.log --region us-east-1` 231 | 4. `jq '.' report.log` 232 | 5. `jq '.users[] | select(.username=="johndoe")' report.log` 233 | 5. `jq '.' report.log | grep age | cut -d':' -f2 | sort -n` 234 | 235 | ## Bonus Bonus Points 236 | 237 | 1. `jq 'def maximal_by(f): (map(f) | max) as $mx | .[] | select(f == $mx); .users | maximal_by(.keys[].age)' report.log` 238 | 2. `jq 'def minimal_by(f): (map(f) | min) as $mn | .[] | select(f == $mn); .users | minimal_by(.keys[].age)' report.log` 239 | -------------------------------------------------------------------------------- /grunt/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "key_disabler", 3 | "version": "1.1.2", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "key_disabler", 9 | "version": "1.1.2", 10 | "license": "ISC", 11 | "dependencies": { 12 | "grunt": "^1.4.1", 13 | "grunt-cli": "^1.4.3", 14 | "grunt-contrib-jshint": "^3.0.0", 15 | "grunt-contrib-watch": "^1.1.0", 16 | "grunt-exec": "^0.4.6", 17 | "grunt-jsbeautifier": "^0.2.7" 18 | }, 19 | "devDependencies": { 20 | "grunt-bumpup": "^0.6.3", 21 | "grunt-contrib-rename": "^0.2.0", 22 | "grunt-replace": "^2.0.2" 23 | } 24 | }, 25 | "node_modules/abbrev": { 26 | "version": "1.1.1", 27 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 28 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 29 | }, 30 | "node_modules/ansi-styles": { 31 | "version": "4.3.0", 32 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 33 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 34 | "dependencies": { 35 | "color-convert": "^2.0.1" 36 | }, 37 | "engines": { 38 | "node": ">=8" 39 | }, 40 | "funding": { 41 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 42 | } 43 | }, 44 | "node_modules/applause": { 45 | "version": "2.0.4", 46 | "resolved": "https://registry.npmjs.org/applause/-/applause-2.0.4.tgz", 47 | "integrity": "sha512-wFhNjSoflbAEgelX3psyKSXV2iQFjuYW31DEhcCOD/bQ98VdfltLclK4p1mI6E58Qp4Q7+5RCbBdr+Nc9b5QhA==", 48 | "dev": true, 49 | "dependencies": { 50 | "lodash": "^4.17.21", 51 | "optional-require": "^1.0.2" 52 | }, 53 | "engines": { 54 | "node": ">=10" 55 | }, 56 | "optionalDependencies": { 57 | "cson-parser": "^4.0.8", 58 | "js-yaml": "^4.0.0" 59 | } 60 | }, 61 | "node_modules/applause/node_modules/argparse": { 62 | "version": "2.0.1", 63 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 64 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 65 | "dev": true, 66 | "optional": true 67 | }, 68 | "node_modules/applause/node_modules/js-yaml": { 69 | "version": "4.1.0", 70 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 71 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 72 | "dev": true, 73 | "optional": true, 74 | "dependencies": { 75 | "argparse": "^2.0.1" 76 | }, 77 | "bin": { 78 | "js-yaml": "bin/js-yaml.js" 79 | } 80 | }, 81 | "node_modules/argparse": { 82 | "version": "1.0.10", 83 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 84 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 85 | "dependencies": { 86 | "sprintf-js": "~1.0.2" 87 | } 88 | }, 89 | "node_modules/array-each": { 90 | "version": "1.0.1", 91 | "resolved": "https://registry.npmjs.org/array-each/-/array-each-1.0.1.tgz", 92 | "integrity": "sha1-p5SvDAWrF1KEbudTofIRoFugxE8=", 93 | "engines": { 94 | "node": ">=0.10.0" 95 | } 96 | }, 97 | "node_modules/array-slice": { 98 | "version": "1.1.0", 99 | "resolved": "https://registry.npmjs.org/array-slice/-/array-slice-1.1.0.tgz", 100 | "integrity": "sha512-B1qMD3RBP7O8o0H2KbrXDyB0IccejMF15+87Lvlor12ONPRHP6gTjXMNkt/d3ZuOGbAe66hFmaCfECI24Ufp6w==", 101 | "engines": { 102 | "node": ">=0.10.0" 103 | } 104 | }, 105 | "node_modules/async": { 106 | "version": "2.6.3", 107 | "resolved": "https://registry.npmjs.org/async/-/async-2.6.3.tgz", 108 | "integrity": "sha512-zflvls11DCy+dQWzTW2dzuilv8Z5X/pjfmZOWba6TNIVDm+2UDaJmXSOXlasHKfNBs8oo3M0aT50fDEWfKZjXg==", 109 | "dependencies": { 110 | "lodash": "^4.17.14" 111 | } 112 | }, 113 | "node_modules/balanced-match": { 114 | "version": "1.0.2", 115 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 116 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 117 | }, 118 | "node_modules/body": { 119 | "version": "5.1.0", 120 | "resolved": "https://registry.npmjs.org/body/-/body-5.1.0.tgz", 121 | "integrity": "sha1-5LoM5BCkaTYyM2dgnstOZVMSUGk=", 122 | "dependencies": { 123 | "continuable-cache": "^0.3.1", 124 | "error": "^7.0.0", 125 | "raw-body": "~1.1.0", 126 | "safe-json-parse": "~1.0.1" 127 | } 128 | }, 129 | "node_modules/brace-expansion": { 130 | "version": "1.1.11", 131 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 132 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 133 | "dependencies": { 134 | "balanced-match": "^1.0.0", 135 | "concat-map": "0.0.1" 136 | } 137 | }, 138 | "node_modules/braces": { 139 | "version": "3.0.2", 140 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 141 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 142 | "dependencies": { 143 | "fill-range": "^7.0.1" 144 | }, 145 | "engines": { 146 | "node": ">=8" 147 | } 148 | }, 149 | "node_modules/bytes": { 150 | "version": "1.0.0", 151 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-1.0.0.tgz", 152 | "integrity": "sha1-NWnt6Lo0MV+rmcPpLLBMciDeH6g=" 153 | }, 154 | "node_modules/call-bind": { 155 | "version": "1.0.2", 156 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 157 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 158 | "dependencies": { 159 | "function-bind": "^1.1.1", 160 | "get-intrinsic": "^1.0.2" 161 | }, 162 | "funding": { 163 | "url": "https://github.com/sponsors/ljharb" 164 | } 165 | }, 166 | "node_modules/chalk": { 167 | "version": "4.1.1", 168 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.1.tgz", 169 | "integrity": "sha512-diHzdDKxcU+bAsUboHLPEDQiw0qEe0qd7SYUn3HgcFlWgbDcfLGswOHYeGrHKzG9z6UYf01d9VFMfZxPM1xZSg==", 170 | "dependencies": { 171 | "ansi-styles": "^4.1.0", 172 | "supports-color": "^7.1.0" 173 | }, 174 | "engines": { 175 | "node": ">=10" 176 | }, 177 | "funding": { 178 | "url": "https://github.com/chalk/chalk?sponsor=1" 179 | } 180 | }, 181 | "node_modules/cli": { 182 | "version": "1.0.1", 183 | "resolved": "https://registry.npmjs.org/cli/-/cli-1.0.1.tgz", 184 | "integrity": "sha1-IoF1NPJL+klQw01TLUjsvGIbjBQ=", 185 | "dependencies": { 186 | "exit": "0.1.2", 187 | "glob": "^7.1.1" 188 | }, 189 | "engines": { 190 | "node": ">=0.2.5" 191 | } 192 | }, 193 | "node_modules/coffeescript": { 194 | "version": "1.12.7", 195 | "resolved": "https://registry.npmjs.org/coffeescript/-/coffeescript-1.12.7.tgz", 196 | "integrity": "sha512-pLXHFxQMPklVoEekowk8b3erNynC+DVJzChxS/LCBBgR6/8AJkHivkm//zbowcfc7BTCAjryuhx6gPqPRfsFoA==", 197 | "dev": true, 198 | "optional": true, 199 | "bin": { 200 | "cake": "bin/cake", 201 | "coffee": "bin/coffee" 202 | }, 203 | "engines": { 204 | "node": ">=0.8.0" 205 | } 206 | }, 207 | "node_modules/color-convert": { 208 | "version": "2.0.1", 209 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 210 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 211 | "dependencies": { 212 | "color-name": "~1.1.4" 213 | }, 214 | "engines": { 215 | "node": ">=7.0.0" 216 | } 217 | }, 218 | "node_modules/color-name": { 219 | "version": "1.1.4", 220 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 221 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 222 | }, 223 | "node_modules/colors": { 224 | "version": "1.1.2", 225 | "resolved": "https://registry.npmjs.org/colors/-/colors-1.1.2.tgz", 226 | "integrity": "sha1-FopHAXVran9RoSzgyXv6KMCE7WM=", 227 | "engines": { 228 | "node": ">=0.1.90" 229 | } 230 | }, 231 | "node_modules/commander": { 232 | "version": "2.20.3", 233 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", 234 | "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==" 235 | }, 236 | "node_modules/concat-map": { 237 | "version": "0.0.1", 238 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 239 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 240 | }, 241 | "node_modules/config-chain": { 242 | "version": "1.1.13", 243 | "resolved": "https://registry.npmjs.org/config-chain/-/config-chain-1.1.13.tgz", 244 | "integrity": "sha512-qj+f8APARXHrM0hraqXYb2/bOVSV4PvJQlNZ/DVj0QrmNM2q2euizkeuVckQ57J+W0mRH6Hvi+k50M4Jul2VRQ==", 245 | "dependencies": { 246 | "ini": "^1.3.4", 247 | "proto-list": "~1.2.1" 248 | } 249 | }, 250 | "node_modules/console-browserify": { 251 | "version": "1.1.0", 252 | "resolved": "https://registry.npmjs.org/console-browserify/-/console-browserify-1.1.0.tgz", 253 | "integrity": "sha1-8CQcRXMKn8YyOyBtvzjtx0HQuxA=", 254 | "dependencies": { 255 | "date-now": "^0.1.4" 256 | } 257 | }, 258 | "node_modules/continuable-cache": { 259 | "version": "0.3.1", 260 | "resolved": "https://registry.npmjs.org/continuable-cache/-/continuable-cache-0.3.1.tgz", 261 | "integrity": "sha1-vXJ6f67XfnH/OYWskzUakSczrQ8=" 262 | }, 263 | "node_modules/core-util-is": { 264 | "version": "1.0.2", 265 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 266 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 267 | }, 268 | "node_modules/cson-parser": { 269 | "version": "4.0.9", 270 | "resolved": "https://registry.npmjs.org/cson-parser/-/cson-parser-4.0.9.tgz", 271 | "integrity": "sha512-I79SAcCYquWnEfXYj8hBqOOWKj6eH6zX1hhX3yqmS4K3bYp7jME3UFpHPzu3rUew0oyfc0s8T6IlWGXRAheHag==", 272 | "dev": true, 273 | "optional": true, 274 | "dependencies": { 275 | "coffeescript": "1.12.7" 276 | }, 277 | "engines": { 278 | "node": ">=10.13" 279 | } 280 | }, 281 | "node_modules/date-now": { 282 | "version": "0.1.4", 283 | "resolved": "https://registry.npmjs.org/date-now/-/date-now-0.1.4.tgz", 284 | "integrity": "sha1-6vQ5/U1ISK105cx9vvIAZyueNFs=" 285 | }, 286 | "node_modules/dateformat": { 287 | "version": "3.0.3", 288 | "resolved": "https://registry.npmjs.org/dateformat/-/dateformat-3.0.3.tgz", 289 | "integrity": "sha512-jyCETtSl3VMZMWeRo7iY1FL19ges1t55hMo5yaam4Jrsm5EPL89UQkoQRyiI+Yf4k8r2ZpdngkV8hr1lIdjb3Q==", 290 | "engines": { 291 | "node": "*" 292 | } 293 | }, 294 | "node_modules/debug": { 295 | "version": "3.2.7", 296 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 297 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 298 | "dependencies": { 299 | "ms": "^2.1.1" 300 | } 301 | }, 302 | "node_modules/deep-extend": { 303 | "version": "0.6.0", 304 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 305 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", 306 | "engines": { 307 | "node": ">=4.0.0" 308 | } 309 | }, 310 | "node_modules/detect-file": { 311 | "version": "1.0.0", 312 | "resolved": "https://registry.npmjs.org/detect-file/-/detect-file-1.0.0.tgz", 313 | "integrity": "sha1-8NZtA2cqglyxtzvbP+YjEMjlUrc=", 314 | "engines": { 315 | "node": ">=0.10.0" 316 | } 317 | }, 318 | "node_modules/dom-serializer": { 319 | "version": "0.2.2", 320 | "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-0.2.2.tgz", 321 | "integrity": "sha512-2/xPb3ORsQ42nHYiSunXkDjPLBaEj/xTwUO4B7XCZQTRk7EBtTOPaygh10YAAh2OI1Qrp6NWfpAhzswj0ydt9g==", 322 | "dependencies": { 323 | "domelementtype": "^2.0.1", 324 | "entities": "^2.0.0" 325 | } 326 | }, 327 | "node_modules/dom-serializer/node_modules/domelementtype": { 328 | "version": "2.2.0", 329 | "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.2.0.tgz", 330 | "integrity": "sha512-DtBMo82pv1dFtUmHyr48beiuq792Sxohr+8Hm9zoxklYPfa6n0Z3Byjj2IV7bmr2IyqClnqEQhfgHJJ5QF0R5A==", 331 | "funding": [ 332 | { 333 | "type": "github", 334 | "url": "https://github.com/sponsors/fb55" 335 | } 336 | ] 337 | }, 338 | "node_modules/dom-serializer/node_modules/entities": { 339 | "version": "2.2.0", 340 | "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz", 341 | "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==", 342 | "funding": { 343 | "url": "https://github.com/fb55/entities?sponsor=1" 344 | } 345 | }, 346 | "node_modules/domelementtype": { 347 | "version": "1.3.1", 348 | "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-1.3.1.tgz", 349 | "integrity": "sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w==" 350 | }, 351 | "node_modules/domhandler": { 352 | "version": "2.3.0", 353 | "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-2.3.0.tgz", 354 | "integrity": "sha1-LeWaCCLVAn+r/28DLCsloqir5zg=", 355 | "dependencies": { 356 | "domelementtype": "1" 357 | } 358 | }, 359 | "node_modules/domutils": { 360 | "version": "1.5.1", 361 | "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.5.1.tgz", 362 | "integrity": "sha1-3NhIiib1Y9YQeeSMn3t+Mjc2gs8=", 363 | "dependencies": { 364 | "dom-serializer": "0", 365 | "domelementtype": "1" 366 | } 367 | }, 368 | "node_modules/editorconfig": { 369 | "version": "0.15.3", 370 | "resolved": "https://registry.npmjs.org/editorconfig/-/editorconfig-0.15.3.tgz", 371 | "integrity": "sha512-M9wIMFx96vq0R4F+gRpY3o2exzb8hEj/n9S8unZtHSvYjibBp/iMufSzvmOcV/laG0ZtuTVGtiJggPOSW2r93g==", 372 | "dependencies": { 373 | "commander": "^2.19.0", 374 | "lru-cache": "^4.1.5", 375 | "semver": "^5.6.0", 376 | "sigmund": "^1.0.1" 377 | }, 378 | "bin": { 379 | "editorconfig": "bin/editorconfig" 380 | } 381 | }, 382 | "node_modules/editorconfig/node_modules/semver": { 383 | "version": "5.7.1", 384 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 385 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 386 | "bin": { 387 | "semver": "bin/semver" 388 | } 389 | }, 390 | "node_modules/entities": { 391 | "version": "1.0.0", 392 | "resolved": "https://registry.npmjs.org/entities/-/entities-1.0.0.tgz", 393 | "integrity": "sha1-sph6o4ITR/zeZCsk/fyeT7cSvyY=" 394 | }, 395 | "node_modules/error": { 396 | "version": "7.2.1", 397 | "resolved": "https://registry.npmjs.org/error/-/error-7.2.1.tgz", 398 | "integrity": "sha512-fo9HBvWnx3NGUKMvMwB/CBCMMrfEJgbDTVDEkPygA3Bdd3lM1OyCd+rbQ8BwnpF6GdVeOLDNmyL4N5Bg80ZvdA==", 399 | "dependencies": { 400 | "string-template": "~0.2.1" 401 | } 402 | }, 403 | "node_modules/esprima": { 404 | "version": "4.0.1", 405 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 406 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 407 | "bin": { 408 | "esparse": "bin/esparse.js", 409 | "esvalidate": "bin/esvalidate.js" 410 | }, 411 | "engines": { 412 | "node": ">=4" 413 | } 414 | }, 415 | "node_modules/eventemitter2": { 416 | "version": "0.4.14", 417 | "resolved": "https://registry.npmjs.org/eventemitter2/-/eventemitter2-0.4.14.tgz", 418 | "integrity": "sha1-j2G3XN4BKy6esoTUVFWDtWQ7Yas=" 419 | }, 420 | "node_modules/exit": { 421 | "version": "0.1.2", 422 | "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", 423 | "integrity": "sha1-BjJjj42HfMghB9MKD/8aF8uhzQw=", 424 | "engines": { 425 | "node": ">= 0.8.0" 426 | } 427 | }, 428 | "node_modules/expand-tilde": { 429 | "version": "2.0.2", 430 | "resolved": "https://registry.npmjs.org/expand-tilde/-/expand-tilde-2.0.2.tgz", 431 | "integrity": "sha1-l+gBqgUt8CRU3kawK/YhZCzchQI=", 432 | "dependencies": { 433 | "homedir-polyfill": "^1.0.1" 434 | }, 435 | "engines": { 436 | "node": ">=0.10.0" 437 | } 438 | }, 439 | "node_modules/extend": { 440 | "version": "3.0.2", 441 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 442 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==" 443 | }, 444 | "node_modules/faye-websocket": { 445 | "version": "0.10.0", 446 | "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.10.0.tgz", 447 | "integrity": "sha1-TkkvjQTftviQA1B/btvy1QHnxvQ=", 448 | "dependencies": { 449 | "websocket-driver": ">=0.5.1" 450 | }, 451 | "engines": { 452 | "node": ">=0.4.0" 453 | } 454 | }, 455 | "node_modules/file-sync-cmp": { 456 | "version": "0.1.1", 457 | "resolved": "https://registry.npmjs.org/file-sync-cmp/-/file-sync-cmp-0.1.1.tgz", 458 | "integrity": "sha1-peeo/7+kk7Q7kju9TKiaU7Y7YSs=", 459 | "dev": true 460 | }, 461 | "node_modules/fill-range": { 462 | "version": "7.0.1", 463 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 464 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 465 | "dependencies": { 466 | "to-regex-range": "^5.0.1" 467 | }, 468 | "engines": { 469 | "node": ">=8" 470 | } 471 | }, 472 | "node_modules/findup-sync": { 473 | "version": "0.3.0", 474 | "resolved": "https://registry.npmjs.org/findup-sync/-/findup-sync-0.3.0.tgz", 475 | "integrity": "sha1-N5MKpdgWt3fANEXhlmzGeQpMCxY=", 476 | "dependencies": { 477 | "glob": "~5.0.0" 478 | }, 479 | "engines": { 480 | "node": ">= 0.6.0" 481 | } 482 | }, 483 | "node_modules/findup-sync/node_modules/glob": { 484 | "version": "5.0.15", 485 | "resolved": "https://registry.npmjs.org/glob/-/glob-5.0.15.tgz", 486 | "integrity": "sha1-G8k2ueAvSmA/zCIuz3Yz0wuLk7E=", 487 | "dependencies": { 488 | "inflight": "^1.0.4", 489 | "inherits": "2", 490 | "minimatch": "2 || 3", 491 | "once": "^1.3.0", 492 | "path-is-absolute": "^1.0.0" 493 | }, 494 | "engines": { 495 | "node": "*" 496 | } 497 | }, 498 | "node_modules/fined": { 499 | "version": "1.2.0", 500 | "resolved": "https://registry.npmjs.org/fined/-/fined-1.2.0.tgz", 501 | "integrity": "sha512-ZYDqPLGxDkDhDZBjZBb+oD1+j0rA4E0pXY50eplAAOPg2N/gUBSSk5IM1/QhPfyVo19lJ+CvXpqfvk+b2p/8Ng==", 502 | "dependencies": { 503 | "expand-tilde": "^2.0.2", 504 | "is-plain-object": "^2.0.3", 505 | "object.defaults": "^1.1.0", 506 | "object.pick": "^1.2.0", 507 | "parse-filepath": "^1.0.1" 508 | }, 509 | "engines": { 510 | "node": ">= 0.10" 511 | } 512 | }, 513 | "node_modules/flagged-respawn": { 514 | "version": "1.0.1", 515 | "resolved": "https://registry.npmjs.org/flagged-respawn/-/flagged-respawn-1.0.1.tgz", 516 | "integrity": "sha512-lNaHNVymajmk0OJMBn8fVUAU1BtDeKIqKoVhk4xAALB57aALg6b4W0MfJ/cUE0g9YBXy5XhSlPIpYIJ7HaY/3Q==", 517 | "engines": { 518 | "node": ">= 0.10" 519 | } 520 | }, 521 | "node_modules/for-in": { 522 | "version": "1.0.2", 523 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", 524 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", 525 | "engines": { 526 | "node": ">=0.10.0" 527 | } 528 | }, 529 | "node_modules/for-own": { 530 | "version": "1.0.0", 531 | "resolved": "https://registry.npmjs.org/for-own/-/for-own-1.0.0.tgz", 532 | "integrity": "sha1-xjMy9BXO3EsE2/5wz4NklMU8tEs=", 533 | "dependencies": { 534 | "for-in": "^1.0.1" 535 | }, 536 | "engines": { 537 | "node": ">=0.10.0" 538 | } 539 | }, 540 | "node_modules/fs.realpath": { 541 | "version": "1.0.0", 542 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 543 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 544 | }, 545 | "node_modules/function-bind": { 546 | "version": "1.1.1", 547 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 548 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 549 | }, 550 | "node_modules/gaze": { 551 | "version": "1.1.3", 552 | "resolved": "https://registry.npmjs.org/gaze/-/gaze-1.1.3.tgz", 553 | "integrity": "sha512-BRdNm8hbWzFzWHERTrejLqwHDfS4GibPoq5wjTPIoJHoBtKGPg3xAFfxmM+9ztbXelxcf2hwQcaz1PtmFeue8g==", 554 | "dependencies": { 555 | "globule": "^1.0.0" 556 | }, 557 | "engines": { 558 | "node": ">= 4.0.0" 559 | } 560 | }, 561 | "node_modules/get-intrinsic": { 562 | "version": "1.1.1", 563 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", 564 | "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", 565 | "dependencies": { 566 | "function-bind": "^1.1.1", 567 | "has": "^1.0.3", 568 | "has-symbols": "^1.0.1" 569 | }, 570 | "funding": { 571 | "url": "https://github.com/sponsors/ljharb" 572 | } 573 | }, 574 | "node_modules/getobject": { 575 | "version": "1.0.1", 576 | "resolved": "https://registry.npmjs.org/getobject/-/getobject-1.0.1.tgz", 577 | "integrity": "sha512-tj18lLe+917AACr6BdVoUuHnBPTVd9BEJp1vxnMZ58ztNvuxz9Ufa+wf3g37tlGITH35jggwZ2d9lcgHJJgXfQ==", 578 | "engines": { 579 | "node": ">=10" 580 | } 581 | }, 582 | "node_modules/glob": { 583 | "version": "7.1.7", 584 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.7.tgz", 585 | "integrity": "sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ==", 586 | "dependencies": { 587 | "fs.realpath": "^1.0.0", 588 | "inflight": "^1.0.4", 589 | "inherits": "2", 590 | "minimatch": "^3.0.4", 591 | "once": "^1.3.0", 592 | "path-is-absolute": "^1.0.0" 593 | }, 594 | "engines": { 595 | "node": "*" 596 | }, 597 | "funding": { 598 | "url": "https://github.com/sponsors/isaacs" 599 | } 600 | }, 601 | "node_modules/global-modules": { 602 | "version": "1.0.0", 603 | "resolved": "https://registry.npmjs.org/global-modules/-/global-modules-1.0.0.tgz", 604 | "integrity": "sha512-sKzpEkf11GpOFuw0Zzjzmt4B4UZwjOcG757PPvrfhxcLFbq0wpsgpOqxpxtxFiCG4DtG93M6XRVbF2oGdev7bg==", 605 | "dependencies": { 606 | "global-prefix": "^1.0.1", 607 | "is-windows": "^1.0.1", 608 | "resolve-dir": "^1.0.0" 609 | }, 610 | "engines": { 611 | "node": ">=0.10.0" 612 | } 613 | }, 614 | "node_modules/global-prefix": { 615 | "version": "1.0.2", 616 | "resolved": "https://registry.npmjs.org/global-prefix/-/global-prefix-1.0.2.tgz", 617 | "integrity": "sha1-2/dDxsFJklk8ZVVoy2btMsASLr4=", 618 | "dependencies": { 619 | "expand-tilde": "^2.0.2", 620 | "homedir-polyfill": "^1.0.1", 621 | "ini": "^1.3.4", 622 | "is-windows": "^1.0.1", 623 | "which": "^1.2.14" 624 | }, 625 | "engines": { 626 | "node": ">=0.10.0" 627 | } 628 | }, 629 | "node_modules/global-prefix/node_modules/which": { 630 | "version": "1.3.1", 631 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 632 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 633 | "dependencies": { 634 | "isexe": "^2.0.0" 635 | }, 636 | "bin": { 637 | "which": "bin/which" 638 | } 639 | }, 640 | "node_modules/globule": { 641 | "version": "1.3.2", 642 | "resolved": "https://registry.npmjs.org/globule/-/globule-1.3.2.tgz", 643 | "integrity": "sha512-7IDTQTIu2xzXkT+6mlluidnWo+BypnbSoEVVQCGfzqnl5Ik8d3e1d4wycb8Rj9tWW+Z39uPWsdlquqiqPCd/pA==", 644 | "dependencies": { 645 | "glob": "~7.1.1", 646 | "lodash": "~4.17.10", 647 | "minimatch": "~3.0.2" 648 | }, 649 | "engines": { 650 | "node": ">= 0.10" 651 | } 652 | }, 653 | "node_modules/grunt": { 654 | "version": "1.4.1", 655 | "resolved": "https://registry.npmjs.org/grunt/-/grunt-1.4.1.tgz", 656 | "integrity": "sha512-ZXIYXTsAVrA7sM+jZxjQdrBOAg7DyMUplOMhTaspMRExei+fD0BTwdWXnn0W5SXqhb/Q/nlkzXclSi3IH55PIA==", 657 | "dependencies": { 658 | "dateformat": "~3.0.3", 659 | "eventemitter2": "~0.4.13", 660 | "exit": "~0.1.2", 661 | "findup-sync": "~0.3.0", 662 | "glob": "~7.1.6", 663 | "grunt-cli": "~1.4.2", 664 | "grunt-known-options": "~2.0.0", 665 | "grunt-legacy-log": "~3.0.0", 666 | "grunt-legacy-util": "~2.0.1", 667 | "iconv-lite": "~0.4.13", 668 | "js-yaml": "~3.14.0", 669 | "minimatch": "~3.0.4", 670 | "mkdirp": "~1.0.4", 671 | "nopt": "~3.0.6", 672 | "rimraf": "~3.0.2" 673 | }, 674 | "bin": { 675 | "grunt": "bin/grunt" 676 | }, 677 | "engines": { 678 | "node": ">=8" 679 | } 680 | }, 681 | "node_modules/grunt-bumpup": { 682 | "version": "0.6.3", 683 | "resolved": "https://registry.npmjs.org/grunt-bumpup/-/grunt-bumpup-0.6.3.tgz", 684 | "integrity": "sha1-dU6Wu2pTN9C5VInl3EmWuvyLtBQ=", 685 | "dev": true, 686 | "dependencies": { 687 | "moment": "^2.8.3", 688 | "semver": "^4.0.3" 689 | }, 690 | "engines": { 691 | "node": ">=0.8.0" 692 | }, 693 | "peerDependencies": { 694 | "grunt": ">=0.4.0" 695 | } 696 | }, 697 | "node_modules/grunt-cli": { 698 | "version": "1.4.3", 699 | "resolved": "https://registry.npmjs.org/grunt-cli/-/grunt-cli-1.4.3.tgz", 700 | "integrity": "sha512-9Dtx/AhVeB4LYzsViCjUQkd0Kw0McN2gYpdmGYKtE2a5Yt7v1Q+HYZVWhqXc/kGnxlMtqKDxSwotiGeFmkrCoQ==", 701 | "dependencies": { 702 | "grunt-known-options": "~2.0.0", 703 | "interpret": "~1.1.0", 704 | "liftup": "~3.0.1", 705 | "nopt": "~4.0.1", 706 | "v8flags": "~3.2.0" 707 | }, 708 | "bin": { 709 | "grunt": "bin/grunt" 710 | }, 711 | "engines": { 712 | "node": ">=10" 713 | } 714 | }, 715 | "node_modules/grunt-cli/node_modules/nopt": { 716 | "version": "4.0.3", 717 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.3.tgz", 718 | "integrity": "sha512-CvaGwVMztSMJLOeXPrez7fyfObdZqNUK1cPAEzLHrTybIua9pMdmmPR5YwtfNftIOMv3DPUhFaxsZMNTQO20Kg==", 719 | "dependencies": { 720 | "abbrev": "1", 721 | "osenv": "^0.1.4" 722 | }, 723 | "bin": { 724 | "nopt": "bin/nopt.js" 725 | } 726 | }, 727 | "node_modules/grunt-contrib-jshint": { 728 | "version": "3.0.0", 729 | "resolved": "https://registry.npmjs.org/grunt-contrib-jshint/-/grunt-contrib-jshint-3.0.0.tgz", 730 | "integrity": "sha512-o0V3HNK54+w2Lss/AP0LsAUCEmPDQIcgsDFvTy0sE8sdPXq/8vHdNdMEitK9Wcfoq7H6v02v6soiiwJ0wavT7A==", 731 | "dependencies": { 732 | "chalk": "^4.1.0", 733 | "hooker": "^0.2.3", 734 | "jshint": "~2.12.0" 735 | }, 736 | "engines": { 737 | "node": ">=10" 738 | } 739 | }, 740 | "node_modules/grunt-contrib-rename": { 741 | "version": "0.2.0", 742 | "resolved": "https://registry.npmjs.org/grunt-contrib-rename/-/grunt-contrib-rename-0.2.0.tgz", 743 | "integrity": "sha1-1CPU+SqZpYcncEX4MikdmM4V/co=", 744 | "dev": true, 745 | "engines": { 746 | "node": ">= 7.9.0" 747 | }, 748 | "peerDependencies": { 749 | "grunt": ">=0.4.5" 750 | } 751 | }, 752 | "node_modules/grunt-contrib-watch": { 753 | "version": "1.1.0", 754 | "resolved": "https://registry.npmjs.org/grunt-contrib-watch/-/grunt-contrib-watch-1.1.0.tgz", 755 | "integrity": "sha512-yGweN+0DW5yM+oo58fRu/XIRrPcn3r4tQx+nL7eMRwjpvk+rQY6R8o94BPK0i2UhTg9FN21hS+m8vR8v9vXfeg==", 756 | "dependencies": { 757 | "async": "^2.6.0", 758 | "gaze": "^1.1.0", 759 | "lodash": "^4.17.10", 760 | "tiny-lr": "^1.1.1" 761 | }, 762 | "engines": { 763 | "node": ">=0.10.0" 764 | } 765 | }, 766 | "node_modules/grunt-exec": { 767 | "version": "0.4.7", 768 | "resolved": "https://registry.npmjs.org/grunt-exec/-/grunt-exec-0.4.7.tgz", 769 | "integrity": "sha1-QAUf+k6wyWV+BTuV6I1ENSocLCU=", 770 | "engines": { 771 | "node": ">=0.8.0" 772 | }, 773 | "peerDependencies": { 774 | "grunt": ">=0.4" 775 | } 776 | }, 777 | "node_modules/grunt-jsbeautifier": { 778 | "version": "0.2.13", 779 | "resolved": "https://registry.npmjs.org/grunt-jsbeautifier/-/grunt-jsbeautifier-0.2.13.tgz", 780 | "integrity": "sha1-89QXOPy1+ZhO8pbVvuvEBIkQVkI=", 781 | "dependencies": { 782 | "async": "^2.0.0-rc.3", 783 | "grunt": ">=0.4.1", 784 | "js-beautify": ">=1.4.2", 785 | "lodash": ">=2.4.1", 786 | "rc": ">=0.5.5", 787 | "semver": ">=4.3.1", 788 | "underscore.string": ">=2.3.3" 789 | }, 790 | "engines": { 791 | "node": ">=0.8" 792 | } 793 | }, 794 | "node_modules/grunt-known-options": { 795 | "version": "2.0.0", 796 | "resolved": "https://registry.npmjs.org/grunt-known-options/-/grunt-known-options-2.0.0.tgz", 797 | "integrity": "sha512-GD7cTz0I4SAede1/+pAbmJRG44zFLPipVtdL9o3vqx9IEyb7b4/Y3s7r6ofI3CchR5GvYJ+8buCSioDv5dQLiA==", 798 | "engines": { 799 | "node": ">=0.10.0" 800 | } 801 | }, 802 | "node_modules/grunt-legacy-log": { 803 | "version": "3.0.0", 804 | "resolved": "https://registry.npmjs.org/grunt-legacy-log/-/grunt-legacy-log-3.0.0.tgz", 805 | "integrity": "sha512-GHZQzZmhyq0u3hr7aHW4qUH0xDzwp2YXldLPZTCjlOeGscAOWWPftZG3XioW8MasGp+OBRIu39LFx14SLjXRcA==", 806 | "dependencies": { 807 | "colors": "~1.1.2", 808 | "grunt-legacy-log-utils": "~2.1.0", 809 | "hooker": "~0.2.3", 810 | "lodash": "~4.17.19" 811 | }, 812 | "engines": { 813 | "node": ">= 0.10.0" 814 | } 815 | }, 816 | "node_modules/grunt-legacy-log-utils": { 817 | "version": "2.1.0", 818 | "resolved": "https://registry.npmjs.org/grunt-legacy-log-utils/-/grunt-legacy-log-utils-2.1.0.tgz", 819 | "integrity": "sha512-lwquaPXJtKQk0rUM1IQAop5noEpwFqOXasVoedLeNzaibf/OPWjKYvvdqnEHNmU+0T0CaReAXIbGo747ZD+Aaw==", 820 | "dependencies": { 821 | "chalk": "~4.1.0", 822 | "lodash": "~4.17.19" 823 | }, 824 | "engines": { 825 | "node": ">=10" 826 | } 827 | }, 828 | "node_modules/grunt-legacy-util": { 829 | "version": "2.0.1", 830 | "resolved": "https://registry.npmjs.org/grunt-legacy-util/-/grunt-legacy-util-2.0.1.tgz", 831 | "integrity": "sha512-2bQiD4fzXqX8rhNdXkAywCadeqiPiay0oQny77wA2F3WF4grPJXCvAcyoWUJV+po/b15glGkxuSiQCK299UC2w==", 832 | "dependencies": { 833 | "async": "~3.2.0", 834 | "exit": "~0.1.2", 835 | "getobject": "~1.0.0", 836 | "hooker": "~0.2.3", 837 | "lodash": "~4.17.21", 838 | "underscore.string": "~3.3.5", 839 | "which": "~2.0.2" 840 | }, 841 | "engines": { 842 | "node": ">=10" 843 | } 844 | }, 845 | "node_modules/grunt-legacy-util/node_modules/async": { 846 | "version": "3.2.0", 847 | "resolved": "https://registry.npmjs.org/async/-/async-3.2.0.tgz", 848 | "integrity": "sha512-TR2mEZFVOj2pLStYxLht7TyfuRzaydfpxr3k9RpHIzMgw7A64dzsdqCxH1WJyQdoe8T10nDXd9wnEigmiuHIZw==" 849 | }, 850 | "node_modules/grunt-replace": { 851 | "version": "2.0.2", 852 | "resolved": "https://registry.npmjs.org/grunt-replace/-/grunt-replace-2.0.2.tgz", 853 | "integrity": "sha512-cv7ua3vBeUpCBkb+L4vZ8hwE8Sz6Sf/mb3031kufKVfKAestekHSsDO0BK63mhrRknsAHlnkHkieIxrjHS/fJA==", 854 | "dev": true, 855 | "dependencies": { 856 | "applause": "^2.0.0", 857 | "chalk": "^4.1.0", 858 | "file-sync-cmp": "^0.1.0", 859 | "lodash": "^4.17.21" 860 | }, 861 | "engines": { 862 | "node": ">=10" 863 | } 864 | }, 865 | "node_modules/has": { 866 | "version": "1.0.3", 867 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 868 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 869 | "dependencies": { 870 | "function-bind": "^1.1.1" 871 | }, 872 | "engines": { 873 | "node": ">= 0.4.0" 874 | } 875 | }, 876 | "node_modules/has-flag": { 877 | "version": "4.0.0", 878 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 879 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 880 | "engines": { 881 | "node": ">=8" 882 | } 883 | }, 884 | "node_modules/has-symbols": { 885 | "version": "1.0.2", 886 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", 887 | "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==", 888 | "engines": { 889 | "node": ">= 0.4" 890 | }, 891 | "funding": { 892 | "url": "https://github.com/sponsors/ljharb" 893 | } 894 | }, 895 | "node_modules/homedir-polyfill": { 896 | "version": "1.0.3", 897 | "resolved": "https://registry.npmjs.org/homedir-polyfill/-/homedir-polyfill-1.0.3.tgz", 898 | "integrity": "sha512-eSmmWE5bZTK2Nou4g0AI3zZ9rswp7GRKoKXS1BLUkvPviOqs4YTN1djQIqrXy9k5gEtdLPy86JjRwsNM9tnDcA==", 899 | "dependencies": { 900 | "parse-passwd": "^1.0.0" 901 | }, 902 | "engines": { 903 | "node": ">=0.10.0" 904 | } 905 | }, 906 | "node_modules/hooker": { 907 | "version": "0.2.3", 908 | "resolved": "https://registry.npmjs.org/hooker/-/hooker-0.2.3.tgz", 909 | "integrity": "sha1-uDT3I8xKJCqmWWNFnfbZhMXT2Vk=", 910 | "engines": { 911 | "node": "*" 912 | } 913 | }, 914 | "node_modules/htmlparser2": { 915 | "version": "3.8.3", 916 | "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-3.8.3.tgz", 917 | "integrity": "sha1-mWwosZFRaovoZQGn15dX5ccMEGg=", 918 | "dependencies": { 919 | "domelementtype": "1", 920 | "domhandler": "2.3", 921 | "domutils": "1.5", 922 | "entities": "1.0", 923 | "readable-stream": "1.1" 924 | } 925 | }, 926 | "node_modules/http-parser-js": { 927 | "version": "0.5.3", 928 | "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.5.3.tgz", 929 | "integrity": "sha512-t7hjvef/5HEK7RWTdUzVUhl8zkEu+LlaE0IYzdMuvbSDipxBRpOn4Uhw8ZyECEa808iVT8XCjzo6xmYt4CiLZg==" 930 | }, 931 | "node_modules/iconv-lite": { 932 | "version": "0.4.24", 933 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 934 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 935 | "dependencies": { 936 | "safer-buffer": ">= 2.1.2 < 3" 937 | }, 938 | "engines": { 939 | "node": ">=0.10.0" 940 | } 941 | }, 942 | "node_modules/inflight": { 943 | "version": "1.0.6", 944 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 945 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 946 | "dependencies": { 947 | "once": "^1.3.0", 948 | "wrappy": "1" 949 | } 950 | }, 951 | "node_modules/inherits": { 952 | "version": "2.0.4", 953 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 954 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 955 | }, 956 | "node_modules/ini": { 957 | "version": "1.3.8", 958 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", 959 | "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==" 960 | }, 961 | "node_modules/interpret": { 962 | "version": "1.1.0", 963 | "resolved": "https://registry.npmjs.org/interpret/-/interpret-1.1.0.tgz", 964 | "integrity": "sha1-ftGxQQxqDg94z5XTuEQMY/eLhhQ=" 965 | }, 966 | "node_modules/is-absolute": { 967 | "version": "1.0.0", 968 | "resolved": "https://registry.npmjs.org/is-absolute/-/is-absolute-1.0.0.tgz", 969 | "integrity": "sha512-dOWoqflvcydARa360Gvv18DZ/gRuHKi2NU/wU5X1ZFzdYfH29nkiNZsF3mp4OJ3H4yo9Mx8A/uAGNzpzPN3yBA==", 970 | "dependencies": { 971 | "is-relative": "^1.0.0", 972 | "is-windows": "^1.0.1" 973 | }, 974 | "engines": { 975 | "node": ">=0.10.0" 976 | } 977 | }, 978 | "node_modules/is-core-module": { 979 | "version": "2.4.0", 980 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.4.0.tgz", 981 | "integrity": "sha512-6A2fkfq1rfeQZjxrZJGerpLCTHRNEBiSgnu0+obeJpEPZRUooHgsizvzv0ZjJwOz3iWIHdJtVWJ/tmPr3D21/A==", 982 | "dependencies": { 983 | "has": "^1.0.3" 984 | }, 985 | "funding": { 986 | "url": "https://github.com/sponsors/ljharb" 987 | } 988 | }, 989 | "node_modules/is-extglob": { 990 | "version": "2.1.1", 991 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 992 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 993 | "engines": { 994 | "node": ">=0.10.0" 995 | } 996 | }, 997 | "node_modules/is-glob": { 998 | "version": "4.0.1", 999 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1000 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1001 | "dependencies": { 1002 | "is-extglob": "^2.1.1" 1003 | }, 1004 | "engines": { 1005 | "node": ">=0.10.0" 1006 | } 1007 | }, 1008 | "node_modules/is-number": { 1009 | "version": "7.0.0", 1010 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1011 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1012 | "engines": { 1013 | "node": ">=0.12.0" 1014 | } 1015 | }, 1016 | "node_modules/is-plain-object": { 1017 | "version": "2.0.4", 1018 | "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", 1019 | "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", 1020 | "dependencies": { 1021 | "isobject": "^3.0.1" 1022 | }, 1023 | "engines": { 1024 | "node": ">=0.10.0" 1025 | } 1026 | }, 1027 | "node_modules/is-relative": { 1028 | "version": "1.0.0", 1029 | "resolved": "https://registry.npmjs.org/is-relative/-/is-relative-1.0.0.tgz", 1030 | "integrity": "sha512-Kw/ReK0iqwKeu0MITLFuj0jbPAmEiOsIwyIXvvbfa6QfmN9pkD1M+8pdk7Rl/dTKbH34/XBFMbgD4iMJhLQbGA==", 1031 | "dependencies": { 1032 | "is-unc-path": "^1.0.0" 1033 | }, 1034 | "engines": { 1035 | "node": ">=0.10.0" 1036 | } 1037 | }, 1038 | "node_modules/is-unc-path": { 1039 | "version": "1.0.0", 1040 | "resolved": "https://registry.npmjs.org/is-unc-path/-/is-unc-path-1.0.0.tgz", 1041 | "integrity": "sha512-mrGpVd0fs7WWLfVsStvgF6iEJnbjDFZh9/emhRDcGWTduTfNHd9CHeUwH3gYIjdbwo4On6hunkztwOaAw0yllQ==", 1042 | "dependencies": { 1043 | "unc-path-regex": "^0.1.2" 1044 | }, 1045 | "engines": { 1046 | "node": ">=0.10.0" 1047 | } 1048 | }, 1049 | "node_modules/is-windows": { 1050 | "version": "1.0.2", 1051 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", 1052 | "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", 1053 | "engines": { 1054 | "node": ">=0.10.0" 1055 | } 1056 | }, 1057 | "node_modules/isarray": { 1058 | "version": "0.0.1", 1059 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 1060 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=" 1061 | }, 1062 | "node_modules/isexe": { 1063 | "version": "2.0.0", 1064 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1065 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" 1066 | }, 1067 | "node_modules/isobject": { 1068 | "version": "3.0.1", 1069 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", 1070 | "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", 1071 | "engines": { 1072 | "node": ">=0.10.0" 1073 | } 1074 | }, 1075 | "node_modules/js-beautify": { 1076 | "version": "1.14.0", 1077 | "resolved": "https://registry.npmjs.org/js-beautify/-/js-beautify-1.14.0.tgz", 1078 | "integrity": "sha512-yuck9KirNSCAwyNJbqW+BxJqJ0NLJ4PwBUzQQACl5O3qHMBXVkXb/rD0ilh/Lat/tn88zSZ+CAHOlk0DsY7GuQ==", 1079 | "dependencies": { 1080 | "config-chain": "^1.1.12", 1081 | "editorconfig": "^0.15.3", 1082 | "glob": "^7.1.3", 1083 | "nopt": "^5.0.0" 1084 | }, 1085 | "bin": { 1086 | "css-beautify": "js/bin/css-beautify.js", 1087 | "html-beautify": "js/bin/html-beautify.js", 1088 | "js-beautify": "js/bin/js-beautify.js" 1089 | }, 1090 | "engines": { 1091 | "node": ">=10" 1092 | } 1093 | }, 1094 | "node_modules/js-beautify/node_modules/nopt": { 1095 | "version": "5.0.0", 1096 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-5.0.0.tgz", 1097 | "integrity": "sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ==", 1098 | "dependencies": { 1099 | "abbrev": "1" 1100 | }, 1101 | "bin": { 1102 | "nopt": "bin/nopt.js" 1103 | }, 1104 | "engines": { 1105 | "node": ">=6" 1106 | } 1107 | }, 1108 | "node_modules/js-yaml": { 1109 | "version": "3.14.1", 1110 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 1111 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 1112 | "dependencies": { 1113 | "argparse": "^1.0.7", 1114 | "esprima": "^4.0.0" 1115 | }, 1116 | "bin": { 1117 | "js-yaml": "bin/js-yaml.js" 1118 | } 1119 | }, 1120 | "node_modules/jshint": { 1121 | "version": "2.12.0", 1122 | "resolved": "https://registry.npmjs.org/jshint/-/jshint-2.12.0.tgz", 1123 | "integrity": "sha512-TwuuaUDmra0JMkuqvqy+WGo2xGHSNjv1BA1nTIgtH2K5z1jHuAEeAgp7laaR+hLRmajRjcrM71+vByBDanCyYA==", 1124 | "dependencies": { 1125 | "cli": "~1.0.0", 1126 | "console-browserify": "1.1.x", 1127 | "exit": "0.1.x", 1128 | "htmlparser2": "3.8.x", 1129 | "lodash": "~4.17.19", 1130 | "minimatch": "~3.0.2", 1131 | "shelljs": "0.3.x", 1132 | "strip-json-comments": "1.0.x" 1133 | }, 1134 | "bin": { 1135 | "jshint": "bin/jshint" 1136 | } 1137 | }, 1138 | "node_modules/kind-of": { 1139 | "version": "6.0.3", 1140 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", 1141 | "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==", 1142 | "engines": { 1143 | "node": ">=0.10.0" 1144 | } 1145 | }, 1146 | "node_modules/liftup": { 1147 | "version": "3.0.1", 1148 | "resolved": "https://registry.npmjs.org/liftup/-/liftup-3.0.1.tgz", 1149 | "integrity": "sha512-yRHaiQDizWSzoXk3APcA71eOI/UuhEkNN9DiW2Tt44mhYzX4joFoCZlxsSOF7RyeLlfqzFLQI1ngFq3ggMPhOw==", 1150 | "dependencies": { 1151 | "extend": "^3.0.2", 1152 | "findup-sync": "^4.0.0", 1153 | "fined": "^1.2.0", 1154 | "flagged-respawn": "^1.0.1", 1155 | "is-plain-object": "^2.0.4", 1156 | "object.map": "^1.0.1", 1157 | "rechoir": "^0.7.0", 1158 | "resolve": "^1.19.0" 1159 | }, 1160 | "engines": { 1161 | "node": ">=10" 1162 | } 1163 | }, 1164 | "node_modules/liftup/node_modules/findup-sync": { 1165 | "version": "4.0.0", 1166 | "resolved": "https://registry.npmjs.org/findup-sync/-/findup-sync-4.0.0.tgz", 1167 | "integrity": "sha512-6jvvn/12IC4quLBL1KNokxC7wWTvYncaVUYSoxWw7YykPLuRrnv4qdHcSOywOI5RpkOVGeQRtWM8/q+G6W6qfQ==", 1168 | "dependencies": { 1169 | "detect-file": "^1.0.0", 1170 | "is-glob": "^4.0.0", 1171 | "micromatch": "^4.0.2", 1172 | "resolve-dir": "^1.0.1" 1173 | }, 1174 | "engines": { 1175 | "node": ">= 8" 1176 | } 1177 | }, 1178 | "node_modules/livereload-js": { 1179 | "version": "2.4.0", 1180 | "resolved": "https://registry.npmjs.org/livereload-js/-/livereload-js-2.4.0.tgz", 1181 | "integrity": "sha512-XPQH8Z2GDP/Hwz2PCDrh2mth4yFejwA1OZ/81Ti3LgKyhDcEjsSsqFWZojHG0va/duGd+WyosY7eXLDoOyqcPw==" 1182 | }, 1183 | "node_modules/lodash": { 1184 | "version": "4.17.21", 1185 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 1186 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 1187 | }, 1188 | "node_modules/lru-cache": { 1189 | "version": "4.1.5", 1190 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", 1191 | "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", 1192 | "dependencies": { 1193 | "pseudomap": "^1.0.2", 1194 | "yallist": "^2.1.2" 1195 | } 1196 | }, 1197 | "node_modules/make-iterator": { 1198 | "version": "1.0.1", 1199 | "resolved": "https://registry.npmjs.org/make-iterator/-/make-iterator-1.0.1.tgz", 1200 | "integrity": "sha512-pxiuXh0iVEq7VM7KMIhs5gxsfxCux2URptUQaXo4iZZJxBAzTPOLE2BumO5dbfVYq/hBJFBR/a1mFDmOx5AGmw==", 1201 | "dependencies": { 1202 | "kind-of": "^6.0.2" 1203 | }, 1204 | "engines": { 1205 | "node": ">=0.10.0" 1206 | } 1207 | }, 1208 | "node_modules/map-cache": { 1209 | "version": "0.2.2", 1210 | "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz", 1211 | "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=", 1212 | "engines": { 1213 | "node": ">=0.10.0" 1214 | } 1215 | }, 1216 | "node_modules/micromatch": { 1217 | "version": "4.0.4", 1218 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.4.tgz", 1219 | "integrity": "sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg==", 1220 | "dependencies": { 1221 | "braces": "^3.0.1", 1222 | "picomatch": "^2.2.3" 1223 | }, 1224 | "engines": { 1225 | "node": ">=8.6" 1226 | } 1227 | }, 1228 | "node_modules/minimatch": { 1229 | "version": "3.0.4", 1230 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1231 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1232 | "dependencies": { 1233 | "brace-expansion": "^1.1.7" 1234 | }, 1235 | "engines": { 1236 | "node": "*" 1237 | } 1238 | }, 1239 | "node_modules/minimist": { 1240 | "version": "1.2.5", 1241 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1242 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" 1243 | }, 1244 | "node_modules/mkdirp": { 1245 | "version": "1.0.4", 1246 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 1247 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", 1248 | "bin": { 1249 | "mkdirp": "bin/cmd.js" 1250 | }, 1251 | "engines": { 1252 | "node": ">=10" 1253 | } 1254 | }, 1255 | "node_modules/moment": { 1256 | "version": "2.29.1", 1257 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.1.tgz", 1258 | "integrity": "sha512-kHmoybcPV8Sqy59DwNDY3Jefr64lK/by/da0ViFcuA4DH0vQg5Q6Ze5VimxkfQNSC+Mls/Kx53s7TjP1RhFEDQ==", 1259 | "dev": true, 1260 | "engines": { 1261 | "node": "*" 1262 | } 1263 | }, 1264 | "node_modules/ms": { 1265 | "version": "2.1.3", 1266 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1267 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1268 | }, 1269 | "node_modules/nopt": { 1270 | "version": "3.0.6", 1271 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-3.0.6.tgz", 1272 | "integrity": "sha1-xkZdvwirzU2zWTF/eaxopkayj/k=", 1273 | "dependencies": { 1274 | "abbrev": "1" 1275 | }, 1276 | "bin": { 1277 | "nopt": "bin/nopt.js" 1278 | } 1279 | }, 1280 | "node_modules/object-assign": { 1281 | "version": "4.1.1", 1282 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1283 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 1284 | "engines": { 1285 | "node": ">=0.10.0" 1286 | } 1287 | }, 1288 | "node_modules/object-inspect": { 1289 | "version": "1.10.3", 1290 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.10.3.tgz", 1291 | "integrity": "sha512-e5mCJlSH7poANfC8z8S9s9S2IN5/4Zb3aZ33f5s8YqoazCFzNLloLU8r5VCG+G7WoqLvAAZoVMcy3tp/3X0Plw==", 1292 | "funding": { 1293 | "url": "https://github.com/sponsors/ljharb" 1294 | } 1295 | }, 1296 | "node_modules/object.defaults": { 1297 | "version": "1.1.0", 1298 | "resolved": "https://registry.npmjs.org/object.defaults/-/object.defaults-1.1.0.tgz", 1299 | "integrity": "sha1-On+GgzS0B96gbaFtiNXNKeQ1/s8=", 1300 | "dependencies": { 1301 | "array-each": "^1.0.1", 1302 | "array-slice": "^1.0.0", 1303 | "for-own": "^1.0.0", 1304 | "isobject": "^3.0.0" 1305 | }, 1306 | "engines": { 1307 | "node": ">=0.10.0" 1308 | } 1309 | }, 1310 | "node_modules/object.map": { 1311 | "version": "1.0.1", 1312 | "resolved": "https://registry.npmjs.org/object.map/-/object.map-1.0.1.tgz", 1313 | "integrity": "sha1-z4Plncj8wK1fQlDh94s7gb2AHTc=", 1314 | "dependencies": { 1315 | "for-own": "^1.0.0", 1316 | "make-iterator": "^1.0.0" 1317 | }, 1318 | "engines": { 1319 | "node": ">=0.10.0" 1320 | } 1321 | }, 1322 | "node_modules/object.pick": { 1323 | "version": "1.3.0", 1324 | "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz", 1325 | "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", 1326 | "dependencies": { 1327 | "isobject": "^3.0.1" 1328 | }, 1329 | "engines": { 1330 | "node": ">=0.10.0" 1331 | } 1332 | }, 1333 | "node_modules/once": { 1334 | "version": "1.4.0", 1335 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1336 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1337 | "dependencies": { 1338 | "wrappy": "1" 1339 | } 1340 | }, 1341 | "node_modules/optional-require": { 1342 | "version": "1.0.3", 1343 | "resolved": "https://registry.npmjs.org/optional-require/-/optional-require-1.0.3.tgz", 1344 | "integrity": "sha512-RV2Zp2MY2aeYK5G+B/Sps8lW5NHAzE5QClbFP15j+PWmP+T9PxlJXBOOLoSAdgwFvS4t0aMR4vpedMkbHfh0nA==", 1345 | "dev": true, 1346 | "engines": { 1347 | "node": ">=4" 1348 | } 1349 | }, 1350 | "node_modules/os-homedir": { 1351 | "version": "1.0.2", 1352 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 1353 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", 1354 | "engines": { 1355 | "node": ">=0.10.0" 1356 | } 1357 | }, 1358 | "node_modules/os-tmpdir": { 1359 | "version": "1.0.2", 1360 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1361 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 1362 | "engines": { 1363 | "node": ">=0.10.0" 1364 | } 1365 | }, 1366 | "node_modules/osenv": { 1367 | "version": "0.1.5", 1368 | "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz", 1369 | "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==", 1370 | "dependencies": { 1371 | "os-homedir": "^1.0.0", 1372 | "os-tmpdir": "^1.0.0" 1373 | } 1374 | }, 1375 | "node_modules/parse-filepath": { 1376 | "version": "1.0.2", 1377 | "resolved": "https://registry.npmjs.org/parse-filepath/-/parse-filepath-1.0.2.tgz", 1378 | "integrity": "sha1-pjISf1Oq89FYdvWHLz/6x2PWyJE=", 1379 | "dependencies": { 1380 | "is-absolute": "^1.0.0", 1381 | "map-cache": "^0.2.0", 1382 | "path-root": "^0.1.1" 1383 | }, 1384 | "engines": { 1385 | "node": ">=0.8" 1386 | } 1387 | }, 1388 | "node_modules/parse-passwd": { 1389 | "version": "1.0.0", 1390 | "resolved": "https://registry.npmjs.org/parse-passwd/-/parse-passwd-1.0.0.tgz", 1391 | "integrity": "sha1-bVuTSkVpk7I9N/QKOC1vFmao5cY=", 1392 | "engines": { 1393 | "node": ">=0.10.0" 1394 | } 1395 | }, 1396 | "node_modules/path-is-absolute": { 1397 | "version": "1.0.1", 1398 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1399 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1400 | "engines": { 1401 | "node": ">=0.10.0" 1402 | } 1403 | }, 1404 | "node_modules/path-parse": { 1405 | "version": "1.0.7", 1406 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1407 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" 1408 | }, 1409 | "node_modules/path-root": { 1410 | "version": "0.1.1", 1411 | "resolved": "https://registry.npmjs.org/path-root/-/path-root-0.1.1.tgz", 1412 | "integrity": "sha1-mkpoFMrBwM1zNgqV8yCDyOpHRbc=", 1413 | "dependencies": { 1414 | "path-root-regex": "^0.1.0" 1415 | }, 1416 | "engines": { 1417 | "node": ">=0.10.0" 1418 | } 1419 | }, 1420 | "node_modules/path-root-regex": { 1421 | "version": "0.1.2", 1422 | "resolved": "https://registry.npmjs.org/path-root-regex/-/path-root-regex-0.1.2.tgz", 1423 | "integrity": "sha1-v8zcjfWxLcUsi0PsONGNcsBLqW0=", 1424 | "engines": { 1425 | "node": ">=0.10.0" 1426 | } 1427 | }, 1428 | "node_modules/picomatch": { 1429 | "version": "2.3.0", 1430 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 1431 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 1432 | "engines": { 1433 | "node": ">=8.6" 1434 | }, 1435 | "funding": { 1436 | "url": "https://github.com/sponsors/jonschlinkert" 1437 | } 1438 | }, 1439 | "node_modules/proto-list": { 1440 | "version": "1.2.4", 1441 | "resolved": "https://registry.npmjs.org/proto-list/-/proto-list-1.2.4.tgz", 1442 | "integrity": "sha1-IS1b/hMYMGpCD2QCuOJv85ZHqEk=" 1443 | }, 1444 | "node_modules/pseudomap": { 1445 | "version": "1.0.2", 1446 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 1447 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" 1448 | }, 1449 | "node_modules/qs": { 1450 | "version": "6.10.1", 1451 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.10.1.tgz", 1452 | "integrity": "sha512-M528Hph6wsSVOBiYUnGf+K/7w0hNshs/duGsNXPUCLH5XAqjEtiPGwNONLV0tBH8NoGb0mvD5JubnUTrujKDTg==", 1453 | "dependencies": { 1454 | "side-channel": "^1.0.4" 1455 | }, 1456 | "engines": { 1457 | "node": ">=0.6" 1458 | }, 1459 | "funding": { 1460 | "url": "https://github.com/sponsors/ljharb" 1461 | } 1462 | }, 1463 | "node_modules/raw-body": { 1464 | "version": "1.1.7", 1465 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-1.1.7.tgz", 1466 | "integrity": "sha1-HQJ8K/oRasxmI7yo8AAWVyqH1CU=", 1467 | "dependencies": { 1468 | "bytes": "1", 1469 | "string_decoder": "0.10" 1470 | }, 1471 | "engines": { 1472 | "node": ">= 0.8.0" 1473 | } 1474 | }, 1475 | "node_modules/rc": { 1476 | "version": "1.2.8", 1477 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 1478 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 1479 | "dependencies": { 1480 | "deep-extend": "^0.6.0", 1481 | "ini": "~1.3.0", 1482 | "minimist": "^1.2.0", 1483 | "strip-json-comments": "~2.0.1" 1484 | }, 1485 | "bin": { 1486 | "rc": "cli.js" 1487 | } 1488 | }, 1489 | "node_modules/rc/node_modules/strip-json-comments": { 1490 | "version": "2.0.1", 1491 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1492 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1493 | "engines": { 1494 | "node": ">=0.10.0" 1495 | } 1496 | }, 1497 | "node_modules/readable-stream": { 1498 | "version": "1.1.14", 1499 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", 1500 | "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", 1501 | "dependencies": { 1502 | "core-util-is": "~1.0.0", 1503 | "inherits": "~2.0.1", 1504 | "isarray": "0.0.1", 1505 | "string_decoder": "~0.10.x" 1506 | } 1507 | }, 1508 | "node_modules/rechoir": { 1509 | "version": "0.7.0", 1510 | "resolved": "https://registry.npmjs.org/rechoir/-/rechoir-0.7.0.tgz", 1511 | "integrity": "sha512-ADsDEH2bvbjltXEP+hTIAmeFekTFK0V2BTxMkok6qILyAJEXV0AFfoWcAq4yfll5VdIMd/RVXq0lR+wQi5ZU3Q==", 1512 | "dependencies": { 1513 | "resolve": "^1.9.0" 1514 | }, 1515 | "engines": { 1516 | "node": ">= 0.10" 1517 | } 1518 | }, 1519 | "node_modules/resolve": { 1520 | "version": "1.20.0", 1521 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.20.0.tgz", 1522 | "integrity": "sha512-wENBPt4ySzg4ybFQW2TT1zMQucPK95HSh/nq2CFTZVOGut2+pQvSsgtda4d26YrYcr067wjbmzOG8byDPBX63A==", 1523 | "dependencies": { 1524 | "is-core-module": "^2.2.0", 1525 | "path-parse": "^1.0.6" 1526 | }, 1527 | "funding": { 1528 | "url": "https://github.com/sponsors/ljharb" 1529 | } 1530 | }, 1531 | "node_modules/resolve-dir": { 1532 | "version": "1.0.1", 1533 | "resolved": "https://registry.npmjs.org/resolve-dir/-/resolve-dir-1.0.1.tgz", 1534 | "integrity": "sha1-eaQGRMNivoLybv/nOcm7U4IEb0M=", 1535 | "dependencies": { 1536 | "expand-tilde": "^2.0.0", 1537 | "global-modules": "^1.0.0" 1538 | }, 1539 | "engines": { 1540 | "node": ">=0.10.0" 1541 | } 1542 | }, 1543 | "node_modules/rimraf": { 1544 | "version": "3.0.2", 1545 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1546 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1547 | "dependencies": { 1548 | "glob": "^7.1.3" 1549 | }, 1550 | "bin": { 1551 | "rimraf": "bin.js" 1552 | }, 1553 | "funding": { 1554 | "url": "https://github.com/sponsors/isaacs" 1555 | } 1556 | }, 1557 | "node_modules/safe-buffer": { 1558 | "version": "5.2.1", 1559 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1560 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1561 | "funding": [ 1562 | { 1563 | "type": "github", 1564 | "url": "https://github.com/sponsors/feross" 1565 | }, 1566 | { 1567 | "type": "patreon", 1568 | "url": "https://www.patreon.com/feross" 1569 | }, 1570 | { 1571 | "type": "consulting", 1572 | "url": "https://feross.org/support" 1573 | } 1574 | ] 1575 | }, 1576 | "node_modules/safe-json-parse": { 1577 | "version": "1.0.1", 1578 | "resolved": "https://registry.npmjs.org/safe-json-parse/-/safe-json-parse-1.0.1.tgz", 1579 | "integrity": "sha1-PnZyPjjf3aE8mx0poeB//uSzC1c=" 1580 | }, 1581 | "node_modules/safer-buffer": { 1582 | "version": "2.1.2", 1583 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1584 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1585 | }, 1586 | "node_modules/semver": { 1587 | "version": "4.3.6", 1588 | "resolved": "https://registry.npmjs.org/semver/-/semver-4.3.6.tgz", 1589 | "integrity": "sha1-MAvG4OhjdPe6YQaLWx7NV/xlMto=", 1590 | "bin": { 1591 | "semver": "bin/semver" 1592 | } 1593 | }, 1594 | "node_modules/shelljs": { 1595 | "version": "0.3.0", 1596 | "resolved": "https://registry.npmjs.org/shelljs/-/shelljs-0.3.0.tgz", 1597 | "integrity": "sha1-NZbmMHp4FUT1kfN9phg2DzHbV7E=", 1598 | "bin": { 1599 | "shjs": "bin/shjs" 1600 | }, 1601 | "engines": { 1602 | "node": ">=0.8.0" 1603 | } 1604 | }, 1605 | "node_modules/side-channel": { 1606 | "version": "1.0.4", 1607 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 1608 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 1609 | "dependencies": { 1610 | "call-bind": "^1.0.0", 1611 | "get-intrinsic": "^1.0.2", 1612 | "object-inspect": "^1.9.0" 1613 | }, 1614 | "funding": { 1615 | "url": "https://github.com/sponsors/ljharb" 1616 | } 1617 | }, 1618 | "node_modules/sigmund": { 1619 | "version": "1.0.1", 1620 | "resolved": "https://registry.npmjs.org/sigmund/-/sigmund-1.0.1.tgz", 1621 | "integrity": "sha1-P/IfGYytIXX587eBhT/ZTQ0ZtZA=" 1622 | }, 1623 | "node_modules/sprintf-js": { 1624 | "version": "1.0.3", 1625 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1626 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=" 1627 | }, 1628 | "node_modules/string_decoder": { 1629 | "version": "0.10.31", 1630 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 1631 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=" 1632 | }, 1633 | "node_modules/string-template": { 1634 | "version": "0.2.1", 1635 | "resolved": "https://registry.npmjs.org/string-template/-/string-template-0.2.1.tgz", 1636 | "integrity": "sha1-QpMuWYo1LQH8IuwzZ9nYTuxsmt0=" 1637 | }, 1638 | "node_modules/strip-json-comments": { 1639 | "version": "1.0.4", 1640 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-1.0.4.tgz", 1641 | "integrity": "sha1-HhX7ysl9Pumb8tc7TGVrCCu6+5E=", 1642 | "bin": { 1643 | "strip-json-comments": "cli.js" 1644 | }, 1645 | "engines": { 1646 | "node": ">=0.8.0" 1647 | } 1648 | }, 1649 | "node_modules/supports-color": { 1650 | "version": "7.2.0", 1651 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1652 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1653 | "dependencies": { 1654 | "has-flag": "^4.0.0" 1655 | }, 1656 | "engines": { 1657 | "node": ">=8" 1658 | } 1659 | }, 1660 | "node_modules/tiny-lr": { 1661 | "version": "1.1.1", 1662 | "resolved": "https://registry.npmjs.org/tiny-lr/-/tiny-lr-1.1.1.tgz", 1663 | "integrity": "sha512-44yhA3tsaRoMOjQQ+5v5mVdqef+kH6Qze9jTpqtVufgYjYt08zyZAwNwwVBj3i1rJMnR52IxOW0LK0vBzgAkuA==", 1664 | "dependencies": { 1665 | "body": "^5.1.0", 1666 | "debug": "^3.1.0", 1667 | "faye-websocket": "~0.10.0", 1668 | "livereload-js": "^2.3.0", 1669 | "object-assign": "^4.1.0", 1670 | "qs": "^6.4.0" 1671 | } 1672 | }, 1673 | "node_modules/to-regex-range": { 1674 | "version": "5.0.1", 1675 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1676 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1677 | "dependencies": { 1678 | "is-number": "^7.0.0" 1679 | }, 1680 | "engines": { 1681 | "node": ">=8.0" 1682 | } 1683 | }, 1684 | "node_modules/unc-path-regex": { 1685 | "version": "0.1.2", 1686 | "resolved": "https://registry.npmjs.org/unc-path-regex/-/unc-path-regex-0.1.2.tgz", 1687 | "integrity": "sha1-5z3T17DXxe2G+6xrCufYxqadUPo=", 1688 | "engines": { 1689 | "node": ">=0.10.0" 1690 | } 1691 | }, 1692 | "node_modules/underscore.string": { 1693 | "version": "3.3.5", 1694 | "resolved": "https://registry.npmjs.org/underscore.string/-/underscore.string-3.3.5.tgz", 1695 | "integrity": "sha512-g+dpmgn+XBneLmXXo+sGlW5xQEt4ErkS3mgeN2GFbremYeMBSJKr9Wf2KJplQVaiPY/f7FN6atosWYNm9ovrYg==", 1696 | "dependencies": { 1697 | "sprintf-js": "^1.0.3", 1698 | "util-deprecate": "^1.0.2" 1699 | }, 1700 | "engines": { 1701 | "node": "*" 1702 | } 1703 | }, 1704 | "node_modules/util-deprecate": { 1705 | "version": "1.0.2", 1706 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1707 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 1708 | }, 1709 | "node_modules/v8flags": { 1710 | "version": "3.2.0", 1711 | "resolved": "https://registry.npmjs.org/v8flags/-/v8flags-3.2.0.tgz", 1712 | "integrity": "sha512-mH8etigqMfiGWdeXpaaqGfs6BndypxusHHcv2qSHyZkGEznCd/qAXCWWRzeowtL54147cktFOC4P5y+kl8d8Jg==", 1713 | "dependencies": { 1714 | "homedir-polyfill": "^1.0.1" 1715 | }, 1716 | "engines": { 1717 | "node": ">= 0.10" 1718 | } 1719 | }, 1720 | "node_modules/websocket-driver": { 1721 | "version": "0.7.4", 1722 | "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.4.tgz", 1723 | "integrity": "sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg==", 1724 | "dependencies": { 1725 | "http-parser-js": ">=0.5.1", 1726 | "safe-buffer": ">=5.1.0", 1727 | "websocket-extensions": ">=0.1.1" 1728 | }, 1729 | "engines": { 1730 | "node": ">=0.8.0" 1731 | } 1732 | }, 1733 | "node_modules/websocket-extensions": { 1734 | "version": "0.1.4", 1735 | "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.4.tgz", 1736 | "integrity": "sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg==", 1737 | "engines": { 1738 | "node": ">=0.8.0" 1739 | } 1740 | }, 1741 | "node_modules/which": { 1742 | "version": "2.0.2", 1743 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1744 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1745 | "dependencies": { 1746 | "isexe": "^2.0.0" 1747 | }, 1748 | "bin": { 1749 | "node-which": "bin/node-which" 1750 | }, 1751 | "engines": { 1752 | "node": ">= 8" 1753 | } 1754 | }, 1755 | "node_modules/wrappy": { 1756 | "version": "1.0.2", 1757 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1758 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 1759 | }, 1760 | "node_modules/yallist": { 1761 | "version": "2.1.2", 1762 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 1763 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" 1764 | } 1765 | }, 1766 | "dependencies": { 1767 | "abbrev": { 1768 | "version": "1.1.1", 1769 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 1770 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 1771 | }, 1772 | "ansi-styles": { 1773 | "version": "4.3.0", 1774 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1775 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1776 | "requires": { 1777 | "color-convert": "^2.0.1" 1778 | } 1779 | }, 1780 | "applause": { 1781 | "version": "2.0.4", 1782 | "resolved": "https://registry.npmjs.org/applause/-/applause-2.0.4.tgz", 1783 | "integrity": "sha512-wFhNjSoflbAEgelX3psyKSXV2iQFjuYW31DEhcCOD/bQ98VdfltLclK4p1mI6E58Qp4Q7+5RCbBdr+Nc9b5QhA==", 1784 | "dev": true, 1785 | "requires": { 1786 | "cson-parser": "^4.0.8", 1787 | "js-yaml": "^4.0.0", 1788 | "lodash": "^4.17.21", 1789 | "optional-require": "^1.0.2" 1790 | }, 1791 | "dependencies": { 1792 | "argparse": { 1793 | "version": "2.0.1", 1794 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 1795 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 1796 | "dev": true, 1797 | "optional": true 1798 | }, 1799 | "js-yaml": { 1800 | "version": "4.1.0", 1801 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1802 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1803 | "dev": true, 1804 | "optional": true, 1805 | "requires": { 1806 | "argparse": "^2.0.1" 1807 | } 1808 | } 1809 | } 1810 | }, 1811 | "argparse": { 1812 | "version": "1.0.10", 1813 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 1814 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 1815 | "requires": { 1816 | "sprintf-js": "~1.0.2" 1817 | } 1818 | }, 1819 | "array-each": { 1820 | "version": "1.0.1", 1821 | "resolved": "https://registry.npmjs.org/array-each/-/array-each-1.0.1.tgz", 1822 | "integrity": "sha1-p5SvDAWrF1KEbudTofIRoFugxE8=" 1823 | }, 1824 | "array-slice": { 1825 | "version": "1.1.0", 1826 | "resolved": "https://registry.npmjs.org/array-slice/-/array-slice-1.1.0.tgz", 1827 | "integrity": "sha512-B1qMD3RBP7O8o0H2KbrXDyB0IccejMF15+87Lvlor12ONPRHP6gTjXMNkt/d3ZuOGbAe66hFmaCfECI24Ufp6w==" 1828 | }, 1829 | "async": { 1830 | "version": "2.6.3", 1831 | "resolved": "https://registry.npmjs.org/async/-/async-2.6.3.tgz", 1832 | "integrity": "sha512-zflvls11DCy+dQWzTW2dzuilv8Z5X/pjfmZOWba6TNIVDm+2UDaJmXSOXlasHKfNBs8oo3M0aT50fDEWfKZjXg==", 1833 | "requires": { 1834 | "lodash": "^4.17.14" 1835 | } 1836 | }, 1837 | "balanced-match": { 1838 | "version": "1.0.2", 1839 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1840 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 1841 | }, 1842 | "body": { 1843 | "version": "5.1.0", 1844 | "resolved": "https://registry.npmjs.org/body/-/body-5.1.0.tgz", 1845 | "integrity": "sha1-5LoM5BCkaTYyM2dgnstOZVMSUGk=", 1846 | "requires": { 1847 | "continuable-cache": "^0.3.1", 1848 | "error": "^7.0.0", 1849 | "raw-body": "~1.1.0", 1850 | "safe-json-parse": "~1.0.1" 1851 | } 1852 | }, 1853 | "brace-expansion": { 1854 | "version": "1.1.11", 1855 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1856 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1857 | "requires": { 1858 | "balanced-match": "^1.0.0", 1859 | "concat-map": "0.0.1" 1860 | } 1861 | }, 1862 | "braces": { 1863 | "version": "3.0.2", 1864 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 1865 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 1866 | "requires": { 1867 | "fill-range": "^7.0.1" 1868 | } 1869 | }, 1870 | "bytes": { 1871 | "version": "1.0.0", 1872 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-1.0.0.tgz", 1873 | "integrity": "sha1-NWnt6Lo0MV+rmcPpLLBMciDeH6g=" 1874 | }, 1875 | "call-bind": { 1876 | "version": "1.0.2", 1877 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 1878 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 1879 | "requires": { 1880 | "function-bind": "^1.1.1", 1881 | "get-intrinsic": "^1.0.2" 1882 | } 1883 | }, 1884 | "chalk": { 1885 | "version": "4.1.1", 1886 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.1.tgz", 1887 | "integrity": "sha512-diHzdDKxcU+bAsUboHLPEDQiw0qEe0qd7SYUn3HgcFlWgbDcfLGswOHYeGrHKzG9z6UYf01d9VFMfZxPM1xZSg==", 1888 | "requires": { 1889 | "ansi-styles": "^4.1.0", 1890 | "supports-color": "^7.1.0" 1891 | } 1892 | }, 1893 | "cli": { 1894 | "version": "1.0.1", 1895 | "resolved": "https://registry.npmjs.org/cli/-/cli-1.0.1.tgz", 1896 | "integrity": "sha1-IoF1NPJL+klQw01TLUjsvGIbjBQ=", 1897 | "requires": { 1898 | "exit": "0.1.2", 1899 | "glob": "^7.1.1" 1900 | } 1901 | }, 1902 | "coffeescript": { 1903 | "version": "1.12.7", 1904 | "resolved": "https://registry.npmjs.org/coffeescript/-/coffeescript-1.12.7.tgz", 1905 | "integrity": "sha512-pLXHFxQMPklVoEekowk8b3erNynC+DVJzChxS/LCBBgR6/8AJkHivkm//zbowcfc7BTCAjryuhx6gPqPRfsFoA==", 1906 | "dev": true, 1907 | "optional": true 1908 | }, 1909 | "color-convert": { 1910 | "version": "2.0.1", 1911 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1912 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1913 | "requires": { 1914 | "color-name": "~1.1.4" 1915 | } 1916 | }, 1917 | "color-name": { 1918 | "version": "1.1.4", 1919 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1920 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 1921 | }, 1922 | "colors": { 1923 | "version": "1.1.2", 1924 | "resolved": "https://registry.npmjs.org/colors/-/colors-1.1.2.tgz", 1925 | "integrity": "sha1-FopHAXVran9RoSzgyXv6KMCE7WM=" 1926 | }, 1927 | "commander": { 1928 | "version": "2.20.3", 1929 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", 1930 | "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==" 1931 | }, 1932 | "concat-map": { 1933 | "version": "0.0.1", 1934 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1935 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 1936 | }, 1937 | "config-chain": { 1938 | "version": "1.1.13", 1939 | "resolved": "https://registry.npmjs.org/config-chain/-/config-chain-1.1.13.tgz", 1940 | "integrity": "sha512-qj+f8APARXHrM0hraqXYb2/bOVSV4PvJQlNZ/DVj0QrmNM2q2euizkeuVckQ57J+W0mRH6Hvi+k50M4Jul2VRQ==", 1941 | "requires": { 1942 | "ini": "^1.3.4", 1943 | "proto-list": "~1.2.1" 1944 | } 1945 | }, 1946 | "console-browserify": { 1947 | "version": "1.1.0", 1948 | "resolved": "https://registry.npmjs.org/console-browserify/-/console-browserify-1.1.0.tgz", 1949 | "integrity": "sha1-8CQcRXMKn8YyOyBtvzjtx0HQuxA=", 1950 | "requires": { 1951 | "date-now": "^0.1.4" 1952 | } 1953 | }, 1954 | "continuable-cache": { 1955 | "version": "0.3.1", 1956 | "resolved": "https://registry.npmjs.org/continuable-cache/-/continuable-cache-0.3.1.tgz", 1957 | "integrity": "sha1-vXJ6f67XfnH/OYWskzUakSczrQ8=" 1958 | }, 1959 | "core-util-is": { 1960 | "version": "1.0.2", 1961 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 1962 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 1963 | }, 1964 | "cson-parser": { 1965 | "version": "4.0.9", 1966 | "resolved": "https://registry.npmjs.org/cson-parser/-/cson-parser-4.0.9.tgz", 1967 | "integrity": "sha512-I79SAcCYquWnEfXYj8hBqOOWKj6eH6zX1hhX3yqmS4K3bYp7jME3UFpHPzu3rUew0oyfc0s8T6IlWGXRAheHag==", 1968 | "dev": true, 1969 | "optional": true, 1970 | "requires": { 1971 | "coffeescript": "1.12.7" 1972 | } 1973 | }, 1974 | "date-now": { 1975 | "version": "0.1.4", 1976 | "resolved": "https://registry.npmjs.org/date-now/-/date-now-0.1.4.tgz", 1977 | "integrity": "sha1-6vQ5/U1ISK105cx9vvIAZyueNFs=" 1978 | }, 1979 | "dateformat": { 1980 | "version": "3.0.3", 1981 | "resolved": "https://registry.npmjs.org/dateformat/-/dateformat-3.0.3.tgz", 1982 | "integrity": "sha512-jyCETtSl3VMZMWeRo7iY1FL19ges1t55hMo5yaam4Jrsm5EPL89UQkoQRyiI+Yf4k8r2ZpdngkV8hr1lIdjb3Q==" 1983 | }, 1984 | "debug": { 1985 | "version": "3.2.7", 1986 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1987 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1988 | "requires": { 1989 | "ms": "^2.1.1" 1990 | } 1991 | }, 1992 | "deep-extend": { 1993 | "version": "0.6.0", 1994 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 1995 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==" 1996 | }, 1997 | "detect-file": { 1998 | "version": "1.0.0", 1999 | "resolved": "https://registry.npmjs.org/detect-file/-/detect-file-1.0.0.tgz", 2000 | "integrity": "sha1-8NZtA2cqglyxtzvbP+YjEMjlUrc=" 2001 | }, 2002 | "dom-serializer": { 2003 | "version": "0.2.2", 2004 | "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-0.2.2.tgz", 2005 | "integrity": "sha512-2/xPb3ORsQ42nHYiSunXkDjPLBaEj/xTwUO4B7XCZQTRk7EBtTOPaygh10YAAh2OI1Qrp6NWfpAhzswj0ydt9g==", 2006 | "requires": { 2007 | "domelementtype": "^2.0.1", 2008 | "entities": "^2.0.0" 2009 | }, 2010 | "dependencies": { 2011 | "domelementtype": { 2012 | "version": "2.2.0", 2013 | "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.2.0.tgz", 2014 | "integrity": "sha512-DtBMo82pv1dFtUmHyr48beiuq792Sxohr+8Hm9zoxklYPfa6n0Z3Byjj2IV7bmr2IyqClnqEQhfgHJJ5QF0R5A==" 2015 | }, 2016 | "entities": { 2017 | "version": "2.2.0", 2018 | "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz", 2019 | "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==" 2020 | } 2021 | } 2022 | }, 2023 | "domelementtype": { 2024 | "version": "1.3.1", 2025 | "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-1.3.1.tgz", 2026 | "integrity": "sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w==" 2027 | }, 2028 | "domhandler": { 2029 | "version": "2.3.0", 2030 | "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-2.3.0.tgz", 2031 | "integrity": "sha1-LeWaCCLVAn+r/28DLCsloqir5zg=", 2032 | "requires": { 2033 | "domelementtype": "1" 2034 | } 2035 | }, 2036 | "domutils": { 2037 | "version": "1.5.1", 2038 | "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.5.1.tgz", 2039 | "integrity": "sha1-3NhIiib1Y9YQeeSMn3t+Mjc2gs8=", 2040 | "requires": { 2041 | "dom-serializer": "0", 2042 | "domelementtype": "1" 2043 | } 2044 | }, 2045 | "editorconfig": { 2046 | "version": "0.15.3", 2047 | "resolved": "https://registry.npmjs.org/editorconfig/-/editorconfig-0.15.3.tgz", 2048 | "integrity": "sha512-M9wIMFx96vq0R4F+gRpY3o2exzb8hEj/n9S8unZtHSvYjibBp/iMufSzvmOcV/laG0ZtuTVGtiJggPOSW2r93g==", 2049 | "requires": { 2050 | "commander": "^2.19.0", 2051 | "lru-cache": "^4.1.5", 2052 | "semver": "^5.6.0", 2053 | "sigmund": "^1.0.1" 2054 | }, 2055 | "dependencies": { 2056 | "semver": { 2057 | "version": "5.7.1", 2058 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 2059 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 2060 | } 2061 | } 2062 | }, 2063 | "entities": { 2064 | "version": "1.0.0", 2065 | "resolved": "https://registry.npmjs.org/entities/-/entities-1.0.0.tgz", 2066 | "integrity": "sha1-sph6o4ITR/zeZCsk/fyeT7cSvyY=" 2067 | }, 2068 | "error": { 2069 | "version": "7.2.1", 2070 | "resolved": "https://registry.npmjs.org/error/-/error-7.2.1.tgz", 2071 | "integrity": "sha512-fo9HBvWnx3NGUKMvMwB/CBCMMrfEJgbDTVDEkPygA3Bdd3lM1OyCd+rbQ8BwnpF6GdVeOLDNmyL4N5Bg80ZvdA==", 2072 | "requires": { 2073 | "string-template": "~0.2.1" 2074 | } 2075 | }, 2076 | "esprima": { 2077 | "version": "4.0.1", 2078 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 2079 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==" 2080 | }, 2081 | "eventemitter2": { 2082 | "version": "0.4.14", 2083 | "resolved": "https://registry.npmjs.org/eventemitter2/-/eventemitter2-0.4.14.tgz", 2084 | "integrity": "sha1-j2G3XN4BKy6esoTUVFWDtWQ7Yas=" 2085 | }, 2086 | "exit": { 2087 | "version": "0.1.2", 2088 | "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", 2089 | "integrity": "sha1-BjJjj42HfMghB9MKD/8aF8uhzQw=" 2090 | }, 2091 | "expand-tilde": { 2092 | "version": "2.0.2", 2093 | "resolved": "https://registry.npmjs.org/expand-tilde/-/expand-tilde-2.0.2.tgz", 2094 | "integrity": "sha1-l+gBqgUt8CRU3kawK/YhZCzchQI=", 2095 | "requires": { 2096 | "homedir-polyfill": "^1.0.1" 2097 | } 2098 | }, 2099 | "extend": { 2100 | "version": "3.0.2", 2101 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 2102 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==" 2103 | }, 2104 | "faye-websocket": { 2105 | "version": "0.10.0", 2106 | "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.10.0.tgz", 2107 | "integrity": "sha1-TkkvjQTftviQA1B/btvy1QHnxvQ=", 2108 | "requires": { 2109 | "websocket-driver": ">=0.5.1" 2110 | } 2111 | }, 2112 | "file-sync-cmp": { 2113 | "version": "0.1.1", 2114 | "resolved": "https://registry.npmjs.org/file-sync-cmp/-/file-sync-cmp-0.1.1.tgz", 2115 | "integrity": "sha1-peeo/7+kk7Q7kju9TKiaU7Y7YSs=", 2116 | "dev": true 2117 | }, 2118 | "fill-range": { 2119 | "version": "7.0.1", 2120 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2121 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2122 | "requires": { 2123 | "to-regex-range": "^5.0.1" 2124 | } 2125 | }, 2126 | "findup-sync": { 2127 | "version": "0.3.0", 2128 | "resolved": "https://registry.npmjs.org/findup-sync/-/findup-sync-0.3.0.tgz", 2129 | "integrity": "sha1-N5MKpdgWt3fANEXhlmzGeQpMCxY=", 2130 | "requires": { 2131 | "glob": "~5.0.0" 2132 | }, 2133 | "dependencies": { 2134 | "glob": { 2135 | "version": "5.0.15", 2136 | "resolved": "https://registry.npmjs.org/glob/-/glob-5.0.15.tgz", 2137 | "integrity": "sha1-G8k2ueAvSmA/zCIuz3Yz0wuLk7E=", 2138 | "requires": { 2139 | "inflight": "^1.0.4", 2140 | "inherits": "2", 2141 | "minimatch": "2 || 3", 2142 | "once": "^1.3.0", 2143 | "path-is-absolute": "^1.0.0" 2144 | } 2145 | } 2146 | } 2147 | }, 2148 | "fined": { 2149 | "version": "1.2.0", 2150 | "resolved": "https://registry.npmjs.org/fined/-/fined-1.2.0.tgz", 2151 | "integrity": "sha512-ZYDqPLGxDkDhDZBjZBb+oD1+j0rA4E0pXY50eplAAOPg2N/gUBSSk5IM1/QhPfyVo19lJ+CvXpqfvk+b2p/8Ng==", 2152 | "requires": { 2153 | "expand-tilde": "^2.0.2", 2154 | "is-plain-object": "^2.0.3", 2155 | "object.defaults": "^1.1.0", 2156 | "object.pick": "^1.2.0", 2157 | "parse-filepath": "^1.0.1" 2158 | } 2159 | }, 2160 | "flagged-respawn": { 2161 | "version": "1.0.1", 2162 | "resolved": "https://registry.npmjs.org/flagged-respawn/-/flagged-respawn-1.0.1.tgz", 2163 | "integrity": "sha512-lNaHNVymajmk0OJMBn8fVUAU1BtDeKIqKoVhk4xAALB57aALg6b4W0MfJ/cUE0g9YBXy5XhSlPIpYIJ7HaY/3Q==" 2164 | }, 2165 | "for-in": { 2166 | "version": "1.0.2", 2167 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", 2168 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=" 2169 | }, 2170 | "for-own": { 2171 | "version": "1.0.0", 2172 | "resolved": "https://registry.npmjs.org/for-own/-/for-own-1.0.0.tgz", 2173 | "integrity": "sha1-xjMy9BXO3EsE2/5wz4NklMU8tEs=", 2174 | "requires": { 2175 | "for-in": "^1.0.1" 2176 | } 2177 | }, 2178 | "fs.realpath": { 2179 | "version": "1.0.0", 2180 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2181 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 2182 | }, 2183 | "function-bind": { 2184 | "version": "1.1.1", 2185 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 2186 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 2187 | }, 2188 | "gaze": { 2189 | "version": "1.1.3", 2190 | "resolved": "https://registry.npmjs.org/gaze/-/gaze-1.1.3.tgz", 2191 | "integrity": "sha512-BRdNm8hbWzFzWHERTrejLqwHDfS4GibPoq5wjTPIoJHoBtKGPg3xAFfxmM+9ztbXelxcf2hwQcaz1PtmFeue8g==", 2192 | "requires": { 2193 | "globule": "^1.0.0" 2194 | } 2195 | }, 2196 | "get-intrinsic": { 2197 | "version": "1.1.1", 2198 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", 2199 | "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", 2200 | "requires": { 2201 | "function-bind": "^1.1.1", 2202 | "has": "^1.0.3", 2203 | "has-symbols": "^1.0.1" 2204 | } 2205 | }, 2206 | "getobject": { 2207 | "version": "1.0.1", 2208 | "resolved": "https://registry.npmjs.org/getobject/-/getobject-1.0.1.tgz", 2209 | "integrity": "sha512-tj18lLe+917AACr6BdVoUuHnBPTVd9BEJp1vxnMZ58ztNvuxz9Ufa+wf3g37tlGITH35jggwZ2d9lcgHJJgXfQ==" 2210 | }, 2211 | "glob": { 2212 | "version": "7.1.7", 2213 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.7.tgz", 2214 | "integrity": "sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ==", 2215 | "requires": { 2216 | "fs.realpath": "^1.0.0", 2217 | "inflight": "^1.0.4", 2218 | "inherits": "2", 2219 | "minimatch": "^3.0.4", 2220 | "once": "^1.3.0", 2221 | "path-is-absolute": "^1.0.0" 2222 | } 2223 | }, 2224 | "global-modules": { 2225 | "version": "1.0.0", 2226 | "resolved": "https://registry.npmjs.org/global-modules/-/global-modules-1.0.0.tgz", 2227 | "integrity": "sha512-sKzpEkf11GpOFuw0Zzjzmt4B4UZwjOcG757PPvrfhxcLFbq0wpsgpOqxpxtxFiCG4DtG93M6XRVbF2oGdev7bg==", 2228 | "requires": { 2229 | "global-prefix": "^1.0.1", 2230 | "is-windows": "^1.0.1", 2231 | "resolve-dir": "^1.0.0" 2232 | } 2233 | }, 2234 | "global-prefix": { 2235 | "version": "1.0.2", 2236 | "resolved": "https://registry.npmjs.org/global-prefix/-/global-prefix-1.0.2.tgz", 2237 | "integrity": "sha1-2/dDxsFJklk8ZVVoy2btMsASLr4=", 2238 | "requires": { 2239 | "expand-tilde": "^2.0.2", 2240 | "homedir-polyfill": "^1.0.1", 2241 | "ini": "^1.3.4", 2242 | "is-windows": "^1.0.1", 2243 | "which": "^1.2.14" 2244 | }, 2245 | "dependencies": { 2246 | "which": { 2247 | "version": "1.3.1", 2248 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 2249 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 2250 | "requires": { 2251 | "isexe": "^2.0.0" 2252 | } 2253 | } 2254 | } 2255 | }, 2256 | "globule": { 2257 | "version": "1.3.2", 2258 | "resolved": "https://registry.npmjs.org/globule/-/globule-1.3.2.tgz", 2259 | "integrity": "sha512-7IDTQTIu2xzXkT+6mlluidnWo+BypnbSoEVVQCGfzqnl5Ik8d3e1d4wycb8Rj9tWW+Z39uPWsdlquqiqPCd/pA==", 2260 | "requires": { 2261 | "glob": "~7.1.1", 2262 | "lodash": "~4.17.10", 2263 | "minimatch": "~3.0.2" 2264 | } 2265 | }, 2266 | "grunt": { 2267 | "version": "1.4.1", 2268 | "resolved": "https://registry.npmjs.org/grunt/-/grunt-1.4.1.tgz", 2269 | "integrity": "sha512-ZXIYXTsAVrA7sM+jZxjQdrBOAg7DyMUplOMhTaspMRExei+fD0BTwdWXnn0W5SXqhb/Q/nlkzXclSi3IH55PIA==", 2270 | "requires": { 2271 | "dateformat": "~3.0.3", 2272 | "eventemitter2": "~0.4.13", 2273 | "exit": "~0.1.2", 2274 | "findup-sync": "~0.3.0", 2275 | "glob": "~7.1.6", 2276 | "grunt-cli": "~1.4.2", 2277 | "grunt-known-options": "~2.0.0", 2278 | "grunt-legacy-log": "~3.0.0", 2279 | "grunt-legacy-util": "~2.0.1", 2280 | "iconv-lite": "~0.4.13", 2281 | "js-yaml": "~3.14.0", 2282 | "minimatch": "~3.0.4", 2283 | "mkdirp": "~1.0.4", 2284 | "nopt": "~3.0.6", 2285 | "rimraf": "~3.0.2" 2286 | } 2287 | }, 2288 | "grunt-bumpup": { 2289 | "version": "0.6.3", 2290 | "resolved": "https://registry.npmjs.org/grunt-bumpup/-/grunt-bumpup-0.6.3.tgz", 2291 | "integrity": "sha1-dU6Wu2pTN9C5VInl3EmWuvyLtBQ=", 2292 | "dev": true, 2293 | "requires": { 2294 | "moment": "^2.8.3", 2295 | "semver": "^4.0.3" 2296 | } 2297 | }, 2298 | "grunt-cli": { 2299 | "version": "1.4.3", 2300 | "resolved": "https://registry.npmjs.org/grunt-cli/-/grunt-cli-1.4.3.tgz", 2301 | "integrity": "sha512-9Dtx/AhVeB4LYzsViCjUQkd0Kw0McN2gYpdmGYKtE2a5Yt7v1Q+HYZVWhqXc/kGnxlMtqKDxSwotiGeFmkrCoQ==", 2302 | "requires": { 2303 | "grunt-known-options": "~2.0.0", 2304 | "interpret": "~1.1.0", 2305 | "liftup": "~3.0.1", 2306 | "nopt": "~4.0.1", 2307 | "v8flags": "~3.2.0" 2308 | }, 2309 | "dependencies": { 2310 | "nopt": { 2311 | "version": "4.0.3", 2312 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.3.tgz", 2313 | "integrity": "sha512-CvaGwVMztSMJLOeXPrez7fyfObdZqNUK1cPAEzLHrTybIua9pMdmmPR5YwtfNftIOMv3DPUhFaxsZMNTQO20Kg==", 2314 | "requires": { 2315 | "abbrev": "1", 2316 | "osenv": "^0.1.4" 2317 | } 2318 | } 2319 | } 2320 | }, 2321 | "grunt-contrib-jshint": { 2322 | "version": "3.0.0", 2323 | "resolved": "https://registry.npmjs.org/grunt-contrib-jshint/-/grunt-contrib-jshint-3.0.0.tgz", 2324 | "integrity": "sha512-o0V3HNK54+w2Lss/AP0LsAUCEmPDQIcgsDFvTy0sE8sdPXq/8vHdNdMEitK9Wcfoq7H6v02v6soiiwJ0wavT7A==", 2325 | "requires": { 2326 | "chalk": "^4.1.0", 2327 | "hooker": "^0.2.3", 2328 | "jshint": "~2.12.0" 2329 | } 2330 | }, 2331 | "grunt-contrib-rename": { 2332 | "version": "0.2.0", 2333 | "resolved": "https://registry.npmjs.org/grunt-contrib-rename/-/grunt-contrib-rename-0.2.0.tgz", 2334 | "integrity": "sha1-1CPU+SqZpYcncEX4MikdmM4V/co=", 2335 | "dev": true, 2336 | "requires": {} 2337 | }, 2338 | "grunt-contrib-watch": { 2339 | "version": "1.1.0", 2340 | "resolved": "https://registry.npmjs.org/grunt-contrib-watch/-/grunt-contrib-watch-1.1.0.tgz", 2341 | "integrity": "sha512-yGweN+0DW5yM+oo58fRu/XIRrPcn3r4tQx+nL7eMRwjpvk+rQY6R8o94BPK0i2UhTg9FN21hS+m8vR8v9vXfeg==", 2342 | "requires": { 2343 | "async": "^2.6.0", 2344 | "gaze": "^1.1.0", 2345 | "lodash": "^4.17.10", 2346 | "tiny-lr": "^1.1.1" 2347 | } 2348 | }, 2349 | "grunt-exec": { 2350 | "version": "0.4.7", 2351 | "resolved": "https://registry.npmjs.org/grunt-exec/-/grunt-exec-0.4.7.tgz", 2352 | "integrity": "sha1-QAUf+k6wyWV+BTuV6I1ENSocLCU=", 2353 | "requires": {} 2354 | }, 2355 | "grunt-jsbeautifier": { 2356 | "version": "0.2.13", 2357 | "resolved": "https://registry.npmjs.org/grunt-jsbeautifier/-/grunt-jsbeautifier-0.2.13.tgz", 2358 | "integrity": "sha1-89QXOPy1+ZhO8pbVvuvEBIkQVkI=", 2359 | "requires": { 2360 | "async": "^2.0.0-rc.3", 2361 | "grunt": ">=0.4.1", 2362 | "js-beautify": ">=1.4.2", 2363 | "lodash": ">=2.4.1", 2364 | "rc": ">=0.5.5", 2365 | "semver": ">=4.3.1", 2366 | "underscore.string": ">=2.3.3" 2367 | } 2368 | }, 2369 | "grunt-known-options": { 2370 | "version": "2.0.0", 2371 | "resolved": "https://registry.npmjs.org/grunt-known-options/-/grunt-known-options-2.0.0.tgz", 2372 | "integrity": "sha512-GD7cTz0I4SAede1/+pAbmJRG44zFLPipVtdL9o3vqx9IEyb7b4/Y3s7r6ofI3CchR5GvYJ+8buCSioDv5dQLiA==" 2373 | }, 2374 | "grunt-legacy-log": { 2375 | "version": "3.0.0", 2376 | "resolved": "https://registry.npmjs.org/grunt-legacy-log/-/grunt-legacy-log-3.0.0.tgz", 2377 | "integrity": "sha512-GHZQzZmhyq0u3hr7aHW4qUH0xDzwp2YXldLPZTCjlOeGscAOWWPftZG3XioW8MasGp+OBRIu39LFx14SLjXRcA==", 2378 | "requires": { 2379 | "colors": "~1.1.2", 2380 | "grunt-legacy-log-utils": "~2.1.0", 2381 | "hooker": "~0.2.3", 2382 | "lodash": "~4.17.19" 2383 | } 2384 | }, 2385 | "grunt-legacy-log-utils": { 2386 | "version": "2.1.0", 2387 | "resolved": "https://registry.npmjs.org/grunt-legacy-log-utils/-/grunt-legacy-log-utils-2.1.0.tgz", 2388 | "integrity": "sha512-lwquaPXJtKQk0rUM1IQAop5noEpwFqOXasVoedLeNzaibf/OPWjKYvvdqnEHNmU+0T0CaReAXIbGo747ZD+Aaw==", 2389 | "requires": { 2390 | "chalk": "~4.1.0", 2391 | "lodash": "~4.17.19" 2392 | } 2393 | }, 2394 | "grunt-legacy-util": { 2395 | "version": "2.0.1", 2396 | "resolved": "https://registry.npmjs.org/grunt-legacy-util/-/grunt-legacy-util-2.0.1.tgz", 2397 | "integrity": "sha512-2bQiD4fzXqX8rhNdXkAywCadeqiPiay0oQny77wA2F3WF4grPJXCvAcyoWUJV+po/b15glGkxuSiQCK299UC2w==", 2398 | "requires": { 2399 | "async": "~3.2.0", 2400 | "exit": "~0.1.2", 2401 | "getobject": "~1.0.0", 2402 | "hooker": "~0.2.3", 2403 | "lodash": "~4.17.21", 2404 | "underscore.string": "~3.3.5", 2405 | "which": "~2.0.2" 2406 | }, 2407 | "dependencies": { 2408 | "async": { 2409 | "version": "3.2.0", 2410 | "resolved": "https://registry.npmjs.org/async/-/async-3.2.0.tgz", 2411 | "integrity": "sha512-TR2mEZFVOj2pLStYxLht7TyfuRzaydfpxr3k9RpHIzMgw7A64dzsdqCxH1WJyQdoe8T10nDXd9wnEigmiuHIZw==" 2412 | } 2413 | } 2414 | }, 2415 | "grunt-replace": { 2416 | "version": "2.0.2", 2417 | "resolved": "https://registry.npmjs.org/grunt-replace/-/grunt-replace-2.0.2.tgz", 2418 | "integrity": "sha512-cv7ua3vBeUpCBkb+L4vZ8hwE8Sz6Sf/mb3031kufKVfKAestekHSsDO0BK63mhrRknsAHlnkHkieIxrjHS/fJA==", 2419 | "dev": true, 2420 | "requires": { 2421 | "applause": "^2.0.0", 2422 | "chalk": "^4.1.0", 2423 | "file-sync-cmp": "^0.1.0", 2424 | "lodash": "^4.17.21" 2425 | } 2426 | }, 2427 | "has": { 2428 | "version": "1.0.3", 2429 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 2430 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 2431 | "requires": { 2432 | "function-bind": "^1.1.1" 2433 | } 2434 | }, 2435 | "has-flag": { 2436 | "version": "4.0.0", 2437 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2438 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" 2439 | }, 2440 | "has-symbols": { 2441 | "version": "1.0.2", 2442 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", 2443 | "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==" 2444 | }, 2445 | "homedir-polyfill": { 2446 | "version": "1.0.3", 2447 | "resolved": "https://registry.npmjs.org/homedir-polyfill/-/homedir-polyfill-1.0.3.tgz", 2448 | "integrity": "sha512-eSmmWE5bZTK2Nou4g0AI3zZ9rswp7GRKoKXS1BLUkvPviOqs4YTN1djQIqrXy9k5gEtdLPy86JjRwsNM9tnDcA==", 2449 | "requires": { 2450 | "parse-passwd": "^1.0.0" 2451 | } 2452 | }, 2453 | "hooker": { 2454 | "version": "0.2.3", 2455 | "resolved": "https://registry.npmjs.org/hooker/-/hooker-0.2.3.tgz", 2456 | "integrity": "sha1-uDT3I8xKJCqmWWNFnfbZhMXT2Vk=" 2457 | }, 2458 | "htmlparser2": { 2459 | "version": "3.8.3", 2460 | "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-3.8.3.tgz", 2461 | "integrity": "sha1-mWwosZFRaovoZQGn15dX5ccMEGg=", 2462 | "requires": { 2463 | "domelementtype": "1", 2464 | "domhandler": "2.3", 2465 | "domutils": "1.5", 2466 | "entities": "1.0", 2467 | "readable-stream": "1.1" 2468 | } 2469 | }, 2470 | "http-parser-js": { 2471 | "version": "0.5.3", 2472 | "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.5.3.tgz", 2473 | "integrity": "sha512-t7hjvef/5HEK7RWTdUzVUhl8zkEu+LlaE0IYzdMuvbSDipxBRpOn4Uhw8ZyECEa808iVT8XCjzo6xmYt4CiLZg==" 2474 | }, 2475 | "iconv-lite": { 2476 | "version": "0.4.24", 2477 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 2478 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 2479 | "requires": { 2480 | "safer-buffer": ">= 2.1.2 < 3" 2481 | } 2482 | }, 2483 | "inflight": { 2484 | "version": "1.0.6", 2485 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2486 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 2487 | "requires": { 2488 | "once": "^1.3.0", 2489 | "wrappy": "1" 2490 | } 2491 | }, 2492 | "inherits": { 2493 | "version": "2.0.4", 2494 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2495 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 2496 | }, 2497 | "ini": { 2498 | "version": "1.3.8", 2499 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", 2500 | "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==" 2501 | }, 2502 | "interpret": { 2503 | "version": "1.1.0", 2504 | "resolved": "https://registry.npmjs.org/interpret/-/interpret-1.1.0.tgz", 2505 | "integrity": "sha1-ftGxQQxqDg94z5XTuEQMY/eLhhQ=" 2506 | }, 2507 | "is-absolute": { 2508 | "version": "1.0.0", 2509 | "resolved": "https://registry.npmjs.org/is-absolute/-/is-absolute-1.0.0.tgz", 2510 | "integrity": "sha512-dOWoqflvcydARa360Gvv18DZ/gRuHKi2NU/wU5X1ZFzdYfH29nkiNZsF3mp4OJ3H4yo9Mx8A/uAGNzpzPN3yBA==", 2511 | "requires": { 2512 | "is-relative": "^1.0.0", 2513 | "is-windows": "^1.0.1" 2514 | } 2515 | }, 2516 | "is-core-module": { 2517 | "version": "2.4.0", 2518 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.4.0.tgz", 2519 | "integrity": "sha512-6A2fkfq1rfeQZjxrZJGerpLCTHRNEBiSgnu0+obeJpEPZRUooHgsizvzv0ZjJwOz3iWIHdJtVWJ/tmPr3D21/A==", 2520 | "requires": { 2521 | "has": "^1.0.3" 2522 | } 2523 | }, 2524 | "is-extglob": { 2525 | "version": "2.1.1", 2526 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2527 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=" 2528 | }, 2529 | "is-glob": { 2530 | "version": "4.0.1", 2531 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 2532 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 2533 | "requires": { 2534 | "is-extglob": "^2.1.1" 2535 | } 2536 | }, 2537 | "is-number": { 2538 | "version": "7.0.0", 2539 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2540 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==" 2541 | }, 2542 | "is-plain-object": { 2543 | "version": "2.0.4", 2544 | "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", 2545 | "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", 2546 | "requires": { 2547 | "isobject": "^3.0.1" 2548 | } 2549 | }, 2550 | "is-relative": { 2551 | "version": "1.0.0", 2552 | "resolved": "https://registry.npmjs.org/is-relative/-/is-relative-1.0.0.tgz", 2553 | "integrity": "sha512-Kw/ReK0iqwKeu0MITLFuj0jbPAmEiOsIwyIXvvbfa6QfmN9pkD1M+8pdk7Rl/dTKbH34/XBFMbgD4iMJhLQbGA==", 2554 | "requires": { 2555 | "is-unc-path": "^1.0.0" 2556 | } 2557 | }, 2558 | "is-unc-path": { 2559 | "version": "1.0.0", 2560 | "resolved": "https://registry.npmjs.org/is-unc-path/-/is-unc-path-1.0.0.tgz", 2561 | "integrity": "sha512-mrGpVd0fs7WWLfVsStvgF6iEJnbjDFZh9/emhRDcGWTduTfNHd9CHeUwH3gYIjdbwo4On6hunkztwOaAw0yllQ==", 2562 | "requires": { 2563 | "unc-path-regex": "^0.1.2" 2564 | } 2565 | }, 2566 | "is-windows": { 2567 | "version": "1.0.2", 2568 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", 2569 | "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==" 2570 | }, 2571 | "isarray": { 2572 | "version": "0.0.1", 2573 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 2574 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=" 2575 | }, 2576 | "isexe": { 2577 | "version": "2.0.0", 2578 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2579 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" 2580 | }, 2581 | "isobject": { 2582 | "version": "3.0.1", 2583 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", 2584 | "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" 2585 | }, 2586 | "js-beautify": { 2587 | "version": "1.14.0", 2588 | "resolved": "https://registry.npmjs.org/js-beautify/-/js-beautify-1.14.0.tgz", 2589 | "integrity": "sha512-yuck9KirNSCAwyNJbqW+BxJqJ0NLJ4PwBUzQQACl5O3qHMBXVkXb/rD0ilh/Lat/tn88zSZ+CAHOlk0DsY7GuQ==", 2590 | "requires": { 2591 | "config-chain": "^1.1.12", 2592 | "editorconfig": "^0.15.3", 2593 | "glob": "^7.1.3", 2594 | "nopt": "^5.0.0" 2595 | }, 2596 | "dependencies": { 2597 | "nopt": { 2598 | "version": "5.0.0", 2599 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-5.0.0.tgz", 2600 | "integrity": "sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ==", 2601 | "requires": { 2602 | "abbrev": "1" 2603 | } 2604 | } 2605 | } 2606 | }, 2607 | "js-yaml": { 2608 | "version": "3.14.1", 2609 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 2610 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 2611 | "requires": { 2612 | "argparse": "^1.0.7", 2613 | "esprima": "^4.0.0" 2614 | } 2615 | }, 2616 | "jshint": { 2617 | "version": "2.12.0", 2618 | "resolved": "https://registry.npmjs.org/jshint/-/jshint-2.12.0.tgz", 2619 | "integrity": "sha512-TwuuaUDmra0JMkuqvqy+WGo2xGHSNjv1BA1nTIgtH2K5z1jHuAEeAgp7laaR+hLRmajRjcrM71+vByBDanCyYA==", 2620 | "requires": { 2621 | "cli": "~1.0.0", 2622 | "console-browserify": "1.1.x", 2623 | "exit": "0.1.x", 2624 | "htmlparser2": "3.8.x", 2625 | "lodash": "~4.17.19", 2626 | "minimatch": "~3.0.2", 2627 | "shelljs": "0.3.x", 2628 | "strip-json-comments": "1.0.x" 2629 | } 2630 | }, 2631 | "kind-of": { 2632 | "version": "6.0.3", 2633 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", 2634 | "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==" 2635 | }, 2636 | "liftup": { 2637 | "version": "3.0.1", 2638 | "resolved": "https://registry.npmjs.org/liftup/-/liftup-3.0.1.tgz", 2639 | "integrity": "sha512-yRHaiQDizWSzoXk3APcA71eOI/UuhEkNN9DiW2Tt44mhYzX4joFoCZlxsSOF7RyeLlfqzFLQI1ngFq3ggMPhOw==", 2640 | "requires": { 2641 | "extend": "^3.0.2", 2642 | "findup-sync": "^4.0.0", 2643 | "fined": "^1.2.0", 2644 | "flagged-respawn": "^1.0.1", 2645 | "is-plain-object": "^2.0.4", 2646 | "object.map": "^1.0.1", 2647 | "rechoir": "^0.7.0", 2648 | "resolve": "^1.19.0" 2649 | }, 2650 | "dependencies": { 2651 | "findup-sync": { 2652 | "version": "4.0.0", 2653 | "resolved": "https://registry.npmjs.org/findup-sync/-/findup-sync-4.0.0.tgz", 2654 | "integrity": "sha512-6jvvn/12IC4quLBL1KNokxC7wWTvYncaVUYSoxWw7YykPLuRrnv4qdHcSOywOI5RpkOVGeQRtWM8/q+G6W6qfQ==", 2655 | "requires": { 2656 | "detect-file": "^1.0.0", 2657 | "is-glob": "^4.0.0", 2658 | "micromatch": "^4.0.2", 2659 | "resolve-dir": "^1.0.1" 2660 | } 2661 | } 2662 | } 2663 | }, 2664 | "livereload-js": { 2665 | "version": "2.4.0", 2666 | "resolved": "https://registry.npmjs.org/livereload-js/-/livereload-js-2.4.0.tgz", 2667 | "integrity": "sha512-XPQH8Z2GDP/Hwz2PCDrh2mth4yFejwA1OZ/81Ti3LgKyhDcEjsSsqFWZojHG0va/duGd+WyosY7eXLDoOyqcPw==" 2668 | }, 2669 | "lodash": { 2670 | "version": "4.17.21", 2671 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 2672 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 2673 | }, 2674 | "lru-cache": { 2675 | "version": "4.1.5", 2676 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", 2677 | "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", 2678 | "requires": { 2679 | "pseudomap": "^1.0.2", 2680 | "yallist": "^2.1.2" 2681 | } 2682 | }, 2683 | "make-iterator": { 2684 | "version": "1.0.1", 2685 | "resolved": "https://registry.npmjs.org/make-iterator/-/make-iterator-1.0.1.tgz", 2686 | "integrity": "sha512-pxiuXh0iVEq7VM7KMIhs5gxsfxCux2URptUQaXo4iZZJxBAzTPOLE2BumO5dbfVYq/hBJFBR/a1mFDmOx5AGmw==", 2687 | "requires": { 2688 | "kind-of": "^6.0.2" 2689 | } 2690 | }, 2691 | "map-cache": { 2692 | "version": "0.2.2", 2693 | "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz", 2694 | "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=" 2695 | }, 2696 | "micromatch": { 2697 | "version": "4.0.4", 2698 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.4.tgz", 2699 | "integrity": "sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg==", 2700 | "requires": { 2701 | "braces": "^3.0.1", 2702 | "picomatch": "^2.2.3" 2703 | } 2704 | }, 2705 | "minimatch": { 2706 | "version": "3.0.4", 2707 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2708 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2709 | "requires": { 2710 | "brace-expansion": "^1.1.7" 2711 | } 2712 | }, 2713 | "minimist": { 2714 | "version": "1.2.5", 2715 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 2716 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" 2717 | }, 2718 | "mkdirp": { 2719 | "version": "1.0.4", 2720 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 2721 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==" 2722 | }, 2723 | "moment": { 2724 | "version": "2.29.1", 2725 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.1.tgz", 2726 | "integrity": "sha512-kHmoybcPV8Sqy59DwNDY3Jefr64lK/by/da0ViFcuA4DH0vQg5Q6Ze5VimxkfQNSC+Mls/Kx53s7TjP1RhFEDQ==", 2727 | "dev": true 2728 | }, 2729 | "ms": { 2730 | "version": "2.1.3", 2731 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2732 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 2733 | }, 2734 | "nopt": { 2735 | "version": "3.0.6", 2736 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-3.0.6.tgz", 2737 | "integrity": "sha1-xkZdvwirzU2zWTF/eaxopkayj/k=", 2738 | "requires": { 2739 | "abbrev": "1" 2740 | } 2741 | }, 2742 | "object-assign": { 2743 | "version": "4.1.1", 2744 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 2745 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 2746 | }, 2747 | "object-inspect": { 2748 | "version": "1.10.3", 2749 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.10.3.tgz", 2750 | "integrity": "sha512-e5mCJlSH7poANfC8z8S9s9S2IN5/4Zb3aZ33f5s8YqoazCFzNLloLU8r5VCG+G7WoqLvAAZoVMcy3tp/3X0Plw==" 2751 | }, 2752 | "object.defaults": { 2753 | "version": "1.1.0", 2754 | "resolved": "https://registry.npmjs.org/object.defaults/-/object.defaults-1.1.0.tgz", 2755 | "integrity": "sha1-On+GgzS0B96gbaFtiNXNKeQ1/s8=", 2756 | "requires": { 2757 | "array-each": "^1.0.1", 2758 | "array-slice": "^1.0.0", 2759 | "for-own": "^1.0.0", 2760 | "isobject": "^3.0.0" 2761 | } 2762 | }, 2763 | "object.map": { 2764 | "version": "1.0.1", 2765 | "resolved": "https://registry.npmjs.org/object.map/-/object.map-1.0.1.tgz", 2766 | "integrity": "sha1-z4Plncj8wK1fQlDh94s7gb2AHTc=", 2767 | "requires": { 2768 | "for-own": "^1.0.0", 2769 | "make-iterator": "^1.0.0" 2770 | } 2771 | }, 2772 | "object.pick": { 2773 | "version": "1.3.0", 2774 | "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz", 2775 | "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", 2776 | "requires": { 2777 | "isobject": "^3.0.1" 2778 | } 2779 | }, 2780 | "once": { 2781 | "version": "1.4.0", 2782 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2783 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2784 | "requires": { 2785 | "wrappy": "1" 2786 | } 2787 | }, 2788 | "optional-require": { 2789 | "version": "1.0.3", 2790 | "resolved": "https://registry.npmjs.org/optional-require/-/optional-require-1.0.3.tgz", 2791 | "integrity": "sha512-RV2Zp2MY2aeYK5G+B/Sps8lW5NHAzE5QClbFP15j+PWmP+T9PxlJXBOOLoSAdgwFvS4t0aMR4vpedMkbHfh0nA==", 2792 | "dev": true 2793 | }, 2794 | "os-homedir": { 2795 | "version": "1.0.2", 2796 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 2797 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=" 2798 | }, 2799 | "os-tmpdir": { 2800 | "version": "1.0.2", 2801 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 2802 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" 2803 | }, 2804 | "osenv": { 2805 | "version": "0.1.5", 2806 | "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz", 2807 | "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==", 2808 | "requires": { 2809 | "os-homedir": "^1.0.0", 2810 | "os-tmpdir": "^1.0.0" 2811 | } 2812 | }, 2813 | "parse-filepath": { 2814 | "version": "1.0.2", 2815 | "resolved": "https://registry.npmjs.org/parse-filepath/-/parse-filepath-1.0.2.tgz", 2816 | "integrity": "sha1-pjISf1Oq89FYdvWHLz/6x2PWyJE=", 2817 | "requires": { 2818 | "is-absolute": "^1.0.0", 2819 | "map-cache": "^0.2.0", 2820 | "path-root": "^0.1.1" 2821 | } 2822 | }, 2823 | "parse-passwd": { 2824 | "version": "1.0.0", 2825 | "resolved": "https://registry.npmjs.org/parse-passwd/-/parse-passwd-1.0.0.tgz", 2826 | "integrity": "sha1-bVuTSkVpk7I9N/QKOC1vFmao5cY=" 2827 | }, 2828 | "path-is-absolute": { 2829 | "version": "1.0.1", 2830 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2831 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 2832 | }, 2833 | "path-parse": { 2834 | "version": "1.0.7", 2835 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 2836 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" 2837 | }, 2838 | "path-root": { 2839 | "version": "0.1.1", 2840 | "resolved": "https://registry.npmjs.org/path-root/-/path-root-0.1.1.tgz", 2841 | "integrity": "sha1-mkpoFMrBwM1zNgqV8yCDyOpHRbc=", 2842 | "requires": { 2843 | "path-root-regex": "^0.1.0" 2844 | } 2845 | }, 2846 | "path-root-regex": { 2847 | "version": "0.1.2", 2848 | "resolved": "https://registry.npmjs.org/path-root-regex/-/path-root-regex-0.1.2.tgz", 2849 | "integrity": "sha1-v8zcjfWxLcUsi0PsONGNcsBLqW0=" 2850 | }, 2851 | "picomatch": { 2852 | "version": "2.3.0", 2853 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 2854 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==" 2855 | }, 2856 | "proto-list": { 2857 | "version": "1.2.4", 2858 | "resolved": "https://registry.npmjs.org/proto-list/-/proto-list-1.2.4.tgz", 2859 | "integrity": "sha1-IS1b/hMYMGpCD2QCuOJv85ZHqEk=" 2860 | }, 2861 | "pseudomap": { 2862 | "version": "1.0.2", 2863 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 2864 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" 2865 | }, 2866 | "qs": { 2867 | "version": "6.10.1", 2868 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.10.1.tgz", 2869 | "integrity": "sha512-M528Hph6wsSVOBiYUnGf+K/7w0hNshs/duGsNXPUCLH5XAqjEtiPGwNONLV0tBH8NoGb0mvD5JubnUTrujKDTg==", 2870 | "requires": { 2871 | "side-channel": "^1.0.4" 2872 | } 2873 | }, 2874 | "raw-body": { 2875 | "version": "1.1.7", 2876 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-1.1.7.tgz", 2877 | "integrity": "sha1-HQJ8K/oRasxmI7yo8AAWVyqH1CU=", 2878 | "requires": { 2879 | "bytes": "1", 2880 | "string_decoder": "0.10" 2881 | } 2882 | }, 2883 | "rc": { 2884 | "version": "1.2.8", 2885 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 2886 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 2887 | "requires": { 2888 | "deep-extend": "^0.6.0", 2889 | "ini": "~1.3.0", 2890 | "minimist": "^1.2.0", 2891 | "strip-json-comments": "~2.0.1" 2892 | }, 2893 | "dependencies": { 2894 | "strip-json-comments": { 2895 | "version": "2.0.1", 2896 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2897 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=" 2898 | } 2899 | } 2900 | }, 2901 | "readable-stream": { 2902 | "version": "1.1.14", 2903 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", 2904 | "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", 2905 | "requires": { 2906 | "core-util-is": "~1.0.0", 2907 | "inherits": "~2.0.1", 2908 | "isarray": "0.0.1", 2909 | "string_decoder": "~0.10.x" 2910 | } 2911 | }, 2912 | "rechoir": { 2913 | "version": "0.7.0", 2914 | "resolved": "https://registry.npmjs.org/rechoir/-/rechoir-0.7.0.tgz", 2915 | "integrity": "sha512-ADsDEH2bvbjltXEP+hTIAmeFekTFK0V2BTxMkok6qILyAJEXV0AFfoWcAq4yfll5VdIMd/RVXq0lR+wQi5ZU3Q==", 2916 | "requires": { 2917 | "resolve": "^1.9.0" 2918 | } 2919 | }, 2920 | "resolve": { 2921 | "version": "1.20.0", 2922 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.20.0.tgz", 2923 | "integrity": "sha512-wENBPt4ySzg4ybFQW2TT1zMQucPK95HSh/nq2CFTZVOGut2+pQvSsgtda4d26YrYcr067wjbmzOG8byDPBX63A==", 2924 | "requires": { 2925 | "is-core-module": "^2.2.0", 2926 | "path-parse": "^1.0.6" 2927 | } 2928 | }, 2929 | "resolve-dir": { 2930 | "version": "1.0.1", 2931 | "resolved": "https://registry.npmjs.org/resolve-dir/-/resolve-dir-1.0.1.tgz", 2932 | "integrity": "sha1-eaQGRMNivoLybv/nOcm7U4IEb0M=", 2933 | "requires": { 2934 | "expand-tilde": "^2.0.0", 2935 | "global-modules": "^1.0.0" 2936 | } 2937 | }, 2938 | "rimraf": { 2939 | "version": "3.0.2", 2940 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2941 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2942 | "requires": { 2943 | "glob": "^7.1.3" 2944 | } 2945 | }, 2946 | "safe-buffer": { 2947 | "version": "5.2.1", 2948 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 2949 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 2950 | }, 2951 | "safe-json-parse": { 2952 | "version": "1.0.1", 2953 | "resolved": "https://registry.npmjs.org/safe-json-parse/-/safe-json-parse-1.0.1.tgz", 2954 | "integrity": "sha1-PnZyPjjf3aE8mx0poeB//uSzC1c=" 2955 | }, 2956 | "safer-buffer": { 2957 | "version": "2.1.2", 2958 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2959 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 2960 | }, 2961 | "semver": { 2962 | "version": "4.3.6", 2963 | "resolved": "https://registry.npmjs.org/semver/-/semver-4.3.6.tgz", 2964 | "integrity": "sha1-MAvG4OhjdPe6YQaLWx7NV/xlMto=" 2965 | }, 2966 | "shelljs": { 2967 | "version": "0.3.0", 2968 | "resolved": "https://registry.npmjs.org/shelljs/-/shelljs-0.3.0.tgz", 2969 | "integrity": "sha1-NZbmMHp4FUT1kfN9phg2DzHbV7E=" 2970 | }, 2971 | "side-channel": { 2972 | "version": "1.0.4", 2973 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 2974 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 2975 | "requires": { 2976 | "call-bind": "^1.0.0", 2977 | "get-intrinsic": "^1.0.2", 2978 | "object-inspect": "^1.9.0" 2979 | } 2980 | }, 2981 | "sigmund": { 2982 | "version": "1.0.1", 2983 | "resolved": "https://registry.npmjs.org/sigmund/-/sigmund-1.0.1.tgz", 2984 | "integrity": "sha1-P/IfGYytIXX587eBhT/ZTQ0ZtZA=" 2985 | }, 2986 | "sprintf-js": { 2987 | "version": "1.0.3", 2988 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2989 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=" 2990 | }, 2991 | "string_decoder": { 2992 | "version": "0.10.31", 2993 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 2994 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=" 2995 | }, 2996 | "string-template": { 2997 | "version": "0.2.1", 2998 | "resolved": "https://registry.npmjs.org/string-template/-/string-template-0.2.1.tgz", 2999 | "integrity": "sha1-QpMuWYo1LQH8IuwzZ9nYTuxsmt0=" 3000 | }, 3001 | "strip-json-comments": { 3002 | "version": "1.0.4", 3003 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-1.0.4.tgz", 3004 | "integrity": "sha1-HhX7ysl9Pumb8tc7TGVrCCu6+5E=" 3005 | }, 3006 | "supports-color": { 3007 | "version": "7.2.0", 3008 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 3009 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 3010 | "requires": { 3011 | "has-flag": "^4.0.0" 3012 | } 3013 | }, 3014 | "tiny-lr": { 3015 | "version": "1.1.1", 3016 | "resolved": "https://registry.npmjs.org/tiny-lr/-/tiny-lr-1.1.1.tgz", 3017 | "integrity": "sha512-44yhA3tsaRoMOjQQ+5v5mVdqef+kH6Qze9jTpqtVufgYjYt08zyZAwNwwVBj3i1rJMnR52IxOW0LK0vBzgAkuA==", 3018 | "requires": { 3019 | "body": "^5.1.0", 3020 | "debug": "^3.1.0", 3021 | "faye-websocket": "~0.10.0", 3022 | "livereload-js": "^2.3.0", 3023 | "object-assign": "^4.1.0", 3024 | "qs": "^6.4.0" 3025 | } 3026 | }, 3027 | "to-regex-range": { 3028 | "version": "5.0.1", 3029 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3030 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3031 | "requires": { 3032 | "is-number": "^7.0.0" 3033 | } 3034 | }, 3035 | "unc-path-regex": { 3036 | "version": "0.1.2", 3037 | "resolved": "https://registry.npmjs.org/unc-path-regex/-/unc-path-regex-0.1.2.tgz", 3038 | "integrity": "sha1-5z3T17DXxe2G+6xrCufYxqadUPo=" 3039 | }, 3040 | "underscore.string": { 3041 | "version": "3.3.5", 3042 | "resolved": "https://registry.npmjs.org/underscore.string/-/underscore.string-3.3.5.tgz", 3043 | "integrity": "sha512-g+dpmgn+XBneLmXXo+sGlW5xQEt4ErkS3mgeN2GFbremYeMBSJKr9Wf2KJplQVaiPY/f7FN6atosWYNm9ovrYg==", 3044 | "requires": { 3045 | "sprintf-js": "^1.0.3", 3046 | "util-deprecate": "^1.0.2" 3047 | } 3048 | }, 3049 | "util-deprecate": { 3050 | "version": "1.0.2", 3051 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3052 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 3053 | }, 3054 | "v8flags": { 3055 | "version": "3.2.0", 3056 | "resolved": "https://registry.npmjs.org/v8flags/-/v8flags-3.2.0.tgz", 3057 | "integrity": "sha512-mH8etigqMfiGWdeXpaaqGfs6BndypxusHHcv2qSHyZkGEznCd/qAXCWWRzeowtL54147cktFOC4P5y+kl8d8Jg==", 3058 | "requires": { 3059 | "homedir-polyfill": "^1.0.1" 3060 | } 3061 | }, 3062 | "websocket-driver": { 3063 | "version": "0.7.4", 3064 | "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.4.tgz", 3065 | "integrity": "sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg==", 3066 | "requires": { 3067 | "http-parser-js": ">=0.5.1", 3068 | "safe-buffer": ">=5.1.0", 3069 | "websocket-extensions": ">=0.1.1" 3070 | } 3071 | }, 3072 | "websocket-extensions": { 3073 | "version": "0.1.4", 3074 | "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.4.tgz", 3075 | "integrity": "sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg==" 3076 | }, 3077 | "which": { 3078 | "version": "2.0.2", 3079 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3080 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3081 | "requires": { 3082 | "isexe": "^2.0.0" 3083 | } 3084 | }, 3085 | "wrappy": { 3086 | "version": "1.0.2", 3087 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3088 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 3089 | }, 3090 | "yallist": { 3091 | "version": "2.1.2", 3092 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 3093 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" 3094 | } 3095 | } 3096 | } 3097 | --------------------------------------------------------------------------------