cdk-lambda-subminute 2.0.545 → 2.0.547

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/.jsii CHANGED
@@ -3889,7 +3889,7 @@
3889
3889
  "stability": "stable"
3890
3890
  },
3891
3891
  "homepage": "https://github.com/HsiehShuJeng/cdk-lambda-subminute.git",
3892
- "jsiiVersion": "5.4.43 (build 160ec70)",
3892
+ "jsiiVersion": "5.4.44 (build 419233e)",
3893
3893
  "keywords": [
3894
3894
  "aws-cloudwatch-events",
3895
3895
  "aws-lambda",
@@ -4359,6 +4359,6 @@
4359
4359
  "symbolId": "src/cdk-lambda-subminute:SubminuteStateMachineProps"
4360
4360
  }
4361
4361
  },
4362
- "version": "2.0.545",
4363
- "fingerprint": "rkbae0jSKM2gozPANTjkn78Qgdvss8vn176j/9ry4OE="
4362
+ "version": "2.0.547",
4363
+ "fingerprint": "Lsq5TGOePwA7ayQntYK/fmr3JcQIFmm+EEV9Os9EAA0="
4364
4364
  }
@@ -45,7 +45,7 @@ class LambdaSubminute extends constructs_1.Construct {
45
45
  }
46
46
  exports.LambdaSubminute = LambdaSubminute;
47
47
  _a = JSII_RTTI_SYMBOL_1;
48
- LambdaSubminute[_a] = { fqn: "cdk-lambda-subminute.LambdaSubminute", version: "2.0.545" };
48
+ LambdaSubminute[_a] = { fqn: "cdk-lambda-subminute.LambdaSubminute", version: "2.0.547" };
49
49
  class IteratorLambda extends constructs_1.Construct {
50
50
  constructor(scope, name, props) {
51
51
  super(scope, name);
@@ -85,7 +85,7 @@ class IteratorLambda extends constructs_1.Construct {
85
85
  }
86
86
  exports.IteratorLambda = IteratorLambda;
87
87
  _b = JSII_RTTI_SYMBOL_1;
88
- IteratorLambda[_b] = { fqn: "cdk-lambda-subminute.IteratorLambda", version: "2.0.545" };
88
+ IteratorLambda[_b] = { fqn: "cdk-lambda-subminute.IteratorLambda", version: "2.0.547" };
89
89
  class SubminuteStateMachine extends constructs_1.Construct {
90
90
  constructor(scope, id, props) {
91
91
  super(scope, id);
@@ -160,5 +160,5 @@ class SubminuteStateMachine extends constructs_1.Construct {
160
160
  }
161
161
  exports.SubminuteStateMachine = SubminuteStateMachine;
162
162
  _c = JSII_RTTI_SYMBOL_1;
163
- SubminuteStateMachine[_c] = { fqn: "cdk-lambda-subminute.SubminuteStateMachine", version: "2.0.545" };
163
+ SubminuteStateMachine[_c] = { fqn: "cdk-lambda-subminute.SubminuteStateMachine", version: "2.0.547" };
164
164
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-lambda-subminute.js","sourceRoot":"","sources":["../src/cdk-lambda-subminute.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport events = require('aws-cdk-lib/aws-events');\nimport targets = require('aws-cdk-lib/aws-events-targets');\nimport * as iam from 'aws-cdk-lib/aws-iam';\n\nimport { IFunction, Runtime, Tracing } from 'aws-cdk-lib/aws-lambda';\nimport { NodejsFunction } from 'aws-cdk-lib/aws-lambda-nodejs';\nimport { RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport * as sfn from 'aws-cdk-lib/aws-stepfunctions';\nimport * as tasks from 'aws-cdk-lib/aws-stepfunctions-tasks';\nimport { Construct } from 'constructs';\n\nexport interface LambdaSubminuteProps {\n  /**\n   * The Lambda function that is going to be executed per time unit less than one minute.\n   */\n  readonly targetFunction: IFunction;\n  /**\n   * A pattern you want this statemachine to be executed.\n   * @see https://docs.aws.amazon.com/AmazonCloudWatch/latest/events/ScheduledEvents.html\n   *\n   * @default cron(50/1 15-17 ? * * *) UTC+0 being run every minute starting from 15:00 PM to 17:00 PM.\n   */\n  readonly cronjobExpression?: string;\n  /**\n   * How many times you intent to execute in a minute.\n   *\n   * @default 6\n   */\n  readonly frequency?: number;\n  /**\n   * Seconds for an interval, the product of `frequency` and `intervalTime` should be approximagely 1 minute.\n   *\n   * @default 10\n   */\n  readonly intervalTime?: number;\n}\n\nexport class LambdaSubminute extends Construct {\n  /**\n   * The Lambda function that plays the role of the iterator.\n   */\n  readonly iteratorFunction: IFunction;\n  /**\n   * The ARN of the state machine that executes the target Lambda function per time unit less than one minute.\n   */\n  readonly stateMachineArn: string;\n  constructor(parent: Construct, name: string, props: LambdaSubminuteProps) {\n    super(parent, name);\n    const iterator = new IteratorLambda(this, 'IteratorLambda', { targetFunction: props.targetFunction });\n    this.iteratorFunction = iterator.function;\n    const subminuteStateMachine = new SubminuteStateMachine(this, 'SubminuteStateMachine', {\n      stateMachineName: 'lambda-subminute-statemachine',\n      targetFunction: props.targetFunction,\n      iteratorFunction: this.iteratorFunction,\n      intervalTime: props.intervalTime ?? 10,\n      frequency: props.frequency ?? 6,\n    });\n    this.stateMachineArn = subminuteStateMachine.stateMachine.stateMachineArn;\n\n    const startRule = new events.Rule(this, 'StartSubminuteStateMachine', {\n      schedule: events.Schedule.expression(props.cronjobExpression ?? 'cron(50/1 15-17 ? * * *)'),\n      ruleName: 'subminute-statemachine-lambda-rule',\n      description: `A rule to run the subminute state machine, i.e. ${subminuteStateMachine.stateMachine.stateMachineName}`,\n    });\n    startRule.addTarget(new targets.SfnStateMachine(\n      subminuteStateMachine.stateMachine, {\n        input: events.RuleTargetInput.fromObject({\n          iterator: {\n            index: 0,\n            count: 6,\n          },\n        }),\n      }));\n  }\n}\n\nexport interface IteratorLambdaProps {\n  /**\n     * The Lambda function that is going to be executed per time unit less than one minute.\n     */\n  readonly targetFunction: IFunction;\n}\n\nexport class IteratorLambda extends Construct {\n  /**\n     * A Lambda function that plays the role of the iterator.\n     */\n  readonly function: IFunction;\n  constructor(scope: Construct, name: string, props: IteratorLambdaProps) {\n    super(scope, name);\n    const iteratorLambdaRole = new iam.Role(this, 'IteratorLambdaRole', {\n      assumedBy: new iam.CompositePrincipal(\n        new iam.ServicePrincipal('lambda.amazonaws.com'),\n      ),\n      description: 'An execution role for a Lambda function to invoke a target Lambda Function per time unit less than one minute',\n      managedPolicies: [\n        iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaBasicExecutionRole'),\n        iam.ManagedPolicy.fromAwsManagedPolicyName('AWSXRayDaemonWriteAccess'),\n        iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaVPCAccessExecutionRole'),\n      ],\n      roleName: 'Lambda-Iterator-Role',\n    });\n    cdk.DockerVolumeConsistency.CONSISTENT;\n\n\n    iteratorLambdaRole.addToPolicy(new iam.PolicyStatement({\n      sid: 'TargetLambdaPermission',\n      effect: iam.Effect.ALLOW,\n      actions: ['lambda:InvokeFunction'],\n      resources: [props.targetFunction.functionArn],\n    }));\n\n    this.function = new NodejsFunction(this, 'Iterator', {\n      functionName: 'lambda-subminute-iterator',\n      description: 'A function for breaking the limit of 1 minute with the CloudWatch Rules.',\n      logRetention: RetentionDays.THREE_MONTHS,\n      runtime: Runtime.NODEJS_18_X,\n      entry: fs.existsSync(path.join(__dirname, 'resources/iterator/iterator_agent.ts')) ? path.join(__dirname, 'resources/iterator/iterator_agent.ts') : path.join(__dirname, 'resources/iterator/iterator_agent.js'),\n      handler: 'lambdaHandler',\n      environment: {\n        TARGET_FN_NAME: props.targetFunction.functionName,\n      },\n      memorySize: 128,\n      role: iteratorLambdaRole,\n      timeout: cdk.Duration.seconds(58), // 1 min\n      tracing: Tracing.ACTIVE,\n    });\n  }\n}\n\nexport interface SubminuteStateMachineProps {\n  /**\n   * the name of the state machine.\n   */\n  readonly stateMachineName: string;\n  /**\n   * the Lambda function that executes your intention.\n   */\n  readonly targetFunction: IFunction;\n  /**\n   * the iterator Lambda function for the target Lambda function.\n   */\n  readonly iteratorFunction: IFunction;\n  /**\n   * Seconds for an interval, the product of `frequency` and `intervalTime` should be approximagely 1 minute.\n   *\n   * @default 10\n   */\n  readonly intervalTime: number;\n  /**\n   * How many times you intent to execute in a minute.\n   *\n   * @default 6\n   */\n  readonly frequency: number;\n}\n\nexport class SubminuteStateMachine extends Construct {\n  readonly stateMachine: sfn.StateMachine;\n  constructor(scope: Construct, id: string, props: SubminuteStateMachineProps) {\n    super(scope, id);\n    const stateMachineRole = this._createWorkFlowRole(\n      props.targetFunction.functionArn, props.iteratorFunction.functionArn);\n    const jobDefinition = this.createJobDefinition(props.iteratorFunction, props.intervalTime, props.frequency);\n    const stateMachine = new sfn.StateMachine(this, 'StateMachine', {\n      stateMachineName: props.stateMachineName,\n      definition: jobDefinition,\n      role: stateMachineRole,\n    });\n    this.stateMachine = stateMachine;\n  }\n\n  /**\n   * Creates a state machine for breaking the limit of 1 minute with the CloudWatch Rules.\n   *\n   * @param iteratorFunction The iterator Lambda function for the target Labmda funciton.\n   * @param intervalTime Seconds for an interval, the product of `frequency` and `intervalTime` should be approximagely 1 minute.\n   * @param frequency How many times you intent to execute in a minute.\n   * @returns THe job definition for the state machine.\n   */\n  private createJobDefinition = (\n    iteratorFunction: IFunction, intervalTime: number, frequency: number): sfn.Chain => {\n    const configureCount = new sfn.Pass(this, 'ConfigureCount', {\n      result: sfn.Result.fromObject({\n        index: 0,\n        count: frequency,\n      }),\n      resultPath: '$.iterator',\n    });\n    const iterator = new tasks.LambdaInvoke(this, 'Iterator', {\n      lambdaFunction: iteratorFunction,\n      resultPath: '$.iterator',\n      resultSelector: {\n        'index.$': '$.Payload.index',\n        'count.$': '$.Payload.count',\n        'continue.$': '$.Payload.continue',\n      },\n    });\n    const wait = new sfn.Wait(this, 'Wait for the target Lambda function finished', {\n      time: sfn.WaitTime.duration(cdk.Duration.seconds(intervalTime)),\n    });\n    wait.next(iterator);\n    const done = new sfn.Pass(this, 'Done');\n\n    const isCountReached = new sfn.Choice(this, 'IsCountReached');\n    isCountReached.when(sfn.Condition.booleanEquals('$.iterator.continue', true), wait);\n    isCountReached.otherwise(done);\n    const jobDefinition = configureCount.next(iterator).next(isCountReached);\n    return jobDefinition;\n  };\n\n  /**\n   * Creates a role and corresponding policies for the subminute state machine.\n   *\n   * @param targetFunctionArn the ARN of the Lambda function that executes your intention.\n   * @param iteratorFunctionArn the ARN of the iterator Lambda function for the target Lambda function.\n   * @returns the role as the documentation indicates.\n   */\n  private _createWorkFlowRole = (targetFunctionArn: string, iteratorFunctionArn: string) => {\n    const workFlowExecutionRole = new iam.Role(this, 'StepFunctionExecutionRole', {\n      assumedBy: new iam.ServicePrincipal('states.amazonaws.com'),\n      description: 'Execute a workflow related to executing a Lambda function per time unit less than 1 minute.',\n    });\n    workFlowExecutionRole.addToPolicy(new iam.PolicyStatement({\n      sid: 'LambdaInvokePermissions',\n      effect: iam.Effect.ALLOW,\n      actions: ['lambda:InvokeFunction'],\n      resources: [\n        targetFunctionArn,\n        iteratorFunctionArn,\n      ],\n    }));\n    return workFlowExecutionRole;\n  };\n}"]}
@@ -5,6 +5,20 @@ All notable changes to this project will be documented in this file.
5
5
  The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/)
6
6
  and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
7
7
 
8
+ ## [v1.1.0](https://github.com/inspect-js/has-proto/compare/v1.0.3...v1.1.0) - 2024-12-01
9
+
10
+ ### Commits
11
+
12
+ - [New] add `accessor` and `mutator` endpoints [`144f6a9`](https://github.com/inspect-js/has-proto/commit/144f6a9c2a3925f25058d5d5ea7eab3be57767d9)
13
+ - [types] use shared config [`8b597cf`](https://github.com/inspect-js/has-proto/commit/8b597cff2b09f0351bc357cac0e0c7b0c8bb7e70)
14
+ - [Refactor] cache result at module level [`88418bd`](https://github.com/inspect-js/has-proto/commit/88418bde7e0c37c7d9aa6cc79150e774004c01d8)
15
+ - [Dev Deps] update `@ljharb/eslint-config`, `auto-changelog`, `tape` [`d246200`](https://github.com/inspect-js/has-proto/commit/d246200bae6ceceebb495df7f8eb0f27a017b63f)
16
+ - [Deps] update `gopd`, `reflect.getprototypeof` [`6f72364`](https://github.com/inspect-js/has-proto/commit/6f723645da9b5bef0aaae4a1aa66c07a1fed179f)
17
+ - [Tests] add `@arethetypeswrong/cli` [`8194e1a`](https://github.com/inspect-js/has-proto/commit/8194e1a607233f63c5bd0b91112c0423b3296ac9)
18
+ - [Tests] replace `aud` with `npm audit` [`fd7ad11`](https://github.com/inspect-js/has-proto/commit/fd7ad111dc35488b3200a763204dba0f6087defc)
19
+ - [Dev Deps] update `@types/tape` [`2695808`](https://github.com/inspect-js/has-proto/commit/26958086aec0b1cbfdddd4f10e54d2de1facf85c)
20
+ - [Dev Deps] add missing peer dep [`fa4b2f7`](https://github.com/inspect-js/has-proto/commit/fa4b2f77f7c0071e1c06b5590c9bada8e6b2edce)
21
+
8
22
  ## [v1.0.3](https://github.com/inspect-js/has-proto/compare/v1.0.2...v1.0.3) - 2024-02-19
9
23
 
10
24
  ### Commits
@@ -16,6 +16,25 @@ var hasProto = require('has-proto');
16
16
  var assert = require('assert');
17
17
 
18
18
  assert.equal(typeof hasProto(), 'boolean');
19
+
20
+ var hasProtoAccessor = require('has-proto/accessor')();
21
+ if (hasProtoAccessor) {
22
+ assert.equal([].__proto__, Array.prototype);
23
+ } else {
24
+ assert(!('__proto__' in Object.prototype));
25
+ }
26
+
27
+ var hasProtoMutator = require('has-proto/mutator');
28
+ var obj = {};
29
+ assert('toString' in obj);
30
+
31
+ obj.__proto__ = null;
32
+ if (hasProtoMutator) {
33
+ assert(!('toString' in obj));
34
+ } else {
35
+ assert('toString' in obj);
36
+ assert.equal(obj.__proto__, null);
37
+ }
19
38
  ```
20
39
 
21
40
  ## Tests
@@ -0,0 +1,3 @@
1
+ declare function accessor(): boolean;
2
+
3
+ export = accessor;
@@ -0,0 +1,20 @@
1
+ 'use strict';
2
+
3
+ var result = require('./')();
4
+
5
+ var test = {
6
+ __proto__: null,
7
+ foo: {}
8
+ };
9
+
10
+ /** @type {import('./accessor')} */
11
+ module.exports = function hasAccessor() {
12
+ /* eslint no-proto: 0 */
13
+ return result
14
+ && !('toString' in test)
15
+ // eslint-disable-next-line no-extra-parens
16
+ && /** @type {{ __proto__?: typeof Object.prototype }} */ ({}).__proto__ === Object.prototype
17
+ // eslint-disable-next-line no-extra-parens
18
+ && /** @type {ReadonlyArray<never> & { __proto__?: typeof Array.prototype }} */ (
19
+ []).__proto__ === Array.prototype;
20
+ };
@@ -0,0 +1,12 @@
1
+ 'use strict';
2
+
3
+ var callBind = require('call-bind');
4
+ var gOPD = require('gopd');
5
+
6
+ // eslint-disable-next-line no-extra-parens, no-proto
7
+ var hasProto = /** @type {{ __proto__?: typeof Array.prototype }} */ ([]).__proto__ === Array.prototype;
8
+
9
+ // eslint-disable-next-line no-extra-parens
10
+ var dunderGetter = hasProto && gOPD && gOPD(Object.prototype, /** @type {keyof typeof Object.prototype} */ ('__proto__'));
11
+
12
+ module.exports = dunderGetter && dunderGetter.get && callBind(dunderGetter.get);
@@ -0,0 +1,9 @@
1
+ 'use strict';
2
+
3
+ var callBind = require('call-bind');
4
+ var gOPD = require('gopd');
5
+
6
+ // @ts-expect-error TS can't handle dunder proto
7
+ var desc = gOPD && gOPD(Object.prototype, '__proto__');
8
+
9
+ module.exports = !!desc && !!desc.set && callBind(desc.set);
@@ -1,3 +1,3 @@
1
1
  declare function hasProto(): boolean;
2
2
 
3
- export = hasProto;
3
+ export = hasProto;
@@ -5,11 +5,11 @@ var test = {
5
5
  foo: {}
6
6
  };
7
7
 
8
- var $Object = Object;
8
+ // @ts-expect-error: TS errors on an inherited property for some reason
9
+ var result = { __proto__: test }.foo === test.foo
10
+ && !(test instanceof Object);
9
11
 
10
12
  /** @type {import('.')} */
11
13
  module.exports = function hasProto() {
12
- // @ts-expect-error: TS errors on an inherited property for some reason
13
- return { __proto__: test }.foo === test.foo
14
- && !(test instanceof $Object);
14
+ return result;
15
15
  };
@@ -0,0 +1,3 @@
1
+ declare function mutator(): boolean;
2
+
3
+ export = mutator;
@@ -0,0 +1,33 @@
1
+ 'use strict';
2
+
3
+ var result = require('./')();
4
+
5
+ var test = {
6
+ __proto__: null,
7
+ foo: {}
8
+ };
9
+
10
+ var setter = require('./helpers/setDunder');
11
+
12
+ /** @type {import('./mutator')} */
13
+ module.exports = function hasMutator() {
14
+ if (!result) {
15
+ return false;
16
+ }
17
+
18
+ var obj = { __proto__: test };
19
+ // @ts-expect-error: TS errors on an inherited property for some reason
20
+ if (obj.foo !== test.foo) {
21
+ return false;
22
+ }
23
+
24
+ if (!setter) {
25
+ return false;
26
+ }
27
+
28
+ setter(obj, null);
29
+ if ('foo' in obj || 'toString' in obj) {
30
+ return false;
31
+ }
32
+ return true;
33
+ };
@@ -1,10 +1,12 @@
1
1
  {
2
2
  "name": "has-proto",
3
- "version": "1.0.3",
3
+ "version": "1.1.0",
4
4
  "description": "Does this environment have the ability to get the [[Prototype]] of an object on creation with `__proto__`?",
5
5
  "main": "index.js",
6
6
  "exports": {
7
7
  ".": "./index.js",
8
+ "./accessor": "./accessor.js",
9
+ "./mutator": "./mutator.js",
8
10
  "./package.json": "./package.json"
9
11
  },
10
12
  "sideEffects": false,
@@ -12,12 +14,13 @@
12
14
  "prepack": "npmignore --auto --commentLines=autogenerated",
13
15
  "prepublishOnly": "safe-publish-latest",
14
16
  "prepublish": "not-in-publish || npm run prepublishOnly",
17
+ "prelint": "evalmd README.md",
15
18
  "lint": "eslint --ext=js,mjs .",
16
- "postlint": "tsc -p .",
19
+ "postlint": "tsc -p . && attw -P",
17
20
  "pretest": "npm run lint",
18
21
  "tests-only": "tape 'test/**/*.js'",
19
22
  "test": "npm run tests-only",
20
- "posttest": "aud --production",
23
+ "posttest": "npx npm@'>=10.2' audit --production",
21
24
  "version": "auto-changelog && git add CHANGELOG.md",
22
25
  "postversion": "auto-changelog && git add CHANGELOG.md && git commit --no-edit --amend && git tag -f \"v$(node -e \"console.log(require('./package.json').version)\")\""
23
26
  },
@@ -48,15 +51,22 @@
48
51
  "files": "test/index.js"
49
52
  },
50
53
  "devDependencies": {
51
- "@ljharb/eslint-config": "^21.1.0",
52
- "@types/tape": "^5.6.4",
53
- "aud": "^2.0.4",
54
- "auto-changelog": "^2.4.0",
54
+ "@arethetypeswrong/cli": "^0.17.0",
55
+ "@ljharb/eslint-config": "^21.1.1",
56
+ "@ljharb/tsconfig": "^0.2.0",
57
+ "@types/call-bind": "^1.0.5",
58
+ "@types/gopd": "^1.0.3",
59
+ "@types/tape": "^5.6.5",
60
+ "auto-changelog": "^2.5.0",
61
+ "encoding": "^0.1.13",
55
62
  "eslint": "=8.8.0",
63
+ "evalmd": "^0.0.19",
64
+ "gopd": "^1.1.0",
56
65
  "in-publish": "^2.0.1",
57
66
  "npmignore": "^0.3.1",
67
+ "reflect.getprototypeof": "^1.0.7",
58
68
  "safe-publish-latest": "^2.0.0",
59
- "tape": "^5.7.5",
69
+ "tape": "^5.9.0",
60
70
  "typescript": "next"
61
71
  },
62
72
  "engines": {
@@ -72,7 +82,11 @@
72
82
  },
73
83
  "publishConfig": {
74
84
  "ignore": [
75
- ".github/workflows"
85
+ ".github/workflows",
86
+ "types"
76
87
  ]
88
+ },
89
+ "dependencies": {
90
+ "call-bind": "^1.0.7"
77
91
  }
78
92
  }
@@ -0,0 +1,34 @@
1
+ 'use strict';
2
+
3
+ var test = require('tape');
4
+ var gPO = require('reflect.getprototypeof/polyfill')();
5
+ var gOPD = require('gopd');
6
+
7
+ var hasProto = require('../');
8
+ var hasProtoAccessor = require('../accessor');
9
+
10
+ var getter = require('../helpers/getDunder');
11
+
12
+ test('hasProtoAccessor', function (t) {
13
+ var result = hasProtoAccessor();
14
+ t.equal(typeof result, 'boolean', 'returns a boolean (' + result + ')');
15
+
16
+ var obj = { __proto__: null };
17
+ if (result) {
18
+ t.notOk('toString' in obj, 'null object lacks toString');
19
+ t.equal(gPO(obj), null);
20
+ if (gOPD && getter) {
21
+ t.equal(getter(obj), null);
22
+ }
23
+ } else if (hasProto()) {
24
+ t.notOk('toString' in obj, 'null object lacks toString');
25
+ if (gOPD && getter) {
26
+ t.equal(getter(obj), null);
27
+ }
28
+ } else {
29
+ t.ok('toString' in obj, 'without proto, null object has toString');
30
+ t.equal(gPO(obj), Object.prototype);
31
+ }
32
+
33
+ t.end();
34
+ });
@@ -1,8 +1,13 @@
1
1
  'use strict';
2
2
 
3
3
  var test = require('tape');
4
+ var gPO = require('reflect.getprototypeof/polyfill')();
5
+ var gOPD = require('gopd');
6
+
4
7
  var hasProto = require('../');
5
8
 
9
+ var getter = require('../helpers/getDunder');
10
+
6
11
  test('hasProto', function (t) {
7
12
  var result = hasProto();
8
13
  t.equal(typeof result, 'boolean', 'returns a boolean (' + result + ')');
@@ -10,10 +15,14 @@ test('hasProto', function (t) {
10
15
  var obj = { __proto__: null };
11
16
  if (result) {
12
17
  t.notOk('toString' in obj, 'null object lacks toString');
18
+ if (gOPD && getter) {
19
+ t.equal(getter(obj), null);
20
+ }
13
21
  } else {
14
22
  t.ok('toString' in obj, 'without proto, null object has toString');
15
- t.equal(obj.__proto__, null); // eslint-disable-line no-proto
23
+ t.equal(gPO(obj), Object.prototype);
16
24
  }
17
25
 
18
26
  t.end();
19
27
  });
28
+
@@ -0,0 +1,34 @@
1
+ 'use strict';
2
+
3
+ var test = require('tape');
4
+ var gPO = require('reflect.getprototypeof/polyfill')();
5
+ var gOPD = require('gopd');
6
+
7
+ var hasProto = require('../');
8
+ var hasProtoMutator = require('../mutator');
9
+
10
+ var getter = require('../helpers/getDunder');
11
+
12
+ test('hasProtoMutator', function (t) {
13
+ var result = hasProtoMutator();
14
+ t.equal(typeof result, 'boolean', 'returns a boolean (' + result + ')');
15
+
16
+ var obj = { __proto__: null };
17
+ if (result) {
18
+ t.notOk('toString' in obj, 'null object lacks toString');
19
+ t.equal(gPO(obj), null);
20
+ if (gOPD && getter) {
21
+ t.equal(getter(obj), null);
22
+ }
23
+ } else if (hasProto()) {
24
+ t.notOk('toString' in obj, 'null object lacks toString');
25
+ if (gOPD && getter) {
26
+ t.equal(getter(obj), null);
27
+ }
28
+ } else {
29
+ t.ok('toString' in obj, 'without proto, null object has toString');
30
+ t.equal(gPO(obj), Object.prototype);
31
+ }
32
+
33
+ t.end();
34
+ });
@@ -1,49 +1,11 @@
1
1
  {
2
- "compilerOptions": {
3
- /* Visit https://aka.ms/tsconfig to read more about this file */
4
-
5
- /* Projects */
6
-
7
- /* Language and Environment */
8
- "target": "ESNext", /* Set the JavaScript language version for emitted JavaScript and include compatible library declarations. */
9
- // "lib": [], /* Specify a set of bundled library declaration files that describe the target runtime environment. */
10
- // "noLib": true, /* Disable including any library files, including the default lib.d.ts. */
11
- "useDefineForClassFields": true, /* Emit ECMAScript-standard-compliant class fields. */
12
- // "moduleDetection": "auto", /* Control what method is used to detect module-format JS files. */
13
-
14
- /* Modules */
15
- "module": "commonjs", /* Specify what module code is generated. */
16
- // "rootDir": "./", /* Specify the root folder within your source files. */
17
- // "moduleResolution": "node10", /* Specify how TypeScript looks up a file from a given module specifier. */
18
- // "baseUrl": "./", /* Specify the base directory to resolve non-relative module names. */
19
- // "paths": {}, /* Specify a set of entries that re-map imports to additional lookup locations. */
20
- // "rootDirs": [], /* Allow multiple folders to be treated as one when resolving modules. */
21
- "typeRoots": ["types"], /* Specify multiple folders that act like './node_modules/@types'. */
22
- "resolveJsonModule": true, /* Enable importing .json files. */
23
- // "allowArbitraryExtensions": true, /* Enable importing files with any extension, provided a declaration file is present. */
24
-
25
- /* JavaScript Support */
26
- "allowJs": true, /* Allow JavaScript files to be a part of your program. Use the 'checkJS' option to get errors from these files. */
27
- "checkJs": true, /* Enable error reporting in type-checked JavaScript files. */
28
- "maxNodeModuleJsDepth": 0, /* Specify the maximum folder depth used for checking JavaScript files from 'node_modules'. Only applicable with 'allowJs'. */
29
-
30
- /* Emit */
31
- "declaration": true, /* Generate .d.ts files from TypeScript and JavaScript files in your project. */
32
- "declarationMap": true, /* Create sourcemaps for d.ts files. */
33
- "noEmit": true, /* Disable emitting files from a compilation. */
34
-
35
- /* Interop Constraints */
36
- "allowSyntheticDefaultImports": true, /* Allow 'import x from y' when a module doesn't have a default export. */
37
- "esModuleInterop": true, /* Emit additional JavaScript to ease support for importing CommonJS modules. This enables 'allowSyntheticDefaultImports' for type compatibility. */
38
- "forceConsistentCasingInFileNames": true, /* Ensure that casing is correct in imports. */
39
-
40
- /* Type Checking */
41
- "strict": true, /* Enable all strict type-checking options. */
42
-
43
- /* Completeness */
44
- //"skipLibCheck": true /* Skip type checking all .d.ts files. */
45
- },
46
- "exclude": [
47
- "coverage"
48
- ]
2
+ "extends": "@ljharb/tsconfig",
3
+ "exclude": [
4
+ "coverage",
5
+ ],
6
+ "compilerOptions": {
7
+ "typeRoots": [
8
+ "types",
9
+ ],
10
+ },
49
11
  }
@@ -5,6 +5,22 @@ All notable changes to this project will be documented in this file.
5
5
  The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/)
6
6
  and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
7
7
 
8
+ ## [v1.1.0](https://github.com/inspect-js/has-symbols/compare/v1.0.3...v1.1.0) - 2024-12-02
9
+
10
+ ### Commits
11
+
12
+ - [actions] update workflows [`548c0bf`](https://github.com/inspect-js/has-symbols/commit/548c0bf8c9b1235458df7a1c0490b0064647a282)
13
+ - [actions] further shard; update action deps [`bec56bb`](https://github.com/inspect-js/has-symbols/commit/bec56bb0fb44b43a786686b944875a3175cf3ff3)
14
+ - [meta] use `npmignore` to autogenerate an npmignore file [`ac81032`](https://github.com/inspect-js/has-symbols/commit/ac81032809157e0a079e5264e9ce9b6f1275777e)
15
+ - [New] add types [`6469cbf`](https://github.com/inspect-js/has-symbols/commit/6469cbff1866cfe367b2b3d181d9296ec14b2a3d)
16
+ - [actions] update rebase action to use reusable workflow [`9c9d4d0`](https://github.com/inspect-js/has-symbols/commit/9c9d4d0d8938e4b267acdf8e421f4e92d1716d72)
17
+ - [Dev Deps] update `eslint`, `@ljharb/eslint-config`, `aud`, `tape` [`adb5887`](https://github.com/inspect-js/has-symbols/commit/adb5887ca9444849b08beb5caaa9e1d42320cdfb)
18
+ - [Dev Deps] update `@ljharb/eslint-config`, `aud`, `tape` [`13ec198`](https://github.com/inspect-js/has-symbols/commit/13ec198ec80f1993a87710af1606a1970b22c7cb)
19
+ - [Dev Deps] update `auto-changelog`, `core-js`, `tape` [`941be52`](https://github.com/inspect-js/has-symbols/commit/941be5248387cab1da72509b22acf3fdb223f057)
20
+ - [Tests] replace `aud` with `npm audit` [`74f49e9`](https://github.com/inspect-js/has-symbols/commit/74f49e9a9d17a443020784234a1c53ce765b3559)
21
+ - [Dev Deps] update `npmignore` [`9c0ac04`](https://github.com/inspect-js/has-symbols/commit/9c0ac0452a834f4c2a4b54044f2d6a89f17e9a70)
22
+ - [Dev Deps] add missing peer dep [`52337a5`](https://github.com/inspect-js/has-symbols/commit/52337a5621cced61f846f2afdab7707a8132cc12)
23
+
8
24
  ## [v1.0.3](https://github.com/inspect-js/has-symbols/compare/v1.0.2...v1.0.3) - 2022-03-01
9
25
 
10
26
  ### Commits
@@ -0,0 +1,3 @@
1
+ declare function hasNativeSymbols(): boolean;
2
+
3
+ export = hasNativeSymbols;
@@ -3,6 +3,7 @@
3
3
  var origSymbol = typeof Symbol !== 'undefined' && Symbol;
4
4
  var hasSymbolSham = require('./shams');
5
5
 
6
+ /** @type {import('.')} */
6
7
  module.exports = function hasNativeSymbols() {
7
8
  if (typeof origSymbol !== 'function') { return false; }
8
9
  if (typeof Symbol !== 'function') { return false; }
@@ -1,21 +1,23 @@
1
1
  {
2
2
  "name": "has-symbols",
3
- "version": "1.0.3",
3
+ "version": "1.1.0",
4
4
  "description": "Determine if the JS environment has Symbol support. Supports spec, or shams.",
5
5
  "main": "index.js",
6
6
  "scripts": {
7
+ "prepack": "npmignore --auto --commentLines=autogenerated",
7
8
  "prepublishOnly": "safe-publish-latest",
8
9
  "prepublish": "not-in-publish || npm run prepublishOnly",
9
10
  "pretest": "npm run --silent lint",
10
11
  "test": "npm run tests-only",
11
- "posttest": "aud --production",
12
- "tests-only": "npm run test:stock && npm run test:staging && npm run test:shams",
12
+ "posttest": "npx npm@'>=10.2' audit --production",
13
+ "tests-only": "npm run test:stock && npm run test:shams",
13
14
  "test:stock": "nyc node test",
14
15
  "test:staging": "nyc node --harmony --es-staging test",
15
16
  "test:shams": "npm run --silent test:shams:getownpropertysymbols && npm run --silent test:shams:corejs",
16
17
  "test:shams:corejs": "nyc node test/shams/core-js.js",
17
18
  "test:shams:getownpropertysymbols": "nyc node test/shams/get-own-property-symbols.js",
18
19
  "lint": "eslint --ext=js,mjs .",
20
+ "postlint": "tsc -p . && attw -P",
19
21
  "version": "auto-changelog && git add CHANGELOG.md",
20
22
  "postversion": "auto-changelog && git add CHANGELOG.md && git commit --no-edit --amend && git tag -f \"v$(node -e \"console.log(require('./package.json').version)\")\""
21
23
  },
@@ -54,15 +56,22 @@
54
56
  },
55
57
  "homepage": "https://github.com/ljharb/has-symbols#readme",
56
58
  "devDependencies": {
57
- "@ljharb/eslint-config": "^20.2.3",
58
- "aud": "^2.0.0",
59
- "auto-changelog": "^2.4.0",
59
+ "@arethetypeswrong/cli": "^0.17.0",
60
+ "@ljharb/eslint-config": "^21.1.1",
61
+ "@ljharb/tsconfig": "^0.2.0",
62
+ "@types/core-js": "^2.5.8",
63
+ "@types/tape": "^5.6.5",
64
+ "auto-changelog": "^2.5.0",
60
65
  "core-js": "^2.6.12",
66
+ "encoding": "^0.1.13",
61
67
  "eslint": "=8.8.0",
62
68
  "get-own-property-symbols": "^0.9.5",
69
+ "in-publish": "^2.0.1",
70
+ "npmignore": "^0.3.1",
63
71
  "nyc": "^10.3.2",
64
72
  "safe-publish-latest": "^2.0.0",
65
- "tape": "^5.5.2"
73
+ "tape": "^5.9.0",
74
+ "typescript": "next"
66
75
  },
67
76
  "testling": {
68
77
  "files": "test/index.js",
@@ -93,9 +102,10 @@
93
102
  "backfillLimit": false,
94
103
  "hideCredit": true
95
104
  },
96
- "greenkeeper": {
105
+ "publishConfig": {
97
106
  "ignore": [
98
- "core-js"
107
+ ".github/workflows",
108
+ "types"
99
109
  ]
100
110
  }
101
111
  }
@@ -0,0 +1,3 @@
1
+ declare function hasSymbolShams(): boolean;
2
+
3
+ export = hasSymbolShams;
@@ -1,10 +1,12 @@
1
1
  'use strict';
2
2
 
3
+ /** @type {import('./shams')} */
3
4
  /* eslint complexity: [2, 18], max-statements: [2, 33] */
4
5
  module.exports = function hasSymbols() {
5
6
  if (typeof Symbol !== 'function' || typeof Object.getOwnPropertySymbols !== 'function') { return false; }
6
7
  if (typeof Symbol.iterator === 'symbol') { return true; }
7
8
 
9
+ /** @type {{ [k in symbol]?: unknown }} */
8
10
  var obj = {};
9
11
  var sym = Symbol('test');
10
12
  var symObj = Object(sym);
@@ -23,7 +25,7 @@ module.exports = function hasSymbols() {
23
25
 
24
26
  var symVal = 42;
25
27
  obj[sym] = symVal;
26
- for (sym in obj) { return false; } // eslint-disable-line no-restricted-syntax, no-unreachable-loop
28
+ for (var _ in obj) { return false; } // eslint-disable-line no-restricted-syntax, no-unreachable-loop
27
29
  if (typeof Object.keys === 'function' && Object.keys(obj).length !== 0) { return false; }
28
30
 
29
31
  if (typeof Object.getOwnPropertyNames === 'function' && Object.getOwnPropertyNames(obj).length !== 0) { return false; }
@@ -34,7 +36,8 @@ module.exports = function hasSymbols() {
34
36
  if (!Object.prototype.propertyIsEnumerable.call(obj, sym)) { return false; }
35
37
 
36
38
  if (typeof Object.getOwnPropertyDescriptor === 'function') {
37
- var descriptor = Object.getOwnPropertyDescriptor(obj, sym);
39
+ // eslint-disable-next-line no-extra-parens
40
+ var descriptor = /** @type {PropertyDescriptor} */ (Object.getOwnPropertyDescriptor(obj, sym));
38
41
  if (descriptor.value !== symVal || descriptor.enumerable !== true) { return false; }
39
42
  }
40
43
 
@@ -8,6 +8,7 @@ if (typeof Symbol === 'function' && typeof Symbol() === 'symbol') {
8
8
  t.equal(typeof Symbol(), 'symbol');
9
9
  t.end();
10
10
  });
11
+ // @ts-expect-error TS is stupid and doesn't know about top level return
11
12
  return;
12
13
  }
13
14
 
@@ -8,6 +8,7 @@ if (typeof Symbol === 'function' && typeof Symbol() === 'symbol') {
8
8
  t.equal(typeof Symbol(), 'symbol');
9
9
  t.end();
10
10
  });
11
+ // @ts-expect-error TS is stupid and doesn't know about top level return
11
12
  return;
12
13
  }
13
14
 
@@ -1,5 +1,6 @@
1
1
  'use strict';
2
2
 
3
+ /** @type {(t: import('tape').Test) => false | void} */
3
4
  // eslint-disable-next-line consistent-return
4
5
  module.exports = function runSymbolTests(t) {
5
6
  t.equal(typeof Symbol, 'function', 'global Symbol is a function');
@@ -31,6 +32,7 @@ module.exports = function runSymbolTests(t) {
31
32
 
32
33
  t.equal(typeof Object.getOwnPropertySymbols, 'function', 'Object.getOwnPropertySymbols is a function');
33
34
 
35
+ /** @type {{ [k in symbol]?: unknown }} */
34
36
  var obj = {};
35
37
  var sym = Symbol('test');
36
38
  var symObj = Object(sym);
@@ -40,8 +42,8 @@ module.exports = function runSymbolTests(t) {
40
42
 
41
43
  var symVal = 42;
42
44
  obj[sym] = symVal;
43
- // eslint-disable-next-line no-restricted-syntax
44
- for (sym in obj) { t.fail('symbol property key was found in for..in of object'); }
45
+ // eslint-disable-next-line no-restricted-syntax, no-unused-vars
46
+ for (var _ in obj) { t.fail('symbol property key was found in for..in of object'); }
45
47
 
46
48
  t.deepEqual(Object.keys(obj), [], 'no enumerable own keys on symbol-valued object');
47
49
  t.deepEqual(Object.getOwnPropertyNames(obj), [], 'no own names on symbol-valued object');
@@ -0,0 +1,10 @@
1
+ {
2
+ "extends": "@ljharb/tsconfig",
3
+ "compilerOptions": {
4
+ "target": "ES2021",
5
+ "maxNodeModuleJsDepth": 0,
6
+ },
7
+ "exclude": [
8
+ "coverage"
9
+ ]
10
+ }
package/package.json CHANGED
@@ -57,7 +57,7 @@
57
57
  "jsii-docgen": "^10.5.0",
58
58
  "jsii-pacmak": "^1.105.0",
59
59
  "jsii-rosetta": "5.4.x",
60
- "projen": "^0.90.5",
60
+ "projen": "^0.90.6",
61
61
  "source-map-support": "^0.5.21",
62
62
  "ts-jest": "^27",
63
63
  "typescript": "^4.9.5"
@@ -91,7 +91,7 @@
91
91
  "publishConfig": {
92
92
  "access": "public"
93
93
  },
94
- "version": "2.0.545",
94
+ "version": "2.0.547",
95
95
  "jest": {
96
96
  "coverageProvider": "v8",
97
97
  "testMatch": [