@oneuptime/common 10.7.2 → 10.8.1

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