@fivenet-app/gen 2025.5.3 → 2026.3.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 (195) hide show
  1. package/README.md +1 -1
  2. package/buf/validate/validate.ts +11301 -0
  3. package/clients.ts +193 -154
  4. package/codegen/dbscanner/dbscanner.ts +91 -0
  5. package/codegen/perms/perms.ts +287 -0
  6. package/codegen/sanitizer/sanitizer.ts +113 -0
  7. package/google/protobuf/any.ts +4 -3
  8. package/google/protobuf/descriptor.ts +393 -239
  9. package/google/protobuf/duration.ts +4 -3
  10. package/google/protobuf/struct.ts +485 -0
  11. package/google/protobuf/timestamp.ts +4 -3
  12. package/package.json +3 -3
  13. package/perms.ts +217 -160
  14. package/resources/accounts/accounts.ts +115 -47
  15. package/resources/accounts/{oauth2.ts → oauth2/oauth2.ts} +33 -32
  16. package/resources/audit/audit.ts +172 -53
  17. package/resources/calendar/{access.ts → access/access.ts} +72 -71
  18. package/resources/calendar/calendar.ts +79 -543
  19. package/resources/calendar/entries/entries.ts +474 -0
  20. package/resources/centrum/access/access.ts +345 -0
  21. package/resources/centrum/dispatchers/dispatchers.ts +149 -0
  22. package/resources/centrum/{dispatches.ts → dispatches/dispatches.ts} +267 -164
  23. package/resources/centrum/joblist.ts +136 -0
  24. package/resources/centrum/settings/settings.ts +657 -0
  25. package/resources/centrum/{units_access.ts → units/access/access.ts} +78 -79
  26. package/resources/centrum/{units.ts → units/units.ts} +230 -130
  27. package/resources/clientconfig/clientconfig.ts +1015 -0
  28. package/resources/collab/collab.ts +805 -0
  29. package/resources/common/content/content.ts +169 -63
  30. package/resources/common/content/diff_activity.ts +267 -0
  31. package/resources/common/database/database.ts +92 -35
  32. package/resources/common/error.ts +17 -16
  33. package/resources/common/i18n.ts +20 -24
  34. package/resources/common/id_mapping.ts +69 -0
  35. package/resources/common/tests/objects.ts +4 -3
  36. package/resources/{common/cron → cron}/cron.ts +77 -65
  37. package/resources/discord/discord.ts +209 -0
  38. package/resources/documents/{access.ts → access/access.ts} +75 -76
  39. package/resources/documents/{activity.ts → activity/activity.ts} +349 -124
  40. package/resources/documents/approval/approval.ts +945 -0
  41. package/resources/documents/{category.ts → category/category.ts} +25 -32
  42. package/resources/documents/{comment.ts → comment/comment.ts} +35 -34
  43. package/resources/documents/data/data.ts +303 -0
  44. package/resources/documents/documents.ts +374 -686
  45. package/resources/{common/uuid.ts → documents/forms/forms.ts} +22 -21
  46. package/resources/documents/pins/pins.ts +127 -0
  47. package/resources/documents/references/references.ts +187 -0
  48. package/resources/documents/relations/relations.ts +184 -0
  49. package/resources/documents/{requests.ts → requests/requests.ts} +45 -44
  50. package/resources/documents/stamps/stamp.ts +355 -0
  51. package/resources/documents/{templates.ts → templates/templates.ts} +524 -199
  52. package/resources/documents/workflow/workflow.ts +600 -0
  53. package/resources/file/file.ts +152 -0
  54. package/{services/settings → resources/file}/filestore.ts +179 -165
  55. package/resources/file/meta.ts +148 -0
  56. package/resources/{common/grpcws → grpcws}/grpcws.ts +66 -65
  57. package/resources/jobs/{activity.ts → colleagues/activity/activity.ts} +83 -86
  58. package/resources/jobs/{colleagues.ts → colleagues/colleagues.ts} +76 -80
  59. package/resources/jobs/{conduct.ts → conduct/conduct.ts} +86 -62
  60. package/resources/jobs/jobs.ts +14 -13
  61. package/resources/jobs/{labels.ts → labels/labels.ts} +36 -37
  62. package/resources/jobs/{job_props.ts → props/props.ts} +63 -65
  63. package/resources/jobs/{job_settings.ts → settings/settings.ts} +89 -96
  64. package/resources/jobs/{timeclock.ts → timeclock/timeclock.ts} +42 -41
  65. package/resources/laws/laws.ts +40 -49
  66. package/resources/livemap/coords.ts +81 -0
  67. package/resources/livemap/heatmap/heatmap.ts +93 -0
  68. package/resources/livemap/{livemap.ts → markers/marker_marker.ts} +68 -335
  69. package/resources/livemap/markers/user_marker.ts +377 -0
  70. package/resources/mailer/{access.ts → access/access.ts} +119 -118
  71. package/resources/mailer/{email.ts → emails/email.ts} +38 -41
  72. package/resources/mailer/{events.ts → events/events.ts} +44 -43
  73. package/resources/mailer/{message.ts → messages/message.ts} +69 -74
  74. package/resources/mailer/{settings.ts → settings/settings.ts} +23 -25
  75. package/resources/mailer/{template.ts → templates/template.ts} +37 -40
  76. package/resources/mailer/{thread.ts → threads/thread.ts} +93 -94
  77. package/resources/notifications/clientview/clientview.ts +239 -0
  78. package/resources/notifications/{events.ts → events/events.ts} +67 -130
  79. package/resources/notifications/notifications.ts +55 -60
  80. package/resources/permissions/{attributes.ts → attributes/attributes.ts} +94 -237
  81. package/resources/permissions/events/events.ts +149 -0
  82. package/resources/permissions/{permissions.ts → permissions/permissions.ts} +127 -47
  83. package/resources/qualifications/{access.ts → access/access.ts} +43 -42
  84. package/resources/qualifications/{exam.ts → exam/exam.ts} +419 -229
  85. package/resources/qualifications/qualifications.ts +327 -388
  86. package/resources/settings/banner.ts +14 -21
  87. package/resources/settings/config.ts +663 -79
  88. package/resources/settings/data.ts +90 -0
  89. package/resources/settings/perms.ts +151 -0
  90. package/resources/settings/status.ts +533 -0
  91. package/resources/stats/stats.ts +382 -2
  92. package/resources/sync/{activity.ts → activity/activity.ts} +126 -46
  93. package/resources/sync/data/data.ts +1001 -0
  94. package/resources/sync/data/v2/data.ts +220 -0
  95. package/resources/timestamp/timestamp.ts +3 -2
  96. package/resources/{centrum/user_unit.ts → tracker/mapping.ts} +44 -44
  97. package/resources/userinfo/userinfo.ts +442 -0
  98. package/resources/users/{activity.ts → activity/activity.ts} +182 -166
  99. package/resources/users/{labels.ts → labels/labels.ts} +27 -30
  100. package/resources/users/{licenses.ts → licenses/licenses.ts} +18 -17
  101. package/resources/users/{props.ts → props/props.ts} +109 -77
  102. package/resources/users/short/user.ts +184 -0
  103. package/resources/users/user.ts +528 -0
  104. package/resources/vehicles/activity/activity.ts +231 -0
  105. package/resources/vehicles/props/props.ts +125 -0
  106. package/resources/vehicles/vehicles.ts +43 -18
  107. package/resources/wiki/{access.ts → access/access.ts} +72 -71
  108. package/resources/wiki/{activity.ts → activity/activity.ts} +218 -102
  109. package/resources/wiki/page.ts +164 -93
  110. package/services/auth/auth.client.ts +45 -35
  111. package/services/auth/auth.ts +498 -288
  112. package/services/calendar/calendar.client.ts +32 -91
  113. package/services/calendar/calendar.ts +157 -134
  114. package/services/centrum/centrum.client.ts +97 -137
  115. package/services/centrum/centrum.ts +755 -352
  116. package/services/citizens/citizens.client.ts +70 -39
  117. package/services/citizens/citizens.ts +226 -112
  118. package/services/completor/completor.client.ts +16 -35
  119. package/services/completor/completor.ts +95 -54
  120. package/services/documents/approval.client.ts +188 -0
  121. package/services/documents/approval.ts +1776 -0
  122. package/services/documents/collab.client.ts +46 -0
  123. package/services/documents/collab.ts +13 -0
  124. package/services/documents/documents.client.ts +88 -217
  125. package/services/documents/documents.ts +579 -619
  126. package/services/documents/forms.client.ts +51 -0
  127. package/services/documents/forms.ts +232 -0
  128. package/services/documents/stamps.client.ts +77 -0
  129. package/services/documents/stamps.ts +481 -0
  130. package/services/documents/stats.client.ts +38 -0
  131. package/services/documents/stats.ts +245 -0
  132. package/services/filestore/filestore.client.ts +86 -0
  133. package/services/filestore/filestore.ts +262 -0
  134. package/services/jobs/conduct.client.ts +40 -28
  135. package/services/jobs/conduct.ts +183 -56
  136. package/services/jobs/jobs.client.ts +22 -61
  137. package/services/jobs/jobs.ts +138 -121
  138. package/services/jobs/stats.client.ts +38 -0
  139. package/services/jobs/stats.ts +207 -0
  140. package/services/jobs/timeclock.client.ts +8 -19
  141. package/services/jobs/timeclock.ts +76 -75
  142. package/services/livemap/livemap.client.ts +8 -19
  143. package/services/livemap/livemap.ts +297 -126
  144. package/services/mailer/mailer.client.ts +44 -127
  145. package/services/mailer/mailer.ts +266 -269
  146. package/services/notifications/notifications.client.ts +65 -0
  147. package/services/{notificator/notificator.ts → notifications/notifications.ts} +126 -83
  148. package/services/qualifications/qualifications.client.ts +46 -91
  149. package/services/qualifications/qualifications.ts +250 -209
  150. package/services/settings/accounts.client.ts +31 -33
  151. package/services/settings/accounts.ts +251 -67
  152. package/services/settings/config.client.ts +6 -13
  153. package/services/settings/config.ts +8 -7
  154. package/services/settings/cron.client.ts +4 -7
  155. package/services/settings/cron.ts +7 -6
  156. package/services/settings/laws.client.ts +10 -25
  157. package/services/settings/laws.ts +30 -29
  158. package/services/settings/settings.client.ts +57 -103
  159. package/services/settings/settings.ts +237 -633
  160. package/services/settings/system.client.ts +103 -0
  161. package/services/settings/system.ts +718 -0
  162. package/services/stats/stats.client.ts +9 -8
  163. package/services/stats/stats.ts +27 -26
  164. package/services/sync/sync.client.ts +16 -15
  165. package/services/sync/sync.ts +174 -97
  166. package/services/sync/v2/sync.client.ts +331 -0
  167. package/services/sync/v2/sync.ts +1766 -0
  168. package/services/vehicles/vehicles.client.ts +17 -7
  169. package/services/vehicles/vehicles.ts +170 -25
  170. package/services/wiki/collab.client.ts +46 -0
  171. package/services/wiki/collab.ts +13 -0
  172. package/services/wiki/wiki.client.ts +28 -37
  173. package/services/wiki/wiki.ts +97 -67
  174. package/svcs.ts +174 -106
  175. package/resources/centrum/attributes.ts +0 -186
  176. package/resources/centrum/disponents.ts +0 -81
  177. package/resources/centrum/settings.ts +0 -307
  178. package/resources/documents/workflow.ts +0 -351
  179. package/resources/filestore/file.ts +0 -204
  180. package/resources/internet/access.ts +0 -358
  181. package/resources/internet/ads.ts +0 -257
  182. package/resources/internet/domain.ts +0 -328
  183. package/resources/internet/page.ts +0 -428
  184. package/resources/internet/search.ts +0 -128
  185. package/resources/livemap/tracker.ts +0 -81
  186. package/resources/sync/data.ts +0 -587
  187. package/resources/users/users.ts +0 -435
  188. package/services/internet/ads.client.ts +0 -41
  189. package/services/internet/ads.ts +0 -145
  190. package/services/internet/domain.client.ts +0 -109
  191. package/services/internet/domain.ts +0 -658
  192. package/services/internet/internet.client.ts +0 -58
  193. package/services/internet/internet.ts +0 -268
  194. package/services/notificator/notificator.client.ts +0 -76
  195. package/services/settings/filestore.client.ts +0 -75
@@ -1,5 +1,6 @@
1
- // @generated by protobuf-ts 2.10.0 with parameter optimize_speed,long_type_number,force_server_none
2
- // @generated from protobuf file "resources/jobs/colleagues.proto" (package "resources.jobs", syntax proto3)
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/jobs/colleagues/colleagues.proto" (package "resources.jobs.colleagues", syntax proto3)
3
+ // tslint:disable
3
4
  // @ts-nocheck
4
5
  import type { BinaryWriteOptions } from "@protobuf-ts/runtime";
5
6
  import type { IBinaryWriter } from "@protobuf-ts/runtime";
@@ -10,128 +11,123 @@ import { UnknownFieldHandler } from "@protobuf-ts/runtime";
10
11
  import type { PartialMessage } from "@protobuf-ts/runtime";
11
12
  import { reflectionMergePartial } from "@protobuf-ts/runtime";
12
13
  import { MessageType } from "@protobuf-ts/runtime";
13
- import { Labels } from "./labels";
14
- import { Timestamp } from "../timestamp/timestamp";
15
- import { File } from "../filestore/file";
14
+ import { Labels } from "../labels/labels";
15
+ import { Timestamp } from "../../timestamp/timestamp";
16
16
  /**
17
- * @generated from protobuf message resources.jobs.Colleague
17
+ * @generated from protobuf message resources.jobs.colleagues.Colleague
18
18
  */
19
19
  export interface Colleague {
20
20
  /**
21
- * @generated from protobuf field: int32 user_id = 1;
21
+ * @generated from protobuf field: int32 user_id = 1
22
22
  */
23
- userId: number; // @gotags: alias:"id"
24
- /**
25
- * @generated from protobuf field: optional string identifier = 2;
26
- */
27
- identifier?: string;
23
+ userId: number;
28
24
  /**
29
- * @generated from protobuf field: string job = 3;
25
+ * @generated from protobuf field: string job = 3
30
26
  */
31
27
  job: string;
32
28
  /**
33
- * @generated from protobuf field: optional string job_label = 4;
29
+ * @generated from protobuf field: optional string job_label = 4
34
30
  */
35
31
  jobLabel?: string;
36
32
  /**
37
- * @generated from protobuf field: int32 job_grade = 5;
33
+ * @generated from protobuf field: int32 job_grade = 5
38
34
  */
39
35
  jobGrade: number;
40
36
  /**
41
- * @generated from protobuf field: optional string job_grade_label = 6;
37
+ * @generated from protobuf field: optional string job_grade_label = 6
42
38
  */
43
39
  jobGradeLabel?: string;
44
40
  /**
45
- * @generated from protobuf field: string firstname = 7;
41
+ * @generated from protobuf field: string firstname = 7
46
42
  */
47
43
  firstname: string;
48
44
  /**
49
- * @generated from protobuf field: string lastname = 8;
45
+ * @generated from protobuf field: string lastname = 8
50
46
  */
51
47
  lastname: string;
52
48
  /**
53
- * @generated from protobuf field: string dateofbirth = 9;
49
+ * @generated from protobuf field: string dateofbirth = 9
54
50
  */
55
51
  dateofbirth: string;
56
52
  /**
57
- * @generated from protobuf field: optional string phone_number = 12;
53
+ * @generated from protobuf field: optional string phone_number = 12
58
54
  */
59
55
  phoneNumber?: string;
60
56
  /**
61
- * @generated from protobuf field: optional resources.filestore.File avatar = 17;
57
+ * @generated from protobuf field: optional int64 profile_picture_file_id = 17
62
58
  */
63
- avatar?: File;
59
+ profilePictureFileId?: number;
64
60
  /**
65
- * @generated from protobuf field: resources.jobs.ColleagueProps props = 18;
61
+ * @generated from protobuf field: optional string profile_picture = 18
66
62
  */
67
- props?: ColleagueProps; // @gotags: alias:"colleague_props"
63
+ profilePicture?: string;
68
64
  /**
69
- * @sanitize: method=StripTags
70
- *
71
- * @generated from protobuf field: optional string email = 19;
65
+ * @generated from protobuf field: resources.jobs.colleagues.ColleagueProps props = 19
66
+ */
67
+ props?: ColleagueProps;
68
+ /**
69
+ * @generated from protobuf field: optional string email = 20
72
70
  */
73
71
  email?: string;
74
72
  }
75
73
  /**
76
- * @generated from protobuf message resources.jobs.ColleagueProps
74
+ * @generated from protobuf message resources.jobs.colleagues.ColleagueProps
77
75
  */
78
76
  export interface ColleagueProps {
79
77
  /**
80
- * @generated from protobuf field: int32 user_id = 1;
78
+ * @generated from protobuf field: int32 user_id = 1
81
79
  */
82
80
  userId: number;
83
81
  /**
84
- * @generated from protobuf field: string job = 2;
82
+ * @generated from protobuf field: string job = 2
85
83
  */
86
84
  job: string;
87
85
  /**
88
- * @generated from protobuf field: optional resources.timestamp.Timestamp deleted_at = 3;
86
+ * @generated from protobuf field: optional resources.timestamp.Timestamp deleted_at = 3
89
87
  */
90
88
  deletedAt?: Timestamp;
91
89
  /**
92
- * @generated from protobuf field: optional resources.timestamp.Timestamp absence_begin = 4;
90
+ * @generated from protobuf field: optional resources.timestamp.Timestamp absence_begin = 4
93
91
  */
94
92
  absenceBegin?: Timestamp;
95
93
  /**
96
- * @generated from protobuf field: optional resources.timestamp.Timestamp absence_end = 5;
94
+ * @generated from protobuf field: optional resources.timestamp.Timestamp absence_end = 5
97
95
  */
98
96
  absenceEnd?: Timestamp;
99
97
  /**
100
- * @sanitize: method=StripTags
101
- *
102
- * @generated from protobuf field: optional string note = 6;
98
+ * @generated from protobuf field: optional string note = 6
103
99
  */
104
100
  note?: string;
105
101
  /**
106
- * @generated from protobuf field: optional resources.jobs.Labels labels = 7;
102
+ * @generated from protobuf field: optional resources.jobs.labels.Labels labels = 7
107
103
  */
108
104
  labels?: Labels;
109
105
  /**
110
- * @generated from protobuf field: optional string name_prefix = 8;
106
+ * @generated from protobuf field: optional string name_prefix = 8
111
107
  */
112
108
  namePrefix?: string;
113
109
  /**
114
- * @generated from protobuf field: optional string name_suffix = 9;
110
+ * @generated from protobuf field: optional string name_suffix = 9
115
111
  */
116
112
  nameSuffix?: string;
117
113
  }
118
114
  // @generated message type with reflection information, may provide speed optimized methods
119
115
  class Colleague$Type extends MessageType<Colleague> {
120
116
  constructor() {
121
- super("resources.jobs.Colleague", [
122
- { no: 1, name: "user_id", kind: "scalar", T: 5 /*ScalarType.INT32*/, options: { "validate.rules": { int32: { gt: 0 } } } },
123
- { no: 2, name: "identifier", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "validate.rules": { string: { maxLen: "64" } } } },
124
- { no: 3, name: "job", kind: "scalar", T: 9 /*ScalarType.STRING*/, options: { "validate.rules": { string: { maxLen: "20" } } } },
125
- { no: 4, name: "job_label", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "validate.rules": { string: { maxLen: "50" } } } },
126
- { no: 5, name: "job_grade", kind: "scalar", T: 5 /*ScalarType.INT32*/, options: { "validate.rules": { int32: { gt: -1 } } } },
127
- { no: 6, name: "job_grade_label", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "validate.rules": { string: { maxLen: "50" } } } },
128
- { no: 7, name: "firstname", kind: "scalar", T: 9 /*ScalarType.STRING*/, options: { "validate.rules": { string: { minLen: "1", maxLen: "50" } } } },
129
- { no: 8, name: "lastname", kind: "scalar", T: 9 /*ScalarType.STRING*/, options: { "validate.rules": { string: { minLen: "1", maxLen: "50" } } } },
130
- { no: 9, name: "dateofbirth", kind: "scalar", T: 9 /*ScalarType.STRING*/, options: { "validate.rules": { string: { len: "10" } } } },
131
- { no: 12, name: "phone_number", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "validate.rules": { string: { maxLen: "20" } } } },
132
- { no: 17, name: "avatar", kind: "message", T: () => File },
133
- { no: 18, name: "props", kind: "message", T: () => ColleagueProps },
134
- { no: 19, name: "email", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "validate.rules": { string: { minLen: "6", maxLen: "80" } } } }
117
+ super("resources.jobs.colleagues.Colleague", [
118
+ { no: 1, name: "user_id", kind: "scalar", T: 5 /*ScalarType.INT32*/, options: { "buf.validate.field": { int32: { gt: 0 } }, "tagger.tags": "alias:\"id\"" } },
119
+ { no: 3, name: "job", kind: "scalar", T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "20" } } } },
120
+ { no: 4, name: "job_label", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "50" } } } },
121
+ { no: 5, name: "job_grade", kind: "scalar", T: 5 /*ScalarType.INT32*/, options: { "buf.validate.field": { int32: { gte: 0 } } } },
122
+ { no: 6, name: "job_grade_label", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "50" } } } },
123
+ { no: 7, name: "firstname", kind: "scalar", T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { minLen: "1", maxLen: "50" } } } },
124
+ { no: 8, name: "lastname", kind: "scalar", T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { minLen: "1", maxLen: "50" } } } },
125
+ { no: 9, name: "dateofbirth", kind: "scalar", T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "10" } } } },
126
+ { no: 12, name: "phone_number", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "20" } } } },
127
+ { no: 17, name: "profile_picture_file_id", kind: "scalar", opt: true, T: 3 /*ScalarType.INT64*/, L: 2 /*LongType.NUMBER*/ },
128
+ { no: 18, name: "profile_picture", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "tagger.tags": "alias:\"profile_picture\"" } },
129
+ { no: 19, name: "props", kind: "message", T: () => ColleagueProps, options: { "tagger.tags": "alias:\"colleague_props\"" } },
130
+ { no: 20, name: "email", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { minLen: "6", maxLen: "80" } }, "codegen.sanitizer.sanitizer": { enabled: true, stripHtmlTags: true } } }
135
131
  ]);
136
132
  }
137
133
  create(value?: PartialMessage<Colleague>): Colleague {
@@ -154,9 +150,6 @@ class Colleague$Type extends MessageType<Colleague> {
154
150
  case /* int32 user_id */ 1:
155
151
  message.userId = reader.int32();
156
152
  break;
157
- case /* optional string identifier */ 2:
158
- message.identifier = reader.string();
159
- break;
160
153
  case /* string job */ 3:
161
154
  message.job = reader.string();
162
155
  break;
@@ -181,13 +174,16 @@ class Colleague$Type extends MessageType<Colleague> {
181
174
  case /* optional string phone_number */ 12:
182
175
  message.phoneNumber = reader.string();
183
176
  break;
184
- case /* optional resources.filestore.File avatar */ 17:
185
- message.avatar = File.internalBinaryRead(reader, reader.uint32(), options, message.avatar);
177
+ case /* optional int64 profile_picture_file_id */ 17:
178
+ message.profilePictureFileId = reader.int64().toNumber();
179
+ break;
180
+ case /* optional string profile_picture */ 18:
181
+ message.profilePicture = reader.string();
186
182
  break;
187
- case /* resources.jobs.ColleagueProps props */ 18:
183
+ case /* resources.jobs.colleagues.ColleagueProps props */ 19:
188
184
  message.props = ColleagueProps.internalBinaryRead(reader, reader.uint32(), options, message.props);
189
185
  break;
190
- case /* optional string email */ 19:
186
+ case /* optional string email */ 20:
191
187
  message.email = reader.string();
192
188
  break;
193
189
  default:
@@ -205,9 +201,6 @@ class Colleague$Type extends MessageType<Colleague> {
205
201
  /* int32 user_id = 1; */
206
202
  if (message.userId !== 0)
207
203
  writer.tag(1, WireType.Varint).int32(message.userId);
208
- /* optional string identifier = 2; */
209
- if (message.identifier !== undefined)
210
- writer.tag(2, WireType.LengthDelimited).string(message.identifier);
211
204
  /* string job = 3; */
212
205
  if (message.job !== "")
213
206
  writer.tag(3, WireType.LengthDelimited).string(message.job);
@@ -232,15 +225,18 @@ class Colleague$Type extends MessageType<Colleague> {
232
225
  /* optional string phone_number = 12; */
233
226
  if (message.phoneNumber !== undefined)
234
227
  writer.tag(12, WireType.LengthDelimited).string(message.phoneNumber);
235
- /* optional resources.filestore.File avatar = 17; */
236
- if (message.avatar)
237
- File.internalBinaryWrite(message.avatar, writer.tag(17, WireType.LengthDelimited).fork(), options).join();
238
- /* resources.jobs.ColleagueProps props = 18; */
228
+ /* optional int64 profile_picture_file_id = 17; */
229
+ if (message.profilePictureFileId !== undefined)
230
+ writer.tag(17, WireType.Varint).int64(message.profilePictureFileId);
231
+ /* optional string profile_picture = 18; */
232
+ if (message.profilePicture !== undefined)
233
+ writer.tag(18, WireType.LengthDelimited).string(message.profilePicture);
234
+ /* resources.jobs.colleagues.ColleagueProps props = 19; */
239
235
  if (message.props)
240
- ColleagueProps.internalBinaryWrite(message.props, writer.tag(18, WireType.LengthDelimited).fork(), options).join();
241
- /* optional string email = 19; */
236
+ ColleagueProps.internalBinaryWrite(message.props, writer.tag(19, WireType.LengthDelimited).fork(), options).join();
237
+ /* optional string email = 20; */
242
238
  if (message.email !== undefined)
243
- writer.tag(19, WireType.LengthDelimited).string(message.email);
239
+ writer.tag(20, WireType.LengthDelimited).string(message.email);
244
240
  let u = options.writeUnknownFields;
245
241
  if (u !== false)
246
242
  (u == true ? UnknownFieldHandler.onWrite : u)(this.typeName, message, writer);
@@ -248,22 +244,22 @@ class Colleague$Type extends MessageType<Colleague> {
248
244
  }
249
245
  }
250
246
  /**
251
- * @generated MessageType for protobuf message resources.jobs.Colleague
247
+ * @generated MessageType for protobuf message resources.jobs.colleagues.Colleague
252
248
  */
253
249
  export const Colleague = new Colleague$Type();
254
250
  // @generated message type with reflection information, may provide speed optimized methods
255
251
  class ColleagueProps$Type extends MessageType<ColleagueProps> {
256
252
  constructor() {
257
- super("resources.jobs.ColleagueProps", [
258
- { no: 1, name: "user_id", kind: "scalar", T: 5 /*ScalarType.INT32*/, options: { "validate.rules": { int32: { gt: 0 } } } },
259
- { no: 2, name: "job", kind: "scalar", T: 9 /*ScalarType.STRING*/, options: { "validate.rules": { string: { maxLen: "20" } } } },
253
+ super("resources.jobs.colleagues.ColleagueProps", [
254
+ { no: 1, name: "user_id", kind: "scalar", T: 5 /*ScalarType.INT32*/, options: { "buf.validate.field": { int32: { gte: 0 } } } },
255
+ { no: 2, name: "job", kind: "scalar", T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "20" } } } },
260
256
  { no: 3, name: "deleted_at", kind: "message", T: () => Timestamp },
261
257
  { no: 4, name: "absence_begin", kind: "message", T: () => Timestamp },
262
258
  { no: 5, name: "absence_end", kind: "message", T: () => Timestamp },
263
- { no: 6, name: "note", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/ },
259
+ { no: 6, name: "note", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "codegen.sanitizer.sanitizer": { enabled: true, stripHtmlTags: true } } },
264
260
  { no: 7, name: "labels", kind: "message", T: () => Labels },
265
- { no: 8, name: "name_prefix", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "validate.rules": { string: { maxLen: "12" } } } },
266
- { no: 9, name: "name_suffix", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "validate.rules": { string: { maxLen: "12" } } } }
261
+ { no: 8, name: "name_prefix", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "12" } } } },
262
+ { no: 9, name: "name_suffix", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "12" } } } }
267
263
  ]);
268
264
  }
269
265
  create(value?: PartialMessage<ColleagueProps>): ColleagueProps {
@@ -297,7 +293,7 @@ class ColleagueProps$Type extends MessageType<ColleagueProps> {
297
293
  case /* optional string note */ 6:
298
294
  message.note = reader.string();
299
295
  break;
300
- case /* optional resources.jobs.Labels labels */ 7:
296
+ case /* optional resources.jobs.labels.Labels labels */ 7:
301
297
  message.labels = Labels.internalBinaryRead(reader, reader.uint32(), options, message.labels);
302
298
  break;
303
299
  case /* optional string name_prefix */ 8:
@@ -336,7 +332,7 @@ class ColleagueProps$Type extends MessageType<ColleagueProps> {
336
332
  /* optional string note = 6; */
337
333
  if (message.note !== undefined)
338
334
  writer.tag(6, WireType.LengthDelimited).string(message.note);
339
- /* optional resources.jobs.Labels labels = 7; */
335
+ /* optional resources.jobs.labels.Labels labels = 7; */
340
336
  if (message.labels)
341
337
  Labels.internalBinaryWrite(message.labels, writer.tag(7, WireType.LengthDelimited).fork(), options).join();
342
338
  /* optional string name_prefix = 8; */
@@ -352,6 +348,6 @@ class ColleagueProps$Type extends MessageType<ColleagueProps> {
352
348
  }
353
349
  }
354
350
  /**
355
- * @generated MessageType for protobuf message resources.jobs.ColleagueProps
351
+ * @generated MessageType for protobuf message resources.jobs.colleagues.ColleagueProps
356
352
  */
357
353
  export const ColleagueProps = new ColleagueProps$Type();
@@ -1,5 +1,6 @@
1
- // @generated by protobuf-ts 2.10.0 with parameter optimize_speed,long_type_number,force_server_none
2
- // @generated from protobuf file "resources/jobs/conduct.proto" (package "resources.jobs", syntax proto3)
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/jobs/conduct/conduct.proto" (package "resources.jobs.conduct", syntax proto3)
3
+ // tslint:disable
3
4
  // @ts-nocheck
4
5
  import type { BinaryWriteOptions } from "@protobuf-ts/runtime";
5
6
  import type { IBinaryWriter } from "@protobuf-ts/runtime";
@@ -10,65 +11,73 @@ import { UnknownFieldHandler } from "@protobuf-ts/runtime";
10
11
  import type { PartialMessage } from "@protobuf-ts/runtime";
11
12
  import { reflectionMergePartial } from "@protobuf-ts/runtime";
12
13
  import { MessageType } from "@protobuf-ts/runtime";
13
- import { Colleague } from "./colleagues";
14
- import { Timestamp } from "../timestamp/timestamp";
14
+ import { Colleague } from "../colleagues/colleagues";
15
+ import { File } from "../../file/file";
16
+ import { Content } from "../../common/content/content";
17
+ import { Timestamp } from "../../timestamp/timestamp";
15
18
  /**
16
- * @generated from protobuf message resources.jobs.ConductEntry
19
+ * @generated from protobuf message resources.jobs.conduct.ConductEntry
17
20
  */
18
21
  export interface ConductEntry {
19
22
  /**
20
- * @generated from protobuf field: uint64 id = 1;
23
+ * @generated from protobuf field: int64 id = 1
21
24
  */
22
- id: number; // @gotags: sql:"primary_key" alias:"id"
25
+ id: number;
23
26
  /**
24
- * @generated from protobuf field: optional resources.timestamp.Timestamp created_at = 2;
27
+ * @generated from protobuf field: optional resources.timestamp.Timestamp created_at = 2
25
28
  */
26
29
  createdAt?: Timestamp;
27
30
  /**
28
- * @generated from protobuf field: optional resources.timestamp.Timestamp updated_at = 3;
31
+ * @generated from protobuf field: optional resources.timestamp.Timestamp updated_at = 3
29
32
  */
30
33
  updatedAt?: Timestamp;
31
34
  /**
32
- * @generated from protobuf field: optional resources.timestamp.Timestamp deleted_at = 4;
35
+ * @generated from protobuf field: optional resources.timestamp.Timestamp deleted_at = 4
33
36
  */
34
37
  deletedAt?: Timestamp;
35
38
  /**
36
- * @generated from protobuf field: string job = 5;
39
+ * @generated from protobuf field: string job = 5
37
40
  */
38
41
  job: string;
39
42
  /**
40
- * @generated from protobuf field: resources.jobs.ConductType type = 6;
43
+ * @generated from protobuf field: resources.jobs.conduct.ConductType type = 6
41
44
  */
42
45
  type: ConductType;
43
46
  /**
44
- * @sanitize
45
- *
46
- * @generated from protobuf field: string message = 7;
47
+ * @generated from protobuf field: bool draft = 7
47
48
  */
48
- message: string;
49
+ draft: boolean;
49
50
  /**
50
- * @generated from protobuf field: optional resources.timestamp.Timestamp expires_at = 8;
51
+ * @generated from protobuf field: resources.common.content.Content message = 8
52
+ */
53
+ message?: Content;
54
+ /**
55
+ * @generated from protobuf field: repeated resources.file.File files = 9
56
+ */
57
+ files: File[];
58
+ /**
59
+ * @generated from protobuf field: optional resources.timestamp.Timestamp expires_at = 10
51
60
  */
52
61
  expiresAt?: Timestamp;
53
62
  /**
54
- * @generated from protobuf field: int32 target_user_id = 9;
63
+ * @generated from protobuf field: int32 target_user_id = 11
55
64
  */
56
65
  targetUserId: number;
57
66
  /**
58
- * @generated from protobuf field: optional resources.jobs.Colleague target_user = 10;
67
+ * @generated from protobuf field: optional resources.jobs.colleagues.Colleague target_user = 12
59
68
  */
60
- targetUser?: Colleague; // @gotags: alias:"target_user"
69
+ targetUser?: Colleague;
61
70
  /**
62
- * @generated from protobuf field: int32 creator_id = 11;
71
+ * @generated from protobuf field: int32 creator_id = 13
63
72
  */
64
73
  creatorId: number;
65
74
  /**
66
- * @generated from protobuf field: optional resources.jobs.Colleague creator = 12;
75
+ * @generated from protobuf field: optional resources.jobs.colleagues.Colleague creator = 14
67
76
  */
68
- creator?: Colleague; // @gotags: alias:"creator"
77
+ creator?: Colleague;
69
78
  }
70
79
  /**
71
- * @generated from protobuf enum resources.jobs.ConductType
80
+ * @generated from protobuf enum resources.jobs.conduct.ConductType
72
81
  */
73
82
  export enum ConductType {
74
83
  /**
@@ -103,19 +112,21 @@ export enum ConductType {
103
112
  // @generated message type with reflection information, may provide speed optimized methods
104
113
  class ConductEntry$Type extends MessageType<ConductEntry> {
105
114
  constructor() {
106
- super("resources.jobs.ConductEntry", [
107
- { no: 1, name: "id", kind: "scalar", T: 4 /*ScalarType.UINT64*/, L: 2 /*LongType.NUMBER*/ },
115
+ super("resources.jobs.conduct.ConductEntry", [
116
+ { no: 1, name: "id", kind: "scalar", T: 3 /*ScalarType.INT64*/, L: 2 /*LongType.NUMBER*/, options: { "tagger.tags": "sql:\"primary_key\" alias:\"id\"" } },
108
117
  { no: 2, name: "created_at", kind: "message", T: () => Timestamp },
109
118
  { no: 3, name: "updated_at", kind: "message", T: () => Timestamp },
110
119
  { no: 4, name: "deleted_at", kind: "message", T: () => Timestamp },
111
- { no: 5, name: "job", kind: "scalar", T: 9 /*ScalarType.STRING*/, options: { "validate.rules": { string: { maxLen: "20" } } } },
112
- { no: 6, name: "type", kind: "enum", T: () => ["resources.jobs.ConductType", ConductType, "CONDUCT_TYPE_"], options: { "validate.rules": { enum: { definedOnly: true } } } },
113
- { no: 7, name: "message", kind: "scalar", T: 9 /*ScalarType.STRING*/, options: { "validate.rules": { string: { minLen: "3", maxLen: "2048" } } } },
114
- { no: 8, name: "expires_at", kind: "message", T: () => Timestamp },
115
- { no: 9, name: "target_user_id", kind: "scalar", T: 5 /*ScalarType.INT32*/, options: { "validate.rules": { int32: { gt: 0 } } } },
116
- { no: 10, name: "target_user", kind: "message", T: () => Colleague },
117
- { no: 11, name: "creator_id", kind: "scalar", T: 5 /*ScalarType.INT32*/, options: { "validate.rules": { int32: { gt: 0 } } } },
118
- { no: 12, name: "creator", kind: "message", T: () => Colleague }
120
+ { no: 5, name: "job", kind: "scalar", T: 9 /*ScalarType.STRING*/, options: { "buf.validate.field": { string: { maxLen: "20" } } } },
121
+ { no: 6, name: "type", kind: "enum", T: () => ["resources.jobs.conduct.ConductType", ConductType, "CONDUCT_TYPE_"], options: { "buf.validate.field": { enum: { definedOnly: true } } } },
122
+ { no: 7, name: "draft", kind: "scalar", T: 8 /*ScalarType.BOOL*/ },
123
+ { no: 8, name: "message", kind: "message", T: () => Content },
124
+ { no: 9, name: "files", kind: "message", repeat: 2 /*RepeatType.UNPACKED*/, T: () => File, options: { "tagger.tags": "alias:\"files\"" } },
125
+ { no: 10, name: "expires_at", kind: "message", T: () => Timestamp },
126
+ { no: 11, name: "target_user_id", kind: "scalar", T: 5 /*ScalarType.INT32*/, options: { "buf.validate.field": { int32: { gt: 0 } } } },
127
+ { no: 12, name: "target_user", kind: "message", T: () => Colleague, options: { "tagger.tags": "alias:\"target_user\"" } },
128
+ { no: 13, name: "creator_id", kind: "scalar", T: 5 /*ScalarType.INT32*/, options: { "buf.validate.field": { int32: { gt: 0 } } } },
129
+ { no: 14, name: "creator", kind: "message", T: () => Colleague, options: { "tagger.tags": "alias:\"creator\"" } }
119
130
  ]);
120
131
  }
121
132
  create(value?: PartialMessage<ConductEntry>): ConductEntry {
@@ -123,7 +134,8 @@ class ConductEntry$Type extends MessageType<ConductEntry> {
123
134
  message.id = 0;
124
135
  message.job = "";
125
136
  message.type = 0;
126
- message.message = "";
137
+ message.draft = false;
138
+ message.files = [];
127
139
  message.targetUserId = 0;
128
140
  message.creatorId = 0;
129
141
  if (value !== undefined)
@@ -135,8 +147,8 @@ class ConductEntry$Type extends MessageType<ConductEntry> {
135
147
  while (reader.pos < end) {
136
148
  let [fieldNo, wireType] = reader.tag();
137
149
  switch (fieldNo) {
138
- case /* uint64 id */ 1:
139
- message.id = reader.uint64().toNumber();
150
+ case /* int64 id */ 1:
151
+ message.id = reader.int64().toNumber();
140
152
  break;
141
153
  case /* optional resources.timestamp.Timestamp created_at */ 2:
142
154
  message.createdAt = Timestamp.internalBinaryRead(reader, reader.uint32(), options, message.createdAt);
@@ -150,25 +162,31 @@ class ConductEntry$Type extends MessageType<ConductEntry> {
150
162
  case /* string job */ 5:
151
163
  message.job = reader.string();
152
164
  break;
153
- case /* resources.jobs.ConductType type */ 6:
165
+ case /* resources.jobs.conduct.ConductType type */ 6:
154
166
  message.type = reader.int32();
155
167
  break;
156
- case /* string message */ 7:
157
- message.message = reader.string();
168
+ case /* bool draft */ 7:
169
+ message.draft = reader.bool();
170
+ break;
171
+ case /* resources.common.content.Content message */ 8:
172
+ message.message = Content.internalBinaryRead(reader, reader.uint32(), options, message.message);
173
+ break;
174
+ case /* repeated resources.file.File files */ 9:
175
+ message.files.push(File.internalBinaryRead(reader, reader.uint32(), options));
158
176
  break;
159
- case /* optional resources.timestamp.Timestamp expires_at */ 8:
177
+ case /* optional resources.timestamp.Timestamp expires_at */ 10:
160
178
  message.expiresAt = Timestamp.internalBinaryRead(reader, reader.uint32(), options, message.expiresAt);
161
179
  break;
162
- case /* int32 target_user_id */ 9:
180
+ case /* int32 target_user_id */ 11:
163
181
  message.targetUserId = reader.int32();
164
182
  break;
165
- case /* optional resources.jobs.Colleague target_user */ 10:
183
+ case /* optional resources.jobs.colleagues.Colleague target_user */ 12:
166
184
  message.targetUser = Colleague.internalBinaryRead(reader, reader.uint32(), options, message.targetUser);
167
185
  break;
168
- case /* int32 creator_id */ 11:
186
+ case /* int32 creator_id */ 13:
169
187
  message.creatorId = reader.int32();
170
188
  break;
171
- case /* optional resources.jobs.Colleague creator */ 12:
189
+ case /* optional resources.jobs.colleagues.Colleague creator */ 14:
172
190
  message.creator = Colleague.internalBinaryRead(reader, reader.uint32(), options, message.creator);
173
191
  break;
174
192
  default:
@@ -183,9 +201,9 @@ class ConductEntry$Type extends MessageType<ConductEntry> {
183
201
  return message;
184
202
  }
185
203
  internalBinaryWrite(message: ConductEntry, writer: IBinaryWriter, options: BinaryWriteOptions): IBinaryWriter {
186
- /* uint64 id = 1; */
204
+ /* int64 id = 1; */
187
205
  if (message.id !== 0)
188
- writer.tag(1, WireType.Varint).uint64(message.id);
206
+ writer.tag(1, WireType.Varint).int64(message.id);
189
207
  /* optional resources.timestamp.Timestamp created_at = 2; */
190
208
  if (message.createdAt)
191
209
  Timestamp.internalBinaryWrite(message.createdAt, writer.tag(2, WireType.LengthDelimited).fork(), options).join();
@@ -198,27 +216,33 @@ class ConductEntry$Type extends MessageType<ConductEntry> {
198
216
  /* string job = 5; */
199
217
  if (message.job !== "")
200
218
  writer.tag(5, WireType.LengthDelimited).string(message.job);
201
- /* resources.jobs.ConductType type = 6; */
219
+ /* resources.jobs.conduct.ConductType type = 6; */
202
220
  if (message.type !== 0)
203
221
  writer.tag(6, WireType.Varint).int32(message.type);
204
- /* string message = 7; */
205
- if (message.message !== "")
206
- writer.tag(7, WireType.LengthDelimited).string(message.message);
207
- /* optional resources.timestamp.Timestamp expires_at = 8; */
222
+ /* bool draft = 7; */
223
+ if (message.draft !== false)
224
+ writer.tag(7, WireType.Varint).bool(message.draft);
225
+ /* resources.common.content.Content message = 8; */
226
+ if (message.message)
227
+ Content.internalBinaryWrite(message.message, writer.tag(8, WireType.LengthDelimited).fork(), options).join();
228
+ /* repeated resources.file.File files = 9; */
229
+ for (let i = 0; i < message.files.length; i++)
230
+ File.internalBinaryWrite(message.files[i], writer.tag(9, WireType.LengthDelimited).fork(), options).join();
231
+ /* optional resources.timestamp.Timestamp expires_at = 10; */
208
232
  if (message.expiresAt)
209
- Timestamp.internalBinaryWrite(message.expiresAt, writer.tag(8, WireType.LengthDelimited).fork(), options).join();
210
- /* int32 target_user_id = 9; */
233
+ Timestamp.internalBinaryWrite(message.expiresAt, writer.tag(10, WireType.LengthDelimited).fork(), options).join();
234
+ /* int32 target_user_id = 11; */
211
235
  if (message.targetUserId !== 0)
212
- writer.tag(9, WireType.Varint).int32(message.targetUserId);
213
- /* optional resources.jobs.Colleague target_user = 10; */
236
+ writer.tag(11, WireType.Varint).int32(message.targetUserId);
237
+ /* optional resources.jobs.colleagues.Colleague target_user = 12; */
214
238
  if (message.targetUser)
215
- Colleague.internalBinaryWrite(message.targetUser, writer.tag(10, WireType.LengthDelimited).fork(), options).join();
216
- /* int32 creator_id = 11; */
239
+ Colleague.internalBinaryWrite(message.targetUser, writer.tag(12, WireType.LengthDelimited).fork(), options).join();
240
+ /* int32 creator_id = 13; */
217
241
  if (message.creatorId !== 0)
218
- writer.tag(11, WireType.Varint).int32(message.creatorId);
219
- /* optional resources.jobs.Colleague creator = 12; */
242
+ writer.tag(13, WireType.Varint).int32(message.creatorId);
243
+ /* optional resources.jobs.colleagues.Colleague creator = 14; */
220
244
  if (message.creator)
221
- Colleague.internalBinaryWrite(message.creator, writer.tag(12, WireType.LengthDelimited).fork(), options).join();
245
+ Colleague.internalBinaryWrite(message.creator, writer.tag(14, WireType.LengthDelimited).fork(), options).join();
222
246
  let u = options.writeUnknownFields;
223
247
  if (u !== false)
224
248
  (u == true ? UnknownFieldHandler.onWrite : u)(this.typeName, message, writer);
@@ -226,6 +250,6 @@ class ConductEntry$Type extends MessageType<ConductEntry> {
226
250
  }
227
251
  }
228
252
  /**
229
- * @generated MessageType for protobuf message resources.jobs.ConductEntry
253
+ * @generated MessageType for protobuf message resources.jobs.conduct.ConductEntry
230
254
  */
231
255
  export const ConductEntry = new ConductEntry$Type();