@friggframework/devtools 2.0.0-next.7 → 2.0.0-next.71

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 (240) hide show
  1. package/frigg-cli/README.md +1289 -0
  2. package/frigg-cli/__tests__/unit/commands/build.test.js +279 -0
  3. package/frigg-cli/__tests__/unit/commands/db-setup.test.js +649 -0
  4. package/frigg-cli/__tests__/unit/commands/deploy.test.js +320 -0
  5. package/frigg-cli/__tests__/unit/commands/doctor.test.js +309 -0
  6. package/frigg-cli/__tests__/unit/commands/install.test.js +400 -0
  7. package/frigg-cli/__tests__/unit/commands/ui.test.js +346 -0
  8. package/frigg-cli/__tests__/unit/dependencies.test.js +74 -0
  9. package/frigg-cli/__tests__/unit/utils/database-validator.test.js +397 -0
  10. package/frigg-cli/__tests__/unit/utils/error-messages.test.js +345 -0
  11. package/frigg-cli/__tests__/unit/version-detection.test.js +171 -0
  12. package/frigg-cli/__tests__/utils/mock-factory.js +270 -0
  13. package/frigg-cli/__tests__/utils/prisma-mock.js +194 -0
  14. package/frigg-cli/__tests__/utils/test-fixtures.js +463 -0
  15. package/frigg-cli/__tests__/utils/test-setup.js +287 -0
  16. package/frigg-cli/auth-command/CLAUDE.md +293 -0
  17. package/frigg-cli/auth-command/README.md +450 -0
  18. package/frigg-cli/auth-command/api-key-flow.js +153 -0
  19. package/frigg-cli/auth-command/auth-tester.js +344 -0
  20. package/frigg-cli/auth-command/credential-storage.js +182 -0
  21. package/frigg-cli/auth-command/index.js +256 -0
  22. package/frigg-cli/auth-command/json-schema-form.js +67 -0
  23. package/frigg-cli/auth-command/module-loader.js +172 -0
  24. package/frigg-cli/auth-command/oauth-callback-server.js +431 -0
  25. package/frigg-cli/auth-command/oauth-flow.js +195 -0
  26. package/frigg-cli/auth-command/utils/browser.js +30 -0
  27. package/frigg-cli/build-command/index.js +45 -12
  28. package/frigg-cli/db-setup-command/index.js +246 -0
  29. package/frigg-cli/deploy-command/SPEC-DEPLOY-DRY-RUN.md +981 -0
  30. package/frigg-cli/deploy-command/index.js +295 -23
  31. package/frigg-cli/doctor-command/index.js +335 -0
  32. package/frigg-cli/generate-command/__tests__/generate-command.test.js +301 -0
  33. package/frigg-cli/generate-command/azure-generator.js +43 -0
  34. package/frigg-cli/generate-command/gcp-generator.js +47 -0
  35. package/frigg-cli/generate-command/index.js +332 -0
  36. package/frigg-cli/generate-command/terraform-generator.js +555 -0
  37. package/frigg-cli/generate-iam-command.js +118 -0
  38. package/frigg-cli/index.js +174 -1
  39. package/frigg-cli/index.test.js +1 -4
  40. package/frigg-cli/init-command/backend-first-handler.js +756 -0
  41. package/frigg-cli/init-command/index.js +93 -0
  42. package/frigg-cli/init-command/template-handler.js +143 -0
  43. package/frigg-cli/install-command/index.js +1 -4
  44. package/frigg-cli/jest.config.js +124 -0
  45. package/frigg-cli/package.json +63 -0
  46. package/frigg-cli/repair-command/index.js +564 -0
  47. package/frigg-cli/start-command/index.js +118 -5
  48. package/frigg-cli/start-command/start-command.test.js +297 -0
  49. package/frigg-cli/test/init-command.test.js +180 -0
  50. package/frigg-cli/test/npm-registry.test.js +319 -0
  51. package/frigg-cli/ui-command/index.js +154 -0
  52. package/frigg-cli/utils/app-resolver.js +319 -0
  53. package/frigg-cli/utils/backend-path.js +16 -17
  54. package/frigg-cli/utils/database-validator.js +167 -0
  55. package/frigg-cli/utils/error-messages.js +329 -0
  56. package/frigg-cli/utils/npm-registry.js +167 -0
  57. package/frigg-cli/utils/process-manager.js +199 -0
  58. package/frigg-cli/utils/repo-detection.js +405 -0
  59. package/infrastructure/ARCHITECTURE.md +487 -0
  60. package/infrastructure/CLAUDE.md +481 -0
  61. package/infrastructure/HEALTH.md +468 -0
  62. package/infrastructure/README.md +522 -0
  63. package/infrastructure/__tests__/fixtures/mock-aws-resources.js +391 -0
  64. package/infrastructure/__tests__/helpers/test-utils.js +277 -0
  65. package/infrastructure/__tests__/postgres-config.test.js +914 -0
  66. package/infrastructure/__tests__/template-generation.test.js +687 -0
  67. package/infrastructure/create-frigg-infrastructure.js +129 -20
  68. package/infrastructure/docs/POSTGRES-CONFIGURATION.md +630 -0
  69. package/infrastructure/docs/PRE-DEPLOYMENT-HEALTH-CHECK-SPEC.md +1317 -0
  70. package/infrastructure/docs/WEBSOCKET-CONFIGURATION.md +105 -0
  71. package/infrastructure/docs/deployment-instructions.md +268 -0
  72. package/infrastructure/docs/generate-iam-command.md +278 -0
  73. package/infrastructure/docs/iam-policy-templates.md +193 -0
  74. package/infrastructure/domains/database/aurora-builder.js +809 -0
  75. package/infrastructure/domains/database/aurora-builder.test.js +950 -0
  76. package/infrastructure/domains/database/aurora-discovery.js +87 -0
  77. package/infrastructure/domains/database/aurora-discovery.test.js +188 -0
  78. package/infrastructure/domains/database/aurora-resolver.js +210 -0
  79. package/infrastructure/domains/database/aurora-resolver.test.js +347 -0
  80. package/infrastructure/domains/database/migration-builder.js +701 -0
  81. package/infrastructure/domains/database/migration-builder.test.js +321 -0
  82. package/infrastructure/domains/database/migration-resolver.js +163 -0
  83. package/infrastructure/domains/database/migration-resolver.test.js +337 -0
  84. package/infrastructure/domains/health/application/ports/IPropertyReconciler.js +164 -0
  85. package/infrastructure/domains/health/application/ports/IResourceDetector.js +129 -0
  86. package/infrastructure/domains/health/application/ports/IResourceImporter.js +142 -0
  87. package/infrastructure/domains/health/application/ports/IStackRepository.js +131 -0
  88. package/infrastructure/domains/health/application/ports/index.js +26 -0
  89. package/infrastructure/domains/health/application/use-cases/__tests__/execute-resource-import-use-case.test.js +679 -0
  90. package/infrastructure/domains/health/application/use-cases/__tests__/mismatch-analyzer-method-name.test.js +167 -0
  91. package/infrastructure/domains/health/application/use-cases/__tests__/repair-via-import-use-case.test.js +1130 -0
  92. package/infrastructure/domains/health/application/use-cases/execute-resource-import-use-case.js +221 -0
  93. package/infrastructure/domains/health/application/use-cases/reconcile-properties-use-case.js +152 -0
  94. package/infrastructure/domains/health/application/use-cases/reconcile-properties-use-case.test.js +343 -0
  95. package/infrastructure/domains/health/application/use-cases/repair-via-import-use-case.js +535 -0
  96. package/infrastructure/domains/health/application/use-cases/repair-via-import-use-case.test.js +376 -0
  97. package/infrastructure/domains/health/application/use-cases/run-health-check-use-case.js +213 -0
  98. package/infrastructure/domains/health/application/use-cases/run-health-check-use-case.test.js +441 -0
  99. package/infrastructure/domains/health/docs/ACME-DEV-DRIFT-ANALYSIS.md +267 -0
  100. package/infrastructure/domains/health/docs/BUILD-VS-DEPLOYED-TEMPLATE-ANALYSIS.md +324 -0
  101. package/infrastructure/domains/health/docs/ORPHAN-DETECTION-ANALYSIS.md +386 -0
  102. package/infrastructure/domains/health/docs/SPEC-CLEANUP-COMMAND.md +1419 -0
  103. package/infrastructure/domains/health/docs/TDD-IMPLEMENTATION-SUMMARY.md +391 -0
  104. package/infrastructure/domains/health/docs/TEMPLATE-COMPARISON-IMPLEMENTATION.md +551 -0
  105. package/infrastructure/domains/health/domain/entities/issue.js +299 -0
  106. package/infrastructure/domains/health/domain/entities/issue.test.js +528 -0
  107. package/infrastructure/domains/health/domain/entities/property-mismatch.js +108 -0
  108. package/infrastructure/domains/health/domain/entities/property-mismatch.test.js +275 -0
  109. package/infrastructure/domains/health/domain/entities/resource.js +159 -0
  110. package/infrastructure/domains/health/domain/entities/resource.test.js +432 -0
  111. package/infrastructure/domains/health/domain/entities/stack-health-report.js +306 -0
  112. package/infrastructure/domains/health/domain/entities/stack-health-report.test.js +601 -0
  113. package/infrastructure/domains/health/domain/services/__tests__/health-score-percentage-based.test.js +380 -0
  114. package/infrastructure/domains/health/domain/services/__tests__/import-progress-monitor.test.js +971 -0
  115. package/infrastructure/domains/health/domain/services/__tests__/import-template-generator.test.js +1150 -0
  116. package/infrastructure/domains/health/domain/services/__tests__/logical-id-mapper.test.js +672 -0
  117. package/infrastructure/domains/health/domain/services/__tests__/template-parser.test.js +496 -0
  118. package/infrastructure/domains/health/domain/services/__tests__/update-progress-monitor.test.js +419 -0
  119. package/infrastructure/domains/health/domain/services/health-score-calculator.js +248 -0
  120. package/infrastructure/domains/health/domain/services/health-score-calculator.test.js +504 -0
  121. package/infrastructure/domains/health/domain/services/import-progress-monitor.js +195 -0
  122. package/infrastructure/domains/health/domain/services/import-template-generator.js +435 -0
  123. package/infrastructure/domains/health/domain/services/logical-id-mapper.js +345 -0
  124. package/infrastructure/domains/health/domain/services/mismatch-analyzer.js +234 -0
  125. package/infrastructure/domains/health/domain/services/mismatch-analyzer.test.js +431 -0
  126. package/infrastructure/domains/health/domain/services/property-mutability-config.js +382 -0
  127. package/infrastructure/domains/health/domain/services/template-parser.js +245 -0
  128. package/infrastructure/domains/health/domain/services/update-progress-monitor.js +192 -0
  129. package/infrastructure/domains/health/domain/value-objects/health-score.js +138 -0
  130. package/infrastructure/domains/health/domain/value-objects/health-score.test.js +267 -0
  131. package/infrastructure/domains/health/domain/value-objects/property-mutability.js +161 -0
  132. package/infrastructure/domains/health/domain/value-objects/property-mutability.test.js +198 -0
  133. package/infrastructure/domains/health/domain/value-objects/resource-state.js +167 -0
  134. package/infrastructure/domains/health/domain/value-objects/resource-state.test.js +196 -0
  135. package/infrastructure/domains/health/domain/value-objects/stack-identifier.js +192 -0
  136. package/infrastructure/domains/health/domain/value-objects/stack-identifier.test.js +262 -0
  137. package/infrastructure/domains/health/infrastructure/adapters/__tests__/orphan-detection-cfn-tagged.test.js +312 -0
  138. package/infrastructure/domains/health/infrastructure/adapters/__tests__/orphan-detection-multi-stack.test.js +367 -0
  139. package/infrastructure/domains/health/infrastructure/adapters/__tests__/orphan-detection-relationship-analysis.test.js +432 -0
  140. package/infrastructure/domains/health/infrastructure/adapters/aws-property-reconciler.js +784 -0
  141. package/infrastructure/domains/health/infrastructure/adapters/aws-property-reconciler.test.js +1133 -0
  142. package/infrastructure/domains/health/infrastructure/adapters/aws-resource-detector.js +565 -0
  143. package/infrastructure/domains/health/infrastructure/adapters/aws-resource-detector.test.js +554 -0
  144. package/infrastructure/domains/health/infrastructure/adapters/aws-resource-importer.js +318 -0
  145. package/infrastructure/domains/health/infrastructure/adapters/aws-resource-importer.test.js +398 -0
  146. package/infrastructure/domains/health/infrastructure/adapters/aws-stack-repository.js +777 -0
  147. package/infrastructure/domains/health/infrastructure/adapters/aws-stack-repository.test.js +580 -0
  148. package/infrastructure/domains/integration/integration-builder.js +404 -0
  149. package/infrastructure/domains/integration/integration-builder.test.js +690 -0
  150. package/infrastructure/domains/integration/integration-resolver.js +170 -0
  151. package/infrastructure/domains/integration/integration-resolver.test.js +369 -0
  152. package/infrastructure/domains/integration/websocket-builder.js +69 -0
  153. package/infrastructure/domains/integration/websocket-builder.test.js +195 -0
  154. package/infrastructure/domains/networking/vpc-builder.js +2051 -0
  155. package/infrastructure/domains/networking/vpc-builder.test.js +1960 -0
  156. package/infrastructure/domains/networking/vpc-discovery.js +177 -0
  157. package/infrastructure/domains/networking/vpc-discovery.test.js +350 -0
  158. package/infrastructure/domains/networking/vpc-resolver.js +505 -0
  159. package/infrastructure/domains/networking/vpc-resolver.test.js +801 -0
  160. package/infrastructure/domains/parameters/ssm-builder.js +79 -0
  161. package/infrastructure/domains/parameters/ssm-builder.test.js +189 -0
  162. package/infrastructure/domains/parameters/ssm-discovery.js +84 -0
  163. package/infrastructure/domains/parameters/ssm-discovery.test.js +210 -0
  164. package/infrastructure/domains/scheduler/scheduler-builder.js +211 -0
  165. package/infrastructure/domains/security/iam-generator.js +816 -0
  166. package/infrastructure/domains/security/iam-generator.test.js +204 -0
  167. package/infrastructure/domains/security/kms-builder.js +415 -0
  168. package/infrastructure/domains/security/kms-builder.test.js +392 -0
  169. package/infrastructure/domains/security/kms-discovery.js +80 -0
  170. package/infrastructure/domains/security/kms-discovery.test.js +177 -0
  171. package/infrastructure/domains/security/kms-resolver.js +96 -0
  172. package/infrastructure/domains/security/kms-resolver.test.js +216 -0
  173. package/infrastructure/domains/security/templates/frigg-deployment-iam-stack.yaml +401 -0
  174. package/infrastructure/domains/security/templates/iam-policy-basic.json +218 -0
  175. package/infrastructure/domains/security/templates/iam-policy-full.json +288 -0
  176. package/infrastructure/domains/shared/base-builder.js +112 -0
  177. package/infrastructure/domains/shared/base-resolver.js +186 -0
  178. package/infrastructure/domains/shared/base-resolver.test.js +305 -0
  179. package/infrastructure/domains/shared/builder-orchestrator.js +212 -0
  180. package/infrastructure/domains/shared/builder-orchestrator.test.js +213 -0
  181. package/infrastructure/domains/shared/cloudformation-discovery-v2.js +334 -0
  182. package/infrastructure/domains/shared/cloudformation-discovery.js +672 -0
  183. package/infrastructure/domains/shared/cloudformation-discovery.test.js +985 -0
  184. package/infrastructure/domains/shared/environment-builder.js +119 -0
  185. package/infrastructure/domains/shared/environment-builder.test.js +247 -0
  186. package/infrastructure/domains/shared/providers/aws-provider-adapter.js +579 -0
  187. package/infrastructure/domains/shared/providers/aws-provider-adapter.test.js +416 -0
  188. package/infrastructure/domains/shared/providers/azure-provider-adapter.stub.js +93 -0
  189. package/infrastructure/domains/shared/providers/cloud-provider-adapter.js +136 -0
  190. package/infrastructure/domains/shared/providers/gcp-provider-adapter.stub.js +82 -0
  191. package/infrastructure/domains/shared/providers/provider-factory.js +108 -0
  192. package/infrastructure/domains/shared/providers/provider-factory.test.js +170 -0
  193. package/infrastructure/domains/shared/resource-discovery.enhanced.test.js +306 -0
  194. package/infrastructure/domains/shared/resource-discovery.js +233 -0
  195. package/infrastructure/domains/shared/resource-discovery.test.js +588 -0
  196. package/infrastructure/domains/shared/types/app-definition.js +205 -0
  197. package/infrastructure/domains/shared/types/discovery-result.js +106 -0
  198. package/infrastructure/domains/shared/types/discovery-result.test.js +258 -0
  199. package/infrastructure/domains/shared/types/index.js +46 -0
  200. package/infrastructure/domains/shared/types/resource-ownership.js +108 -0
  201. package/infrastructure/domains/shared/types/resource-ownership.test.js +101 -0
  202. package/infrastructure/domains/shared/utilities/base-definition-factory.js +408 -0
  203. package/infrastructure/domains/shared/utilities/base-definition-factory.js.bak +338 -0
  204. package/infrastructure/domains/shared/utilities/base-definition-factory.test.js +291 -0
  205. package/infrastructure/domains/shared/utilities/handler-path-resolver.js +134 -0
  206. package/infrastructure/domains/shared/utilities/handler-path-resolver.test.js +268 -0
  207. package/infrastructure/domains/shared/utilities/prisma-layer-manager.js +159 -0
  208. package/infrastructure/domains/shared/utilities/prisma-layer-manager.test.js +444 -0
  209. package/infrastructure/domains/shared/validation/env-validator.js +78 -0
  210. package/infrastructure/domains/shared/validation/env-validator.test.js +173 -0
  211. package/infrastructure/domains/shared/validation/plugin-validator.js +187 -0
  212. package/infrastructure/domains/shared/validation/plugin-validator.test.js +323 -0
  213. package/infrastructure/esbuild.config.js +53 -0
  214. package/infrastructure/infrastructure-composer.js +119 -0
  215. package/infrastructure/infrastructure-composer.test.js +1895 -0
  216. package/infrastructure/integration.test.js +383 -0
  217. package/infrastructure/scripts/build-prisma-layer.js +701 -0
  218. package/infrastructure/scripts/build-prisma-layer.test.js +170 -0
  219. package/infrastructure/scripts/build-time-discovery.js +238 -0
  220. package/infrastructure/scripts/build-time-discovery.test.js +379 -0
  221. package/infrastructure/scripts/run-discovery.js +110 -0
  222. package/infrastructure/scripts/verify-prisma-layer.js +72 -0
  223. package/management-ui/README.md +203 -0
  224. package/package.json +44 -14
  225. package/test/index.js +2 -4
  226. package/test/mock-api.js +1 -3
  227. package/test/mock-integration.js +4 -14
  228. package/.eslintrc.json +0 -3
  229. package/CHANGELOG.md +0 -132
  230. package/infrastructure/app-handler-helpers.js +0 -57
  231. package/infrastructure/backend-utils.js +0 -87
  232. package/infrastructure/routers/auth.js +0 -26
  233. package/infrastructure/routers/integration-defined-routers.js +0 -42
  234. package/infrastructure/routers/middleware/loadUser.js +0 -15
  235. package/infrastructure/routers/middleware/requireLoggedInUser.js +0 -12
  236. package/infrastructure/routers/user.js +0 -41
  237. package/infrastructure/routers/websocket.js +0 -55
  238. package/infrastructure/serverless-template.js +0 -291
  239. package/infrastructure/workers/integration-defined-workers.js +0 -24
  240. package/test/auther-definition-tester.js +0 -125
@@ -1,42 +0,0 @@
1
- const { createAppHandler } = require('./../app-handler-helpers');
2
- const {
3
- integrationFactory,
4
- loadRouterFromObject,
5
- } = require('./../backend-utils');
6
- const { Router } = require('express');
7
-
8
- const handlers = {};
9
- for (const IntegrationClass of integrationFactory.integrationClasses) {
10
- const router = Router();
11
- const basePath = `/api/${IntegrationClass.Definition.name}-integration`;
12
-
13
- console.log(`\n│ Configuring routes for ${IntegrationClass.Definition.name} Integration:`);
14
-
15
- for (const routeDef of IntegrationClass.Definition.routes) {
16
- if (typeof routeDef === 'function') {
17
- router.use(basePath, routeDef(IntegrationClass));
18
- console.log(`│ ANY ${basePath}/* (function handler)`);
19
- } else if (typeof routeDef === 'object') {
20
- router.use(
21
- basePath,
22
- loadRouterFromObject(IntegrationClass, routeDef)
23
- );
24
- const method = (routeDef.method || 'ANY').toUpperCase();
25
- const fullPath = `${basePath}${routeDef.path}`;
26
- console.log(`│ ${method} ${fullPath}`);
27
- } else if (routeDef instanceof express.Router) {
28
- router.use(basePath, routeDef);
29
- console.log(`│ ANY ${basePath}/* (express router)`);
30
- }
31
- }
32
- console.log('│');
33
-
34
- handlers[`${IntegrationClass.Definition.name}`] = {
35
- handler: createAppHandler(
36
- `HTTP Event: ${IntegrationClass.Definition.name}`,
37
- router
38
- ),
39
- };
40
- }
41
-
42
- module.exports = { handlers };
@@ -1,15 +0,0 @@
1
- const catchAsyncError = require('express-async-handler');
2
- const { User } = require('../../backend-utils');
3
-
4
- module.exports = catchAsyncError(async (req, res, next) => {
5
- const authorizationHeader = req.headers.authorization;
6
-
7
- if (authorizationHeader) {
8
- // Removes "Bearer " and trims
9
- const token = authorizationHeader.split(' ')[1].trim();
10
- // Load user for later middleware/routes to use
11
- req.user = await User.newUser({ token });
12
- }
13
-
14
- return next();
15
- });
@@ -1,12 +0,0 @@
1
- const Boom = require('@hapi/boom');
2
-
3
- // CheckLoggedIn Middleware
4
- const requireLoggedInUser = (req, res, next) => {
5
- if (!req.user || !req.user.isLoggedIn()) {
6
- throw Boom.unauthorized('Invalid Token');
7
- }
8
-
9
- next();
10
- };
11
-
12
- module.exports = { requireLoggedInUser };
@@ -1,41 +0,0 @@
1
- const express = require('express');
2
- const { createAppHandler } = require('../app-handler-helpers');
3
- const { checkRequiredParams } = require('@friggframework/core');
4
- const { User } = require('../backend-utils');
5
- const catchAsyncError = require('express-async-handler');
6
-
7
- const router = express();
8
-
9
- // define the login endpoint
10
- router.route('/user/login').post(
11
- catchAsyncError(async (req, res) => {
12
- const { username, password } = checkRequiredParams(req.body, [
13
- 'username',
14
- 'password',
15
- ]);
16
- const user = await User.loginUser({ username, password });
17
- const token = await user.createUserToken(120);
18
- res.status(201);
19
- res.json({ token });
20
- })
21
- );
22
-
23
- router.route('/user/create').post(
24
- catchAsyncError(async (req, res) => {
25
- const { username, password } = checkRequiredParams(req.body, [
26
- 'username',
27
- 'password',
28
- ]);
29
- const user = await User.createIndividualUser({
30
- username,
31
- password,
32
- });
33
- const token = await user.createUserToken(120);
34
- res.status(201);
35
- res.json({ token });
36
- })
37
- );
38
-
39
- const handler = createAppHandler('HTTP Event: User', router);
40
-
41
- module.exports = { handler, router };
@@ -1,55 +0,0 @@
1
- const { createHandler } = require('@friggframework/core');
2
- const { WebsocketConnection } = require('@friggframework/core');
3
-
4
- const handleWebSocketConnection = async (event, context) => {
5
- // Handle different WebSocket events
6
- switch (event.requestContext.eventType) {
7
- case 'CONNECT':
8
- // Handle new connection
9
- try {
10
- const connectionId = event.requestContext.connectionId;
11
- await WebsocketConnection.create({ connectionId });
12
- console.log(`Stored new connection: ${connectionId}`);
13
- return { statusCode: 200, body: 'Connected.' };
14
- } catch (error) {
15
- console.error('Error storing connection:', error);
16
- return { statusCode: 500, body: 'Error connecting.' };
17
- }
18
-
19
- case 'DISCONNECT':
20
- // Handle disconnection
21
- try {
22
- const connectionId = event.requestContext.connectionId;
23
- await WebsocketConnection.deleteOne({ connectionId });
24
- console.log(`Removed connection: ${connectionId}`);
25
- return { statusCode: 200, body: 'Disconnected.' };
26
- } catch (error) {
27
- console.error('Error removing connection:', error);
28
- return { statusCode: 500, body: 'Error disconnecting.' };
29
- }
30
-
31
- case 'MESSAGE':
32
- // Handle incoming message
33
- const message = JSON.parse(event.body);
34
- console.log('Received message:', message);
35
-
36
- // Process the message and send a response
37
- const responseMessage = { message: 'Message received' };
38
- return {
39
- statusCode: 200,
40
- body: JSON.stringify(responseMessage),
41
- };
42
-
43
- default:
44
- return { statusCode: 400, body: 'Unhandled event type.' };
45
- }
46
- };
47
-
48
- const handler = createHandler({
49
- eventName: 'WebSocket Event',
50
- method: handleWebSocketConnection,
51
- shouldUseDatabase: true, // Set to true as we're using the database
52
- isUserFacingResponse: true, // This is a server-to-server response
53
- });
54
-
55
- module.exports = { handler };
@@ -1,291 +0,0 @@
1
- const path = require('path');
2
- const fs = require('fs');
3
-
4
- const composeServerlessDefinition = (AppDefinition, IntegrationFactory) => {
5
- const definition = {
6
- frameworkVersion: '>=3.17.0',
7
- service: AppDefinition.name || 'create-frigg-app',
8
- package: {
9
- individually: true,
10
- },
11
- useDotenv: true,
12
- provider: {
13
- name: AppDefinition.provider || 'aws',
14
- runtime: 'nodejs20.x',
15
- timeout: 30,
16
- region: 'us-east-1',
17
- stage: '${opt:stage}',
18
- environment: {
19
- STAGE: '${opt:stage}',
20
- AWS_NODEJS_CONNECTION_REUSE_ENABLED: 1,
21
- },
22
- iamRoleStatements: [
23
- {
24
- Effect: 'Allow',
25
- Action: ['sns:Publish'],
26
- Resource: {
27
- Ref: 'InternalErrorBridgeTopic',
28
- },
29
- },
30
- ],
31
- },
32
- plugins: [
33
- 'serverless-dotenv-plugin',
34
- 'serverless-offline-sqs',
35
- 'serverless-offline',
36
- '@friggframework/serverless-plugin',
37
- ],
38
- custom: {
39
- 'serverless-offline': {
40
- httpPort: 3001,
41
- lambdaPort: 4001,
42
- websocketPort: 3002,
43
- },
44
- 'serverless-offline-sqs': {
45
- autoCreate: false,
46
- apiVersion: '2012-11-05',
47
- endpoint: 'http://localhost:4566',
48
- region: 'us-east-1',
49
- accessKeyId: 'root',
50
- secretAccessKey: 'root',
51
- skipCacheInvalidation: false,
52
- },
53
- webpack: {
54
- webpackConfig: 'webpack.config.js',
55
- includeModules: {
56
- forceExclude: ['aws-sdk'],
57
- },
58
- packager: 'npm',
59
- excludeFiles: ['src/**/*.test.js', 'test/'],
60
- },
61
- },
62
- functions: {
63
- defaultWebsocket: {
64
- handler:
65
- '/../node_modules/@friggframework/devtools/infrastructure/routers/websocket.handler',
66
- events: [
67
- {
68
- websocket: {
69
- route: '$connect',
70
- },
71
- },
72
- {
73
- websocket: {
74
- route: '$default',
75
- },
76
- },
77
- {
78
- websocket: {
79
- route: '$disconnect',
80
- },
81
- },
82
- ],
83
- },
84
- auth: {
85
- handler:
86
- '/../node_modules/@friggframework/devtools/infrastructure/routers/auth.handler',
87
- events: [
88
- {
89
- http: {
90
- path: '/api/integrations',
91
- method: 'ANY',
92
- cors: true,
93
- },
94
- },
95
- {
96
- http: {
97
- path: '/api/integrations/{proxy+}',
98
- method: 'ANY',
99
- cors: true,
100
- },
101
- },
102
- {
103
- http: {
104
- path: '/api/authorize',
105
- method: 'ANY',
106
- cors: true,
107
- },
108
- },
109
- ],
110
- },
111
- user: {
112
- handler:
113
- '/../node_modules/@friggframework/devtools/infrastructure/routers/user.handler',
114
- events: [
115
- {
116
- http: {
117
- path: '/user/{proxy+}',
118
- method: 'ANY',
119
- cors: true,
120
- },
121
- },
122
- ],
123
- },
124
- },
125
- resources: {
126
- Resources: {
127
- InternalErrorQueue: {
128
- Type: 'AWS::SQS::Queue',
129
- Properties: {
130
- QueueName:
131
- 'internal-error-queue-${self:provider.stage}',
132
- MessageRetentionPeriod: 300,
133
- },
134
- },
135
- InternalErrorBridgeTopic: {
136
- Type: 'AWS::SNS::Topic',
137
- Properties: {
138
- Subscription: [
139
- {
140
- Protocol: 'sqs',
141
- Endpoint: {
142
- 'Fn::GetAtt': ['InternalErrorQueue', 'Arn'],
143
- },
144
- },
145
- ],
146
- },
147
- },
148
- InternalErrorBridgePolicy: {
149
- Type: 'AWS::SQS::QueuePolicy',
150
- Properties: {
151
- Queues: [{ Ref: 'InternalErrorQueue' }],
152
- PolicyDocument: {
153
- Version: '2012-10-17',
154
- Statement: [
155
- {
156
- Sid: 'Allow Dead Letter SNS to publish to SQS',
157
- Effect: 'Allow',
158
- Principal: {
159
- Service: 'sns.amazonaws.com',
160
- },
161
- Resource: {
162
- 'Fn::GetAtt': [
163
- 'InternalErrorQueue',
164
- 'Arn',
165
- ],
166
- },
167
- Action: [
168
- 'SQS:SendMessage',
169
- 'SQS:SendMessageBatch',
170
- ],
171
- Condition: {
172
- ArnEquals: {
173
- 'aws:SourceArn': {
174
- Ref: 'InternalErrorBridgeTopic',
175
- },
176
- },
177
- },
178
- },
179
- ],
180
- },
181
- },
182
- },
183
- ApiGatewayAlarm5xx: {
184
- Type: 'AWS::CloudWatch::Alarm',
185
- Properties: {
186
- AlarmDescription: 'API Gateway 5xx Errors',
187
- Namespace: 'AWS/ApiGateway',
188
- MetricName: '5XXError',
189
- Statistic: 'Sum',
190
- Threshold: 0,
191
- ComparisonOperator: 'GreaterThanThreshold',
192
- EvaluationPeriods: 1,
193
- Period: 60,
194
- AlarmActions: [{ Ref: 'InternalErrorBridgeTopic' }],
195
- Dimensions: [
196
- {
197
- Name: 'ApiName',
198
- Value: {
199
- 'Fn::Join': [
200
- '-',
201
- [
202
- '${self:provider.stage}',
203
- '${self:service}',
204
- ],
205
- ],
206
- },
207
- },
208
- ],
209
- },
210
- },
211
- },
212
- },
213
- };
214
-
215
- // Add integration-specific functions and resources
216
- AppDefinition.integrations.forEach((integration) => {
217
- const integrationName = integration.Definition.name;
218
-
219
- // Add function for the integration
220
- definition.functions[integrationName] = {
221
- handler: `/../node_modules/@friggframework/devtools/infrastructure/routers/integration-defined-routers.handlers.${integrationName}.handler`,
222
- // events: integration.Definition.routes.map((route) => ({
223
- // http: {
224
- // path: `/api/${integrationName}-integration${route.path}`,
225
- // method: route.method || 'ANY',
226
- // cors: true,
227
- // },
228
- // })),
229
- events: [
230
- {
231
- http: {
232
- path: `/api/${integrationName}-integration/{proxy*}`,
233
- method: 'ANY',
234
- cors: true,
235
- },
236
- },
237
- ],
238
- };
239
-
240
- // Add SQS Queue for the integration
241
- const queueReference = `${
242
- integrationName.charAt(0).toUpperCase() + integrationName.slice(1)
243
- }Queue`;
244
- const queueName = `\${self:service}--\${self:provider.stage}-${queueReference}`;
245
- definition.resources.Resources[queueReference] = {
246
- Type: 'AWS::SQS::Queue',
247
- Properties: {
248
- QueueName: `\${self:custom.${queueReference}}`,
249
- MessageRetentionPeriod: 60,
250
- RedrivePolicy: {
251
- maxReceiveCount: 1,
252
- deadLetterTargetArn: {
253
- 'Fn::GetAtt': ['InternalErrorQueue', 'Arn'],
254
- },
255
- },
256
- },
257
- };
258
-
259
- // Add Queue Worker for the integration
260
- const queueWorkerName = `${integrationName}QueueWorker`;
261
- definition.functions[queueWorkerName] = {
262
- handler: `/../node_modules/@friggframework/devtools/infrastructure/workers/integration-defined-workers.handlers.${integrationName}.queueWorker`,
263
- reservedConcurrency: 5,
264
- events: [
265
- {
266
- sqs: {
267
- arn: {
268
- 'Fn::GetAtt': [queueReference, 'Arn'],
269
- },
270
- batchSize: 1,
271
- },
272
- },
273
- ],
274
- timeout: 600,
275
- };
276
-
277
- // Add Queue URL for the integration to the ENVironment variables
278
- definition.provider.environment = {
279
- ...definition.provider.environment,
280
- [integrationName.toUpperCase() + '_QUEUE_URL']: {
281
- Ref: queueReference,
282
- },
283
- };
284
-
285
- definition.custom[queueReference] = queueName;
286
- });
287
-
288
- return definition;
289
- };
290
-
291
- module.exports = { composeServerlessDefinition };
@@ -1,24 +0,0 @@
1
- const { createHandler } = require('@friggframework/core');
2
- const { integrationFactory, createQueueWorker } = require('./../backend-utils');
3
-
4
- const handlers = {};
5
- integrationFactory.integrationClasses.forEach((IntegrationClass) => {
6
- const defaultQueueWorker = createQueueWorker(IntegrationClass);
7
-
8
- handlers[`${IntegrationClass.Definition.name}`] = {
9
- queueWorker: createHandler({
10
- eventName: `Queue Worker for ${IntegrationClass.Definition.name}`,
11
- isUserFacingResponse: false,
12
- method: async (event, context) => {
13
- const worker = new defaultQueueWorker();
14
- await worker.run(event, context);
15
- return {
16
- message: 'Successfully processed the Generic Queue Worker',
17
- input: event,
18
- };
19
- },
20
- }),
21
- };
22
- });
23
-
24
- module.exports = { handlers };
@@ -1,125 +0,0 @@
1
- const {
2
- Auther,
3
- ModuleConstants,
4
- createObjectId,
5
- connectToDatabase,
6
- disconnectFromDatabase,
7
- } = require('@friggframework/core');
8
- const { createMockApiObject } = require("./mock-integration");
9
-
10
-
11
- function testAutherDefinition(definition, mocks) {
12
- const getModule = async (params) => {
13
- const module = await Auther.getInstance({
14
- definition,
15
- userId: createObjectId(),
16
- ...params,
17
- });
18
- if (mocks.tokenResponse) {
19
- mocks.getTokenFrom = async function(code) {
20
- await this.setTokens(mocks.tokenResponse);
21
- return mocks.tokenResponse
22
- }
23
- mocks.getTokenFromCode = mocks.getTokenFromCode || mocks.getTokenFrom
24
- mocks.getTokenFromCodeBasicAuthHeader = mocks.getTokenFromCodeBasicAuthHeader || mocks.getTokenFrom
25
- mocks.getTokenFromClientCredentials = mocks.getTokenFromClientCredentials || mocks.getTokenFrom
26
- mocks.getTokenFromUsernamePassword = mocks.getTokenFromUsernamePassword || mocks.getTokenFrom
27
- }
28
- if (mocks.refreshResponse) {
29
- mocks.refreshAccessToken = async function(code) {
30
- await this.setTokens(mocks.refreshResponse);
31
- return mocks.refreshResponse
32
- }
33
- }
34
- module.api = createMockApiObject(jest, module.api, mocks);
35
- return module
36
- }
37
-
38
-
39
- describe(`${definition.moduleName} Module Tests`, () => {
40
- let module, authUrl;
41
- beforeAll(async () => {
42
- await connectToDatabase();
43
- module = await getModule();
44
- });
45
-
46
- afterAll(async () => {
47
- await disconnectFromDatabase();
48
- });
49
-
50
- let requirements, authCallbackParams;
51
- if (definition.API.requesterType === ModuleConstants.authType.oauth2) {
52
- authCallbackParams = mocks.authorizeResponse || mocks.authorizeParams;
53
- describe('getAuthorizationRequirements() test', () => {
54
- it('should return auth requirements', async () => {
55
- requirements = await module.getAuthorizationRequirements();
56
- expect(requirements).toBeDefined();
57
- expect(requirements.type).toEqual(ModuleConstants.authType.oauth2);
58
- expect(requirements.url).toBeDefined();
59
- authUrl = requirements.url;
60
- });
61
- });
62
- } else if (definition.API.requesterType === ModuleConstants.authType.basic) {
63
- // could also confirm authCallbackParams against the auth requirements
64
- authCallbackParams = mocks.authorizeParams
65
- describe('getAuthorizationRequirements() test', () => {
66
- it('should return auth requirements', async () => {
67
- requirements = module.getAuthorizationRequirements();
68
- expect(requirements).toBeDefined();
69
- expect(requirements.type).toEqual(ModuleConstants.authType.basic);
70
- });
71
- });
72
- } else if (definition.API.requesterType === ModuleConstants.authType.apiKey) {
73
- // could also confirm authCallbackParams against the auth requirements
74
- authCallbackParams = mocks.authorizeParams
75
- describe('getAuthorizationRequirements() test', () => {
76
- it('should return auth requirements', async () => {
77
- requirements = module.getAuthorizationRequirements();
78
- expect(requirements).toBeDefined();
79
- expect(requirements.type).toEqual(ModuleConstants.authType.apiKey);
80
- });
81
- });
82
- }
83
-
84
- describe('Authorization requests', () => {
85
- let firstRes;
86
- it('processAuthorizationCallback()', async () => {
87
- firstRes = await module.processAuthorizationCallback(authCallbackParams);
88
- expect(firstRes).toBeDefined();
89
- expect(firstRes.entity_id).toBeDefined();
90
- expect(firstRes.credential_id).toBeDefined();
91
- });
92
- it('retrieves existing entity on subsequent calls', async () => {
93
- const res = await module.processAuthorizationCallback(authCallbackParams);
94
- expect(res).toEqual(firstRes);
95
- });
96
- });
97
-
98
- describe('Test credential retrieval and module instantiation', () => {
99
- it('retrieve by entity id', async () => {
100
- const newModule = await getModule({
101
- userId: module.userId,
102
- entityId: module.entity.id
103
- });
104
- expect(newModule).toBeDefined();
105
- expect(newModule.entity).toBeDefined();
106
- expect(newModule.credential).toBeDefined();
107
- expect(await newModule.testAuth()).toBeTruthy();
108
-
109
- });
110
-
111
- it('retrieve by credential id', async () => {
112
- const newModule = await getModule({
113
- userId: module.userId,
114
- credentialId: module.credential.id
115
- });
116
- expect(newModule).toBeDefined();
117
- expect(newModule.credential).toBeDefined();
118
- expect(await newModule.testAuth()).toBeTruthy();
119
- });
120
- });
121
- });
122
- }
123
-
124
- module.exports = { testAutherDefinition }
125
-