@voidhash/mimic-effect 0.0.2 → 0.0.4

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 (105) hide show
  1. package/.turbo/turbo-build.log +99 -14
  2. package/dist/DocumentManager.cjs +118 -0
  3. package/dist/DocumentManager.d.cts +45 -0
  4. package/dist/DocumentManager.d.cts.map +1 -0
  5. package/dist/DocumentManager.d.mts +45 -0
  6. package/dist/DocumentManager.d.mts.map +1 -0
  7. package/dist/DocumentManager.mjs +105 -0
  8. package/dist/DocumentManager.mjs.map +1 -0
  9. package/dist/DocumentProtocol.cjs +94 -0
  10. package/dist/DocumentProtocol.d.cts +113 -0
  11. package/dist/DocumentProtocol.d.cts.map +1 -0
  12. package/dist/DocumentProtocol.d.mts +113 -0
  13. package/dist/DocumentProtocol.d.mts.map +1 -0
  14. package/dist/DocumentProtocol.mjs +89 -0
  15. package/dist/DocumentProtocol.mjs.map +1 -0
  16. package/dist/MimicAuthService.cjs +55 -0
  17. package/dist/MimicAuthService.d.cts +65 -0
  18. package/dist/MimicAuthService.d.cts.map +1 -0
  19. package/dist/MimicAuthService.d.mts +65 -0
  20. package/dist/MimicAuthService.d.mts.map +1 -0
  21. package/dist/MimicAuthService.mjs +47 -0
  22. package/dist/MimicAuthService.mjs.map +1 -0
  23. package/dist/MimicConfig.cjs +52 -0
  24. package/dist/MimicConfig.d.cts +115 -0
  25. package/dist/MimicConfig.d.cts.map +1 -0
  26. package/dist/MimicConfig.d.mts +115 -0
  27. package/dist/MimicConfig.d.mts.map +1 -0
  28. package/dist/MimicConfig.mjs +43 -0
  29. package/dist/MimicConfig.mjs.map +1 -0
  30. package/dist/MimicDataStorage.cjs +83 -0
  31. package/dist/MimicDataStorage.d.cts +113 -0
  32. package/dist/MimicDataStorage.d.cts.map +1 -0
  33. package/dist/MimicDataStorage.d.mts +113 -0
  34. package/dist/MimicDataStorage.d.mts.map +1 -0
  35. package/dist/MimicDataStorage.mjs +74 -0
  36. package/dist/MimicDataStorage.mjs.map +1 -0
  37. package/dist/MimicServer.cjs +122 -0
  38. package/dist/MimicServer.d.cts +106 -0
  39. package/dist/MimicServer.d.cts.map +1 -0
  40. package/dist/MimicServer.d.mts +106 -0
  41. package/dist/MimicServer.d.mts.map +1 -0
  42. package/dist/MimicServer.mjs +116 -0
  43. package/dist/MimicServer.mjs.map +1 -0
  44. package/dist/PresenceManager.cjs +108 -0
  45. package/dist/PresenceManager.d.cts +91 -0
  46. package/dist/PresenceManager.d.cts.map +1 -0
  47. package/dist/PresenceManager.d.mts +91 -0
  48. package/dist/PresenceManager.d.mts.map +1 -0
  49. package/dist/PresenceManager.mjs +95 -0
  50. package/dist/PresenceManager.mjs.map +1 -0
  51. package/dist/WebSocketHandler.cjs +365 -0
  52. package/dist/WebSocketHandler.d.cts +34 -0
  53. package/dist/WebSocketHandler.d.cts.map +1 -0
  54. package/dist/WebSocketHandler.d.mts +34 -0
  55. package/dist/WebSocketHandler.d.mts.map +1 -0
  56. package/dist/WebSocketHandler.mjs +355 -0
  57. package/dist/WebSocketHandler.mjs.map +1 -0
  58. package/dist/_virtual/_@oxc-project_runtime@0.103.0/helpers/defineProperty.cjs +14 -0
  59. package/dist/_virtual/_@oxc-project_runtime@0.103.0/helpers/defineProperty.mjs +14 -0
  60. package/dist/_virtual/_@oxc-project_runtime@0.103.0/helpers/objectSpread2.cjs +27 -0
  61. package/dist/_virtual/_@oxc-project_runtime@0.103.0/helpers/objectSpread2.mjs +27 -0
  62. package/dist/_virtual/_@oxc-project_runtime@0.103.0/helpers/toPrimitive.cjs +16 -0
  63. package/dist/_virtual/_@oxc-project_runtime@0.103.0/helpers/toPrimitive.mjs +16 -0
  64. package/dist/_virtual/_@oxc-project_runtime@0.103.0/helpers/toPropertyKey.cjs +11 -0
  65. package/dist/_virtual/_@oxc-project_runtime@0.103.0/helpers/toPropertyKey.mjs +11 -0
  66. package/dist/_virtual/_@oxc-project_runtime@0.103.0/helpers/typeof.cjs +18 -0
  67. package/dist/_virtual/_@oxc-project_runtime@0.103.0/helpers/typeof.mjs +12 -0
  68. package/dist/_virtual/rolldown_runtime.cjs +43 -0
  69. package/dist/{chunk-C6wwvPpM.mjs → _virtual/rolldown_runtime.mjs} +1 -1
  70. package/dist/auth/NoAuth.cjs +43 -0
  71. package/dist/auth/NoAuth.d.cts +22 -0
  72. package/dist/auth/NoAuth.d.cts.map +1 -0
  73. package/dist/auth/NoAuth.d.mts +22 -0
  74. package/dist/auth/NoAuth.d.mts.map +1 -0
  75. package/dist/auth/NoAuth.mjs +36 -0
  76. package/dist/auth/NoAuth.mjs.map +1 -0
  77. package/dist/errors.cjs +74 -0
  78. package/dist/errors.d.cts +89 -0
  79. package/dist/errors.d.cts.map +1 -0
  80. package/dist/errors.d.mts +89 -0
  81. package/dist/errors.d.mts.map +1 -0
  82. package/dist/errors.mjs +67 -0
  83. package/dist/errors.mjs.map +1 -0
  84. package/dist/index.cjs +29 -1227
  85. package/dist/index.d.cts +12 -795
  86. package/dist/index.d.mts +12 -795
  87. package/dist/index.mjs +13 -1162
  88. package/dist/storage/InMemoryDataStorage.cjs +57 -0
  89. package/dist/storage/InMemoryDataStorage.d.cts +19 -0
  90. package/dist/storage/InMemoryDataStorage.d.cts.map +1 -0
  91. package/dist/storage/InMemoryDataStorage.d.mts +19 -0
  92. package/dist/storage/InMemoryDataStorage.d.mts.map +1 -0
  93. package/dist/storage/InMemoryDataStorage.mjs +48 -0
  94. package/dist/storage/InMemoryDataStorage.mjs.map +1 -0
  95. package/package.json +3 -3
  96. package/src/DocumentManager.ts +2 -2
  97. package/src/MimicConfig.ts +22 -1
  98. package/src/MimicServer.ts +11 -161
  99. package/tests/DocumentManager.test.ts +61 -0
  100. package/tests/MimicConfig.test.ts +72 -0
  101. package/tests/MimicServer.test.ts +55 -162
  102. package/tsdown.config.ts +1 -1
  103. package/dist/index.d.cts.map +0 -1
  104. package/dist/index.d.mts.map +0 -1
  105. package/dist/index.mjs.map +0 -1
@@ -0,0 +1,43 @@
1
+ const require_rolldown_runtime = require('../_virtual/rolldown_runtime.cjs');
2
+ const require_MimicAuthService = require('../MimicAuthService.cjs');
3
+ let effect_Effect = require("effect/Effect");
4
+ effect_Effect = require_rolldown_runtime.__toESM(effect_Effect);
5
+ let effect_Layer = require("effect/Layer");
6
+ effect_Layer = require_rolldown_runtime.__toESM(effect_Layer);
7
+
8
+ //#region src/auth/NoAuth.ts
9
+ /**
10
+ * @since 0.0.1
11
+ * No authentication implementation for Mimic connections.
12
+ * All connections are automatically authenticated (open access).
13
+ */
14
+ var NoAuth_exports = /* @__PURE__ */ require_rolldown_runtime.__export({
15
+ layer: () => layer,
16
+ layerDefault: () => layerDefault
17
+ });
18
+ /**
19
+ * Authentication service that auto-succeeds all authentication requests.
20
+ * Use this for development or when authentication is handled externally.
21
+ */
22
+ const noAuthService = { authenticate: (_token) => effect_Effect.succeed({ success: true }) };
23
+ /**
24
+ * Layer that provides no authentication (open access).
25
+ * All connections are automatically authenticated.
26
+ *
27
+ * WARNING: Only use this for development or when authentication
28
+ * is handled at a different layer (e.g., API gateway, reverse proxy).
29
+ */
30
+ const layer = effect_Layer.succeed(require_MimicAuthService.MimicAuthServiceTag, noAuthService);
31
+ /**
32
+ * Default layer alias for convenience.
33
+ */
34
+ const layerDefault = layer;
35
+
36
+ //#endregion
37
+ Object.defineProperty(exports, 'NoAuth_exports', {
38
+ enumerable: true,
39
+ get: function () {
40
+ return NoAuth_exports;
41
+ }
42
+ });
43
+ exports.layerDefault = layerDefault;
@@ -0,0 +1,22 @@
1
+ import { MimicAuthServiceTag } from "../MimicAuthService.cjs";
2
+ import * as Layer from "effect/Layer";
3
+
4
+ //#region src/auth/NoAuth.d.ts
5
+ declare namespace NoAuth_d_exports {
6
+ export { layer, layerDefault };
7
+ }
8
+ /**
9
+ * Layer that provides no authentication (open access).
10
+ * All connections are automatically authenticated.
11
+ *
12
+ * WARNING: Only use this for development or when authentication
13
+ * is handled at a different layer (e.g., API gateway, reverse proxy).
14
+ */
15
+ declare const layer: Layer.Layer<MimicAuthServiceTag>;
16
+ /**
17
+ * Default layer alias for convenience.
18
+ */
19
+ declare const layerDefault: Layer.Layer<MimicAuthServiceTag, never, never>;
20
+ //#endregion
21
+ export { NoAuth_d_exports };
22
+ //# sourceMappingURL=NoAuth.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NoAuth.d.cts","names":[],"sources":["../../src/auth/NoAuth.ts"],"sourcesContent":[],"mappings":";;;;;;;;;;;;;;AAqCa,cAAA,KAAmB,EAAZ,KAAA,CAAM,KAAM,CAAA,mBAAD,CAAA;AAQ/B;;;cAAa,cAAY,KAAA,CAAA,MAAA"}
@@ -0,0 +1,22 @@
1
+ import { MimicAuthServiceTag } from "../MimicAuthService.mjs";
2
+ import * as Layer from "effect/Layer";
3
+
4
+ //#region src/auth/NoAuth.d.ts
5
+ declare namespace NoAuth_d_exports {
6
+ export { layer, layerDefault };
7
+ }
8
+ /**
9
+ * Layer that provides no authentication (open access).
10
+ * All connections are automatically authenticated.
11
+ *
12
+ * WARNING: Only use this for development or when authentication
13
+ * is handled at a different layer (e.g., API gateway, reverse proxy).
14
+ */
15
+ declare const layer: Layer.Layer<MimicAuthServiceTag>;
16
+ /**
17
+ * Default layer alias for convenience.
18
+ */
19
+ declare const layerDefault: Layer.Layer<MimicAuthServiceTag, never, never>;
20
+ //#endregion
21
+ export { NoAuth_d_exports };
22
+ //# sourceMappingURL=NoAuth.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NoAuth.d.mts","names":[],"sources":["../../src/auth/NoAuth.ts"],"sourcesContent":[],"mappings":";;;;;;;;;;;;;;AAqCa,cAAA,KAAmB,EAAZ,KAAA,CAAM,KAAM,CAAA,mBAAD,CAAA;AAQ/B;;;cAAa,cAAY,KAAA,CAAA,MAAA"}
@@ -0,0 +1,36 @@
1
+ import { __export } from "../_virtual/rolldown_runtime.mjs";
2
+ import { MimicAuthServiceTag } from "../MimicAuthService.mjs";
3
+ import * as Effect from "effect/Effect";
4
+ import * as Layer from "effect/Layer";
5
+
6
+ //#region src/auth/NoAuth.ts
7
+ /**
8
+ * @since 0.0.1
9
+ * No authentication implementation for Mimic connections.
10
+ * All connections are automatically authenticated (open access).
11
+ */
12
+ var NoAuth_exports = /* @__PURE__ */ __export({
13
+ layer: () => layer,
14
+ layerDefault: () => layerDefault
15
+ });
16
+ /**
17
+ * Authentication service that auto-succeeds all authentication requests.
18
+ * Use this for development or when authentication is handled externally.
19
+ */
20
+ const noAuthService = { authenticate: (_token) => Effect.succeed({ success: true }) };
21
+ /**
22
+ * Layer that provides no authentication (open access).
23
+ * All connections are automatically authenticated.
24
+ *
25
+ * WARNING: Only use this for development or when authentication
26
+ * is handled at a different layer (e.g., API gateway, reverse proxy).
27
+ */
28
+ const layer = Layer.succeed(MimicAuthServiceTag, noAuthService);
29
+ /**
30
+ * Default layer alias for convenience.
31
+ */
32
+ const layerDefault = layer;
33
+
34
+ //#endregion
35
+ export { NoAuth_exports, layerDefault };
36
+ //# sourceMappingURL=NoAuth.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NoAuth.mjs","names":["noAuthService: MimicAuthService","layer: Layer.Layer<MimicAuthServiceTag>"],"sources":["../../src/auth/NoAuth.ts"],"sourcesContent":["/**\n * @since 0.0.1\n * No authentication implementation for Mimic connections.\n * All connections are automatically authenticated (open access).\n */\nimport * as Effect from \"effect/Effect\";\nimport * as Layer from \"effect/Layer\";\n\nimport {\n MimicAuthServiceTag,\n type MimicAuthService,\n} from \"../MimicAuthService.js\";\n\n// =============================================================================\n// No-Auth Implementation\n// =============================================================================\n\n/**\n * Authentication service that auto-succeeds all authentication requests.\n * Use this for development or when authentication is handled externally.\n */\nconst noAuthService: MimicAuthService = {\n authenticate: (_token: string) =>\n Effect.succeed({ success: true as const }),\n};\n\n// =============================================================================\n// Layer\n// =============================================================================\n\n/**\n * Layer that provides no authentication (open access).\n * All connections are automatically authenticated.\n * \n * WARNING: Only use this for development or when authentication\n * is handled at a different layer (e.g., API gateway, reverse proxy).\n */\nexport const layer: Layer.Layer<MimicAuthServiceTag> = Layer.succeed(\n MimicAuthServiceTag,\n noAuthService\n);\n\n/**\n * Default layer alias for convenience.\n */\nexport const layerDefault = layer;\n"],"mappings":";;;;;;;;;;;;;;;;;;;AAqBA,MAAMA,gBAAkC,EACtC,eAAe,WACb,OAAO,QAAQ,EAAE,SAAS,MAAe,CAAC,EAC7C;;;;;;;;AAaD,MAAaC,QAA0C,MAAM,QAC3D,qBACA,cACD;;;;AAKD,MAAa,eAAe"}
@@ -0,0 +1,74 @@
1
+ const require_rolldown_runtime = require('./_virtual/rolldown_runtime.cjs');
2
+ let effect_Data = require("effect/Data");
3
+ effect_Data = require_rolldown_runtime.__toESM(effect_Data);
4
+
5
+ //#region src/errors.ts
6
+ /**
7
+ * @since 0.0.1
8
+ * Error types for the Mimic server.
9
+ */
10
+ /**
11
+ * Error when a document type is not found in the schema registry.
12
+ */
13
+ var DocumentTypeNotFoundError = class extends effect_Data.TaggedError("DocumentTypeNotFoundError") {
14
+ get message() {
15
+ return `Document type not found: ${this.documentType}`;
16
+ }
17
+ };
18
+ /**
19
+ * Error when a document is not found.
20
+ */
21
+ var DocumentNotFoundError = class extends effect_Data.TaggedError("DocumentNotFoundError") {
22
+ get message() {
23
+ return `Document not found: ${this.documentId}`;
24
+ }
25
+ };
26
+ /**
27
+ * Error when authentication fails.
28
+ */
29
+ var AuthenticationError = class extends effect_Data.TaggedError("AuthenticationError") {
30
+ get message() {
31
+ return `Authentication failed: ${this.reason}`;
32
+ }
33
+ };
34
+ /**
35
+ * Error when a transaction is rejected.
36
+ */
37
+ var TransactionRejectedError = class extends effect_Data.TaggedError("TransactionRejectedError") {
38
+ get message() {
39
+ return `Transaction ${this.transactionId} rejected: ${this.reason}`;
40
+ }
41
+ };
42
+ /**
43
+ * Error when parsing a client message fails.
44
+ */
45
+ var MessageParseError = class extends effect_Data.TaggedError("MessageParseError") {
46
+ get message() {
47
+ return `Failed to parse message: ${String(this.cause)}`;
48
+ }
49
+ };
50
+ /**
51
+ * Error when the WebSocket connection is invalid.
52
+ */
53
+ var InvalidConnectionError = class extends effect_Data.TaggedError("InvalidConnectionError") {
54
+ get message() {
55
+ return `Invalid connection: ${this.reason}`;
56
+ }
57
+ };
58
+ /**
59
+ * Error when the document ID is missing from the URL path.
60
+ */
61
+ var MissingDocumentIdError = class extends effect_Data.TaggedError("MissingDocumentIdError") {
62
+ get message() {
63
+ return this.path ? `Document ID is required in the URL path: ${this.path}` : "Document ID is required in the URL path";
64
+ }
65
+ };
66
+
67
+ //#endregion
68
+ exports.AuthenticationError = AuthenticationError;
69
+ exports.DocumentNotFoundError = DocumentNotFoundError;
70
+ exports.DocumentTypeNotFoundError = DocumentTypeNotFoundError;
71
+ exports.InvalidConnectionError = InvalidConnectionError;
72
+ exports.MessageParseError = MessageParseError;
73
+ exports.MissingDocumentIdError = MissingDocumentIdError;
74
+ exports.TransactionRejectedError = TransactionRejectedError;
@@ -0,0 +1,89 @@
1
+ import * as effect_Types0 from "effect/Types";
2
+ import * as effect_Cause0 from "effect/Cause";
3
+
4
+ //#region src/errors.d.ts
5
+ declare const DocumentTypeNotFoundError_base: new <A extends Record<string, any> = {}>(args: effect_Types0.Equals<A, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" ? never : P]: A[P] }) => effect_Cause0.YieldableError & {
6
+ readonly _tag: "DocumentTypeNotFoundError";
7
+ } & Readonly<A>;
8
+ /**
9
+ * Error when a document type is not found in the schema registry.
10
+ */
11
+ declare class DocumentTypeNotFoundError extends DocumentTypeNotFoundError_base<{
12
+ readonly documentType: string;
13
+ }> {
14
+ get message(): string;
15
+ }
16
+ declare const DocumentNotFoundError_base: new <A extends Record<string, any> = {}>(args: effect_Types0.Equals<A, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" ? never : P]: A[P] }) => effect_Cause0.YieldableError & {
17
+ readonly _tag: "DocumentNotFoundError";
18
+ } & Readonly<A>;
19
+ /**
20
+ * Error when a document is not found.
21
+ */
22
+ declare class DocumentNotFoundError extends DocumentNotFoundError_base<{
23
+ readonly documentId: string;
24
+ }> {
25
+ get message(): string;
26
+ }
27
+ declare const AuthenticationError_base: new <A extends Record<string, any> = {}>(args: effect_Types0.Equals<A, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" ? never : P]: A[P] }) => effect_Cause0.YieldableError & {
28
+ readonly _tag: "AuthenticationError";
29
+ } & Readonly<A>;
30
+ /**
31
+ * Error when authentication fails.
32
+ */
33
+ declare class AuthenticationError extends AuthenticationError_base<{
34
+ readonly reason: string;
35
+ }> {
36
+ get message(): string;
37
+ }
38
+ declare const TransactionRejectedError_base: new <A extends Record<string, any> = {}>(args: effect_Types0.Equals<A, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" ? never : P]: A[P] }) => effect_Cause0.YieldableError & {
39
+ readonly _tag: "TransactionRejectedError";
40
+ } & Readonly<A>;
41
+ /**
42
+ * Error when a transaction is rejected.
43
+ */
44
+ declare class TransactionRejectedError extends TransactionRejectedError_base<{
45
+ readonly transactionId: string;
46
+ readonly reason: string;
47
+ }> {
48
+ get message(): string;
49
+ }
50
+ declare const MessageParseError_base: new <A extends Record<string, any> = {}>(args: effect_Types0.Equals<A, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" ? never : P]: A[P] }) => effect_Cause0.YieldableError & {
51
+ readonly _tag: "MessageParseError";
52
+ } & Readonly<A>;
53
+ /**
54
+ * Error when parsing a client message fails.
55
+ */
56
+ declare class MessageParseError extends MessageParseError_base<{
57
+ readonly cause: unknown;
58
+ }> {
59
+ get message(): string;
60
+ }
61
+ declare const InvalidConnectionError_base: new <A extends Record<string, any> = {}>(args: effect_Types0.Equals<A, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" ? never : P]: A[P] }) => effect_Cause0.YieldableError & {
62
+ readonly _tag: "InvalidConnectionError";
63
+ } & Readonly<A>;
64
+ /**
65
+ * Error when the WebSocket connection is invalid.
66
+ */
67
+ declare class InvalidConnectionError extends InvalidConnectionError_base<{
68
+ readonly reason: string;
69
+ }> {
70
+ get message(): string;
71
+ }
72
+ declare const MissingDocumentIdError_base: new <A extends Record<string, any> = {}>(args: effect_Types0.Equals<A, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" ? never : P]: A[P] }) => effect_Cause0.YieldableError & {
73
+ readonly _tag: "MissingDocumentIdError";
74
+ } & Readonly<A>;
75
+ /**
76
+ * Error when the document ID is missing from the URL path.
77
+ */
78
+ declare class MissingDocumentIdError extends MissingDocumentIdError_base<{
79
+ readonly path?: string;
80
+ }> {
81
+ get message(): string;
82
+ }
83
+ /**
84
+ * Union of all Mimic server errors.
85
+ */
86
+ type MimicServerError = DocumentTypeNotFoundError | DocumentNotFoundError | AuthenticationError | TransactionRejectedError | MessageParseError | InvalidConnectionError | MissingDocumentIdError;
87
+ //#endregion
88
+ export { AuthenticationError, DocumentNotFoundError, DocumentTypeNotFoundError, InvalidConnectionError, MessageParseError, MimicServerError, MissingDocumentIdError, TransactionRejectedError };
89
+ //# sourceMappingURL=errors.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.cts","names":[],"sources":["../src/errors.ts"],"sourcesContent":[],"mappings":";;;;;;;;;;cAaa,yBAAA,SAAkC;;;;;cAQ9C;;;;;;AARY,cAaA,qBAAA,SAA8B,0BAbI,CAAA;EAQ9C,SAAA,UAAA,EAAA,MAAA;;;;cAaA;;;;;;cAKY,mBAAA,SAA4B;;;EAb5B,IAAA,OAAA,CAAA,CAAA,EAAA,MAAA;AAQZ;cAaA;;;;;;cAKY,wBAAA,SAAiC;;;;;;AAb9C,cAsBC,sBAtBgC,EAAQ,IAAA,CAAA,gBAAA,CAAA,MAAA,EAAA,GAAA,CAAA,GAAA,CAAA,CAAA,CAAA,CAAA,IAAA,sBAAA,EAAA,EAAA,CAAA,CAAA,CAAA,SAAA,IAAA,GAAA,IAAA,GAAA,iBAAA,OAAA,KAAA,SAAA,MAAA,GAAA,KAAA,IAAA,IAAA,EAAA,CAAA,EAAA,EAAA,kCAAA;EAQxC,SAAA,IAAA,EAAA,mBAAA;;;;;cAmBY,iBAAA,SAA0B;;;;;cAMtC;;;AApBD;AASC;;cAgBY,sBAAA,SAA+B;;;;;cAQ3C;;;;;;AAnBY,cAwBA,sBAAA,SAA+B,2BAxBL,CAAA;EAMtC,SAAA,IAAA,CAAA,EAAA,MAAA;;;;;;;KAiCW,gBAAA,GACR,4BACA,wBACA,sBACA,2BACA,oBACA,yBACA"}
@@ -0,0 +1,89 @@
1
+ import * as effect_Types0 from "effect/Types";
2
+ import * as effect_Cause0 from "effect/Cause";
3
+
4
+ //#region src/errors.d.ts
5
+ declare const DocumentTypeNotFoundError_base: new <A extends Record<string, any> = {}>(args: effect_Types0.Equals<A, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" ? never : P]: A[P] }) => effect_Cause0.YieldableError & {
6
+ readonly _tag: "DocumentTypeNotFoundError";
7
+ } & Readonly<A>;
8
+ /**
9
+ * Error when a document type is not found in the schema registry.
10
+ */
11
+ declare class DocumentTypeNotFoundError extends DocumentTypeNotFoundError_base<{
12
+ readonly documentType: string;
13
+ }> {
14
+ get message(): string;
15
+ }
16
+ declare const DocumentNotFoundError_base: new <A extends Record<string, any> = {}>(args: effect_Types0.Equals<A, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" ? never : P]: A[P] }) => effect_Cause0.YieldableError & {
17
+ readonly _tag: "DocumentNotFoundError";
18
+ } & Readonly<A>;
19
+ /**
20
+ * Error when a document is not found.
21
+ */
22
+ declare class DocumentNotFoundError extends DocumentNotFoundError_base<{
23
+ readonly documentId: string;
24
+ }> {
25
+ get message(): string;
26
+ }
27
+ declare const AuthenticationError_base: new <A extends Record<string, any> = {}>(args: effect_Types0.Equals<A, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" ? never : P]: A[P] }) => effect_Cause0.YieldableError & {
28
+ readonly _tag: "AuthenticationError";
29
+ } & Readonly<A>;
30
+ /**
31
+ * Error when authentication fails.
32
+ */
33
+ declare class AuthenticationError extends AuthenticationError_base<{
34
+ readonly reason: string;
35
+ }> {
36
+ get message(): string;
37
+ }
38
+ declare const TransactionRejectedError_base: new <A extends Record<string, any> = {}>(args: effect_Types0.Equals<A, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" ? never : P]: A[P] }) => effect_Cause0.YieldableError & {
39
+ readonly _tag: "TransactionRejectedError";
40
+ } & Readonly<A>;
41
+ /**
42
+ * Error when a transaction is rejected.
43
+ */
44
+ declare class TransactionRejectedError extends TransactionRejectedError_base<{
45
+ readonly transactionId: string;
46
+ readonly reason: string;
47
+ }> {
48
+ get message(): string;
49
+ }
50
+ declare const MessageParseError_base: new <A extends Record<string, any> = {}>(args: effect_Types0.Equals<A, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" ? never : P]: A[P] }) => effect_Cause0.YieldableError & {
51
+ readonly _tag: "MessageParseError";
52
+ } & Readonly<A>;
53
+ /**
54
+ * Error when parsing a client message fails.
55
+ */
56
+ declare class MessageParseError extends MessageParseError_base<{
57
+ readonly cause: unknown;
58
+ }> {
59
+ get message(): string;
60
+ }
61
+ declare const InvalidConnectionError_base: new <A extends Record<string, any> = {}>(args: effect_Types0.Equals<A, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" ? never : P]: A[P] }) => effect_Cause0.YieldableError & {
62
+ readonly _tag: "InvalidConnectionError";
63
+ } & Readonly<A>;
64
+ /**
65
+ * Error when the WebSocket connection is invalid.
66
+ */
67
+ declare class InvalidConnectionError extends InvalidConnectionError_base<{
68
+ readonly reason: string;
69
+ }> {
70
+ get message(): string;
71
+ }
72
+ declare const MissingDocumentIdError_base: new <A extends Record<string, any> = {}>(args: effect_Types0.Equals<A, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" ? never : P]: A[P] }) => effect_Cause0.YieldableError & {
73
+ readonly _tag: "MissingDocumentIdError";
74
+ } & Readonly<A>;
75
+ /**
76
+ * Error when the document ID is missing from the URL path.
77
+ */
78
+ declare class MissingDocumentIdError extends MissingDocumentIdError_base<{
79
+ readonly path?: string;
80
+ }> {
81
+ get message(): string;
82
+ }
83
+ /**
84
+ * Union of all Mimic server errors.
85
+ */
86
+ type MimicServerError = DocumentTypeNotFoundError | DocumentNotFoundError | AuthenticationError | TransactionRejectedError | MessageParseError | InvalidConnectionError | MissingDocumentIdError;
87
+ //#endregion
88
+ export { AuthenticationError, DocumentNotFoundError, DocumentTypeNotFoundError, InvalidConnectionError, MessageParseError, MimicServerError, MissingDocumentIdError, TransactionRejectedError };
89
+ //# sourceMappingURL=errors.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.mts","names":[],"sources":["../src/errors.ts"],"sourcesContent":[],"mappings":";;;;;;;;;;cAaa,yBAAA,SAAkC;;;;;cAQ9C;;;;;;AARY,cAaA,qBAAA,SAA8B,0BAbI,CAAA;EAQ9C,SAAA,UAAA,EAAA,MAAA;;;;cAaA;;;;;;cAKY,mBAAA,SAA4B;;;EAb5B,IAAA,OAAA,CAAA,CAAA,EAAA,MAAA;AAQZ;cAaA;;;;;;cAKY,wBAAA,SAAiC;;;;;;AAb9C,cAsBC,sBAtBgC,EAAQ,IAAA,CAAA,gBAAA,CAAA,MAAA,EAAA,GAAA,CAAA,GAAA,CAAA,CAAA,CAAA,CAAA,IAAA,sBAAA,EAAA,EAAA,CAAA,CAAA,CAAA,SAAA,IAAA,GAAA,IAAA,GAAA,iBAAA,OAAA,KAAA,SAAA,MAAA,GAAA,KAAA,IAAA,IAAA,EAAA,CAAA,EAAA,EAAA,kCAAA;EAQxC,SAAA,IAAA,EAAA,mBAAA;;;;;cAmBY,iBAAA,SAA0B;;;;;cAMtC;;;AApBD;AASC;;cAgBY,sBAAA,SAA+B;;;;;cAQ3C;;;;;;AAnBY,cAwBA,sBAAA,SAA+B,2BAxBL,CAAA;EAMtC,SAAA,IAAA,CAAA,EAAA,MAAA;;;;;;;KAiCW,gBAAA,GACR,4BACA,wBACA,sBACA,2BACA,oBACA,yBACA"}
@@ -0,0 +1,67 @@
1
+ import * as Data from "effect/Data";
2
+
3
+ //#region src/errors.ts
4
+ /**
5
+ * @since 0.0.1
6
+ * Error types for the Mimic server.
7
+ */
8
+ /**
9
+ * Error when a document type is not found in the schema registry.
10
+ */
11
+ var DocumentTypeNotFoundError = class extends Data.TaggedError("DocumentTypeNotFoundError") {
12
+ get message() {
13
+ return `Document type not found: ${this.documentType}`;
14
+ }
15
+ };
16
+ /**
17
+ * Error when a document is not found.
18
+ */
19
+ var DocumentNotFoundError = class extends Data.TaggedError("DocumentNotFoundError") {
20
+ get message() {
21
+ return `Document not found: ${this.documentId}`;
22
+ }
23
+ };
24
+ /**
25
+ * Error when authentication fails.
26
+ */
27
+ var AuthenticationError = class extends Data.TaggedError("AuthenticationError") {
28
+ get message() {
29
+ return `Authentication failed: ${this.reason}`;
30
+ }
31
+ };
32
+ /**
33
+ * Error when a transaction is rejected.
34
+ */
35
+ var TransactionRejectedError = class extends Data.TaggedError("TransactionRejectedError") {
36
+ get message() {
37
+ return `Transaction ${this.transactionId} rejected: ${this.reason}`;
38
+ }
39
+ };
40
+ /**
41
+ * Error when parsing a client message fails.
42
+ */
43
+ var MessageParseError = class extends Data.TaggedError("MessageParseError") {
44
+ get message() {
45
+ return `Failed to parse message: ${String(this.cause)}`;
46
+ }
47
+ };
48
+ /**
49
+ * Error when the WebSocket connection is invalid.
50
+ */
51
+ var InvalidConnectionError = class extends Data.TaggedError("InvalidConnectionError") {
52
+ get message() {
53
+ return `Invalid connection: ${this.reason}`;
54
+ }
55
+ };
56
+ /**
57
+ * Error when the document ID is missing from the URL path.
58
+ */
59
+ var MissingDocumentIdError = class extends Data.TaggedError("MissingDocumentIdError") {
60
+ get message() {
61
+ return this.path ? `Document ID is required in the URL path: ${this.path}` : "Document ID is required in the URL path";
62
+ }
63
+ };
64
+
65
+ //#endregion
66
+ export { AuthenticationError, DocumentNotFoundError, DocumentTypeNotFoundError, InvalidConnectionError, MessageParseError, MissingDocumentIdError, TransactionRejectedError };
67
+ //# sourceMappingURL=errors.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.mjs","names":[],"sources":["../src/errors.ts"],"sourcesContent":["/**\n * @since 0.0.1\n * Error types for the Mimic server.\n */\nimport * as Data from \"effect/Data\";\n\n// =============================================================================\n// Error Types\n// =============================================================================\n\n/**\n * Error when a document type is not found in the schema registry.\n */\nexport class DocumentTypeNotFoundError extends Data.TaggedError(\n \"DocumentTypeNotFoundError\"\n)<{\n readonly documentType: string;\n}> {\n override get message(): string {\n return `Document type not found: ${this.documentType}`;\n }\n}\n\n/**\n * Error when a document is not found.\n */\nexport class DocumentNotFoundError extends Data.TaggedError(\n \"DocumentNotFoundError\"\n)<{\n readonly documentId: string;\n}> {\n override get message(): string {\n return `Document not found: ${this.documentId}`;\n }\n}\n\n/**\n * Error when authentication fails.\n */\nexport class AuthenticationError extends Data.TaggedError(\n \"AuthenticationError\"\n)<{\n readonly reason: string;\n}> {\n override get message(): string {\n return `Authentication failed: ${this.reason}`;\n }\n}\n\n/**\n * Error when a transaction is rejected.\n */\nexport class TransactionRejectedError extends Data.TaggedError(\n \"TransactionRejectedError\"\n)<{\n readonly transactionId: string;\n readonly reason: string;\n}> {\n override get message(): string {\n return `Transaction ${this.transactionId} rejected: ${this.reason}`;\n }\n}\n\n/**\n * Error when parsing a client message fails.\n */\nexport class MessageParseError extends Data.TaggedError(\"MessageParseError\")<{\n readonly cause: unknown;\n}> {\n override get message(): string {\n return `Failed to parse message: ${String(this.cause)}`;\n }\n}\n\n/**\n * Error when the WebSocket connection is invalid.\n */\nexport class InvalidConnectionError extends Data.TaggedError(\n \"InvalidConnectionError\"\n)<{\n readonly reason: string;\n}> {\n override get message(): string {\n return `Invalid connection: ${this.reason}`;\n }\n}\n\n/**\n * Error when the document ID is missing from the URL path.\n */\nexport class MissingDocumentIdError extends Data.TaggedError(\n \"MissingDocumentIdError\"\n)<{\n readonly path?: string;\n}> {\n override get message(): string {\n return this.path \n ? `Document ID is required in the URL path: ${this.path}`\n : \"Document ID is required in the URL path\";\n }\n}\n\n/**\n * Union of all Mimic server errors.\n */\nexport type MimicServerError =\n | DocumentTypeNotFoundError\n | DocumentNotFoundError\n | AuthenticationError\n | TransactionRejectedError\n | MessageParseError\n | InvalidConnectionError\n | MissingDocumentIdError;\n"],"mappings":";;;;;;;;;;AAaA,IAAa,4BAAb,cAA+C,KAAK,YAClD,4BACD,CAEE;CACD,IAAa,UAAkB;AAC7B,SAAO,4BAA4B,KAAK;;;;;;AAO5C,IAAa,wBAAb,cAA2C,KAAK,YAC9C,wBACD,CAEE;CACD,IAAa,UAAkB;AAC7B,SAAO,uBAAuB,KAAK;;;;;;AAOvC,IAAa,sBAAb,cAAyC,KAAK,YAC5C,sBACD,CAEE;CACD,IAAa,UAAkB;AAC7B,SAAO,0BAA0B,KAAK;;;;;;AAO1C,IAAa,2BAAb,cAA8C,KAAK,YACjD,2BACD,CAGE;CACD,IAAa,UAAkB;AAC7B,SAAO,eAAe,KAAK,cAAc,aAAa,KAAK;;;;;;AAO/D,IAAa,oBAAb,cAAuC,KAAK,YAAY,oBAAoB,CAEzE;CACD,IAAa,UAAkB;AAC7B,SAAO,4BAA4B,OAAO,KAAK,MAAM;;;;;;AAOzD,IAAa,yBAAb,cAA4C,KAAK,YAC/C,yBACD,CAEE;CACD,IAAa,UAAkB;AAC7B,SAAO,uBAAuB,KAAK;;;;;;AAOvC,IAAa,yBAAb,cAA4C,KAAK,YAC/C,yBACD,CAEE;CACD,IAAa,UAAkB;AAC7B,SAAO,KAAK,OACR,4CAA4C,KAAK,SACjD"}