@cloud-copilot/iam-simulate 0.1.0 → 0.1.2
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/dist/cjs/condition/baseConditionperatorTests.js +1 -1
- package/dist/cjs/condition/baseConditionperatorTests.js.map +1 -1
- package/dist/cjs/core_engine/coreSimulatorEngine.d.ts.map +1 -1
- package/dist/cjs/core_engine/coreSimulatorEngine.js +4 -1
- package/dist/cjs/core_engine/coreSimulatorEngine.js.map +1 -1
- package/dist/cjs/index.d.ts +4 -0
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +8 -0
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/request/request.d.ts +9 -3
- package/dist/cjs/request/request.d.ts.map +1 -1
- package/dist/cjs/request/request.js +4 -7
- package/dist/cjs/request/request.js.map +1 -1
- package/dist/cjs/request/requestResource.d.ts +7 -1
- package/dist/cjs/request/requestResource.d.ts.map +1 -1
- package/dist/cjs/request/requestResource.js +6 -1
- package/dist/cjs/request/requestResource.js.map +1 -1
- package/dist/cjs/services/DefaultServiceAuthorizer.d.ts.map +1 -1
- package/dist/cjs/services/DefaultServiceAuthorizer.js +2 -2
- package/dist/cjs/services/DefaultServiceAuthorizer.js.map +1 -1
- package/dist/cjs/simulation_engine/contextKeys.d.ts +3 -0
- package/dist/cjs/simulation_engine/contextKeys.d.ts.map +1 -0
- package/dist/cjs/simulation_engine/contextKeys.js +53 -0
- package/dist/cjs/simulation_engine/contextKeys.js.map +1 -0
- package/dist/cjs/simulation_engine/simulationEngine.d.ts +25 -0
- package/dist/cjs/simulation_engine/simulationEngine.d.ts.map +1 -0
- package/dist/cjs/simulation_engine/simulationEngine.js +38 -0
- package/dist/cjs/simulation_engine/simulationEngine.js.map +1 -0
- package/dist/esm/StatementAnalysis.d.ts +27 -0
- package/dist/esm/StatementAnalysis.d.ts.map +1 -0
- package/dist/esm/StatementAnalysis.js +2 -0
- package/dist/esm/StatementAnalysis.js.map +1 -0
- package/dist/esm/action/action.d.ts +9 -1
- package/dist/esm/action/action.d.ts.map +1 -1
- package/dist/esm/action/action.js +16 -0
- package/dist/esm/action/action.js.map +1 -1
- package/dist/esm/condition/arn/ArnEquals.d.ts +3 -0
- package/dist/esm/condition/arn/ArnEquals.d.ts.map +1 -0
- package/dist/esm/condition/arn/ArnEquals.js +8 -0
- package/dist/esm/condition/arn/ArnEquals.js.map +1 -0
- package/dist/esm/condition/arn/ArnLike.d.ts +3 -0
- package/dist/esm/condition/arn/ArnLike.d.ts.map +1 -0
- package/dist/esm/condition/arn/ArnLike.js +47 -0
- package/dist/esm/condition/arn/ArnLike.js.map +1 -0
- package/dist/esm/condition/arn/ArnNotEquals.d.ts +3 -0
- package/dist/esm/condition/arn/ArnNotEquals.d.ts.map +1 -0
- package/dist/esm/condition/arn/ArnNotEquals.js +8 -0
- package/dist/esm/condition/arn/ArnNotEquals.js.map +1 -0
- package/dist/esm/condition/arn/ArnNotLike.d.ts +3 -0
- package/dist/esm/condition/arn/ArnNotLike.d.ts.map +1 -0
- package/dist/esm/condition/arn/ArnNotLike.js +10 -0
- package/dist/esm/condition/arn/ArnNotLike.js.map +1 -0
- package/dist/esm/condition/baseConditionperatorTests.d.ts +12 -0
- package/dist/esm/condition/baseConditionperatorTests.d.ts.map +1 -0
- package/dist/esm/condition/baseConditionperatorTests.js +18 -0
- package/dist/esm/condition/baseConditionperatorTests.js.map +1 -0
- package/dist/esm/condition/binary/BinaryEquals.d.ts +7 -0
- package/dist/esm/condition/binary/BinaryEquals.d.ts.map +1 -0
- package/dist/esm/condition/binary/BinaryEquals.js +13 -0
- package/dist/esm/condition/binary/BinaryEquals.js.map +1 -0
- package/dist/esm/condition/boolean/Bool.d.ts +3 -0
- package/dist/esm/condition/boolean/Bool.d.ts.map +1 -0
- package/dist/esm/condition/boolean/Bool.js +17 -0
- package/dist/esm/condition/boolean/Bool.js.map +1 -0
- package/dist/esm/condition/condition.d.ts +1 -0
- package/dist/esm/condition/condition.d.ts.map +1 -1
- package/dist/esm/condition/condition.js +60 -11
- package/dist/esm/condition/condition.js.map +1 -1
- package/dist/esm/condition/date/DateEquals.d.ts +3 -0
- package/dist/esm/condition/date/DateEquals.d.ts.map +1 -0
- package/dist/esm/condition/date/DateEquals.js +14 -0
- package/dist/esm/condition/date/DateEquals.js.map +1 -0
- package/dist/esm/condition/date/DateGreaterThan.d.ts +3 -0
- package/dist/esm/condition/date/DateGreaterThan.d.ts.map +1 -0
- package/dist/esm/condition/date/DateGreaterThan.js +14 -0
- package/dist/esm/condition/date/DateGreaterThan.js.map +1 -0
- package/dist/esm/condition/date/DateGreaterThanEquals.d.ts +3 -0
- package/dist/esm/condition/date/DateGreaterThanEquals.d.ts.map +1 -0
- package/dist/esm/condition/date/DateGreaterThanEquals.js +14 -0
- package/dist/esm/condition/date/DateGreaterThanEquals.js.map +1 -0
- package/dist/esm/condition/date/DateLessThan.d.ts +3 -0
- package/dist/esm/condition/date/DateLessThan.d.ts.map +1 -0
- package/dist/esm/condition/date/DateLessThan.js +14 -0
- package/dist/esm/condition/date/DateLessThan.js.map +1 -0
- package/dist/esm/condition/date/DateLessThanEquals.d.ts +3 -0
- package/dist/esm/condition/date/DateLessThanEquals.d.ts.map +1 -0
- package/dist/esm/condition/date/DateLessThanEquals.js +14 -0
- package/dist/esm/condition/date/DateLessThanEquals.js.map +1 -0
- package/dist/esm/condition/date/DateNotEquals.d.ts +3 -0
- package/dist/esm/condition/date/DateNotEquals.d.ts.map +1 -0
- package/dist/esm/condition/date/DateNotEquals.js +26 -0
- package/dist/esm/condition/date/DateNotEquals.js.map +1 -0
- package/dist/esm/condition/date/date.d.ts +17 -0
- package/dist/esm/condition/date/date.d.ts.map +1 -0
- package/dist/esm/condition/date/date.js +38 -0
- package/dist/esm/condition/date/date.js.map +1 -0
- package/dist/esm/condition/ipaddress/IpAddress.d.ts +3 -0
- package/dist/esm/condition/ipaddress/IpAddress.d.ts.map +1 -0
- package/dist/esm/condition/ipaddress/IpAddress.js +24 -0
- package/dist/esm/condition/ipaddress/IpAddress.js.map +1 -0
- package/dist/esm/condition/ipaddress/NotIpAddress.d.ts +3 -0
- package/dist/esm/condition/ipaddress/NotIpAddress.d.ts.map +1 -0
- package/dist/esm/condition/ipaddress/NotIpAddress.js +28 -0
- package/dist/esm/condition/ipaddress/NotIpAddress.js.map +1 -0
- package/dist/esm/condition/ipaddress/ipv4.d.ts +24 -0
- package/dist/esm/condition/ipaddress/ipv4.d.ts.map +1 -0
- package/dist/esm/condition/ipaddress/ipv4.js +54 -0
- package/dist/esm/condition/ipaddress/ipv4.js.map +1 -0
- package/dist/esm/condition/ipaddress/ipv6.d.ts +24 -0
- package/dist/esm/condition/ipaddress/ipv6.d.ts.map +1 -0
- package/dist/esm/condition/ipaddress/ipv6.js +106 -0
- package/dist/esm/condition/ipaddress/ipv6.js.map +1 -0
- package/dist/esm/condition/numeric/NumericEquals.d.ts +3 -0
- package/dist/esm/condition/numeric/NumericEquals.d.ts.map +1 -0
- package/dist/esm/condition/numeric/NumericEquals.js +14 -0
- package/dist/esm/condition/numeric/NumericEquals.js.map +1 -0
- package/dist/esm/condition/numeric/NumericGreaterThan.d.ts +3 -0
- package/dist/esm/condition/numeric/NumericGreaterThan.d.ts.map +1 -0
- package/dist/esm/condition/numeric/NumericGreaterThan.js +14 -0
- package/dist/esm/condition/numeric/NumericGreaterThan.js.map +1 -0
- package/dist/esm/condition/numeric/NumericGreaterThanEquals.d.ts +3 -0
- package/dist/esm/condition/numeric/NumericGreaterThanEquals.d.ts.map +1 -0
- package/dist/esm/condition/numeric/NumericGreaterThanEquals.js +14 -0
- package/dist/esm/condition/numeric/NumericGreaterThanEquals.js.map +1 -0
- package/dist/esm/condition/numeric/NumericLessThan.d.ts +3 -0
- package/dist/esm/condition/numeric/NumericLessThan.d.ts.map +1 -0
- package/dist/esm/condition/numeric/NumericLessThan.js +14 -0
- package/dist/esm/condition/numeric/NumericLessThan.js.map +1 -0
- package/dist/esm/condition/numeric/NumericLessThanEquals.d.ts +3 -0
- package/dist/esm/condition/numeric/NumericLessThanEquals.d.ts.map +1 -0
- package/dist/esm/condition/numeric/NumericLessThanEquals.js +14 -0
- package/dist/esm/condition/numeric/NumericLessThanEquals.js.map +1 -0
- package/dist/esm/condition/numeric/NumericNotEquals.d.ts +3 -0
- package/dist/esm/condition/numeric/NumericNotEquals.d.ts.map +1 -0
- package/dist/esm/condition/numeric/NumericNotEquals.js +26 -0
- package/dist/esm/condition/numeric/NumericNotEquals.js.map +1 -0
- package/dist/esm/condition/numeric/numeric.d.ts +17 -0
- package/dist/esm/condition/numeric/numeric.d.ts.map +1 -0
- package/dist/esm/condition/numeric/numeric.js +37 -0
- package/dist/esm/condition/numeric/numeric.js.map +1 -0
- package/dist/esm/condition/string/StringEquals.d.ts.map +1 -0
- package/dist/esm/condition/string/StringEquals.js.map +1 -0
- package/dist/esm/condition/string/StringEqualsIgnoreCase.d.ts +3 -0
- package/dist/esm/condition/string/StringEqualsIgnoreCase.d.ts.map +1 -0
- package/dist/esm/condition/string/StringEqualsIgnoreCase.js +14 -0
- package/dist/esm/condition/string/StringEqualsIgnoreCase.js.map +1 -0
- package/dist/esm/condition/string/StringLike.d.ts +3 -0
- package/dist/esm/condition/string/StringLike.d.ts.map +1 -0
- package/dist/esm/condition/string/StringLike.js +11 -0
- package/dist/esm/condition/string/StringLike.js.map +1 -0
- package/dist/esm/condition/string/StringNotEquals.d.ts +3 -0
- package/dist/esm/condition/string/StringNotEquals.d.ts.map +1 -0
- package/dist/esm/condition/string/StringNotEquals.js +11 -0
- package/dist/esm/condition/string/StringNotEquals.js.map +1 -0
- package/dist/esm/condition/string/StringNotEqualsIgnoreCase.d.ts +3 -0
- package/dist/esm/condition/string/StringNotEqualsIgnoreCase.d.ts.map +1 -0
- package/dist/esm/condition/string/StringNotEqualsIgnoreCase.js +10 -0
- package/dist/esm/condition/string/StringNotEqualsIgnoreCase.js.map +1 -0
- package/dist/esm/condition/string/StringNotLike.d.ts +3 -0
- package/dist/esm/condition/string/StringNotLike.d.ts.map +1 -0
- package/dist/esm/condition/string/StringNotLike.js +10 -0
- package/dist/esm/condition/string/StringNotLike.js.map +1 -0
- package/dist/esm/core_engine/coreSimulatorEngine.d.ts +44 -0
- package/dist/esm/core_engine/coreSimulatorEngine.d.ts.map +1 -0
- package/dist/esm/core_engine/coreSimulatorEngine.js +58 -0
- package/dist/esm/core_engine/coreSimulatorEngine.js.map +1 -0
- package/dist/esm/evaluate.d.ts +1 -1
- package/dist/esm/evaluate.d.ts.map +1 -1
- package/dist/esm/index.d.ts +4 -0
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +3 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/principal/principal.d.ts +1 -2
- package/dist/esm/principal/principal.d.ts.map +1 -1
- package/dist/esm/request/request.d.ts +9 -5
- package/dist/esm/request/request.d.ts.map +1 -1
- package/dist/esm/request/request.js +4 -8
- package/dist/esm/request/request.js.map +1 -1
- package/dist/esm/request/requestResource.d.ts +7 -1
- package/dist/esm/request/requestResource.d.ts.map +1 -1
- package/dist/esm/request/requestResource.js +5 -1
- package/dist/esm/request/requestResource.js.map +1 -1
- package/dist/esm/resource/resource.d.ts +16 -1
- package/dist/esm/resource/resource.d.ts.map +1 -1
- package/dist/esm/resource/resource.js +24 -26
- package/dist/esm/resource/resource.js.map +1 -1
- package/dist/esm/services/DefaultServiceAuthorizer.d.ts +12 -0
- package/dist/esm/services/DefaultServiceAuthorizer.d.ts.map +1 -0
- package/dist/esm/services/DefaultServiceAuthorizer.js +75 -0
- package/dist/esm/services/DefaultServiceAuthorizer.js.map +1 -0
- package/dist/esm/services/ServiceAuthorizer.d.ts +11 -0
- package/dist/esm/services/ServiceAuthorizer.d.ts.map +1 -0
- package/dist/esm/services/ServiceAuthorizer.js +2 -0
- package/dist/esm/services/ServiceAuthorizer.js.map +1 -0
- package/dist/esm/simulation_engine/contextKeys.d.ts +3 -0
- package/dist/esm/simulation_engine/contextKeys.d.ts.map +1 -0
- package/dist/esm/simulation_engine/contextKeys.js +49 -0
- package/dist/esm/simulation_engine/contextKeys.js.map +1 -0
- package/dist/esm/simulation_engine/simulationEngine.d.ts +25 -0
- package/dist/esm/simulation_engine/simulationEngine.d.ts.map +1 -0
- package/dist/esm/simulation_engine/simulationEngine.js +35 -0
- package/dist/esm/simulation_engine/simulationEngine.js.map +1 -0
- package/dist/esm/util.d.ts +32 -0
- package/dist/esm/util.d.ts.map +1 -1
- package/dist/esm/util.js +78 -2
- package/dist/esm/util.js.map +1 -1
- package/package.json +1 -1
- package/dist/cjs/action.d.ts +0 -4
- package/dist/cjs/action.d.ts.map +0 -1
- package/dist/cjs/action.js +0 -21
- package/dist/cjs/action.js.map +0 -1
- package/dist/cjs/condition/strings/StringEquals.d.ts.map +0 -1
- package/dist/cjs/condition/strings/StringEquals.js +0 -14
- package/dist/cjs/condition/strings/StringEquals.js.map +0 -1
- package/dist/cjs/request/requestSupplementalData.d.ts +0 -19
- package/dist/cjs/request/requestSupplementalData.d.ts.map +0 -1
- package/dist/cjs/request/requestSupplementalData.js +0 -37
- package/dist/cjs/request/requestSupplementalData.js.map +0 -1
- package/dist/cjs/request.d.ts +0 -15
- package/dist/cjs/request.d.ts.map +0 -1
- package/dist/cjs/request.js +0 -17
- package/dist/cjs/request.js.map +0 -1
- package/dist/esm/action.d.ts +0 -4
- package/dist/esm/action.d.ts.map +0 -1
- package/dist/esm/action.js +0 -18
- package/dist/esm/action.js.map +0 -1
- package/dist/esm/condition/strings/StringEquals.d.ts +0 -3
- package/dist/esm/condition/strings/StringEquals.d.ts.map +0 -1
- package/dist/esm/condition/strings/StringEquals.js.map +0 -1
- package/dist/esm/request/requestSupplementalData.d.ts +0 -19
- package/dist/esm/request/requestSupplementalData.d.ts.map +0 -1
- package/dist/esm/request/requestSupplementalData.js +0 -30
- package/dist/esm/request/requestSupplementalData.js.map +0 -1
- package/dist/esm/request.d.ts +0 -15
- package/dist/esm/request.d.ts.map +0 -1
- package/dist/esm/request.js +0 -9
- package/dist/esm/request.js.map +0 -1
- /package/dist/{cjs/condition/strings → esm/condition/string}/StringEquals.d.ts +0 -0
- /package/dist/esm/condition/{strings → string}/StringEquals.js +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ArnNotLike.js","sourceRoot":"","sources":["../../../../src/condition/arn/ArnNotLike.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAEvC,MAAM,CAAC,MAAM,UAAU,GAA0B;IAC/C,IAAI,EAAE,YAAY;IAClB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAA;IAC1D,CAAC;IACD,eAAe,EAAE,IAAI;IACrB,eAAe,EAAE,IAAI;CACtB,CAAA"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { BaseConditionOperator } from "./BaseConditionOperator.js";
|
|
2
|
+
export interface BaseOperatorTest {
|
|
3
|
+
name: string;
|
|
4
|
+
requestContext?: {
|
|
5
|
+
[key: string]: string;
|
|
6
|
+
};
|
|
7
|
+
policyValues: string[];
|
|
8
|
+
testValue: string;
|
|
9
|
+
expected: boolean;
|
|
10
|
+
}
|
|
11
|
+
export declare function testOperator(name: string, tests: BaseOperatorTest[], operator: BaseConditionOperator): void;
|
|
12
|
+
//# sourceMappingURL=baseConditionperatorTests.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"baseConditionperatorTests.d.ts","sourceRoot":"","sources":["../../../src/condition/baseConditionperatorTests.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAA;AAElE,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,MAAM,CAAA;IACZ,cAAc,CAAC,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,CAAA;IAC1C,YAAY,EAAE,MAAM,EAAE,CAAA;IACtB,SAAS,EAAE,MAAM,CAAA;IACjB,QAAQ,EAAE,OAAO,CAAA;CAClB;AAED,wBAAgB,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,gBAAgB,EAAE,EAAE,QAAQ,EAAE,qBAAqB,QAcpG"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { describe, expect } from "vitest";
|
|
2
|
+
import { AwsRequestImpl } from "../request/request.js";
|
|
3
|
+
import { RequestContextImpl } from "../requestContext.js";
|
|
4
|
+
export function testOperator(name, tests, operator) {
|
|
5
|
+
describe(name, it => {
|
|
6
|
+
for (const test of tests) {
|
|
7
|
+
it(test.name, () => {
|
|
8
|
+
//Given the request
|
|
9
|
+
const request = new AwsRequestImpl('', { resource: '', accountId: '' }, '', new RequestContextImpl(test.requestContext || {}));
|
|
10
|
+
//When the condition is evaluated
|
|
11
|
+
const result = operator.matches(request, test.testValue, test.policyValues);
|
|
12
|
+
//Then the result should be as expected
|
|
13
|
+
expect(result).toBe(test.expected);
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=baseConditionperatorTests.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"baseConditionperatorTests.js","sourceRoot":"","sources":["../../../src/condition/baseConditionperatorTests.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAA;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAA;AACtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAA;AAWzD,MAAM,UAAU,YAAY,CAAC,IAAY,EAAE,KAAyB,EAAE,QAA+B;IACnG,QAAQ,CAAC,IAAI,EAAE,EAAE,CAAC,EAAE;QAClB,KAAI,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACxB,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,GAAG,EAAE;gBACjB,mBAAmB;gBACnB,MAAM,OAAO,GAAG,IAAI,cAAc,CAAC,EAAE,EAAE,EAAC,QAAQ,EAAE,EAAE,EAAE,SAAS,EAAE,EAAE,EAAC,EAAE,EAAE,EAAE,IAAI,kBAAkB,CAAC,IAAI,CAAC,cAAc,IAAI,EAAE,CAAC,CAAC,CAAA;gBAC5H,iCAAiC;gBACjC,MAAM,MAAM,GAAG,QAAQ,CAAC,OAAO,CAAC,OAAO,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,YAAY,CAAC,CAAA;gBAE3E,uCAAuC;gBACvC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;YACpC,CAAC,CAAC,CAAA;QACJ,CAAC;IACH,CAAC,CAAC,CAAA;AACJ,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { BaseConditionOperator } from "../BaseConditionOperator.js";
|
|
2
|
+
/**
|
|
3
|
+
* For Binary we don't really have the ability to accept binary
|
|
4
|
+
* values right now, so just do a string match.
|
|
5
|
+
*/
|
|
6
|
+
export declare const BinaryEquals: BaseConditionOperator;
|
|
7
|
+
//# sourceMappingURL=BinaryEquals.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BinaryEquals.d.ts","sourceRoot":"","sources":["../../../../src/condition/binary/BinaryEquals.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAEpE;;;GAGG;AACH,eAAO,MAAM,YAAY,EAAE,qBAO1B,CAAA"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* For Binary we don't really have the ability to accept binary
|
|
3
|
+
* values right now, so just do a string match.
|
|
4
|
+
*/
|
|
5
|
+
export const BinaryEquals = {
|
|
6
|
+
name: 'BinaryEquals',
|
|
7
|
+
matches: (request, keyValue, policyValues) => {
|
|
8
|
+
return policyValues.includes(keyValue);
|
|
9
|
+
},
|
|
10
|
+
allowsVariables: true,
|
|
11
|
+
allowsWildcards: false
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=BinaryEquals.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BinaryEquals.js","sourceRoot":"","sources":["../../../../src/condition/binary/BinaryEquals.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,MAAM,CAAC,MAAM,YAAY,GAA0B;IACjD,IAAI,EAAE,cAAc;IACpB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,OAAO,YAAY,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IACzC,CAAC;IACD,eAAe,EAAE,IAAI;IACrB,eAAe,EAAE,KAAK;CACvB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Bool.d.ts","sourceRoot":"","sources":["../../../../src/condition/boolean/Bool.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAEpE,eAAO,MAAM,IAAI,EAAE,qBAclB,CAAA"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { convertIamStringToRegex } from "../../util.js";
|
|
2
|
+
export const Bool = {
|
|
3
|
+
name: 'Bool',
|
|
4
|
+
matches: (request, keyValue, policyValues) => {
|
|
5
|
+
return policyValues.some(policyValue => {
|
|
6
|
+
const pattern = convertIamStringToRegex(policyValue, request, { replaceWildcards: false });
|
|
7
|
+
const lowercasePattern = pattern.source.toLowerCase();
|
|
8
|
+
if (lowercasePattern != '^true$' && lowercasePattern != '^false$') {
|
|
9
|
+
return false;
|
|
10
|
+
}
|
|
11
|
+
return new RegExp(pattern, 'i').test(keyValue);
|
|
12
|
+
});
|
|
13
|
+
},
|
|
14
|
+
allowsVariables: true,
|
|
15
|
+
allowsWildcards: false
|
|
16
|
+
};
|
|
17
|
+
//# sourceMappingURL=Bool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Bool.js","sourceRoot":"","sources":["../../../../src/condition/boolean/Bool.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAC;AAGxD,MAAM,CAAC,MAAM,IAAI,GAA0B;IACzC,IAAI,EAAE,MAAM;IACZ,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,OAAO,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACrC,MAAM,OAAO,GAAG,uBAAuB,CAAC,WAAW,EAAE,OAAO,EAAE,EAAC,gBAAgB,EAAE,KAAK,EAAC,CAAC,CAAA;YACxF,MAAM,gBAAgB,GAAG,OAAO,CAAC,MAAM,CAAC,WAAW,EAAE,CAAA;YACrD,IAAG,gBAAgB,IAAI,QAAQ,IAAI,gBAAgB,IAAI,SAAS,EAAE,CAAC;gBACjE,OAAO,KAAK,CAAA;YACd,CAAC;YACD,OAAO,IAAI,MAAM,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QAChD,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,eAAe,EAAE,IAAI;IACrB,eAAe,EAAE,KAAK;CACvB,CAAA"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Condition } from '@cloud-copilot/iam-policy';
|
|
2
2
|
import { AwsRequest } from '../request/request';
|
|
3
3
|
export type ConditionMatchResult = 'Match' | 'NoMatch' | 'Unknown';
|
|
4
|
+
export declare function requestMatchesConditions(request: AwsRequest, conditions: Condition[]): ConditionMatchResult;
|
|
4
5
|
export declare function singleConditionMatchesRequest(request: AwsRequest, condition: Condition): ConditionMatchResult;
|
|
5
6
|
//# sourceMappingURL=condition.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"condition.d.ts","sourceRoot":"","sources":["../../../src/condition/condition.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"condition.d.ts","sourceRoot":"","sources":["../../../src/condition/condition.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AA4BhD,MAAM,MAAM,oBAAoB,GAAG,OAAO,GAAG,SAAS,GAAG,SAAS,CAAA;AAiBlE,wBAAgB,wBAAwB,CAAC,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,SAAS,EAAE,GAAG,oBAAoB,CAW3G;AAED,wBAAgB,6BAA6B,CAAC,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,GAAG,oBAAoB,CAiE7G"}
|
|
@@ -1,20 +1,62 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
1
|
+
import { ArnEquals } from './arn/ArnEquals.js';
|
|
2
|
+
import { ArnLike } from './arn/ArnLike.js';
|
|
3
|
+
import { ArnNotEquals } from './arn/ArnNotEquals.js';
|
|
4
|
+
import { ArnNotLike } from './arn/ArnNotLike.js';
|
|
5
|
+
import { BinaryEquals } from './binary/BinaryEquals.js';
|
|
6
|
+
import { Bool } from './boolean/Bool.js';
|
|
7
|
+
import { DateEquals } from './date/DateEquals.js';
|
|
8
|
+
import { DateGreaterThan } from './date/DateGreaterThan.js';
|
|
9
|
+
import { DateGreaterThanEquals } from './date/DateGreaterThanEquals.js';
|
|
10
|
+
import { DateLessThan } from './date/DateLessThan.js';
|
|
11
|
+
import { DateLessThanEquals } from './date/DateLessThanEquals.js';
|
|
12
|
+
import { DateNotEquals } from './date/DateNotEquals.js';
|
|
13
|
+
import { IpAddress } from './ipaddress/IpAddress.js';
|
|
14
|
+
import { NotIpAddress } from './ipaddress/NotIpAddress.js';
|
|
15
|
+
import { NumericEquals } from './numeric/NumericEquals.js';
|
|
16
|
+
import { NumericGreaterThan } from './numeric/NumericGreaterThan.js';
|
|
17
|
+
import { NumericGreaterThanEquals } from './numeric/NumericGreaterThanEquals.js';
|
|
18
|
+
import { NumericLessThan } from './numeric/NumericLessThan.js';
|
|
19
|
+
import { NumericNotEquals } from './numeric/NumericNotEquals.js';
|
|
20
|
+
import { StringEquals } from './string/StringEquals.js';
|
|
21
|
+
import { StringEqualsIgnoreCase } from './string/StringEqualsIgnoreCase.js';
|
|
22
|
+
import { StringLike } from './string/StringLike.js';
|
|
23
|
+
import { StringNotEquals } from './string/StringNotEquals.js';
|
|
24
|
+
import { StringNotEqualsIgnoreCase } from './string/StringNotEqualsIgnoreCase.js';
|
|
25
|
+
import { StringNotLike } from './string/StringNotLike.js';
|
|
26
|
+
const allOperators = [
|
|
27
|
+
StringEquals, StringNotEquals, StringEqualsIgnoreCase, StringNotEqualsIgnoreCase, StringLike, StringNotLike,
|
|
28
|
+
NumericEquals, NumericNotEquals, NumericLessThan, NumericNotEquals, NumericGreaterThan, NumericGreaterThanEquals,
|
|
29
|
+
DateEquals, DateNotEquals, DateLessThan, DateLessThanEquals, DateGreaterThan, DateGreaterThanEquals,
|
|
30
|
+
Bool,
|
|
31
|
+
BinaryEquals,
|
|
32
|
+
IpAddress, NotIpAddress,
|
|
33
|
+
ArnLike, ArnEquals, ArnNotLike, ArnNotEquals
|
|
34
|
+
];
|
|
35
|
+
const baseOperations = {};
|
|
36
|
+
for (const operator of allOperators) {
|
|
37
|
+
baseOperations[operator.name.toLowerCase()] = operator;
|
|
38
|
+
}
|
|
39
|
+
export function requestMatchesConditions(request, conditions) {
|
|
40
|
+
const results = conditions.map(condition => singleConditionMatchesRequest(request, condition));
|
|
41
|
+
const unknowns = results.filter(result => result === 'Unknown');
|
|
42
|
+
if (unknowns.length > 0) {
|
|
43
|
+
return 'Unknown';
|
|
44
|
+
}
|
|
45
|
+
const noMatches = results.filter(result => result === 'NoMatch');
|
|
46
|
+
if (noMatches.length > 0) {
|
|
47
|
+
return 'NoMatch';
|
|
10
48
|
}
|
|
11
|
-
|
|
49
|
+
return 'Match';
|
|
50
|
+
}
|
|
12
51
|
export function singleConditionMatchesRequest(request, condition) {
|
|
13
52
|
const key = condition.conditionKey();
|
|
14
53
|
const policyValues = condition.conditionValues();
|
|
15
|
-
const baseOperation = baseOperations[condition.operation().baseOperator().toLowerCase()];
|
|
54
|
+
const baseOperation = baseOperations[condition.operation().baseOperator().toLowerCase()]?.matches;
|
|
16
55
|
const keyExists = request.contextKeyExists(key);
|
|
17
56
|
const keyValue = keyExists ? request.getContextKeyValue(key) : undefined;
|
|
57
|
+
if (condition.operation().value().toLowerCase() == 'null' || condition.operation().baseOperator()?.toLowerCase() == 'null') {
|
|
58
|
+
return testNull(condition, keyExists);
|
|
59
|
+
}
|
|
18
60
|
if (condition.operation().setOperator()) {
|
|
19
61
|
const setOperator = condition.operation().setOperator();
|
|
20
62
|
if (setOperator === 'ForAnyValue') {
|
|
@@ -67,4 +109,11 @@ export function singleConditionMatchesRequest(request, condition) {
|
|
|
67
109
|
const matches = baseOperation(request, keyValue.value, policyValues);
|
|
68
110
|
return matches ? 'Match' : 'NoMatch';
|
|
69
111
|
}
|
|
112
|
+
function testNull(condition, keyExists) {
|
|
113
|
+
const lowerCaseValues = condition.conditionValues().map(value => value.toLowerCase());
|
|
114
|
+
if (keyExists) {
|
|
115
|
+
return lowerCaseValues.includes('false') ? 'Match' : 'NoMatch';
|
|
116
|
+
}
|
|
117
|
+
return lowerCaseValues.includes('true') ? 'Match' : 'NoMatch';
|
|
118
|
+
}
|
|
70
119
|
//# sourceMappingURL=condition.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"condition.js","sourceRoot":"","sources":["../../../src/condition/condition.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"condition.js","sourceRoot":"","sources":["../../../src/condition/condition.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DateEquals.d.ts","sourceRoot":"","sources":["../../../../src/condition/date/DateEquals.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,UAAU,EAAE,qBAYxB,CAAA"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { checkIfDate } from "./date.js";
|
|
2
|
+
export const DateEquals = {
|
|
3
|
+
name: 'DateEquals',
|
|
4
|
+
matches: (request, keyValue, policyValues) => {
|
|
5
|
+
return policyValues.some(policyValue => {
|
|
6
|
+
return checkIfDate(policyValue, keyValue, (policyEpoch, requestEpoch) => {
|
|
7
|
+
return policyEpoch == requestEpoch;
|
|
8
|
+
});
|
|
9
|
+
});
|
|
10
|
+
},
|
|
11
|
+
allowsVariables: false,
|
|
12
|
+
allowsWildcards: false
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=DateEquals.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DateEquals.js","sourceRoot":"","sources":["../../../../src/condition/date/DateEquals.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAExC,MAAM,CAAC,MAAM,UAAU,GAA0B;IAC/C,IAAI,EAAE,YAAY;IAElB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,OAAO,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACrC,OAAO,WAAW,CAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,YAAY,EAAE,EAAE;gBACtE,OAAO,WAAW,IAAI,YAAY,CAAA;YACpC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DateGreaterThan.d.ts","sourceRoot":"","sources":["../../../../src/condition/date/DateGreaterThan.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,eAAe,EAAE,qBAY7B,CAAA"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { checkIfDate } from "./date.js";
|
|
2
|
+
export const DateGreaterThan = {
|
|
3
|
+
name: 'DateGreaterThan',
|
|
4
|
+
matches: (request, keyValue, policyValues) => {
|
|
5
|
+
return policyValues.some(policyValue => {
|
|
6
|
+
return checkIfDate(policyValue, keyValue, (policyEpoch, requestEpoch) => {
|
|
7
|
+
return policyEpoch < requestEpoch;
|
|
8
|
+
});
|
|
9
|
+
});
|
|
10
|
+
},
|
|
11
|
+
allowsVariables: false,
|
|
12
|
+
allowsWildcards: false
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=DateGreaterThan.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DateGreaterThan.js","sourceRoot":"","sources":["../../../../src/condition/date/DateGreaterThan.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAExC,MAAM,CAAC,MAAM,eAAe,GAA0B;IACpD,IAAI,EAAE,iBAAiB;IAEvB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,OAAO,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACrC,OAAO,WAAW,CAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,YAAY,EAAE,EAAE;gBACtE,OAAO,WAAW,GAAG,YAAY,CAAA;YACnC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DateGreaterThanEquals.d.ts","sourceRoot":"","sources":["../../../../src/condition/date/DateGreaterThanEquals.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,qBAAqB,EAAE,qBAYnC,CAAA"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { checkIfDate } from "./date.js";
|
|
2
|
+
export const DateGreaterThanEquals = {
|
|
3
|
+
name: 'DateGreaterThanEquals',
|
|
4
|
+
matches: (request, keyValue, policyValues) => {
|
|
5
|
+
return policyValues.some(policyValue => {
|
|
6
|
+
return checkIfDate(policyValue, keyValue, (policyEpoch, requestEpoch) => {
|
|
7
|
+
return policyEpoch <= requestEpoch;
|
|
8
|
+
});
|
|
9
|
+
});
|
|
10
|
+
},
|
|
11
|
+
allowsVariables: false,
|
|
12
|
+
allowsWildcards: false
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=DateGreaterThanEquals.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DateGreaterThanEquals.js","sourceRoot":"","sources":["../../../../src/condition/date/DateGreaterThanEquals.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAExC,MAAM,CAAC,MAAM,qBAAqB,GAA0B;IAC1D,IAAI,EAAE,uBAAuB;IAE7B,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,OAAO,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACrC,OAAO,WAAW,CAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,YAAY,EAAE,EAAE;gBACtE,OAAO,WAAW,IAAI,YAAY,CAAA;YACpC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DateLessThan.d.ts","sourceRoot":"","sources":["../../../../src/condition/date/DateLessThan.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,YAAY,EAAE,qBAY1B,CAAA"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { checkIfDate } from "./date.js";
|
|
2
|
+
export const DateLessThan = {
|
|
3
|
+
name: 'DateLessThan',
|
|
4
|
+
matches: (request, keyValue, policyValues) => {
|
|
5
|
+
return policyValues.some(policyValue => {
|
|
6
|
+
return checkIfDate(policyValue, keyValue, (policyEpoch, requestEpoch) => {
|
|
7
|
+
return policyEpoch > requestEpoch;
|
|
8
|
+
});
|
|
9
|
+
});
|
|
10
|
+
},
|
|
11
|
+
allowsVariables: false,
|
|
12
|
+
allowsWildcards: false
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=DateLessThan.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DateLessThan.js","sourceRoot":"","sources":["../../../../src/condition/date/DateLessThan.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAExC,MAAM,CAAC,MAAM,YAAY,GAA0B;IACjD,IAAI,EAAE,cAAc;IAEpB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,OAAO,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACrC,OAAO,WAAW,CAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,YAAY,EAAE,EAAE;gBACtE,OAAO,WAAW,GAAG,YAAY,CAAA;YACnC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DateLessThanEquals.d.ts","sourceRoot":"","sources":["../../../../src/condition/date/DateLessThanEquals.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,kBAAkB,EAAE,qBAYhC,CAAA"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { checkIfDate } from "./date.js";
|
|
2
|
+
export const DateLessThanEquals = {
|
|
3
|
+
name: 'DateLessThanEquals',
|
|
4
|
+
matches: (request, keyValue, policyValues) => {
|
|
5
|
+
return policyValues.some(policyValue => {
|
|
6
|
+
return checkIfDate(policyValue, keyValue, (policyEpoch, requestEpoch) => {
|
|
7
|
+
return policyEpoch >= requestEpoch;
|
|
8
|
+
});
|
|
9
|
+
});
|
|
10
|
+
},
|
|
11
|
+
allowsVariables: false,
|
|
12
|
+
allowsWildcards: false
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=DateLessThanEquals.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DateLessThanEquals.js","sourceRoot":"","sources":["../../../../src/condition/date/DateLessThanEquals.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAExC,MAAM,CAAC,MAAM,kBAAkB,GAA0B;IACvD,IAAI,EAAE,oBAAoB;IAE1B,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,OAAO,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACrC,OAAO,WAAW,CAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,YAAY,EAAE,EAAE;gBACtE,OAAO,WAAW,IAAI,YAAY,CAAA;YACpC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DateNotEquals.d.ts","sourceRoot":"","sources":["../../../../src/condition/date/DateNotEquals.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,aAAa,EAAE,qBAsB3B,CAAA"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { isDefined, isNotDefined } from "../../util.js";
|
|
2
|
+
import { parseDate } from "./date.js";
|
|
3
|
+
export const DateNotEquals = {
|
|
4
|
+
name: 'DateNotEquals',
|
|
5
|
+
matches: (request, keyValue, policyValues) => {
|
|
6
|
+
//How does this behave with malformed numbers
|
|
7
|
+
// return !NumericEquals.matches(request, keyValue, policyValues)
|
|
8
|
+
// const numericMatch = policyValues.some(policyValue => {
|
|
9
|
+
// return checkIfNumeric(policyValue, keyValue, (policyNumber, testNumber) => {
|
|
10
|
+
// return policyNumber == testNumber
|
|
11
|
+
// })
|
|
12
|
+
// })
|
|
13
|
+
const requestValue = parseDate(keyValue);
|
|
14
|
+
if (isNotDefined(requestValue)) {
|
|
15
|
+
return false;
|
|
16
|
+
}
|
|
17
|
+
const policyNumbers = policyValues.map(value => parseDate(value)).filter(value => isDefined(value));
|
|
18
|
+
if (policyNumbers.length === 0) {
|
|
19
|
+
return false;
|
|
20
|
+
}
|
|
21
|
+
return !policyNumbers.some(policyNumber => policyNumber == requestValue);
|
|
22
|
+
},
|
|
23
|
+
allowsVariables: false,
|
|
24
|
+
allowsWildcards: false
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=DateNotEquals.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DateNotEquals.js","sourceRoot":"","sources":["../../../../src/condition/date/DateNotEquals.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAExD,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAEtC,MAAM,CAAC,MAAM,aAAa,GAA0B;IAClD,IAAI,EAAE,eAAe;IACrB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,6CAA6C;QAC7C,iEAAiE;QACjE,2DAA2D;QAC3D,iFAAiF;QACjF,wCAAwC;QACxC,OAAO;QACP,KAAK;QACL,MAAM,YAAY,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAA;QACxC,IAAG,YAAY,CAAC,YAAY,CAAC,EAAE,CAAC;YAC9B,OAAO,KAAK,CAAA;QACd,CAAC;QACD,MAAM,aAAa,GAAG,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAA;QACnG,IAAG,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC9B,OAAO,KAAK,CAAA;QACd,CAAC;QACD,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,YAAY,IAAI,YAAY,CAAC,CAAA;IAC1E,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Parse a string to an epoch date value
|
|
3
|
+
*
|
|
4
|
+
* @param value the string to parse
|
|
5
|
+
* @returns the number or undefined if it cannot be parsed
|
|
6
|
+
*/
|
|
7
|
+
export declare function parseDate(value: string): number | undefined;
|
|
8
|
+
/**
|
|
9
|
+
* Test two values to see if they are dates or date epochs, if they are, run the check function
|
|
10
|
+
*
|
|
11
|
+
* @param policyValue
|
|
12
|
+
* @param testValue
|
|
13
|
+
* @param check
|
|
14
|
+
* @returns
|
|
15
|
+
*/
|
|
16
|
+
export declare function checkIfDate(policyValue: string, testValue: string, check: (policyValue: number, testValue: number) => boolean): boolean;
|
|
17
|
+
//# sourceMappingURL=date.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"date.d.ts","sourceRoot":"","sources":["../../../../src/condition/date/date.ts"],"names":[],"mappings":"AAEA;;;;;GAKG;AACH,wBAAgB,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAiB3D;AAED;;;;;;;GAOG;AACH,wBAAgB,WAAW,CAAC,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,KAAK,OAAO,GAAG,OAAO,CAOvI"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { isDefined, isNotDefined } from "../../util.js";
|
|
2
|
+
/**
|
|
3
|
+
* Parse a string to an epoch date value
|
|
4
|
+
*
|
|
5
|
+
* @param value the string to parse
|
|
6
|
+
* @returns the number or undefined if it cannot be parsed
|
|
7
|
+
*/
|
|
8
|
+
export function parseDate(value) {
|
|
9
|
+
// An Integer such as 2024 will be interpreted as a unix epoch date
|
|
10
|
+
// A unix epoch date
|
|
11
|
+
const epochDate = parseInt(value, 10);
|
|
12
|
+
if (isDefined(epochDate) && !isNaN(epochDate) && epochDate.toString() === value) {
|
|
13
|
+
return epochDate;
|
|
14
|
+
}
|
|
15
|
+
// Date Values can be a date string: https://www.w3.org/TR/NOTE-datetime
|
|
16
|
+
const dateNumber = Date.parse(value);
|
|
17
|
+
if (isDefined(dateNumber) && !isNaN(dateNumber)) {
|
|
18
|
+
return dateNumber;
|
|
19
|
+
}
|
|
20
|
+
return undefined;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Test two values to see if they are dates or date epochs, if they are, run the check function
|
|
24
|
+
*
|
|
25
|
+
* @param policyValue
|
|
26
|
+
* @param testValue
|
|
27
|
+
* @param check
|
|
28
|
+
* @returns
|
|
29
|
+
*/
|
|
30
|
+
export function checkIfDate(policyValue, testValue, check) {
|
|
31
|
+
const policyNumber = parseDate(policyValue);
|
|
32
|
+
const testNumber = parseDate(testValue);
|
|
33
|
+
if (isNotDefined(policyNumber) || isNotDefined(testNumber)) {
|
|
34
|
+
return false;
|
|
35
|
+
}
|
|
36
|
+
return check(policyNumber, testNumber);
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=date.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"date.js","sourceRoot":"","sources":["../../../../src/condition/date/date.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,eAAe,CAAA;AAEvD;;;;;GAKG;AACH,MAAM,UAAU,SAAS,CAAC,KAAa;IACrC,mEAAmE;IACnE,oBAAoB;IACpB,MAAM,SAAS,GAAG,QAAQ,CAAC,KAAK,EAAE,EAAE,CAAC,CAAA;IACrC,IAAG,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,SAAS,CAAC,QAAQ,EAAE,KAAK,KAAK,EAAE,CAAC;QAC/E,OAAO,SAAS,CAAA;IAClB,CAAC;IAED,wEAAwE;IACxE,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;IACpC,IAAG,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE,CAAC;QAC/C,OAAO,UAAU,CAAA;IACnB,CAAC;IAID,OAAO,SAAS,CAAA;AAClB,CAAC;AAED;;;;;;;GAOG;AACH,MAAM,UAAU,WAAW,CAAC,WAAmB,EAAE,SAAiB,EAAE,KAA0D;IAC5H,MAAM,YAAY,GAAG,SAAS,CAAC,WAAW,CAAC,CAAA;IAC3C,MAAM,UAAU,GAAG,SAAS,CAAC,SAAS,CAAC,CAAA;IACvC,IAAG,YAAY,CAAC,YAAY,CAAC,IAAI,YAAY,CAAC,UAAU,CAAC,EAAE,CAAC;QAC1D,OAAO,KAAK,CAAA;IACd,CAAC;IACD,OAAO,KAAK,CAAC,YAAY,EAAE,UAAU,CAAC,CAAA;AACxC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IpAddress.d.ts","sourceRoot":"","sources":["../../../../src/condition/ipaddress/IpAddress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAIpE,eAAO,MAAM,SAAS,EAAE,qBAoBvB,CAAA"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { isIpInCidrV4, isValidCidrV4, isValidIpV4 } from "./ipv4.js";
|
|
2
|
+
import { isIpInCidrV6, isValidIpCidrV6 as isValidCidrV6, isValidIpV6 } from "./ipv6.js";
|
|
3
|
+
export const IpAddress = {
|
|
4
|
+
name: 'IpAddress',
|
|
5
|
+
matches: (request, keyValue, policyValues) => {
|
|
6
|
+
if (!isValidIpV4(keyValue) && !isValidIpV6(keyValue)) {
|
|
7
|
+
return false;
|
|
8
|
+
}
|
|
9
|
+
return policyValues.some(policyValue => {
|
|
10
|
+
const isV4Cidr = isValidCidrV4(policyValue);
|
|
11
|
+
const isV6Cidr = isValidCidrV6(policyValue);
|
|
12
|
+
if (!isV4Cidr && !isV6Cidr) {
|
|
13
|
+
return false;
|
|
14
|
+
}
|
|
15
|
+
if (isV4Cidr) {
|
|
16
|
+
return isValidIpV4(keyValue) && isIpInCidrV4(keyValue, policyValue);
|
|
17
|
+
}
|
|
18
|
+
return isValidIpV6(keyValue) && isIpInCidrV6(keyValue, policyValue);
|
|
19
|
+
});
|
|
20
|
+
},
|
|
21
|
+
allowsVariables: false,
|
|
22
|
+
allowsWildcards: false
|
|
23
|
+
};
|
|
24
|
+
//# sourceMappingURL=IpAddress.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IpAddress.js","sourceRoot":"","sources":["../../../../src/condition/ipaddress/IpAddress.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACrE,OAAO,EAAE,YAAY,EAAE,eAAe,IAAI,aAAa,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAExF,MAAM,CAAC,MAAM,SAAS,GAA0B;IAC9C,IAAI,EAAE,WAAW;IACjB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,IAAG,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,CAAC;YACpD,OAAO,KAAK,CAAA;QACd,CAAC;QACD,OAAO,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACrC,MAAM,QAAQ,GAAG,aAAa,CAAC,WAAW,CAAC,CAAA;YAC3C,MAAM,QAAQ,GAAG,aAAa,CAAC,WAAW,CAAC,CAAA;YAC3C,IAAG,CAAC,QAAQ,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAC1B,OAAO,KAAK,CAAA;YACd,CAAC;YACD,IAAG,QAAQ,EAAE,CAAC;gBACZ,OAAO,WAAW,CAAC,QAAQ,CAAC,IAAI,YAAY,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAA;YACrE,CAAC;YACD,OAAO,WAAW,CAAC,QAAQ,CAAC,IAAI,YAAY,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAA;QACrE,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NotIpAddress.d.ts","sourceRoot":"","sources":["../../../../src/condition/ipaddress/NotIpAddress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAIpE,eAAO,MAAM,YAAY,EAAE,qBAyB1B,CAAA"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { isIpInCidrV4, isValidCidrV4, isValidIpV4 } from "./ipv4.js";
|
|
2
|
+
import { isIpInCidrV6, isValidIpCidrV6 as isValidCidrV6, isValidIpV6 } from "./ipv6.js";
|
|
3
|
+
export const NotIpAddress = {
|
|
4
|
+
name: 'NotIpAddress',
|
|
5
|
+
matches: (request, keyValue, policyValues) => {
|
|
6
|
+
const validPolicyValues = policyValues.filter(policyValue => isValidCidrV4(policyValue) || isValidCidrV6(policyValue));
|
|
7
|
+
if (validPolicyValues.length === 0) {
|
|
8
|
+
return false;
|
|
9
|
+
}
|
|
10
|
+
if (!isValidIpV4(keyValue) && !isValidIpV6(keyValue)) {
|
|
11
|
+
return false;
|
|
12
|
+
}
|
|
13
|
+
return !validPolicyValues.some(policyValue => {
|
|
14
|
+
const isV4Cidr = isValidCidrV4(policyValue);
|
|
15
|
+
const isV6Cidr = isValidCidrV6(policyValue);
|
|
16
|
+
if (!isV4Cidr && !isV6Cidr) {
|
|
17
|
+
return false;
|
|
18
|
+
}
|
|
19
|
+
if (isV4Cidr) {
|
|
20
|
+
return isValidIpV4(keyValue) && isIpInCidrV4(keyValue, policyValue);
|
|
21
|
+
}
|
|
22
|
+
return isValidIpV6(keyValue) && isIpInCidrV6(keyValue, policyValue);
|
|
23
|
+
});
|
|
24
|
+
},
|
|
25
|
+
allowsVariables: false,
|
|
26
|
+
allowsWildcards: false
|
|
27
|
+
};
|
|
28
|
+
//# sourceMappingURL=NotIpAddress.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NotIpAddress.js","sourceRoot":"","sources":["../../../../src/condition/ipaddress/NotIpAddress.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACrE,OAAO,EAAE,YAAY,EAAE,eAAe,IAAI,aAAa,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAExF,MAAM,CAAC,MAAM,YAAY,GAA0B;IACjD,IAAI,EAAE,cAAc;IACpB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,MAAM,iBAAiB,GAAG,YAAY,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,aAAa,CAAC,WAAW,CAAC,CAAC,CAAA;QACtH,IAAG,iBAAiB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAClC,OAAO,KAAK,CAAA;QACd,CAAC;QAED,IAAG,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,CAAC;YACpD,OAAO,KAAK,CAAA;QACd,CAAC;QACD,OAAO,CAAC,iBAAiB,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YAC3C,MAAM,QAAQ,GAAG,aAAa,CAAC,WAAW,CAAC,CAAA;YAC3C,MAAM,QAAQ,GAAG,aAAa,CAAC,WAAW,CAAC,CAAA;YAC3C,IAAG,CAAC,QAAQ,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAC1B,OAAO,KAAK,CAAA;YACd,CAAC;YACD,IAAG,QAAQ,EAAE,CAAC;gBACZ,OAAO,WAAW,CAAC,QAAQ,CAAC,IAAI,YAAY,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAA;YACrE,CAAC;YACD,OAAO,WAAW,CAAC,QAAQ,CAAC,IAAI,YAAY,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAA;QACrE,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Determines if a given IP address is within a specified CIDR block.
|
|
3
|
+
*
|
|
4
|
+
* @param ip - The IP address to check (e.g., '192.168.1.10').
|
|
5
|
+
* @param cidr - The CIDR block (e.g., '192.168.1.0/24').
|
|
6
|
+
* @returns True if the IP address is within the CIDR block; otherwise, false.
|
|
7
|
+
* @throws Error if either the IP address or CIDR block is invalid.
|
|
8
|
+
*/
|
|
9
|
+
export declare function isIpInCidrV4(ip: string, cidr: string): boolean;
|
|
10
|
+
/**
|
|
11
|
+
* Validates an IPv4 address.
|
|
12
|
+
*
|
|
13
|
+
* @param ip - The IP address to validate.
|
|
14
|
+
* @returns True if the IP address is valid; otherwise, false.
|
|
15
|
+
*/
|
|
16
|
+
export declare function isValidIpV4(ip: string): boolean;
|
|
17
|
+
/**
|
|
18
|
+
* Validates an IPv4 CIDR block.
|
|
19
|
+
*
|
|
20
|
+
* @param cidr - The CIDR block to validate.
|
|
21
|
+
* @returns True if the CIDR block is valid; otherwise, false.
|
|
22
|
+
*/
|
|
23
|
+
export declare function isValidCidrV4(cidr: string): boolean;
|
|
24
|
+
//# sourceMappingURL=ipv4.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ipv4.d.ts","sourceRoot":"","sources":["../../../../src/condition/ipaddress/ipv4.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,wBAAgB,YAAY,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAkB9D;AAED;;;;;GAKG;AACH,wBAAgB,WAAW,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAI/C;AAED;;;;;GAKG;AACH,wBAAgB,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAInD"}
|