@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,205 @@
1
+ import { MigrationInterface, QueryRunner } from "typeorm";
2
+
3
+ /*
4
+ * Phase 1: Serverless / FaaS resource type. Creates the ServerlessFunction
5
+ * resource table, its owner-user / owner-team tables, and the label join
6
+ * table — mirroring the Host/DockerHost/KubernetesCluster shape so the
7
+ * polymorphic telemetry serviceId can point at a ServerlessFunction row.
8
+ */
9
+ export class AddServerlessFunctionTables1780933132562
10
+ implements MigrationInterface
11
+ {
12
+ public name = "AddServerlessFunctionTables1780933132562";
13
+
14
+ public async up(queryRunner: QueryRunner): Promise<void> {
15
+ await queryRunner.query(
16
+ `CREATE TABLE "ServerlessFunction" ("_id" uuid NOT NULL DEFAULT uuid_generate_v4(), "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "updatedAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "deletedAt" TIMESTAMP WITH TIME ZONE, "version" integer NOT NULL, "projectId" uuid NOT NULL, "name" character varying(100) NOT NULL, "slug" character varying(100) NOT NULL, "description" character varying(500), "functionIdentifier" character varying(100) NOT NULL, "cloudPlatform" character varying(100), "cloudProvider" character varying(100), "cloudRegion" character varying(100), "cloudAccountId" character varying(100), "functionVersion" character varying(100), "runtimeName" character varying(100), "runtimeVersion" character varying(100), "otelCollectorStatus" character varying(100) DEFAULT 'disconnected', "agentVersion" character varying(100), "lastSeenAt" TIMESTAMP WITH TIME ZONE, "retainTelemetryDataForDays" integer, "telemetryRetentionConfig" jsonb, "createdByUserId" uuid, "deletedByUserId" uuid, CONSTRAINT "PK_ServerlessFunction" PRIMARY KEY ("_id"))`,
17
+ );
18
+ await queryRunner.query(
19
+ `CREATE INDEX "IDX_ServerlessFunction_projectId" ON "ServerlessFunction" ("projectId") `,
20
+ );
21
+ await queryRunner.query(
22
+ `CREATE UNIQUE INDEX "UQ_ServerlessFunction_project_fnId" ON "ServerlessFunction" ("projectId", "functionIdentifier") `,
23
+ );
24
+
25
+ await queryRunner.query(
26
+ `CREATE TABLE "ServerlessFunctionOwnerTeam" ("_id" uuid NOT NULL DEFAULT uuid_generate_v4(), "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "updatedAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "deletedAt" TIMESTAMP WITH TIME ZONE, "version" integer NOT NULL, "projectId" uuid NOT NULL, "teamId" uuid NOT NULL, "serverlessFunctionId" uuid NOT NULL, "createdByUserId" uuid, "deletedByUserId" uuid, "isOwnerNotified" boolean NOT NULL DEFAULT false, CONSTRAINT "PK_ServerlessFunctionOwnerTeam" PRIMARY KEY ("_id"))`,
27
+ );
28
+ await queryRunner.query(
29
+ `CREATE INDEX "IDX_SrvlessFnOwnerTeam_projectId" ON "ServerlessFunctionOwnerTeam" ("projectId") `,
30
+ );
31
+ await queryRunner.query(
32
+ `CREATE INDEX "IDX_SrvlessFnOwnerTeam_teamId" ON "ServerlessFunctionOwnerTeam" ("teamId") `,
33
+ );
34
+ await queryRunner.query(
35
+ `CREATE INDEX "IDX_SrvlessFnOwnerTeam_fnId" ON "ServerlessFunctionOwnerTeam" ("serverlessFunctionId") `,
36
+ );
37
+ await queryRunner.query(
38
+ `CREATE INDEX "IDX_SrvlessFnOwnerTeam_notified" ON "ServerlessFunctionOwnerTeam" ("isOwnerNotified") `,
39
+ );
40
+
41
+ await queryRunner.query(
42
+ `CREATE TABLE "ServerlessFunctionOwnerUser" ("_id" uuid NOT NULL DEFAULT uuid_generate_v4(), "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "updatedAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "deletedAt" TIMESTAMP WITH TIME ZONE, "version" integer NOT NULL, "projectId" uuid NOT NULL, "userId" uuid NOT NULL, "serverlessFunctionId" uuid NOT NULL, "createdByUserId" uuid, "deletedByUserId" uuid, "isOwnerNotified" boolean NOT NULL DEFAULT false, CONSTRAINT "PK_ServerlessFunctionOwnerUser" PRIMARY KEY ("_id"))`,
43
+ );
44
+ await queryRunner.query(
45
+ `CREATE INDEX "IDX_SrvlessFnOwnerUser_projectId" ON "ServerlessFunctionOwnerUser" ("projectId") `,
46
+ );
47
+ await queryRunner.query(
48
+ `CREATE INDEX "IDX_SrvlessFnOwnerUser_userId" ON "ServerlessFunctionOwnerUser" ("userId") `,
49
+ );
50
+ await queryRunner.query(
51
+ `CREATE INDEX "IDX_SrvlessFnOwnerUser_fnId" ON "ServerlessFunctionOwnerUser" ("serverlessFunctionId") `,
52
+ );
53
+ await queryRunner.query(
54
+ `CREATE INDEX "IDX_SrvlessFnOwnerUser_notified" ON "ServerlessFunctionOwnerUser" ("isOwnerNotified") `,
55
+ );
56
+
57
+ await queryRunner.query(
58
+ `CREATE TABLE "ServerlessFunctionLabel" ("serverlessFunctionId" uuid NOT NULL, "labelId" uuid NOT NULL, CONSTRAINT "PK_ServerlessFunctionLabel" PRIMARY KEY ("serverlessFunctionId", "labelId"))`,
59
+ );
60
+ await queryRunner.query(
61
+ `CREATE INDEX "IDX_ServerlessFunctionLabel_fnId" ON "ServerlessFunctionLabel" ("serverlessFunctionId") `,
62
+ );
63
+ await queryRunner.query(
64
+ `CREATE INDEX "IDX_ServerlessFunctionLabel_labelId" ON "ServerlessFunctionLabel" ("labelId") `,
65
+ );
66
+
67
+ // Foreign keys: ServerlessFunction
68
+ await queryRunner.query(
69
+ `ALTER TABLE "ServerlessFunction" ADD CONSTRAINT "FK_ServerlessFunction_projectId" FOREIGN KEY ("projectId") REFERENCES "Project"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
70
+ );
71
+ await queryRunner.query(
72
+ `ALTER TABLE "ServerlessFunction" ADD CONSTRAINT "FK_ServerlessFunction_createdBy" FOREIGN KEY ("createdByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
73
+ );
74
+ await queryRunner.query(
75
+ `ALTER TABLE "ServerlessFunction" ADD CONSTRAINT "FK_ServerlessFunction_deletedBy" FOREIGN KEY ("deletedByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
76
+ );
77
+
78
+ // Foreign keys: ServerlessFunctionOwnerTeam
79
+ await queryRunner.query(
80
+ `ALTER TABLE "ServerlessFunctionOwnerTeam" ADD CONSTRAINT "FK_SrvlessFnOwnerTeam_projectId" FOREIGN KEY ("projectId") REFERENCES "Project"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
81
+ );
82
+ await queryRunner.query(
83
+ `ALTER TABLE "ServerlessFunctionOwnerTeam" ADD CONSTRAINT "FK_SrvlessFnOwnerTeam_teamId" FOREIGN KEY ("teamId") REFERENCES "Team"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
84
+ );
85
+ await queryRunner.query(
86
+ `ALTER TABLE "ServerlessFunctionOwnerTeam" ADD CONSTRAINT "FK_SrvlessFnOwnerTeam_fnId" FOREIGN KEY ("serverlessFunctionId") REFERENCES "ServerlessFunction"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
87
+ );
88
+ await queryRunner.query(
89
+ `ALTER TABLE "ServerlessFunctionOwnerTeam" ADD CONSTRAINT "FK_SrvlessFnOwnerTeam_createdBy" FOREIGN KEY ("createdByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
90
+ );
91
+ await queryRunner.query(
92
+ `ALTER TABLE "ServerlessFunctionOwnerTeam" ADD CONSTRAINT "FK_SrvlessFnOwnerTeam_deletedBy" FOREIGN KEY ("deletedByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
93
+ );
94
+
95
+ // Foreign keys: ServerlessFunctionOwnerUser
96
+ await queryRunner.query(
97
+ `ALTER TABLE "ServerlessFunctionOwnerUser" ADD CONSTRAINT "FK_SrvlessFnOwnerUser_projectId" FOREIGN KEY ("projectId") REFERENCES "Project"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
98
+ );
99
+ await queryRunner.query(
100
+ `ALTER TABLE "ServerlessFunctionOwnerUser" ADD CONSTRAINT "FK_SrvlessFnOwnerUser_userId" FOREIGN KEY ("userId") REFERENCES "User"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
101
+ );
102
+ await queryRunner.query(
103
+ `ALTER TABLE "ServerlessFunctionOwnerUser" ADD CONSTRAINT "FK_SrvlessFnOwnerUser_fnId" FOREIGN KEY ("serverlessFunctionId") REFERENCES "ServerlessFunction"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
104
+ );
105
+ await queryRunner.query(
106
+ `ALTER TABLE "ServerlessFunctionOwnerUser" ADD CONSTRAINT "FK_SrvlessFnOwnerUser_createdBy" FOREIGN KEY ("createdByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
107
+ );
108
+ await queryRunner.query(
109
+ `ALTER TABLE "ServerlessFunctionOwnerUser" ADD CONSTRAINT "FK_SrvlessFnOwnerUser_deletedBy" FOREIGN KEY ("deletedByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
110
+ );
111
+
112
+ // Foreign keys: ServerlessFunctionLabel join table
113
+ await queryRunner.query(
114
+ `ALTER TABLE "ServerlessFunctionLabel" ADD CONSTRAINT "FK_ServerlessFunctionLabel_fnId" FOREIGN KEY ("serverlessFunctionId") REFERENCES "ServerlessFunction"("_id") ON DELETE CASCADE ON UPDATE CASCADE`,
115
+ );
116
+ await queryRunner.query(
117
+ `ALTER TABLE "ServerlessFunctionLabel" ADD CONSTRAINT "FK_ServerlessFunctionLabel_labelId" FOREIGN KEY ("labelId") REFERENCES "Label"("_id") ON DELETE CASCADE ON UPDATE CASCADE`,
118
+ );
119
+ }
120
+
121
+ public async down(queryRunner: QueryRunner): Promise<void> {
122
+ await queryRunner.query(
123
+ `ALTER TABLE "ServerlessFunctionLabel" DROP CONSTRAINT "FK_ServerlessFunctionLabel_labelId"`,
124
+ );
125
+ await queryRunner.query(
126
+ `ALTER TABLE "ServerlessFunctionLabel" DROP CONSTRAINT "FK_ServerlessFunctionLabel_fnId"`,
127
+ );
128
+ await queryRunner.query(
129
+ `ALTER TABLE "ServerlessFunctionOwnerUser" DROP CONSTRAINT "FK_SrvlessFnOwnerUser_deletedBy"`,
130
+ );
131
+ await queryRunner.query(
132
+ `ALTER TABLE "ServerlessFunctionOwnerUser" DROP CONSTRAINT "FK_SrvlessFnOwnerUser_createdBy"`,
133
+ );
134
+ await queryRunner.query(
135
+ `ALTER TABLE "ServerlessFunctionOwnerUser" DROP CONSTRAINT "FK_SrvlessFnOwnerUser_fnId"`,
136
+ );
137
+ await queryRunner.query(
138
+ `ALTER TABLE "ServerlessFunctionOwnerUser" DROP CONSTRAINT "FK_SrvlessFnOwnerUser_userId"`,
139
+ );
140
+ await queryRunner.query(
141
+ `ALTER TABLE "ServerlessFunctionOwnerUser" DROP CONSTRAINT "FK_SrvlessFnOwnerUser_projectId"`,
142
+ );
143
+ await queryRunner.query(
144
+ `ALTER TABLE "ServerlessFunctionOwnerTeam" DROP CONSTRAINT "FK_SrvlessFnOwnerTeam_deletedBy"`,
145
+ );
146
+ await queryRunner.query(
147
+ `ALTER TABLE "ServerlessFunctionOwnerTeam" DROP CONSTRAINT "FK_SrvlessFnOwnerTeam_createdBy"`,
148
+ );
149
+ await queryRunner.query(
150
+ `ALTER TABLE "ServerlessFunctionOwnerTeam" DROP CONSTRAINT "FK_SrvlessFnOwnerTeam_fnId"`,
151
+ );
152
+ await queryRunner.query(
153
+ `ALTER TABLE "ServerlessFunctionOwnerTeam" DROP CONSTRAINT "FK_SrvlessFnOwnerTeam_teamId"`,
154
+ );
155
+ await queryRunner.query(
156
+ `ALTER TABLE "ServerlessFunctionOwnerTeam" DROP CONSTRAINT "FK_SrvlessFnOwnerTeam_projectId"`,
157
+ );
158
+ await queryRunner.query(
159
+ `ALTER TABLE "ServerlessFunction" DROP CONSTRAINT "FK_ServerlessFunction_deletedBy"`,
160
+ );
161
+ await queryRunner.query(
162
+ `ALTER TABLE "ServerlessFunction" DROP CONSTRAINT "FK_ServerlessFunction_createdBy"`,
163
+ );
164
+ await queryRunner.query(
165
+ `ALTER TABLE "ServerlessFunction" DROP CONSTRAINT "FK_ServerlessFunction_projectId"`,
166
+ );
167
+
168
+ await queryRunner.query(
169
+ `DROP INDEX "public"."IDX_ServerlessFunctionLabel_labelId"`,
170
+ );
171
+ await queryRunner.query(
172
+ `DROP INDEX "public"."IDX_ServerlessFunctionLabel_fnId"`,
173
+ );
174
+ await queryRunner.query(`DROP TABLE "ServerlessFunctionLabel"`);
175
+ await queryRunner.query(
176
+ `DROP INDEX "public"."IDX_SrvlessFnOwnerUser_notified"`,
177
+ );
178
+ await queryRunner.query(`DROP INDEX "public"."IDX_SrvlessFnOwnerUser_fnId"`);
179
+ await queryRunner.query(
180
+ `DROP INDEX "public"."IDX_SrvlessFnOwnerUser_userId"`,
181
+ );
182
+ await queryRunner.query(
183
+ `DROP INDEX "public"."IDX_SrvlessFnOwnerUser_projectId"`,
184
+ );
185
+ await queryRunner.query(`DROP TABLE "ServerlessFunctionOwnerUser"`);
186
+ await queryRunner.query(
187
+ `DROP INDEX "public"."IDX_SrvlessFnOwnerTeam_notified"`,
188
+ );
189
+ await queryRunner.query(`DROP INDEX "public"."IDX_SrvlessFnOwnerTeam_fnId"`);
190
+ await queryRunner.query(
191
+ `DROP INDEX "public"."IDX_SrvlessFnOwnerTeam_teamId"`,
192
+ );
193
+ await queryRunner.query(
194
+ `DROP INDEX "public"."IDX_SrvlessFnOwnerTeam_projectId"`,
195
+ );
196
+ await queryRunner.query(`DROP TABLE "ServerlessFunctionOwnerTeam"`);
197
+ await queryRunner.query(
198
+ `DROP INDEX "public"."UQ_ServerlessFunction_project_fnId"`,
199
+ );
200
+ await queryRunner.query(
201
+ `DROP INDEX "public"."IDX_ServerlessFunction_projectId"`,
202
+ );
203
+ await queryRunner.query(`DROP TABLE "ServerlessFunction"`);
204
+ }
205
+ }
@@ -0,0 +1,195 @@
1
+ import { MigrationInterface, QueryRunner } from "typeorm";
2
+
3
+ /*
4
+ * Phase 2: Cloud platform compute resource type. Creates the CloudResource
5
+ * resource table, its owner-user / owner-team tables, and the label join
6
+ * table — mirroring the ServerlessFunction shape so the polymorphic telemetry
7
+ * serviceId can point at a CloudResource row.
8
+ */
9
+ export class AddCloudResourceTables1780935387827 implements MigrationInterface {
10
+ public name = "AddCloudResourceTables1780935387827";
11
+
12
+ public async up(queryRunner: QueryRunner): Promise<void> {
13
+ await queryRunner.query(
14
+ `CREATE TABLE "CloudResource" ("_id" uuid NOT NULL DEFAULT uuid_generate_v4(), "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "updatedAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "deletedAt" TIMESTAMP WITH TIME ZONE, "version" integer NOT NULL, "projectId" uuid NOT NULL, "name" character varying(100) NOT NULL, "slug" character varying(100) NOT NULL, "description" character varying(500), "resourceIdentifier" character varying(100) NOT NULL, "cloudPlatform" character varying(100), "cloudProvider" character varying(100), "cloudRegion" character varying(100), "cloudAccountId" character varying(100), "runtimeName" character varying(100), "runtimeVersion" character varying(100), "otelCollectorStatus" character varying(100) DEFAULT 'disconnected', "agentVersion" character varying(100), "lastSeenAt" TIMESTAMP WITH TIME ZONE, "retainTelemetryDataForDays" integer, "telemetryRetentionConfig" jsonb, "createdByUserId" uuid, "deletedByUserId" uuid, CONSTRAINT "PK_CloudResource" PRIMARY KEY ("_id"))`,
15
+ );
16
+ await queryRunner.query(
17
+ `CREATE INDEX "IDX_CloudResource_projectId" ON "CloudResource" ("projectId") `,
18
+ );
19
+ await queryRunner.query(
20
+ `CREATE UNIQUE INDEX "UQ_CloudResource_project_resId" ON "CloudResource" ("projectId", "resourceIdentifier") `,
21
+ );
22
+
23
+ await queryRunner.query(
24
+ `CREATE TABLE "CloudResourceOwnerTeam" ("_id" uuid NOT NULL DEFAULT uuid_generate_v4(), "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "updatedAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "deletedAt" TIMESTAMP WITH TIME ZONE, "version" integer NOT NULL, "projectId" uuid NOT NULL, "teamId" uuid NOT NULL, "cloudResourceId" uuid NOT NULL, "createdByUserId" uuid, "deletedByUserId" uuid, "isOwnerNotified" boolean NOT NULL DEFAULT false, CONSTRAINT "PK_CloudResourceOwnerTeam" PRIMARY KEY ("_id"))`,
25
+ );
26
+ await queryRunner.query(
27
+ `CREATE INDEX "IDX_CloudResOwnerTeam_projectId" ON "CloudResourceOwnerTeam" ("projectId") `,
28
+ );
29
+ await queryRunner.query(
30
+ `CREATE INDEX "IDX_CloudResOwnerTeam_teamId" ON "CloudResourceOwnerTeam" ("teamId") `,
31
+ );
32
+ await queryRunner.query(
33
+ `CREATE INDEX "IDX_CloudResOwnerTeam_resId" ON "CloudResourceOwnerTeam" ("cloudResourceId") `,
34
+ );
35
+ await queryRunner.query(
36
+ `CREATE INDEX "IDX_CloudResOwnerTeam_notified" ON "CloudResourceOwnerTeam" ("isOwnerNotified") `,
37
+ );
38
+
39
+ await queryRunner.query(
40
+ `CREATE TABLE "CloudResourceOwnerUser" ("_id" uuid NOT NULL DEFAULT uuid_generate_v4(), "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "updatedAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "deletedAt" TIMESTAMP WITH TIME ZONE, "version" integer NOT NULL, "projectId" uuid NOT NULL, "userId" uuid NOT NULL, "cloudResourceId" uuid NOT NULL, "createdByUserId" uuid, "deletedByUserId" uuid, "isOwnerNotified" boolean NOT NULL DEFAULT false, CONSTRAINT "PK_CloudResourceOwnerUser" PRIMARY KEY ("_id"))`,
41
+ );
42
+ await queryRunner.query(
43
+ `CREATE INDEX "IDX_CloudResOwnerUser_projectId" ON "CloudResourceOwnerUser" ("projectId") `,
44
+ );
45
+ await queryRunner.query(
46
+ `CREATE INDEX "IDX_CloudResOwnerUser_userId" ON "CloudResourceOwnerUser" ("userId") `,
47
+ );
48
+ await queryRunner.query(
49
+ `CREATE INDEX "IDX_CloudResOwnerUser_resId" ON "CloudResourceOwnerUser" ("cloudResourceId") `,
50
+ );
51
+ await queryRunner.query(
52
+ `CREATE INDEX "IDX_CloudResOwnerUser_notified" ON "CloudResourceOwnerUser" ("isOwnerNotified") `,
53
+ );
54
+
55
+ await queryRunner.query(
56
+ `CREATE TABLE "CloudResourceLabel" ("cloudResourceId" uuid NOT NULL, "labelId" uuid NOT NULL, CONSTRAINT "PK_CloudResourceLabel" PRIMARY KEY ("cloudResourceId", "labelId"))`,
57
+ );
58
+ await queryRunner.query(
59
+ `CREATE INDEX "IDX_CloudResourceLabel_resId" ON "CloudResourceLabel" ("cloudResourceId") `,
60
+ );
61
+ await queryRunner.query(
62
+ `CREATE INDEX "IDX_CloudResourceLabel_labelId" ON "CloudResourceLabel" ("labelId") `,
63
+ );
64
+
65
+ // Foreign keys: CloudResource
66
+ await queryRunner.query(
67
+ `ALTER TABLE "CloudResource" ADD CONSTRAINT "FK_CloudResource_projectId" FOREIGN KEY ("projectId") REFERENCES "Project"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
68
+ );
69
+ await queryRunner.query(
70
+ `ALTER TABLE "CloudResource" ADD CONSTRAINT "FK_CloudResource_createdBy" FOREIGN KEY ("createdByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
71
+ );
72
+ await queryRunner.query(
73
+ `ALTER TABLE "CloudResource" ADD CONSTRAINT "FK_CloudResource_deletedBy" FOREIGN KEY ("deletedByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
74
+ );
75
+
76
+ // Foreign keys: CloudResourceOwnerTeam
77
+ await queryRunner.query(
78
+ `ALTER TABLE "CloudResourceOwnerTeam" ADD CONSTRAINT "FK_CloudResOwnerTeam_projectId" FOREIGN KEY ("projectId") REFERENCES "Project"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
79
+ );
80
+ await queryRunner.query(
81
+ `ALTER TABLE "CloudResourceOwnerTeam" ADD CONSTRAINT "FK_CloudResOwnerTeam_teamId" FOREIGN KEY ("teamId") REFERENCES "Team"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
82
+ );
83
+ await queryRunner.query(
84
+ `ALTER TABLE "CloudResourceOwnerTeam" ADD CONSTRAINT "FK_CloudResOwnerTeam_resId" FOREIGN KEY ("cloudResourceId") REFERENCES "CloudResource"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
85
+ );
86
+ await queryRunner.query(
87
+ `ALTER TABLE "CloudResourceOwnerTeam" ADD CONSTRAINT "FK_CloudResOwnerTeam_createdBy" FOREIGN KEY ("createdByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
88
+ );
89
+ await queryRunner.query(
90
+ `ALTER TABLE "CloudResourceOwnerTeam" ADD CONSTRAINT "FK_CloudResOwnerTeam_deletedBy" FOREIGN KEY ("deletedByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
91
+ );
92
+
93
+ // Foreign keys: CloudResourceOwnerUser
94
+ await queryRunner.query(
95
+ `ALTER TABLE "CloudResourceOwnerUser" ADD CONSTRAINT "FK_CloudResOwnerUser_projectId" FOREIGN KEY ("projectId") REFERENCES "Project"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
96
+ );
97
+ await queryRunner.query(
98
+ `ALTER TABLE "CloudResourceOwnerUser" ADD CONSTRAINT "FK_CloudResOwnerUser_userId" FOREIGN KEY ("userId") REFERENCES "User"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
99
+ );
100
+ await queryRunner.query(
101
+ `ALTER TABLE "CloudResourceOwnerUser" ADD CONSTRAINT "FK_CloudResOwnerUser_resId" FOREIGN KEY ("cloudResourceId") REFERENCES "CloudResource"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
102
+ );
103
+ await queryRunner.query(
104
+ `ALTER TABLE "CloudResourceOwnerUser" ADD CONSTRAINT "FK_CloudResOwnerUser_createdBy" FOREIGN KEY ("createdByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
105
+ );
106
+ await queryRunner.query(
107
+ `ALTER TABLE "CloudResourceOwnerUser" ADD CONSTRAINT "FK_CloudResOwnerUser_deletedBy" FOREIGN KEY ("deletedByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
108
+ );
109
+
110
+ // Foreign keys: CloudResourceLabel join table
111
+ await queryRunner.query(
112
+ `ALTER TABLE "CloudResourceLabel" ADD CONSTRAINT "FK_CloudResourceLabel_resId" FOREIGN KEY ("cloudResourceId") REFERENCES "CloudResource"("_id") ON DELETE CASCADE ON UPDATE CASCADE`,
113
+ );
114
+ await queryRunner.query(
115
+ `ALTER TABLE "CloudResourceLabel" ADD CONSTRAINT "FK_CloudResourceLabel_labelId" FOREIGN KEY ("labelId") REFERENCES "Label"("_id") ON DELETE CASCADE ON UPDATE CASCADE`,
116
+ );
117
+ }
118
+
119
+ public async down(queryRunner: QueryRunner): Promise<void> {
120
+ await queryRunner.query(
121
+ `ALTER TABLE "CloudResourceLabel" DROP CONSTRAINT "FK_CloudResourceLabel_labelId"`,
122
+ );
123
+ await queryRunner.query(
124
+ `ALTER TABLE "CloudResourceLabel" DROP CONSTRAINT "FK_CloudResourceLabel_resId"`,
125
+ );
126
+ await queryRunner.query(
127
+ `ALTER TABLE "CloudResourceOwnerUser" DROP CONSTRAINT "FK_CloudResOwnerUser_deletedBy"`,
128
+ );
129
+ await queryRunner.query(
130
+ `ALTER TABLE "CloudResourceOwnerUser" DROP CONSTRAINT "FK_CloudResOwnerUser_createdBy"`,
131
+ );
132
+ await queryRunner.query(
133
+ `ALTER TABLE "CloudResourceOwnerUser" DROP CONSTRAINT "FK_CloudResOwnerUser_resId"`,
134
+ );
135
+ await queryRunner.query(
136
+ `ALTER TABLE "CloudResourceOwnerUser" DROP CONSTRAINT "FK_CloudResOwnerUser_userId"`,
137
+ );
138
+ await queryRunner.query(
139
+ `ALTER TABLE "CloudResourceOwnerUser" DROP CONSTRAINT "FK_CloudResOwnerUser_projectId"`,
140
+ );
141
+ await queryRunner.query(
142
+ `ALTER TABLE "CloudResourceOwnerTeam" DROP CONSTRAINT "FK_CloudResOwnerTeam_deletedBy"`,
143
+ );
144
+ await queryRunner.query(
145
+ `ALTER TABLE "CloudResourceOwnerTeam" DROP CONSTRAINT "FK_CloudResOwnerTeam_createdBy"`,
146
+ );
147
+ await queryRunner.query(
148
+ `ALTER TABLE "CloudResourceOwnerTeam" DROP CONSTRAINT "FK_CloudResOwnerTeam_resId"`,
149
+ );
150
+ await queryRunner.query(
151
+ `ALTER TABLE "CloudResourceOwnerTeam" DROP CONSTRAINT "FK_CloudResOwnerTeam_teamId"`,
152
+ );
153
+ await queryRunner.query(
154
+ `ALTER TABLE "CloudResourceOwnerTeam" DROP CONSTRAINT "FK_CloudResOwnerTeam_projectId"`,
155
+ );
156
+ await queryRunner.query(
157
+ `ALTER TABLE "CloudResource" DROP CONSTRAINT "FK_CloudResource_deletedBy"`,
158
+ );
159
+ await queryRunner.query(
160
+ `ALTER TABLE "CloudResource" DROP CONSTRAINT "FK_CloudResource_createdBy"`,
161
+ );
162
+ await queryRunner.query(
163
+ `ALTER TABLE "CloudResource" DROP CONSTRAINT "FK_CloudResource_projectId"`,
164
+ );
165
+
166
+ await queryRunner.query(
167
+ `DROP INDEX "public"."IDX_CloudResourceLabel_labelId"`,
168
+ );
169
+ await queryRunner.query(`DROP INDEX "public"."IDX_CloudResourceLabel_resId"`);
170
+ await queryRunner.query(`DROP TABLE "CloudResourceLabel"`);
171
+ await queryRunner.query(
172
+ `DROP INDEX "public"."IDX_CloudResOwnerUser_notified"`,
173
+ );
174
+ await queryRunner.query(`DROP INDEX "public"."IDX_CloudResOwnerUser_resId"`);
175
+ await queryRunner.query(`DROP INDEX "public"."IDX_CloudResOwnerUser_userId"`);
176
+ await queryRunner.query(
177
+ `DROP INDEX "public"."IDX_CloudResOwnerUser_projectId"`,
178
+ );
179
+ await queryRunner.query(`DROP TABLE "CloudResourceOwnerUser"`);
180
+ await queryRunner.query(
181
+ `DROP INDEX "public"."IDX_CloudResOwnerTeam_notified"`,
182
+ );
183
+ await queryRunner.query(`DROP INDEX "public"."IDX_CloudResOwnerTeam_resId"`);
184
+ await queryRunner.query(`DROP INDEX "public"."IDX_CloudResOwnerTeam_teamId"`);
185
+ await queryRunner.query(
186
+ `DROP INDEX "public"."IDX_CloudResOwnerTeam_projectId"`,
187
+ );
188
+ await queryRunner.query(`DROP TABLE "CloudResourceOwnerTeam"`);
189
+ await queryRunner.query(
190
+ `DROP INDEX "public"."UQ_CloudResource_project_resId"`,
191
+ );
192
+ await queryRunner.query(`DROP INDEX "public"."IDX_CloudResource_projectId"`);
193
+ await queryRunner.query(`DROP TABLE "CloudResource"`);
194
+ }
195
+ }
@@ -0,0 +1,202 @@
1
+ import { MigrationInterface, QueryRunner } from "typeorm";
2
+
3
+ /*
4
+ * Phase 3: Browser / Mobile RUM resource type. Creates the RumApplication
5
+ * resource table, its owner-user / owner-team tables, and the label join
6
+ * table — mirroring the other telemetry-resource shapes so the polymorphic
7
+ * telemetry serviceId can point at a RumApplication row. RUM is keyed per
8
+ * application (service.name), never per end-user device.
9
+ */
10
+ export class AddRumApplicationTables1780936579718
11
+ implements MigrationInterface
12
+ {
13
+ public name = "AddRumApplicationTables1780936579718";
14
+
15
+ public async up(queryRunner: QueryRunner): Promise<void> {
16
+ await queryRunner.query(
17
+ `CREATE TABLE "RumApplication" ("_id" uuid NOT NULL DEFAULT uuid_generate_v4(), "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "updatedAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "deletedAt" TIMESTAMP WITH TIME ZONE, "version" integer NOT NULL, "projectId" uuid NOT NULL, "name" character varying(100) NOT NULL, "slug" character varying(100) NOT NULL, "description" character varying(500), "appIdentifier" character varying(100) NOT NULL, "clientType" character varying(100), "otelCollectorStatus" character varying(100) DEFAULT 'disconnected', "agentVersion" character varying(100), "lastSeenAt" TIMESTAMP WITH TIME ZONE, "retainTelemetryDataForDays" integer, "telemetryRetentionConfig" jsonb, "createdByUserId" uuid, "deletedByUserId" uuid, CONSTRAINT "PK_RumApplication" PRIMARY KEY ("_id"))`,
18
+ );
19
+ await queryRunner.query(
20
+ `CREATE INDEX "IDX_RumApplication_projectId" ON "RumApplication" ("projectId") `,
21
+ );
22
+ await queryRunner.query(
23
+ `CREATE UNIQUE INDEX "UQ_RumApplication_project_appId" ON "RumApplication" ("projectId", "appIdentifier") `,
24
+ );
25
+
26
+ await queryRunner.query(
27
+ `CREATE TABLE "RumApplicationOwnerTeam" ("_id" uuid NOT NULL DEFAULT uuid_generate_v4(), "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "updatedAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "deletedAt" TIMESTAMP WITH TIME ZONE, "version" integer NOT NULL, "projectId" uuid NOT NULL, "teamId" uuid NOT NULL, "rumApplicationId" uuid NOT NULL, "createdByUserId" uuid, "deletedByUserId" uuid, "isOwnerNotified" boolean NOT NULL DEFAULT false, CONSTRAINT "PK_RumApplicationOwnerTeam" PRIMARY KEY ("_id"))`,
28
+ );
29
+ await queryRunner.query(
30
+ `CREATE INDEX "IDX_RumAppOwnerTeam_projectId" ON "RumApplicationOwnerTeam" ("projectId") `,
31
+ );
32
+ await queryRunner.query(
33
+ `CREATE INDEX "IDX_RumAppOwnerTeam_teamId" ON "RumApplicationOwnerTeam" ("teamId") `,
34
+ );
35
+ await queryRunner.query(
36
+ `CREATE INDEX "IDX_RumAppOwnerTeam_appId" ON "RumApplicationOwnerTeam" ("rumApplicationId") `,
37
+ );
38
+ await queryRunner.query(
39
+ `CREATE INDEX "IDX_RumAppOwnerTeam_notified" ON "RumApplicationOwnerTeam" ("isOwnerNotified") `,
40
+ );
41
+
42
+ await queryRunner.query(
43
+ `CREATE TABLE "RumApplicationOwnerUser" ("_id" uuid NOT NULL DEFAULT uuid_generate_v4(), "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "updatedAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "deletedAt" TIMESTAMP WITH TIME ZONE, "version" integer NOT NULL, "projectId" uuid NOT NULL, "userId" uuid NOT NULL, "rumApplicationId" uuid NOT NULL, "createdByUserId" uuid, "deletedByUserId" uuid, "isOwnerNotified" boolean NOT NULL DEFAULT false, CONSTRAINT "PK_RumApplicationOwnerUser" PRIMARY KEY ("_id"))`,
44
+ );
45
+ await queryRunner.query(
46
+ `CREATE INDEX "IDX_RumAppOwnerUser_projectId" ON "RumApplicationOwnerUser" ("projectId") `,
47
+ );
48
+ await queryRunner.query(
49
+ `CREATE INDEX "IDX_RumAppOwnerUser_userId" ON "RumApplicationOwnerUser" ("userId") `,
50
+ );
51
+ await queryRunner.query(
52
+ `CREATE INDEX "IDX_RumAppOwnerUser_appId" ON "RumApplicationOwnerUser" ("rumApplicationId") `,
53
+ );
54
+ await queryRunner.query(
55
+ `CREATE INDEX "IDX_RumAppOwnerUser_notified" ON "RumApplicationOwnerUser" ("isOwnerNotified") `,
56
+ );
57
+
58
+ await queryRunner.query(
59
+ `CREATE TABLE "RumApplicationLabel" ("rumApplicationId" uuid NOT NULL, "labelId" uuid NOT NULL, CONSTRAINT "PK_RumApplicationLabel" PRIMARY KEY ("rumApplicationId", "labelId"))`,
60
+ );
61
+ await queryRunner.query(
62
+ `CREATE INDEX "IDX_RumApplicationLabel_appId" ON "RumApplicationLabel" ("rumApplicationId") `,
63
+ );
64
+ await queryRunner.query(
65
+ `CREATE INDEX "IDX_RumApplicationLabel_labelId" ON "RumApplicationLabel" ("labelId") `,
66
+ );
67
+
68
+ // Foreign keys: RumApplication
69
+ await queryRunner.query(
70
+ `ALTER TABLE "RumApplication" ADD CONSTRAINT "FK_RumApplication_projectId" FOREIGN KEY ("projectId") REFERENCES "Project"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
71
+ );
72
+ await queryRunner.query(
73
+ `ALTER TABLE "RumApplication" ADD CONSTRAINT "FK_RumApplication_createdBy" FOREIGN KEY ("createdByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
74
+ );
75
+ await queryRunner.query(
76
+ `ALTER TABLE "RumApplication" ADD CONSTRAINT "FK_RumApplication_deletedBy" FOREIGN KEY ("deletedByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
77
+ );
78
+
79
+ // Foreign keys: RumApplicationOwnerTeam
80
+ await queryRunner.query(
81
+ `ALTER TABLE "RumApplicationOwnerTeam" ADD CONSTRAINT "FK_RumAppOwnerTeam_projectId" FOREIGN KEY ("projectId") REFERENCES "Project"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
82
+ );
83
+ await queryRunner.query(
84
+ `ALTER TABLE "RumApplicationOwnerTeam" ADD CONSTRAINT "FK_RumAppOwnerTeam_teamId" FOREIGN KEY ("teamId") REFERENCES "Team"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
85
+ );
86
+ await queryRunner.query(
87
+ `ALTER TABLE "RumApplicationOwnerTeam" ADD CONSTRAINT "FK_RumAppOwnerTeam_appId" FOREIGN KEY ("rumApplicationId") REFERENCES "RumApplication"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
88
+ );
89
+ await queryRunner.query(
90
+ `ALTER TABLE "RumApplicationOwnerTeam" ADD CONSTRAINT "FK_RumAppOwnerTeam_createdBy" FOREIGN KEY ("createdByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
91
+ );
92
+ await queryRunner.query(
93
+ `ALTER TABLE "RumApplicationOwnerTeam" ADD CONSTRAINT "FK_RumAppOwnerTeam_deletedBy" FOREIGN KEY ("deletedByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
94
+ );
95
+
96
+ // Foreign keys: RumApplicationOwnerUser
97
+ await queryRunner.query(
98
+ `ALTER TABLE "RumApplicationOwnerUser" ADD CONSTRAINT "FK_RumAppOwnerUser_projectId" FOREIGN KEY ("projectId") REFERENCES "Project"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
99
+ );
100
+ await queryRunner.query(
101
+ `ALTER TABLE "RumApplicationOwnerUser" ADD CONSTRAINT "FK_RumAppOwnerUser_userId" FOREIGN KEY ("userId") REFERENCES "User"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
102
+ );
103
+ await queryRunner.query(
104
+ `ALTER TABLE "RumApplicationOwnerUser" ADD CONSTRAINT "FK_RumAppOwnerUser_appId" FOREIGN KEY ("rumApplicationId") REFERENCES "RumApplication"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
105
+ );
106
+ await queryRunner.query(
107
+ `ALTER TABLE "RumApplicationOwnerUser" ADD CONSTRAINT "FK_RumAppOwnerUser_createdBy" FOREIGN KEY ("createdByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
108
+ );
109
+ await queryRunner.query(
110
+ `ALTER TABLE "RumApplicationOwnerUser" ADD CONSTRAINT "FK_RumAppOwnerUser_deletedBy" FOREIGN KEY ("deletedByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
111
+ );
112
+
113
+ // Foreign keys: RumApplicationLabel join table
114
+ await queryRunner.query(
115
+ `ALTER TABLE "RumApplicationLabel" ADD CONSTRAINT "FK_RumApplicationLabel_appId" FOREIGN KEY ("rumApplicationId") REFERENCES "RumApplication"("_id") ON DELETE CASCADE ON UPDATE CASCADE`,
116
+ );
117
+ await queryRunner.query(
118
+ `ALTER TABLE "RumApplicationLabel" ADD CONSTRAINT "FK_RumApplicationLabel_labelId" FOREIGN KEY ("labelId") REFERENCES "Label"("_id") ON DELETE CASCADE ON UPDATE CASCADE`,
119
+ );
120
+ }
121
+
122
+ public async down(queryRunner: QueryRunner): Promise<void> {
123
+ await queryRunner.query(
124
+ `ALTER TABLE "RumApplicationLabel" DROP CONSTRAINT "FK_RumApplicationLabel_labelId"`,
125
+ );
126
+ await queryRunner.query(
127
+ `ALTER TABLE "RumApplicationLabel" DROP CONSTRAINT "FK_RumApplicationLabel_appId"`,
128
+ );
129
+ await queryRunner.query(
130
+ `ALTER TABLE "RumApplicationOwnerUser" DROP CONSTRAINT "FK_RumAppOwnerUser_deletedBy"`,
131
+ );
132
+ await queryRunner.query(
133
+ `ALTER TABLE "RumApplicationOwnerUser" DROP CONSTRAINT "FK_RumAppOwnerUser_createdBy"`,
134
+ );
135
+ await queryRunner.query(
136
+ `ALTER TABLE "RumApplicationOwnerUser" DROP CONSTRAINT "FK_RumAppOwnerUser_appId"`,
137
+ );
138
+ await queryRunner.query(
139
+ `ALTER TABLE "RumApplicationOwnerUser" DROP CONSTRAINT "FK_RumAppOwnerUser_userId"`,
140
+ );
141
+ await queryRunner.query(
142
+ `ALTER TABLE "RumApplicationOwnerUser" DROP CONSTRAINT "FK_RumAppOwnerUser_projectId"`,
143
+ );
144
+ await queryRunner.query(
145
+ `ALTER TABLE "RumApplicationOwnerTeam" DROP CONSTRAINT "FK_RumAppOwnerTeam_deletedBy"`,
146
+ );
147
+ await queryRunner.query(
148
+ `ALTER TABLE "RumApplicationOwnerTeam" DROP CONSTRAINT "FK_RumAppOwnerTeam_createdBy"`,
149
+ );
150
+ await queryRunner.query(
151
+ `ALTER TABLE "RumApplicationOwnerTeam" DROP CONSTRAINT "FK_RumAppOwnerTeam_appId"`,
152
+ );
153
+ await queryRunner.query(
154
+ `ALTER TABLE "RumApplicationOwnerTeam" DROP CONSTRAINT "FK_RumAppOwnerTeam_teamId"`,
155
+ );
156
+ await queryRunner.query(
157
+ `ALTER TABLE "RumApplicationOwnerTeam" DROP CONSTRAINT "FK_RumAppOwnerTeam_projectId"`,
158
+ );
159
+ await queryRunner.query(
160
+ `ALTER TABLE "RumApplication" DROP CONSTRAINT "FK_RumApplication_deletedBy"`,
161
+ );
162
+ await queryRunner.query(
163
+ `ALTER TABLE "RumApplication" DROP CONSTRAINT "FK_RumApplication_createdBy"`,
164
+ );
165
+ await queryRunner.query(
166
+ `ALTER TABLE "RumApplication" DROP CONSTRAINT "FK_RumApplication_projectId"`,
167
+ );
168
+
169
+ await queryRunner.query(
170
+ `DROP INDEX "public"."IDX_RumApplicationLabel_labelId"`,
171
+ );
172
+ await queryRunner.query(
173
+ `DROP INDEX "public"."IDX_RumApplicationLabel_appId"`,
174
+ );
175
+ await queryRunner.query(`DROP TABLE "RumApplicationLabel"`);
176
+ await queryRunner.query(
177
+ `DROP INDEX "public"."IDX_RumAppOwnerUser_notified"`,
178
+ );
179
+ await queryRunner.query(`DROP INDEX "public"."IDX_RumAppOwnerUser_appId"`);
180
+ await queryRunner.query(`DROP INDEX "public"."IDX_RumAppOwnerUser_userId"`);
181
+ await queryRunner.query(
182
+ `DROP INDEX "public"."IDX_RumAppOwnerUser_projectId"`,
183
+ );
184
+ await queryRunner.query(`DROP TABLE "RumApplicationOwnerUser"`);
185
+ await queryRunner.query(
186
+ `DROP INDEX "public"."IDX_RumAppOwnerTeam_notified"`,
187
+ );
188
+ await queryRunner.query(`DROP INDEX "public"."IDX_RumAppOwnerTeam_appId"`);
189
+ await queryRunner.query(`DROP INDEX "public"."IDX_RumAppOwnerTeam_teamId"`);
190
+ await queryRunner.query(
191
+ `DROP INDEX "public"."IDX_RumAppOwnerTeam_projectId"`,
192
+ );
193
+ await queryRunner.query(`DROP TABLE "RumApplicationOwnerTeam"`);
194
+ await queryRunner.query(
195
+ `DROP INDEX "public"."UQ_RumApplication_project_appId"`,
196
+ );
197
+ await queryRunner.query(
198
+ `DROP INDEX "public"."IDX_RumApplication_projectId"`,
199
+ );
200
+ await queryRunner.query(`DROP TABLE "RumApplication"`);
201
+ }
202
+ }