@oneuptime/common 10.7.2 → 10.8.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 (253) hide show
  1. package/Models/DatabaseModels/CloudResource.ts +846 -0
  2. package/Models/DatabaseModels/CloudResourceInstance.ts +276 -0
  3. package/Models/DatabaseModels/CloudResourceLabelRule.ts +510 -0
  4. package/Models/DatabaseModels/CloudResourceOwnerRule.ts +592 -0
  5. package/Models/DatabaseModels/CloudResourceOwnerTeam.ts +487 -0
  6. package/Models/DatabaseModels/CloudResourceOwnerUser.ts +486 -0
  7. package/Models/DatabaseModels/Host.ts +209 -0
  8. package/Models/DatabaseModels/Index.ts +36 -0
  9. package/Models/DatabaseModels/RumApplication.ts +731 -0
  10. package/Models/DatabaseModels/RumApplicationClient.ts +229 -0
  11. package/Models/DatabaseModels/RumApplicationLabelRule.ts +510 -0
  12. package/Models/DatabaseModels/RumApplicationOwnerRule.ts +592 -0
  13. package/Models/DatabaseModels/RumApplicationOwnerTeam.ts +486 -0
  14. package/Models/DatabaseModels/RumApplicationOwnerUser.ts +485 -0
  15. package/Models/DatabaseModels/ServerlessFunction.ts +881 -0
  16. package/Models/DatabaseModels/ServerlessFunctionInstance.ts +212 -0
  17. package/Models/DatabaseModels/ServerlessFunctionLabelRule.ts +510 -0
  18. package/Models/DatabaseModels/ServerlessFunctionOwnerRule.ts +592 -0
  19. package/Models/DatabaseModels/ServerlessFunctionOwnerTeam.ts +487 -0
  20. package/Models/DatabaseModels/ServerlessFunctionOwnerUser.ts +486 -0
  21. package/Models/DatabaseModels/Service.ts +268 -0
  22. package/Models/DatabaseModels/TelemetryException.ts +15 -1
  23. package/Models/DatabaseModels/WorkflowLog.ts +52 -0
  24. package/Server/Infrastructure/Postgres/SchemaMigrations/1780931746908-AddResumeStateToWorkflowLog.ts +21 -0
  25. package/Server/Infrastructure/Postgres/SchemaMigrations/1780931863719-AddTelemetryResourceMetadataColumns.ts +108 -0
  26. package/Server/Infrastructure/Postgres/SchemaMigrations/1780933132562-AddServerlessFunctionTables.ts +205 -0
  27. package/Server/Infrastructure/Postgres/SchemaMigrations/1780935387827-AddCloudResourceTables.ts +195 -0
  28. package/Server/Infrastructure/Postgres/SchemaMigrations/1780936579718-AddRumApplicationTables.ts +202 -0
  29. package/Server/Infrastructure/Postgres/SchemaMigrations/1780938407319-AddServerlessFunctionRuleTables.ts +156 -0
  30. package/Server/Infrastructure/Postgres/SchemaMigrations/1780940721814-AddCloudResourceRuleTables.ts +149 -0
  31. package/Server/Infrastructure/Postgres/SchemaMigrations/1780940998002-AddRumApplicationRuleTables.ts +149 -0
  32. package/Server/Infrastructure/Postgres/SchemaMigrations/1780941762204-AddTelemetryResourceInventoryTables.ts +95 -0
  33. package/Server/Infrastructure/Postgres/SchemaMigrations/1780985763463-AddRumApplicationSdkLanguage.ts +25 -0
  34. package/Server/Infrastructure/Postgres/SchemaMigrations/1780987192743-RecastCloudResourcesByEnvironment.ts +30 -0
  35. package/Server/Infrastructure/Postgres/SchemaMigrations/Index.ts +22 -0
  36. package/Server/Infrastructure/Queue.ts +11 -0
  37. package/Server/Services/CloudResourceInstanceService.ts +76 -0
  38. package/Server/Services/CloudResourceLabelRuleEngineService.ts +175 -0
  39. package/Server/Services/CloudResourceLabelRuleService.ts +14 -0
  40. package/Server/Services/CloudResourceOwnerRuleEngineService.ts +192 -0
  41. package/Server/Services/CloudResourceOwnerRuleService.ts +14 -0
  42. package/Server/Services/CloudResourceOwnerTeamService.ts +10 -0
  43. package/Server/Services/CloudResourceOwnerUserService.ts +10 -0
  44. package/Server/Services/CloudResourceService.ts +342 -0
  45. package/Server/Services/ExceptionAggregationService.ts +3 -0
  46. package/Server/Services/HostService.ts +42 -0
  47. package/Server/Services/LogAggregationService.ts +3 -0
  48. package/Server/Services/MetricAggregationService.ts +3 -0
  49. package/Server/Services/OpenTelemetryIngestService.ts +148 -1
  50. package/Server/Services/RumApplicationClientService.ts +69 -0
  51. package/Server/Services/RumApplicationLabelRuleEngineService.ts +175 -0
  52. package/Server/Services/RumApplicationLabelRuleService.ts +14 -0
  53. package/Server/Services/RumApplicationOwnerRuleEngineService.ts +192 -0
  54. package/Server/Services/RumApplicationOwnerRuleService.ts +14 -0
  55. package/Server/Services/RumApplicationOwnerTeamService.ts +10 -0
  56. package/Server/Services/RumApplicationOwnerUserService.ts +10 -0
  57. package/Server/Services/RumApplicationService.ts +301 -0
  58. package/Server/Services/ServerlessFunctionInstanceService.ts +61 -0
  59. package/Server/Services/ServerlessFunctionLabelRuleEngineService.ts +182 -0
  60. package/Server/Services/ServerlessFunctionLabelRuleService.ts +14 -0
  61. package/Server/Services/ServerlessFunctionOwnerRuleEngineService.ts +199 -0
  62. package/Server/Services/ServerlessFunctionOwnerRuleService.ts +14 -0
  63. package/Server/Services/ServerlessFunctionOwnerTeamService.ts +10 -0
  64. package/Server/Services/ServerlessFunctionOwnerUserService.ts +10 -0
  65. package/Server/Services/ServerlessFunctionService.ts +351 -0
  66. package/Server/Services/ServiceService.ts +95 -8
  67. package/Server/Services/TraceAggregationService.ts +3 -0
  68. package/Server/Types/Database/Permissions/OwnerTableRegistry.ts +39 -0
  69. package/Server/Types/Workflow/ComponentCode.ts +9 -0
  70. package/Server/Types/Workflow/Components/Index.ts +2 -0
  71. package/Server/Types/Workflow/Components/Sleep.ts +105 -0
  72. package/Server/Types/Workflow/Workflow.ts +6 -0
  73. package/Server/Utils/Telemetry/ResourceFacetResolver.ts +150 -0
  74. package/Types/Permission.ts +692 -1
  75. package/Types/Telemetry/ServiceType.ts +3 -0
  76. package/Types/Workflow/ComponentID.ts +1 -0
  77. package/Types/Workflow/Components/Sleep.ts +71 -0
  78. package/Types/Workflow/Components.ts +2 -0
  79. package/Types/Workflow/WorkflowStatus.ts +1 -0
  80. package/UI/Components/BulkUpdate/BulkLabelActions.tsx +159 -32
  81. package/UI/Components/Navbar/NavBar.tsx +72 -123
  82. package/UI/Components/Navbar/NavBarMenuModal.tsx +642 -0
  83. package/UI/Components/Workflow/WorkflowStatus.tsx +3 -0
  84. package/build/dist/Models/DatabaseModels/CloudResource.js +871 -0
  85. package/build/dist/Models/DatabaseModels/CloudResource.js.map +1 -0
  86. package/build/dist/Models/DatabaseModels/CloudResourceInstance.js +300 -0
  87. package/build/dist/Models/DatabaseModels/CloudResourceInstance.js.map +1 -0
  88. package/build/dist/Models/DatabaseModels/CloudResourceLabelRule.js +520 -0
  89. package/build/dist/Models/DatabaseModels/CloudResourceLabelRule.js.map +1 -0
  90. package/build/dist/Models/DatabaseModels/CloudResourceOwnerRule.js +601 -0
  91. package/build/dist/Models/DatabaseModels/CloudResourceOwnerRule.js.map +1 -0
  92. package/build/dist/Models/DatabaseModels/CloudResourceOwnerTeam.js +503 -0
  93. package/build/dist/Models/DatabaseModels/CloudResourceOwnerTeam.js.map +1 -0
  94. package/build/dist/Models/DatabaseModels/CloudResourceOwnerUser.js +502 -0
  95. package/build/dist/Models/DatabaseModels/CloudResourceOwnerUser.js.map +1 -0
  96. package/build/dist/Models/DatabaseModels/Host.js +215 -0
  97. package/build/dist/Models/DatabaseModels/Host.js.map +1 -1
  98. package/build/dist/Models/DatabaseModels/Index.js +36 -0
  99. package/build/dist/Models/DatabaseModels/Index.js.map +1 -1
  100. package/build/dist/Models/DatabaseModels/RumApplication.js +751 -0
  101. package/build/dist/Models/DatabaseModels/RumApplication.js.map +1 -0
  102. package/build/dist/Models/DatabaseModels/RumApplicationClient.js +252 -0
  103. package/build/dist/Models/DatabaseModels/RumApplicationClient.js.map +1 -0
  104. package/build/dist/Models/DatabaseModels/RumApplicationLabelRule.js +520 -0
  105. package/build/dist/Models/DatabaseModels/RumApplicationLabelRule.js.map +1 -0
  106. package/build/dist/Models/DatabaseModels/RumApplicationOwnerRule.js +601 -0
  107. package/build/dist/Models/DatabaseModels/RumApplicationOwnerRule.js.map +1 -0
  108. package/build/dist/Models/DatabaseModels/RumApplicationOwnerTeam.js +503 -0
  109. package/build/dist/Models/DatabaseModels/RumApplicationOwnerTeam.js.map +1 -0
  110. package/build/dist/Models/DatabaseModels/RumApplicationOwnerUser.js +502 -0
  111. package/build/dist/Models/DatabaseModels/RumApplicationOwnerUser.js.map +1 -0
  112. package/build/dist/Models/DatabaseModels/ServerlessFunction.js +908 -0
  113. package/build/dist/Models/DatabaseModels/ServerlessFunction.js.map +1 -0
  114. package/build/dist/Models/DatabaseModels/ServerlessFunctionInstance.js +234 -0
  115. package/build/dist/Models/DatabaseModels/ServerlessFunctionInstance.js.map +1 -0
  116. package/build/dist/Models/DatabaseModels/ServerlessFunctionLabelRule.js +520 -0
  117. package/build/dist/Models/DatabaseModels/ServerlessFunctionLabelRule.js.map +1 -0
  118. package/build/dist/Models/DatabaseModels/ServerlessFunctionOwnerRule.js +601 -0
  119. package/build/dist/Models/DatabaseModels/ServerlessFunctionOwnerRule.js.map +1 -0
  120. package/build/dist/Models/DatabaseModels/ServerlessFunctionOwnerTeam.js +503 -0
  121. package/build/dist/Models/DatabaseModels/ServerlessFunctionOwnerTeam.js.map +1 -0
  122. package/build/dist/Models/DatabaseModels/ServerlessFunctionOwnerUser.js +502 -0
  123. package/build/dist/Models/DatabaseModels/ServerlessFunctionOwnerUser.js.map +1 -0
  124. package/build/dist/Models/DatabaseModels/Service.js +276 -0
  125. package/build/dist/Models/DatabaseModels/Service.js.map +1 -1
  126. package/build/dist/Models/DatabaseModels/TelemetryException.js +12 -1
  127. package/build/dist/Models/DatabaseModels/TelemetryException.js.map +1 -1
  128. package/build/dist/Models/DatabaseModels/WorkflowLog.js +53 -0
  129. package/build/dist/Models/DatabaseModels/WorkflowLog.js.map +1 -1
  130. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780931746908-AddResumeStateToWorkflowLog.js +14 -0
  131. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780931746908-AddResumeStateToWorkflowLog.js.map +1 -0
  132. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780931863719-AddTelemetryResourceMetadataColumns.js +53 -0
  133. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780931863719-AddTelemetryResourceMetadataColumns.js.map +1 -0
  134. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780933132562-AddServerlessFunctionTables.js +82 -0
  135. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780933132562-AddServerlessFunctionTables.js.map +1 -0
  136. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780935387827-AddCloudResourceTables.js +82 -0
  137. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780935387827-AddCloudResourceTables.js.map +1 -0
  138. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780936579718-AddRumApplicationTables.js +83 -0
  139. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780936579718-AddRumApplicationTables.js.map +1 -0
  140. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780938407319-AddServerlessFunctionRuleTables.js +67 -0
  141. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780938407319-AddServerlessFunctionRuleTables.js.map +1 -0
  142. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780940721814-AddCloudResourceRuleTables.js +60 -0
  143. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780940721814-AddCloudResourceRuleTables.js.map +1 -0
  144. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780940998002-AddRumApplicationRuleTables.js +60 -0
  145. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780940998002-AddRumApplicationRuleTables.js.map +1 -0
  146. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780941762204-AddTelemetryResourceInventoryTables.js +45 -0
  147. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780941762204-AddTelemetryResourceInventoryTables.js.map +1 -0
  148. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780985763463-AddRumApplicationSdkLanguage.js +18 -0
  149. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780985763463-AddRumApplicationSdkLanguage.js.map +1 -0
  150. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780987192743-RecastCloudResourcesByEnvironment.js +27 -0
  151. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1780987192743-RecastCloudResourcesByEnvironment.js.map +1 -0
  152. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js +22 -0
  153. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js.map +1 -1
  154. package/build/dist/Server/Infrastructure/Queue.js +3 -0
  155. package/build/dist/Server/Infrastructure/Queue.js.map +1 -1
  156. package/build/dist/Server/Services/CloudResourceInstanceService.js +76 -0
  157. package/build/dist/Server/Services/CloudResourceInstanceService.js.map +1 -0
  158. package/build/dist/Server/Services/CloudResourceLabelRuleEngineService.js +160 -0
  159. package/build/dist/Server/Services/CloudResourceLabelRuleEngineService.js.map +1 -0
  160. package/build/dist/Server/Services/CloudResourceLabelRuleService.js +13 -0
  161. package/build/dist/Server/Services/CloudResourceLabelRuleService.js.map +1 -0
  162. package/build/dist/Server/Services/CloudResourceOwnerRuleEngineService.js +179 -0
  163. package/build/dist/Server/Services/CloudResourceOwnerRuleEngineService.js.map +1 -0
  164. package/build/dist/Server/Services/CloudResourceOwnerRuleService.js +13 -0
  165. package/build/dist/Server/Services/CloudResourceOwnerRuleService.js.map +1 -0
  166. package/build/dist/Server/Services/CloudResourceOwnerTeamService.js +9 -0
  167. package/build/dist/Server/Services/CloudResourceOwnerTeamService.js.map +1 -0
  168. package/build/dist/Server/Services/CloudResourceOwnerUserService.js +9 -0
  169. package/build/dist/Server/Services/CloudResourceOwnerUserService.js.map +1 -0
  170. package/build/dist/Server/Services/CloudResourceService.js +287 -0
  171. package/build/dist/Server/Services/CloudResourceService.js.map +1 -0
  172. package/build/dist/Server/Services/ExceptionAggregationService.js +3 -0
  173. package/build/dist/Server/Services/ExceptionAggregationService.js.map +1 -1
  174. package/build/dist/Server/Services/HostService.js +29 -1
  175. package/build/dist/Server/Services/HostService.js.map +1 -1
  176. package/build/dist/Server/Services/LogAggregationService.js +3 -0
  177. package/build/dist/Server/Services/LogAggregationService.js.map +1 -1
  178. package/build/dist/Server/Services/MetricAggregationService.js +3 -0
  179. package/build/dist/Server/Services/MetricAggregationService.js.map +1 -1
  180. package/build/dist/Server/Services/OpenTelemetryIngestService.js +98 -2
  181. package/build/dist/Server/Services/OpenTelemetryIngestService.js.map +1 -1
  182. package/build/dist/Server/Services/RumApplicationClientService.js +70 -0
  183. package/build/dist/Server/Services/RumApplicationClientService.js.map +1 -0
  184. package/build/dist/Server/Services/RumApplicationLabelRuleEngineService.js +160 -0
  185. package/build/dist/Server/Services/RumApplicationLabelRuleEngineService.js.map +1 -0
  186. package/build/dist/Server/Services/RumApplicationLabelRuleService.js +13 -0
  187. package/build/dist/Server/Services/RumApplicationLabelRuleService.js.map +1 -0
  188. package/build/dist/Server/Services/RumApplicationOwnerRuleEngineService.js +179 -0
  189. package/build/dist/Server/Services/RumApplicationOwnerRuleEngineService.js.map +1 -0
  190. package/build/dist/Server/Services/RumApplicationOwnerRuleService.js +13 -0
  191. package/build/dist/Server/Services/RumApplicationOwnerRuleService.js.map +1 -0
  192. package/build/dist/Server/Services/RumApplicationOwnerTeamService.js +9 -0
  193. package/build/dist/Server/Services/RumApplicationOwnerTeamService.js.map +1 -0
  194. package/build/dist/Server/Services/RumApplicationOwnerUserService.js +9 -0
  195. package/build/dist/Server/Services/RumApplicationOwnerUserService.js.map +1 -0
  196. package/build/dist/Server/Services/RumApplicationService.js +259 -0
  197. package/build/dist/Server/Services/RumApplicationService.js.map +1 -0
  198. package/build/dist/Server/Services/ServerlessFunctionInstanceService.js +64 -0
  199. package/build/dist/Server/Services/ServerlessFunctionInstanceService.js.map +1 -0
  200. package/build/dist/Server/Services/ServerlessFunctionLabelRuleEngineService.js +160 -0
  201. package/build/dist/Server/Services/ServerlessFunctionLabelRuleEngineService.js.map +1 -0
  202. package/build/dist/Server/Services/ServerlessFunctionLabelRuleService.js +13 -0
  203. package/build/dist/Server/Services/ServerlessFunctionLabelRuleService.js.map +1 -0
  204. package/build/dist/Server/Services/ServerlessFunctionOwnerRuleEngineService.js +179 -0
  205. package/build/dist/Server/Services/ServerlessFunctionOwnerRuleEngineService.js.map +1 -0
  206. package/build/dist/Server/Services/ServerlessFunctionOwnerRuleService.js +13 -0
  207. package/build/dist/Server/Services/ServerlessFunctionOwnerRuleService.js.map +1 -0
  208. package/build/dist/Server/Services/ServerlessFunctionOwnerTeamService.js +9 -0
  209. package/build/dist/Server/Services/ServerlessFunctionOwnerTeamService.js.map +1 -0
  210. package/build/dist/Server/Services/ServerlessFunctionOwnerUserService.js +9 -0
  211. package/build/dist/Server/Services/ServerlessFunctionOwnerUserService.js.map +1 -0
  212. package/build/dist/Server/Services/ServerlessFunctionService.js +299 -0
  213. package/build/dist/Server/Services/ServerlessFunctionService.js.map +1 -0
  214. package/build/dist/Server/Services/ServiceService.js +63 -7
  215. package/build/dist/Server/Services/ServiceService.js.map +1 -1
  216. package/build/dist/Server/Services/TraceAggregationService.js +3 -0
  217. package/build/dist/Server/Services/TraceAggregationService.js.map +1 -1
  218. package/build/dist/Server/Types/Database/Permissions/OwnerTableRegistry.js +39 -0
  219. package/build/dist/Server/Types/Database/Permissions/OwnerTableRegistry.js.map +1 -1
  220. package/build/dist/Server/Types/Workflow/ComponentCode.js.map +1 -1
  221. package/build/dist/Server/Types/Workflow/Components/Index.js +2 -0
  222. package/build/dist/Server/Types/Workflow/Components/Index.js.map +1 -1
  223. package/build/dist/Server/Types/Workflow/Components/Sleep.js +85 -0
  224. package/build/dist/Server/Types/Workflow/Components/Sleep.js.map +1 -0
  225. package/build/dist/Server/Utils/Telemetry/ResourceFacetResolver.js +90 -0
  226. package/build/dist/Server/Utils/Telemetry/ResourceFacetResolver.js.map +1 -1
  227. package/build/dist/Types/Permission.js +609 -1
  228. package/build/dist/Types/Permission.js.map +1 -1
  229. package/build/dist/Types/Telemetry/ServiceType.js +3 -0
  230. package/build/dist/Types/Telemetry/ServiceType.js.map +1 -1
  231. package/build/dist/Types/Workflow/ComponentID.js +1 -0
  232. package/build/dist/Types/Workflow/ComponentID.js.map +1 -1
  233. package/build/dist/Types/Workflow/Components/Sleep.js +64 -0
  234. package/build/dist/Types/Workflow/Components/Sleep.js.map +1 -0
  235. package/build/dist/Types/Workflow/Components.js +2 -0
  236. package/build/dist/Types/Workflow/Components.js.map +1 -1
  237. package/build/dist/Types/Workflow/WorkflowStatus.js +1 -0
  238. package/build/dist/Types/Workflow/WorkflowStatus.js.map +1 -1
  239. package/build/dist/UI/Components/BulkUpdate/BulkLabelActions.js +113 -19
  240. package/build/dist/UI/Components/BulkUpdate/BulkLabelActions.js.map +1 -1
  241. package/build/dist/UI/Components/Navbar/NavBar.js +34 -66
  242. package/build/dist/UI/Components/Navbar/NavBar.js.map +1 -1
  243. package/build/dist/UI/Components/Navbar/NavBarMenuModal.js +412 -0
  244. package/build/dist/UI/Components/Navbar/NavBarMenuModal.js.map +1 -0
  245. package/build/dist/UI/Components/Workflow/WorkflowStatus.js +3 -0
  246. package/build/dist/UI/Components/Workflow/WorkflowStatus.js.map +1 -1
  247. package/package.json +1 -1
  248. package/UI/Components/Navbar/NavBarMenu.tsx +0 -183
  249. package/UI/Components/Navbar/NavBarMenuItem.tsx +0 -146
  250. package/build/dist/UI/Components/Navbar/NavBarMenu.js +0 -82
  251. package/build/dist/UI/Components/Navbar/NavBarMenu.js.map +0 -1
  252. package/build/dist/UI/Components/Navbar/NavBarMenuItem.js +0 -109
  253. package/build/dist/UI/Components/Navbar/NavBarMenuItem.js.map +0 -1
@@ -0,0 +1,212 @@
1
+ import ServerlessFunction from "./ServerlessFunction";
2
+ import Project from "./Project";
3
+ import User from "./User";
4
+ import BaseModel from "./DatabaseBaseModel/DatabaseBaseModel";
5
+ import Route from "../../Types/API/Route";
6
+ import ColumnAccessControl from "../../Types/Database/AccessControl/ColumnAccessControl";
7
+ import TableAccessControl from "../../Types/Database/AccessControl/TableAccessControl";
8
+ import ColumnLength from "../../Types/Database/ColumnLength";
9
+ import ColumnType from "../../Types/Database/ColumnType";
10
+ import CrudApiEndpoint from "../../Types/Database/CrudApiEndpoint";
11
+ import TableColumn from "../../Types/Database/TableColumn";
12
+ import TableColumnType from "../../Types/Database/TableColumnType";
13
+ import TableMetadata from "../../Types/Database/TableMetadata";
14
+ import TenantColumn from "../../Types/Database/TenantColumn";
15
+ import IconProp from "../../Types/Icon/IconProp";
16
+ import ObjectID from "../../Types/ObjectID";
17
+ import Permission from "../../Types/Permission";
18
+ import { Column, Entity, Index, JoinColumn, ManyToOne } from "typeorm";
19
+
20
+ /*
21
+ * Live inventory of a single instance of a serverless function (faas.instance),
22
+ * upserted from the telemetry ingest pipeline; not user-editable. Sparse —
23
+ * only populated for collectors that emit the faas.instance resource attribute.
24
+ */
25
+
26
+ const READ_PERMISSIONS: Array<Permission> = [
27
+ Permission.ProjectOwner,
28
+ Permission.ProjectAdmin,
29
+ Permission.ProjectMember,
30
+ Permission.Viewer,
31
+ Permission.SettingsAdmin,
32
+ Permission.SettingsMember,
33
+ Permission.SettingsViewer,
34
+ Permission.ReadServerlessFunction,
35
+ ];
36
+
37
+ @TenantColumn("projectId")
38
+ @TableAccessControl({
39
+ create: [],
40
+ read: READ_PERMISSIONS,
41
+ update: [],
42
+ delete: [],
43
+ })
44
+ @CrudApiEndpoint(new Route("/serverless-function-instance"))
45
+ @TableMetadata({
46
+ tableName: "ServerlessFunctionInstance",
47
+ singularName: "Serverless Function Instance",
48
+ pluralName: "Serverless Function Instances",
49
+ icon: IconProp.Bolt,
50
+ tableDescription:
51
+ "Live inventory of serverless function instances (faas.instance), as last reported via OpenTelemetry. Populated by the ingest pipeline; not user-editable.",
52
+ })
53
+ @Index(["projectId", "serverlessFunctionId", "instanceName"], {
54
+ unique: true,
55
+ })
56
+ @Entity({
57
+ name: "ServerlessFunctionInstance",
58
+ })
59
+ export default class ServerlessFunctionInstance extends BaseModel {
60
+ @ColumnAccessControl({ create: [], read: READ_PERMISSIONS, update: [] })
61
+ @TableColumn({
62
+ manyToOneRelationColumn: "projectId",
63
+ type: TableColumnType.Entity,
64
+ modelType: Project,
65
+ title: "Project",
66
+ description: "Relation to Project this instance belongs to.",
67
+ })
68
+ @ManyToOne(
69
+ () => {
70
+ return Project;
71
+ },
72
+ {
73
+ eager: false,
74
+ nullable: true,
75
+ onDelete: "CASCADE",
76
+ orphanedRowAction: "nullify",
77
+ },
78
+ )
79
+ @JoinColumn({ name: "projectId" })
80
+ public project?: Project = undefined;
81
+
82
+ @ColumnAccessControl({ create: [], read: READ_PERMISSIONS, update: [] })
83
+ @Index()
84
+ @TableColumn({
85
+ type: TableColumnType.ObjectID,
86
+ required: true,
87
+ canReadOnRelationQuery: true,
88
+ title: "Project ID",
89
+ description: "ID of the Project this instance belongs to.",
90
+ })
91
+ @Column({
92
+ type: ColumnType.ObjectID,
93
+ nullable: false,
94
+ transformer: ObjectID.getDatabaseTransformer(),
95
+ })
96
+ public projectId?: ObjectID = undefined;
97
+
98
+ @ColumnAccessControl({ create: [], read: READ_PERMISSIONS, update: [] })
99
+ @TableColumn({
100
+ manyToOneRelationColumn: "serverlessFunctionId",
101
+ type: TableColumnType.Entity,
102
+ modelType: ServerlessFunction,
103
+ title: "Serverless Function",
104
+ description: "Function this instance belongs to.",
105
+ })
106
+ @ManyToOne(
107
+ () => {
108
+ return ServerlessFunction;
109
+ },
110
+ {
111
+ eager: false,
112
+ nullable: true,
113
+ onDelete: "CASCADE",
114
+ orphanedRowAction: "nullify",
115
+ },
116
+ )
117
+ @JoinColumn({ name: "serverlessFunctionId" })
118
+ public serverlessFunction?: ServerlessFunction = undefined;
119
+
120
+ @ColumnAccessControl({ create: [], read: READ_PERMISSIONS, update: [] })
121
+ @Index()
122
+ @TableColumn({
123
+ type: TableColumnType.ObjectID,
124
+ required: true,
125
+ canReadOnRelationQuery: true,
126
+ title: "Serverless Function ID",
127
+ description: "ID of the function this instance belongs to.",
128
+ })
129
+ @Column({
130
+ type: ColumnType.ObjectID,
131
+ nullable: false,
132
+ transformer: ObjectID.getDatabaseTransformer(),
133
+ })
134
+ public serverlessFunctionId?: ObjectID = undefined;
135
+
136
+ @ColumnAccessControl({ create: [], read: READ_PERMISSIONS, update: [] })
137
+ @TableColumn({
138
+ required: true,
139
+ type: TableColumnType.ShortText,
140
+ canReadOnRelationQuery: true,
141
+ title: "Instance Name",
142
+ description: "faas.instance value identifying this function instance.",
143
+ })
144
+ @Column({
145
+ nullable: false,
146
+ type: ColumnType.ShortText,
147
+ length: ColumnLength.ShortText,
148
+ })
149
+ public instanceName?: string = undefined;
150
+
151
+ @ColumnAccessControl({ create: [], read: READ_PERMISSIONS, update: [] })
152
+ @TableColumn({
153
+ required: true,
154
+ type: TableColumnType.Date,
155
+ canReadOnRelationQuery: true,
156
+ title: "Last Seen At",
157
+ description: "When telemetry for this instance was last observed.",
158
+ })
159
+ @Column({
160
+ nullable: false,
161
+ type: ColumnType.Date,
162
+ })
163
+ public lastSeenAt?: Date = undefined;
164
+
165
+ @ColumnAccessControl({ create: [], read: READ_PERMISSIONS, update: [] })
166
+ @TableColumn({
167
+ type: TableColumnType.ObjectID,
168
+ title: "Created By User ID",
169
+ description: "ID of the user who created this row (ingest writes as root).",
170
+ })
171
+ @Column({
172
+ type: ColumnType.ObjectID,
173
+ nullable: true,
174
+ transformer: ObjectID.getDatabaseTransformer(),
175
+ })
176
+ public createdByUserId?: ObjectID = undefined;
177
+
178
+ @ColumnAccessControl({ create: [], read: READ_PERMISSIONS, update: [] })
179
+ @TableColumn({
180
+ manyToOneRelationColumn: "deletedByUserId",
181
+ type: TableColumnType.Entity,
182
+ modelType: User,
183
+ title: "Deleted By User",
184
+ description: "Relation to the user who deleted this row.",
185
+ })
186
+ @ManyToOne(
187
+ () => {
188
+ return User;
189
+ },
190
+ {
191
+ eager: false,
192
+ nullable: true,
193
+ onDelete: "SET NULL",
194
+ orphanedRowAction: "nullify",
195
+ },
196
+ )
197
+ @JoinColumn({ name: "deletedByUserId" })
198
+ public deletedByUser?: User = undefined;
199
+
200
+ @ColumnAccessControl({ create: [], read: READ_PERMISSIONS, update: [] })
201
+ @TableColumn({
202
+ type: TableColumnType.ObjectID,
203
+ title: "Deleted By User ID",
204
+ description: "ID of the user who deleted this row.",
205
+ })
206
+ @Column({
207
+ type: ColumnType.ObjectID,
208
+ nullable: true,
209
+ transformer: ObjectID.getDatabaseTransformer(),
210
+ })
211
+ public deletedByUserId?: ObjectID = undefined;
212
+ }
@@ -0,0 +1,510 @@
1
+ import Label from "./Label";
2
+ import Project from "./Project";
3
+ import User from "./User";
4
+ import BaseModel from "./DatabaseBaseModel/DatabaseBaseModel";
5
+ import Route from "../../Types/API/Route";
6
+ import ColumnAccessControl from "../../Types/Database/AccessControl/ColumnAccessControl";
7
+ import TableAccessControl from "../../Types/Database/AccessControl/TableAccessControl";
8
+ import ColumnLength from "../../Types/Database/ColumnLength";
9
+ import ColumnType from "../../Types/Database/ColumnType";
10
+ import CrudApiEndpoint from "../../Types/Database/CrudApiEndpoint";
11
+ import EnableDocumentation from "../../Types/Database/EnableDocumentation";
12
+ import EnableWorkflow from "../../Types/Database/EnableWorkflow";
13
+ import TableColumn from "../../Types/Database/TableColumn";
14
+ import TableColumnType from "../../Types/Database/TableColumnType";
15
+ import TableMetadata from "../../Types/Database/TableMetadata";
16
+ import TenantColumn from "../../Types/Database/TenantColumn";
17
+ import IconProp from "../../Types/Icon/IconProp";
18
+ import ObjectID from "../../Types/ObjectID";
19
+ import Permission from "../../Types/Permission";
20
+ import {
21
+ Column,
22
+ Entity,
23
+ Index,
24
+ JoinColumn,
25
+ JoinTable,
26
+ ManyToMany,
27
+ ManyToOne,
28
+ } from "typeorm";
29
+
30
+ @EnableDocumentation()
31
+ @TenantColumn("projectId")
32
+ @TableAccessControl({
33
+ create: [
34
+ Permission.ProjectOwner,
35
+ Permission.ProjectAdmin,
36
+ Permission.CreateServerlessFunctionLabelRule,
37
+ ],
38
+ read: [
39
+ Permission.ProjectOwner,
40
+ Permission.ProjectAdmin,
41
+ Permission.ProjectMember,
42
+ Permission.Viewer,
43
+ Permission.ReadServerlessFunctionLabelRule,
44
+ ],
45
+ delete: [
46
+ Permission.ProjectOwner,
47
+ Permission.ProjectAdmin,
48
+ Permission.DeleteServerlessFunctionLabelRule,
49
+ ],
50
+ update: [
51
+ Permission.ProjectOwner,
52
+ Permission.ProjectAdmin,
53
+ Permission.EditServerlessFunctionLabelRule,
54
+ ],
55
+ })
56
+ @CrudApiEndpoint(new Route("/serverless-function-label-rule"))
57
+ @Entity({
58
+ name: "ServerlessFunctionLabelRule",
59
+ })
60
+ @EnableWorkflow({
61
+ create: true,
62
+ delete: true,
63
+ update: true,
64
+ read: true,
65
+ })
66
+ @TableMetadata({
67
+ tableName: "ServerlessFunctionLabelRule",
68
+ singularName: "Serverless Function Label Rule",
69
+ pluralName: "Serverless Function Label Rules",
70
+ icon: IconProp.Tag,
71
+ tableDescription:
72
+ "Rules for automatically attaching labels to serverless functions when matching functions are created.",
73
+ })
74
+ export default class ServerlessFunctionLabelRule extends BaseModel {
75
+ @ColumnAccessControl({
76
+ create: [
77
+ Permission.ProjectOwner,
78
+ Permission.ProjectAdmin,
79
+ Permission.CreateServerlessFunctionLabelRule,
80
+ ],
81
+ read: [
82
+ Permission.ProjectOwner,
83
+ Permission.ProjectAdmin,
84
+ Permission.ProjectMember,
85
+ Permission.Viewer,
86
+ Permission.ReadServerlessFunctionLabelRule,
87
+ ],
88
+ update: [],
89
+ })
90
+ @TableColumn({
91
+ manyToOneRelationColumn: "projectId",
92
+ type: TableColumnType.Entity,
93
+ modelType: Project,
94
+ title: "Project",
95
+ description: "Relation to Project Resource in which this object belongs",
96
+ })
97
+ @ManyToOne(
98
+ () => {
99
+ return Project;
100
+ },
101
+ {
102
+ eager: false,
103
+ nullable: true,
104
+ onDelete: "CASCADE",
105
+ orphanedRowAction: "nullify",
106
+ },
107
+ )
108
+ @JoinColumn({ name: "projectId" })
109
+ public project?: Project = undefined;
110
+
111
+ @ColumnAccessControl({
112
+ create: [
113
+ Permission.ProjectOwner,
114
+ Permission.ProjectAdmin,
115
+ Permission.CreateServerlessFunctionLabelRule,
116
+ ],
117
+ read: [
118
+ Permission.ProjectOwner,
119
+ Permission.ProjectAdmin,
120
+ Permission.ProjectMember,
121
+ Permission.Viewer,
122
+ Permission.ReadServerlessFunctionLabelRule,
123
+ ],
124
+ update: [],
125
+ })
126
+ @Index()
127
+ @TableColumn({
128
+ type: TableColumnType.ObjectID,
129
+ required: true,
130
+ canReadOnRelationQuery: true,
131
+ title: "Project ID",
132
+ description: "ID of your OneUptime Project in which this object belongs",
133
+ })
134
+ @Column({
135
+ type: ColumnType.ObjectID,
136
+ nullable: false,
137
+ transformer: ObjectID.getDatabaseTransformer(),
138
+ })
139
+ public projectId?: ObjectID = undefined;
140
+
141
+ @ColumnAccessControl({
142
+ create: [
143
+ Permission.ProjectOwner,
144
+ Permission.ProjectAdmin,
145
+ Permission.CreateServerlessFunctionLabelRule,
146
+ ],
147
+ read: [
148
+ Permission.ProjectOwner,
149
+ Permission.ProjectAdmin,
150
+ Permission.ProjectMember,
151
+ Permission.Viewer,
152
+ Permission.ReadServerlessFunctionLabelRule,
153
+ ],
154
+ update: [
155
+ Permission.ProjectOwner,
156
+ Permission.ProjectAdmin,
157
+ Permission.EditServerlessFunctionLabelRule,
158
+ ],
159
+ })
160
+ @Index()
161
+ @TableColumn({
162
+ required: true,
163
+ type: TableColumnType.ShortText,
164
+ canReadOnRelationQuery: true,
165
+ title: "Name",
166
+ description: "Name of this rule",
167
+ })
168
+ @Column({
169
+ nullable: false,
170
+ type: ColumnType.ShortText,
171
+ length: ColumnLength.ShortText,
172
+ })
173
+ public name?: string = undefined;
174
+
175
+ @ColumnAccessControl({
176
+ create: [
177
+ Permission.ProjectOwner,
178
+ Permission.ProjectAdmin,
179
+ Permission.CreateServerlessFunctionLabelRule,
180
+ ],
181
+ read: [
182
+ Permission.ProjectOwner,
183
+ Permission.ProjectAdmin,
184
+ Permission.ProjectMember,
185
+ Permission.Viewer,
186
+ Permission.ReadServerlessFunctionLabelRule,
187
+ ],
188
+ update: [
189
+ Permission.ProjectOwner,
190
+ Permission.ProjectAdmin,
191
+ Permission.EditServerlessFunctionLabelRule,
192
+ ],
193
+ })
194
+ @TableColumn({
195
+ required: false,
196
+ type: TableColumnType.LongText,
197
+ title: "Description",
198
+ description: "Description of this rule",
199
+ })
200
+ @Column({
201
+ nullable: true,
202
+ type: ColumnType.LongText,
203
+ length: ColumnLength.LongText,
204
+ })
205
+ public description?: string = undefined;
206
+
207
+ @ColumnAccessControl({
208
+ create: [
209
+ Permission.ProjectOwner,
210
+ Permission.ProjectAdmin,
211
+ Permission.CreateServerlessFunctionLabelRule,
212
+ ],
213
+ read: [
214
+ Permission.ProjectOwner,
215
+ Permission.ProjectAdmin,
216
+ Permission.ProjectMember,
217
+ Permission.Viewer,
218
+ Permission.ReadServerlessFunctionLabelRule,
219
+ ],
220
+ update: [
221
+ Permission.ProjectOwner,
222
+ Permission.ProjectAdmin,
223
+ Permission.EditServerlessFunctionLabelRule,
224
+ ],
225
+ })
226
+ @Index()
227
+ @TableColumn({
228
+ required: true,
229
+ type: TableColumnType.Boolean,
230
+ title: "Is Enabled",
231
+ description: "Whether this rule is enabled",
232
+ defaultValue: true,
233
+ isDefaultValueColumn: true,
234
+ })
235
+ @Column({
236
+ type: ColumnType.Boolean,
237
+ nullable: false,
238
+ default: true,
239
+ })
240
+ public isEnabled?: boolean = undefined;
241
+
242
+ @ColumnAccessControl({
243
+ create: [
244
+ Permission.ProjectOwner,
245
+ Permission.ProjectAdmin,
246
+ Permission.CreateServerlessFunctionLabelRule,
247
+ ],
248
+ read: [
249
+ Permission.ProjectOwner,
250
+ Permission.ProjectAdmin,
251
+ Permission.ProjectMember,
252
+ Permission.Viewer,
253
+ Permission.ReadServerlessFunctionLabelRule,
254
+ ],
255
+ update: [
256
+ Permission.ProjectOwner,
257
+ Permission.ProjectAdmin,
258
+ Permission.EditServerlessFunctionLabelRule,
259
+ ],
260
+ })
261
+ @TableColumn({
262
+ required: false,
263
+ type: TableColumnType.EntityArray,
264
+ modelType: Label,
265
+ title: "Match Labels",
266
+ description:
267
+ "Only trigger for functions that already have at least one of these labels. Leave empty to match regardless of labels.",
268
+ })
269
+ @ManyToMany(
270
+ () => {
271
+ return Label;
272
+ },
273
+ { eager: false },
274
+ )
275
+ @JoinTable({
276
+ name: "SrvlessFnLabelRuleMatchLabel",
277
+ inverseJoinColumn: {
278
+ name: "labelId",
279
+ referencedColumnName: "_id",
280
+ },
281
+ joinColumn: {
282
+ name: "serverlessFunctionLabelRuleId",
283
+ referencedColumnName: "_id",
284
+ },
285
+ })
286
+ public matchLabels?: Array<Label> = undefined;
287
+
288
+ @ColumnAccessControl({
289
+ create: [
290
+ Permission.ProjectOwner,
291
+ Permission.ProjectAdmin,
292
+ Permission.CreateServerlessFunctionLabelRule,
293
+ ],
294
+ read: [
295
+ Permission.ProjectOwner,
296
+ Permission.ProjectAdmin,
297
+ Permission.ProjectMember,
298
+ Permission.Viewer,
299
+ Permission.ReadServerlessFunctionLabelRule,
300
+ ],
301
+ update: [
302
+ Permission.ProjectOwner,
303
+ Permission.ProjectAdmin,
304
+ Permission.EditServerlessFunctionLabelRule,
305
+ ],
306
+ })
307
+ @TableColumn({
308
+ required: false,
309
+ type: TableColumnType.LongText,
310
+ title: "Name Regex Pattern",
311
+ description:
312
+ "Regex (case-insensitive) matched against the function name. Leave empty to match any name.",
313
+ })
314
+ @Column({
315
+ type: ColumnType.LongText,
316
+ nullable: true,
317
+ length: ColumnLength.LongText,
318
+ })
319
+ public nameRegexPattern?: string = undefined;
320
+
321
+ @ColumnAccessControl({
322
+ create: [
323
+ Permission.ProjectOwner,
324
+ Permission.ProjectAdmin,
325
+ Permission.CreateServerlessFunctionLabelRule,
326
+ ],
327
+ read: [
328
+ Permission.ProjectOwner,
329
+ Permission.ProjectAdmin,
330
+ Permission.ProjectMember,
331
+ Permission.Viewer,
332
+ Permission.ReadServerlessFunctionLabelRule,
333
+ ],
334
+ update: [
335
+ Permission.ProjectOwner,
336
+ Permission.ProjectAdmin,
337
+ Permission.EditServerlessFunctionLabelRule,
338
+ ],
339
+ })
340
+ @TableColumn({
341
+ required: false,
342
+ type: TableColumnType.LongText,
343
+ title: "Description Regex Pattern",
344
+ description:
345
+ "Regex (case-insensitive) matched against the function description. Leave empty to match any description.",
346
+ })
347
+ @Column({
348
+ type: ColumnType.LongText,
349
+ nullable: true,
350
+ length: ColumnLength.LongText,
351
+ })
352
+ public descriptionRegexPattern?: string = undefined;
353
+
354
+ @ColumnAccessControl({
355
+ create: [
356
+ Permission.ProjectOwner,
357
+ Permission.ProjectAdmin,
358
+ Permission.CreateServerlessFunctionLabelRule,
359
+ ],
360
+ read: [
361
+ Permission.ProjectOwner,
362
+ Permission.ProjectAdmin,
363
+ Permission.ProjectMember,
364
+ Permission.Viewer,
365
+ Permission.ReadServerlessFunctionLabelRule,
366
+ ],
367
+ update: [
368
+ Permission.ProjectOwner,
369
+ Permission.ProjectAdmin,
370
+ Permission.EditServerlessFunctionLabelRule,
371
+ ],
372
+ })
373
+ @TableColumn({
374
+ required: false,
375
+ type: TableColumnType.EntityArray,
376
+ modelType: Label,
377
+ title: "Labels to Add",
378
+ description:
379
+ "Labels to attach to the function when this rule matches. Already-attached labels are not duplicated.",
380
+ })
381
+ @ManyToMany(
382
+ () => {
383
+ return Label;
384
+ },
385
+ { eager: false },
386
+ )
387
+ @JoinTable({
388
+ name: "SrvlessFnLabelRuleAddLabel",
389
+ inverseJoinColumn: {
390
+ name: "labelId",
391
+ referencedColumnName: "_id",
392
+ },
393
+ joinColumn: {
394
+ name: "serverlessFunctionLabelRuleId",
395
+ referencedColumnName: "_id",
396
+ },
397
+ })
398
+ public labelsToAdd?: Array<Label> = undefined;
399
+
400
+ @ColumnAccessControl({
401
+ create: [
402
+ Permission.ProjectOwner,
403
+ Permission.ProjectAdmin,
404
+ Permission.CreateServerlessFunctionLabelRule,
405
+ ],
406
+ read: [
407
+ Permission.ProjectOwner,
408
+ Permission.ProjectAdmin,
409
+ Permission.ProjectMember,
410
+ Permission.Viewer,
411
+ Permission.ReadServerlessFunctionLabelRule,
412
+ ],
413
+ update: [],
414
+ })
415
+ @TableColumn({
416
+ manyToOneRelationColumn: "createdByUserId",
417
+ type: TableColumnType.Entity,
418
+ modelType: User,
419
+ title: "Created by User",
420
+ description:
421
+ "Relation to User who created this object (if this object was created by a User)",
422
+ })
423
+ @ManyToOne(
424
+ () => {
425
+ return User;
426
+ },
427
+ {
428
+ eager: false,
429
+ nullable: true,
430
+ onDelete: "SET NULL",
431
+ orphanedRowAction: "nullify",
432
+ },
433
+ )
434
+ @JoinColumn({ name: "createdByUserId" })
435
+ public createdByUser?: User = undefined;
436
+
437
+ @ColumnAccessControl({
438
+ create: [
439
+ Permission.ProjectOwner,
440
+ Permission.ProjectAdmin,
441
+ Permission.CreateServerlessFunctionLabelRule,
442
+ ],
443
+ read: [
444
+ Permission.ProjectOwner,
445
+ Permission.ProjectAdmin,
446
+ Permission.ProjectMember,
447
+ Permission.Viewer,
448
+ Permission.ReadServerlessFunctionLabelRule,
449
+ ],
450
+ update: [],
451
+ })
452
+ @TableColumn({
453
+ type: TableColumnType.ObjectID,
454
+ title: "Created by User ID",
455
+ description:
456
+ "User ID who created this object (if this object was created by a User)",
457
+ })
458
+ @Column({
459
+ type: ColumnType.ObjectID,
460
+ nullable: true,
461
+ transformer: ObjectID.getDatabaseTransformer(),
462
+ })
463
+ public createdByUserId?: ObjectID = undefined;
464
+
465
+ @ColumnAccessControl({
466
+ create: [],
467
+ read: [],
468
+ update: [],
469
+ })
470
+ @TableColumn({
471
+ manyToOneRelationColumn: "deletedByUserId",
472
+ type: TableColumnType.Entity,
473
+ title: "Deleted by User",
474
+ modelType: User,
475
+ description:
476
+ "Relation to User who deleted this object (if this object was deleted by a User)",
477
+ })
478
+ @ManyToOne(
479
+ () => {
480
+ return User;
481
+ },
482
+ {
483
+ cascade: false,
484
+ eager: false,
485
+ nullable: true,
486
+ onDelete: "SET NULL",
487
+ orphanedRowAction: "nullify",
488
+ },
489
+ )
490
+ @JoinColumn({ name: "deletedByUserId" })
491
+ public deletedByUser?: User = undefined;
492
+
493
+ @ColumnAccessControl({
494
+ create: [],
495
+ read: [],
496
+ update: [],
497
+ })
498
+ @TableColumn({
499
+ type: TableColumnType.ObjectID,
500
+ title: "Deleted by User ID",
501
+ description:
502
+ "User ID who deleted this object (if this object was deleted by a User)",
503
+ })
504
+ @Column({
505
+ type: ColumnType.ObjectID,
506
+ nullable: true,
507
+ transformer: ObjectID.getDatabaseTransformer(),
508
+ })
509
+ public deletedByUserId?: ObjectID = undefined;
510
+ }