@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,846 @@
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 AccessControlColumn from "../../Types/Database/AccessControlColumn";
9
+ import ColumnLength from "../../Types/Database/ColumnLength";
10
+ import ColumnType from "../../Types/Database/ColumnType";
11
+ import CrudApiEndpoint from "../../Types/Database/CrudApiEndpoint";
12
+ import EnableDocumentation from "../../Types/Database/EnableDocumentation";
13
+ import SlugifyColumn from "../../Types/Database/SlugifyColumn";
14
+ import TableColumn from "../../Types/Database/TableColumn";
15
+ import TableColumnType from "../../Types/Database/TableColumnType";
16
+ import TableMetadata from "../../Types/Database/TableMetadata";
17
+ import TenantColumn from "../../Types/Database/TenantColumn";
18
+ import UniqueColumnBy from "../../Types/Database/UniqueColumnBy";
19
+ import IconProp from "../../Types/Icon/IconProp";
20
+ import ObjectID from "../../Types/ObjectID";
21
+ import Permission from "../../Types/Permission";
22
+ import TelemetryRetentionConfig from "../../Types/Telemetry/TelemetryRetentionConfig";
23
+ import {
24
+ Column,
25
+ Entity,
26
+ Index,
27
+ JoinColumn,
28
+ JoinTable,
29
+ ManyToMany,
30
+ ManyToOne,
31
+ } from "typeorm";
32
+
33
+ @AccessControlColumn("labels")
34
+ @EnableDocumentation()
35
+ @TenantColumn("projectId")
36
+ @TableAccessControl({
37
+ create: [
38
+ Permission.ProjectOwner,
39
+ Permission.ProjectAdmin,
40
+ Permission.ProjectMember,
41
+ Permission.SettingsAdmin,
42
+ Permission.SettingsMember,
43
+ Permission.CreateCloudResource,
44
+ ],
45
+ read: [
46
+ Permission.ProjectOwner,
47
+ Permission.ProjectAdmin,
48
+ Permission.ProjectMember,
49
+ Permission.Viewer,
50
+ Permission.SettingsAdmin,
51
+ Permission.SettingsMember,
52
+ Permission.SettingsViewer,
53
+ Permission.ReadCloudResource,
54
+ ],
55
+ delete: [
56
+ Permission.ProjectOwner,
57
+ Permission.ProjectAdmin,
58
+ Permission.ProjectMember,
59
+ Permission.SettingsAdmin,
60
+ Permission.SettingsMember,
61
+ Permission.DeleteCloudResource,
62
+ ],
63
+ update: [
64
+ Permission.ProjectOwner,
65
+ Permission.ProjectAdmin,
66
+ Permission.ProjectMember,
67
+ Permission.SettingsAdmin,
68
+ Permission.SettingsMember,
69
+ Permission.EditCloudResource,
70
+ ],
71
+ })
72
+ @CrudApiEndpoint(new Route("/cloud-resource"))
73
+ @SlugifyColumn("name", "slug")
74
+ /*
75
+ * Enforce one CloudResource row per (projectId, resourceIdentifier) at the DB
76
+ * level so concurrent first-contact ingest batches for the same managed-compute
77
+ * workload collapse into a single row instead of racing to create duplicates.
78
+ */
79
+ @Index(["projectId", "resourceIdentifier"], { unique: true })
80
+ @TableMetadata({
81
+ tableName: "CloudResource",
82
+ singularName: "Cloud Resource",
83
+ pluralName: "Cloud Resources",
84
+ icon: IconProp.Cloud,
85
+ tableDescription:
86
+ "Managed cloud compute auto-discovered from OpenTelemetry cloud.platform (e.g. AWS ECS/Fargate, GCP Cloud Run, Azure Container Apps, Elastic Beanstalk, App Runner).",
87
+ })
88
+ @Entity({
89
+ name: "CloudResource",
90
+ })
91
+ export default class CloudResource extends BaseModel {
92
+ @ColumnAccessControl({
93
+ create: [
94
+ Permission.ProjectOwner,
95
+ Permission.ProjectAdmin,
96
+ Permission.ProjectMember,
97
+ Permission.SettingsAdmin,
98
+ Permission.SettingsMember,
99
+ Permission.CreateCloudResource,
100
+ ],
101
+ read: [
102
+ Permission.ProjectOwner,
103
+ Permission.ProjectAdmin,
104
+ Permission.ProjectMember,
105
+ Permission.Viewer,
106
+ Permission.SettingsAdmin,
107
+ Permission.SettingsMember,
108
+ Permission.SettingsViewer,
109
+ Permission.ReadCloudResource,
110
+ ],
111
+ update: [],
112
+ })
113
+ @TableColumn({
114
+ manyToOneRelationColumn: "projectId",
115
+ type: TableColumnType.Entity,
116
+ modelType: Project,
117
+ title: "Project",
118
+ description: "Relation to Project Resource in which this object belongs",
119
+ })
120
+ @ManyToOne(
121
+ () => {
122
+ return Project;
123
+ },
124
+ {
125
+ eager: false,
126
+ nullable: true,
127
+ onDelete: "CASCADE",
128
+ orphanedRowAction: "nullify",
129
+ },
130
+ )
131
+ @JoinColumn({ name: "projectId" })
132
+ public project?: Project = undefined;
133
+
134
+ @ColumnAccessControl({
135
+ create: [
136
+ Permission.ProjectOwner,
137
+ Permission.ProjectAdmin,
138
+ Permission.ProjectMember,
139
+ Permission.SettingsAdmin,
140
+ Permission.SettingsMember,
141
+ Permission.CreateCloudResource,
142
+ ],
143
+ read: [
144
+ Permission.ProjectOwner,
145
+ Permission.ProjectAdmin,
146
+ Permission.ProjectMember,
147
+ Permission.Viewer,
148
+ Permission.SettingsAdmin,
149
+ Permission.SettingsMember,
150
+ Permission.SettingsViewer,
151
+ Permission.ReadCloudResource,
152
+ ],
153
+ update: [],
154
+ })
155
+ @Index()
156
+ @TableColumn({
157
+ type: TableColumnType.ObjectID,
158
+ required: true,
159
+ canReadOnRelationQuery: true,
160
+ title: "Project ID",
161
+ description: "ID of your OneUptime Project in which this object belongs",
162
+ })
163
+ @Column({
164
+ type: ColumnType.ObjectID,
165
+ nullable: false,
166
+ transformer: ObjectID.getDatabaseTransformer(),
167
+ })
168
+ public projectId?: ObjectID = undefined;
169
+
170
+ @ColumnAccessControl({
171
+ create: [
172
+ Permission.ProjectOwner,
173
+ Permission.ProjectAdmin,
174
+ Permission.ProjectMember,
175
+ Permission.SettingsAdmin,
176
+ Permission.SettingsMember,
177
+ Permission.CreateCloudResource,
178
+ ],
179
+ read: [
180
+ Permission.ProjectOwner,
181
+ Permission.ProjectAdmin,
182
+ Permission.ProjectMember,
183
+ Permission.Viewer,
184
+ Permission.SettingsAdmin,
185
+ Permission.SettingsMember,
186
+ Permission.SettingsViewer,
187
+ Permission.ReadCloudResource,
188
+ ],
189
+ update: [
190
+ Permission.ProjectOwner,
191
+ Permission.ProjectAdmin,
192
+ Permission.ProjectMember,
193
+ Permission.SettingsAdmin,
194
+ Permission.SettingsMember,
195
+ Permission.EditCloudResource,
196
+ ],
197
+ })
198
+ @TableColumn({
199
+ required: true,
200
+ type: TableColumnType.ShortText,
201
+ canReadOnRelationQuery: true,
202
+ title: "Name",
203
+ description: "Friendly name for this cloud resource",
204
+ example: "checkout-service",
205
+ })
206
+ @Column({
207
+ nullable: false,
208
+ type: ColumnType.ShortText,
209
+ length: ColumnLength.ShortText,
210
+ })
211
+ @UniqueColumnBy("projectId")
212
+ public name?: string = undefined;
213
+
214
+ @ColumnAccessControl({
215
+ create: [],
216
+ read: [
217
+ Permission.ProjectOwner,
218
+ Permission.ProjectAdmin,
219
+ Permission.ProjectMember,
220
+ Permission.Viewer,
221
+ Permission.SettingsAdmin,
222
+ Permission.SettingsMember,
223
+ Permission.SettingsViewer,
224
+ Permission.ReadCloudResource,
225
+ ],
226
+ update: [],
227
+ })
228
+ @TableColumn({
229
+ required: true,
230
+ unique: true,
231
+ type: TableColumnType.Slug,
232
+ computed: true,
233
+ title: "Slug",
234
+ description: "Friendly globally unique name for your object",
235
+ })
236
+ @Column({
237
+ nullable: false,
238
+ type: ColumnType.Slug,
239
+ length: ColumnLength.Slug,
240
+ })
241
+ public slug?: string = undefined;
242
+
243
+ @ColumnAccessControl({
244
+ create: [
245
+ Permission.ProjectOwner,
246
+ Permission.ProjectAdmin,
247
+ Permission.ProjectMember,
248
+ Permission.SettingsAdmin,
249
+ Permission.SettingsMember,
250
+ Permission.CreateCloudResource,
251
+ ],
252
+ read: [
253
+ Permission.ProjectOwner,
254
+ Permission.ProjectAdmin,
255
+ Permission.ProjectMember,
256
+ Permission.Viewer,
257
+ Permission.SettingsAdmin,
258
+ Permission.SettingsMember,
259
+ Permission.SettingsViewer,
260
+ Permission.ReadCloudResource,
261
+ ],
262
+ update: [
263
+ Permission.ProjectOwner,
264
+ Permission.ProjectAdmin,
265
+ Permission.ProjectMember,
266
+ Permission.SettingsAdmin,
267
+ Permission.SettingsMember,
268
+ Permission.EditCloudResource,
269
+ ],
270
+ })
271
+ @TableColumn({
272
+ required: false,
273
+ type: TableColumnType.LongText,
274
+ canReadOnRelationQuery: true,
275
+ title: "Description",
276
+ description: "Friendly description that will help you remember",
277
+ })
278
+ @Column({
279
+ nullable: true,
280
+ type: ColumnType.LongText,
281
+ length: ColumnLength.LongText,
282
+ })
283
+ public description?: string = undefined;
284
+
285
+ @ColumnAccessControl({
286
+ create: [],
287
+ read: [
288
+ Permission.ProjectOwner,
289
+ Permission.ProjectAdmin,
290
+ Permission.ProjectMember,
291
+ Permission.Viewer,
292
+ Permission.SettingsAdmin,
293
+ Permission.SettingsMember,
294
+ Permission.SettingsViewer,
295
+ Permission.ReadCloudResource,
296
+ ],
297
+ update: [],
298
+ })
299
+ @TableColumn({
300
+ required: true,
301
+ type: TableColumnType.ShortText,
302
+ canReadOnRelationQuery: true,
303
+ title: "Resource Identifier",
304
+ description:
305
+ "Stable identifier for this managed-compute workload (service.name, falling back to host.name). Identity key for this resource.",
306
+ })
307
+ @Column({
308
+ nullable: false,
309
+ type: ColumnType.ShortText,
310
+ length: ColumnLength.ShortText,
311
+ })
312
+ public resourceIdentifier?: string = undefined;
313
+
314
+ @ColumnAccessControl({
315
+ create: [],
316
+ read: [
317
+ Permission.ProjectOwner,
318
+ Permission.ProjectAdmin,
319
+ Permission.ProjectMember,
320
+ Permission.Viewer,
321
+ Permission.SettingsAdmin,
322
+ Permission.SettingsMember,
323
+ Permission.SettingsViewer,
324
+ Permission.ReadCloudResource,
325
+ ],
326
+ update: [],
327
+ })
328
+ @TableColumn({
329
+ required: false,
330
+ type: TableColumnType.ShortText,
331
+ canReadOnRelationQuery: true,
332
+ title: "Cloud Platform",
333
+ description:
334
+ "Last-seen cloud.platform OpenTelemetry resource attribute, e.g. aws_ecs, gcp_cloud_run, azure_container_apps.",
335
+ })
336
+ @Column({
337
+ nullable: true,
338
+ type: ColumnType.ShortText,
339
+ length: ColumnLength.ShortText,
340
+ })
341
+ public cloudPlatform?: string = undefined;
342
+
343
+ @ColumnAccessControl({
344
+ create: [],
345
+ read: [
346
+ Permission.ProjectOwner,
347
+ Permission.ProjectAdmin,
348
+ Permission.ProjectMember,
349
+ Permission.Viewer,
350
+ Permission.SettingsAdmin,
351
+ Permission.SettingsMember,
352
+ Permission.SettingsViewer,
353
+ Permission.ReadCloudResource,
354
+ ],
355
+ update: [],
356
+ })
357
+ @TableColumn({
358
+ required: false,
359
+ type: TableColumnType.ShortText,
360
+ canReadOnRelationQuery: true,
361
+ title: "Cloud Provider",
362
+ description:
363
+ "Last-seen cloud.provider OpenTelemetry resource attribute, e.g. aws, gcp, azure.",
364
+ })
365
+ @Column({
366
+ nullable: true,
367
+ type: ColumnType.ShortText,
368
+ length: ColumnLength.ShortText,
369
+ })
370
+ public cloudProvider?: string = undefined;
371
+
372
+ @ColumnAccessControl({
373
+ create: [],
374
+ read: [
375
+ Permission.ProjectOwner,
376
+ Permission.ProjectAdmin,
377
+ Permission.ProjectMember,
378
+ Permission.Viewer,
379
+ Permission.SettingsAdmin,
380
+ Permission.SettingsMember,
381
+ Permission.SettingsViewer,
382
+ Permission.ReadCloudResource,
383
+ ],
384
+ update: [],
385
+ })
386
+ @TableColumn({
387
+ required: false,
388
+ type: TableColumnType.ShortText,
389
+ canReadOnRelationQuery: true,
390
+ title: "Cloud Region",
391
+ description:
392
+ "Last-seen cloud.region OpenTelemetry resource attribute, e.g. us-east-1.",
393
+ })
394
+ @Column({
395
+ nullable: true,
396
+ type: ColumnType.ShortText,
397
+ length: ColumnLength.ShortText,
398
+ })
399
+ public cloudRegion?: string = undefined;
400
+
401
+ @ColumnAccessControl({
402
+ create: [],
403
+ read: [
404
+ Permission.ProjectOwner,
405
+ Permission.ProjectAdmin,
406
+ Permission.ProjectMember,
407
+ Permission.Viewer,
408
+ Permission.SettingsAdmin,
409
+ Permission.SettingsMember,
410
+ Permission.SettingsViewer,
411
+ Permission.ReadCloudResource,
412
+ ],
413
+ update: [],
414
+ })
415
+ @TableColumn({
416
+ required: false,
417
+ type: TableColumnType.ShortText,
418
+ canReadOnRelationQuery: true,
419
+ title: "Cloud Account ID",
420
+ description: "Last-seen cloud.account.id OpenTelemetry resource attribute.",
421
+ })
422
+ @Column({
423
+ nullable: true,
424
+ type: ColumnType.ShortText,
425
+ length: ColumnLength.ShortText,
426
+ })
427
+ public cloudAccountId?: string = undefined;
428
+
429
+ @ColumnAccessControl({
430
+ create: [],
431
+ read: [
432
+ Permission.ProjectOwner,
433
+ Permission.ProjectAdmin,
434
+ Permission.ProjectMember,
435
+ Permission.Viewer,
436
+ Permission.SettingsAdmin,
437
+ Permission.SettingsMember,
438
+ Permission.SettingsViewer,
439
+ Permission.ReadCloudResource,
440
+ ],
441
+ update: [],
442
+ })
443
+ @TableColumn({
444
+ required: false,
445
+ type: TableColumnType.ShortText,
446
+ canReadOnRelationQuery: true,
447
+ title: "Runtime Name",
448
+ description:
449
+ "Last-seen process.runtime.name OpenTelemetry resource attribute.",
450
+ })
451
+ @Column({
452
+ nullable: true,
453
+ type: ColumnType.ShortText,
454
+ length: ColumnLength.ShortText,
455
+ })
456
+ public runtimeName?: string = undefined;
457
+
458
+ @ColumnAccessControl({
459
+ create: [],
460
+ read: [
461
+ Permission.ProjectOwner,
462
+ Permission.ProjectAdmin,
463
+ Permission.ProjectMember,
464
+ Permission.Viewer,
465
+ Permission.SettingsAdmin,
466
+ Permission.SettingsMember,
467
+ Permission.SettingsViewer,
468
+ Permission.ReadCloudResource,
469
+ ],
470
+ update: [],
471
+ })
472
+ @TableColumn({
473
+ required: false,
474
+ type: TableColumnType.ShortText,
475
+ canReadOnRelationQuery: true,
476
+ title: "Runtime Version",
477
+ description:
478
+ "Last-seen process.runtime.version OpenTelemetry resource attribute.",
479
+ })
480
+ @Column({
481
+ nullable: true,
482
+ type: ColumnType.ShortText,
483
+ length: ColumnLength.ShortText,
484
+ })
485
+ public runtimeVersion?: string = undefined;
486
+
487
+ @ColumnAccessControl({
488
+ create: [],
489
+ read: [
490
+ Permission.ProjectOwner,
491
+ Permission.ProjectAdmin,
492
+ Permission.ProjectMember,
493
+ Permission.Viewer,
494
+ Permission.SettingsAdmin,
495
+ Permission.SettingsMember,
496
+ Permission.SettingsViewer,
497
+ Permission.ReadCloudResource,
498
+ ],
499
+ update: [],
500
+ })
501
+ @TableColumn({
502
+ required: false,
503
+ type: TableColumnType.ShortText,
504
+ title: "OTel Collector Status",
505
+ description:
506
+ "Whether telemetry is currently being received (connected) or has gone stale (disconnected).",
507
+ })
508
+ @Column({
509
+ nullable: true,
510
+ type: ColumnType.ShortText,
511
+ length: ColumnLength.ShortText,
512
+ })
513
+ public otelCollectorStatus?: string = undefined;
514
+
515
+ @ColumnAccessControl({
516
+ create: [],
517
+ read: [
518
+ Permission.ProjectOwner,
519
+ Permission.ProjectAdmin,
520
+ Permission.ProjectMember,
521
+ Permission.Viewer,
522
+ Permission.SettingsAdmin,
523
+ Permission.SettingsMember,
524
+ Permission.SettingsViewer,
525
+ Permission.ReadCloudResource,
526
+ ],
527
+ update: [],
528
+ })
529
+ @TableColumn({
530
+ required: false,
531
+ type: TableColumnType.ShortText,
532
+ title: "Agent Version",
533
+ description: "Version of the OneUptime agent reporting this resource.",
534
+ })
535
+ @Column({
536
+ nullable: true,
537
+ type: ColumnType.ShortText,
538
+ length: ColumnLength.ShortText,
539
+ })
540
+ public agentVersion?: string = undefined;
541
+
542
+ @ColumnAccessControl({
543
+ create: [],
544
+ read: [
545
+ Permission.ProjectOwner,
546
+ Permission.ProjectAdmin,
547
+ Permission.ProjectMember,
548
+ Permission.Viewer,
549
+ Permission.SettingsAdmin,
550
+ Permission.SettingsMember,
551
+ Permission.SettingsViewer,
552
+ Permission.ReadCloudResource,
553
+ ],
554
+ update: [],
555
+ })
556
+ @TableColumn({
557
+ required: false,
558
+ type: TableColumnType.Date,
559
+ canReadOnRelationQuery: true,
560
+ title: "Last Seen At",
561
+ description: "When telemetry was last received for this resource",
562
+ })
563
+ @Column({
564
+ nullable: true,
565
+ type: ColumnType.Date,
566
+ })
567
+ public lastSeenAt?: Date = undefined;
568
+
569
+ @ColumnAccessControl({
570
+ create: [
571
+ Permission.ProjectOwner,
572
+ Permission.ProjectAdmin,
573
+ Permission.ProjectMember,
574
+ Permission.SettingsAdmin,
575
+ Permission.SettingsMember,
576
+ Permission.CreateCloudResource,
577
+ ],
578
+ read: [
579
+ Permission.ProjectOwner,
580
+ Permission.ProjectAdmin,
581
+ Permission.ProjectMember,
582
+ Permission.Viewer,
583
+ Permission.SettingsAdmin,
584
+ Permission.SettingsMember,
585
+ Permission.SettingsViewer,
586
+ Permission.ReadCloudResource,
587
+ ],
588
+ update: [
589
+ Permission.ProjectOwner,
590
+ Permission.ProjectAdmin,
591
+ Permission.ProjectMember,
592
+ Permission.SettingsAdmin,
593
+ Permission.SettingsMember,
594
+ Permission.EditCloudResource,
595
+ ],
596
+ })
597
+ @TableColumn({
598
+ required: false,
599
+ type: TableColumnType.EntityArray,
600
+ modelType: Label,
601
+ title: "Labels",
602
+ description:
603
+ "Relation to Labels Array where this object is categorized in.",
604
+ })
605
+ @ManyToMany(
606
+ () => {
607
+ return Label;
608
+ },
609
+ { eager: false },
610
+ )
611
+ @JoinTable({
612
+ name: "CloudResourceLabel",
613
+ inverseJoinColumn: {
614
+ name: "labelId",
615
+ referencedColumnName: "_id",
616
+ },
617
+ joinColumn: {
618
+ name: "cloudResourceId",
619
+ referencedColumnName: "_id",
620
+ },
621
+ })
622
+ public labels?: Array<Label> = undefined;
623
+
624
+ @ColumnAccessControl({
625
+ create: [
626
+ Permission.ProjectOwner,
627
+ Permission.ProjectAdmin,
628
+ Permission.ProjectMember,
629
+ Permission.SettingsAdmin,
630
+ Permission.SettingsMember,
631
+ Permission.CreateCloudResource,
632
+ ],
633
+ read: [
634
+ Permission.ProjectOwner,
635
+ Permission.ProjectAdmin,
636
+ Permission.ProjectMember,
637
+ Permission.Viewer,
638
+ Permission.SettingsAdmin,
639
+ Permission.SettingsMember,
640
+ Permission.SettingsViewer,
641
+ Permission.ReadCloudResource,
642
+ ],
643
+ update: [
644
+ Permission.ProjectOwner,
645
+ Permission.ProjectAdmin,
646
+ Permission.ProjectMember,
647
+ Permission.SettingsAdmin,
648
+ Permission.SettingsMember,
649
+ Permission.EditCloudResource,
650
+ ],
651
+ })
652
+ @TableColumn({
653
+ type: TableColumnType.Number,
654
+ title: "Retain Telemetry Data For Days",
655
+ description:
656
+ "Number of days to retain telemetry data for this resource. Leave blank to use the project-wide default.",
657
+ })
658
+ @Column({
659
+ type: ColumnType.Number,
660
+ nullable: true,
661
+ unique: false,
662
+ })
663
+ public retainTelemetryDataForDays?: number = undefined;
664
+
665
+ @ColumnAccessControl({
666
+ create: [
667
+ Permission.ProjectOwner,
668
+ Permission.ProjectAdmin,
669
+ Permission.ProjectMember,
670
+ Permission.SettingsAdmin,
671
+ Permission.SettingsMember,
672
+ Permission.CreateCloudResource,
673
+ ],
674
+ read: [
675
+ Permission.ProjectOwner,
676
+ Permission.ProjectAdmin,
677
+ Permission.ProjectMember,
678
+ Permission.Viewer,
679
+ Permission.SettingsAdmin,
680
+ Permission.SettingsMember,
681
+ Permission.SettingsViewer,
682
+ Permission.ReadCloudResource,
683
+ ],
684
+ update: [
685
+ Permission.ProjectOwner,
686
+ Permission.ProjectAdmin,
687
+ Permission.ProjectMember,
688
+ Permission.SettingsAdmin,
689
+ Permission.SettingsMember,
690
+ Permission.EditCloudResource,
691
+ ],
692
+ })
693
+ @TableColumn({
694
+ type: TableColumnType.JSON,
695
+ required: false,
696
+ title: "Telemetry Data Retention Overrides",
697
+ description:
698
+ "Per-pillar retention overrides for this resource. Unset fields fall back to the resource default, then the project's retention settings.",
699
+ })
700
+ @Column({
701
+ type: ColumnType.JSON,
702
+ nullable: true,
703
+ })
704
+ public telemetryRetentionConfig?: TelemetryRetentionConfig = undefined;
705
+
706
+ @ColumnAccessControl({
707
+ create: [
708
+ Permission.ProjectOwner,
709
+ Permission.ProjectAdmin,
710
+ Permission.ProjectMember,
711
+ Permission.SettingsAdmin,
712
+ Permission.SettingsMember,
713
+ Permission.CreateCloudResource,
714
+ ],
715
+ read: [
716
+ Permission.ProjectOwner,
717
+ Permission.ProjectAdmin,
718
+ Permission.ProjectMember,
719
+ Permission.Viewer,
720
+ Permission.SettingsAdmin,
721
+ Permission.SettingsMember,
722
+ Permission.SettingsViewer,
723
+ Permission.ReadCloudResource,
724
+ ],
725
+ update: [],
726
+ })
727
+ @TableColumn({
728
+ manyToOneRelationColumn: "createdByUserId",
729
+ type: TableColumnType.Entity,
730
+ modelType: User,
731
+ title: "Created by User",
732
+ description:
733
+ "Relation to User who created this object (if this object was created by a User)",
734
+ })
735
+ @ManyToOne(
736
+ () => {
737
+ return User;
738
+ },
739
+ {
740
+ eager: false,
741
+ nullable: true,
742
+ onDelete: "SET NULL",
743
+ orphanedRowAction: "nullify",
744
+ },
745
+ )
746
+ @JoinColumn({ name: "createdByUserId" })
747
+ public createdByUser?: User = undefined;
748
+
749
+ @ColumnAccessControl({
750
+ create: [
751
+ Permission.ProjectOwner,
752
+ Permission.ProjectAdmin,
753
+ Permission.ProjectMember,
754
+ Permission.SettingsAdmin,
755
+ Permission.SettingsMember,
756
+ Permission.CreateCloudResource,
757
+ ],
758
+ read: [
759
+ Permission.ProjectOwner,
760
+ Permission.ProjectAdmin,
761
+ Permission.ProjectMember,
762
+ Permission.Viewer,
763
+ Permission.SettingsAdmin,
764
+ Permission.SettingsMember,
765
+ Permission.SettingsViewer,
766
+ Permission.ReadCloudResource,
767
+ ],
768
+ update: [],
769
+ })
770
+ @TableColumn({
771
+ type: TableColumnType.ObjectID,
772
+ title: "Created by User ID",
773
+ description:
774
+ "User ID who created this object (if this object was created by a User)",
775
+ })
776
+ @Column({
777
+ type: ColumnType.ObjectID,
778
+ nullable: true,
779
+ transformer: ObjectID.getDatabaseTransformer(),
780
+ })
781
+ public createdByUserId?: ObjectID = undefined;
782
+
783
+ @ColumnAccessControl({
784
+ create: [],
785
+ read: [
786
+ Permission.ProjectOwner,
787
+ Permission.ProjectAdmin,
788
+ Permission.ProjectMember,
789
+ Permission.Viewer,
790
+ Permission.SettingsAdmin,
791
+ Permission.SettingsMember,
792
+ Permission.SettingsViewer,
793
+ Permission.ReadCloudResource,
794
+ ],
795
+ update: [],
796
+ })
797
+ @TableColumn({
798
+ manyToOneRelationColumn: "deletedByUserId",
799
+ type: TableColumnType.Entity,
800
+ title: "Deleted by User",
801
+ modelType: User,
802
+ description:
803
+ "Relation to User who deleted this object (if this object was deleted by a User)",
804
+ })
805
+ @ManyToOne(
806
+ () => {
807
+ return User;
808
+ },
809
+ {
810
+ cascade: false,
811
+ eager: false,
812
+ nullable: true,
813
+ onDelete: "SET NULL",
814
+ orphanedRowAction: "nullify",
815
+ },
816
+ )
817
+ @JoinColumn({ name: "deletedByUserId" })
818
+ public deletedByUser?: User = undefined;
819
+
820
+ @ColumnAccessControl({
821
+ create: [],
822
+ read: [
823
+ Permission.ProjectOwner,
824
+ Permission.ProjectAdmin,
825
+ Permission.ProjectMember,
826
+ Permission.Viewer,
827
+ Permission.SettingsAdmin,
828
+ Permission.SettingsMember,
829
+ Permission.SettingsViewer,
830
+ Permission.ReadCloudResource,
831
+ ],
832
+ update: [],
833
+ })
834
+ @TableColumn({
835
+ type: TableColumnType.ObjectID,
836
+ title: "Deleted by User ID",
837
+ description:
838
+ "User ID who deleted this object (if this object was deleted by a User)",
839
+ })
840
+ @Column({
841
+ type: ColumnType.ObjectID,
842
+ nullable: true,
843
+ transformer: ObjectID.getDatabaseTransformer(),
844
+ })
845
+ public deletedByUserId?: ObjectID = undefined;
846
+ }