@tstdl/base 0.93.77 → 0.93.80

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/authentication/client/http-client.middleware.js +2 -2
  2. package/authentication/models/authentication-credentials.model.d.ts +2 -2
  3. package/authentication/models/authentication-credentials.model.js +5 -3
  4. package/authentication/models/authentication-session.model.d.ts +2 -2
  5. package/authentication/models/authentication-session.model.js +5 -3
  6. package/authentication/models/index.d.ts +4 -0
  7. package/authentication/models/index.js +4 -0
  8. package/authentication/models/service-account.model.d.ts +7 -0
  9. package/authentication/models/service-account.model.js +31 -0
  10. package/authentication/models/subject.model.d.ts +16 -0
  11. package/authentication/models/subject.model.js +59 -0
  12. package/authentication/models/system-account.model.d.ts +5 -0
  13. package/authentication/models/system-account.model.js +25 -0
  14. package/authentication/models/user.model.d.ts +15 -0
  15. package/authentication/models/user.model.js +47 -0
  16. package/authentication/server/drizzle/0000_violet_callisto.sql +99 -0
  17. package/authentication/server/drizzle/meta/0000_snapshot.json +500 -6
  18. package/authentication/server/drizzle/meta/_journal.json +2 -2
  19. package/authentication/server/index.d.ts +1 -0
  20. package/authentication/server/index.js +1 -0
  21. package/authentication/server/schemas.d.ts +16 -1
  22. package/authentication/server/schemas.js +7 -1
  23. package/authentication/server/subject.service.d.ts +6 -0
  24. package/authentication/server/subject.service.js +44 -0
  25. package/circuit-breaker/circuit-breaker.d.ts +32 -0
  26. package/circuit-breaker/circuit-breaker.js +9 -0
  27. package/circuit-breaker/index.d.ts +2 -0
  28. package/circuit-breaker/index.js +2 -0
  29. package/circuit-breaker/postgres/circuit-breaker.d.ts +7 -0
  30. package/circuit-breaker/postgres/circuit-breaker.js +78 -0
  31. package/circuit-breaker/postgres/drizzle/0000_hard_shocker.sql +9 -0
  32. package/circuit-breaker/postgres/drizzle/meta/0000_snapshot.json +82 -0
  33. package/circuit-breaker/postgres/drizzle/meta/_journal.json +13 -0
  34. package/circuit-breaker/postgres/drizzle.config.d.ts +2 -0
  35. package/circuit-breaker/postgres/drizzle.config.js +11 -0
  36. package/circuit-breaker/postgres/index.d.ts +5 -0
  37. package/circuit-breaker/postgres/index.js +5 -0
  38. package/circuit-breaker/postgres/model.d.ts +9 -0
  39. package/circuit-breaker/postgres/model.js +40 -0
  40. package/circuit-breaker/postgres/module.d.ts +6 -0
  41. package/circuit-breaker/postgres/module.js +25 -0
  42. package/circuit-breaker/postgres/provider.d.ts +6 -0
  43. package/circuit-breaker/postgres/provider.js +21 -0
  44. package/circuit-breaker/postgres/schemas.d.ts +8 -0
  45. package/circuit-breaker/postgres/schemas.js +6 -0
  46. package/circuit-breaker/provider.d.ts +4 -0
  47. package/circuit-breaker/provider.js +2 -0
  48. package/circuit-breaker/tests/circuit-breaker.test.js +113 -0
  49. package/document-management/models/document.model.d.ts +0 -1
  50. package/document-management/models/document.model.js +0 -5
  51. package/document-management/server/api/document-management.api.js +1 -2
  52. package/document-management/server/drizzle/{0000_ordinary_pretty_boy.sql → 0000_glamorous_lorna_dane.sql} +96 -76
  53. package/document-management/server/drizzle/meta/0000_snapshot.json +360 -142
  54. package/document-management/server/drizzle/meta/_journal.json +2 -9
  55. package/document-management/server/services/document-collection.service.js +3 -3
  56. package/document-management/server/services/document-management-ancillary.service.d.ts +1 -1
  57. package/document-management/server/services/document-management.service.js +1 -1
  58. package/document-management/server/services/document-workflow.service.js +5 -5
  59. package/document-management/server/services/document.service.d.ts +0 -2
  60. package/document-management/server/services/document.service.js +1 -2
  61. package/document-management/service-models/enriched/enriched-document.view.d.ts +1 -1
  62. package/examples/document-management/main.d.ts +1 -1
  63. package/examples/document-management/main.js +1 -1
  64. package/logger/transports/console.d.ts +1 -1
  65. package/logger/transports/console.js +4 -1
  66. package/message-bus/message-bus-base.js +1 -1
  67. package/orm/server/drizzle/schema-converter.js +53 -32
  68. package/package.json +6 -3
  69. package/queue/enqueue-batch.d.ts +11 -11
  70. package/queue/enqueue-batch.js +2 -3
  71. package/queue/index.d.ts +1 -0
  72. package/queue/index.js +1 -0
  73. package/queue/postgres/drizzle/0003_tricky_venom.sql +30 -0
  74. package/queue/postgres/drizzle/meta/0003_snapshot.json +288 -0
  75. package/queue/postgres/drizzle/meta/_journal.json +7 -0
  76. package/queue/postgres/drizzle.config.js +2 -2
  77. package/queue/postgres/index.d.ts +1 -1
  78. package/queue/postgres/index.js +1 -1
  79. package/queue/postgres/module.d.ts +1 -1
  80. package/queue/postgres/module.js +1 -1
  81. package/queue/postgres/queue.d.ts +52 -23
  82. package/queue/postgres/queue.js +582 -64
  83. package/queue/postgres/queue.provider.d.ts +1 -1
  84. package/queue/postgres/schemas.d.ts +13 -2
  85. package/queue/postgres/schemas.js +4 -2
  86. package/queue/postgres/task.model.d.ts +24 -0
  87. package/queue/postgres/task.model.js +115 -0
  88. package/queue/provider.d.ts +1 -1
  89. package/queue/queue.d.ts +158 -37
  90. package/queue/queue.js +97 -19
  91. package/queue/task-context.d.ts +38 -0
  92. package/queue/task-context.js +102 -0
  93. package/queue/tests/queue.test.d.ts +1 -0
  94. package/queue/tests/queue.test.js +623 -0
  95. package/test4.d.ts +1 -1
  96. package/test4.js +1 -1
  97. package/utils/format-error.d.ts +17 -20
  98. package/utils/format-error.js +105 -47
  99. package/authentication/server/drizzle/0000_calm_warlock.sql +0 -28
  100. package/document-management/server/drizzle/0001_lyrical_wong.sql +0 -123
  101. package/document-management/server/drizzle/meta/0001_snapshot.json +0 -2728
  102. package/queue/postgres/job.model.d.ts +0 -12
  103. package/queue/postgres/job.model.js +0 -53
  104. package/test6.js +0 -33
  105. /package/{test6.d.ts → circuit-breaker/tests/circuit-breaker.test.d.ts} +0 -0
@@ -1,31 +1,28 @@
1
- import type { UndefinableJson } from '../types/index.js';
1
+ import type { Record, UndefinableJson } from '../types/index.js';
2
2
  export type FormatErrorOptions = {
3
- /**
4
- * Include error name in message
5
- */
3
+ /** Include error name in message */
6
4
  includeName?: boolean;
7
- /**
8
- * Include all error properties beside name and message
9
- */
5
+ /** Include all error properties beside name and message */
10
6
  includeRest?: boolean | 'if-no-extra-info';
11
- /**
12
- * Include extraInfo from errors implementing {@link ErrorExtraInfo}
13
- */
7
+ /** Include extraInfo from errors implementing {@link ErrorExtraInfo} */
14
8
  includeExtraInfo?: boolean;
15
- /**
16
- * Include stack trace
17
- */
9
+ /** Include stack trace */
18
10
  includeStack?: boolean;
19
- /**
20
- * Maximum recursion depth for nested causes and aggregate errors (default: 5)
21
- */
11
+ /** Maximum recursion depth for nested causes and aggregate errors (default: 5) */
22
12
  depth?: number;
23
13
  };
14
+ export type SerializedError = {
15
+ name?: string;
16
+ message: string;
17
+ rest?: Record;
18
+ extraInfo?: UndefinableJson;
19
+ stack?: string;
20
+ cause?: SerializedError;
21
+ aggregateErrors?: SerializedError[];
22
+ };
24
23
  export interface ErrorExtraInfo {
25
24
  /** Format extra data (without message and stack) as JSON */
26
25
  getExtraInfo(): UndefinableJson | undefined;
27
26
  }
28
- /**
29
- * Enhanced error formatting
30
- */
31
- export declare function formatError(error: any, options?: FormatErrorOptions): string;
27
+ export declare function serializeError(error: unknown, options?: FormatErrorOptions): SerializedError;
28
+ export declare function formatError(error: unknown, options?: FormatErrorOptions): string;
@@ -2,76 +2,134 @@ import { unwrapError } from '../errors/utils.js';
2
2
  import { decycle } from './object/decycle.js';
3
3
  import { objectKeys } from './object/object.js';
4
4
  import { tryChain } from './try-chain.js';
5
- import { isArray, isDefined, isFunction, isObject, isUndefined } from './type-guards.js';
6
- /**
7
- * Enhanced error formatting
8
- */
9
- export function formatError(error, options = {}) {
5
+ import { isArray, isDefined, isFunction, isObject, isString, isUndefined } from './type-guards.js';
6
+ export function serializeError(error, options = {}) {
10
7
  const { includeName = true, includeRest = 'if-no-extra-info', includeExtraInfo = true, includeStack = true, depth = 5, } = options;
11
8
  if (depth <= 0) {
12
- return '[Max recursion depth reached]';
9
+ return { message: '[Max recursion depth reached]' };
13
10
  }
14
11
  const actualError = unwrapError(error);
12
+ // 1. Initial Property Extraction
15
13
  let name;
16
14
  let message;
17
15
  let stack;
18
- let rest;
19
- let extraInfo;
20
16
  let cause;
21
17
  let aggregateErrors;
18
+ let extraInfo;
19
+ let rest;
20
+ // Track if we treat this as a raw object (affects default name logic)
21
+ let isRawObjectFallback = false;
22
22
  if (isObject(actualError)) {
23
- if (actualError instanceof Error) {
24
- ({ name, message, stack, cause, ...rest } = actualError);
25
- if (actualError instanceof AggregateError) {
26
- aggregateErrors = actualError.errors;
27
- }
23
+ const errObj = actualError;
24
+ // Extract standard properties
25
+ name = isString(errObj.name) ? errObj.name : undefined;
26
+ message = isString(errObj.message) ? errObj.message : undefined;
27
+ stack = isString(errObj.stack) ? errObj.stack : undefined;
28
+ cause = errObj.cause;
29
+ if (actualError instanceof AggregateError) {
30
+ aggregateErrors = actualError.errors;
28
31
  }
29
- else {
30
- // Handle plain objects that might have error-like properties
31
- ({ name, message, stack, cause, ...rest } = actualError);
32
- }
33
- // Check for extra info (duck-typing)
34
- if (includeExtraInfo && isFunction(actualError.getExtraInfo)) { // eslint-disable-line @typescript-eslint/unbound-method
32
+ // Extract Extra Info
33
+ if (includeExtraInfo && isFunction(actualError.getExtraInfo)) {
35
34
  extraInfo = actualError.getExtraInfo();
36
35
  }
36
+ // Isolate 'rest' properties via destructuring
37
+ const { name: _n, message: _m, stack: _s, cause: _c, errors: _agg, ...restObj } = errObj;
38
+ rest = restObj;
37
39
  }
38
- // If no message, serialize the whole object as a fallback
39
- if (isUndefined(message) || (String(message).trim().length == 0)) { // eslint-disable-line @typescript-eslint/no-unnecessary-type-conversion
40
- // Handle primitives directly
41
- if (!isObject(actualError)) {
42
- message = String(actualError);
40
+ else {
41
+ // Primitive types (string, number, etc.)
42
+ message = String(actualError);
43
+ }
44
+ // 2. Message Normalization & Fallback Logic
45
+ const hasEmptyMessage = isUndefined(message) || (String(message).trim().length == 0);
46
+ if (hasEmptyMessage) {
47
+ if (actualError instanceof Error) {
48
+ // Standard Error with empty message: keep name, keep rest, ensure message is string
49
+ message = '';
43
50
  }
44
- else {
51
+ else if (isObject(actualError)) {
52
+ // Plain Object (e.g. { code: 500 }): Serialize entire object into message
45
53
  message = tryChain([
46
- () => JSON.stringify(actualError, null, 2), // Try normal serialization first
47
- () => {
48
- // Fallback with decycle for objects with circular references
49
- const decycledError = decycle(actualError);
50
- return JSON.stringify(decycledError, null, 2);
51
- },
54
+ () => JSON.stringify(actualError, null, 2),
55
+ () => JSON.stringify(decycle(actualError), null, 2),
52
56
  // eslint-disable-next-line @typescript-eslint/no-base-to-string
53
- () => `[Unstringifiable object: ${String(actualError)}]`, // Safe fallback if JSON.stringify still fails
57
+ () => `[Unstringifiable object: ${String(actualError)}]`,
54
58
  ]);
59
+ // Clear rest to avoid duplication since the whole object is now the message
60
+ rest = undefined;
61
+ // Flag as fallback to prevent defaulting name to "Error"
62
+ isRawObjectFallback = true;
63
+ }
64
+ else {
65
+ // Fallback for weird primitive edge cases (should be covered by initial String() conversion)
66
+ message = String(actualError);
55
67
  }
56
68
  }
57
- // --- String Assembly ---
58
- const nameString = includeName ? `${name ?? 'Error'}: ` : '';
59
- let restString = '';
60
- const shouldIncludeRest = (includeRest == true) || (includeRest == 'if-no-extra-info' && isUndefined(extraInfo));
61
- if (shouldIncludeRest && isDefined(rest) && objectKeys(rest).length > 0) {
62
- restString = `\n${JSON.stringify(decycle(rest), null, 2)}`;
69
+ // 3. Finalize Optional Properties
70
+ const shouldIncludeRest = includeRest === true || (includeRest === 'if-no-extra-info' && isUndefined(extraInfo));
71
+ const hasRest = isDefined(rest) && objectKeys(rest).length > 0;
72
+ // Determine Final Name
73
+ // If fallback (raw object) and no name exists, return undefined. Otherwise default to 'Error'.
74
+ const defaultName = isRawObjectFallback ? undefined : 'Error';
75
+ const finalName = includeName ? (name ?? defaultName) : undefined;
76
+ const nextOptions = { ...options, depth: depth - 1 };
77
+ return {
78
+ name: finalName,
79
+ message: message ?? '',
80
+ extraInfo: isDefined(extraInfo) ? extraInfo : undefined,
81
+ rest: shouldIncludeRest && hasRest ? decycle(rest) : undefined,
82
+ stack: (includeStack && isDefined(stack)) ? stack : undefined,
83
+ cause: (includeStack && cause)
84
+ ? serializeError(cause, nextOptions)
85
+ : undefined,
86
+ aggregateErrors: (isArray(aggregateErrors))
87
+ ? aggregateErrors.map((err) => serializeError(err, nextOptions))
88
+ : undefined,
89
+ };
90
+ }
91
+ export function formatError(error, options = {}) {
92
+ const serialized = serializeError(error, options);
93
+ return formatSerializedError(serialized, options);
94
+ }
95
+ function formatSerializedError(serialized, options) {
96
+ const { name, message, rest, extraInfo, stack, cause, aggregateErrors, } = serialized;
97
+ const { includeName = true, includeStack = true, depth = 5 } = options;
98
+ // 1. Header (Name: Message)
99
+ const prefix = includeName && name ? `${name}: ` : '';
100
+ const header = `${prefix}${message}`;
101
+ // 2. Body (Rest / Extra Info)
102
+ let body = '';
103
+ if (rest) {
104
+ body += `\n${JSON.stringify(rest, null, 2)}`;
105
+ }
106
+ if (extraInfo) {
107
+ body += `\n${JSON.stringify(extraInfo, null, 2)}`;
108
+ }
109
+ // 3. Stack Trace
110
+ let stackString = '';
111
+ if (includeStack && stack) {
112
+ // Deduplicate header if stack already starts with it (standard Node.js behavior)
113
+ if (stack.startsWith(header)) {
114
+ stackString = stack.slice(header.length);
115
+ }
116
+ else {
117
+ stackString = `\n${stack}`;
118
+ }
63
119
  }
64
- const extraInfoString = isDefined(extraInfo) ? `\n${JSON.stringify(extraInfo, null, 2)}` : '';
65
- const stackString = (includeStack && isDefined(stack)) ? `\n${stack}` : '';
66
- const causeString = includeStack && cause
67
- ? formatNestedError('Caused by:', cause, { ...options, depth: depth - 1 })
120
+ // 4. Recursion (Causes and Aggregate Errors)
121
+ const nextOptions = { ...options, depth: depth - 1 };
122
+ const causeString = (includeStack && cause)
123
+ ? formatNestedError('Caused by:', cause, nextOptions)
68
124
  : '';
69
- const aggregateErrorsString = isArray(aggregateErrors)
70
- ? aggregateErrors.map((err, i) => formatNestedError(`Sub-error #${i + 1}:`, err, { ...options, depth: depth - 1 })).join('')
125
+ const aggregateErrorsString = aggregateErrors
126
+ ? aggregateErrors
127
+ .map((err, i) => formatNestedError(`Sub-error #${i + 1}:`, err, nextOptions))
128
+ .join('')
71
129
  : '';
72
- return `${nameString}${message}${restString}${extraInfoString}${stackString}${causeString}${aggregateErrorsString}`;
130
+ return `${header}${body}${stackString}${causeString}${aggregateErrorsString}`;
73
131
  }
74
- function formatNestedError(prefix, error, options) {
75
- const formatted = formatError(error, options).replace(/\n/g, '\n ');
132
+ function formatNestedError(prefix, serializedError, options) {
133
+ const formatted = formatSerializedError(serializedError, options).replace(/\n/g, '\n ');
76
134
  return `\n\n${prefix}\n ${formatted}`;
77
135
  }
@@ -1,28 +0,0 @@
1
- CREATE TABLE "authentication"."credentials" (
2
- "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
3
- "subject" text NOT NULL,
4
- "hash_version" integer NOT NULL,
5
- "salt" "bytea" NOT NULL,
6
- "hash" "bytea" NOT NULL,
7
- "revision" integer NOT NULL,
8
- "revision_timestamp" timestamp with time zone NOT NULL,
9
- "create_timestamp" timestamp with time zone NOT NULL,
10
- "delete_timestamp" timestamp with time zone,
11
- "attributes" jsonb DEFAULT '{}'::jsonb NOT NULL,
12
- CONSTRAINT "credentials_subject_unique" UNIQUE("subject")
13
- );
14
- --> statement-breakpoint
15
- CREATE TABLE "authentication"."session" (
16
- "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
17
- "subject" text NOT NULL,
18
- "begin" timestamp with time zone NOT NULL,
19
- "end" timestamp with time zone NOT NULL,
20
- "refresh_token_hash_version" integer NOT NULL,
21
- "refresh_token_salt" "bytea" NOT NULL,
22
- "refresh_token_hash" "bytea" NOT NULL,
23
- "revision" integer NOT NULL,
24
- "revision_timestamp" timestamp with time zone NOT NULL,
25
- "create_timestamp" timestamp with time zone NOT NULL,
26
- "delete_timestamp" timestamp with time zone,
27
- "attributes" jsonb DEFAULT '{}'::jsonb NOT NULL
28
- );
@@ -1,123 +0,0 @@
1
- ALTER TABLE "document_management"."document" DROP CONSTRAINT "document_type_id_type_id_fk";
2
- --> statement-breakpoint
3
- ALTER TABLE "document_management"."assignment_scope" DROP CONSTRAINT "assignment_scope_task_id_assignment_task_id_fk";
4
- --> statement-breakpoint
5
- ALTER TABLE "document_management"."assignment_scope" DROP CONSTRAINT "assignment_scope_collection_id_collection_id_fk";
6
- --> statement-breakpoint
7
- ALTER TABLE "document_management"."assignment_task" DROP CONSTRAINT "assignment_task_document_id_document_id_fk";
8
- --> statement-breakpoint
9
- ALTER TABLE "document_management"."category" DROP CONSTRAINT "category_parent_id_category_id_fk";
10
- --> statement-breakpoint
11
- ALTER TABLE "document_management"."collection" DROP CONSTRAINT "collection_parent_id_collection_id_fk";
12
- --> statement-breakpoint
13
- ALTER TABLE "document_management"."collection_assignment" DROP CONSTRAINT "collection_assignment_collection_id_collection_id_fk";
14
- --> statement-breakpoint
15
- ALTER TABLE "document_management"."collection_assignment" DROP CONSTRAINT "collection_assignment_document_id_document_id_fk";
16
- --> statement-breakpoint
17
- ALTER TABLE "document_management"."property_value" DROP CONSTRAINT "property_value_document_id_document_id_fk";
18
- --> statement-breakpoint
19
- ALTER TABLE "document_management"."property_value" DROP CONSTRAINT "property_value_property_id_property_id_fk";
20
- --> statement-breakpoint
21
- ALTER TABLE "document_management"."request" DROP CONSTRAINT "request_type_id_type_id_fk";
22
- --> statement-breakpoint
23
- ALTER TABLE "document_management"."request" DROP CONSTRAINT "request_document_id_document_id_fk";
24
- --> statement-breakpoint
25
- ALTER TABLE "document_management"."request_collection_assignment" DROP CONSTRAINT "request_collection_assignment_request_id_request_id_fk";
26
- --> statement-breakpoint
27
- ALTER TABLE "document_management"."request_collection_assignment" DROP CONSTRAINT "request_collection_assignment_collection_id_collection_id_fk";
28
- --> statement-breakpoint
29
- ALTER TABLE "document_management"."request_template" DROP CONSTRAINT "request_template_requests_template_id_requests_template_id_fk";
30
- --> statement-breakpoint
31
- ALTER TABLE "document_management"."request_template" DROP CONSTRAINT "request_template_type_id_type_id_fk";
32
- --> statement-breakpoint
33
- ALTER TABLE "document_management"."tag_assignment" DROP CONSTRAINT "tag_assignment_document_id_document_id_fk";
34
- --> statement-breakpoint
35
- ALTER TABLE "document_management"."tag_assignment" DROP CONSTRAINT "tag_assignment_tag_id_tag_id_fk";
36
- --> statement-breakpoint
37
- ALTER TABLE "document_management"."type" DROP CONSTRAINT "type_category_id_category_id_fk";
38
- --> statement-breakpoint
39
- ALTER TABLE "document_management"."type_property" DROP CONSTRAINT "type_property_type_id_type_id_fk";
40
- --> statement-breakpoint
41
- ALTER TABLE "document_management"."type_property" DROP CONSTRAINT "type_property_property_id_property_id_fk";
42
- --> statement-breakpoint
43
- ALTER TABLE "document_management"."document_type_validation" DROP CONSTRAINT "document_type_validation_type_id_type_id_fk";
44
- --> statement-breakpoint
45
- ALTER TABLE "document_management"."document_type_validation" DROP CONSTRAINT "document_type_validation_validation_id_validation_definition_id_fk";
46
- --> statement-breakpoint
47
- ALTER TABLE "document_management"."validation_execution" DROP CONSTRAINT "validation_execution_workflow_id_workflow_id_fk";
48
- --> statement-breakpoint
49
- ALTER TABLE "document_management"."validation_execution" DROP CONSTRAINT "validation_execution_definition_id_validation_definition_id_fk";
50
- --> statement-breakpoint
51
- ALTER TABLE "document_management"."validation_execution_related_document" DROP CONSTRAINT "validation_execution_related_document_execution_id_validation_execution_id_fk";
52
- --> statement-breakpoint
53
- ALTER TABLE "document_management"."validation_execution_related_document" DROP CONSTRAINT "validation_execution_related_document_document_id_document_id_fk";
54
- --> statement-breakpoint
55
- ALTER TABLE "document_management"."workflow" DROP CONSTRAINT "workflow_document_id_document_id_fk";
56
- ALTER TABLE "document_management"."document" DROP CONSTRAINT "document_pkey";--> statement-breakpoint
57
- ALTER TABLE "document_management"."assignment_scope" DROP CONSTRAINT "assignment_scope_pkey";--> statement-breakpoint
58
- ALTER TABLE "document_management"."assignment_task" DROP CONSTRAINT "assignment_task_pkey";--> statement-breakpoint
59
- ALTER TABLE "document_management"."category" DROP CONSTRAINT "category_pkey";--> statement-breakpoint
60
- ALTER TABLE "document_management"."category" ALTER COLUMN "tenant_id" SET NOT NULL;--> statement-breakpoint
61
- ALTER TABLE "document_management"."collection" DROP CONSTRAINT "collection_pkey";--> statement-breakpoint
62
- ALTER TABLE "document_management"."collection_assignment" DROP CONSTRAINT "collection_assignment_pkey";--> statement-breakpoint
63
- ALTER TABLE "document_management"."property" DROP CONSTRAINT "property_pkey";--> statement-breakpoint
64
- ALTER TABLE "document_management"."property" ALTER COLUMN "tenant_id" SET NOT NULL;--> statement-breakpoint
65
- ALTER TABLE "document_management"."property_value" DROP CONSTRAINT "property_value_pkey";--> statement-breakpoint
66
- ALTER TABLE "document_management"."request" DROP CONSTRAINT "request_pkey";--> statement-breakpoint
67
- ALTER TABLE "document_management"."request_collection_assignment" DROP CONSTRAINT "request_collection_assignment_pkey";--> statement-breakpoint
68
- ALTER TABLE "document_management"."request_template" DROP CONSTRAINT "request_template_pkey";--> statement-breakpoint
69
- ALTER TABLE "document_management"."request_template" ALTER COLUMN "tenant_id" SET NOT NULL;--> statement-breakpoint
70
- ALTER TABLE "document_management"."requests_template" DROP CONSTRAINT "requests_template_pkey";--> statement-breakpoint
71
- ALTER TABLE "document_management"."requests_template" ALTER COLUMN "tenant_id" SET NOT NULL;--> statement-breakpoint
72
- ALTER TABLE "document_management"."tag" DROP CONSTRAINT "tag_pkey";--> statement-breakpoint
73
- ALTER TABLE "document_management"."tag" ALTER COLUMN "tenant_id" SET NOT NULL;--> statement-breakpoint
74
- ALTER TABLE "document_management"."tag_assignment" DROP CONSTRAINT "tag_assignment_pkey";--> statement-breakpoint
75
- ALTER TABLE "document_management"."type" DROP CONSTRAINT "type_pkey";--> statement-breakpoint
76
- ALTER TABLE "document_management"."type" ALTER COLUMN "tenant_id" SET NOT NULL;--> statement-breakpoint
77
- ALTER TABLE "document_management"."type_property" DROP CONSTRAINT "type_property_pkey";--> statement-breakpoint
78
- ALTER TABLE "document_management"."type_property" ALTER COLUMN "tenant_id" SET NOT NULL;--> statement-breakpoint
79
- ALTER TABLE "document_management"."document_type_validation" DROP CONSTRAINT "document_type_validation_pkey";--> statement-breakpoint
80
- ALTER TABLE "document_management"."document_type_validation" ALTER COLUMN "tenant_id" SET NOT NULL;--> statement-breakpoint
81
- ALTER TABLE "document_management"."validation_definition" DROP CONSTRAINT "validation_definition_pkey";--> statement-breakpoint
82
- ALTER TABLE "document_management"."validation_definition" ALTER COLUMN "tenant_id" SET NOT NULL;--> statement-breakpoint
83
- ALTER TABLE "document_management"."validation_execution" DROP CONSTRAINT "validation_execution_pkey";--> statement-breakpoint
84
- ALTER TABLE "document_management"."validation_execution_related_document" DROP CONSTRAINT "validation_execution_related_document_pkey";--> statement-breakpoint
85
- ALTER TABLE "document_management"."workflow" DROP CONSTRAINT "workflow_pkey";--> statement-breakpoint
86
- ALTER TABLE "document_management"."document" ADD CONSTRAINT "document_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
87
- ALTER TABLE "document_management"."assignment_scope" ADD CONSTRAINT "assignment_scope_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
88
- ALTER TABLE "document_management"."assignment_task" ADD CONSTRAINT "assignment_task_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
89
- ALTER TABLE "document_management"."category" ADD CONSTRAINT "category_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
90
- ALTER TABLE "document_management"."collection" ADD CONSTRAINT "collection_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
91
- ALTER TABLE "document_management"."collection_assignment" ADD CONSTRAINT "collection_assignment_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
92
- ALTER TABLE "document_management"."property" ADD CONSTRAINT "property_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
93
- ALTER TABLE "document_management"."property_value" ADD CONSTRAINT "property_value_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
94
- ALTER TABLE "document_management"."request" ADD CONSTRAINT "request_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
95
- ALTER TABLE "document_management"."request_collection_assignment" ADD CONSTRAINT "request_collection_assignment_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
96
- ALTER TABLE "document_management"."request_template" ADD CONSTRAINT "request_template_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
97
- ALTER TABLE "document_management"."requests_template" ADD CONSTRAINT "requests_template_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
98
- ALTER TABLE "document_management"."tag" ADD CONSTRAINT "tag_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
99
- ALTER TABLE "document_management"."tag_assignment" ADD CONSTRAINT "tag_assignment_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
100
- ALTER TABLE "document_management"."type" ADD CONSTRAINT "type_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
101
- ALTER TABLE "document_management"."type_property" ADD CONSTRAINT "type_property_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
102
- ALTER TABLE "document_management"."document_type_validation" ADD CONSTRAINT "document_type_validation_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
103
- ALTER TABLE "document_management"."validation_definition" ADD CONSTRAINT "validation_definition_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
104
- ALTER TABLE "document_management"."validation_execution" ADD CONSTRAINT "validation_execution_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
105
- ALTER TABLE "document_management"."validation_execution_related_document" ADD CONSTRAINT "validation_execution_related_document_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
106
- ALTER TABLE "document_management"."workflow" ADD CONSTRAINT "workflow_tenant_id_id_pk" PRIMARY KEY("tenant_id","id");--> statement-breakpoint
107
- ALTER TABLE "document_management"."document" ADD CONSTRAINT "document_id_fkey" FOREIGN KEY ("tenant_id","type_id") REFERENCES "document_management"."type"("tenant_id","id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
108
- ALTER TABLE "document_management"."assignment_scope" ADD CONSTRAINT "assignment_scope_id_fkey" FOREIGN KEY ("tenant_id","collection_id") REFERENCES "document_management"."collection"("tenant_id","id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
109
- ALTER TABLE "document_management"."assignment_task" ADD CONSTRAINT "assignment_task_id_fkey" FOREIGN KEY ("tenant_id","document_id") REFERENCES "document_management"."document"("tenant_id","id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
110
- ALTER TABLE "document_management"."category" ADD CONSTRAINT "category_id_fkey" FOREIGN KEY ("tenant_id","parent_id") REFERENCES "document_management"."category"("tenant_id","id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
111
- ALTER TABLE "document_management"."collection" ADD CONSTRAINT "collection_id_fkey" FOREIGN KEY ("tenant_id","parent_id") REFERENCES "document_management"."collection"("tenant_id","id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
112
- ALTER TABLE "document_management"."collection_assignment" ADD CONSTRAINT "collection_assignment_id_fkey" FOREIGN KEY ("tenant_id","document_id") REFERENCES "document_management"."document"("tenant_id","id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
113
- ALTER TABLE "document_management"."property_value" ADD CONSTRAINT "property_value_id_fkey" FOREIGN KEY ("tenant_id","property_id") REFERENCES "document_management"."property"("tenant_id","id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
114
- ALTER TABLE "document_management"."request" ADD CONSTRAINT "request_id_fkey" FOREIGN KEY ("tenant_id","document_id") REFERENCES "document_management"."document"("tenant_id","id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
115
- ALTER TABLE "document_management"."request_collection_assignment" ADD CONSTRAINT "request_collection_assignment_id_fkey" FOREIGN KEY ("tenant_id","collection_id") REFERENCES "document_management"."collection"("tenant_id","id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
116
- ALTER TABLE "document_management"."request_template" ADD CONSTRAINT "request_template_id_fkey" FOREIGN KEY ("tenant_id","type_id") REFERENCES "document_management"."type"("tenant_id","id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
117
- ALTER TABLE "document_management"."tag_assignment" ADD CONSTRAINT "tag_assignment_id_fkey" FOREIGN KEY ("tenant_id","tag_id") REFERENCES "document_management"."tag"("tenant_id","id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
118
- ALTER TABLE "document_management"."type" ADD CONSTRAINT "type_id_fkey" FOREIGN KEY ("tenant_id","category_id") REFERENCES "document_management"."category"("tenant_id","id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
119
- ALTER TABLE "document_management"."type_property" ADD CONSTRAINT "type_property_id_fkey" FOREIGN KEY ("tenant_id","property_id") REFERENCES "document_management"."property"("tenant_id","id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
120
- ALTER TABLE "document_management"."document_type_validation" ADD CONSTRAINT "document_type_validation_id_fkey" FOREIGN KEY ("tenant_id","validation_id") REFERENCES "document_management"."validation_definition"("tenant_id","id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
121
- ALTER TABLE "document_management"."validation_execution" ADD CONSTRAINT "validation_execution_id_fkey" FOREIGN KEY ("tenant_id","definition_id") REFERENCES "document_management"."validation_definition"("tenant_id","id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
122
- ALTER TABLE "document_management"."validation_execution_related_document" ADD CONSTRAINT "validation_execution_related_document_id_fkey" FOREIGN KEY ("tenant_id","document_id") REFERENCES "document_management"."document"("tenant_id","id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint
123
- ALTER TABLE "document_management"."workflow" ADD CONSTRAINT "workflow_id_fkey" FOREIGN KEY ("tenant_id","document_id") REFERENCES "document_management"."document"("tenant_id","id") ON DELETE no action ON UPDATE no action;