@gnar-engine/cli 1.0.0 → 1.0.2

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 (230) hide show
  1. package/assets/gnar-engine-logo-white.svg +9 -0
  2. package/bootstrap/deploy.localdev.yml +51 -0
  3. package/bootstrap/secrets.localdev.yml +27 -0
  4. package/bootstrap/services/agent/Dockerfile +23 -0
  5. package/bootstrap/services/agent/notes.md +28 -0
  6. package/bootstrap/services/agent/package.json +16 -0
  7. package/bootstrap/services/agent/src/app.js +52 -0
  8. package/bootstrap/services/agent/src/commands/agent.handler.js +104 -0
  9. package/bootstrap/services/agent/src/config.js +52 -0
  10. package/bootstrap/services/agent/src/controllers/http.controller.js +44 -0
  11. package/bootstrap/services/agent/src/controllers/message.controller.js +51 -0
  12. package/bootstrap/services/agent/src/db/migrations/01-init.js +50 -0
  13. package/bootstrap/services/agent/src/db/migrations/02-agent-service-init.js +36 -0
  14. package/bootstrap/services/agent/src/policies/agent.policy.js +13 -0
  15. package/bootstrap/services/agent/src/schema/Agent.schema.js +17 -0
  16. package/bootstrap/services/agent/src/services/agent.service.js +259 -0
  17. package/bootstrap/services/agent/src/services/chatgpt.service.js +46 -0
  18. package/bootstrap/services/agent/src/services/manifest.service.js +21 -0
  19. package/bootstrap/services/control/Dockerfile +23 -0
  20. package/bootstrap/services/control/Dockerfile.prod +37 -0
  21. package/bootstrap/services/control/README.md +25 -0
  22. package/bootstrap/services/control/package.json +16 -0
  23. package/bootstrap/services/control/src/app.js +45 -0
  24. package/bootstrap/services/control/src/commands/control.handler.js +231 -0
  25. package/bootstrap/services/control/src/commands/service.handler.js +81 -0
  26. package/bootstrap/services/control/src/commands/task.handler.js +247 -0
  27. package/bootstrap/services/control/src/config.js +55 -0
  28. package/bootstrap/services/control/src/controllers/http.controller.js +228 -0
  29. package/bootstrap/services/control/src/controllers/message.controller.js +40 -0
  30. package/bootstrap/services/control/src/db/migrations/01-init.js +50 -0
  31. package/bootstrap/services/control/src/db/migrations/02-control-service-init.js +60 -0
  32. package/bootstrap/services/control/src/db/migrations/03-alter-tasks.js +29 -0
  33. package/bootstrap/services/control/src/policies/task.policy.js +53 -0
  34. package/bootstrap/services/control/src/schema/control.schema.js +42 -0
  35. package/bootstrap/services/control/src/services/registry.service.js +83 -0
  36. package/bootstrap/services/control/src/services/reset.service.js +28 -0
  37. package/bootstrap/services/control/src/services/task.service.js +153 -0
  38. package/bootstrap/services/control/src/tests/control.test.js +50 -0
  39. package/bootstrap/services/notification/Dockerfile +23 -0
  40. package/bootstrap/services/notification/Dockerfile.prod +37 -0
  41. package/bootstrap/services/notification/README.md +3 -0
  42. package/bootstrap/services/notification/package.json +34 -0
  43. package/bootstrap/services/notification/src/app.js +51 -0
  44. package/bootstrap/services/notification/src/commands/command-bus.js +20 -0
  45. package/bootstrap/services/notification/src/commands/handlers/control.handler.js +18 -0
  46. package/bootstrap/services/notification/src/commands/handlers/notification.handler.js +157 -0
  47. package/bootstrap/services/notification/src/config.js +15 -0
  48. package/bootstrap/services/notification/src/controllers/message.controller.js +82 -0
  49. package/bootstrap/services/notification/src/services/logger.service.js +16 -0
  50. package/bootstrap/services/notification/src/services/ses.service.js +23 -0
  51. package/bootstrap/services/notification/src/templates/admin-order-recieved.hbs +136 -0
  52. package/bootstrap/services/notification/src/templates/admin-subscription-failed.hbs +87 -0
  53. package/bootstrap/services/notification/src/templates/customer-order-recieved.hbs +132 -0
  54. package/bootstrap/services/notification/src/templates/customer-subscription-failed.hbs +77 -0
  55. package/bootstrap/services/notification/src/tests/notification.test.js +0 -0
  56. package/bootstrap/services/portal/Dockerfile +23 -0
  57. package/bootstrap/services/portal/Dockerfile.remote +40 -0
  58. package/bootstrap/services/portal/README.md +22 -0
  59. package/bootstrap/services/portal/nginx.conf +12 -0
  60. package/bootstrap/services/portal/package.json +59 -0
  61. package/bootstrap/services/portal/public/favicon.ico +0 -0
  62. package/bootstrap/services/portal/public/gnar-white.png +0 -0
  63. package/bootstrap/services/portal/public/gnarengine-logo-black.png +0 -0
  64. package/bootstrap/services/portal/public/index.html +43 -0
  65. package/bootstrap/services/portal/public/logo192.png +0 -0
  66. package/bootstrap/services/portal/public/logo512.png +0 -0
  67. package/bootstrap/services/portal/public/manifest.json +25 -0
  68. package/bootstrap/services/portal/public/robots.txt +3 -0
  69. package/bootstrap/services/portal/src/App.js +56 -0
  70. package/bootstrap/services/portal/src/assets/Logo_Anchord_Black.svg +1 -0
  71. package/bootstrap/services/portal/src/assets/Logo_Anchord_Black_Green.svg +1 -0
  72. package/bootstrap/services/portal/src/assets/Logo_Anchord_White_Green.svg +1 -0
  73. package/bootstrap/services/portal/src/assets/activity.svg +3 -0
  74. package/bootstrap/services/portal/src/assets/arrow.svg +3 -0
  75. package/bootstrap/services/portal/src/assets/bin-white.svg +3 -0
  76. package/bootstrap/services/portal/src/assets/bin.svg +3 -0
  77. package/bootstrap/services/portal/src/assets/check.svg +3 -0
  78. package/bootstrap/services/portal/src/assets/chevron.svg +3 -0
  79. package/bootstrap/services/portal/src/assets/contact.svg +3 -0
  80. package/bootstrap/services/portal/src/assets/dots-vertical.svg +5 -0
  81. package/bootstrap/services/portal/src/assets/eye-off.svg +3 -0
  82. package/bootstrap/services/portal/src/assets/eye.svg +4 -0
  83. package/bootstrap/services/portal/src/assets/gnar-engine-black.svg +47 -0
  84. package/bootstrap/services/portal/src/assets/gnar-engine-white.svg +47 -0
  85. package/bootstrap/services/portal/src/assets/gnar_engine.svg +3 -0
  86. package/bootstrap/services/portal/src/assets/gnarengine-logo-black.png +0 -0
  87. package/bootstrap/services/portal/src/assets/home.svg +3 -0
  88. package/bootstrap/services/portal/src/assets/link.svg +3 -0
  89. package/bootstrap/services/portal/src/assets/lock.svg +3 -0
  90. package/bootstrap/services/portal/src/assets/package.svg +4 -0
  91. package/bootstrap/services/portal/src/assets/raffle.svg +3 -0
  92. package/bootstrap/services/portal/src/assets/settings.svg +4 -0
  93. package/bootstrap/services/portal/src/assets/shopping-bag.svg +3 -0
  94. package/bootstrap/services/portal/src/assets/user-black.svg +3 -0
  95. package/bootstrap/services/portal/src/assets/user.svg +3 -0
  96. package/bootstrap/services/portal/src/assets/users.svg +3 -0
  97. package/bootstrap/services/portal/src/assets/wallet.svg +3 -0
  98. package/bootstrap/services/portal/src/css/style.css +1007 -0
  99. package/bootstrap/services/portal/src/data/data.js +70 -0
  100. package/bootstrap/services/portal/src/features/attributeFormRow/AttributeFormRow.jsx +32 -0
  101. package/bootstrap/services/portal/src/features/billingShipping/BillingShipping.jsx +160 -0
  102. package/bootstrap/services/portal/src/features/crud/crudEdit.less +230 -0
  103. package/bootstrap/services/portal/src/features/crud/crudList.less +134 -0
  104. package/bootstrap/services/portal/src/features/crud/crudPage.less +31 -0
  105. package/bootstrap/services/portal/src/features/crudContact/CrudContactList.jsx +108 -0
  106. package/bootstrap/services/portal/src/features/crudContact/CrudContactSingle.jsx +243 -0
  107. package/bootstrap/services/portal/src/features/crudOrder/CrudOrderList.jsx +109 -0
  108. package/bootstrap/services/portal/src/features/crudOrder/CrudOrderSingle.jsx +315 -0
  109. package/bootstrap/services/portal/src/features/crudProducts/CrudProductList.jsx +104 -0
  110. package/bootstrap/services/portal/src/features/crudProducts/CrudProductSingle.jsx +388 -0
  111. package/bootstrap/services/portal/src/features/crudRaffles/CrudRafflesList.jsx +104 -0
  112. package/bootstrap/services/portal/src/features/crudRaffles/CrudRafflesSingle.jsx +208 -0
  113. package/bootstrap/services/portal/src/features/crudSubscription/CrudSubscriptionList.jsx +110 -0
  114. package/bootstrap/services/portal/src/features/crudSubscription/CrudSubscriptionSingle.jsx +261 -0
  115. package/bootstrap/services/portal/src/features/crudUser/CrudUserList.jsx +107 -0
  116. package/bootstrap/services/portal/src/features/crudUser/CrudUserSingle.jsx +402 -0
  117. package/bootstrap/services/portal/src/features/inventoryFormRow/InventoryFormRow.jsx +30 -0
  118. package/bootstrap/services/portal/src/features/lineItems/LineItems.jsx +113 -0
  119. package/bootstrap/services/portal/src/features/loginForm/LoginForm.jsx +56 -0
  120. package/bootstrap/services/portal/src/features/loginForm/loginForm.less +56 -0
  121. package/bootstrap/services/portal/src/features/notes/Notes.jsx +18 -0
  122. package/bootstrap/services/portal/src/features/passwordReset/PasswordResetForm.jsx +96 -0
  123. package/bootstrap/services/portal/src/features/passwordReset/PasswordResetRequestForm.jsx +74 -0
  124. package/bootstrap/services/portal/src/features/priceFormRow/PriceFormRow.jsx +102 -0
  125. package/bootstrap/services/portal/src/features/priceFormRow/priceFormRow.less +24 -0
  126. package/bootstrap/services/portal/src/features/raffleEntriesList/RaffleEntriesList.jsx +99 -0
  127. package/bootstrap/services/portal/src/features/raffleProductFormRow/RaffleProductFormRow.jsx +46 -0
  128. package/bootstrap/services/portal/src/features/sidebar/Sidebar.jsx +64 -0
  129. package/bootstrap/services/portal/src/features/sidebar/sidebar.less +49 -0
  130. package/bootstrap/services/portal/src/features/skus/Skus.jsx +109 -0
  131. package/bootstrap/services/portal/src/features/subscriptionSchedule/SubscriptionSchedule.jsx +44 -0
  132. package/bootstrap/services/portal/src/features/taxonomyFormRow/TaxonomyFormRow.jsx +32 -0
  133. package/bootstrap/services/portal/src/features/user/User.jsx +54 -0
  134. package/bootstrap/services/portal/src/features/user/user.less +57 -0
  135. package/bootstrap/services/portal/src/includes/utilities.js +259 -0
  136. package/bootstrap/services/portal/src/index.js +14 -0
  137. package/bootstrap/services/portal/src/layouts/CrudLayout.jsx +50 -0
  138. package/bootstrap/services/portal/src/layouts/LoginLayout.jsx +17 -0
  139. package/bootstrap/services/portal/src/layouts/PortalLayout.jsx +48 -0
  140. package/bootstrap/services/portal/src/layouts/loginLayout.less +33 -0
  141. package/bootstrap/services/portal/src/layouts/portalLayout.less +67 -0
  142. package/bootstrap/services/portal/src/pages/contacts/Contacts.jsx +199 -0
  143. package/bootstrap/services/portal/src/pages/dashboard/Dashboard.jsx +17 -0
  144. package/bootstrap/services/portal/src/pages/integrations/Integrations.jsx +10 -0
  145. package/bootstrap/services/portal/src/pages/login/Login.jsx +15 -0
  146. package/bootstrap/services/portal/src/pages/login/login.less +10 -0
  147. package/bootstrap/services/portal/src/pages/orders/Orders.jsx +199 -0
  148. package/bootstrap/services/portal/src/pages/passwordReset/PasswordResetPage.jsx +15 -0
  149. package/bootstrap/services/portal/src/pages/passwordResetRequest/PasswordResetRequestPage.jsx +15 -0
  150. package/bootstrap/services/portal/src/pages/payments/Payments.jsx +10 -0
  151. package/bootstrap/services/portal/src/pages/portal/Portal.jsx +43 -0
  152. package/bootstrap/services/portal/src/pages/products/Products.jsx +212 -0
  153. package/bootstrap/services/portal/src/pages/raffleEntries/RaffleEntries.jsx +124 -0
  154. package/bootstrap/services/portal/src/pages/raffles/Raffles.jsx +186 -0
  155. package/bootstrap/services/portal/src/pages/reports/Reports.jsx +10 -0
  156. package/bootstrap/services/portal/src/pages/settings/Settings.jsx +10 -0
  157. package/bootstrap/services/portal/src/pages/subscriptions/Subscriptions.jsx +199 -0
  158. package/bootstrap/services/portal/src/pages/users/Users.jsx +193 -0
  159. package/bootstrap/services/portal/src/pages/users/users.less +25 -0
  160. package/bootstrap/services/portal/src/slices/authSlice.js +71 -0
  161. package/bootstrap/services/portal/src/store/configureStore.js +12 -0
  162. package/bootstrap/services/portal/src/styles/global.less +159 -0
  163. package/bootstrap/services/portal/src/styles/inputs.less +157 -0
  164. package/bootstrap/services/portal/src/styles/main.less +26 -0
  165. package/bootstrap/services/portal/src/ui/collapsible/Collapsible.jsx +97 -0
  166. package/bootstrap/services/portal/src/ui/collapsible/collapsible.less +23 -0
  167. package/bootstrap/services/portal/src/ui/customCheckbox/CustomCheckbox.jsx +17 -0
  168. package/bootstrap/services/portal/src/ui/customCheckbox/customCheckbox.less +42 -0
  169. package/bootstrap/services/portal/src/ui/customMultiSelect/CustomMultiSelect.jsx +63 -0
  170. package/bootstrap/services/portal/src/ui/customMultiSelect/CustomMultiSelectPeriod.jsx +63 -0
  171. package/bootstrap/services/portal/src/ui/customSelect/CustomSelect.jsx +63 -0
  172. package/bootstrap/services/portal/src/ui/customSelect/customSelect.less +92 -0
  173. package/bootstrap/services/portal/src/ui/goBack/GoBack.jsx +19 -0
  174. package/bootstrap/services/portal/src/ui/loader/Loader.jsx +12 -0
  175. package/bootstrap/services/portal/src/ui/pagination/Pagination.jsx +23 -0
  176. package/bootstrap/services/portal/src/ui/repeater/Repeater.jsx +29 -0
  177. package/bootstrap/services/portal/src/ui/saveButton/SaveButton.jsx +69 -0
  178. package/bootstrap/services/portal/src/ui/saveButton/saveButton.less +0 -0
  179. package/bootstrap/services/rabbit-mq/Dockerfile.prod +9 -0
  180. package/bootstrap/services/user/Dockerfile +23 -0
  181. package/bootstrap/services/user/Dockerfile.prod +37 -0
  182. package/bootstrap/services/user/README.md +8 -0
  183. package/bootstrap/services/user/package.json +16 -0
  184. package/bootstrap/services/user/src/app.js +45 -0
  185. package/bootstrap/services/user/src/commands/session.handler.js +23 -0
  186. package/bootstrap/services/user/src/commands/user.handler.js +286 -0
  187. package/bootstrap/services/user/src/config.js +73 -0
  188. package/bootstrap/services/user/src/controllers/http.controller.js +156 -0
  189. package/bootstrap/services/user/src/controllers/message.controller.js +51 -0
  190. package/bootstrap/services/user/src/db/migrations/01-init.js +50 -0
  191. package/bootstrap/services/user/src/db/migrations/02-user-service-init.js +63 -0
  192. package/bootstrap/services/user/src/db/migrations/03-unauth-sessions.js +43 -0
  193. package/bootstrap/services/user/src/db/seeders/development/01-root-user.js +29 -0
  194. package/bootstrap/services/user/src/db/seeders/development/02-portal-admin-user.js +27 -0
  195. package/bootstrap/services/user/src/db/seeders/production/01-root-user.js +29 -0
  196. package/bootstrap/services/user/src/policies/user.policy.js +81 -0
  197. package/bootstrap/services/user/src/schema/user.schema.js +69 -0
  198. package/bootstrap/services/user/src/services/authentication.service.js +127 -0
  199. package/bootstrap/services/user/src/services/session.service.js +58 -0
  200. package/bootstrap/services/user/src/services/user.service.js +130 -0
  201. package/bootstrap/services/user/src/tests/user.test.js +126 -0
  202. package/package.json +3 -7
  203. package/src/agent/agent.client.js +28 -0
  204. package/src/agent/commands.js +48 -0
  205. package/src/cli.js +30 -0
  206. package/src/config.js +8 -0
  207. package/src/control/commands.js +156 -0
  208. package/src/control/control.client.js +127 -0
  209. package/src/dev/commands.js +71 -0
  210. package/src/dev/dev.service.js +320 -0
  211. package/src/engine/infra.js +142 -0
  212. package/src/helpers/helpers.js +63 -0
  213. package/src/profiles/command.js +170 -0
  214. package/src/profiles/profiles.client.js +101 -0
  215. package/src/scaffolder/commands.js +123 -0
  216. package/src/scaffolder/scaffolder.handler.js +252 -0
  217. package/src/services/client.js +174 -0
  218. package/templates/service/Dockerfile.hbs +20 -0
  219. package/templates/service/app.js.hbs +38 -0
  220. package/templates/service/commands/{{serviceName}}.handler.js.hbs +97 -0
  221. package/templates/service/config.js.hbs +48 -0
  222. package/templates/service/controllers/http.controller.js.hbs +87 -0
  223. package/templates/service/controllers/message.controller.js.hbs +51 -0
  224. package/templates/service/db/migrations/01-init.js.hbs +50 -0
  225. package/templates/service/db/migrations/02-{{lowerCase serviceName}}-service-init.js.hbs +23 -0
  226. package/templates/service/package.json.hbs +18 -0
  227. package/templates/service/policies/{{serviceName}}.policy.js.hbs +49 -0
  228. package/templates/service/schema/{{serviceName}}.schema.js.hbs +14 -0
  229. package/templates/service/services/{{serviceName}}.service.js.hbs +32 -0
  230. package/dist/cli.js +0 -18
@@ -0,0 +1,9 @@
1
+ <svg width="344" height="61" viewBox="0 0 344 61" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
2
+ <rect width="344" height="61" fill="url(#pattern0_238_39)"/>
3
+ <defs>
4
+ <pattern id="pattern0_238_39" patternContentUnits="objectBoundingBox" width="1" height="1">
5
+ <use xlink:href="#image0_238_39" transform="matrix(0.001 0 0 0.00563934 0 -0.0103607)"/>
6
+ </pattern>
7
+ <image id="image0_238_39" width="1000" height="181" preserveAspectRatio="none" xlink:href=""/>
8
+ </defs>
9
+ </svg>
@@ -0,0 +1,51 @@
1
+ # deploy.localdev.yml
2
+
3
+ # - This file is used to orchestrate locally running containers for development
4
+ # - environment: localdev is a named convention required for local development
5
+
6
+ config:
7
+ core-version: 1.0
8
+ architecture: microservice
9
+ region: eu-west-2
10
+ environment: localdev
11
+ namespace: my-project
12
+
13
+ services:
14
+ - name: control
15
+ listener_rules:
16
+ paths:
17
+ - /control
18
+ - /tasks
19
+ min-tasks: 1
20
+ max-tasks: 1
21
+ depends_on:
22
+ - control-db
23
+ command: ["npm", "run", "start:dev"]
24
+ ports:
25
+ - "4001:3000"
26
+
27
+ - name: user
28
+ listener_rules:
29
+ paths:
30
+ - /authenticate
31
+ - /users
32
+ min-tasks: 1
33
+ max-tasks: 1
34
+ depends_on:
35
+ - control-db
36
+ command: ["npm", "run", "start:dev"]
37
+ ports:
38
+ - "4002:3000"
39
+
40
+ - name: agent
41
+ listener_rules:
42
+ paths:
43
+ - /agent
44
+ min-tasks: 1
45
+ max-tasks: 1
46
+ depends_on:
47
+ - agent-db
48
+ command: ["npm", "run", "start:dev"]
49
+ ports:
50
+ - "4003:3000"
51
+
@@ -0,0 +1,27 @@
1
+ global:
2
+ RABBITMQ_URL: amqp://gnar_engine_rabbit_user:gn4rlyRaB81Tw4sh@rabbitmq:5672
3
+ RABBITMQ_USER: gnar_engine_rabbit_user
4
+ RABBITMQ_PASS: gn4rlyRaB81Tw4sh
5
+ services:
6
+ control:
7
+ MYSQL_HOST: control-db
8
+ MYSQL_DATABASE: ge_control_db
9
+ MYSQL_USER: ge_control_db_user
10
+ MYSQL_PASSWORD: zWF85kfGJNRA9ayp
11
+ MYSQL_RANDOM_ROOT_PASSWORD: wH0Pzkht75NvMd3b
12
+ user:
13
+ MYSQL_HOST: user-db
14
+ MYSQL_DATABASE: ge_user_db
15
+ MYSQL_USER: ge_user_db_user
16
+ MYSQL_PASSWORD: WTEYWqs6wDBX459p
17
+ MYSQL_RANDOM_ROOT_PASSWORD: GXEy5T7Cp2zuOTah
18
+ ROOT_ADMIN_EMAIL: adam@gnar.co.uk
19
+ ROOT_ADMIN_USERNAME: engineadmin
20
+ ROOT_ADMIN_PASSWORD: n0eYk6aoiYAeSur1
21
+ ROOT_ADMIN_API_KEY: qydfeMcyutzIXBvHjrB2qGL9hTdco81X
22
+ agent:
23
+ MYSQL_HOST: agent-db
24
+ MYSQL_DATABASE: ge_agent_db
25
+ MYSQL_USER: ge_agent_db_user
26
+ MYSQL_PASSWORD: 4BARYvygGSv6BRPH
27
+ MYSQL_RANDOM_ROOT_PASSWORD: s27o951anIt8Lqmy
@@ -0,0 +1,23 @@
1
+ # Dockerfile for Agent Service
2
+ FROM node:20-alpine
3
+
4
+ # Set the working directory
5
+ WORKDIR /usr/gnar_engine/app
6
+
7
+ # Define a global env var
8
+ ENV GLOBAL_SERVICE_BASE_DIR=/usr/gnar_engine/app/src/
9
+
10
+ # Copy package.json and package-lock.json
11
+ COPY ./services/agent/package*.json ./
12
+
13
+ # Install nodemon
14
+ RUN npm install -g nodemon
15
+
16
+ # Install app dependencies
17
+ RUN npm install
18
+
19
+ # Expose the port the service will run on
20
+ EXPOSE 3000
21
+
22
+ # Start the application
23
+ CMD ["nodemon", "--watch", "./gnar_engine", "./gnar_engine/app.js"]
@@ -0,0 +1,28 @@
1
+ # Gnar MCP Notes
2
+
3
+ ### Aims
4
+
5
+ - We don't want to provide all command implementations (with payload information) until we know what commands are required.
6
+
7
+ Step 1: Gather Facts
8
+
9
+ - All first prompts (no chatId provided) are 'gather facts'.
10
+ - This prompt will be augmented with the all service/model schemas and a list of all available commands e.g. userService.create, userService.update.
11
+ - From the client input the model should generate an action plan with an ordered list of the commands required, and also request the exact data required from the user to carry out the plan (based on the schemas provided in the augmented prompt).
12
+
13
+ Step 2: Confirm plan
14
+
15
+ - All further prompts (chatId provided) that do not have a 'confirmed plan' are 'confirm plan'.
16
+ - This prompt will be augmented with the all service/model schemas, a list of all available commands, a manifest containing the command implementations (including payload information) for each command in the most recently proposed action plan, the most recently proposed action plan itself, and a list of all previous user inputs and response texts.
17
+ - The model should determine from the resources provided if the action plan is accurate and if we have enough information, request conmfirmation from the user to action the request. If not we should request further information from the user until all information is provided. Should reassess the proposed plan based on user input and the command implementations provided in the prompt augmentation. If the plan is suitable, we have all the required information, and the user has confirmed that we can action the request, the model should include - actionPlanGoAhead = true in the response, and also the first command execution payload in the actionPlan.
18
+
19
+
20
+ // should we postback before actioning?
21
+ Step 3: Action plan loop
22
+ - Before returning back to the client - if the agent response has 'actionPlanGoAhead' = true, we should initalise the action plan execution loop
23
+ - Action Plan Execution Loop (foreach action plan command):
24
+ - The command will be triggered with the included payload.
25
+ - The result of the first command will be passed back to the agent with the system prompt, action plan, all messages, schemas, relevant command implementations.
26
+ - This prompt should confirm the payload for the next command in the action Plan.
27
+
28
+ - Upon the last command being executed, the model will be prompted to provide a text output to confirm the result of the action plan.
@@ -0,0 +1,16 @@
1
+ {
2
+ "name": "agent-service",
3
+ "version": "1.0.0",
4
+ "description": "LLM Agent microservice for Gnar Engine",
5
+ "type": "module",
6
+ "scripts": {
7
+ "start": "node ./src/app.js",
8
+ "start:dev": "nodemon --watch ./src ./src/app.js"
9
+ },
10
+ "dependencies": {
11
+ "@gnar-engine/core": "^1.0.1",
12
+ "openai": "5.13.1"
13
+ },
14
+ "author": "Gnar Software",
15
+ "license": "MIT"
16
+ }
@@ -0,0 +1,52 @@
1
+ import { message, http, logger, db, registerService } from '@gnar-engine/core';
2
+ import { config } from './config.js';
3
+ import { messageHandlers } from './controllers/message.controller.js';
4
+ import { httpController as AgentPlatformHttpController } from './controllers/http.controller.js';
5
+ import { manifestService } from './services/manifest.service.js';
6
+ import { Agent } from './services/agent.service.js';
7
+
8
+ /**
9
+ * Initialise service
10
+ */
11
+ export const initService = async () => {
12
+
13
+ // Run migrations
14
+ db.migrations.runMigrations({config});
15
+ db.seeders.runSeeders({config});
16
+
17
+ // Import command handlers after the command bus is initialised
18
+ await import('./commands/agent.handler.js');
19
+ // Add more handlers as needed
20
+
21
+ // Initialise and register message handlers
22
+ await message.init({
23
+ config: config.message,
24
+ handlers: messageHandlers
25
+ });
26
+
27
+ // Register http routes
28
+ await http.registerRoutes({
29
+ controllers: [
30
+ AgentPlatformHttpController,
31
+ ]
32
+ });
33
+
34
+ // Initialise agent client
35
+ await Agent.init();
36
+
37
+ // Start the HTTP server
38
+ await http.start();
39
+
40
+ // Register service with control service
41
+ await registerService();
42
+
43
+ // Start manifest generation poll
44
+ //setInterval(() => {
45
+ manifestService.generateServiceManifests();
46
+ //}, 3600);
47
+
48
+ logger.info('G n a r E n g i n e | Agent Service initialised successfully.');
49
+ }
50
+
51
+ initService();
52
+
@@ -0,0 +1,104 @@
1
+ import { commands, logger } from '@gnar-engine/core';
2
+ import { Agent } from '../services/agent.service.js';
3
+ import { config } from '../config.js';
4
+
5
+
6
+ /**
7
+ * Prompt the LLM agent
8
+ */
9
+ commands.register('agentService.prompt', async ({input, chatId, authUser}) => {
10
+ try {
11
+ logger.info('recieved input' + JSON.stringify(input));
12
+ let chatContextToStore = {};
13
+
14
+ const [manifests, resolvedChatId, chat] = await Promise.all([
15
+ // Get the manifests
16
+ commands.execute('controlService.getManifests'),
17
+
18
+ // Create a new chat if chatId is not provided
19
+ (async () => {
20
+ if (!chatId) {
21
+ return await Agent.createChat({
22
+ userId: '',
23
+ title: input.substring(0, 50),
24
+ sessionKey: input.sessionKey
25
+ });
26
+ }
27
+
28
+ return chatId
29
+ })(),
30
+
31
+ // Retrieve existing chat if chatId is provided
32
+ (async () => {
33
+ if (chatId) {
34
+ return await Agent.getChat({chatId});
35
+ }
36
+
37
+ return null;
38
+ })()
39
+ ]);
40
+
41
+ let preparedInput;
42
+
43
+ // Gather facts
44
+ if (!chatId) {
45
+ preparedInput = await Agent.prepareGatherFactsPrompt({inputText: input, manifests: manifests});
46
+ }
47
+
48
+ // Prepare Plan
49
+ else if (chat) {
50
+ await logger.info('GOT HERE WITH CHAT: ' + JSON.stringify(chat));
51
+ preparedInput = await Agent.preparePlanPrompt({inputText: input, manifests: manifests, chat: chat});
52
+ }
53
+
54
+ // Infer
55
+ let agentResponse = await Agent.infer({preparedInput});
56
+ logger.info('Agent response: ' + agentResponse);
57
+ agentResponse = JSON.parse(agentResponse);
58
+
59
+ // Collect context from response
60
+ chatContextToStore.actionPlan = agentResponse.actionPlan || null;
61
+ chatContextToStore.input = input;
62
+ chatContextToStore.responseText = agentResponse.responseText || null;
63
+
64
+ // Collect required command implementations from manifests to store for next time
65
+ if (agentResponse.commandsRequired) {
66
+ chatContextToStore.commandsManifest = [];
67
+
68
+ agentResponse.commandsRequired.forEach((commandRequired) => {
69
+ manifests.manifests.forEach((manifest) => {
70
+ //logger.info('got here ' + commandRequired + ' ' + JSON.stringify(manifest.manifest) );
71
+ if (manifest.manifest?.commandImplementations?.[commandRequired]) {
72
+ chatContextToStore.commandsManifest.push(manifest.manifest.commandImplementations[commandRequired]);
73
+ }
74
+ })
75
+ });
76
+ }
77
+
78
+ logger.info('Chat context to store: ' + JSON.stringify(chatContextToStore));
79
+
80
+ // Store chat messages
81
+ chatId = resolvedChatId;
82
+ Agent.createChatMessage({
83
+ chatId: chatId,
84
+ userName: authUser.username,
85
+ context: chatContextToStore
86
+ });
87
+
88
+ // Plan execution loop
89
+ if (agentResponse.actionPlan) {
90
+ logger.info('Executing plan: ' + agentResponse.actionPlan);
91
+
92
+ }
93
+
94
+ let response = {
95
+ structuredResponse: agentResponse,
96
+ chatId: chatId
97
+ };
98
+
99
+ return response;
100
+ } catch (err) {
101
+ logger.error("Error handling LLM agent prompt: " + err);
102
+ throw err;
103
+ }
104
+ });
@@ -0,0 +1,52 @@
1
+ /**
2
+ * Gnar Engine Service Config
3
+ */
4
+ export const config = {
5
+ // service name
6
+ serviceName: 'agentService',
7
+
8
+ // microservice | modular-monolith
9
+ architecture: process.env.GLOBAL_ARCHITECTURE || 'microservice',
10
+
11
+ // web server
12
+ http: {
13
+ allowedOrigins: [],
14
+ allowedMethods: ['GET', 'POST', 'PUT', 'DELETE'],
15
+ allowedHeaders: ['Content-Type', 'Authorization'],
16
+ rateLimiting: {
17
+ max: 3,
18
+ timeWindow: '1 second',
19
+ }
20
+ },
21
+
22
+ // database
23
+ db: {
24
+ // type: mongodb | mysql
25
+ type: 'mysql',
26
+
27
+ // MongoDB
28
+ connectionUrl: process.env.AGENT_MONGO_URL,
29
+ connectionArgs: {},
30
+
31
+ // MySQL
32
+ host: process.env.AGENT_MYSQL_HOST,
33
+ user: process.env.AGENT_MYSQL_USER,
34
+ password: process.env.AGENT_MYSQL_PASSWORD,
35
+ database: process.env.AGENT_MYSQL_DATABASE,
36
+ connectionLimit: 10,
37
+ queueLimit: 20,
38
+ maxRetries: 5
39
+ },
40
+
41
+ // message broker
42
+ message: {
43
+ url: process.env.RABBITMQ_URL,
44
+ queueName: 'agentServiceQueue',
45
+ prefetch: 20
46
+ },
47
+
48
+ hashNameSpace: '',
49
+
50
+ // Default agent type
51
+ agent: 'chatgpt'
52
+ }
@@ -0,0 +1,44 @@
1
+ import { commands, logger } from '@gnar-engine/core';
2
+ import { authorise } from '../policies/agent.policy.js';
3
+
4
+ /**
5
+ * HTTP controller
6
+ */
7
+ export const httpController = {
8
+
9
+ /**
10
+ * Prompt the agent
11
+ */
12
+ agentPrompt: {
13
+ method: 'POST',
14
+ url: '/agent/prompt',
15
+ preHandler: async (request, reply) => authorise.agentPrompt(request, reply),
16
+ handler: async (request, reply) => {
17
+ logger.info('Received agent prompt request' + JSON.stringify(request.body));
18
+ const params = {
19
+ input: request.body.textInput,
20
+ chatId: request.body.chatId || '',
21
+ authUser: request.user
22
+ };
23
+
24
+ // Sanitize input (remove all JSON delimiters)
25
+ params.input = params.input.replace(/[\{\}\[\]\"\'\:\,]/g, '');
26
+
27
+ // execute
28
+ let response;
29
+ logger.info('params' + JSON.stringify(params));
30
+ try {
31
+ response = await commands.execute('prompt', params);
32
+ } catch (error) {
33
+ logger.error(error.message);
34
+ return reply.code(500).send({ error: error.message});
35
+ }
36
+
37
+ logger.info('response is: ' + JSON.stringify(response));
38
+
39
+ // handle response
40
+ reply.code(200).send(response);
41
+ }
42
+ },
43
+
44
+ }
@@ -0,0 +1,51 @@
1
+ import { commands } from '@gnar-engine/core';
2
+
3
+ export const messageHandlers = {
4
+
5
+ getAgent: async (payload) => {
6
+ let result;
7
+ if (payload.data?.id) {
8
+ result = await commands.execute('getSingleAgent', {
9
+ id: payload.data.id
10
+ });
11
+ } else if (payload.data?.email) {
12
+ result = await commands.execute('getSingleAgent', {
13
+ email: payload.data.email
14
+ });
15
+ } else {
16
+ throw new Error('No Agent ID or email provided');
17
+ }
18
+ if (!result) {
19
+ throw new Error('Agent not found');
20
+ }
21
+ return { Agent: result };
22
+ },
23
+
24
+ getManyAgents: async (payload) => {
25
+ const results = await commands.execute('getManyAgents', {});
26
+ return { agents: results };
27
+ },
28
+
29
+ createAgent: async (payload) => {
30
+ const results = await commands.execute('createAgents', {
31
+ agents: [payload.data.Agent]
32
+ });
33
+ return { agents: results };
34
+ },
35
+
36
+ updateAgent: async (payload) => {
37
+ const result = await commands.execute('updateAgent', {
38
+ id: payload.data.id,
39
+ newAgentData: payload.data
40
+ });
41
+ return { Agent: result };
42
+ },
43
+
44
+ deleteAgent: async (payload) => {
45
+ await commands.execute('deleteAgent', {
46
+ id: payload.data.id
47
+ });
48
+ return { message: 'Agent deleted' };
49
+ },
50
+
51
+ };
@@ -0,0 +1,50 @@
1
+ import { logger, db } from '@gnar-engine/core';
2
+
3
+ /**
4
+ * Up
5
+ */
6
+ export const up = async () => {
7
+ await initDatabaseTables();
8
+ }
9
+
10
+ /**
11
+ * Down
12
+ */
13
+ export const down = async () => {
14
+ await dropDatabaseTables();
15
+ }
16
+
17
+ /**
18
+ * Create all tables
19
+ */
20
+ export const initDatabaseTables = async () => {
21
+
22
+ // Migrations table
23
+ logger.info("Creating migrations table");
24
+ const createMigrationsTableQuery = `
25
+ CREATE TABLE migrations (
26
+ id INT AUTO_INCREMENT PRIMARY KEY,
27
+ name VARCHAR(255) NOT NULL UNIQUE,
28
+ created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
29
+ )`;
30
+ await db.query(createMigrationsTableQuery);
31
+
32
+ // Seeders table
33
+ logger.info("Creating seeders table");
34
+ const createSeedersTableQuery = `
35
+ CREATE TABLE seeders (
36
+ id INT AUTO_INCREMENT PRIMARY KEY,
37
+ name VARCHAR(255) NOT NULL UNIQUE,
38
+ created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
39
+ )`;
40
+ await db.query(createSeedersTableQuery);
41
+ }
42
+
43
+ /**
44
+ * Drop all tables
45
+ */
46
+ export const dropDatabaseTables = async () => {
47
+ logger.info('Dropping tables');
48
+ await db.query('DROP TABLE IF EXISTS migrations');
49
+ await db.query('DROP TABLE IF EXISTS seeders');
50
+ }
@@ -0,0 +1,36 @@
1
+ import { logger, db } from '@gnar-engine/core';
2
+
3
+ /**
4
+ * Up
5
+ */
6
+ export const up = async () => {
7
+ logger.info('Creating table: agent-chats');
8
+ await db.query(`
9
+ CREATE TABLE agent_chats (
10
+ id CHAR(36) PRIMARY KEY,
11
+ user_id CHAR(36) NOT NULL,
12
+ title VARCHAR(255) NOT NULL,
13
+ created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
14
+ updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
15
+ )
16
+ `);
17
+
18
+ logger.info('Creating table: agent-chat-messages');
19
+ await db.query(`
20
+ CREATE TABLE agent_chat_messages (
21
+ id CHAR(36) PRIMARY KEY,
22
+ chat_id CHAR(36) NOT NULL,
23
+ user_name VARCHAR(255) NOT NULL,
24
+ context MEDIUMTEXT NOT NULL,
25
+ created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
26
+ )
27
+ `);
28
+ }
29
+
30
+ /**
31
+ * Down
32
+ */
33
+ export const down = async () => {
34
+ logger.info('Dropping table: agents');
35
+ await db.query('DROP TABLE IF EXISTS agents');
36
+ }
@@ -0,0 +1,13 @@
1
+ import { config } from '../config.js';
2
+
3
+ export const authorise = {
4
+
5
+ /**
6
+ * Authorise agent prompt
7
+ */
8
+ agentPrompt: async (request, reply) => {
9
+ if (!request.user || request.user.role !== 'service_admin') {
10
+ reply.code(403).send({error: 'not authorised'});
11
+ }
12
+ }
13
+ }
@@ -0,0 +1,17 @@
1
+ import { schema } from '@gnar-engine/core';
2
+ import { config } from '../config.js';
3
+
4
+ export const AgentSchema = {
5
+ schemaName: 'agentService.AgentSchema',
6
+ schema: {
7
+ type: 'object',
8
+ properties: {
9
+ // Add your properties here
10
+
11
+ },
12
+ required: [],
13
+ additionalProperties: false
14
+ }
15
+ };
16
+
17
+ export const validateAgent = schema.compile(AgentSchema);