@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,486 @@
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 ColumnType from "../../Types/Database/ColumnType";
9
+ import CrudApiEndpoint from "../../Types/Database/CrudApiEndpoint";
10
+ import EnableDocumentation from "../../Types/Database/EnableDocumentation";
11
+ import EnableWorkflow from "../../Types/Database/EnableWorkflow";
12
+ import TableColumn from "../../Types/Database/TableColumn";
13
+ import TableColumnType from "../../Types/Database/TableColumnType";
14
+ import TableMetadata from "../../Types/Database/TableMetadata";
15
+ import TenantColumn from "../../Types/Database/TenantColumn";
16
+ import IconProp from "../../Types/Icon/IconProp";
17
+ import ObjectID from "../../Types/ObjectID";
18
+ import Permission from "../../Types/Permission";
19
+ import { Column, Entity, Index, JoinColumn, ManyToOne } from "typeorm";
20
+
21
+ @EnableDocumentation()
22
+ @TenantColumn("projectId")
23
+ @TableAccessControl({
24
+ create: [
25
+ Permission.ProjectOwner,
26
+ Permission.ProjectAdmin,
27
+ Permission.ProjectMember,
28
+ Permission.SettingsAdmin,
29
+ Permission.SettingsMember,
30
+ Permission.CreateServerlessFunctionOwnerUser,
31
+ ],
32
+ read: [
33
+ Permission.ProjectOwner,
34
+ Permission.ProjectAdmin,
35
+ Permission.ProjectMember,
36
+ Permission.Viewer,
37
+ Permission.SettingsAdmin,
38
+ Permission.SettingsMember,
39
+ Permission.SettingsViewer,
40
+ Permission.ReadServerlessFunctionOwnerUser,
41
+ ],
42
+ delete: [
43
+ Permission.ProjectOwner,
44
+ Permission.ProjectAdmin,
45
+ Permission.ProjectMember,
46
+ Permission.SettingsAdmin,
47
+ Permission.SettingsMember,
48
+ Permission.DeleteServerlessFunctionOwnerUser,
49
+ ],
50
+ update: [
51
+ Permission.ProjectOwner,
52
+ Permission.ProjectAdmin,
53
+ Permission.ProjectMember,
54
+ Permission.SettingsAdmin,
55
+ Permission.SettingsMember,
56
+ Permission.EditServerlessFunctionOwnerUser,
57
+ ],
58
+ })
59
+ @EnableWorkflow({
60
+ create: true,
61
+ delete: true,
62
+ update: true,
63
+ read: true,
64
+ })
65
+ @CrudApiEndpoint(new Route("/serverless-function-owner-user"))
66
+ @TableMetadata({
67
+ tableName: "ServerlessFunctionOwnerUser",
68
+ singularName: "Serverless Function User Owner",
69
+ pluralName: "Serverless Function User Owners",
70
+ icon: IconProp.Bolt,
71
+ tableDescription: "Add users as owners to your serverless functions.",
72
+ })
73
+ @Entity({
74
+ name: "ServerlessFunctionOwnerUser",
75
+ })
76
+ export default class ServerlessFunctionOwnerUser extends BaseModel {
77
+ @ColumnAccessControl({
78
+ create: [
79
+ Permission.ProjectOwner,
80
+ Permission.ProjectAdmin,
81
+ Permission.ProjectMember,
82
+ Permission.SettingsAdmin,
83
+ Permission.SettingsMember,
84
+ Permission.CreateServerlessFunctionOwnerUser,
85
+ ],
86
+ read: [
87
+ Permission.ProjectOwner,
88
+ Permission.ProjectAdmin,
89
+ Permission.ProjectMember,
90
+ Permission.Viewer,
91
+ Permission.SettingsAdmin,
92
+ Permission.SettingsMember,
93
+ Permission.SettingsViewer,
94
+ Permission.ReadServerlessFunctionOwnerUser,
95
+ ],
96
+ update: [],
97
+ })
98
+ @TableColumn({
99
+ manyToOneRelationColumn: "projectId",
100
+ type: TableColumnType.Entity,
101
+ modelType: Project,
102
+ title: "Project",
103
+ description: "Relation to Project Resource in which this object belongs",
104
+ })
105
+ @ManyToOne(
106
+ () => {
107
+ return Project;
108
+ },
109
+ {
110
+ eager: false,
111
+ nullable: false,
112
+ onDelete: "CASCADE",
113
+ orphanedRowAction: "nullify",
114
+ },
115
+ )
116
+ @JoinColumn({ name: "projectId" })
117
+ public project?: Project = undefined;
118
+
119
+ @ColumnAccessControl({
120
+ create: [
121
+ Permission.ProjectOwner,
122
+ Permission.ProjectAdmin,
123
+ Permission.ProjectMember,
124
+ Permission.SettingsAdmin,
125
+ Permission.SettingsMember,
126
+ Permission.CreateServerlessFunctionOwnerUser,
127
+ ],
128
+ read: [
129
+ Permission.ProjectOwner,
130
+ Permission.ProjectAdmin,
131
+ Permission.ProjectMember,
132
+ Permission.Viewer,
133
+ Permission.SettingsAdmin,
134
+ Permission.SettingsMember,
135
+ Permission.SettingsViewer,
136
+ Permission.ReadServerlessFunctionOwnerUser,
137
+ ],
138
+ update: [],
139
+ })
140
+ @Index()
141
+ @TableColumn({
142
+ type: TableColumnType.ObjectID,
143
+ required: true,
144
+ canReadOnRelationQuery: true,
145
+ title: "Project ID",
146
+ description: "ID of your OneUptime Project in which this object belongs",
147
+ })
148
+ @Column({
149
+ type: ColumnType.ObjectID,
150
+ nullable: false,
151
+ transformer: ObjectID.getDatabaseTransformer(),
152
+ })
153
+ public projectId?: ObjectID = undefined;
154
+
155
+ @ColumnAccessControl({
156
+ create: [
157
+ Permission.ProjectOwner,
158
+ Permission.ProjectAdmin,
159
+ Permission.ProjectMember,
160
+ Permission.SettingsAdmin,
161
+ Permission.SettingsMember,
162
+ Permission.CreateServerlessFunctionOwnerUser,
163
+ ],
164
+ read: [
165
+ Permission.ProjectOwner,
166
+ Permission.ProjectAdmin,
167
+ Permission.ProjectMember,
168
+ Permission.Viewer,
169
+ Permission.SettingsAdmin,
170
+ Permission.SettingsMember,
171
+ Permission.SettingsViewer,
172
+ Permission.ReadServerlessFunctionOwnerUser,
173
+ ],
174
+ update: [],
175
+ })
176
+ @TableColumn({
177
+ manyToOneRelationColumn: "userId",
178
+ type: TableColumnType.Entity,
179
+ modelType: User,
180
+ title: "User",
181
+ description:
182
+ "User that is the owner. This user will receive notifications. ",
183
+ })
184
+ @ManyToOne(
185
+ () => {
186
+ return User;
187
+ },
188
+ {
189
+ eager: false,
190
+ nullable: true,
191
+ onDelete: "CASCADE",
192
+ orphanedRowAction: "nullify",
193
+ },
194
+ )
195
+ @JoinColumn({ name: "userId" })
196
+ public user?: User = undefined;
197
+
198
+ @ColumnAccessControl({
199
+ create: [
200
+ Permission.ProjectOwner,
201
+ Permission.ProjectAdmin,
202
+ Permission.ProjectMember,
203
+ Permission.SettingsAdmin,
204
+ Permission.SettingsMember,
205
+ Permission.CreateServerlessFunctionOwnerUser,
206
+ ],
207
+ read: [
208
+ Permission.ProjectOwner,
209
+ Permission.ProjectAdmin,
210
+ Permission.ProjectMember,
211
+ Permission.Viewer,
212
+ Permission.SettingsAdmin,
213
+ Permission.SettingsMember,
214
+ Permission.SettingsViewer,
215
+ Permission.ReadServerlessFunctionOwnerUser,
216
+ ],
217
+ update: [],
218
+ })
219
+ @Index()
220
+ @TableColumn({
221
+ type: TableColumnType.ObjectID,
222
+ required: true,
223
+ canReadOnRelationQuery: true,
224
+ title: "User ID",
225
+ description: "ID of your OneUptime User in which this object belongs",
226
+ })
227
+ @Column({
228
+ type: ColumnType.ObjectID,
229
+ nullable: false,
230
+ transformer: ObjectID.getDatabaseTransformer(),
231
+ })
232
+ public userId?: ObjectID = undefined;
233
+
234
+ @ColumnAccessControl({
235
+ create: [
236
+ Permission.ProjectOwner,
237
+ Permission.ProjectAdmin,
238
+ Permission.ProjectMember,
239
+ Permission.SettingsAdmin,
240
+ Permission.SettingsMember,
241
+ Permission.CreateServerlessFunctionOwnerUser,
242
+ ],
243
+ read: [
244
+ Permission.ProjectOwner,
245
+ Permission.ProjectAdmin,
246
+ Permission.ProjectMember,
247
+ Permission.Viewer,
248
+ Permission.SettingsAdmin,
249
+ Permission.SettingsMember,
250
+ Permission.SettingsViewer,
251
+ Permission.ReadServerlessFunctionOwnerUser,
252
+ ],
253
+ update: [],
254
+ })
255
+ @TableColumn({
256
+ manyToOneRelationColumn: "serverlessFunctionId",
257
+ type: TableColumnType.Entity,
258
+ modelType: ServerlessFunction,
259
+ title: "Serverless Function",
260
+ description:
261
+ "Relation to Serverless Function Resource in which this object belongs",
262
+ })
263
+ @ManyToOne(
264
+ () => {
265
+ return ServerlessFunction;
266
+ },
267
+ {
268
+ eager: false,
269
+ nullable: true,
270
+ onDelete: "CASCADE",
271
+ orphanedRowAction: "nullify",
272
+ },
273
+ )
274
+ @JoinColumn({ name: "serverlessFunctionId" })
275
+ public serverlessFunction?: ServerlessFunction = undefined;
276
+
277
+ @ColumnAccessControl({
278
+ create: [
279
+ Permission.ProjectOwner,
280
+ Permission.ProjectAdmin,
281
+ Permission.ProjectMember,
282
+ Permission.SettingsAdmin,
283
+ Permission.SettingsMember,
284
+ Permission.CreateServerlessFunctionOwnerUser,
285
+ ],
286
+ read: [
287
+ Permission.ProjectOwner,
288
+ Permission.ProjectAdmin,
289
+ Permission.ProjectMember,
290
+ Permission.Viewer,
291
+ Permission.SettingsAdmin,
292
+ Permission.SettingsMember,
293
+ Permission.SettingsViewer,
294
+ Permission.ReadServerlessFunctionOwnerUser,
295
+ ],
296
+ update: [],
297
+ })
298
+ @Index()
299
+ @TableColumn({
300
+ type: TableColumnType.ObjectID,
301
+ required: true,
302
+ canReadOnRelationQuery: true,
303
+ title: "Serverless Function ID",
304
+ description:
305
+ "ID of your OneUptime Serverless Function in which this object belongs",
306
+ })
307
+ @Column({
308
+ type: ColumnType.ObjectID,
309
+ nullable: false,
310
+ transformer: ObjectID.getDatabaseTransformer(),
311
+ })
312
+ public serverlessFunctionId?: ObjectID = undefined;
313
+
314
+ @ColumnAccessControl({
315
+ create: [
316
+ Permission.ProjectOwner,
317
+ Permission.ProjectAdmin,
318
+ Permission.ProjectMember,
319
+ Permission.SettingsAdmin,
320
+ Permission.SettingsMember,
321
+ Permission.CreateServerlessFunctionOwnerUser,
322
+ ],
323
+ read: [
324
+ Permission.ProjectOwner,
325
+ Permission.ProjectAdmin,
326
+ Permission.ProjectMember,
327
+ Permission.Viewer,
328
+ Permission.SettingsAdmin,
329
+ Permission.SettingsMember,
330
+ Permission.SettingsViewer,
331
+ Permission.ReadServerlessFunctionOwnerUser,
332
+ ],
333
+ update: [],
334
+ })
335
+ @TableColumn({
336
+ manyToOneRelationColumn: "createdByUserId",
337
+ type: TableColumnType.Entity,
338
+ modelType: User,
339
+ title: "Created by User",
340
+ description:
341
+ "Relation to User who created this object (if this object was created by a User)",
342
+ })
343
+ @ManyToOne(
344
+ () => {
345
+ return User;
346
+ },
347
+ {
348
+ eager: false,
349
+ nullable: true,
350
+ onDelete: "SET NULL",
351
+ orphanedRowAction: "nullify",
352
+ },
353
+ )
354
+ @JoinColumn({ name: "createdByUserId" })
355
+ public createdByUser?: User = undefined;
356
+
357
+ @ColumnAccessControl({
358
+ create: [
359
+ Permission.ProjectOwner,
360
+ Permission.ProjectAdmin,
361
+ Permission.ProjectMember,
362
+ Permission.SettingsAdmin,
363
+ Permission.SettingsMember,
364
+ Permission.CreateServerlessFunctionOwnerUser,
365
+ ],
366
+ read: [
367
+ Permission.ProjectOwner,
368
+ Permission.ProjectAdmin,
369
+ Permission.ProjectMember,
370
+ Permission.Viewer,
371
+ Permission.SettingsAdmin,
372
+ Permission.SettingsMember,
373
+ Permission.SettingsViewer,
374
+ Permission.ReadServerlessFunctionOwnerUser,
375
+ ],
376
+ update: [],
377
+ })
378
+ @TableColumn({
379
+ type: TableColumnType.ObjectID,
380
+ title: "Created by User ID",
381
+ description:
382
+ "User ID who created this object (if this object was created by a User)",
383
+ })
384
+ @Column({
385
+ type: ColumnType.ObjectID,
386
+ nullable: true,
387
+ transformer: ObjectID.getDatabaseTransformer(),
388
+ })
389
+ public createdByUserId?: ObjectID = undefined;
390
+
391
+ @ColumnAccessControl({
392
+ create: [],
393
+ read: [
394
+ Permission.ProjectOwner,
395
+ Permission.ProjectAdmin,
396
+ Permission.ProjectMember,
397
+ Permission.Viewer,
398
+ Permission.SettingsAdmin,
399
+ Permission.SettingsMember,
400
+ Permission.SettingsViewer,
401
+ Permission.ReadServerlessFunctionOwnerUser,
402
+ ],
403
+ update: [],
404
+ })
405
+ @TableColumn({
406
+ manyToOneRelationColumn: "deletedByUserId",
407
+ type: TableColumnType.Entity,
408
+ title: "Deleted by User",
409
+ modelType: User,
410
+ description:
411
+ "Relation to User who deleted this object (if this object was deleted by a User)",
412
+ })
413
+ @ManyToOne(
414
+ () => {
415
+ return User;
416
+ },
417
+ {
418
+ cascade: false,
419
+ eager: false,
420
+ nullable: true,
421
+ onDelete: "SET NULL",
422
+ orphanedRowAction: "nullify",
423
+ },
424
+ )
425
+ @JoinColumn({ name: "deletedByUserId" })
426
+ public deletedByUser?: User = undefined;
427
+
428
+ @ColumnAccessControl({
429
+ create: [],
430
+ read: [
431
+ Permission.ProjectOwner,
432
+ Permission.ProjectAdmin,
433
+ Permission.ProjectMember,
434
+ Permission.Viewer,
435
+ Permission.SettingsAdmin,
436
+ Permission.SettingsMember,
437
+ Permission.SettingsViewer,
438
+ Permission.ReadServerlessFunctionOwnerUser,
439
+ ],
440
+ update: [],
441
+ })
442
+ @TableColumn({
443
+ type: TableColumnType.ObjectID,
444
+ title: "Deleted by User ID",
445
+ description:
446
+ "User ID who deleted this object (if this object was deleted by a User)",
447
+ })
448
+ @Column({
449
+ type: ColumnType.ObjectID,
450
+ nullable: true,
451
+ transformer: ObjectID.getDatabaseTransformer(),
452
+ })
453
+ public deletedByUserId?: ObjectID = undefined;
454
+
455
+ @ColumnAccessControl({
456
+ create: [],
457
+ read: [
458
+ Permission.ProjectOwner,
459
+ Permission.ProjectAdmin,
460
+ Permission.ProjectMember,
461
+ Permission.Viewer,
462
+ Permission.SettingsAdmin,
463
+ Permission.SettingsMember,
464
+ Permission.SettingsViewer,
465
+ Permission.ReadServerlessFunctionOwnerUser,
466
+ ],
467
+ update: [],
468
+ })
469
+ @Index()
470
+ @TableColumn({
471
+ type: TableColumnType.Boolean,
472
+ computed: true,
473
+ hideColumnInDocumentation: true,
474
+ required: true,
475
+ isDefaultValueColumn: true,
476
+ title: "Are Owners Notified",
477
+ description: "Are owners notified of this resource ownership?",
478
+ defaultValue: false,
479
+ })
480
+ @Column({
481
+ type: ColumnType.Boolean,
482
+ nullable: false,
483
+ default: false,
484
+ })
485
+ public isOwnerNotified?: boolean = undefined;
486
+ }