@fivenet-app/gen 2025.9.1 → 2026.4.0

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 (134) hide show
  1. package/README.md +1 -1
  2. package/clients.ts +36 -0
  3. package/codegen/perms/perms.ts +186 -15
  4. package/codegen/sanitizer/sanitizer.ts +34 -1
  5. package/package.json +2 -2
  6. package/perms.ts +140 -8
  7. package/resources/accounts/accounts.ts +98 -31
  8. package/resources/accounts/{oauth2.ts → oauth2/oauth2.ts} +20 -20
  9. package/resources/audit/audit.ts +156 -38
  10. package/resources/calendar/{access.ts → access/access.ts} +30 -30
  11. package/resources/calendar/calendar.ts +17 -477
  12. package/resources/calendar/entries/entries.ts +474 -0
  13. package/resources/centrum/{access.ts → access/access.ts} +22 -22
  14. package/resources/centrum/{dispatchers.ts → dispatchers/dispatchers.ts} +14 -14
  15. package/resources/centrum/{dispatches.ts → dispatches/dispatches.ts} +151 -185
  16. package/resources/centrum/joblist.ts +136 -0
  17. package/resources/centrum/{settings.ts → settings/settings.ts} +70 -70
  18. package/resources/centrum/{units_access.ts → units/access/access.ts} +30 -30
  19. package/resources/centrum/{units.ts → units/units.ts} +131 -51
  20. package/resources/citizens/labels/labels.ts +526 -0
  21. package/resources/{users → citizens/licenses}/licenses.ts +17 -17
  22. package/resources/clientconfig/clientconfig.ts +126 -258
  23. package/resources/collab/collab.ts +4 -16
  24. package/resources/common/content/content.ts +108 -85
  25. package/resources/common/content/diff_activity.ts +267 -0
  26. package/resources/common/i18n.ts +2 -2
  27. package/resources/{common/cron → cron}/cron.ts +43 -43
  28. package/resources/documents/{access.ts → access/access.ts} +29 -52
  29. package/resources/documents/{activity.ts → activity/activity.ts} +171 -123
  30. package/resources/documents/approval/approval.ts +945 -0
  31. package/resources/documents/{category.ts → category/category.ts} +7 -7
  32. package/resources/documents/{comment.ts → comment/comment.ts} +10 -10
  33. package/resources/documents/data/data.ts +303 -0
  34. package/resources/documents/documents.ts +282 -667
  35. package/resources/{common/uuid.ts → documents/forms/forms.ts} +20 -20
  36. package/resources/documents/{pins.ts → pins/pins.ts} +5 -5
  37. package/resources/documents/references/references.ts +187 -0
  38. package/resources/documents/relations/relations.ts +184 -0
  39. package/resources/documents/{requests.ts → requests/requests.ts} +18 -18
  40. package/resources/documents/stamps/stamp.ts +355 -0
  41. package/resources/documents/{templates.ts → templates/templates.ts} +426 -84
  42. package/resources/documents/{workflow.ts → workflow/workflow.ts} +264 -26
  43. package/resources/file/filestore.ts +1 -1
  44. package/resources/{common/grpcws → grpcws}/grpcws.ts +52 -52
  45. package/resources/jobs/{activity.ts → colleagues/activity/activity.ts} +54 -54
  46. package/resources/jobs/{colleagues.ts → colleagues/colleagues.ts} +17 -28
  47. package/resources/jobs/{conduct.ts → conduct/conduct.ts} +70 -45
  48. package/resources/jobs/{labels.ts → labels/labels.ts} +34 -23
  49. package/resources/jobs/{job_props.ts → props/props.ts} +26 -38
  50. package/resources/jobs/{job_settings.ts → settings/settings.ts} +53 -53
  51. package/resources/jobs/{timeclock.ts → timeclock/timeclock.ts} +17 -17
  52. package/resources/livemap/{heatmap.ts → heatmap/heatmap.ts} +4 -4
  53. package/resources/livemap/{marker_marker.ts → markers/marker_marker.ts} +35 -35
  54. package/resources/livemap/{user_marker.ts → markers/user_marker.ts} +115 -36
  55. package/resources/mailer/{access.ts → access/access.ts} +67 -67
  56. package/resources/mailer/{email.ts → emails/email.ts} +19 -19
  57. package/resources/mailer/{events.ts → events/events.ts} +24 -24
  58. package/resources/mailer/{message.ts → messages/message.ts} +29 -29
  59. package/resources/mailer/{settings.ts → settings/settings.ts} +14 -13
  60. package/resources/mailer/{template.ts → templates/template.ts} +15 -15
  61. package/resources/mailer/{thread.ts → threads/thread.ts} +29 -29
  62. package/resources/notifications/{client_view.ts → clientview/clientview.ts} +22 -22
  63. package/resources/notifications/{events.ts → events/events.ts} +20 -20
  64. package/resources/notifications/notifications.ts +4 -4
  65. package/resources/permissions/{attributes.ts → attributes/attributes.ts} +42 -42
  66. package/resources/permissions/{events.ts → events/events.ts} +7 -7
  67. package/resources/permissions/{permissions.ts → permissions/permissions.ts} +30 -19
  68. package/resources/qualifications/{access.ts → access/access.ts} +19 -19
  69. package/resources/qualifications/{exam.ts → exam/exam.ts} +269 -141
  70. package/resources/qualifications/qualifications.ts +51 -179
  71. package/resources/settings/banner.ts +3 -3
  72. package/resources/settings/config.ts +527 -25
  73. package/resources/{documents/state.ts → settings/data.ts} +41 -20
  74. package/resources/settings/perms.ts +14 -14
  75. package/resources/stats/stats.ts +379 -0
  76. package/resources/sync/{activity.ts → activity/activity.ts} +104 -25
  77. package/resources/sync/{data.ts → data/data.ts} +405 -59
  78. package/resources/userinfo/{user_info.ts → userinfo.ts} +71 -93
  79. package/resources/users/{activity.ts → activity/activity.ts} +242 -101
  80. package/resources/users/{props.ts → props/props.ts} +91 -69
  81. package/resources/users/short/user.ts +184 -0
  82. package/resources/users/{users.ts → user.ts} +266 -195
  83. package/resources/vehicles/{activity.ts → activity/activity.ts} +20 -20
  84. package/resources/vehicles/{props.ts → props/props.ts} +28 -6
  85. package/resources/vehicles/vehicles.ts +20 -8
  86. package/resources/wiki/{access.ts → access/access.ts} +30 -30
  87. package/resources/wiki/{activity.ts → activity/activity.ts} +104 -70
  88. package/resources/wiki/page.ts +39 -15
  89. package/services/auth/auth.client.ts +23 -10
  90. package/services/auth/auth.ts +445 -262
  91. package/services/calendar/calendar.ts +56 -34
  92. package/services/centrum/centrum.ts +127 -127
  93. package/services/citizens/citizens.client.ts +0 -13
  94. package/services/citizens/citizens.ts +44 -134
  95. package/services/citizens/labels.client.ts +77 -0
  96. package/services/citizens/labels.ts +455 -0
  97. package/services/completor/completor.ts +36 -16
  98. package/services/documents/approval.client.ts +188 -0
  99. package/services/documents/approval.ts +1776 -0
  100. package/services/documents/documents.ts +164 -186
  101. package/services/documents/forms.client.ts +51 -0
  102. package/services/documents/forms.ts +232 -0
  103. package/services/documents/stamps.client.ts +77 -0
  104. package/services/documents/stamps.ts +481 -0
  105. package/services/documents/stats.client.ts +38 -0
  106. package/services/documents/stats.ts +245 -0
  107. package/services/jobs/conduct.client.ts +30 -3
  108. package/services/jobs/conduct.ts +159 -33
  109. package/services/jobs/jobs.ts +43 -43
  110. package/services/jobs/stats.client.ts +38 -0
  111. package/services/jobs/stats.ts +207 -0
  112. package/services/jobs/timeclock.ts +39 -39
  113. package/services/livemap/livemap.ts +18 -18
  114. package/services/mailer/mailer.ts +78 -78
  115. package/services/notifications/notifications.ts +35 -35
  116. package/services/qualifications/qualifications.ts +81 -46
  117. package/services/settings/accounts.client.ts +23 -10
  118. package/services/settings/accounts.ts +191 -30
  119. package/services/settings/cron.client.ts +13 -0
  120. package/services/settings/cron.ts +118 -5
  121. package/services/settings/laws.ts +1 -1
  122. package/services/settings/settings.ts +73 -52
  123. package/services/settings/system.client.ts +13 -0
  124. package/services/settings/system.ts +115 -15
  125. package/services/stats/stats.client.ts +7 -7
  126. package/services/stats/stats.ts +24 -24
  127. package/services/sync/sync.client.ts +271 -37
  128. package/services/sync/sync.ts +1525 -421
  129. package/services/vehicles/vehicles.ts +8 -8
  130. package/services/wiki/wiki.ts +8 -8
  131. package/svcs.ts +100 -6
  132. package/resources/centrum/attributes.ts +0 -183
  133. package/resources/documents/signoff.ts +0 -55
  134. package/resources/users/labels.ts +0 -160
@@ -1,5 +1,5 @@
1
1
  // @generated by protobuf-ts 2.11.1 with parameter force_server_none,long_type_number,optimize_speed,ts_nocheck
2
- // @generated from protobuf file "resources/mailer/access.proto" (package "resources.mailer", syntax proto3)
2
+ // @generated from protobuf file "resources/mailer/access/access.proto" (package "resources.mailer.access", syntax proto3)
3
3
  // tslint:disable
4
4
  // @ts-nocheck
5
5
  import type { BinaryWriteOptions } from "@protobuf-ts/runtime";
@@ -11,28 +11,28 @@ import { UnknownFieldHandler } from "@protobuf-ts/runtime";
11
11
  import type { PartialMessage } from "@protobuf-ts/runtime";
12
12
  import { reflectionMergePartial } from "@protobuf-ts/runtime";
13
13
  import { MessageType } from "@protobuf-ts/runtime";
14
- import { QualificationShort } from "../qualifications/qualifications";
15
- import { UserShort } from "../users/users";
16
- import { Timestamp } from "../timestamp/timestamp";
14
+ import { QualificationShort } from "../../qualifications/qualifications";
15
+ import { UserShort } from "../../users/short/user";
16
+ import { Timestamp } from "../../timestamp/timestamp";
17
17
  /**
18
- * @generated from protobuf message resources.mailer.Access
18
+ * @generated from protobuf message resources.mailer.access.Access
19
19
  */
20
20
  export interface Access {
21
21
  /**
22
- * @generated from protobuf field: repeated resources.mailer.JobAccess jobs = 1
22
+ * @generated from protobuf field: repeated resources.mailer.access.JobAccess jobs = 1
23
23
  */
24
24
  jobs: JobAccess[];
25
25
  /**
26
- * @generated from protobuf field: repeated resources.mailer.UserAccess users = 2
26
+ * @generated from protobuf field: repeated resources.mailer.access.UserAccess users = 2
27
27
  */
28
28
  users: UserAccess[];
29
29
  /**
30
- * @generated from protobuf field: repeated resources.mailer.QualificationAccess qualifications = 3
30
+ * @generated from protobuf field: repeated resources.mailer.access.QualificationAccess qualifications = 3
31
31
  */
32
32
  qualifications: QualificationAccess[];
33
33
  }
34
34
  /**
35
- * @generated from protobuf message resources.mailer.JobAccess
35
+ * @generated from protobuf message resources.mailer.access.JobAccess
36
36
  */
37
37
  export interface JobAccess {
38
38
  /**
@@ -44,32 +44,32 @@ export interface JobAccess {
44
44
  */
45
45
  createdAt?: Timestamp;
46
46
  /**
47
- * @generated from protobuf field: int64 target_id = 4
47
+ * @generated from protobuf field: int64 target_id = 3
48
48
  */
49
49
  targetId: number;
50
50
  /**
51
- * @generated from protobuf field: string job = 5
51
+ * @generated from protobuf field: string job = 4
52
52
  */
53
53
  job: string;
54
54
  /**
55
- * @generated from protobuf field: optional string job_label = 6
55
+ * @generated from protobuf field: optional string job_label = 5
56
56
  */
57
57
  jobLabel?: string;
58
58
  /**
59
- * @generated from protobuf field: int32 minimum_grade = 7
59
+ * @generated from protobuf field: int32 minimum_grade = 6
60
60
  */
61
61
  minimumGrade: number;
62
62
  /**
63
- * @generated from protobuf field: optional string job_grade_label = 8
63
+ * @generated from protobuf field: optional string job_grade_label = 7
64
64
  */
65
65
  jobGradeLabel?: string;
66
66
  /**
67
- * @generated from protobuf field: resources.mailer.AccessLevel access = 9
67
+ * @generated from protobuf field: resources.mailer.access.AccessLevel access = 8
68
68
  */
69
69
  access: AccessLevel;
70
70
  }
71
71
  /**
72
- * @generated from protobuf message resources.mailer.UserAccess
72
+ * @generated from protobuf message resources.mailer.access.UserAccess
73
73
  */
74
74
  export interface UserAccess {
75
75
  /**
@@ -89,16 +89,16 @@ export interface UserAccess {
89
89
  */
90
90
  userId: number;
91
91
  /**
92
- * @generated from protobuf field: optional resources.users.UserShort user = 5
92
+ * @generated from protobuf field: optional resources.users.short.UserShort user = 5
93
93
  */
94
94
  user?: UserShort;
95
95
  /**
96
- * @generated from protobuf field: resources.mailer.AccessLevel access = 6
96
+ * @generated from protobuf field: resources.mailer.access.AccessLevel access = 6
97
97
  */
98
98
  access: AccessLevel;
99
99
  }
100
100
  /**
101
- * @generated from protobuf message resources.mailer.QualificationAccess
101
+ * @generated from protobuf message resources.mailer.access.QualificationAccess
102
102
  */
103
103
  export interface QualificationAccess {
104
104
  /**
@@ -122,12 +122,12 @@ export interface QualificationAccess {
122
122
  */
123
123
  qualification?: QualificationShort;
124
124
  /**
125
- * @generated from protobuf field: resources.mailer.AccessLevel access = 6
125
+ * @generated from protobuf field: resources.mailer.access.AccessLevel access = 6
126
126
  */
127
127
  access: AccessLevel;
128
128
  }
129
129
  /**
130
- * @generated from protobuf enum resources.mailer.AccessLevel
130
+ * @generated from protobuf enum resources.mailer.access.AccessLevel
131
131
  */
132
132
  export enum AccessLevel {
133
133
  /**
@@ -154,7 +154,7 @@ export enum AccessLevel {
154
154
  // @generated message type with reflection information, may provide speed optimized methods
155
155
  class Access$Type extends MessageType<Access> {
156
156
  constructor() {
157
- super("resources.mailer.Access", [
157
+ super("resources.mailer.access.Access", [
158
158
  { no: 1, name: "jobs", kind: "message", repeat: 2 /*RepeatType.UNPACKED*/, T: () => JobAccess, options: { "buf.validate.field": { repeated: { maxItems: "20" } }, "tagger.tags": "alias:\"job_access\"" } },
159
159
  { no: 2, name: "users", kind: "message", repeat: 2 /*RepeatType.UNPACKED*/, T: () => UserAccess, options: { "buf.validate.field": { repeated: { maxItems: "20" } }, "tagger.tags": "alias:\"user_access\"" } },
160
160
  { no: 3, name: "qualifications", kind: "message", repeat: 2 /*RepeatType.UNPACKED*/, T: () => QualificationAccess, options: { "buf.validate.field": { repeated: { maxItems: "20" } }, "tagger.tags": "alias:\"qualification_access\"" } }
@@ -174,13 +174,13 @@ class Access$Type extends MessageType<Access> {
174
174
  while (reader.pos < end) {
175
175
  let [fieldNo, wireType] = reader.tag();
176
176
  switch (fieldNo) {
177
- case /* repeated resources.mailer.JobAccess jobs */ 1:
177
+ case /* repeated resources.mailer.access.JobAccess jobs */ 1:
178
178
  message.jobs.push(JobAccess.internalBinaryRead(reader, reader.uint32(), options));
179
179
  break;
180
- case /* repeated resources.mailer.UserAccess users */ 2:
180
+ case /* repeated resources.mailer.access.UserAccess users */ 2:
181
181
  message.users.push(UserAccess.internalBinaryRead(reader, reader.uint32(), options));
182
182
  break;
183
- case /* repeated resources.mailer.QualificationAccess qualifications */ 3:
183
+ case /* repeated resources.mailer.access.QualificationAccess qualifications */ 3:
184
184
  message.qualifications.push(QualificationAccess.internalBinaryRead(reader, reader.uint32(), options));
185
185
  break;
186
186
  default:
@@ -195,13 +195,13 @@ class Access$Type extends MessageType<Access> {
195
195
  return message;
196
196
  }
197
197
  internalBinaryWrite(message: Access, writer: IBinaryWriter, options: BinaryWriteOptions): IBinaryWriter {
198
- /* repeated resources.mailer.JobAccess jobs = 1; */
198
+ /* repeated resources.mailer.access.JobAccess jobs = 1; */
199
199
  for (let i = 0; i < message.jobs.length; i++)
200
200
  JobAccess.internalBinaryWrite(message.jobs[i], writer.tag(1, WireType.LengthDelimited).fork(), options).join();
201
- /* repeated resources.mailer.UserAccess users = 2; */
201
+ /* repeated resources.mailer.access.UserAccess users = 2; */
202
202
  for (let i = 0; i < message.users.length; i++)
203
203
  UserAccess.internalBinaryWrite(message.users[i], writer.tag(2, WireType.LengthDelimited).fork(), options).join();
204
- /* repeated resources.mailer.QualificationAccess qualifications = 3; */
204
+ /* repeated resources.mailer.access.QualificationAccess qualifications = 3; */
205
205
  for (let i = 0; i < message.qualifications.length; i++)
206
206
  QualificationAccess.internalBinaryWrite(message.qualifications[i], writer.tag(3, WireType.LengthDelimited).fork(), options).join();
207
207
  let u = options.writeUnknownFields;
@@ -211,21 +211,21 @@ class Access$Type extends MessageType<Access> {
211
211
  }
212
212
  }
213
213
  /**
214
- * @generated MessageType for protobuf message resources.mailer.Access
214
+ * @generated MessageType for protobuf message resources.mailer.access.Access
215
215
  */
216
216
  export const Access = new Access$Type();
217
217
  // @generated message type with reflection information, may provide speed optimized methods
218
218
  class JobAccess$Type extends MessageType<JobAccess> {
219
219
  constructor() {
220
- super("resources.mailer.JobAccess", [
220
+ super("resources.mailer.access.JobAccess", [
221
221
  { no: 1, name: "id", kind: "scalar", T: 3 /*ScalarType.INT64*/, L: 2 /*LongType.NUMBER*/, options: { "tagger.tags": "sql:\"primary_key\" alias:\"id\"" } },
222
222
  { no: 2, name: "created_at", kind: "message", T: () => Timestamp },
223
- { no: 4, name: "target_id", kind: "scalar", T: 3 /*ScalarType.INT64*/, L: 2 /*LongType.NUMBER*/ },
224
- { no: 5, name: "job", kind: "scalar", T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "20" } } } },
225
- { no: 6, name: "job_label", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "50" } } } },
226
- { no: 7, name: "minimum_grade", kind: "scalar", T: 5 /*ScalarType.INT32*/, options: { "buf.validate.field": { int32: { gte: 0 } } } },
227
- { no: 8, name: "job_grade_label", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "50" } } } },
228
- { no: 9, name: "access", kind: "enum", T: () => ["resources.mailer.AccessLevel", AccessLevel, "ACCESS_LEVEL_"], options: { "buf.validate.field": { enum: { definedOnly: true } } } }
223
+ { no: 3, name: "target_id", kind: "scalar", T: 3 /*ScalarType.INT64*/, L: 2 /*LongType.NUMBER*/ },
224
+ { no: 4, name: "job", kind: "scalar", T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "20" } } } },
225
+ { no: 5, name: "job_label", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "50" } } } },
226
+ { no: 6, name: "minimum_grade", kind: "scalar", T: 5 /*ScalarType.INT32*/, options: { "buf.validate.field": { int32: { gte: 0 } } } },
227
+ { no: 7, name: "job_grade_label", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "50" } } } },
228
+ { no: 8, name: "access", kind: "enum", T: () => ["resources.mailer.access.AccessLevel", AccessLevel, "ACCESS_LEVEL_"], options: { "buf.validate.field": { enum: { definedOnly: true } } } }
229
229
  ]);
230
230
  }
231
231
  create(value?: PartialMessage<JobAccess>): JobAccess {
@@ -250,22 +250,22 @@ class JobAccess$Type extends MessageType<JobAccess> {
250
250
  case /* optional resources.timestamp.Timestamp created_at */ 2:
251
251
  message.createdAt = Timestamp.internalBinaryRead(reader, reader.uint32(), options, message.createdAt);
252
252
  break;
253
- case /* int64 target_id */ 4:
253
+ case /* int64 target_id */ 3:
254
254
  message.targetId = reader.int64().toNumber();
255
255
  break;
256
- case /* string job */ 5:
256
+ case /* string job */ 4:
257
257
  message.job = reader.string();
258
258
  break;
259
- case /* optional string job_label */ 6:
259
+ case /* optional string job_label */ 5:
260
260
  message.jobLabel = reader.string();
261
261
  break;
262
- case /* int32 minimum_grade */ 7:
262
+ case /* int32 minimum_grade */ 6:
263
263
  message.minimumGrade = reader.int32();
264
264
  break;
265
- case /* optional string job_grade_label */ 8:
265
+ case /* optional string job_grade_label */ 7:
266
266
  message.jobGradeLabel = reader.string();
267
267
  break;
268
- case /* resources.mailer.AccessLevel access */ 9:
268
+ case /* resources.mailer.access.AccessLevel access */ 8:
269
269
  message.access = reader.int32();
270
270
  break;
271
271
  default:
@@ -286,24 +286,24 @@ class JobAccess$Type extends MessageType<JobAccess> {
286
286
  /* optional resources.timestamp.Timestamp created_at = 2; */
287
287
  if (message.createdAt)
288
288
  Timestamp.internalBinaryWrite(message.createdAt, writer.tag(2, WireType.LengthDelimited).fork(), options).join();
289
- /* int64 target_id = 4; */
289
+ /* int64 target_id = 3; */
290
290
  if (message.targetId !== 0)
291
- writer.tag(4, WireType.Varint).int64(message.targetId);
292
- /* string job = 5; */
291
+ writer.tag(3, WireType.Varint).int64(message.targetId);
292
+ /* string job = 4; */
293
293
  if (message.job !== "")
294
- writer.tag(5, WireType.LengthDelimited).string(message.job);
295
- /* optional string job_label = 6; */
294
+ writer.tag(4, WireType.LengthDelimited).string(message.job);
295
+ /* optional string job_label = 5; */
296
296
  if (message.jobLabel !== undefined)
297
- writer.tag(6, WireType.LengthDelimited).string(message.jobLabel);
298
- /* int32 minimum_grade = 7; */
297
+ writer.tag(5, WireType.LengthDelimited).string(message.jobLabel);
298
+ /* int32 minimum_grade = 6; */
299
299
  if (message.minimumGrade !== 0)
300
- writer.tag(7, WireType.Varint).int32(message.minimumGrade);
301
- /* optional string job_grade_label = 8; */
300
+ writer.tag(6, WireType.Varint).int32(message.minimumGrade);
301
+ /* optional string job_grade_label = 7; */
302
302
  if (message.jobGradeLabel !== undefined)
303
- writer.tag(8, WireType.LengthDelimited).string(message.jobGradeLabel);
304
- /* resources.mailer.AccessLevel access = 9; */
303
+ writer.tag(7, WireType.LengthDelimited).string(message.jobGradeLabel);
304
+ /* resources.mailer.access.AccessLevel access = 8; */
305
305
  if (message.access !== 0)
306
- writer.tag(9, WireType.Varint).int32(message.access);
306
+ writer.tag(8, WireType.Varint).int32(message.access);
307
307
  let u = options.writeUnknownFields;
308
308
  if (u !== false)
309
309
  (u == true ? UnknownFieldHandler.onWrite : u)(this.typeName, message, writer);
@@ -311,19 +311,19 @@ class JobAccess$Type extends MessageType<JobAccess> {
311
311
  }
312
312
  }
313
313
  /**
314
- * @generated MessageType for protobuf message resources.mailer.JobAccess
314
+ * @generated MessageType for protobuf message resources.mailer.access.JobAccess
315
315
  */
316
316
  export const JobAccess = new JobAccess$Type();
317
317
  // @generated message type with reflection information, may provide speed optimized methods
318
318
  class UserAccess$Type extends MessageType<UserAccess> {
319
319
  constructor() {
320
- super("resources.mailer.UserAccess", [
320
+ super("resources.mailer.access.UserAccess", [
321
321
  { no: 1, name: "id", kind: "scalar", T: 3 /*ScalarType.INT64*/, L: 2 /*LongType.NUMBER*/ },
322
322
  { no: 2, name: "created_at", kind: "message", T: () => Timestamp },
323
323
  { no: 3, name: "target_id", kind: "scalar", T: 3 /*ScalarType.INT64*/, L: 2 /*LongType.NUMBER*/ },
324
324
  { no: 4, name: "user_id", kind: "scalar", T: 5 /*ScalarType.INT32*/, options: { "buf.validate.field": { int32: { gte: 0 } } } },
325
325
  { no: 5, name: "user", kind: "message", T: () => UserShort },
326
- { no: 6, name: "access", kind: "enum", T: () => ["resources.mailer.AccessLevel", AccessLevel, "ACCESS_LEVEL_"], options: { "buf.validate.field": { enum: { definedOnly: true } } } }
326
+ { no: 6, name: "access", kind: "enum", T: () => ["resources.mailer.access.AccessLevel", AccessLevel, "ACCESS_LEVEL_"], options: { "buf.validate.field": { enum: { definedOnly: true } } } }
327
327
  ]);
328
328
  }
329
329
  create(value?: PartialMessage<UserAccess>): UserAccess {
@@ -353,10 +353,10 @@ class UserAccess$Type extends MessageType<UserAccess> {
353
353
  case /* int32 user_id */ 4:
354
354
  message.userId = reader.int32();
355
355
  break;
356
- case /* optional resources.users.UserShort user */ 5:
356
+ case /* optional resources.users.short.UserShort user */ 5:
357
357
  message.user = UserShort.internalBinaryRead(reader, reader.uint32(), options, message.user);
358
358
  break;
359
- case /* resources.mailer.AccessLevel access */ 6:
359
+ case /* resources.mailer.access.AccessLevel access */ 6:
360
360
  message.access = reader.int32();
361
361
  break;
362
362
  default:
@@ -383,10 +383,10 @@ class UserAccess$Type extends MessageType<UserAccess> {
383
383
  /* int32 user_id = 4; */
384
384
  if (message.userId !== 0)
385
385
  writer.tag(4, WireType.Varint).int32(message.userId);
386
- /* optional resources.users.UserShort user = 5; */
386
+ /* optional resources.users.short.UserShort user = 5; */
387
387
  if (message.user)
388
388
  UserShort.internalBinaryWrite(message.user, writer.tag(5, WireType.LengthDelimited).fork(), options).join();
389
- /* resources.mailer.AccessLevel access = 6; */
389
+ /* resources.mailer.access.AccessLevel access = 6; */
390
390
  if (message.access !== 0)
391
391
  writer.tag(6, WireType.Varint).int32(message.access);
392
392
  let u = options.writeUnknownFields;
@@ -396,19 +396,19 @@ class UserAccess$Type extends MessageType<UserAccess> {
396
396
  }
397
397
  }
398
398
  /**
399
- * @generated MessageType for protobuf message resources.mailer.UserAccess
399
+ * @generated MessageType for protobuf message resources.mailer.access.UserAccess
400
400
  */
401
401
  export const UserAccess = new UserAccess$Type();
402
402
  // @generated message type with reflection information, may provide speed optimized methods
403
403
  class QualificationAccess$Type extends MessageType<QualificationAccess> {
404
404
  constructor() {
405
- super("resources.mailer.QualificationAccess", [
405
+ super("resources.mailer.access.QualificationAccess", [
406
406
  { no: 1, name: "id", kind: "scalar", T: 3 /*ScalarType.INT64*/, L: 2 /*LongType.NUMBER*/ },
407
407
  { no: 2, name: "created_at", kind: "message", T: () => Timestamp },
408
408
  { no: 3, name: "target_id", kind: "scalar", T: 3 /*ScalarType.INT64*/, L: 2 /*LongType.NUMBER*/ },
409
409
  { no: 4, name: "qualification_id", kind: "scalar", T: 3 /*ScalarType.INT64*/, L: 2 /*LongType.NUMBER*/ },
410
410
  { no: 5, name: "qualification", kind: "message", T: () => QualificationShort },
411
- { no: 6, name: "access", kind: "enum", T: () => ["resources.mailer.AccessLevel", AccessLevel, "ACCESS_LEVEL_"], options: { "buf.validate.field": { enum: { definedOnly: true } } } }
411
+ { no: 6, name: "access", kind: "enum", T: () => ["resources.mailer.access.AccessLevel", AccessLevel, "ACCESS_LEVEL_"], options: { "buf.validate.field": { enum: { definedOnly: true } } } }
412
412
  ]);
413
413
  }
414
414
  create(value?: PartialMessage<QualificationAccess>): QualificationAccess {
@@ -441,7 +441,7 @@ class QualificationAccess$Type extends MessageType<QualificationAccess> {
441
441
  case /* optional resources.qualifications.QualificationShort qualification */ 5:
442
442
  message.qualification = QualificationShort.internalBinaryRead(reader, reader.uint32(), options, message.qualification);
443
443
  break;
444
- case /* resources.mailer.AccessLevel access */ 6:
444
+ case /* resources.mailer.access.AccessLevel access */ 6:
445
445
  message.access = reader.int32();
446
446
  break;
447
447
  default:
@@ -471,7 +471,7 @@ class QualificationAccess$Type extends MessageType<QualificationAccess> {
471
471
  /* optional resources.qualifications.QualificationShort qualification = 5; */
472
472
  if (message.qualification)
473
473
  QualificationShort.internalBinaryWrite(message.qualification, writer.tag(5, WireType.LengthDelimited).fork(), options).join();
474
- /* resources.mailer.AccessLevel access = 6; */
474
+ /* resources.mailer.access.AccessLevel access = 6; */
475
475
  if (message.access !== 0)
476
476
  writer.tag(6, WireType.Varint).int32(message.access);
477
477
  let u = options.writeUnknownFields;
@@ -481,6 +481,6 @@ class QualificationAccess$Type extends MessageType<QualificationAccess> {
481
481
  }
482
482
  }
483
483
  /**
484
- * @generated MessageType for protobuf message resources.mailer.QualificationAccess
484
+ * @generated MessageType for protobuf message resources.mailer.access.QualificationAccess
485
485
  */
486
486
  export const QualificationAccess = new QualificationAccess$Type();
@@ -1,5 +1,5 @@
1
1
  // @generated by protobuf-ts 2.11.1 with parameter force_server_none,long_type_number,optimize_speed,ts_nocheck
2
- // @generated from protobuf file "resources/mailer/email.proto" (package "resources.mailer", syntax proto3)
2
+ // @generated from protobuf file "resources/mailer/emails/email.proto" (package "resources.mailer.emails", syntax proto3)
3
3
  // tslint:disable
4
4
  // @ts-nocheck
5
5
  import type { BinaryWriteOptions } from "@protobuf-ts/runtime";
@@ -11,12 +11,12 @@ import { UnknownFieldHandler } from "@protobuf-ts/runtime";
11
11
  import type { PartialMessage } from "@protobuf-ts/runtime";
12
12
  import { reflectionMergePartial } from "@protobuf-ts/runtime";
13
13
  import { MessageType } from "@protobuf-ts/runtime";
14
- import { EmailSettings } from "./settings";
15
- import { Access } from "./access";
16
- import { UserShort } from "../users/users";
17
- import { Timestamp } from "../timestamp/timestamp";
14
+ import { EmailSettings } from "../settings/settings";
15
+ import { Access } from "../access/access";
16
+ import { UserShort } from "../../users/short/user";
17
+ import { Timestamp } from "../../timestamp/timestamp";
18
18
  /**
19
- * @generated from protobuf message resources.mailer.Email
19
+ * @generated from protobuf message resources.mailer.emails.Email
20
20
  */
21
21
  export interface Email {
22
22
  /**
@@ -48,7 +48,7 @@ export interface Email {
48
48
  */
49
49
  userId?: number;
50
50
  /**
51
- * @generated from protobuf field: optional resources.users.UserShort user = 8
51
+ * @generated from protobuf field: optional resources.users.short.UserShort user = 8
52
52
  */
53
53
  user?: UserShort;
54
54
  /**
@@ -64,18 +64,18 @@ export interface Email {
64
64
  */
65
65
  label?: string;
66
66
  /**
67
- * @generated from protobuf field: resources.mailer.Access access = 12
67
+ * @generated from protobuf field: resources.mailer.access.Access access = 12
68
68
  */
69
69
  access?: Access;
70
70
  /**
71
- * @generated from protobuf field: optional resources.mailer.EmailSettings settings = 13
71
+ * @generated from protobuf field: optional resources.mailer.settings.EmailSettings settings = 13
72
72
  */
73
73
  settings?: EmailSettings;
74
74
  }
75
75
  // @generated message type with reflection information, may provide speed optimized methods
76
76
  class Email$Type extends MessageType<Email> {
77
77
  constructor() {
78
- super("resources.mailer.Email", [
78
+ super("resources.mailer.emails.Email", [
79
79
  { no: 1, name: "id", kind: "scalar", T: 3 /*ScalarType.INT64*/, L: 2 /*LongType.NUMBER*/ },
80
80
  { no: 2, name: "created_at", kind: "message", T: () => Timestamp },
81
81
  { no: 3, name: "updated_at", kind: "message", T: () => Timestamp },
@@ -84,9 +84,9 @@ class Email$Type extends MessageType<Email> {
84
84
  { no: 6, name: "job", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "40" } } } },
85
85
  { no: 7, name: "user_id", kind: "scalar", opt: true, T: 5 /*ScalarType.INT32*/, options: { "buf.validate.field": { int32: { gt: 0 } } } },
86
86
  { no: 8, name: "user", kind: "message", T: () => UserShort },
87
- { no: 9, name: "email", kind: "scalar", T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { minLen: "6", maxLen: "80" } }, "codegen.sanitizer.sanitizer": { enabled: true, method: "StripTags" } } },
87
+ { no: 9, name: "email", kind: "scalar", T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { minLen: "6", maxLen: "80" } }, "codegen.sanitizer.sanitizer": { enabled: true, stripHtmlTags: true } } },
88
88
  { no: 10, name: "email_changed", kind: "message", T: () => Timestamp },
89
- { no: 11, name: "label", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "128" } }, "codegen.sanitizer.sanitizer": { enabled: true, method: "StripTags" } } },
89
+ { no: 11, name: "label", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "128" } }, "codegen.sanitizer.sanitizer": { enabled: true, stripHtmlTags: true } } },
90
90
  { no: 12, name: "access", kind: "message", T: () => Access },
91
91
  { no: 13, name: "settings", kind: "message", T: () => EmailSettings }
92
92
  ]);
@@ -126,7 +126,7 @@ class Email$Type extends MessageType<Email> {
126
126
  case /* optional int32 user_id */ 7:
127
127
  message.userId = reader.int32();
128
128
  break;
129
- case /* optional resources.users.UserShort user */ 8:
129
+ case /* optional resources.users.short.UserShort user */ 8:
130
130
  message.user = UserShort.internalBinaryRead(reader, reader.uint32(), options, message.user);
131
131
  break;
132
132
  case /* string email */ 9:
@@ -138,10 +138,10 @@ class Email$Type extends MessageType<Email> {
138
138
  case /* optional string label */ 11:
139
139
  message.label = reader.string();
140
140
  break;
141
- case /* resources.mailer.Access access */ 12:
141
+ case /* resources.mailer.access.Access access */ 12:
142
142
  message.access = Access.internalBinaryRead(reader, reader.uint32(), options, message.access);
143
143
  break;
144
- case /* optional resources.mailer.EmailSettings settings */ 13:
144
+ case /* optional resources.mailer.settings.EmailSettings settings */ 13:
145
145
  message.settings = EmailSettings.internalBinaryRead(reader, reader.uint32(), options, message.settings);
146
146
  break;
147
147
  default:
@@ -177,7 +177,7 @@ class Email$Type extends MessageType<Email> {
177
177
  /* optional int32 user_id = 7; */
178
178
  if (message.userId !== undefined)
179
179
  writer.tag(7, WireType.Varint).int32(message.userId);
180
- /* optional resources.users.UserShort user = 8; */
180
+ /* optional resources.users.short.UserShort user = 8; */
181
181
  if (message.user)
182
182
  UserShort.internalBinaryWrite(message.user, writer.tag(8, WireType.LengthDelimited).fork(), options).join();
183
183
  /* string email = 9; */
@@ -189,10 +189,10 @@ class Email$Type extends MessageType<Email> {
189
189
  /* optional string label = 11; */
190
190
  if (message.label !== undefined)
191
191
  writer.tag(11, WireType.LengthDelimited).string(message.label);
192
- /* resources.mailer.Access access = 12; */
192
+ /* resources.mailer.access.Access access = 12; */
193
193
  if (message.access)
194
194
  Access.internalBinaryWrite(message.access, writer.tag(12, WireType.LengthDelimited).fork(), options).join();
195
- /* optional resources.mailer.EmailSettings settings = 13; */
195
+ /* optional resources.mailer.settings.EmailSettings settings = 13; */
196
196
  if (message.settings)
197
197
  EmailSettings.internalBinaryWrite(message.settings, writer.tag(13, WireType.LengthDelimited).fork(), options).join();
198
198
  let u = options.writeUnknownFields;
@@ -202,6 +202,6 @@ class Email$Type extends MessageType<Email> {
202
202
  }
203
203
  }
204
204
  /**
205
- * @generated MessageType for protobuf message resources.mailer.Email
205
+ * @generated MessageType for protobuf message resources.mailer.emails.Email
206
206
  */
207
207
  export const Email = new Email$Type();
@@ -1,5 +1,5 @@
1
1
  // @generated by protobuf-ts 2.11.1 with parameter force_server_none,long_type_number,optimize_speed,ts_nocheck
2
- // @generated from protobuf file "resources/mailer/events.proto" (package "resources.mailer", syntax proto3)
2
+ // @generated from protobuf file "resources/mailer/events/events.proto" (package "resources.mailer.events", syntax proto3)
3
3
  // tslint:disable
4
4
  // @ts-nocheck
5
5
  import type { BinaryWriteOptions } from "@protobuf-ts/runtime";
@@ -11,13 +11,13 @@ import { UnknownFieldHandler } from "@protobuf-ts/runtime";
11
11
  import type { PartialMessage } from "@protobuf-ts/runtime";
12
12
  import { reflectionMergePartial } from "@protobuf-ts/runtime";
13
13
  import { MessageType } from "@protobuf-ts/runtime";
14
- import { Message } from "./message";
15
- import { ThreadState } from "./thread";
16
- import { Thread } from "./thread";
17
- import { EmailSettings } from "./settings";
18
- import { Email } from "./email";
14
+ import { Message } from "../messages/message";
15
+ import { ThreadState } from "../threads/thread";
16
+ import { Thread } from "../threads/thread";
17
+ import { EmailSettings } from "../settings/settings";
18
+ import { Email } from "../emails/email";
19
19
  /**
20
- * @generated from protobuf message resources.mailer.MailerEvent
20
+ * @generated from protobuf message resources.mailer.events.MailerEvent
21
21
  */
22
22
  export interface MailerEvent {
23
23
  /**
@@ -26,7 +26,7 @@ export interface MailerEvent {
26
26
  data: {
27
27
  oneofKind: "emailUpdate";
28
28
  /**
29
- * @generated from protobuf field: resources.mailer.Email email_update = 1
29
+ * @generated from protobuf field: resources.mailer.emails.Email email_update = 1
30
30
  */
31
31
  emailUpdate: Email;
32
32
  } | {
@@ -38,13 +38,13 @@ export interface MailerEvent {
38
38
  } | {
39
39
  oneofKind: "emailSettingsUpdated";
40
40
  /**
41
- * @generated from protobuf field: resources.mailer.EmailSettings email_settings_updated = 3
41
+ * @generated from protobuf field: resources.mailer.settings.EmailSettings email_settings_updated = 3
42
42
  */
43
43
  emailSettingsUpdated: EmailSettings;
44
44
  } | {
45
45
  oneofKind: "threadUpdate";
46
46
  /**
47
- * @generated from protobuf field: resources.mailer.Thread thread_update = 4
47
+ * @generated from protobuf field: resources.mailer.threads.Thread thread_update = 4
48
48
  */
49
49
  threadUpdate: Thread;
50
50
  } | {
@@ -56,13 +56,13 @@ export interface MailerEvent {
56
56
  } | {
57
57
  oneofKind: "threadStateUpdate";
58
58
  /**
59
- * @generated from protobuf field: resources.mailer.ThreadState thread_state_update = 6
59
+ * @generated from protobuf field: resources.mailer.threads.ThreadState thread_state_update = 6
60
60
  */
61
61
  threadStateUpdate: ThreadState;
62
62
  } | {
63
63
  oneofKind: "messageUpdate";
64
64
  /**
65
- * @generated from protobuf field: resources.mailer.Message message_update = 7
65
+ * @generated from protobuf field: resources.mailer.messages.Message message_update = 7
66
66
  */
67
67
  messageUpdate: Message;
68
68
  } | {
@@ -78,7 +78,7 @@ export interface MailerEvent {
78
78
  // @generated message type with reflection information, may provide speed optimized methods
79
79
  class MailerEvent$Type extends MessageType<MailerEvent> {
80
80
  constructor() {
81
- super("resources.mailer.MailerEvent", [
81
+ super("resources.mailer.events.MailerEvent", [
82
82
  { no: 1, name: "email_update", kind: "message", oneof: "data", T: () => Email },
83
83
  { no: 2, name: "email_delete", kind: "scalar", oneof: "data", T: 3 /*ScalarType.INT64*/, L: 2 /*LongType.NUMBER*/ },
84
84
  { no: 3, name: "email_settings_updated", kind: "message", oneof: "data", T: () => EmailSettings },
@@ -101,7 +101,7 @@ class MailerEvent$Type extends MessageType<MailerEvent> {
101
101
  while (reader.pos < end) {
102
102
  let [fieldNo, wireType] = reader.tag();
103
103
  switch (fieldNo) {
104
- case /* resources.mailer.Email email_update */ 1:
104
+ case /* resources.mailer.emails.Email email_update */ 1:
105
105
  message.data = {
106
106
  oneofKind: "emailUpdate",
107
107
  emailUpdate: Email.internalBinaryRead(reader, reader.uint32(), options, (message.data as any).emailUpdate)
@@ -113,13 +113,13 @@ class MailerEvent$Type extends MessageType<MailerEvent> {
113
113
  emailDelete: reader.int64().toNumber()
114
114
  };
115
115
  break;
116
- case /* resources.mailer.EmailSettings email_settings_updated */ 3:
116
+ case /* resources.mailer.settings.EmailSettings email_settings_updated */ 3:
117
117
  message.data = {
118
118
  oneofKind: "emailSettingsUpdated",
119
119
  emailSettingsUpdated: EmailSettings.internalBinaryRead(reader, reader.uint32(), options, (message.data as any).emailSettingsUpdated)
120
120
  };
121
121
  break;
122
- case /* resources.mailer.Thread thread_update */ 4:
122
+ case /* resources.mailer.threads.Thread thread_update */ 4:
123
123
  message.data = {
124
124
  oneofKind: "threadUpdate",
125
125
  threadUpdate: Thread.internalBinaryRead(reader, reader.uint32(), options, (message.data as any).threadUpdate)
@@ -131,13 +131,13 @@ class MailerEvent$Type extends MessageType<MailerEvent> {
131
131
  threadDelete: reader.int64().toNumber()
132
132
  };
133
133
  break;
134
- case /* resources.mailer.ThreadState thread_state_update */ 6:
134
+ case /* resources.mailer.threads.ThreadState thread_state_update */ 6:
135
135
  message.data = {
136
136
  oneofKind: "threadStateUpdate",
137
137
  threadStateUpdate: ThreadState.internalBinaryRead(reader, reader.uint32(), options, (message.data as any).threadStateUpdate)
138
138
  };
139
139
  break;
140
- case /* resources.mailer.Message message_update */ 7:
140
+ case /* resources.mailer.messages.Message message_update */ 7:
141
141
  message.data = {
142
142
  oneofKind: "messageUpdate",
143
143
  messageUpdate: Message.internalBinaryRead(reader, reader.uint32(), options, (message.data as any).messageUpdate)
@@ -161,25 +161,25 @@ class MailerEvent$Type extends MessageType<MailerEvent> {
161
161
  return message;
162
162
  }
163
163
  internalBinaryWrite(message: MailerEvent, writer: IBinaryWriter, options: BinaryWriteOptions): IBinaryWriter {
164
- /* resources.mailer.Email email_update = 1; */
164
+ /* resources.mailer.emails.Email email_update = 1; */
165
165
  if (message.data.oneofKind === "emailUpdate")
166
166
  Email.internalBinaryWrite(message.data.emailUpdate, writer.tag(1, WireType.LengthDelimited).fork(), options).join();
167
167
  /* int64 email_delete = 2; */
168
168
  if (message.data.oneofKind === "emailDelete")
169
169
  writer.tag(2, WireType.Varint).int64(message.data.emailDelete);
170
- /* resources.mailer.EmailSettings email_settings_updated = 3; */
170
+ /* resources.mailer.settings.EmailSettings email_settings_updated = 3; */
171
171
  if (message.data.oneofKind === "emailSettingsUpdated")
172
172
  EmailSettings.internalBinaryWrite(message.data.emailSettingsUpdated, writer.tag(3, WireType.LengthDelimited).fork(), options).join();
173
- /* resources.mailer.Thread thread_update = 4; */
173
+ /* resources.mailer.threads.Thread thread_update = 4; */
174
174
  if (message.data.oneofKind === "threadUpdate")
175
175
  Thread.internalBinaryWrite(message.data.threadUpdate, writer.tag(4, WireType.LengthDelimited).fork(), options).join();
176
176
  /* int64 thread_delete = 5; */
177
177
  if (message.data.oneofKind === "threadDelete")
178
178
  writer.tag(5, WireType.Varint).int64(message.data.threadDelete);
179
- /* resources.mailer.ThreadState thread_state_update = 6; */
179
+ /* resources.mailer.threads.ThreadState thread_state_update = 6; */
180
180
  if (message.data.oneofKind === "threadStateUpdate")
181
181
  ThreadState.internalBinaryWrite(message.data.threadStateUpdate, writer.tag(6, WireType.LengthDelimited).fork(), options).join();
182
- /* resources.mailer.Message message_update = 7; */
182
+ /* resources.mailer.messages.Message message_update = 7; */
183
183
  if (message.data.oneofKind === "messageUpdate")
184
184
  Message.internalBinaryWrite(message.data.messageUpdate, writer.tag(7, WireType.LengthDelimited).fork(), options).join();
185
185
  /* int64 message_delete = 8; */
@@ -192,6 +192,6 @@ class MailerEvent$Type extends MessageType<MailerEvent> {
192
192
  }
193
193
  }
194
194
  /**
195
- * @generated MessageType for protobuf message resources.mailer.MailerEvent
195
+ * @generated MessageType for protobuf message resources.mailer.events.MailerEvent
196
196
  */
197
197
  export const MailerEvent = new MailerEvent$Type();