@prosopo/user-access-policy 3.3.0 → 3.3.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.
Files changed (74) hide show
  1. package/CHANGELOG.md +36 -0
  2. package/dist/accessPolicy.js +71 -57
  3. package/dist/accessPolicyResolver.js +62 -36
  4. package/dist/accessRules.js +9 -6
  5. package/dist/api/accessRuleApiRoutes.js +73 -50
  6. package/dist/api/deleteAllRulesEndpoint.js +22 -19
  7. package/dist/api/deleteRulesEndpoint.js +30 -27
  8. package/dist/api/insertRulesEndpoint.js +57 -57
  9. package/dist/index.js +27 -14
  10. package/dist/redis/redisAccessRules.js +128 -112
  11. package/dist/redis/redisAccessRulesIndex.js +94 -70
  12. package/dist/redis/redisIndex.js +15 -16
  13. package/dist/util.js +4 -2
  14. package/package.json +15 -10
  15. package/vite.cjs.config.ts +7 -6
  16. package/vite.esm.config.ts +20 -0
  17. package/vite.test.config.ts +16 -21
  18. package/dist/accessPolicy.d.ts +0 -169
  19. package/dist/accessPolicy.d.ts.map +0 -1
  20. package/dist/accessPolicy.js.map +0 -1
  21. package/dist/accessPolicyResolver.d.ts +0 -115
  22. package/dist/accessPolicyResolver.d.ts.map +0 -1
  23. package/dist/accessPolicyResolver.js.map +0 -1
  24. package/dist/accessRules.d.ts +0 -16
  25. package/dist/accessRules.d.ts.map +0 -1
  26. package/dist/accessRules.js.map +0 -1
  27. package/dist/api/accessRuleApiRoutes.d.ts +0 -27
  28. package/dist/api/accessRuleApiRoutes.d.ts.map +0 -1
  29. package/dist/api/accessRuleApiRoutes.js.map +0 -1
  30. package/dist/api/deleteAllRulesEndpoint.d.ts +0 -12
  31. package/dist/api/deleteAllRulesEndpoint.d.ts.map +0 -1
  32. package/dist/api/deleteAllRulesEndpoint.js.map +0 -1
  33. package/dist/api/deleteRulesEndpoint.d.ts +0 -116
  34. package/dist/api/deleteRulesEndpoint.d.ts.map +0 -1
  35. package/dist/api/deleteRulesEndpoint.js.map +0 -1
  36. package/dist/api/insertRulesEndpoint.d.ts +0 -22
  37. package/dist/api/insertRulesEndpoint.d.ts.map +0 -1
  38. package/dist/api/insertRulesEndpoint.js.map +0 -1
  39. package/dist/index.d.ts +0 -15
  40. package/dist/index.d.ts.map +0 -1
  41. package/dist/index.js.map +0 -1
  42. package/dist/redis/redisAccessRules.d.ts +0 -7
  43. package/dist/redis/redisAccessRules.d.ts.map +0 -1
  44. package/dist/redis/redisAccessRules.js.map +0 -1
  45. package/dist/redis/redisAccessRulesIndex.d.ts +0 -13
  46. package/dist/redis/redisAccessRulesIndex.d.ts.map +0 -1
  47. package/dist/redis/redisAccessRulesIndex.js.map +0 -1
  48. package/dist/redis/redisIndex.d.ts +0 -9
  49. package/dist/redis/redisIndex.d.ts.map +0 -1
  50. package/dist/redis/redisIndex.js.map +0 -1
  51. package/dist/tests/accessPolicy.test.d.ts +0 -2
  52. package/dist/tests/accessPolicy.test.d.ts.map +0 -1
  53. package/dist/tests/accessPolicy.test.js +0 -27
  54. package/dist/tests/accessPolicy.test.js.map +0 -1
  55. package/dist/tests/redis/redisAccessRules.test.d.ts +0 -2
  56. package/dist/tests/redis/redisAccessRules.test.d.ts.map +0 -1
  57. package/dist/tests/redis/redisAccessRules.test.js +0 -413
  58. package/dist/tests/redis/redisAccessRules.test.js.map +0 -1
  59. package/dist/tests/redis/redisIndex.test.d.ts +0 -2
  60. package/dist/tests/redis/redisIndex.test.d.ts.map +0 -1
  61. package/dist/tests/redis/redisIndex.test.js +0 -84
  62. package/dist/tests/redis/redisIndex.test.js.map +0 -1
  63. package/dist/tests/redis/testRedisClient.d.ts +0 -3
  64. package/dist/tests/redis/testRedisClient.d.ts.map +0 -1
  65. package/dist/tests/redis/testRedisClient.js +0 -8
  66. package/dist/tests/redis/testRedisClient.js.map +0 -1
  67. package/dist/tests/testLogger.d.ts +0 -4
  68. package/dist/tests/testLogger.d.ts.map +0 -1
  69. package/dist/tests/testLogger.js +0 -22
  70. package/dist/tests/testLogger.js.map +0 -1
  71. package/dist/util.d.ts +0 -2
  72. package/dist/util.d.ts.map +0 -1
  73. package/dist/util.js.map +0 -1
  74. package/vite.config.ts +0 -39
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=redisIndex.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"redisIndex.test.d.ts","sourceRoot":"","sources":["../../../src/tests/redis/redisIndex.test.ts"],"names":[],"mappings":""}
@@ -1,84 +0,0 @@
1
- import { SCHEMA_FIELD_TYPE } from "@redis/search";
2
- import { afterAll, beforeAll, beforeEach, describe, expect, test, } from "vitest";
3
- import { createRedisIndex } from "#policy/redis/redisIndex.js";
4
- import { createTestRedisClient } from "#policy/tests/redis/testRedisClient.js";
5
- describe("redisIndex", () => {
6
- let redisClient;
7
- beforeAll(async () => {
8
- redisClient = await createTestRedisClient();
9
- });
10
- beforeEach(async () => {
11
- await redisClient.flushAll();
12
- });
13
- test("creates new index", async () => {
14
- const redisIndex = {
15
- name: "index:first",
16
- schema: {
17
- tagField: SCHEMA_FIELD_TYPE.TAG,
18
- },
19
- options: {},
20
- };
21
- await createRedisIndex(redisClient, redisIndex);
22
- const indexNames = await redisClient.ft._LIST();
23
- expect(indexNames).toContain(redisIndex.name);
24
- });
25
- test("does not re-create existing index when no changes declared", async () => {
26
- const redisIndex = {
27
- name: "index:first",
28
- schema: {
29
- tagField: SCHEMA_FIELD_TYPE.TAG,
30
- },
31
- options: {},
32
- };
33
- await createRedisIndex(redisClient, redisIndex);
34
- await redisClient.ft.alter(redisIndex.name, {
35
- anotherField: SCHEMA_FIELD_TYPE.TAG,
36
- });
37
- await createRedisIndex(redisClient, redisIndex);
38
- const indexNames = await redisClient.ft._LIST();
39
- const actualIndexInfo = await redisClient.ft.info(redisIndex.name);
40
- expect(indexNames).toContain(redisIndex.name);
41
- expect(actualIndexInfo.attributes.length).toBe(2);
42
- });
43
- test("re-creates existing index when schema changes made", async () => {
44
- const redisIndex = {
45
- name: "index:first",
46
- schema: {
47
- tagField: SCHEMA_FIELD_TYPE.TAG,
48
- },
49
- options: {},
50
- };
51
- await createRedisIndex(redisClient, redisIndex);
52
- redisIndex.schema = {
53
- ...redisIndex.schema,
54
- newField: SCHEMA_FIELD_TYPE.TAG,
55
- };
56
- await createRedisIndex(redisClient, redisIndex);
57
- const indexNames = await redisClient.ft._LIST();
58
- const actualIndexInfo = await redisClient.ft.info(redisIndex.name);
59
- expect(indexNames).toContain(redisIndex.name);
60
- expect(actualIndexInfo.attributes.length).toBe(2);
61
- });
62
- test("re-creates existing index when option changes made", async () => {
63
- const redisIndex = {
64
- name: "index:first",
65
- schema: {
66
- tagField: SCHEMA_FIELD_TYPE.TAG,
67
- },
68
- options: {},
69
- };
70
- await createRedisIndex(redisClient, redisIndex);
71
- redisIndex.options = {
72
- ON: "HASH",
73
- };
74
- await createRedisIndex(redisClient, redisIndex);
75
- const indexNames = await redisClient.ft._LIST();
76
- const actualIndexInfo = await redisClient.ft.info(redisIndex.name);
77
- expect(indexNames).toContain(redisIndex.name);
78
- expect(actualIndexInfo.index_definition.key_type).toBe("HASH");
79
- });
80
- afterAll(async () => {
81
- await redisClient.flushAll();
82
- });
83
- });
84
- //# sourceMappingURL=redisIndex.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"redisIndex.test.js","sourceRoot":"","sources":["../../../src/tests/redis/redisIndex.test.ts"],"names":[],"mappings":"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"}
@@ -1,3 +0,0 @@
1
- import { type RedisClientType } from "redis";
2
- export declare const createTestRedisClient: () => Promise<RedisClientType>;
3
- //# sourceMappingURL=testRedisClient.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"testRedisClient.d.ts","sourceRoot":"","sources":["../../../src/tests/redis/testRedisClient.ts"],"names":[],"mappings":"AAaA,OAAO,EAAE,KAAK,eAAe,EAAgB,MAAM,OAAO,CAAC;AAE3D,eAAO,MAAM,qBAAqB,QAAa,OAAO,CAAC,eAAe,CAOtC,CAAC"}
@@ -1,8 +0,0 @@
1
- import { createClient } from "redis";
2
- export const createTestRedisClient = async () => (await createClient({
3
- url: "redis://localhost:6379",
4
- password: "root",
5
- })
6
- .on("error", (err) => console.log("Redis Client Error", err))
7
- .connect());
8
- //# sourceMappingURL=testRedisClient.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"testRedisClient.js","sourceRoot":"","sources":["../../../src/tests/redis/testRedisClient.ts"],"names":[],"mappings":"AAaA,OAAO,EAAwB,YAAY,EAAE,MAAM,OAAO,CAAC;AAE3D,MAAM,CAAC,MAAM,qBAAqB,GAAG,KAAK,IAA8B,EAAE,CACzE,CAAC,MAAM,YAAY,CAAC;IAEnB,GAAG,EAAE,wBAAwB;IAC7B,QAAQ,EAAE,MAAM;CAChB,CAAC;KACA,EAAE,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,EAAE,GAAG,CAAC,CAAC;KAC5D,OAAO,EAAE,CAAoB,CAAC"}
@@ -1,4 +0,0 @@
1
- import type { Logger } from "@prosopo/common";
2
- declare const loggerMockedInstance: Logger;
3
- export { loggerMockedInstance };
4
- //# sourceMappingURL=testLogger.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"testLogger.d.ts","sourceRoot":"","sources":["../../src/tests/testLogger.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAG9C,QAAA,MAAM,oBAAoB,EAAE,MAkB3B,CAAC;AAEF,OAAO,EAAE,oBAAoB,EAAE,CAAC"}
@@ -1,22 +0,0 @@
1
- import { vi } from "vitest";
2
- const loggerMockedInstance = {
3
- trace: vi.fn(),
4
- debug: vi.fn(),
5
- info: vi.fn(),
6
- warn: vi.fn(),
7
- error: vi.fn(),
8
- fatal: vi.fn(),
9
- log: vi.fn(),
10
- setLogLevel: vi.fn(),
11
- getLogLevel: vi.fn(),
12
- with: vi.fn().mockReturnThis(),
13
- getScope: vi.fn().mockReturnValue("test-scope"),
14
- getPretty: vi.fn().mockReturnValue(false),
15
- setPretty: vi.fn(),
16
- getPrintStack: vi.fn().mockReturnValue(false),
17
- setPrintStack: vi.fn(),
18
- getFormat: vi.fn().mockReturnValue("json"),
19
- setFormat: vi.fn(),
20
- };
21
- export { loggerMockedInstance };
22
- //# sourceMappingURL=testLogger.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"testLogger.js","sourceRoot":"","sources":["../../src/tests/testLogger.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAE5B,MAAM,oBAAoB,GAAW;IACpC,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;IACd,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;IACd,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE;IACb,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE;IACb,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;IACd,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;IACd,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE;IACZ,WAAW,EAAE,EAAE,CAAC,EAAE,EAAE;IACpB,WAAW,EAAE,EAAE,CAAC,EAAE,EAAE;IACpB,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,cAAc,EAAE;IAC9B,QAAQ,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,YAAY,CAAC;IAC/C,SAAS,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,KAAK,CAAC;IACzC,SAAS,EAAE,EAAE,CAAC,EAAE,EAAE;IAClB,aAAa,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,KAAK,CAAC;IAC7C,aAAa,EAAE,EAAE,CAAC,EAAE,EAAE;IACtB,SAAS,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,MAAM,CAAC;IAC1C,SAAS,EAAE,EAAE,CAAC,EAAE,EAAE;CAClB,CAAC;AAEF,OAAO,EAAE,oBAAoB,EAAE,CAAC"}
package/dist/util.d.ts DELETED
@@ -1,2 +0,0 @@
1
- export declare const hashUserAgent: (userAgent: string) => string;
2
- //# sourceMappingURL=util.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../src/util.ts"],"names":[],"mappings":"AAeA,eAAO,MAAM,aAAa,cAAe,MAAM,KAAG,MACU,CAAC"}
package/dist/util.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"util.js","sourceRoot":"","sources":["../src/util.ts"],"names":[],"mappings":"AAaA,OAAO,MAAM,MAAM,aAAa,CAAC;AAEjC,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,SAAiB,EAAU,EAAE,CAC1D,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC"}
package/vite.config.ts DELETED
@@ -1,39 +0,0 @@
1
- // Copyright 2021-2025 Prosopo (UK) Ltd.
2
- //
3
- // Licensed under the Apache License, Version 2.0 (the "License");
4
- // you may not use this file except in compliance with the License.
5
- // You may obtain a copy of the License at
6
- //
7
- // http://www.apache.org/licenses/LICENSE-2.0
8
- //
9
- // Unless required by applicable law or agreed to in writing, software
10
- // distributed under the License is distributed on an "AS IS" BASIS,
11
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
- // See the License for the specific language governing permissions and
13
- // limitations under the License.
14
-
15
- import * as path from "node:path";
16
- import { ViteCommonJSConfig } from "@prosopo/config";
17
- import { defineConfig } from "vite";
18
-
19
- // Vite is used for building instead of the vanilla 'tsc --build' command as
20
- // we need to turn the TypeScript aliases (#policy) into relative file paths,
21
- // so it can be used by bundling script from the cli package.
22
- export default async () => {
23
- const viteConfig = await ViteCommonJSConfig(
24
- "user-access-policy",
25
- path.resolve("./tsconfig.json"),
26
- );
27
-
28
- return defineConfig({
29
- ...viteConfig,
30
- build: {
31
- ...viteConfig.build,
32
- outDir: "dist",
33
- lib: {
34
- ...viteConfig.build?.lib,
35
- formats: ["es"],
36
- },
37
- },
38
- });
39
- };