@agenticmail/enterprise 0.3.2 → 0.4.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.
- package/.github/CODEOWNERS +23 -0
- package/.github/workflows/publish-community-skills.yml +121 -0
- package/.github/workflows/validate-community-skills.yml +172 -0
- package/ARCHITECTURE.md +184 -167
- package/CLAUDE.md +40 -0
- package/CONTRIBUTING.md +254 -0
- package/DEPLOYMENT.md +1031 -0
- package/README.md +355 -174
- package/community-skills/_template/README.md +31 -0
- package/community-skills/_template/agenticmail-skill.json +48 -0
- package/community-skills/activecampaign/README.md +21 -0
- package/community-skills/activecampaign/agenticmail-skill.json +56 -0
- package/community-skills/adobe-sign/README.md +21 -0
- package/community-skills/adobe-sign/agenticmail-skill.json +72 -0
- package/community-skills/adp/README.md +21 -0
- package/community-skills/adp/agenticmail-skill.json +65 -0
- package/community-skills/airtable-bases/README.md +29 -0
- package/community-skills/airtable-bases/agenticmail-skill.json +69 -0
- package/community-skills/apollo-io/README.md +21 -0
- package/community-skills/apollo-io/agenticmail-skill.json +50 -0
- package/community-skills/asana-tasks/README.md +30 -0
- package/community-skills/asana-tasks/agenticmail-skill.json +70 -0
- package/community-skills/auth0/README.md +21 -0
- package/community-skills/auth0/agenticmail-skill.json +56 -0
- package/community-skills/aws-services/README.md +38 -0
- package/community-skills/aws-services/agenticmail-skill.json +70 -0
- package/community-skills/azure-devops/README.md +21 -0
- package/community-skills/azure-devops/agenticmail-skill.json +57 -0
- package/community-skills/bamboohr/README.md +21 -0
- package/community-skills/bamboohr/agenticmail-skill.json +56 -0
- package/community-skills/basecamp/README.md +21 -0
- package/community-skills/basecamp/agenticmail-skill.json +56 -0
- package/community-skills/bigcommerce/README.md +21 -0
- package/community-skills/bigcommerce/agenticmail-skill.json +55 -0
- package/community-skills/bitbucket-repos/README.md +29 -0
- package/community-skills/bitbucket-repos/agenticmail-skill.json +70 -0
- package/community-skills/box/README.md +21 -0
- package/community-skills/box/agenticmail-skill.json +48 -0
- package/community-skills/brex/README.md +21 -0
- package/community-skills/brex/agenticmail-skill.json +48 -0
- package/community-skills/buffer/README.md +21 -0
- package/community-skills/buffer/agenticmail-skill.json +50 -0
- package/community-skills/calendly/README.md +20 -0
- package/community-skills/calendly/agenticmail-skill.json +43 -0
- package/community-skills/canva-design/README.md +33 -0
- package/community-skills/canva-design/agenticmail-skill.json +60 -0
- package/community-skills/chargebee/README.md +21 -0
- package/community-skills/chargebee/agenticmail-skill.json +55 -0
- package/community-skills/circleci-pipelines/README.md +28 -0
- package/community-skills/circleci-pipelines/agenticmail-skill.json +66 -0
- package/community-skills/clickup/README.md +21 -0
- package/community-skills/clickup/agenticmail-skill.json +48 -0
- package/community-skills/close-crm/README.md +21 -0
- package/community-skills/close-crm/agenticmail-skill.json +49 -0
- package/community-skills/cloudflare-cdn/README.md +37 -0
- package/community-skills/cloudflare-cdn/agenticmail-skill.json +67 -0
- package/community-skills/confluence-wiki/README.md +31 -0
- package/community-skills/confluence-wiki/agenticmail-skill.json +74 -0
- package/community-skills/contentful/README.md +21 -0
- package/community-skills/contentful/agenticmail-skill.json +62 -0
- package/community-skills/copper-crm/README.md +21 -0
- package/community-skills/copper-crm/agenticmail-skill.json +56 -0
- package/community-skills/crisp/README.md +21 -0
- package/community-skills/crisp/agenticmail-skill.json +56 -0
- package/community-skills/crowdstrike/README.md +21 -0
- package/community-skills/crowdstrike/agenticmail-skill.json +69 -0
- package/community-skills/datadog-monitoring/README.md +37 -0
- package/community-skills/datadog-monitoring/agenticmail-skill.json +73 -0
- package/community-skills/digitalocean/README.md +21 -0
- package/community-skills/digitalocean/agenticmail-skill.json +48 -0
- package/community-skills/discord/README.md +45 -0
- package/community-skills/discord/agenticmail-skill.json +65 -0
- package/community-skills/docker-containers/README.md +38 -0
- package/community-skills/docker-containers/agenticmail-skill.json +70 -0
- package/community-skills/docusign-esign/README.md +35 -0
- package/community-skills/docusign-esign/agenticmail-skill.json +66 -0
- package/community-skills/drift/README.md +21 -0
- package/community-skills/drift/agenticmail-skill.json +50 -0
- package/community-skills/dropbox-storage/README.md +36 -0
- package/community-skills/dropbox-storage/agenticmail-skill.json +67 -0
- package/community-skills/figma-design/README.md +36 -0
- package/community-skills/figma-design/agenticmail-skill.json +66 -0
- package/community-skills/firebase/README.md +21 -0
- package/community-skills/firebase/agenticmail-skill.json +56 -0
- package/community-skills/flyio/README.md +21 -0
- package/community-skills/flyio/agenticmail-skill.json +56 -0
- package/community-skills/freshbooks/README.md +21 -0
- package/community-skills/freshbooks/agenticmail-skill.json +55 -0
- package/community-skills/freshdesk/README.md +21 -0
- package/community-skills/freshdesk/agenticmail-skill.json +57 -0
- package/community-skills/freshsales/README.md +21 -0
- package/community-skills/freshsales/agenticmail-skill.json +55 -0
- package/community-skills/freshservice/README.md +21 -0
- package/community-skills/freshservice/agenticmail-skill.json +56 -0
- package/community-skills/front/README.md +21 -0
- package/community-skills/front/agenticmail-skill.json +48 -0
- package/community-skills/github/README.md +49 -0
- package/community-skills/github/agenticmail-skill.json +73 -0
- package/community-skills/github-actions/README.md +29 -0
- package/community-skills/github-actions/agenticmail-skill.json +72 -0
- package/community-skills/gitlab-ci/README.md +51 -0
- package/community-skills/gitlab-ci/agenticmail-skill.json +66 -0
- package/community-skills/gong/README.md +21 -0
- package/community-skills/gong/agenticmail-skill.json +50 -0
- package/community-skills/google-ads/README.md +36 -0
- package/community-skills/google-ads/agenticmail-skill.json +58 -0
- package/community-skills/google-analytics/README.md +28 -0
- package/community-skills/google-analytics/agenticmail-skill.json +69 -0
- package/community-skills/google-cloud/README.md +33 -0
- package/community-skills/google-cloud/agenticmail-skill.json +59 -0
- package/community-skills/google-drive/README.md +36 -0
- package/community-skills/google-drive/agenticmail-skill.json +65 -0
- package/community-skills/gotomeeting/README.md +20 -0
- package/community-skills/gotomeeting/agenticmail-skill.json +45 -0
- package/community-skills/grafana/README.md +21 -0
- package/community-skills/grafana/agenticmail-skill.json +56 -0
- package/community-skills/greenhouse/README.md +21 -0
- package/community-skills/greenhouse/agenticmail-skill.json +49 -0
- package/community-skills/gusto/README.md +21 -0
- package/community-skills/gusto/agenticmail-skill.json +49 -0
- package/community-skills/hashicorp-vault/README.md +21 -0
- package/community-skills/hashicorp-vault/agenticmail-skill.json +58 -0
- package/community-skills/heroku/README.md +21 -0
- package/community-skills/heroku/agenticmail-skill.json +48 -0
- package/community-skills/hibob/README.md +21 -0
- package/community-skills/hibob/agenticmail-skill.json +48 -0
- package/community-skills/hootsuite/README.md +21 -0
- package/community-skills/hootsuite/agenticmail-skill.json +48 -0
- package/community-skills/hubspot-crm/README.md +36 -0
- package/community-skills/hubspot-crm/agenticmail-skill.json +70 -0
- package/community-skills/huggingface/README.md +21 -0
- package/community-skills/huggingface/agenticmail-skill.json +48 -0
- package/community-skills/index.json +1320 -0
- package/community-skills/intercom-support/README.md +36 -0
- package/community-skills/intercom-support/agenticmail-skill.json +64 -0
- package/community-skills/jira/README.md +53 -0
- package/community-skills/jira/agenticmail-skill.json +72 -0
- package/community-skills/klaviyo/README.md +21 -0
- package/community-skills/klaviyo/agenticmail-skill.json +48 -0
- package/community-skills/kubernetes-cluster/README.md +36 -0
- package/community-skills/kubernetes-cluster/agenticmail-skill.json +72 -0
- package/community-skills/lattice/README.md +21 -0
- package/community-skills/lattice/agenticmail-skill.json +49 -0
- package/community-skills/launchdarkly/README.md +21 -0
- package/community-skills/launchdarkly/agenticmail-skill.json +48 -0
- package/community-skills/lever/README.md +21 -0
- package/community-skills/lever/agenticmail-skill.json +49 -0
- package/community-skills/linear/README.md +29 -0
- package/community-skills/linear/agenticmail-skill.json +81 -0
- package/community-skills/linkedin/README.md +21 -0
- package/community-skills/linkedin/agenticmail-skill.json +48 -0
- package/community-skills/livechat/README.md +20 -0
- package/community-skills/livechat/agenticmail-skill.json +43 -0
- package/community-skills/loom-video/README.md +20 -0
- package/community-skills/loom-video/agenticmail-skill.json +44 -0
- package/community-skills/mailchimp-campaigns/README.md +37 -0
- package/community-skills/mailchimp-campaigns/agenticmail-skill.json +69 -0
- package/community-skills/mailgun/README.md +21 -0
- package/community-skills/mailgun/agenticmail-skill.json +71 -0
- package/community-skills/microsoft-teams/README.md +51 -0
- package/community-skills/microsoft-teams/agenticmail-skill.json +66 -0
- package/community-skills/miro-boards/README.md +20 -0
- package/community-skills/miro-boards/agenticmail-skill.json +44 -0
- package/community-skills/mixpanel-analytics/README.md +34 -0
- package/community-skills/mixpanel-analytics/agenticmail-skill.json +64 -0
- package/community-skills/monday-boards/README.md +28 -0
- package/community-skills/monday-boards/agenticmail-skill.json +68 -0
- package/community-skills/mongodb-atlas/README.md +21 -0
- package/community-skills/mongodb-atlas/agenticmail-skill.json +58 -0
- package/community-skills/neon/README.md +21 -0
- package/community-skills/neon/agenticmail-skill.json +50 -0
- package/community-skills/netlify/README.md +21 -0
- package/community-skills/netlify/agenticmail-skill.json +48 -0
- package/community-skills/netsuite/README.md +21 -0
- package/community-skills/netsuite/agenticmail-skill.json +57 -0
- package/community-skills/newrelic/README.md +21 -0
- package/community-skills/newrelic/agenticmail-skill.json +58 -0
- package/community-skills/notion/README.md +49 -0
- package/community-skills/notion/agenticmail-skill.json +72 -0
- package/community-skills/okta/README.md +21 -0
- package/community-skills/okta/agenticmail-skill.json +57 -0
- package/community-skills/openai/README.md +21 -0
- package/community-skills/openai/agenticmail-skill.json +48 -0
- package/community-skills/opsgenie/README.md +21 -0
- package/community-skills/opsgenie/agenticmail-skill.json +48 -0
- package/community-skills/outreach/README.md +21 -0
- package/community-skills/outreach/agenticmail-skill.json +50 -0
- package/community-skills/paddle/README.md +21 -0
- package/community-skills/paddle/agenticmail-skill.json +55 -0
- package/community-skills/pagerduty/README.md +21 -0
- package/community-skills/pagerduty/agenticmail-skill.json +48 -0
- package/community-skills/pandadoc/README.md +21 -0
- package/community-skills/pandadoc/agenticmail-skill.json +48 -0
- package/community-skills/paypal/README.md +21 -0
- package/community-skills/paypal/agenticmail-skill.json +55 -0
- package/community-skills/personio/README.md +21 -0
- package/community-skills/personio/agenticmail-skill.json +48 -0
- package/community-skills/pinecone/README.md +21 -0
- package/community-skills/pinecone/agenticmail-skill.json +48 -0
- package/community-skills/pipedrive-deals/README.md +33 -0
- package/community-skills/pipedrive-deals/agenticmail-skill.json +60 -0
- package/community-skills/plaid/README.md +21 -0
- package/community-skills/plaid/agenticmail-skill.json +65 -0
- package/community-skills/postmark/README.md +21 -0
- package/community-skills/postmark/agenticmail-skill.json +48 -0
- package/community-skills/power-automate/README.md +21 -0
- package/community-skills/power-automate/agenticmail-skill.json +59 -0
- package/community-skills/quickbooks-accounting/README.md +38 -0
- package/community-skills/quickbooks-accounting/agenticmail-skill.json +70 -0
- package/community-skills/recurly/README.md +21 -0
- package/community-skills/recurly/agenticmail-skill.json +48 -0
- package/community-skills/reddit/README.md +21 -0
- package/community-skills/reddit/agenticmail-skill.json +48 -0
- package/community-skills/render/README.md +21 -0
- package/community-skills/render/agenticmail-skill.json +48 -0
- package/community-skills/ringcentral/README.md +20 -0
- package/community-skills/ringcentral/agenticmail-skill.json +43 -0
- package/community-skills/rippling/README.md +21 -0
- package/community-skills/rippling/agenticmail-skill.json +48 -0
- package/community-skills/salesforce/README.md +53 -0
- package/community-skills/salesforce/agenticmail-skill.json +73 -0
- package/community-skills/salesloft/README.md +21 -0
- package/community-skills/salesloft/agenticmail-skill.json +48 -0
- package/community-skills/sanity/README.md +21 -0
- package/community-skills/sanity/agenticmail-skill.json +62 -0
- package/community-skills/sap/README.md +21 -0
- package/community-skills/sap/agenticmail-skill.json +63 -0
- package/community-skills/segment-cdp/README.md +37 -0
- package/community-skills/segment-cdp/agenticmail-skill.json +66 -0
- package/community-skills/sendgrid-email/README.md +51 -0
- package/community-skills/sendgrid-email/agenticmail-skill.json +71 -0
- package/community-skills/sentry/README.md +21 -0
- package/community-skills/sentry/agenticmail-skill.json +58 -0
- package/community-skills/servicenow/README.md +21 -0
- package/community-skills/servicenow/agenticmail-skill.json +56 -0
- package/community-skills/shopify/README.md +21 -0
- package/community-skills/shopify/agenticmail-skill.json +56 -0
- package/community-skills/shortcut/README.md +21 -0
- package/community-skills/shortcut/agenticmail-skill.json +48 -0
- package/community-skills/slack/README.md +45 -0
- package/community-skills/slack/agenticmail-skill.json +73 -0
- package/community-skills/smartsheet/README.md +21 -0
- package/community-skills/smartsheet/agenticmail-skill.json +48 -0
- package/community-skills/snowflake-warehouse/README.md +37 -0
- package/community-skills/snowflake-warehouse/agenticmail-skill.json +71 -0
- package/community-skills/snyk/README.md +21 -0
- package/community-skills/snyk/agenticmail-skill.json +48 -0
- package/community-skills/splunk/README.md +21 -0
- package/community-skills/splunk/agenticmail-skill.json +56 -0
- package/community-skills/square/README.md +21 -0
- package/community-skills/square/agenticmail-skill.json +55 -0
- package/community-skills/statuspage/README.md +21 -0
- package/community-skills/statuspage/agenticmail-skill.json +56 -0
- package/community-skills/stripe/README.md +45 -0
- package/community-skills/stripe/agenticmail-skill.json +66 -0
- package/community-skills/supabase/README.md +21 -0
- package/community-skills/supabase/agenticmail-skill.json +56 -0
- package/community-skills/teamwork/README.md +21 -0
- package/community-skills/teamwork/agenticmail-skill.json +56 -0
- package/community-skills/telegram-bot/README.md +20 -0
- package/community-skills/telegram-bot/agenticmail-skill.json +52 -0
- package/community-skills/terraform-iac/README.md +34 -0
- package/community-skills/terraform-iac/agenticmail-skill.json +66 -0
- package/community-skills/todoist-tasks/README.md +29 -0
- package/community-skills/todoist-tasks/agenticmail-skill.json +72 -0
- package/community-skills/trello-cards/README.md +30 -0
- package/community-skills/trello-cards/agenticmail-skill.json +72 -0
- package/community-skills/twilio-sms/README.md +47 -0
- package/community-skills/twilio-sms/agenticmail-skill.json +63 -0
- package/community-skills/twitter/README.md +21 -0
- package/community-skills/twitter/agenticmail-skill.json +48 -0
- package/community-skills/vercel-deployments/README.md +29 -0
- package/community-skills/vercel-deployments/agenticmail-skill.json +70 -0
- package/community-skills/weaviate/README.md +21 -0
- package/community-skills/weaviate/agenticmail-skill.json +56 -0
- package/community-skills/webex/README.md +20 -0
- package/community-skills/webex/agenticmail-skill.json +43 -0
- package/community-skills/webflow/README.md +21 -0
- package/community-skills/webflow/agenticmail-skill.json +48 -0
- package/community-skills/whatsapp-business/README.md +20 -0
- package/community-skills/whatsapp-business/agenticmail-skill.json +52 -0
- package/community-skills/whereby/README.md +20 -0
- package/community-skills/whereby/agenticmail-skill.json +43 -0
- package/community-skills/woocommerce/README.md +21 -0
- package/community-skills/woocommerce/agenticmail-skill.json +55 -0
- package/community-skills/wordpress/README.md +21 -0
- package/community-skills/wordpress/agenticmail-skill.json +56 -0
- package/community-skills/workday/README.md +21 -0
- package/community-skills/workday/agenticmail-skill.json +56 -0
- package/community-skills/wrike/README.md +21 -0
- package/community-skills/wrike/agenticmail-skill.json +48 -0
- package/community-skills/xero/README.md +21 -0
- package/community-skills/xero/agenticmail-skill.json +56 -0
- package/community-skills/youtube/README.md +21 -0
- package/community-skills/youtube/agenticmail-skill.json +52 -0
- package/community-skills/zendesk-tickets/README.md +37 -0
- package/community-skills/zendesk-tickets/agenticmail-skill.json +65 -0
- package/community-skills/zoho-crm/README.md +21 -0
- package/community-skills/zoho-crm/agenticmail-skill.json +74 -0
- package/community-skills/zoom-meetings/README.md +51 -0
- package/community-skills/zoom-meetings/agenticmail-skill.json +66 -0
- package/community-skills/zuora/README.md +21 -0
- package/community-skills/zuora/agenticmail-skill.json +55 -0
- package/dashboards/README.md +81 -70
- package/dashboards/django/app.py +117 -0
- package/dashboards/django/static/styles.css +284 -0
- package/dashboards/django/templates/agent_detail.html +501 -0
- package/dashboards/django/templates/agents.html +217 -0
- package/dashboards/django/templates/api_keys.html +41 -0
- package/dashboards/django/templates/audit.html +26 -0
- package/dashboards/django/templates/compliance.html +33 -0
- package/dashboards/django/templates/components/modal.html +6 -0
- package/dashboards/django/templates/components/pagination.html +9 -0
- package/dashboards/django/templates/components/stats.html +8 -0
- package/dashboards/django/templates/dashboard.html +24 -0
- package/dashboards/django/templates/dlp.html +70 -0
- package/dashboards/django/templates/guardrails.html +78 -0
- package/dashboards/django/templates/journal.html +39 -0
- package/dashboards/django/templates/layout.html +52 -0
- package/dashboards/django/templates/login.html +30 -0
- package/dashboards/django/templates/messages.html +38 -0
- package/dashboards/django/templates/settings.html +472 -0
- package/dashboards/django/templates/skills.html +66 -0
- package/dashboards/django/templates/users.html +34 -0
- package/dashboards/django/templates/vault.html +46 -0
- package/dashboards/django/utils/__init__.py +0 -0
- package/dashboards/django/utils/api.py +20 -0
- package/dashboards/django/utils/helpers.py +39 -0
- package/dashboards/django/views/__init__.py +38 -0
- package/dashboards/django/views/agents.py +343 -0
- package/dashboards/django/views/api_keys.py +47 -0
- package/dashboards/django/views/audit.py +35 -0
- package/dashboards/django/views/auth.py +34 -0
- package/dashboards/django/views/compliance.py +37 -0
- package/dashboards/django/views/dashboard.py +27 -0
- package/dashboards/django/views/dlp.py +53 -0
- package/dashboards/django/views/guardrails.py +61 -0
- package/dashboards/django/views/journal.py +41 -0
- package/dashboards/django/views/messages.py +65 -0
- package/dashboards/django/views/settings_view.py +335 -0
- package/dashboards/django/views/skills.py +50 -0
- package/dashboards/django/views/users.py +42 -0
- package/dashboards/django/views/vault.py +50 -0
- package/dashboards/dotnet/AgenticMailDashboard.csproj +10 -0
- package/dashboards/dotnet/Program.cs +53 -233
- package/dashboards/dotnet/Routes/AgentRoutes.cs +771 -0
- package/dashboards/dotnet/Routes/ApiKeyRoutes.cs +185 -0
- package/dashboards/dotnet/Routes/AuditRoutes.cs +86 -0
- package/dashboards/dotnet/Routes/AuthRoutes.cs +50 -0
- package/dashboards/dotnet/Routes/ComplianceRoutes.cs +143 -0
- package/dashboards/dotnet/Routes/DashboardRoutes.cs +81 -0
- package/dashboards/dotnet/Routes/DlpRoutes.cs +230 -0
- package/dashboards/dotnet/Routes/GuardrailRoutes.cs +285 -0
- package/dashboards/dotnet/Routes/JournalRoutes.cs +118 -0
- package/dashboards/dotnet/Routes/MessageRoutes.cs +167 -0
- package/dashboards/dotnet/Routes/SettingRoutes.cs +907 -0
- package/dashboards/dotnet/Routes/SkillRoutes.cs +198 -0
- package/dashboards/dotnet/Routes/UserRoutes.cs +111 -0
- package/dashboards/dotnet/Routes/VaultRoutes.cs +162 -0
- package/dashboards/dotnet/Services/ApiClient.cs +103 -0
- package/dashboards/dotnet/Services/HtmlBuilder.cs +249 -0
- package/dashboards/dotnet/wwwroot/styles.css +284 -0
- package/dashboards/express/app.js +37 -126
- package/dashboards/express/middleware/auth.js +10 -0
- package/dashboards/express/package-lock.json +922 -0
- package/dashboards/express/package.json +17 -0
- package/dashboards/express/public/styles.css +284 -0
- package/dashboards/express/routes/agents.js +771 -0
- package/dashboards/express/routes/apiKeys.js +107 -0
- package/dashboards/express/routes/audit.js +75 -0
- package/dashboards/express/routes/auth.js +38 -0
- package/dashboards/express/routes/compliance.js +93 -0
- package/dashboards/express/routes/dashboard.js +65 -0
- package/dashboards/express/routes/dlp.js +165 -0
- package/dashboards/express/routes/guardrails.js +195 -0
- package/dashboards/express/routes/journal.js +95 -0
- package/dashboards/express/routes/messages.js +97 -0
- package/dashboards/express/routes/settings.js +830 -0
- package/dashboards/express/routes/skills.js +141 -0
- package/dashboards/express/routes/users.js +69 -0
- package/dashboards/express/routes/vault.js +141 -0
- package/dashboards/express/utils/api.js +44 -0
- package/dashboards/express/utils/helpers.js +46 -0
- package/dashboards/express/views/components/modal.js +255 -0
- package/dashboards/express/views/components/stats.js +22 -0
- package/dashboards/express/views/components/table.js +31 -0
- package/dashboards/express/views/layout.js +73 -0
- package/dashboards/express/views/login.js +45 -0
- package/dashboards/go/go.mod +3 -0
- package/dashboards/go/handlers/agents.go +790 -0
- package/dashboards/go/handlers/apikeys.go +38 -0
- package/dashboards/go/handlers/audit.go +52 -0
- package/dashboards/go/handlers/auth.go +39 -0
- package/dashboards/go/handlers/compliance.go +58 -0
- package/dashboards/go/handlers/dashboard.go +43 -0
- package/dashboards/go/handlers/dlp.go +78 -0
- package/dashboards/go/handlers/guardrails.go +89 -0
- package/dashboards/go/handlers/journal.go +60 -0
- package/dashboards/go/handlers/messages.go +59 -0
- package/dashboards/go/handlers/settings.go +951 -0
- package/dashboards/go/handlers/skills.go +129 -0
- package/dashboards/go/handlers/users.go +54 -0
- package/dashboards/go/handlers/vault.go +85 -0
- package/dashboards/go/main.go +35 -485
- package/dashboards/go/middleware/auth.go +17 -0
- package/dashboards/go/services/api.go +38 -0
- package/dashboards/go/services/session.go +52 -0
- package/dashboards/go/static/styles.css +284 -0
- package/dashboards/go/templates/components.go +45 -0
- package/dashboards/go/templates/helpers.go +35 -0
- package/dashboards/go/templates/layout.go +59 -0
- package/dashboards/html/index.html +203 -450
- package/dashboards/html/package.json +11 -0
- package/dashboards/html/public/styles.css +149 -0
- package/dashboards/html/src/api.js +36 -0
- package/dashboards/html/src/components/badge.js +13 -0
- package/dashboards/html/src/components/layout.js +11 -0
- package/dashboards/html/src/components/modal.js +9 -0
- package/dashboards/html/src/components/pagination.js +12 -0
- package/dashboards/html/src/components/stat-card.js +14 -0
- package/dashboards/html/src/components/table.js +6 -0
- package/dashboards/html/src/main.js +83 -0
- package/dashboards/html/src/pages/agents.js +831 -0
- package/dashboards/html/src/pages/api-keys.js +80 -0
- package/dashboards/html/src/pages/audit.js +50 -0
- package/dashboards/html/src/pages/compliance.js +69 -0
- package/dashboards/html/src/pages/dashboard.js +25 -0
- package/dashboards/html/src/pages/dlp.js +112 -0
- package/dashboards/html/src/pages/guardrails.js +127 -0
- package/dashboards/html/src/pages/journal.js +54 -0
- package/dashboards/html/src/pages/login.js +84 -0
- package/dashboards/html/src/pages/messages.js +90 -0
- package/dashboards/html/src/pages/settings.js +656 -0
- package/dashboards/html/src/pages/skills.js +114 -0
- package/dashboards/html/src/pages/users.js +62 -0
- package/dashboards/html/src/pages/vault.js +105 -0
- package/dashboards/html/src/router.js +40 -0
- package/dashboards/html/src/utils/escape.js +7 -0
- package/dashboards/html/src/utils/time.js +16 -0
- package/dashboards/html/src/utils/toast.js +10 -0
- package/dashboards/java/AgenticMailDashboard.java +123 -346
- package/dashboards/java/handlers/AgentsHandler.java +807 -0
- package/dashboards/java/handlers/ApiKeysHandler.java +201 -0
- package/dashboards/java/handlers/AuditHandler.java +95 -0
- package/dashboards/java/handlers/AuthHandler.java +71 -0
- package/dashboards/java/handlers/ComplianceHandler.java +192 -0
- package/dashboards/java/handlers/DashboardHandler.java +98 -0
- package/dashboards/java/handlers/DlpHandler.java +230 -0
- package/dashboards/java/handlers/GuardrailsHandler.java +272 -0
- package/dashboards/java/handlers/JournalHandler.java +130 -0
- package/dashboards/java/handlers/MessagesHandler.java +168 -0
- package/dashboards/java/handlers/SettingsHandler.java +1017 -0
- package/dashboards/java/handlers/SkillsHandler.java +198 -0
- package/dashboards/java/handlers/UsersHandler.java +118 -0
- package/dashboards/java/handlers/VaultHandler.java +168 -0
- package/dashboards/java/services/ApiClient.java +233 -0
- package/dashboards/java/services/SessionManager.java +138 -0
- package/dashboards/java/static/styles.css +288 -0
- package/dashboards/java/templates/Components.java +142 -0
- package/dashboards/java/templates/Helpers.java +106 -0
- package/dashboards/java/templates/Layout.java +98 -0
- package/dashboards/laravel/controllers/AgentController.php +250 -0
- package/dashboards/laravel/controllers/ApiKeyController.php +73 -0
- package/dashboards/laravel/controllers/AuditController.php +31 -0
- package/dashboards/laravel/controllers/AuthController.php +44 -0
- package/dashboards/laravel/controllers/ComplianceController.php +55 -0
- package/dashboards/laravel/controllers/DashboardController.php +28 -0
- package/dashboards/laravel/controllers/DlpController.php +88 -0
- package/dashboards/laravel/controllers/GuardrailController.php +110 -0
- package/dashboards/laravel/controllers/JournalController.php +44 -0
- package/dashboards/laravel/controllers/MessageController.php +47 -0
- package/dashboards/laravel/controllers/SettingController.php +258 -0
- package/dashboards/laravel/controllers/SkillController.php +74 -0
- package/dashboards/laravel/controllers/UserController.php +47 -0
- package/dashboards/laravel/controllers/VaultController.php +94 -0
- package/dashboards/laravel/index.php +319 -0
- package/dashboards/laravel/lib/Api.php +73 -0
- package/dashboards/laravel/lib/Helpers.php +123 -0
- package/dashboards/laravel/public/styles.css +291 -0
- package/dashboards/laravel/views/agent-detail.php +534 -0
- package/dashboards/laravel/views/agents.php +204 -0
- package/dashboards/laravel/views/api-keys.php +55 -0
- package/dashboards/laravel/views/audit.php +30 -0
- package/dashboards/laravel/views/compliance.php +48 -0
- package/dashboards/laravel/views/components/modal.php +59 -0
- package/dashboards/laravel/views/components/stats.php +21 -0
- package/dashboards/laravel/views/components/table.php +35 -0
- package/dashboards/laravel/views/dashboard.php +31 -0
- package/dashboards/laravel/views/dlp.php +87 -0
- package/dashboards/laravel/views/guardrails.php +95 -0
- package/dashboards/laravel/views/journal.php +50 -0
- package/dashboards/laravel/views/layout.php +82 -0
- package/dashboards/laravel/views/login.php +45 -0
- package/dashboards/laravel/views/messages.php +60 -0
- package/dashboards/laravel/views/settings.php +622 -0
- package/dashboards/laravel/views/skills.php +74 -0
- package/dashboards/laravel/views/users.php +42 -0
- package/dashboards/laravel/views/vault.php +80 -0
- package/dashboards/php/components/layout.php +80 -0
- package/dashboards/php/components/modal.php +22 -0
- package/dashboards/php/components/stats.php +20 -0
- package/dashboards/php/components/table.php +33 -0
- package/dashboards/php/index.php +663 -381
- package/dashboards/php/lib/api.php +37 -0
- package/dashboards/php/lib/auth.php +47 -0
- package/dashboards/php/lib/helpers.php +69 -0
- package/dashboards/php/pages/agent-detail.php +552 -0
- package/dashboards/php/pages/agents.php +185 -0
- package/dashboards/php/pages/api-keys.php +34 -0
- package/dashboards/php/pages/audit.php +31 -0
- package/dashboards/php/pages/compliance.php +38 -0
- package/dashboards/php/pages/dashboard.php +29 -0
- package/dashboards/php/pages/dlp.php +65 -0
- package/dashboards/php/pages/guardrails.php +70 -0
- package/dashboards/php/pages/journal.php +53 -0
- package/dashboards/php/pages/login.php +34 -0
- package/dashboards/php/pages/messages.php +53 -0
- package/dashboards/php/pages/settings.php +687 -0
- package/dashboards/php/pages/skills.php +70 -0
- package/dashboards/php/pages/users.php +37 -0
- package/dashboards/php/pages/vault.php +70 -0
- package/dashboards/php/public/styles.css +81 -0
- package/dashboards/python/app.py +61 -259
- package/dashboards/python/routes/__init__.py +0 -0
- package/dashboards/python/routes/agents.py +296 -0
- package/dashboards/python/routes/api_keys.py +49 -0
- package/dashboards/python/routes/audit.py +33 -0
- package/dashboards/python/routes/auth.py +30 -0
- package/dashboards/python/routes/compliance.py +50 -0
- package/dashboards/python/routes/dashboard.py +32 -0
- package/dashboards/python/routes/dlp.py +64 -0
- package/dashboards/python/routes/guardrails.py +79 -0
- package/dashboards/python/routes/journal.py +40 -0
- package/dashboards/python/routes/messages.py +46 -0
- package/dashboards/python/routes/settings.py +260 -0
- package/dashboards/python/routes/skills.py +59 -0
- package/dashboards/python/routes/users.py +43 -0
- package/dashboards/python/routes/vault.py +59 -0
- package/dashboards/python/static/styles.css +288 -0
- package/dashboards/python/templates/agent_detail.html +552 -0
- package/dashboards/python/templates/agents.html +246 -0
- package/dashboards/python/templates/api_keys.html +64 -0
- package/dashboards/python/templates/audit.html +50 -0
- package/dashboards/python/templates/compliance.html +74 -0
- package/dashboards/python/templates/components/modal.html +43 -0
- package/dashboards/python/templates/components/stats.html +26 -0
- package/dashboards/python/templates/components/table.html +43 -0
- package/dashboards/python/templates/dashboard.html +34 -0
- package/dashboards/python/templates/dlp.html +159 -0
- package/dashboards/python/templates/guardrails.html +131 -0
- package/dashboards/python/templates/journal.html +66 -0
- package/dashboards/python/templates/layout.html +86 -0
- package/dashboards/python/templates/login.html +36 -0
- package/dashboards/python/templates/messages.html +90 -0
- package/dashboards/python/templates/settings.html +624 -0
- package/dashboards/python/templates/skills.html +89 -0
- package/dashboards/python/templates/users.html +70 -0
- package/dashboards/python/templates/vault.html +73 -0
- package/dashboards/python/utils/__init__.py +0 -0
- package/dashboards/python/utils/api.py +35 -0
- package/dashboards/python/utils/helpers.py +90 -0
- package/dashboards/rails/app.rb +56 -0
- package/dashboards/rails/helpers/api.rb +39 -0
- package/dashboards/rails/helpers/auth.rb +11 -0
- package/dashboards/rails/helpers/view.rb +95 -0
- package/dashboards/rails/public/styles.css +299 -0
- package/dashboards/rails/routes/agents.rb +173 -0
- package/dashboards/rails/routes/api_keys.rb +30 -0
- package/dashboards/rails/routes/audit.rb +15 -0
- package/dashboards/rails/routes/auth.rb +29 -0
- package/dashboards/rails/routes/compliance.rb +25 -0
- package/dashboards/rails/routes/dashboard.rb +13 -0
- package/dashboards/rails/routes/dlp.rb +40 -0
- package/dashboards/rails/routes/guardrails.rb +51 -0
- package/dashboards/rails/routes/journal.rb +24 -0
- package/dashboards/rails/routes/messages.rb +22 -0
- package/dashboards/rails/routes/settings.rb +196 -0
- package/dashboards/rails/routes/skills.rb +38 -0
- package/dashboards/rails/routes/users.rb +18 -0
- package/dashboards/rails/routes/vault.rb +37 -0
- package/dashboards/rails/views/agent_detail.erb +550 -0
- package/dashboards/rails/views/agents.erb +214 -0
- package/dashboards/rails/views/api_keys.erb +52 -0
- package/dashboards/rails/views/audit.erb +38 -0
- package/dashboards/rails/views/compliance.erb +69 -0
- package/dashboards/rails/views/dashboard.erb +46 -0
- package/dashboards/rails/views/dlp.erb +104 -0
- package/dashboards/rails/views/guardrails.erb +107 -0
- package/dashboards/rails/views/journal.erb +65 -0
- package/dashboards/rails/views/layout.erb +53 -0
- package/dashboards/rails/views/login.erb +47 -0
- package/dashboards/rails/views/messages.erb +62 -0
- package/dashboards/rails/views/settings.erb +578 -0
- package/dashboards/rails/views/skills.erb +66 -0
- package/dashboards/rails/views/users.erb +53 -0
- package/dashboards/rails/views/vault.erb +66 -0
- package/dashboards/ruby/app.rb +53 -182
- package/dashboards/ruby/helpers/api.rb +63 -0
- package/dashboards/ruby/helpers/auth.rb +20 -0
- package/dashboards/ruby/helpers/view.rb +91 -0
- package/dashboards/ruby/public/styles.css +294 -0
- package/dashboards/ruby/routes/agents.rb +197 -0
- package/dashboards/ruby/routes/api_keys.rb +43 -0
- package/dashboards/ruby/routes/audit.rb +15 -0
- package/dashboards/ruby/routes/auth.rb +29 -0
- package/dashboards/ruby/routes/compliance.rb +28 -0
- package/dashboards/ruby/routes/dashboard.rb +13 -0
- package/dashboards/ruby/routes/dlp.rb +55 -0
- package/dashboards/ruby/routes/guardrails.rb +77 -0
- package/dashboards/ruby/routes/journal.rb +24 -0
- package/dashboards/ruby/routes/messages.rb +27 -0
- package/dashboards/ruby/routes/settings.rb +214 -0
- package/dashboards/ruby/routes/skills.rb +50 -0
- package/dashboards/ruby/routes/users.rb +26 -0
- package/dashboards/ruby/routes/vault.rb +49 -0
- package/dashboards/ruby/views/agent_detail.erb +550 -0
- package/dashboards/ruby/views/agents.erb +214 -0
- package/dashboards/ruby/views/api_keys.erb +59 -0
- package/dashboards/ruby/views/audit.erb +38 -0
- package/dashboards/ruby/views/compliance.erb +45 -0
- package/dashboards/ruby/views/dashboard.erb +46 -0
- package/dashboards/ruby/views/dlp.erb +88 -0
- package/dashboards/ruby/views/guardrails.erb +103 -0
- package/dashboards/ruby/views/journal.erb +53 -0
- package/dashboards/ruby/views/layout.erb +52 -0
- package/dashboards/ruby/views/login.erb +31 -0
- package/dashboards/ruby/views/messages.erb +51 -0
- package/dashboards/ruby/views/settings.erb +579 -0
- package/dashboards/ruby/views/skills.erb +66 -0
- package/dashboards/ruby/views/users.erb +53 -0
- package/dashboards/ruby/views/vault.erb +66 -0
- package/dashboards/shared/styles.css +322 -0
- package/dist/{chunk-TVF23PUW.js → chunk-7FVRYOP4.js} +22 -7
- package/dist/chunk-DRXMYYKN.js +79 -0
- package/dist/chunk-E23VJ3QX.js +9427 -0
- package/dist/chunk-EOBN6RCA.js +12652 -0
- package/dist/chunk-FLRYMSKY.js +23 -0
- package/dist/chunk-HAUHDCUB.js +764 -0
- package/dist/chunk-HSF6OJ5Z.js +154 -0
- package/dist/{chunk-PNKVD2UK.js → chunk-KFQGP6VL.js} +7 -0
- package/dist/chunk-LKAFZ343.js +591 -0
- package/dist/{chunk-GXIEEA2T.js → chunk-NTVN3JHS.js} +10 -10
- package/dist/chunk-RO537U6H.js +70 -0
- package/dist/chunk-SGBTJHEF.js +2287 -0
- package/dist/chunk-SMUXH6FM.js +1943 -0
- package/dist/chunk-TY7NVD4U.js +275 -0
- package/dist/chunk-X6UVWFHW.js +3455 -0
- package/dist/{chunk-7RGCCHIT.js → chunk-XMDE2NGH.js} +2 -1
- package/dist/chunk-ZNR5DDTA.js +239 -0
- package/dist/cidr-LISVZSM2.js +17 -0
- package/dist/cli-build-skill-XOYECCLE.js +235 -0
- package/dist/cli-recover-SSGGSKZJ.js +97 -0
- package/dist/cli-submit-skill-RSBLF5XN.js +162 -0
- package/dist/cli-validate-WJBUOEGW.js +148 -0
- package/dist/cli-verify-V3GPFMWU.js +98 -0
- package/dist/cli.js +50 -376
- package/dist/config-store-CRMKWBON.js +58 -0
- package/dist/dashboard/app.js +246 -0
- package/dist/dashboard/assets/logo.png +0 -0
- package/dist/dashboard/components/error-boundary.js +21 -0
- package/dist/dashboard/components/help-button.js +34 -0
- package/dist/dashboard/components/icons.js +53 -0
- package/dist/dashboard/components/modal.js +124 -0
- package/dist/dashboard/components/persona-fields.js +271 -0
- package/dist/dashboard/components/settings-help.js +191 -0
- package/dist/dashboard/components/tag-input.js +96 -0
- package/dist/dashboard/components/utils.js +148 -0
- package/dist/dashboard/index.html +407 -874
- package/dist/dashboard/pages/activity.js +62 -0
- package/dist/dashboard/pages/agent-detail.js +3577 -0
- package/dist/dashboard/pages/agents.js +1072 -0
- package/dist/dashboard/pages/approvals.js +81 -0
- package/dist/dashboard/pages/audit.js +133 -0
- package/dist/dashboard/pages/community-skills.js +665 -0
- package/dist/dashboard/pages/compliance.js +81 -0
- package/dist/dashboard/pages/dashboard.js +150 -0
- package/dist/dashboard/pages/dlp.js +107 -0
- package/dist/dashboard/pages/domain-status.js +123 -0
- package/dist/dashboard/pages/guardrails.js +995 -0
- package/dist/dashboard/pages/journal.js +51 -0
- package/dist/dashboard/pages/knowledge-contributions.js +763 -0
- package/dist/dashboard/pages/knowledge.js +46 -0
- package/dist/dashboard/pages/login.js +491 -0
- package/dist/dashboard/pages/messages.js +274 -0
- package/dist/dashboard/pages/settings.js +1554 -0
- package/dist/dashboard/pages/skill-connections.js +452 -0
- package/dist/dashboard/pages/skills.js +433 -0
- package/dist/dashboard/pages/users.js +49 -0
- package/dist/dashboard/pages/vault.js +538 -0
- package/dist/dashboard/pages/workforce.js +569 -0
- package/dist/dashboard/vendor/react-dom.production.min.js +267 -0
- package/dist/dashboard/vendor/react.production.min.js +31 -0
- package/dist/db-adapter-5PWMLY67.js +7 -0
- package/dist/domain-lock-URIFILHB.js +7 -0
- package/dist/{dynamodb-CCGL2E77.js → dynamodb-CD3LREWD.js} +4 -4
- package/dist/{factory-HINWFYZ3.js → factory-FVJH5RRY.js} +2 -2
- package/dist/firewall-AHIRE6UB.js +10 -0
- package/dist/index.js +133 -448
- package/dist/{managed-RZITNPXG.js → managed-QVTONZ7E.js} +4 -2
- package/dist/{mongodb-ODTXIVPV.js → mongodb-73MGW7LD.js} +4 -4
- package/dist/{mysql-RM3S2FV5.js → mysql-A2RYNBQG.js} +59 -6
- package/dist/{postgres-LN7A6MGQ.js → postgres-OE23X46P.js} +63 -6
- package/dist/registry/cli.js +411 -0
- package/dist/routes-NJK5OI5N.js +5673 -0
- package/dist/runtime-SMA6JUMP.js +46 -0
- package/dist/server-ZT5NWHT4.js +11 -0
- package/dist/setup-RCYNX5NA.js +20 -0
- package/dist/skills-QNR3CCHA.js +14 -0
- package/dist/soul-templates.json +1525 -0
- package/dist/{sqlite-VLKVAJA4.js → sqlite-SFVNZPHX.js} +56 -8
- package/dist/{turso-LDWODSDI.js → turso-L6WQAY7U.js} +59 -6
- package/live-test.mjs +1 -1
- package/package.json +11 -10
- package/schemas/agenticmail-skill.v1.schema.json +180 -0
- package/serve.mjs +12 -2
- package/src/admin/routes.ts +536 -5
- package/src/agent-tools/common.ts +232 -0
- package/src/agent-tools/index.ts +246 -0
- package/src/agent-tools/merge.ts +62 -0
- package/src/agent-tools/middleware.ts +436 -0
- package/src/agent-tools/security.ts +352 -0
- package/src/agent-tools/tools/bash.ts +154 -0
- package/src/agent-tools/tools/browser.ts +236 -0
- package/src/agent-tools/tools/edit.ts +100 -0
- package/src/agent-tools/tools/enterprise-calendar.ts +561 -0
- package/src/agent-tools/tools/enterprise-code-sandbox.ts +395 -0
- package/src/agent-tools/tools/enterprise-database.ts +377 -0
- package/src/agent-tools/tools/enterprise-diff.ts +580 -0
- package/src/agent-tools/tools/enterprise-documents.ts +896 -0
- package/src/agent-tools/tools/enterprise-finance.ts +484 -0
- package/src/agent-tools/tools/enterprise-http.ts +477 -0
- package/src/agent-tools/tools/enterprise-knowledge-search.ts +369 -0
- package/src/agent-tools/tools/enterprise-logs.ts +479 -0
- package/src/agent-tools/tools/enterprise-notifications.ts +532 -0
- package/src/agent-tools/tools/enterprise-security-scan.ts +528 -0
- package/src/agent-tools/tools/enterprise-spreadsheet.ts +825 -0
- package/src/agent-tools/tools/enterprise-translation.ts +530 -0
- package/src/agent-tools/tools/enterprise-vision.ts +348 -0
- package/src/agent-tools/tools/enterprise-web-research.ts +422 -0
- package/src/agent-tools/tools/enterprise-workflow.ts +308 -0
- package/src/agent-tools/tools/glob.ts +129 -0
- package/src/agent-tools/tools/grep.ts +178 -0
- package/src/agent-tools/tools/memory.ts +194 -0
- package/src/agent-tools/tools/read.ts +160 -0
- package/src/agent-tools/tools/web-fetch-utils.ts +202 -0
- package/src/agent-tools/tools/web-fetch.ts +456 -0
- package/src/agent-tools/tools/web-search.ts +480 -0
- package/src/agent-tools/tools/web-shared.ts +232 -0
- package/src/agent-tools/tools/write.ts +68 -0
- package/src/agent-tools/types.ts +193 -0
- package/src/auth/routes.ts +916 -51
- package/src/cli.ts +74 -14
- package/src/dashboard/app.js +246 -0
- package/src/dashboard/assets/logo.png +0 -0
- package/src/dashboard/components/error-boundary.js +21 -0
- package/src/dashboard/components/help-button.js +34 -0
- package/src/dashboard/components/icons.js +53 -0
- package/src/dashboard/components/modal.js +124 -0
- package/src/dashboard/components/persona-fields.js +271 -0
- package/src/dashboard/components/settings-help.js +191 -0
- package/src/dashboard/components/tag-input.js +96 -0
- package/src/dashboard/components/utils.js +148 -0
- package/src/dashboard/index.html +407 -874
- package/src/dashboard/pages/activity.js +62 -0
- package/src/dashboard/pages/agent-detail.js +3577 -0
- package/src/dashboard/pages/agents.js +1072 -0
- package/src/dashboard/pages/approvals.js +81 -0
- package/src/dashboard/pages/audit.js +133 -0
- package/src/dashboard/pages/community-skills.js +665 -0
- package/src/dashboard/pages/compliance.js +81 -0
- package/src/dashboard/pages/dashboard.js +150 -0
- package/src/dashboard/pages/dlp.js +107 -0
- package/src/dashboard/pages/domain-status.js +123 -0
- package/src/dashboard/pages/guardrails.js +995 -0
- package/src/dashboard/pages/journal.js +51 -0
- package/src/dashboard/pages/knowledge-contributions.js +763 -0
- package/src/dashboard/pages/knowledge.js +46 -0
- package/src/dashboard/pages/login.js +491 -0
- package/src/dashboard/pages/messages.js +274 -0
- package/src/dashboard/pages/settings.js +1554 -0
- package/src/dashboard/pages/skill-connections.js +452 -0
- package/src/dashboard/pages/skills.js +433 -0
- package/src/dashboard/pages/users.js +49 -0
- package/src/dashboard/pages/vault.js +538 -0
- package/src/dashboard/pages/workforce.js +569 -0
- package/src/dashboard/vendor/react-dom.production.min.js +267 -0
- package/src/dashboard/vendor/react.production.min.js +31 -0
- package/src/db/adapter.ts +134 -1
- package/src/db/dynamodb.ts +2 -2
- package/src/db/mongodb.ts +2 -2
- package/src/db/mysql.ts +55 -1
- package/src/db/postgres.ts +59 -1
- package/src/db/proxy.ts +39 -0
- package/src/db/sql-schema.ts +2 -1
- package/src/db/sqlite.ts +51 -3
- package/src/db/turso.ts +55 -1
- package/src/deploy/fly.ts +2 -2
- package/src/deploy/managed.ts +32 -11
- package/src/domain-lock/cli-recover.ts +124 -0
- package/src/domain-lock/cli-verify.ts +122 -0
- package/src/domain-lock/index.ts +220 -0
- package/src/engine/activity-routes.ts +116 -0
- package/src/engine/activity.ts +62 -2
- package/src/engine/agent-config.ts +190 -24
- package/src/engine/agent-memory.ts +1062 -0
- package/src/engine/agent-routes.ts +379 -0
- package/src/engine/approvals.ts +309 -2
- package/src/engine/catalog-routes.ts +155 -0
- package/src/engine/cli-build-skill.ts +285 -0
- package/src/engine/cli-submit-skill.ts +200 -0
- package/src/engine/cli-validate.ts +188 -0
- package/src/engine/communication-routes.ts +139 -0
- package/src/engine/communication.ts +759 -0
- package/src/engine/community-registry.ts +1509 -0
- package/src/engine/community-routes.ts +233 -0
- package/src/engine/compliance-routes.ts +93 -0
- package/src/engine/compliance.ts +325 -0
- package/src/engine/db-adapter.ts +349 -1
- package/src/engine/db-schema.ts +971 -23
- package/src/engine/deploy-schema-routes.ts +176 -0
- package/src/engine/deployer.ts +6 -6
- package/src/engine/dlp-routes.ts +59 -0
- package/src/engine/dlp.ts +231 -0
- package/src/engine/guardrail-routes.ts +125 -0
- package/src/engine/guardrails.ts +403 -0
- package/src/engine/index.ts +131 -10
- package/src/engine/journal-routes.ts +56 -0
- package/src/engine/journal.ts +249 -0
- package/src/engine/knowledge-contribution-routes.ts +385 -0
- package/src/engine/knowledge-contribution.ts +1319 -0
- package/src/engine/knowledge-routes.ts +68 -0
- package/src/engine/knowledge.ts +73 -1
- package/src/engine/lifecycle.ts +487 -31
- package/src/engine/memory-routes.ts +142 -0
- package/src/engine/oauth-connect-routes.ts +366 -0
- package/src/engine/oauth-connect.ts +304 -0
- package/src/engine/onboarding-routes.ts +140 -0
- package/src/engine/onboarding.ts +574 -0
- package/src/engine/org-approval-routes.ts +146 -0
- package/src/engine/org-policies.ts +497 -0
- package/src/engine/policy-import-routes.ts +125 -0
- package/src/engine/policy-import.ts +1186 -0
- package/src/engine/policy-routes.ts +163 -0
- package/src/engine/routes.ts +239 -482
- package/src/engine/skill-updater-routes.ts +132 -0
- package/src/engine/skill-updater.ts +480 -0
- package/src/engine/skill-validator.ts +331 -0
- package/src/engine/skills/enterprise-calendar.ts +142 -0
- package/src/engine/skills/enterprise-code-sandbox.ts +112 -0
- package/src/engine/skills/enterprise-database.ts +122 -0
- package/src/engine/skills/enterprise-diff.ts +94 -0
- package/src/engine/skills/enterprise-documents.ts +161 -0
- package/src/engine/skills/enterprise-finance.ts +109 -0
- package/src/engine/skills/enterprise-http.ts +98 -0
- package/src/engine/skills/enterprise-knowledge-search.ts +106 -0
- package/src/engine/skills/enterprise-logs.ts +115 -0
- package/src/engine/skills/enterprise-notifications.ts +119 -0
- package/src/engine/skills/enterprise-security-scan.ts +124 -0
- package/src/engine/skills/enterprise-spreadsheet.ts +170 -0
- package/src/engine/skills/enterprise-translation.ts +111 -0
- package/src/engine/skills/enterprise-vision.ts +107 -0
- package/src/engine/skills/enterprise-web-research.ts +114 -0
- package/src/engine/skills/enterprise-workflow.ts +109 -0
- package/src/engine/skills/gws-admin.ts +17 -0
- package/src/engine/skills/gws-calendar.ts +19 -0
- package/src/engine/skills/gws-chat.ts +16 -0
- package/src/engine/skills/gws-docs.ts +17 -0
- package/src/engine/skills/gws-drive.ts +20 -0
- package/src/engine/skills/gws-forms.ts +16 -0
- package/src/engine/skills/gws-gmail.ts +20 -0
- package/src/engine/skills/gws-groups.ts +16 -0
- package/src/engine/skills/gws-keep.ts +16 -0
- package/src/engine/skills/gws-meet.ts +16 -0
- package/src/engine/skills/gws-sheets.ts +18 -0
- package/src/engine/skills/gws-sites.ts +15 -0
- package/src/engine/skills/gws-slides.ts +16 -0
- package/src/engine/skills/gws-vault.ts +16 -0
- package/src/engine/skills/index.ts +121 -0
- package/src/engine/skills/m365-admin.ts +17 -0
- package/src/engine/skills/m365-bookings.ts +16 -0
- package/src/engine/skills/m365-copilot.ts +16 -0
- package/src/engine/skills/m365-excel.ts +59 -0
- package/src/engine/skills/m365-forms.ts +16 -0
- package/src/engine/skills/m365-onedrive.ts +59 -0
- package/src/engine/skills/m365-onenote.ts +16 -0
- package/src/engine/skills/m365-outlook.ts +26 -0
- package/src/engine/skills/m365-planner.ts +17 -0
- package/src/engine/skills/m365-power-automate.ts +17 -0
- package/src/engine/skills/m365-power-bi.ts +18 -0
- package/src/engine/skills/m365-powerpoint.ts +32 -0
- package/src/engine/skills/m365-sharepoint.ts +19 -0
- package/src/engine/skills/m365-teams.ts +20 -0
- package/src/engine/skills/m365-todo.ts +16 -0
- package/src/engine/skills/m365-whiteboard.ts +15 -0
- package/src/engine/skills/m365-word.ts +41 -0
- package/src/engine/skills.ts +353 -17
- package/src/engine/soul-library.ts +142 -0
- package/src/engine/soul-templates.json +1525 -0
- package/src/engine/storage-manager.ts +252 -0
- package/src/engine/storage-routes.ts +113 -0
- package/src/engine/storage.ts +528 -0
- package/src/engine/tenant.ts +69 -5
- package/src/engine/tool-catalog.ts +177 -13
- package/src/engine/vault-routes.ts +130 -0
- package/src/engine/vault.ts +544 -0
- package/src/engine/workforce-routes.ts +282 -0
- package/src/engine/workforce.ts +957 -0
- package/src/index.ts +9 -1
- package/src/lib/cidr.ts +122 -0
- package/src/lib/config-store.ts +86 -0
- package/src/mcp/adapters/activecampaign.adapter.ts +391 -0
- package/src/mcp/adapters/adobe-sign.adapter.ts +469 -0
- package/src/mcp/adapters/adp.adapter.ts +358 -0
- package/src/mcp/adapters/airtable.adapter.ts +273 -0
- package/src/mcp/adapters/apollo.adapter.ts +420 -0
- package/src/mcp/adapters/asana.adapter.ts +315 -0
- package/src/mcp/adapters/auth0.adapter.ts +386 -0
- package/src/mcp/adapters/aws.adapter.ts +345 -0
- package/src/mcp/adapters/azure-devops.adapter.ts +389 -0
- package/src/mcp/adapters/bamboohr.adapter.ts +376 -0
- package/src/mcp/adapters/basecamp.adapter.ts +366 -0
- package/src/mcp/adapters/bigcommerce.adapter.ts +429 -0
- package/src/mcp/adapters/bitbucket.adapter.ts +260 -0
- package/src/mcp/adapters/box.adapter.ts +350 -0
- package/src/mcp/adapters/brex.adapter.ts +367 -0
- package/src/mcp/adapters/buffer.adapter.ts +303 -0
- package/src/mcp/adapters/calendly.adapter.ts +262 -0
- package/src/mcp/adapters/canva.adapter.ts +256 -0
- package/src/mcp/adapters/chargebee.adapter.ts +448 -0
- package/src/mcp/adapters/circleci.adapter.ts +216 -0
- package/src/mcp/adapters/clickup.adapter.ts +335 -0
- package/src/mcp/adapters/close.adapter.ts +390 -0
- package/src/mcp/adapters/cloudflare.adapter.ts +377 -0
- package/src/mcp/adapters/confluence.adapter.ts +301 -0
- package/src/mcp/adapters/contentful.adapter.ts +355 -0
- package/src/mcp/adapters/copper.adapter.ts +468 -0
- package/src/mcp/adapters/crisp.adapter.ts +415 -0
- package/src/mcp/adapters/crowdstrike.adapter.ts +413 -0
- package/src/mcp/adapters/datadog.adapter.ts +373 -0
- package/src/mcp/adapters/digitalocean.adapter.ts +336 -0
- package/src/mcp/adapters/discord.adapter.ts +248 -0
- package/src/mcp/adapters/docker.adapter.ts +238 -0
- package/src/mcp/adapters/docusign.adapter.ts +431 -0
- package/src/mcp/adapters/drift.adapter.ts +386 -0
- package/src/mcp/adapters/dropbox.adapter.ts +315 -0
- package/src/mcp/adapters/figma.adapter.ts +302 -0
- package/src/mcp/adapters/firebase.adapter.ts +446 -0
- package/src/mcp/adapters/flyio.adapter.ts +302 -0
- package/src/mcp/adapters/freshbooks.adapter.ts +474 -0
- package/src/mcp/adapters/freshdesk.adapter.ts +441 -0
- package/src/mcp/adapters/freshsales.adapter.ts +457 -0
- package/src/mcp/adapters/freshservice.adapter.ts +481 -0
- package/src/mcp/adapters/front.adapter.ts +357 -0
- package/src/mcp/adapters/github-actions.adapter.ts +329 -0
- package/src/mcp/adapters/github.adapter.ts +387 -0
- package/src/mcp/adapters/gitlab.adapter.ts +368 -0
- package/src/mcp/adapters/gong.adapter.ts +386 -0
- package/src/mcp/adapters/google-ads.adapter.ts +363 -0
- package/src/mcp/adapters/google-analytics.adapter.ts +316 -0
- package/src/mcp/adapters/google-cloud.adapter.ts +312 -0
- package/src/mcp/adapters/google-drive.adapter.ts +387 -0
- package/src/mcp/adapters/gotomeeting.adapter.ts +255 -0
- package/src/mcp/adapters/grafana.adapter.ts +361 -0
- package/src/mcp/adapters/greenhouse.adapter.ts +354 -0
- package/src/mcp/adapters/gusto.adapter.ts +329 -0
- package/src/mcp/adapters/hashicorp-vault.adapter.ts +355 -0
- package/src/mcp/adapters/heroku.adapter.ts +291 -0
- package/src/mcp/adapters/hibob.adapter.ts +334 -0
- package/src/mcp/adapters/hootsuite.adapter.ts +322 -0
- package/src/mcp/adapters/hubspot.adapter.ts +400 -0
- package/src/mcp/adapters/huggingface.adapter.ts +349 -0
- package/src/mcp/adapters/index.ts +530 -0
- package/src/mcp/adapters/intercom.adapter.ts +269 -0
- package/src/mcp/adapters/jira.adapter.ts +482 -0
- package/src/mcp/adapters/klaviyo.adapter.ts +353 -0
- package/src/mcp/adapters/kubernetes.adapter.ts +431 -0
- package/src/mcp/adapters/lattice.adapter.ts +339 -0
- package/src/mcp/adapters/launchdarkly.adapter.ts +368 -0
- package/src/mcp/adapters/lever.adapter.ts +347 -0
- package/src/mcp/adapters/linear.adapter.ts +300 -0
- package/src/mcp/adapters/linkedin.adapter.ts +331 -0
- package/src/mcp/adapters/livechat.adapter.ts +259 -0
- package/src/mcp/adapters/loom.adapter.ts +230 -0
- package/src/mcp/adapters/mailchimp.adapter.ts +394 -0
- package/src/mcp/adapters/mailgun.adapter.ts +425 -0
- package/src/mcp/adapters/microsoft-teams.adapter.ts +251 -0
- package/src/mcp/adapters/miro.adapter.ts +274 -0
- package/src/mcp/adapters/mixpanel.adapter.ts +324 -0
- package/src/mcp/adapters/monday.adapter.ts +308 -0
- package/src/mcp/adapters/mongodb-atlas.adapter.ts +345 -0
- package/src/mcp/adapters/neon.adapter.ts +312 -0
- package/src/mcp/adapters/netlify.adapter.ts +324 -0
- package/src/mcp/adapters/netsuite.adapter.ts +411 -0
- package/src/mcp/adapters/newrelic.adapter.ts +339 -0
- package/src/mcp/adapters/notion.adapter.ts +338 -0
- package/src/mcp/adapters/okta.adapter.ts +394 -0
- package/src/mcp/adapters/openai.adapter.ts +315 -0
- package/src/mcp/adapters/opsgenie.adapter.ts +375 -0
- package/src/mcp/adapters/outreach.adapter.ts +372 -0
- package/src/mcp/adapters/paddle.adapter.ts +467 -0
- package/src/mcp/adapters/pagerduty.adapter.ts +412 -0
- package/src/mcp/adapters/pandadoc.adapter.ts +389 -0
- package/src/mcp/adapters/paypal.adapter.ts +465 -0
- package/src/mcp/adapters/personio.adapter.ts +401 -0
- package/src/mcp/adapters/pinecone.adapter.ts +340 -0
- package/src/mcp/adapters/pipedrive.adapter.ts +324 -0
- package/src/mcp/adapters/plaid.adapter.ts +444 -0
- package/src/mcp/adapters/postmark.adapter.ts +387 -0
- package/src/mcp/adapters/power-automate.adapter.ts +388 -0
- package/src/mcp/adapters/quickbooks.adapter.ts +431 -0
- package/src/mcp/adapters/recurly.adapter.ts +433 -0
- package/src/mcp/adapters/reddit.adapter.ts +371 -0
- package/src/mcp/adapters/render.adapter.ts +332 -0
- package/src/mcp/adapters/ringcentral.adapter.ts +281 -0
- package/src/mcp/adapters/rippling.adapter.ts +287 -0
- package/src/mcp/adapters/salesforce.adapter.ts +321 -0
- package/src/mcp/adapters/salesloft.adapter.ts +413 -0
- package/src/mcp/adapters/sanity.adapter.ts +363 -0
- package/src/mcp/adapters/sap.adapter.ts +483 -0
- package/src/mcp/adapters/segment.adapter.ts +260 -0
- package/src/mcp/adapters/sendgrid.adapter.ts +265 -0
- package/src/mcp/adapters/sentry.adapter.ts +331 -0
- package/src/mcp/adapters/servicenow.adapter.ts +468 -0
- package/src/mcp/adapters/shopify.adapter.ts +451 -0
- package/src/mcp/adapters/shortcut.adapter.ts +290 -0
- package/src/mcp/adapters/slack.adapter.ts +380 -0
- package/src/mcp/adapters/smartsheet.adapter.ts +326 -0
- package/src/mcp/adapters/snowflake.adapter.ts +347 -0
- package/src/mcp/adapters/snyk.adapter.ts +394 -0
- package/src/mcp/adapters/splunk.adapter.ts +403 -0
- package/src/mcp/adapters/square.adapter.ts +467 -0
- package/src/mcp/adapters/statuspage.adapter.ts +401 -0
- package/src/mcp/adapters/stripe.adapter.ts +380 -0
- package/src/mcp/adapters/supabase.adapter.ts +334 -0
- package/src/mcp/adapters/teamwork.adapter.ts +404 -0
- package/src/mcp/adapters/telegram.adapter.ts +299 -0
- package/src/mcp/adapters/terraform.adapter.ts +300 -0
- package/src/mcp/adapters/todoist.adapter.ts +239 -0
- package/src/mcp/adapters/trello.adapter.ts +316 -0
- package/src/mcp/adapters/twilio.adapter.ts +233 -0
- package/src/mcp/adapters/twitter.adapter.ts +348 -0
- package/src/mcp/adapters/vercel.adapter.ts +219 -0
- package/src/mcp/adapters/weaviate.adapter.ts +371 -0
- package/src/mcp/adapters/webex.adapter.ts +237 -0
- package/src/mcp/adapters/webflow.adapter.ts +287 -0
- package/src/mcp/adapters/whatsapp.adapter.ts +273 -0
- package/src/mcp/adapters/whereby.adapter.ts +240 -0
- package/src/mcp/adapters/woocommerce.adapter.ts +454 -0
- package/src/mcp/adapters/wordpress.adapter.ts +455 -0
- package/src/mcp/adapters/workday.adapter.ts +354 -0
- package/src/mcp/adapters/wrike.adapter.ts +349 -0
- package/src/mcp/adapters/xero.adapter.ts +472 -0
- package/src/mcp/adapters/youtube.adapter.ts +401 -0
- package/src/mcp/adapters/zendesk.adapter.ts +399 -0
- package/src/mcp/adapters/zoho-crm.adapter.ts +410 -0
- package/src/mcp/adapters/zoom.adapter.ts +241 -0
- package/src/mcp/adapters/zuora.adapter.ts +476 -0
- package/src/mcp/framework/api-executor.ts +192 -0
- package/src/mcp/framework/aws-sigv4.ts +216 -0
- package/src/mcp/framework/credential-resolver.ts +128 -0
- package/src/mcp/framework/skill-mcp-framework.ts +226 -0
- package/src/mcp/framework/types.ts +130 -0
- package/src/mcp/index.ts +124 -0
- package/src/middleware/egress-filter.ts +81 -0
- package/src/middleware/firewall.ts +121 -0
- package/src/middleware/index.ts +33 -0
- package/src/registry/cli.ts +63 -0
- package/src/registry/server.ts +504 -0
- package/src/runtime/agent-loop.ts +504 -0
- package/src/runtime/email-channel.ts +120 -0
- package/src/runtime/followup.ts +211 -0
- package/src/runtime/gateway.ts +260 -0
- package/src/runtime/hooks.ts +472 -0
- package/src/runtime/index.ts +679 -0
- package/src/runtime/llm-client.ts +1019 -0
- package/src/runtime/providers.ts +231 -0
- package/src/runtime/session-manager.ts +340 -0
- package/src/runtime/subagent.ts +154 -0
- package/src/runtime/tool-executor.ts +202 -0
- package/src/runtime/types.ts +215 -0
- package/src/server.ts +157 -45
- package/src/setup/company.ts +127 -8
- package/src/setup/database.ts +2 -1
- package/src/setup/domain.ts +33 -4
- package/src/setup/index.ts +19 -7
- package/src/setup/provision.ts +128 -8
- package/src/setup/registration.ts +227 -0
- package/src/types/hono-env.ts +14 -0
- package/src/types/optional-deps.d.ts +10 -0
- package/start-live.mjs +12 -3
- package/test-integration.mjs +628 -257
- package/dist/chunk-77IDQJL3.js +0 -7
- package/dist/chunk-BE7MXVLA.js +0 -757
- package/dist/chunk-BS2WCSHO.js +0 -48
- package/dist/chunk-FL3VQBGL.js +0 -757
- package/dist/chunk-IQWA44WT.js +0 -970
- package/dist/chunk-N2JVTNNJ.js +0 -2553
- package/dist/chunk-YFDSE4BW.js +0 -1355
- package/dist/db-adapter-DEWEFNIV.js +0 -7
- package/dist/factory-V37IG5AT.js +0 -9
- package/dist/routes-2JEPIIKC.js +0 -441
- package/dist/server-32YYCI3A.js +0 -8
- package/dist/server-H3C6WUOS.js +0 -8
- package/dist/sqlite-3K5YOZ4K.js +0 -439
- package/src/engine/agenticmail-bridge.ts +0 -296
- package/src/engine/openclaw-hook.ts +0 -371
|
@@ -0,0 +1,2287 @@
|
|
|
1
|
+
// src/engine/db-schema.ts
|
|
2
|
+
var ENGINE_TABLES = `
|
|
3
|
+
-- Managed agents (the deployed AI employees)
|
|
4
|
+
CREATE TABLE IF NOT EXISTS managed_agents (
|
|
5
|
+
id TEXT PRIMARY KEY,
|
|
6
|
+
org_id TEXT NOT NULL,
|
|
7
|
+
name TEXT NOT NULL,
|
|
8
|
+
display_name TEXT NOT NULL,
|
|
9
|
+
state TEXT NOT NULL DEFAULT 'draft',
|
|
10
|
+
config JSON NOT NULL,
|
|
11
|
+
health JSON NOT NULL DEFAULT '{}',
|
|
12
|
+
usage JSON NOT NULL DEFAULT '{}',
|
|
13
|
+
permission_profile_id TEXT,
|
|
14
|
+
version INTEGER NOT NULL DEFAULT 1,
|
|
15
|
+
last_deployed_at TEXT,
|
|
16
|
+
last_health_check_at TEXT,
|
|
17
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
18
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
19
|
+
);
|
|
20
|
+
CREATE INDEX IF NOT EXISTS idx_managed_agents_org ON managed_agents(org_id);
|
|
21
|
+
CREATE INDEX IF NOT EXISTS idx_managed_agents_state ON managed_agents(state);
|
|
22
|
+
|
|
23
|
+
-- State transition history
|
|
24
|
+
CREATE TABLE IF NOT EXISTS agent_state_history (
|
|
25
|
+
id TEXT PRIMARY KEY,
|
|
26
|
+
agent_id TEXT NOT NULL,
|
|
27
|
+
from_state TEXT NOT NULL,
|
|
28
|
+
to_state TEXT NOT NULL,
|
|
29
|
+
reason TEXT NOT NULL,
|
|
30
|
+
triggered_by TEXT NOT NULL,
|
|
31
|
+
error TEXT,
|
|
32
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
33
|
+
FOREIGN KEY (agent_id) REFERENCES managed_agents(id) ON DELETE CASCADE
|
|
34
|
+
);
|
|
35
|
+
CREATE INDEX IF NOT EXISTS idx_state_history_agent ON agent_state_history(agent_id);
|
|
36
|
+
CREATE INDEX IF NOT EXISTS idx_state_history_time ON agent_state_history(created_at);
|
|
37
|
+
|
|
38
|
+
-- Permission profiles
|
|
39
|
+
CREATE TABLE IF NOT EXISTS permission_profiles (
|
|
40
|
+
id TEXT PRIMARY KEY,
|
|
41
|
+
org_id TEXT NOT NULL,
|
|
42
|
+
name TEXT NOT NULL,
|
|
43
|
+
description TEXT,
|
|
44
|
+
config JSON NOT NULL,
|
|
45
|
+
is_preset INTEGER NOT NULL DEFAULT 0,
|
|
46
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
47
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
48
|
+
);
|
|
49
|
+
CREATE INDEX IF NOT EXISTS idx_permission_profiles_org ON permission_profiles(org_id);
|
|
50
|
+
|
|
51
|
+
-- Organizations (tenants)
|
|
52
|
+
CREATE TABLE IF NOT EXISTS organizations (
|
|
53
|
+
id TEXT PRIMARY KEY,
|
|
54
|
+
name TEXT NOT NULL,
|
|
55
|
+
slug TEXT NOT NULL UNIQUE,
|
|
56
|
+
plan TEXT NOT NULL DEFAULT 'free',
|
|
57
|
+
limits JSON NOT NULL DEFAULT '{}',
|
|
58
|
+
usage JSON NOT NULL DEFAULT '{}',
|
|
59
|
+
settings JSON NOT NULL DEFAULT '{}',
|
|
60
|
+
sso_config JSON,
|
|
61
|
+
allowed_domains JSON NOT NULL DEFAULT '[]',
|
|
62
|
+
billing JSON,
|
|
63
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
64
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
65
|
+
);
|
|
66
|
+
CREATE UNIQUE INDEX IF NOT EXISTS idx_organizations_slug ON organizations(slug);
|
|
67
|
+
|
|
68
|
+
-- Knowledge bases
|
|
69
|
+
CREATE TABLE IF NOT EXISTS knowledge_bases (
|
|
70
|
+
id TEXT PRIMARY KEY,
|
|
71
|
+
org_id TEXT NOT NULL,
|
|
72
|
+
name TEXT NOT NULL,
|
|
73
|
+
description TEXT,
|
|
74
|
+
agent_ids JSON NOT NULL DEFAULT '[]',
|
|
75
|
+
config JSON NOT NULL DEFAULT '{}',
|
|
76
|
+
stats JSON NOT NULL DEFAULT '{}',
|
|
77
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
78
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
79
|
+
);
|
|
80
|
+
CREATE INDEX IF NOT EXISTS idx_knowledge_bases_org ON knowledge_bases(org_id);
|
|
81
|
+
|
|
82
|
+
-- Knowledge base documents
|
|
83
|
+
CREATE TABLE IF NOT EXISTS kb_documents (
|
|
84
|
+
id TEXT PRIMARY KEY,
|
|
85
|
+
knowledge_base_id TEXT NOT NULL,
|
|
86
|
+
name TEXT NOT NULL,
|
|
87
|
+
source_type TEXT NOT NULL,
|
|
88
|
+
source_url TEXT,
|
|
89
|
+
mime_type TEXT NOT NULL DEFAULT 'text/plain',
|
|
90
|
+
size INTEGER NOT NULL DEFAULT 0,
|
|
91
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
92
|
+
status TEXT NOT NULL DEFAULT 'processing',
|
|
93
|
+
error TEXT,
|
|
94
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
95
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
96
|
+
FOREIGN KEY (knowledge_base_id) REFERENCES knowledge_bases(id) ON DELETE CASCADE
|
|
97
|
+
);
|
|
98
|
+
CREATE INDEX IF NOT EXISTS idx_kb_documents_kb ON kb_documents(knowledge_base_id);
|
|
99
|
+
|
|
100
|
+
-- Knowledge base chunks (for RAG)
|
|
101
|
+
CREATE TABLE IF NOT EXISTS kb_chunks (
|
|
102
|
+
id TEXT PRIMARY KEY,
|
|
103
|
+
document_id TEXT NOT NULL,
|
|
104
|
+
content TEXT NOT NULL,
|
|
105
|
+
token_count INTEGER NOT NULL DEFAULT 0,
|
|
106
|
+
position INTEGER NOT NULL DEFAULT 0,
|
|
107
|
+
embedding BLOB,
|
|
108
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
109
|
+
FOREIGN KEY (document_id) REFERENCES kb_documents(id) ON DELETE CASCADE
|
|
110
|
+
);
|
|
111
|
+
CREATE INDEX IF NOT EXISTS idx_kb_chunks_doc ON kb_chunks(document_id);
|
|
112
|
+
|
|
113
|
+
-- Tool call records (activity tracking)
|
|
114
|
+
CREATE TABLE IF NOT EXISTS tool_calls (
|
|
115
|
+
id TEXT PRIMARY KEY,
|
|
116
|
+
agent_id TEXT NOT NULL,
|
|
117
|
+
org_id TEXT NOT NULL,
|
|
118
|
+
session_id TEXT,
|
|
119
|
+
tool_id TEXT NOT NULL,
|
|
120
|
+
tool_name TEXT NOT NULL,
|
|
121
|
+
parameters JSON,
|
|
122
|
+
result JSON,
|
|
123
|
+
timing JSON NOT NULL,
|
|
124
|
+
cost JSON,
|
|
125
|
+
permission JSON NOT NULL,
|
|
126
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
127
|
+
);
|
|
128
|
+
CREATE INDEX IF NOT EXISTS idx_tool_calls_agent ON tool_calls(agent_id);
|
|
129
|
+
CREATE INDEX IF NOT EXISTS idx_tool_calls_org ON tool_calls(org_id);
|
|
130
|
+
CREATE INDEX IF NOT EXISTS idx_tool_calls_time ON tool_calls(created_at);
|
|
131
|
+
CREATE INDEX IF NOT EXISTS idx_tool_calls_tool ON tool_calls(tool_id);
|
|
132
|
+
|
|
133
|
+
-- Activity events (real-time stream)
|
|
134
|
+
CREATE TABLE IF NOT EXISTS activity_events (
|
|
135
|
+
id TEXT PRIMARY KEY,
|
|
136
|
+
agent_id TEXT NOT NULL,
|
|
137
|
+
org_id TEXT NOT NULL,
|
|
138
|
+
session_id TEXT,
|
|
139
|
+
type TEXT NOT NULL,
|
|
140
|
+
data JSON NOT NULL DEFAULT '{}',
|
|
141
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
142
|
+
);
|
|
143
|
+
CREATE INDEX IF NOT EXISTS idx_activity_agent ON activity_events(agent_id);
|
|
144
|
+
CREATE INDEX IF NOT EXISTS idx_activity_org ON activity_events(org_id);
|
|
145
|
+
CREATE INDEX IF NOT EXISTS idx_activity_type ON activity_events(type);
|
|
146
|
+
CREATE INDEX IF NOT EXISTS idx_activity_time ON activity_events(created_at);
|
|
147
|
+
|
|
148
|
+
-- Conversation entries
|
|
149
|
+
CREATE TABLE IF NOT EXISTS conversations (
|
|
150
|
+
id TEXT PRIMARY KEY,
|
|
151
|
+
agent_id TEXT NOT NULL,
|
|
152
|
+
session_id TEXT NOT NULL,
|
|
153
|
+
role TEXT NOT NULL,
|
|
154
|
+
content TEXT NOT NULL,
|
|
155
|
+
channel TEXT,
|
|
156
|
+
token_count INTEGER NOT NULL DEFAULT 0,
|
|
157
|
+
tool_calls JSON,
|
|
158
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
159
|
+
);
|
|
160
|
+
CREATE INDEX IF NOT EXISTS idx_conversations_agent ON conversations(agent_id);
|
|
161
|
+
CREATE INDEX IF NOT EXISTS idx_conversations_session ON conversations(session_id);
|
|
162
|
+
|
|
163
|
+
-- Approval requests
|
|
164
|
+
CREATE TABLE IF NOT EXISTS approval_requests (
|
|
165
|
+
id TEXT PRIMARY KEY,
|
|
166
|
+
agent_id TEXT NOT NULL,
|
|
167
|
+
agent_name TEXT NOT NULL,
|
|
168
|
+
org_id TEXT NOT NULL,
|
|
169
|
+
tool_id TEXT NOT NULL,
|
|
170
|
+
tool_name TEXT NOT NULL,
|
|
171
|
+
reason TEXT NOT NULL,
|
|
172
|
+
risk_level TEXT NOT NULL,
|
|
173
|
+
side_effects JSON NOT NULL DEFAULT '[]',
|
|
174
|
+
parameters JSON,
|
|
175
|
+
context TEXT,
|
|
176
|
+
status TEXT NOT NULL DEFAULT 'pending',
|
|
177
|
+
decision JSON,
|
|
178
|
+
expires_at TEXT NOT NULL,
|
|
179
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
180
|
+
);
|
|
181
|
+
CREATE INDEX IF NOT EXISTS idx_approvals_org ON approval_requests(org_id);
|
|
182
|
+
CREATE INDEX IF NOT EXISTS idx_approvals_status ON approval_requests(status);
|
|
183
|
+
CREATE INDEX IF NOT EXISTS idx_approvals_agent ON approval_requests(agent_id);
|
|
184
|
+
|
|
185
|
+
-- Approval policies
|
|
186
|
+
CREATE TABLE IF NOT EXISTS approval_policies (
|
|
187
|
+
id TEXT PRIMARY KEY,
|
|
188
|
+
org_id TEXT NOT NULL,
|
|
189
|
+
name TEXT NOT NULL,
|
|
190
|
+
description TEXT,
|
|
191
|
+
triggers JSON NOT NULL,
|
|
192
|
+
approvers JSON NOT NULL,
|
|
193
|
+
timeout JSON NOT NULL,
|
|
194
|
+
notify JSON NOT NULL DEFAULT '{}',
|
|
195
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
196
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
197
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
198
|
+
);
|
|
199
|
+
CREATE INDEX IF NOT EXISTS idx_approval_policies_org ON approval_policies(org_id);
|
|
200
|
+
`;
|
|
201
|
+
var ENGINE_TABLES_POSTGRES = ENGINE_TABLES.replace(/JSON/g, "JSONB").replace(/INTEGER NOT NULL DEFAULT 0/g, "INTEGER NOT NULL DEFAULT 0").replace(/datetime\('now'\)/g, "NOW()").replace(/INTEGER NOT NULL DEFAULT 1/g, "BOOLEAN NOT NULL DEFAULT TRUE").replace(/is_preset INTEGER NOT NULL DEFAULT 0/g, "is_preset BOOLEAN NOT NULL DEFAULT FALSE");
|
|
202
|
+
var MIGRATIONS_TABLE = `
|
|
203
|
+
CREATE TABLE IF NOT EXISTS engine_migrations (
|
|
204
|
+
version INTEGER PRIMARY KEY,
|
|
205
|
+
name TEXT NOT NULL,
|
|
206
|
+
applied_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
207
|
+
);
|
|
208
|
+
`;
|
|
209
|
+
var MIGRATIONS_TABLE_POSTGRES = MIGRATIONS_TABLE.replace(/datetime\('now'\)/g, "NOW()");
|
|
210
|
+
var MIGRATIONS = [
|
|
211
|
+
{
|
|
212
|
+
version: 1,
|
|
213
|
+
name: "initial_schema",
|
|
214
|
+
sql: ENGINE_TABLES,
|
|
215
|
+
postgres: ENGINE_TABLES_POSTGRES
|
|
216
|
+
},
|
|
217
|
+
{
|
|
218
|
+
version: 2,
|
|
219
|
+
name: "sso_and_deploy_credentials",
|
|
220
|
+
sql: `
|
|
221
|
+
-- SSO integrations (SAML, OIDC configs per org)
|
|
222
|
+
CREATE TABLE IF NOT EXISTS sso_integrations (
|
|
223
|
+
id TEXT PRIMARY KEY,
|
|
224
|
+
org_id TEXT NOT NULL,
|
|
225
|
+
provider_type TEXT NOT NULL,
|
|
226
|
+
name TEXT NOT NULL,
|
|
227
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
228
|
+
config JSON NOT NULL DEFAULT '{}',
|
|
229
|
+
metadata_url TEXT,
|
|
230
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
231
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
232
|
+
);
|
|
233
|
+
CREATE INDEX IF NOT EXISTS idx_sso_org ON sso_integrations(org_id);
|
|
234
|
+
CREATE INDEX IF NOT EXISTS idx_sso_type ON sso_integrations(provider_type);
|
|
235
|
+
|
|
236
|
+
-- Deploy credentials (encrypted tokens for Docker/SSH/Fly/Railway)
|
|
237
|
+
CREATE TABLE IF NOT EXISTS deploy_credentials (
|
|
238
|
+
id TEXT PRIMARY KEY,
|
|
239
|
+
org_id TEXT NOT NULL,
|
|
240
|
+
name TEXT NOT NULL,
|
|
241
|
+
target_type TEXT NOT NULL,
|
|
242
|
+
config JSON NOT NULL DEFAULT '{}',
|
|
243
|
+
created_by TEXT NOT NULL,
|
|
244
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
245
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
246
|
+
);
|
|
247
|
+
CREATE INDEX IF NOT EXISTS idx_deploy_creds_org ON deploy_credentials(org_id);
|
|
248
|
+
CREATE INDEX IF NOT EXISTS idx_deploy_creds_type ON deploy_credentials(target_type);
|
|
249
|
+
|
|
250
|
+
-- OIDC state tracking (prevents replay attacks)
|
|
251
|
+
CREATE TABLE IF NOT EXISTS oidc_states (
|
|
252
|
+
state TEXT PRIMARY KEY,
|
|
253
|
+
provider_id TEXT NOT NULL,
|
|
254
|
+
redirect_uri TEXT,
|
|
255
|
+
nonce TEXT,
|
|
256
|
+
code_verifier TEXT,
|
|
257
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
258
|
+
expires_at TEXT NOT NULL
|
|
259
|
+
);
|
|
260
|
+
`,
|
|
261
|
+
postgres: `
|
|
262
|
+
CREATE TABLE IF NOT EXISTS sso_integrations (
|
|
263
|
+
id TEXT PRIMARY KEY,
|
|
264
|
+
org_id TEXT NOT NULL,
|
|
265
|
+
provider_type TEXT NOT NULL,
|
|
266
|
+
name TEXT NOT NULL,
|
|
267
|
+
enabled BOOLEAN NOT NULL DEFAULT TRUE,
|
|
268
|
+
config JSONB NOT NULL DEFAULT '{}',
|
|
269
|
+
metadata_url TEXT,
|
|
270
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
271
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
272
|
+
);
|
|
273
|
+
CREATE INDEX IF NOT EXISTS idx_sso_org ON sso_integrations(org_id);
|
|
274
|
+
CREATE INDEX IF NOT EXISTS idx_sso_type ON sso_integrations(provider_type);
|
|
275
|
+
|
|
276
|
+
CREATE TABLE IF NOT EXISTS deploy_credentials (
|
|
277
|
+
id TEXT PRIMARY KEY,
|
|
278
|
+
org_id TEXT NOT NULL,
|
|
279
|
+
name TEXT NOT NULL,
|
|
280
|
+
target_type TEXT NOT NULL,
|
|
281
|
+
config JSONB NOT NULL DEFAULT '{}',
|
|
282
|
+
created_by TEXT NOT NULL,
|
|
283
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
284
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
285
|
+
);
|
|
286
|
+
CREATE INDEX IF NOT EXISTS idx_deploy_creds_org ON deploy_credentials(org_id);
|
|
287
|
+
CREATE INDEX IF NOT EXISTS idx_deploy_creds_type ON deploy_credentials(target_type);
|
|
288
|
+
|
|
289
|
+
CREATE TABLE IF NOT EXISTS oidc_states (
|
|
290
|
+
state TEXT PRIMARY KEY,
|
|
291
|
+
provider_id TEXT NOT NULL,
|
|
292
|
+
redirect_uri TEXT,
|
|
293
|
+
nonce TEXT,
|
|
294
|
+
code_verifier TEXT,
|
|
295
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
296
|
+
expires_at TIMESTAMPTZ NOT NULL
|
|
297
|
+
);
|
|
298
|
+
`
|
|
299
|
+
},
|
|
300
|
+
{
|
|
301
|
+
version: 3,
|
|
302
|
+
name: "autonomous_employee_trust",
|
|
303
|
+
sql: `
|
|
304
|
+
-- Per-agent budget config (extends managed_agents)
|
|
305
|
+
ALTER TABLE managed_agents ADD COLUMN budget_config JSON DEFAULT '{}';
|
|
306
|
+
|
|
307
|
+
-- Budget alerts log
|
|
308
|
+
CREATE TABLE IF NOT EXISTS budget_alerts (
|
|
309
|
+
id TEXT PRIMARY KEY,
|
|
310
|
+
org_id TEXT NOT NULL,
|
|
311
|
+
agent_id TEXT NOT NULL,
|
|
312
|
+
alert_type TEXT NOT NULL,
|
|
313
|
+
budget_type TEXT NOT NULL,
|
|
314
|
+
current_value REAL NOT NULL,
|
|
315
|
+
limit_value REAL NOT NULL,
|
|
316
|
+
acknowledged INTEGER NOT NULL DEFAULT 0,
|
|
317
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
318
|
+
);
|
|
319
|
+
CREATE INDEX IF NOT EXISTS idx_budget_alerts_org ON budget_alerts(org_id);
|
|
320
|
+
CREATE INDEX IF NOT EXISTS idx_budget_alerts_agent ON budget_alerts(agent_id);
|
|
321
|
+
|
|
322
|
+
-- Escalation chains (multi-level approval workflows)
|
|
323
|
+
CREATE TABLE IF NOT EXISTS escalation_chains (
|
|
324
|
+
id TEXT PRIMARY KEY,
|
|
325
|
+
org_id TEXT NOT NULL,
|
|
326
|
+
name TEXT NOT NULL,
|
|
327
|
+
description TEXT,
|
|
328
|
+
levels JSON NOT NULL,
|
|
329
|
+
fallback_action TEXT NOT NULL DEFAULT 'deny',
|
|
330
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
331
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
332
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
333
|
+
);
|
|
334
|
+
CREATE INDEX IF NOT EXISTS idx_escalation_org ON escalation_chains(org_id);
|
|
335
|
+
|
|
336
|
+
-- Escalation tracking on approval requests
|
|
337
|
+
ALTER TABLE approval_requests ADD COLUMN escalation_chain_id TEXT;
|
|
338
|
+
ALTER TABLE approval_requests ADD COLUMN escalation_level INTEGER DEFAULT 0;
|
|
339
|
+
ALTER TABLE approval_requests ADD COLUMN escalation_history JSON DEFAULT '[]';
|
|
340
|
+
|
|
341
|
+
-- DLP rules
|
|
342
|
+
CREATE TABLE IF NOT EXISTS dlp_rules (
|
|
343
|
+
id TEXT PRIMARY KEY,
|
|
344
|
+
org_id TEXT NOT NULL,
|
|
345
|
+
name TEXT NOT NULL,
|
|
346
|
+
description TEXT,
|
|
347
|
+
pattern_type TEXT NOT NULL,
|
|
348
|
+
pattern TEXT NOT NULL,
|
|
349
|
+
action TEXT NOT NULL DEFAULT 'block',
|
|
350
|
+
applies_to TEXT NOT NULL DEFAULT 'both',
|
|
351
|
+
severity TEXT NOT NULL DEFAULT 'high',
|
|
352
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
353
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
354
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
355
|
+
);
|
|
356
|
+
CREATE INDEX IF NOT EXISTS idx_dlp_rules_org ON dlp_rules(org_id);
|
|
357
|
+
|
|
358
|
+
-- DLP violations log
|
|
359
|
+
CREATE TABLE IF NOT EXISTS dlp_violations (
|
|
360
|
+
id TEXT PRIMARY KEY,
|
|
361
|
+
org_id TEXT NOT NULL,
|
|
362
|
+
agent_id TEXT NOT NULL,
|
|
363
|
+
rule_id TEXT NOT NULL,
|
|
364
|
+
tool_id TEXT NOT NULL,
|
|
365
|
+
action_taken TEXT NOT NULL,
|
|
366
|
+
match_context TEXT,
|
|
367
|
+
direction TEXT NOT NULL,
|
|
368
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
369
|
+
);
|
|
370
|
+
CREATE INDEX IF NOT EXISTS idx_dlp_violations_org ON dlp_violations(org_id);
|
|
371
|
+
CREATE INDEX IF NOT EXISTS idx_dlp_violations_agent ON dlp_violations(agent_id);
|
|
372
|
+
|
|
373
|
+
-- Agent-to-agent messages
|
|
374
|
+
CREATE TABLE IF NOT EXISTS agent_messages (
|
|
375
|
+
id TEXT PRIMARY KEY,
|
|
376
|
+
org_id TEXT NOT NULL,
|
|
377
|
+
from_agent_id TEXT NOT NULL,
|
|
378
|
+
to_agent_id TEXT NOT NULL,
|
|
379
|
+
type TEXT NOT NULL DEFAULT 'message',
|
|
380
|
+
subject TEXT,
|
|
381
|
+
content TEXT NOT NULL,
|
|
382
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
383
|
+
status TEXT NOT NULL DEFAULT 'pending',
|
|
384
|
+
parent_id TEXT,
|
|
385
|
+
priority TEXT NOT NULL DEFAULT 'normal',
|
|
386
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
387
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
388
|
+
);
|
|
389
|
+
CREATE INDEX IF NOT EXISTS idx_agent_messages_org ON agent_messages(org_id);
|
|
390
|
+
CREATE INDEX IF NOT EXISTS idx_agent_messages_to ON agent_messages(to_agent_id);
|
|
391
|
+
CREATE INDEX IF NOT EXISTS idx_agent_messages_from ON agent_messages(from_agent_id);
|
|
392
|
+
CREATE INDEX IF NOT EXISTS idx_agent_messages_status ON agent_messages(status);
|
|
393
|
+
|
|
394
|
+
-- Interventions (pause/resume/kill records)
|
|
395
|
+
CREATE TABLE IF NOT EXISTS interventions (
|
|
396
|
+
id TEXT PRIMARY KEY,
|
|
397
|
+
org_id TEXT NOT NULL,
|
|
398
|
+
agent_id TEXT NOT NULL,
|
|
399
|
+
type TEXT NOT NULL,
|
|
400
|
+
reason TEXT NOT NULL,
|
|
401
|
+
triggered_by TEXT NOT NULL,
|
|
402
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
403
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
404
|
+
);
|
|
405
|
+
CREATE INDEX IF NOT EXISTS idx_interventions_org ON interventions(org_id);
|
|
406
|
+
CREATE INDEX IF NOT EXISTS idx_interventions_agent ON interventions(agent_id);
|
|
407
|
+
|
|
408
|
+
-- Anomaly detection rules
|
|
409
|
+
CREATE TABLE IF NOT EXISTS anomaly_rules (
|
|
410
|
+
id TEXT PRIMARY KEY,
|
|
411
|
+
org_id TEXT NOT NULL,
|
|
412
|
+
name TEXT NOT NULL,
|
|
413
|
+
description TEXT,
|
|
414
|
+
rule_type TEXT NOT NULL,
|
|
415
|
+
config JSON NOT NULL,
|
|
416
|
+
action TEXT NOT NULL DEFAULT 'alert',
|
|
417
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
418
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
419
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
420
|
+
);
|
|
421
|
+
CREATE INDEX IF NOT EXISTS idx_anomaly_rules_org ON anomaly_rules(org_id);
|
|
422
|
+
|
|
423
|
+
-- Action journal (for rollback)
|
|
424
|
+
CREATE TABLE IF NOT EXISTS action_journal (
|
|
425
|
+
id TEXT PRIMARY KEY,
|
|
426
|
+
org_id TEXT NOT NULL,
|
|
427
|
+
agent_id TEXT NOT NULL,
|
|
428
|
+
session_id TEXT,
|
|
429
|
+
tool_id TEXT NOT NULL,
|
|
430
|
+
tool_name TEXT NOT NULL,
|
|
431
|
+
action_type TEXT NOT NULL,
|
|
432
|
+
forward_data JSON NOT NULL,
|
|
433
|
+
reverse_data JSON,
|
|
434
|
+
reversible INTEGER NOT NULL DEFAULT 0,
|
|
435
|
+
reversed INTEGER NOT NULL DEFAULT 0,
|
|
436
|
+
reversed_at TEXT,
|
|
437
|
+
reversed_by TEXT,
|
|
438
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
439
|
+
);
|
|
440
|
+
CREATE INDEX IF NOT EXISTS idx_action_journal_org ON action_journal(org_id);
|
|
441
|
+
CREATE INDEX IF NOT EXISTS idx_action_journal_agent ON action_journal(agent_id);
|
|
442
|
+
CREATE INDEX IF NOT EXISTS idx_action_journal_reversible ON action_journal(reversible);
|
|
443
|
+
|
|
444
|
+
-- Compliance reports
|
|
445
|
+
CREATE TABLE IF NOT EXISTS compliance_reports (
|
|
446
|
+
id TEXT PRIMARY KEY,
|
|
447
|
+
org_id TEXT NOT NULL,
|
|
448
|
+
type TEXT NOT NULL,
|
|
449
|
+
title TEXT NOT NULL,
|
|
450
|
+
parameters JSON NOT NULL DEFAULT '{}',
|
|
451
|
+
status TEXT NOT NULL DEFAULT 'generating',
|
|
452
|
+
data JSON,
|
|
453
|
+
format TEXT NOT NULL DEFAULT 'json',
|
|
454
|
+
generated_by TEXT NOT NULL,
|
|
455
|
+
error TEXT,
|
|
456
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
457
|
+
);
|
|
458
|
+
CREATE INDEX IF NOT EXISTS idx_compliance_reports_org ON compliance_reports(org_id);
|
|
459
|
+
CREATE INDEX IF NOT EXISTS idx_compliance_reports_type ON compliance_reports(type);
|
|
460
|
+
`
|
|
461
|
+
},
|
|
462
|
+
{
|
|
463
|
+
version: 4,
|
|
464
|
+
name: "communication_topology",
|
|
465
|
+
sql: `
|
|
466
|
+
-- Add direction and channel columns to agent_messages for traffic classification
|
|
467
|
+
ALTER TABLE agent_messages ADD COLUMN direction TEXT DEFAULT 'internal';
|
|
468
|
+
ALTER TABLE agent_messages ADD COLUMN channel TEXT DEFAULT 'direct';
|
|
469
|
+
CREATE INDEX IF NOT EXISTS idx_agent_messages_direction ON agent_messages(direction);
|
|
470
|
+
CREATE INDEX IF NOT EXISTS idx_agent_messages_channel ON agent_messages(channel);
|
|
471
|
+
`
|
|
472
|
+
},
|
|
473
|
+
{
|
|
474
|
+
version: 5,
|
|
475
|
+
name: "communication_task_fields_and_compliance",
|
|
476
|
+
sql: `
|
|
477
|
+
-- Add task lifecycle columns to agent_messages
|
|
478
|
+
ALTER TABLE agent_messages ADD COLUMN deadline TEXT;
|
|
479
|
+
ALTER TABLE agent_messages ADD COLUMN claimed_at TEXT;
|
|
480
|
+
ALTER TABLE agent_messages ADD COLUMN completed_at TEXT;
|
|
481
|
+
|
|
482
|
+
-- Add completed_at to compliance reports
|
|
483
|
+
ALTER TABLE compliance_reports ADD COLUMN completed_at TEXT;
|
|
484
|
+
`
|
|
485
|
+
},
|
|
486
|
+
{
|
|
487
|
+
version: 6,
|
|
488
|
+
name: "community_skill_registry",
|
|
489
|
+
sql: `
|
|
490
|
+
-- Community skill index (global marketplace catalog)
|
|
491
|
+
CREATE TABLE IF NOT EXISTS community_skill_index (
|
|
492
|
+
id TEXT PRIMARY KEY,
|
|
493
|
+
name TEXT NOT NULL,
|
|
494
|
+
description TEXT NOT NULL,
|
|
495
|
+
version TEXT NOT NULL DEFAULT '1.0.0',
|
|
496
|
+
author TEXT NOT NULL,
|
|
497
|
+
repository TEXT NOT NULL,
|
|
498
|
+
license TEXT NOT NULL DEFAULT 'MIT',
|
|
499
|
+
category TEXT,
|
|
500
|
+
risk TEXT DEFAULT 'medium',
|
|
501
|
+
icon TEXT,
|
|
502
|
+
tags JSON NOT NULL DEFAULT '[]',
|
|
503
|
+
tools JSON NOT NULL DEFAULT '[]',
|
|
504
|
+
config_schema JSON NOT NULL DEFAULT '{}',
|
|
505
|
+
min_engine_version TEXT,
|
|
506
|
+
homepage TEXT,
|
|
507
|
+
downloads INTEGER NOT NULL DEFAULT 0,
|
|
508
|
+
rating REAL NOT NULL DEFAULT 0,
|
|
509
|
+
rating_count INTEGER NOT NULL DEFAULT 0,
|
|
510
|
+
verified INTEGER NOT NULL DEFAULT 0,
|
|
511
|
+
featured INTEGER NOT NULL DEFAULT 0,
|
|
512
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
513
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
514
|
+
);
|
|
515
|
+
CREATE INDEX IF NOT EXISTS idx_csi_category ON community_skill_index(category);
|
|
516
|
+
CREATE INDEX IF NOT EXISTS idx_csi_author ON community_skill_index(author);
|
|
517
|
+
CREATE INDEX IF NOT EXISTS idx_csi_featured ON community_skill_index(featured);
|
|
518
|
+
CREATE INDEX IF NOT EXISTS idx_csi_verified ON community_skill_index(verified);
|
|
519
|
+
CREATE INDEX IF NOT EXISTS idx_csi_downloads ON community_skill_index(downloads);
|
|
520
|
+
|
|
521
|
+
-- Per-org installed community skills
|
|
522
|
+
CREATE TABLE IF NOT EXISTS community_skill_installed (
|
|
523
|
+
id TEXT PRIMARY KEY,
|
|
524
|
+
org_id TEXT NOT NULL,
|
|
525
|
+
skill_id TEXT NOT NULL,
|
|
526
|
+
version TEXT NOT NULL,
|
|
527
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
528
|
+
config JSON NOT NULL DEFAULT '{}',
|
|
529
|
+
installed_by TEXT NOT NULL,
|
|
530
|
+
installed_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
531
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
532
|
+
);
|
|
533
|
+
CREATE INDEX IF NOT EXISTS idx_csinst_org ON community_skill_installed(org_id);
|
|
534
|
+
CREATE INDEX IF NOT EXISTS idx_csinst_skill ON community_skill_installed(skill_id);
|
|
535
|
+
CREATE UNIQUE INDEX IF NOT EXISTS idx_csinst_org_skill ON community_skill_installed(org_id, skill_id);
|
|
536
|
+
|
|
537
|
+
-- Reviews and ratings for community skills (global, not org-scoped)
|
|
538
|
+
CREATE TABLE IF NOT EXISTS community_skill_reviews (
|
|
539
|
+
id TEXT PRIMARY KEY,
|
|
540
|
+
skill_id TEXT NOT NULL,
|
|
541
|
+
org_id TEXT NOT NULL DEFAULT 'global',
|
|
542
|
+
user_id TEXT NOT NULL,
|
|
543
|
+
user_name TEXT,
|
|
544
|
+
rating INTEGER NOT NULL CHECK (rating >= 1 AND rating <= 5),
|
|
545
|
+
review_text TEXT,
|
|
546
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
547
|
+
);
|
|
548
|
+
CREATE INDEX IF NOT EXISTS idx_csrev_skill ON community_skill_reviews(skill_id);
|
|
549
|
+
`
|
|
550
|
+
},
|
|
551
|
+
{
|
|
552
|
+
version: 7,
|
|
553
|
+
name: "domain_registration",
|
|
554
|
+
sql: `
|
|
555
|
+
ALTER TABLE company_settings ADD COLUMN deployment_key_hash TEXT;
|
|
556
|
+
ALTER TABLE company_settings ADD COLUMN domain_registration_id TEXT;
|
|
557
|
+
ALTER TABLE company_settings ADD COLUMN domain_dns_challenge TEXT;
|
|
558
|
+
ALTER TABLE company_settings ADD COLUMN domain_verified_at TEXT;
|
|
559
|
+
ALTER TABLE company_settings ADD COLUMN domain_registered_at TEXT;
|
|
560
|
+
ALTER TABLE company_settings ADD COLUMN domain_status TEXT DEFAULT 'unregistered';
|
|
561
|
+
`,
|
|
562
|
+
postgres: `
|
|
563
|
+
ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS deployment_key_hash TEXT;
|
|
564
|
+
ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS domain_registration_id TEXT;
|
|
565
|
+
ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS domain_dns_challenge TEXT;
|
|
566
|
+
ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS domain_verified_at TIMESTAMPTZ;
|
|
567
|
+
ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS domain_registered_at TIMESTAMPTZ;
|
|
568
|
+
ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS domain_status TEXT DEFAULT 'unregistered';
|
|
569
|
+
`,
|
|
570
|
+
mysql: `
|
|
571
|
+
ALTER TABLE company_settings ADD COLUMN deployment_key_hash TEXT;
|
|
572
|
+
ALTER TABLE company_settings ADD COLUMN domain_registration_id VARCHAR(255);
|
|
573
|
+
ALTER TABLE company_settings ADD COLUMN domain_dns_challenge TEXT;
|
|
574
|
+
ALTER TABLE company_settings ADD COLUMN domain_verified_at DATETIME;
|
|
575
|
+
ALTER TABLE company_settings ADD COLUMN domain_registered_at DATETIME;
|
|
576
|
+
ALTER TABLE company_settings ADD COLUMN domain_status VARCHAR(20) DEFAULT 'unregistered';
|
|
577
|
+
`,
|
|
578
|
+
nosql: async () => {
|
|
579
|
+
}
|
|
580
|
+
},
|
|
581
|
+
{
|
|
582
|
+
version: 8,
|
|
583
|
+
name: "workforce_management",
|
|
584
|
+
sql: `
|
|
585
|
+
-- Work schedules (per-agent shift configuration)
|
|
586
|
+
CREATE TABLE IF NOT EXISTS work_schedules (
|
|
587
|
+
id TEXT PRIMARY KEY,
|
|
588
|
+
agent_id TEXT NOT NULL UNIQUE,
|
|
589
|
+
org_id TEXT NOT NULL,
|
|
590
|
+
timezone TEXT NOT NULL DEFAULT 'UTC',
|
|
591
|
+
schedule_type TEXT NOT NULL DEFAULT 'standard',
|
|
592
|
+
config JSON NOT NULL DEFAULT '{}',
|
|
593
|
+
enforce_clock_in INTEGER NOT NULL DEFAULT 1,
|
|
594
|
+
enforce_clock_out INTEGER NOT NULL DEFAULT 1,
|
|
595
|
+
auto_wake_enabled INTEGER NOT NULL DEFAULT 1,
|
|
596
|
+
off_hours_action TEXT NOT NULL DEFAULT 'pause',
|
|
597
|
+
grace_period_minutes INTEGER NOT NULL DEFAULT 5,
|
|
598
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
599
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
600
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
601
|
+
);
|
|
602
|
+
CREATE INDEX IF NOT EXISTS idx_work_schedules_agent ON work_schedules(agent_id);
|
|
603
|
+
CREATE INDEX IF NOT EXISTS idx_work_schedules_org ON work_schedules(org_id);
|
|
604
|
+
|
|
605
|
+
-- Clock records (audit trail for clock-in/out events)
|
|
606
|
+
CREATE TABLE IF NOT EXISTS clock_records (
|
|
607
|
+
id TEXT PRIMARY KEY,
|
|
608
|
+
agent_id TEXT NOT NULL,
|
|
609
|
+
org_id TEXT NOT NULL,
|
|
610
|
+
type TEXT NOT NULL,
|
|
611
|
+
triggered_by TEXT NOT NULL,
|
|
612
|
+
scheduled_at TEXT,
|
|
613
|
+
actual_at TEXT NOT NULL,
|
|
614
|
+
reason TEXT,
|
|
615
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
616
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
617
|
+
);
|
|
618
|
+
CREATE INDEX IF NOT EXISTS idx_clock_records_agent ON clock_records(agent_id);
|
|
619
|
+
CREATE INDEX IF NOT EXISTS idx_clock_records_org ON clock_records(org_id);
|
|
620
|
+
CREATE INDEX IF NOT EXISTS idx_clock_records_type ON clock_records(type);
|
|
621
|
+
CREATE INDEX IF NOT EXISTS idx_clock_records_time ON clock_records(created_at);
|
|
622
|
+
|
|
623
|
+
-- Task queue (work continuity between sessions)
|
|
624
|
+
CREATE TABLE IF NOT EXISTS task_queue (
|
|
625
|
+
id TEXT PRIMARY KEY,
|
|
626
|
+
agent_id TEXT NOT NULL,
|
|
627
|
+
org_id TEXT NOT NULL,
|
|
628
|
+
type TEXT NOT NULL DEFAULT 'continue',
|
|
629
|
+
title TEXT NOT NULL,
|
|
630
|
+
description TEXT,
|
|
631
|
+
context JSON NOT NULL DEFAULT '{}',
|
|
632
|
+
priority TEXT NOT NULL DEFAULT 'normal',
|
|
633
|
+
status TEXT NOT NULL DEFAULT 'queued',
|
|
634
|
+
source TEXT NOT NULL DEFAULT 'system',
|
|
635
|
+
scheduled_for TEXT,
|
|
636
|
+
started_at TEXT,
|
|
637
|
+
completed_at TEXT,
|
|
638
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
639
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
640
|
+
);
|
|
641
|
+
CREATE INDEX IF NOT EXISTS idx_task_queue_agent ON task_queue(agent_id);
|
|
642
|
+
CREATE INDEX IF NOT EXISTS idx_task_queue_org ON task_queue(org_id);
|
|
643
|
+
CREATE INDEX IF NOT EXISTS idx_task_queue_status ON task_queue(status);
|
|
644
|
+
`,
|
|
645
|
+
postgres: `
|
|
646
|
+
CREATE TABLE IF NOT EXISTS work_schedules (
|
|
647
|
+
id TEXT PRIMARY KEY,
|
|
648
|
+
agent_id TEXT NOT NULL UNIQUE,
|
|
649
|
+
org_id TEXT NOT NULL,
|
|
650
|
+
timezone TEXT NOT NULL DEFAULT 'UTC',
|
|
651
|
+
schedule_type TEXT NOT NULL DEFAULT 'standard',
|
|
652
|
+
config JSONB NOT NULL DEFAULT '{}',
|
|
653
|
+
enforce_clock_in BOOLEAN NOT NULL DEFAULT TRUE,
|
|
654
|
+
enforce_clock_out BOOLEAN NOT NULL DEFAULT TRUE,
|
|
655
|
+
auto_wake_enabled BOOLEAN NOT NULL DEFAULT TRUE,
|
|
656
|
+
off_hours_action TEXT NOT NULL DEFAULT 'pause',
|
|
657
|
+
grace_period_minutes INTEGER NOT NULL DEFAULT 5,
|
|
658
|
+
enabled BOOLEAN NOT NULL DEFAULT TRUE,
|
|
659
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
660
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
661
|
+
);
|
|
662
|
+
CREATE INDEX IF NOT EXISTS idx_work_schedules_agent ON work_schedules(agent_id);
|
|
663
|
+
CREATE INDEX IF NOT EXISTS idx_work_schedules_org ON work_schedules(org_id);
|
|
664
|
+
|
|
665
|
+
CREATE TABLE IF NOT EXISTS clock_records (
|
|
666
|
+
id TEXT PRIMARY KEY,
|
|
667
|
+
agent_id TEXT NOT NULL,
|
|
668
|
+
org_id TEXT NOT NULL,
|
|
669
|
+
type TEXT NOT NULL,
|
|
670
|
+
triggered_by TEXT NOT NULL,
|
|
671
|
+
scheduled_at TIMESTAMPTZ,
|
|
672
|
+
actual_at TIMESTAMPTZ NOT NULL,
|
|
673
|
+
reason TEXT,
|
|
674
|
+
metadata JSONB NOT NULL DEFAULT '{}',
|
|
675
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
676
|
+
);
|
|
677
|
+
CREATE INDEX IF NOT EXISTS idx_clock_records_agent ON clock_records(agent_id);
|
|
678
|
+
CREATE INDEX IF NOT EXISTS idx_clock_records_org ON clock_records(org_id);
|
|
679
|
+
CREATE INDEX IF NOT EXISTS idx_clock_records_type ON clock_records(type);
|
|
680
|
+
CREATE INDEX IF NOT EXISTS idx_clock_records_time ON clock_records(created_at);
|
|
681
|
+
|
|
682
|
+
CREATE TABLE IF NOT EXISTS task_queue (
|
|
683
|
+
id TEXT PRIMARY KEY,
|
|
684
|
+
agent_id TEXT NOT NULL,
|
|
685
|
+
org_id TEXT NOT NULL,
|
|
686
|
+
type TEXT NOT NULL DEFAULT 'continue',
|
|
687
|
+
title TEXT NOT NULL,
|
|
688
|
+
description TEXT,
|
|
689
|
+
context JSONB NOT NULL DEFAULT '{}',
|
|
690
|
+
priority TEXT NOT NULL DEFAULT 'normal',
|
|
691
|
+
status TEXT NOT NULL DEFAULT 'queued',
|
|
692
|
+
source TEXT NOT NULL DEFAULT 'system',
|
|
693
|
+
scheduled_for TIMESTAMPTZ,
|
|
694
|
+
started_at TIMESTAMPTZ,
|
|
695
|
+
completed_at TIMESTAMPTZ,
|
|
696
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
697
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
698
|
+
);
|
|
699
|
+
CREATE INDEX IF NOT EXISTS idx_task_queue_agent ON task_queue(agent_id);
|
|
700
|
+
CREATE INDEX IF NOT EXISTS idx_task_queue_org ON task_queue(org_id);
|
|
701
|
+
CREATE INDEX IF NOT EXISTS idx_task_queue_status ON task_queue(status);
|
|
702
|
+
`
|
|
703
|
+
},
|
|
704
|
+
{
|
|
705
|
+
version: 9,
|
|
706
|
+
name: "guardrails_policies_memory_onboarding",
|
|
707
|
+
sql: `
|
|
708
|
+
-- Organization policies (the "employee handbook" for AI agents)
|
|
709
|
+
CREATE TABLE IF NOT EXISTS org_policies (
|
|
710
|
+
id TEXT PRIMARY KEY,
|
|
711
|
+
org_id TEXT NOT NULL,
|
|
712
|
+
name TEXT NOT NULL,
|
|
713
|
+
category TEXT NOT NULL,
|
|
714
|
+
description TEXT,
|
|
715
|
+
content TEXT NOT NULL,
|
|
716
|
+
priority INTEGER NOT NULL DEFAULT 0,
|
|
717
|
+
version INTEGER NOT NULL DEFAULT 1,
|
|
718
|
+
enforcement TEXT NOT NULL DEFAULT 'mandatory',
|
|
719
|
+
applies_to JSON NOT NULL DEFAULT '["*"]',
|
|
720
|
+
tags JSON NOT NULL DEFAULT '[]',
|
|
721
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
722
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
723
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
724
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
725
|
+
);
|
|
726
|
+
CREATE INDEX IF NOT EXISTS idx_org_policies_org ON org_policies(org_id);
|
|
727
|
+
CREATE INDEX IF NOT EXISTS idx_org_policies_category ON org_policies(category);
|
|
728
|
+
|
|
729
|
+
-- Agent memory entries (persistent learning and growth)
|
|
730
|
+
CREATE TABLE IF NOT EXISTS agent_memory (
|
|
731
|
+
id TEXT PRIMARY KEY,
|
|
732
|
+
agent_id TEXT NOT NULL,
|
|
733
|
+
org_id TEXT NOT NULL,
|
|
734
|
+
category TEXT NOT NULL,
|
|
735
|
+
title TEXT NOT NULL,
|
|
736
|
+
content TEXT NOT NULL,
|
|
737
|
+
source TEXT NOT NULL DEFAULT 'interaction',
|
|
738
|
+
importance TEXT NOT NULL DEFAULT 'normal',
|
|
739
|
+
confidence REAL NOT NULL DEFAULT 1.0,
|
|
740
|
+
access_count INTEGER NOT NULL DEFAULT 0,
|
|
741
|
+
last_accessed_at TEXT,
|
|
742
|
+
expires_at TEXT,
|
|
743
|
+
tags JSON NOT NULL DEFAULT '[]',
|
|
744
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
745
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
746
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
747
|
+
);
|
|
748
|
+
CREATE INDEX IF NOT EXISTS idx_agent_memory_agent ON agent_memory(agent_id);
|
|
749
|
+
CREATE INDEX IF NOT EXISTS idx_agent_memory_org ON agent_memory(org_id);
|
|
750
|
+
CREATE INDEX IF NOT EXISTS idx_agent_memory_category ON agent_memory(category);
|
|
751
|
+
|
|
752
|
+
-- Onboarding records (tracking policy acknowledgment per agent)
|
|
753
|
+
CREATE TABLE IF NOT EXISTS onboarding_records (
|
|
754
|
+
id TEXT PRIMARY KEY,
|
|
755
|
+
agent_id TEXT NOT NULL,
|
|
756
|
+
org_id TEXT NOT NULL,
|
|
757
|
+
policy_id TEXT NOT NULL,
|
|
758
|
+
status TEXT NOT NULL DEFAULT 'pending',
|
|
759
|
+
acknowledged_at TEXT,
|
|
760
|
+
memory_entry_id TEXT,
|
|
761
|
+
verification_hash TEXT,
|
|
762
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
763
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
764
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
765
|
+
);
|
|
766
|
+
CREATE INDEX IF NOT EXISTS idx_onboarding_agent ON onboarding_records(agent_id);
|
|
767
|
+
CREATE INDEX IF NOT EXISTS idx_onboarding_policy ON onboarding_records(policy_id);
|
|
768
|
+
CREATE UNIQUE INDEX IF NOT EXISTS idx_onboarding_agent_policy ON onboarding_records(agent_id, policy_id);
|
|
769
|
+
|
|
770
|
+
-- Extended guardrail rules (superset of anomaly_rules with more categories)
|
|
771
|
+
CREATE TABLE IF NOT EXISTS guardrail_rules (
|
|
772
|
+
id TEXT PRIMARY KEY,
|
|
773
|
+
org_id TEXT NOT NULL,
|
|
774
|
+
name TEXT NOT NULL,
|
|
775
|
+
description TEXT,
|
|
776
|
+
category TEXT NOT NULL,
|
|
777
|
+
rule_type TEXT NOT NULL,
|
|
778
|
+
conditions JSON NOT NULL DEFAULT '{}',
|
|
779
|
+
action TEXT NOT NULL DEFAULT 'alert',
|
|
780
|
+
severity TEXT NOT NULL DEFAULT 'medium',
|
|
781
|
+
cooldown_minutes INTEGER NOT NULL DEFAULT 0,
|
|
782
|
+
last_triggered_at TEXT,
|
|
783
|
+
trigger_count INTEGER NOT NULL DEFAULT 0,
|
|
784
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
785
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
786
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
787
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
788
|
+
);
|
|
789
|
+
CREATE INDEX IF NOT EXISTS idx_guardrail_rules_org ON guardrail_rules(org_id);
|
|
790
|
+
CREATE INDEX IF NOT EXISTS idx_guardrail_rules_category ON guardrail_rules(category);
|
|
791
|
+
`,
|
|
792
|
+
postgres: `
|
|
793
|
+
CREATE TABLE IF NOT EXISTS org_policies (
|
|
794
|
+
id TEXT PRIMARY KEY,
|
|
795
|
+
org_id TEXT NOT NULL,
|
|
796
|
+
name TEXT NOT NULL,
|
|
797
|
+
category TEXT NOT NULL,
|
|
798
|
+
description TEXT,
|
|
799
|
+
content TEXT NOT NULL,
|
|
800
|
+
priority INTEGER NOT NULL DEFAULT 0,
|
|
801
|
+
version INTEGER NOT NULL DEFAULT 1,
|
|
802
|
+
enforcement TEXT NOT NULL DEFAULT 'mandatory',
|
|
803
|
+
applies_to JSONB NOT NULL DEFAULT '["*"]',
|
|
804
|
+
tags JSONB NOT NULL DEFAULT '[]',
|
|
805
|
+
enabled BOOLEAN NOT NULL DEFAULT TRUE,
|
|
806
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
807
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
808
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
809
|
+
);
|
|
810
|
+
CREATE INDEX IF NOT EXISTS idx_org_policies_org ON org_policies(org_id);
|
|
811
|
+
CREATE INDEX IF NOT EXISTS idx_org_policies_category ON org_policies(category);
|
|
812
|
+
|
|
813
|
+
CREATE TABLE IF NOT EXISTS agent_memory (
|
|
814
|
+
id TEXT PRIMARY KEY,
|
|
815
|
+
agent_id TEXT NOT NULL,
|
|
816
|
+
org_id TEXT NOT NULL,
|
|
817
|
+
category TEXT NOT NULL,
|
|
818
|
+
title TEXT NOT NULL,
|
|
819
|
+
content TEXT NOT NULL,
|
|
820
|
+
source TEXT NOT NULL DEFAULT 'interaction',
|
|
821
|
+
importance TEXT NOT NULL DEFAULT 'normal',
|
|
822
|
+
confidence REAL NOT NULL DEFAULT 1.0,
|
|
823
|
+
access_count INTEGER NOT NULL DEFAULT 0,
|
|
824
|
+
last_accessed_at TIMESTAMPTZ,
|
|
825
|
+
expires_at TIMESTAMPTZ,
|
|
826
|
+
tags JSONB NOT NULL DEFAULT '[]',
|
|
827
|
+
metadata JSONB NOT NULL DEFAULT '{}',
|
|
828
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
829
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
830
|
+
);
|
|
831
|
+
CREATE INDEX IF NOT EXISTS idx_agent_memory_agent ON agent_memory(agent_id);
|
|
832
|
+
CREATE INDEX IF NOT EXISTS idx_agent_memory_org ON agent_memory(org_id);
|
|
833
|
+
CREATE INDEX IF NOT EXISTS idx_agent_memory_category ON agent_memory(category);
|
|
834
|
+
|
|
835
|
+
CREATE TABLE IF NOT EXISTS onboarding_records (
|
|
836
|
+
id TEXT PRIMARY KEY,
|
|
837
|
+
agent_id TEXT NOT NULL,
|
|
838
|
+
org_id TEXT NOT NULL,
|
|
839
|
+
policy_id TEXT NOT NULL,
|
|
840
|
+
status TEXT NOT NULL DEFAULT 'pending',
|
|
841
|
+
acknowledged_at TIMESTAMPTZ,
|
|
842
|
+
memory_entry_id TEXT,
|
|
843
|
+
verification_hash TEXT,
|
|
844
|
+
metadata JSONB NOT NULL DEFAULT '{}',
|
|
845
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
846
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
847
|
+
);
|
|
848
|
+
CREATE INDEX IF NOT EXISTS idx_onboarding_agent ON onboarding_records(agent_id);
|
|
849
|
+
CREATE INDEX IF NOT EXISTS idx_onboarding_policy ON onboarding_records(policy_id);
|
|
850
|
+
CREATE UNIQUE INDEX IF NOT EXISTS idx_onboarding_agent_policy ON onboarding_records(agent_id, policy_id);
|
|
851
|
+
|
|
852
|
+
CREATE TABLE IF NOT EXISTS guardrail_rules (
|
|
853
|
+
id TEXT PRIMARY KEY,
|
|
854
|
+
org_id TEXT NOT NULL,
|
|
855
|
+
name TEXT NOT NULL,
|
|
856
|
+
description TEXT,
|
|
857
|
+
category TEXT NOT NULL,
|
|
858
|
+
rule_type TEXT NOT NULL,
|
|
859
|
+
conditions JSONB NOT NULL DEFAULT '{}',
|
|
860
|
+
action TEXT NOT NULL DEFAULT 'alert',
|
|
861
|
+
severity TEXT NOT NULL DEFAULT 'medium',
|
|
862
|
+
cooldown_minutes INTEGER NOT NULL DEFAULT 0,
|
|
863
|
+
last_triggered_at TIMESTAMPTZ,
|
|
864
|
+
trigger_count INTEGER NOT NULL DEFAULT 0,
|
|
865
|
+
enabled BOOLEAN NOT NULL DEFAULT TRUE,
|
|
866
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
867
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
868
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
869
|
+
);
|
|
870
|
+
CREATE INDEX IF NOT EXISTS idx_guardrail_rules_org ON guardrail_rules(org_id);
|
|
871
|
+
CREATE INDEX IF NOT EXISTS idx_guardrail_rules_category ON guardrail_rules(category);
|
|
872
|
+
`
|
|
873
|
+
},
|
|
874
|
+
{
|
|
875
|
+
version: 10,
|
|
876
|
+
name: "vault_storage_policy_import",
|
|
877
|
+
sql: `
|
|
878
|
+
-- Vault entries (encrypted secrets at rest)
|
|
879
|
+
CREATE TABLE IF NOT EXISTS vault_entries (
|
|
880
|
+
id TEXT PRIMARY KEY,
|
|
881
|
+
org_id TEXT NOT NULL,
|
|
882
|
+
name TEXT NOT NULL,
|
|
883
|
+
category TEXT NOT NULL DEFAULT 'custom',
|
|
884
|
+
encrypted_value TEXT NOT NULL,
|
|
885
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
886
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
887
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
888
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
889
|
+
rotated_at TEXT,
|
|
890
|
+
expires_at TEXT
|
|
891
|
+
);
|
|
892
|
+
CREATE INDEX IF NOT EXISTS idx_vault_org ON vault_entries(org_id);
|
|
893
|
+
CREATE INDEX IF NOT EXISTS idx_vault_category ON vault_entries(category);
|
|
894
|
+
CREATE UNIQUE INDEX IF NOT EXISTS idx_vault_org_name ON vault_entries(org_id, name);
|
|
895
|
+
|
|
896
|
+
-- Vault audit log (tracks every secret access for compliance)
|
|
897
|
+
CREATE TABLE IF NOT EXISTS vault_audit_log (
|
|
898
|
+
id TEXT PRIMARY KEY,
|
|
899
|
+
org_id TEXT NOT NULL,
|
|
900
|
+
vault_entry_id TEXT,
|
|
901
|
+
action TEXT NOT NULL,
|
|
902
|
+
actor TEXT NOT NULL,
|
|
903
|
+
ip TEXT,
|
|
904
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
905
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
906
|
+
);
|
|
907
|
+
CREATE INDEX IF NOT EXISTS idx_vault_audit_org ON vault_audit_log(org_id);
|
|
908
|
+
CREATE INDEX IF NOT EXISTS idx_vault_audit_entry ON vault_audit_log(vault_entry_id);
|
|
909
|
+
|
|
910
|
+
-- Org storage configurations
|
|
911
|
+
CREATE TABLE IF NOT EXISTS org_storage_config (
|
|
912
|
+
id TEXT PRIMARY KEY,
|
|
913
|
+
org_id TEXT NOT NULL,
|
|
914
|
+
storage_type TEXT NOT NULL DEFAULT 'local',
|
|
915
|
+
config JSON NOT NULL DEFAULT '{}',
|
|
916
|
+
vault_credential_id TEXT,
|
|
917
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
918
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
919
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
920
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
921
|
+
);
|
|
922
|
+
CREATE UNIQUE INDEX IF NOT EXISTS idx_org_storage_org ON org_storage_config(org_id);
|
|
923
|
+
|
|
924
|
+
-- Storage objects metadata
|
|
925
|
+
CREATE TABLE IF NOT EXISTS storage_objects (
|
|
926
|
+
id TEXT PRIMARY KEY,
|
|
927
|
+
org_id TEXT NOT NULL,
|
|
928
|
+
storage_key TEXT NOT NULL,
|
|
929
|
+
original_name TEXT NOT NULL,
|
|
930
|
+
content_type TEXT NOT NULL DEFAULT 'application/octet-stream',
|
|
931
|
+
size INTEGER NOT NULL DEFAULT 0,
|
|
932
|
+
related_type TEXT,
|
|
933
|
+
related_id TEXT,
|
|
934
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
935
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
936
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
937
|
+
);
|
|
938
|
+
CREATE INDEX IF NOT EXISTS idx_storage_objects_org ON storage_objects(org_id);
|
|
939
|
+
CREATE INDEX IF NOT EXISTS idx_storage_objects_related ON storage_objects(related_type, related_id);
|
|
940
|
+
|
|
941
|
+
-- Policy import job tracking
|
|
942
|
+
CREATE TABLE IF NOT EXISTS policy_import_jobs (
|
|
943
|
+
id TEXT PRIMARY KEY,
|
|
944
|
+
org_id TEXT NOT NULL,
|
|
945
|
+
format TEXT NOT NULL,
|
|
946
|
+
status TEXT NOT NULL DEFAULT 'pending',
|
|
947
|
+
progress JSON NOT NULL DEFAULT '{}',
|
|
948
|
+
errors JSON NOT NULL DEFAULT '[]',
|
|
949
|
+
policy_ids JSON NOT NULL DEFAULT '[]',
|
|
950
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
951
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
952
|
+
completed_at TEXT
|
|
953
|
+
);
|
|
954
|
+
CREATE INDEX IF NOT EXISTS idx_import_jobs_org ON policy_import_jobs(org_id);
|
|
955
|
+
`,
|
|
956
|
+
postgres: `
|
|
957
|
+
CREATE TABLE IF NOT EXISTS vault_entries (
|
|
958
|
+
id TEXT PRIMARY KEY,
|
|
959
|
+
org_id TEXT NOT NULL,
|
|
960
|
+
name TEXT NOT NULL,
|
|
961
|
+
category TEXT NOT NULL DEFAULT 'custom',
|
|
962
|
+
encrypted_value TEXT NOT NULL,
|
|
963
|
+
metadata JSONB NOT NULL DEFAULT '{}',
|
|
964
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
965
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
966
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
967
|
+
rotated_at TIMESTAMPTZ,
|
|
968
|
+
expires_at TIMESTAMPTZ
|
|
969
|
+
);
|
|
970
|
+
CREATE INDEX IF NOT EXISTS idx_vault_org ON vault_entries(org_id);
|
|
971
|
+
CREATE INDEX IF NOT EXISTS idx_vault_category ON vault_entries(category);
|
|
972
|
+
CREATE UNIQUE INDEX IF NOT EXISTS idx_vault_org_name ON vault_entries(org_id, name);
|
|
973
|
+
|
|
974
|
+
CREATE TABLE IF NOT EXISTS vault_audit_log (
|
|
975
|
+
id TEXT PRIMARY KEY,
|
|
976
|
+
org_id TEXT NOT NULL,
|
|
977
|
+
vault_entry_id TEXT,
|
|
978
|
+
action TEXT NOT NULL,
|
|
979
|
+
actor TEXT NOT NULL,
|
|
980
|
+
ip TEXT,
|
|
981
|
+
metadata JSONB NOT NULL DEFAULT '{}',
|
|
982
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
983
|
+
);
|
|
984
|
+
CREATE INDEX IF NOT EXISTS idx_vault_audit_org ON vault_audit_log(org_id);
|
|
985
|
+
CREATE INDEX IF NOT EXISTS idx_vault_audit_entry ON vault_audit_log(vault_entry_id);
|
|
986
|
+
|
|
987
|
+
CREATE TABLE IF NOT EXISTS org_storage_config (
|
|
988
|
+
id TEXT PRIMARY KEY,
|
|
989
|
+
org_id TEXT NOT NULL,
|
|
990
|
+
storage_type TEXT NOT NULL DEFAULT 'local',
|
|
991
|
+
config JSONB NOT NULL DEFAULT '{}',
|
|
992
|
+
vault_credential_id TEXT,
|
|
993
|
+
enabled BOOLEAN NOT NULL DEFAULT TRUE,
|
|
994
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
995
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
996
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
997
|
+
);
|
|
998
|
+
CREATE UNIQUE INDEX IF NOT EXISTS idx_org_storage_org ON org_storage_config(org_id);
|
|
999
|
+
|
|
1000
|
+
CREATE TABLE IF NOT EXISTS storage_objects (
|
|
1001
|
+
id TEXT PRIMARY KEY,
|
|
1002
|
+
org_id TEXT NOT NULL,
|
|
1003
|
+
storage_key TEXT NOT NULL,
|
|
1004
|
+
original_name TEXT NOT NULL,
|
|
1005
|
+
content_type TEXT NOT NULL DEFAULT 'application/octet-stream',
|
|
1006
|
+
size INTEGER NOT NULL DEFAULT 0,
|
|
1007
|
+
related_type TEXT,
|
|
1008
|
+
related_id TEXT,
|
|
1009
|
+
metadata JSONB NOT NULL DEFAULT '{}',
|
|
1010
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
1011
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
1012
|
+
);
|
|
1013
|
+
CREATE INDEX IF NOT EXISTS idx_storage_objects_org ON storage_objects(org_id);
|
|
1014
|
+
CREATE INDEX IF NOT EXISTS idx_storage_objects_related ON storage_objects(related_type, related_id);
|
|
1015
|
+
|
|
1016
|
+
CREATE TABLE IF NOT EXISTS policy_import_jobs (
|
|
1017
|
+
id TEXT PRIMARY KEY,
|
|
1018
|
+
org_id TEXT NOT NULL,
|
|
1019
|
+
format TEXT NOT NULL,
|
|
1020
|
+
status TEXT NOT NULL DEFAULT 'pending',
|
|
1021
|
+
progress JSONB NOT NULL DEFAULT '{}',
|
|
1022
|
+
errors JSONB NOT NULL DEFAULT '[]',
|
|
1023
|
+
policy_ids JSONB NOT NULL DEFAULT '[]',
|
|
1024
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
1025
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
1026
|
+
completed_at TIMESTAMPTZ
|
|
1027
|
+
);
|
|
1028
|
+
CREATE INDEX IF NOT EXISTS idx_import_jobs_org ON policy_import_jobs(org_id);
|
|
1029
|
+
`
|
|
1030
|
+
},
|
|
1031
|
+
{
|
|
1032
|
+
version: 11,
|
|
1033
|
+
name: "reviews_global_add_user_name",
|
|
1034
|
+
sql: `ALTER TABLE community_skill_reviews ADD COLUMN user_name TEXT;`,
|
|
1035
|
+
postgres: `ALTER TABLE community_skill_reviews ADD COLUMN IF NOT EXISTS user_name TEXT;`
|
|
1036
|
+
},
|
|
1037
|
+
{
|
|
1038
|
+
version: 12,
|
|
1039
|
+
name: "tool_security_config",
|
|
1040
|
+
sql: `ALTER TABLE company_settings ADD COLUMN tool_security_config TEXT DEFAULT '{}';`,
|
|
1041
|
+
postgres: `ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS tool_security_config TEXT DEFAULT '{}';`,
|
|
1042
|
+
mysql: `ALTER TABLE company_settings ADD COLUMN tool_security_config TEXT DEFAULT '{}';`,
|
|
1043
|
+
nosql: async () => {
|
|
1044
|
+
}
|
|
1045
|
+
},
|
|
1046
|
+
{
|
|
1047
|
+
version: 13,
|
|
1048
|
+
name: "firewall_config",
|
|
1049
|
+
sql: `ALTER TABLE company_settings ADD COLUMN firewall_config TEXT DEFAULT '{}';`,
|
|
1050
|
+
postgres: `ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS firewall_config TEXT DEFAULT '{}';`,
|
|
1051
|
+
mysql: `ALTER TABLE company_settings ADD COLUMN firewall_config TEXT DEFAULT '{}';`,
|
|
1052
|
+
nosql: async () => {
|
|
1053
|
+
}
|
|
1054
|
+
},
|
|
1055
|
+
{
|
|
1056
|
+
version: 14,
|
|
1057
|
+
name: "agent_runtime_sessions",
|
|
1058
|
+
sql: `
|
|
1059
|
+
-- Agent runtime sessions (standalone agent execution)
|
|
1060
|
+
CREATE TABLE IF NOT EXISTS agent_sessions (
|
|
1061
|
+
id TEXT PRIMARY KEY,
|
|
1062
|
+
agent_id TEXT NOT NULL,
|
|
1063
|
+
org_id TEXT NOT NULL DEFAULT 'default',
|
|
1064
|
+
status TEXT NOT NULL DEFAULT 'active',
|
|
1065
|
+
token_count INTEGER DEFAULT 0,
|
|
1066
|
+
turn_count INTEGER DEFAULT 0,
|
|
1067
|
+
parent_session_id TEXT,
|
|
1068
|
+
created_at INTEGER NOT NULL,
|
|
1069
|
+
updated_at INTEGER NOT NULL
|
|
1070
|
+
);
|
|
1071
|
+
CREATE INDEX IF NOT EXISTS idx_agent_sessions_agent ON agent_sessions(agent_id);
|
|
1072
|
+
CREATE INDEX IF NOT EXISTS idx_agent_sessions_status ON agent_sessions(status);
|
|
1073
|
+
CREATE INDEX IF NOT EXISTS idx_agent_sessions_parent ON agent_sessions(parent_session_id);
|
|
1074
|
+
|
|
1075
|
+
-- Agent session messages (conversation history per session)
|
|
1076
|
+
CREATE TABLE IF NOT EXISTS agent_session_messages (
|
|
1077
|
+
id TEXT PRIMARY KEY,
|
|
1078
|
+
session_id TEXT NOT NULL,
|
|
1079
|
+
role TEXT NOT NULL,
|
|
1080
|
+
content TEXT NOT NULL,
|
|
1081
|
+
tool_calls TEXT,
|
|
1082
|
+
tool_results TEXT,
|
|
1083
|
+
created_at INTEGER NOT NULL,
|
|
1084
|
+
FOREIGN KEY (session_id) REFERENCES agent_sessions(id) ON DELETE CASCADE
|
|
1085
|
+
);
|
|
1086
|
+
CREATE INDEX IF NOT EXISTS idx_session_messages_session ON agent_session_messages(session_id);
|
|
1087
|
+
CREATE INDEX IF NOT EXISTS idx_session_messages_time ON agent_session_messages(created_at);
|
|
1088
|
+
`,
|
|
1089
|
+
postgres: `
|
|
1090
|
+
CREATE TABLE IF NOT EXISTS agent_sessions (
|
|
1091
|
+
id TEXT PRIMARY KEY,
|
|
1092
|
+
agent_id TEXT NOT NULL,
|
|
1093
|
+
org_id TEXT NOT NULL DEFAULT 'default',
|
|
1094
|
+
status TEXT NOT NULL DEFAULT 'active',
|
|
1095
|
+
token_count INTEGER DEFAULT 0,
|
|
1096
|
+
turn_count INTEGER DEFAULT 0,
|
|
1097
|
+
parent_session_id TEXT,
|
|
1098
|
+
created_at BIGINT NOT NULL,
|
|
1099
|
+
updated_at BIGINT NOT NULL
|
|
1100
|
+
);
|
|
1101
|
+
CREATE INDEX IF NOT EXISTS idx_agent_sessions_agent ON agent_sessions(agent_id);
|
|
1102
|
+
CREATE INDEX IF NOT EXISTS idx_agent_sessions_status ON agent_sessions(status);
|
|
1103
|
+
CREATE INDEX IF NOT EXISTS idx_agent_sessions_parent ON agent_sessions(parent_session_id);
|
|
1104
|
+
|
|
1105
|
+
CREATE TABLE IF NOT EXISTS agent_session_messages (
|
|
1106
|
+
id TEXT PRIMARY KEY,
|
|
1107
|
+
session_id TEXT NOT NULL,
|
|
1108
|
+
role TEXT NOT NULL,
|
|
1109
|
+
content TEXT NOT NULL,
|
|
1110
|
+
tool_calls TEXT,
|
|
1111
|
+
tool_results TEXT,
|
|
1112
|
+
created_at BIGINT NOT NULL,
|
|
1113
|
+
FOREIGN KEY (session_id) REFERENCES agent_sessions(id) ON DELETE CASCADE
|
|
1114
|
+
);
|
|
1115
|
+
CREATE INDEX IF NOT EXISTS idx_session_messages_session ON agent_session_messages(session_id);
|
|
1116
|
+
CREATE INDEX IF NOT EXISTS idx_session_messages_time ON agent_session_messages(created_at);
|
|
1117
|
+
`
|
|
1118
|
+
},
|
|
1119
|
+
{
|
|
1120
|
+
version: 15,
|
|
1121
|
+
name: "long_running_sessions",
|
|
1122
|
+
sql: `
|
|
1123
|
+
-- Add heartbeat tracking to agent sessions
|
|
1124
|
+
ALTER TABLE agent_sessions ADD COLUMN last_heartbeat_at INTEGER;
|
|
1125
|
+
ALTER TABLE agent_sessions ADD COLUMN cost_usd REAL DEFAULT 0;
|
|
1126
|
+
CREATE INDEX IF NOT EXISTS idx_agent_sessions_heartbeat ON agent_sessions(last_heartbeat_at);
|
|
1127
|
+
|
|
1128
|
+
-- Persistent follow-ups (survive restarts)
|
|
1129
|
+
CREATE TABLE IF NOT EXISTS agent_followups (
|
|
1130
|
+
id TEXT PRIMARY KEY,
|
|
1131
|
+
agent_id TEXT NOT NULL,
|
|
1132
|
+
session_id TEXT,
|
|
1133
|
+
message TEXT NOT NULL,
|
|
1134
|
+
execute_at INTEGER NOT NULL,
|
|
1135
|
+
status TEXT NOT NULL DEFAULT 'pending',
|
|
1136
|
+
created_at INTEGER NOT NULL
|
|
1137
|
+
);
|
|
1138
|
+
CREATE INDEX IF NOT EXISTS idx_agent_followups_status ON agent_followups(status);
|
|
1139
|
+
CREATE INDEX IF NOT EXISTS idx_agent_followups_execute ON agent_followups(execute_at);
|
|
1140
|
+
CREATE INDEX IF NOT EXISTS idx_agent_followups_agent ON agent_followups(agent_id);
|
|
1141
|
+
`,
|
|
1142
|
+
postgres: `
|
|
1143
|
+
ALTER TABLE agent_sessions ADD COLUMN IF NOT EXISTS last_heartbeat_at BIGINT;
|
|
1144
|
+
ALTER TABLE agent_sessions ADD COLUMN IF NOT EXISTS cost_usd DOUBLE PRECISION DEFAULT 0;
|
|
1145
|
+
CREATE INDEX IF NOT EXISTS idx_agent_sessions_heartbeat ON agent_sessions(last_heartbeat_at);
|
|
1146
|
+
|
|
1147
|
+
CREATE TABLE IF NOT EXISTS agent_followups (
|
|
1148
|
+
id TEXT PRIMARY KEY,
|
|
1149
|
+
agent_id TEXT NOT NULL,
|
|
1150
|
+
session_id TEXT,
|
|
1151
|
+
message TEXT NOT NULL,
|
|
1152
|
+
execute_at BIGINT NOT NULL,
|
|
1153
|
+
status TEXT NOT NULL DEFAULT 'pending',
|
|
1154
|
+
created_at BIGINT NOT NULL
|
|
1155
|
+
);
|
|
1156
|
+
CREATE INDEX IF NOT EXISTS idx_agent_followups_status ON agent_followups(status);
|
|
1157
|
+
CREATE INDEX IF NOT EXISTS idx_agent_followups_execute ON agent_followups(execute_at);
|
|
1158
|
+
CREATE INDEX IF NOT EXISTS idx_agent_followups_agent ON agent_followups(agent_id);
|
|
1159
|
+
`,
|
|
1160
|
+
mysql: `
|
|
1161
|
+
ALTER TABLE agent_sessions ADD COLUMN last_heartbeat_at BIGINT;
|
|
1162
|
+
ALTER TABLE agent_sessions ADD COLUMN cost_usd DOUBLE DEFAULT 0;
|
|
1163
|
+
CREATE INDEX idx_agent_sessions_heartbeat ON agent_sessions(last_heartbeat_at);
|
|
1164
|
+
|
|
1165
|
+
CREATE TABLE IF NOT EXISTS agent_followups (
|
|
1166
|
+
id VARCHAR(255) PRIMARY KEY,
|
|
1167
|
+
agent_id VARCHAR(255) NOT NULL,
|
|
1168
|
+
session_id VARCHAR(255),
|
|
1169
|
+
message TEXT NOT NULL,
|
|
1170
|
+
execute_at BIGINT NOT NULL,
|
|
1171
|
+
status VARCHAR(50) NOT NULL DEFAULT 'pending',
|
|
1172
|
+
created_at BIGINT NOT NULL
|
|
1173
|
+
);
|
|
1174
|
+
CREATE INDEX idx_agent_followups_status ON agent_followups(status);
|
|
1175
|
+
CREATE INDEX idx_agent_followups_execute ON agent_followups(execute_at);
|
|
1176
|
+
CREATE INDEX idx_agent_followups_agent ON agent_followups(agent_id);
|
|
1177
|
+
`
|
|
1178
|
+
},
|
|
1179
|
+
{
|
|
1180
|
+
version: 16,
|
|
1181
|
+
name: "model_pricing_config",
|
|
1182
|
+
sql: `ALTER TABLE company_settings ADD COLUMN model_pricing_config TEXT DEFAULT '{}';`,
|
|
1183
|
+
postgres: `ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS model_pricing_config TEXT DEFAULT '{}';`,
|
|
1184
|
+
mysql: `ALTER TABLE company_settings ADD COLUMN model_pricing_config TEXT DEFAULT '{}';`,
|
|
1185
|
+
nosql: async () => {
|
|
1186
|
+
}
|
|
1187
|
+
}
|
|
1188
|
+
];
|
|
1189
|
+
function sqliteToPostgres(sql) {
|
|
1190
|
+
return sql.replace(/JSON/g, "JSONB").replace(/datetime\('now'\)/g, "NOW()").replace(/INTEGER NOT NULL DEFAULT 1(?!\d)/g, "BOOLEAN NOT NULL DEFAULT TRUE").replace(/INTEGER NOT NULL DEFAULT 0(?!\d)/g, "INTEGER NOT NULL DEFAULT 0");
|
|
1191
|
+
}
|
|
1192
|
+
function sqliteToMySQL(sql) {
|
|
1193
|
+
return sql.replace(/TEXT PRIMARY KEY/g, "VARCHAR(255) PRIMARY KEY").replace(/TEXT NOT NULL UNIQUE/g, "VARCHAR(255) NOT NULL UNIQUE").replace(/TEXT NOT NULL DEFAULT/g, "VARCHAR(255) NOT NULL DEFAULT").replace(/BLOB/g, "LONGBLOB").replace(/datetime\('now'\)/g, "NOW()").replace(/INTEGER NOT NULL DEFAULT 1/g, "TINYINT(1) NOT NULL DEFAULT 1").replace(/ON CONFLICT\(.*?\) DO UPDATE SET/g, "ON DUPLICATE KEY UPDATE");
|
|
1194
|
+
}
|
|
1195
|
+
|
|
1196
|
+
// src/engine/db-adapter.ts
|
|
1197
|
+
var EngineDatabase = class {
|
|
1198
|
+
db;
|
|
1199
|
+
dialect;
|
|
1200
|
+
/** Raw driver handle for NoSQL migrations (MongoClient db, DynamoDB client, etc.) */
|
|
1201
|
+
rawDriver;
|
|
1202
|
+
constructor(db, dialect = "sqlite", rawDriver) {
|
|
1203
|
+
this.db = db;
|
|
1204
|
+
this.dialect = dialect;
|
|
1205
|
+
this.rawDriver = rawDriver;
|
|
1206
|
+
}
|
|
1207
|
+
// ─── Migration System ─────────────────────────────────
|
|
1208
|
+
/**
|
|
1209
|
+
* Run all pending migrations in order.
|
|
1210
|
+
* Creates the migration tracking table first, then applies any unapplied migrations.
|
|
1211
|
+
*/
|
|
1212
|
+
async migrate() {
|
|
1213
|
+
const trackingDDL = this.dialect === "postgres" ? MIGRATIONS_TABLE_POSTGRES : MIGRATIONS_TABLE;
|
|
1214
|
+
for (const stmt of this.splitStatements(trackingDDL)) {
|
|
1215
|
+
await this.db.run(stmt);
|
|
1216
|
+
}
|
|
1217
|
+
const applied = await this.db.all("SELECT version FROM engine_migrations ORDER BY version");
|
|
1218
|
+
const appliedSet = new Set(applied.map((r) => r.version));
|
|
1219
|
+
let count = 0;
|
|
1220
|
+
for (const migration of MIGRATIONS) {
|
|
1221
|
+
if (appliedSet.has(migration.version)) continue;
|
|
1222
|
+
if ((this.dialect === "mongodb" || this.dialect === "dynamodb") && migration.nosql) {
|
|
1223
|
+
await migration.nosql(this.rawDriver, this.dialect);
|
|
1224
|
+
} else {
|
|
1225
|
+
const sql = this.getSqlForDialect(migration);
|
|
1226
|
+
if (sql) {
|
|
1227
|
+
for (const stmt of this.splitStatements(sql)) {
|
|
1228
|
+
try {
|
|
1229
|
+
await this.db.run(stmt);
|
|
1230
|
+
} catch (e) {
|
|
1231
|
+
if (e?.message?.includes("duplicate column")) continue;
|
|
1232
|
+
throw e;
|
|
1233
|
+
}
|
|
1234
|
+
}
|
|
1235
|
+
}
|
|
1236
|
+
}
|
|
1237
|
+
await this.db.run(
|
|
1238
|
+
"INSERT INTO engine_migrations (version, name) VALUES (?, ?)",
|
|
1239
|
+
[migration.version, migration.name]
|
|
1240
|
+
);
|
|
1241
|
+
count++;
|
|
1242
|
+
}
|
|
1243
|
+
return { applied: count, total: MIGRATIONS.length };
|
|
1244
|
+
}
|
|
1245
|
+
/**
|
|
1246
|
+
* Register and create a dynamic table at runtime.
|
|
1247
|
+
* Used by plugins, skills, or engine extensions that need their own storage.
|
|
1248
|
+
* Table name is auto-prefixed with `ext_` to avoid collisions with core tables.
|
|
1249
|
+
*/
|
|
1250
|
+
async createDynamicTable(def) {
|
|
1251
|
+
const prefixedName = def.name.startsWith("ext_") ? def.name : `ext_${def.name}`;
|
|
1252
|
+
if (this.dialect === "mongodb" && def.mongoSetup) {
|
|
1253
|
+
await def.mongoSetup(this.rawDriver);
|
|
1254
|
+
return;
|
|
1255
|
+
}
|
|
1256
|
+
if (this.dialect === "dynamodb" && def.dynamoSetup) {
|
|
1257
|
+
await def.dynamoSetup(this.rawDriver);
|
|
1258
|
+
return;
|
|
1259
|
+
}
|
|
1260
|
+
let ddl;
|
|
1261
|
+
if (this.dialect === "postgres" && def.postgres) {
|
|
1262
|
+
ddl = def.postgres;
|
|
1263
|
+
} else if (this.dialect === "mysql" && def.mysql) {
|
|
1264
|
+
ddl = def.mysql;
|
|
1265
|
+
} else if (this.dialect === "postgres") {
|
|
1266
|
+
ddl = sqliteToPostgres(def.sql);
|
|
1267
|
+
} else if (this.dialect === "mysql") {
|
|
1268
|
+
ddl = sqliteToMySQL(def.sql);
|
|
1269
|
+
} else {
|
|
1270
|
+
ddl = def.sql;
|
|
1271
|
+
}
|
|
1272
|
+
ddl = ddl.replace(new RegExp(`\\b${def.name}\\b`, "g"), prefixedName);
|
|
1273
|
+
for (const stmt of this.splitStatements(ddl)) {
|
|
1274
|
+
await this.db.run(stmt);
|
|
1275
|
+
}
|
|
1276
|
+
if (def.indexes) {
|
|
1277
|
+
for (const idx of def.indexes) {
|
|
1278
|
+
const prefixedIdx = idx.replace(new RegExp(`\\b${def.name}\\b`, "g"), prefixedName);
|
|
1279
|
+
await this.db.run(prefixedIdx);
|
|
1280
|
+
}
|
|
1281
|
+
}
|
|
1282
|
+
}
|
|
1283
|
+
/**
|
|
1284
|
+
* Run arbitrary SQL — for custom queries on dynamic tables.
|
|
1285
|
+
* Returns rows for SELECT, void for mutations.
|
|
1286
|
+
*/
|
|
1287
|
+
async query(sql, params) {
|
|
1288
|
+
return this.db.all(sql, params);
|
|
1289
|
+
}
|
|
1290
|
+
async execute(sql, params) {
|
|
1291
|
+
return this.db.run(sql, params);
|
|
1292
|
+
}
|
|
1293
|
+
/**
|
|
1294
|
+
* List all dynamic (ext_*) tables currently in the database.
|
|
1295
|
+
*/
|
|
1296
|
+
async listDynamicTables() {
|
|
1297
|
+
if (this.dialect === "postgres") {
|
|
1298
|
+
const rows = await this.db.all(
|
|
1299
|
+
"SELECT tablename FROM pg_tables WHERE schemaname = 'public' AND tablename LIKE 'ext_%'"
|
|
1300
|
+
);
|
|
1301
|
+
return rows.map((r) => r.tablename);
|
|
1302
|
+
} else if (this.dialect === "mysql") {
|
|
1303
|
+
const rows = await this.db.all(
|
|
1304
|
+
"SELECT table_name FROM information_schema.tables WHERE table_schema = DATABASE() AND table_name LIKE 'ext_%'"
|
|
1305
|
+
);
|
|
1306
|
+
return rows.map((r) => r.table_name);
|
|
1307
|
+
} else {
|
|
1308
|
+
const rows = await this.db.all(
|
|
1309
|
+
"SELECT name FROM sqlite_master WHERE type='table' AND name LIKE 'ext_%'"
|
|
1310
|
+
);
|
|
1311
|
+
return rows.map((r) => r.name);
|
|
1312
|
+
}
|
|
1313
|
+
}
|
|
1314
|
+
// ─── Helpers ────────────────────────────────────────
|
|
1315
|
+
splitStatements(sql) {
|
|
1316
|
+
return sql.split(";").map((s) => s.trim()).filter((s) => s.length > 0);
|
|
1317
|
+
}
|
|
1318
|
+
getSqlForDialect(migration) {
|
|
1319
|
+
if (this.dialect === "postgres" && migration.postgres) return migration.postgres;
|
|
1320
|
+
if (this.dialect === "mysql" && migration.mysql) return migration.mysql;
|
|
1321
|
+
if (this.dialect === "postgres" && migration.sql) return sqliteToPostgres(migration.sql);
|
|
1322
|
+
if (this.dialect === "mysql" && migration.sql) return sqliteToMySQL(migration.sql);
|
|
1323
|
+
return migration.sql;
|
|
1324
|
+
}
|
|
1325
|
+
// ─── Managed Agents ─────────────────────────────────
|
|
1326
|
+
async upsertManagedAgent(agent) {
|
|
1327
|
+
await this.db.run(`
|
|
1328
|
+
INSERT INTO managed_agents (id, org_id, name, display_name, state, config, health, usage, permission_profile_id, version, last_deployed_at, last_health_check_at, created_at, updated_at)
|
|
1329
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
1330
|
+
ON CONFLICT(id) DO UPDATE SET
|
|
1331
|
+
state = excluded.state,
|
|
1332
|
+
config = excluded.config,
|
|
1333
|
+
health = excluded.health,
|
|
1334
|
+
usage = excluded.usage,
|
|
1335
|
+
permission_profile_id = excluded.permission_profile_id,
|
|
1336
|
+
version = excluded.version,
|
|
1337
|
+
last_deployed_at = excluded.last_deployed_at,
|
|
1338
|
+
last_health_check_at = excluded.last_health_check_at,
|
|
1339
|
+
updated_at = excluded.updated_at
|
|
1340
|
+
`, [
|
|
1341
|
+
agent.id,
|
|
1342
|
+
agent.orgId,
|
|
1343
|
+
agent.config.name,
|
|
1344
|
+
agent.config.displayName,
|
|
1345
|
+
agent.state,
|
|
1346
|
+
JSON.stringify(agent.config),
|
|
1347
|
+
JSON.stringify(agent.health),
|
|
1348
|
+
JSON.stringify(agent.usage),
|
|
1349
|
+
agent.config.permissionProfileId,
|
|
1350
|
+
agent.version,
|
|
1351
|
+
agent.lastDeployedAt || null,
|
|
1352
|
+
agent.lastHealthCheckAt || null,
|
|
1353
|
+
agent.createdAt,
|
|
1354
|
+
agent.updatedAt
|
|
1355
|
+
]);
|
|
1356
|
+
}
|
|
1357
|
+
async getManagedAgent(id) {
|
|
1358
|
+
const row = await this.db.get("SELECT * FROM managed_agents WHERE id = ?", [id]);
|
|
1359
|
+
return row ? this.rowToManagedAgent(row) : null;
|
|
1360
|
+
}
|
|
1361
|
+
async getManagedAgentsByOrg(orgId) {
|
|
1362
|
+
const rows = await this.db.all("SELECT * FROM managed_agents WHERE org_id = ? ORDER BY created_at DESC", [orgId]);
|
|
1363
|
+
return rows.map((r) => this.rowToManagedAgent(r));
|
|
1364
|
+
}
|
|
1365
|
+
async getManagedAgentsByState(state) {
|
|
1366
|
+
const rows = await this.db.all("SELECT * FROM managed_agents WHERE state = ?", [state]);
|
|
1367
|
+
return rows.map((r) => this.rowToManagedAgent(r));
|
|
1368
|
+
}
|
|
1369
|
+
async getAllManagedAgents() {
|
|
1370
|
+
const rows = await this.db.all("SELECT * FROM managed_agents ORDER BY created_at DESC");
|
|
1371
|
+
return rows.map((r) => this.rowToManagedAgent(r));
|
|
1372
|
+
}
|
|
1373
|
+
async deleteManagedAgent(id) {
|
|
1374
|
+
await this.db.run("DELETE FROM managed_agents WHERE id = ?", [id]);
|
|
1375
|
+
}
|
|
1376
|
+
async countManagedAgents(orgId, state) {
|
|
1377
|
+
const sql = state ? "SELECT COUNT(*) as count FROM managed_agents WHERE org_id = ? AND state = ?" : "SELECT COUNT(*) as count FROM managed_agents WHERE org_id = ?";
|
|
1378
|
+
const row = await this.db.get(sql, state ? [orgId, state] : [orgId]);
|
|
1379
|
+
return row?.count || 0;
|
|
1380
|
+
}
|
|
1381
|
+
// ─── State History ──────────────────────────────────
|
|
1382
|
+
async addStateTransition(agentId, transition) {
|
|
1383
|
+
await this.db.run(`
|
|
1384
|
+
INSERT INTO agent_state_history (id, agent_id, from_state, to_state, reason, triggered_by, error, created_at)
|
|
1385
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?)
|
|
1386
|
+
`, [
|
|
1387
|
+
crypto.randomUUID(),
|
|
1388
|
+
agentId,
|
|
1389
|
+
transition.from,
|
|
1390
|
+
transition.to,
|
|
1391
|
+
transition.reason,
|
|
1392
|
+
transition.triggeredBy,
|
|
1393
|
+
transition.error || null,
|
|
1394
|
+
transition.timestamp
|
|
1395
|
+
]);
|
|
1396
|
+
}
|
|
1397
|
+
async getStateHistory(agentId, limit = 50) {
|
|
1398
|
+
const rows = await this.db.all(
|
|
1399
|
+
"SELECT * FROM agent_state_history WHERE agent_id = ? ORDER BY created_at DESC LIMIT ?",
|
|
1400
|
+
[agentId, limit]
|
|
1401
|
+
);
|
|
1402
|
+
return rows.map((r) => ({
|
|
1403
|
+
from: r.from_state,
|
|
1404
|
+
to: r.to_state,
|
|
1405
|
+
reason: r.reason,
|
|
1406
|
+
triggeredBy: r.triggered_by,
|
|
1407
|
+
timestamp: r.created_at,
|
|
1408
|
+
error: r.error
|
|
1409
|
+
}));
|
|
1410
|
+
}
|
|
1411
|
+
// ─── Permission Profiles ────────────────────────────
|
|
1412
|
+
async upsertPermissionProfile(orgId, profile) {
|
|
1413
|
+
await this.db.run(`
|
|
1414
|
+
INSERT INTO permission_profiles (id, org_id, name, description, config, is_preset, created_at, updated_at)
|
|
1415
|
+
VALUES (?, ?, ?, ?, ?, 0, ?, ?)
|
|
1416
|
+
ON CONFLICT(id) DO UPDATE SET
|
|
1417
|
+
name = excluded.name, description = excluded.description,
|
|
1418
|
+
config = excluded.config, updated_at = excluded.updated_at
|
|
1419
|
+
`, [
|
|
1420
|
+
profile.id,
|
|
1421
|
+
orgId,
|
|
1422
|
+
profile.name,
|
|
1423
|
+
profile.description || null,
|
|
1424
|
+
JSON.stringify(profile),
|
|
1425
|
+
profile.createdAt,
|
|
1426
|
+
profile.updatedAt
|
|
1427
|
+
]);
|
|
1428
|
+
}
|
|
1429
|
+
async getPermissionProfile(id) {
|
|
1430
|
+
const row = await this.db.get("SELECT * FROM permission_profiles WHERE id = ?", [id]);
|
|
1431
|
+
return row ? JSON.parse(row.config) : null;
|
|
1432
|
+
}
|
|
1433
|
+
async getPermissionProfilesByOrg(orgId) {
|
|
1434
|
+
const rows = await this.db.all("SELECT config FROM permission_profiles WHERE org_id = ? ORDER BY name", [orgId]);
|
|
1435
|
+
return rows.map((r) => JSON.parse(r.config));
|
|
1436
|
+
}
|
|
1437
|
+
async deletePermissionProfile(id) {
|
|
1438
|
+
await this.db.run("DELETE FROM permission_profiles WHERE id = ?", [id]);
|
|
1439
|
+
}
|
|
1440
|
+
// ─── Organizations ──────────────────────────────────
|
|
1441
|
+
async upsertOrganization(org) {
|
|
1442
|
+
await this.db.run(`
|
|
1443
|
+
INSERT INTO organizations (id, name, slug, plan, limits, usage, settings, sso_config, allowed_domains, billing, created_at, updated_at)
|
|
1444
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
1445
|
+
ON CONFLICT(id) DO UPDATE SET
|
|
1446
|
+
name = excluded.name, slug = excluded.slug, plan = excluded.plan,
|
|
1447
|
+
limits = excluded.limits, usage = excluded.usage, settings = excluded.settings,
|
|
1448
|
+
sso_config = excluded.sso_config, allowed_domains = excluded.allowed_domains,
|
|
1449
|
+
billing = excluded.billing, updated_at = excluded.updated_at
|
|
1450
|
+
`, [
|
|
1451
|
+
org.id,
|
|
1452
|
+
org.name,
|
|
1453
|
+
org.slug,
|
|
1454
|
+
org.plan,
|
|
1455
|
+
JSON.stringify(org.limits),
|
|
1456
|
+
JSON.stringify(org.usage),
|
|
1457
|
+
JSON.stringify(org.settings),
|
|
1458
|
+
org.ssoConfig ? JSON.stringify(org.ssoConfig) : null,
|
|
1459
|
+
JSON.stringify(org.allowedDomains),
|
|
1460
|
+
org.billing ? JSON.stringify(org.billing) : null,
|
|
1461
|
+
org.createdAt,
|
|
1462
|
+
org.updatedAt
|
|
1463
|
+
]);
|
|
1464
|
+
}
|
|
1465
|
+
async getOrganization(id) {
|
|
1466
|
+
const row = await this.db.get("SELECT * FROM organizations WHERE id = ?", [id]);
|
|
1467
|
+
return row ? this.rowToOrg(row) : null;
|
|
1468
|
+
}
|
|
1469
|
+
async getOrganizationBySlug(slug) {
|
|
1470
|
+
const row = await this.db.get("SELECT * FROM organizations WHERE slug = ?", [slug]);
|
|
1471
|
+
return row ? this.rowToOrg(row) : null;
|
|
1472
|
+
}
|
|
1473
|
+
async listOrganizations() {
|
|
1474
|
+
const rows = await this.db.all("SELECT * FROM organizations ORDER BY created_at DESC");
|
|
1475
|
+
return rows.map((r) => this.rowToOrg(r));
|
|
1476
|
+
}
|
|
1477
|
+
async deleteOrganization(id) {
|
|
1478
|
+
await this.db.run("DELETE FROM organizations WHERE id = ?", [id]);
|
|
1479
|
+
}
|
|
1480
|
+
// ─── Knowledge Bases ────────────────────────────────
|
|
1481
|
+
async upsertKnowledgeBase(kb) {
|
|
1482
|
+
await this.db.run(`
|
|
1483
|
+
INSERT INTO knowledge_bases (id, org_id, name, description, agent_ids, config, stats, created_at, updated_at)
|
|
1484
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
1485
|
+
ON CONFLICT(id) DO UPDATE SET
|
|
1486
|
+
name = excluded.name, description = excluded.description,
|
|
1487
|
+
agent_ids = excluded.agent_ids, config = excluded.config,
|
|
1488
|
+
stats = excluded.stats, updated_at = excluded.updated_at
|
|
1489
|
+
`, [
|
|
1490
|
+
kb.id,
|
|
1491
|
+
kb.orgId,
|
|
1492
|
+
kb.name,
|
|
1493
|
+
kb.description || null,
|
|
1494
|
+
JSON.stringify(kb.agentIds),
|
|
1495
|
+
JSON.stringify(kb.config),
|
|
1496
|
+
JSON.stringify(kb.stats),
|
|
1497
|
+
kb.createdAt,
|
|
1498
|
+
kb.updatedAt
|
|
1499
|
+
]);
|
|
1500
|
+
}
|
|
1501
|
+
async getKnowledgeBase(id) {
|
|
1502
|
+
const row = await this.db.get("SELECT * FROM knowledge_bases WHERE id = ?", [id]);
|
|
1503
|
+
if (!row) return null;
|
|
1504
|
+
const kb = {
|
|
1505
|
+
id: row.id,
|
|
1506
|
+
orgId: row.org_id,
|
|
1507
|
+
name: row.name,
|
|
1508
|
+
description: row.description,
|
|
1509
|
+
agentIds: JSON.parse(row.agent_ids),
|
|
1510
|
+
config: JSON.parse(row.config),
|
|
1511
|
+
stats: JSON.parse(row.stats),
|
|
1512
|
+
createdAt: row.created_at,
|
|
1513
|
+
updatedAt: row.updated_at,
|
|
1514
|
+
documents: []
|
|
1515
|
+
};
|
|
1516
|
+
kb.documents = await this.getKBDocuments(id);
|
|
1517
|
+
return kb;
|
|
1518
|
+
}
|
|
1519
|
+
async getKnowledgeBasesByOrg(orgId) {
|
|
1520
|
+
const rows = await this.db.all("SELECT * FROM knowledge_bases WHERE org_id = ? ORDER BY name", [orgId]);
|
|
1521
|
+
return rows.map((r) => ({
|
|
1522
|
+
id: r.id,
|
|
1523
|
+
orgId: r.org_id,
|
|
1524
|
+
name: r.name,
|
|
1525
|
+
description: r.description,
|
|
1526
|
+
agentIds: JSON.parse(r.agent_ids),
|
|
1527
|
+
config: JSON.parse(r.config),
|
|
1528
|
+
stats: JSON.parse(r.stats),
|
|
1529
|
+
createdAt: r.created_at,
|
|
1530
|
+
updatedAt: r.updated_at,
|
|
1531
|
+
documents: []
|
|
1532
|
+
// Loaded on demand
|
|
1533
|
+
}));
|
|
1534
|
+
}
|
|
1535
|
+
async deleteKnowledgeBase(id) {
|
|
1536
|
+
await this.db.run("DELETE FROM knowledge_bases WHERE id = ?", [id]);
|
|
1537
|
+
}
|
|
1538
|
+
// ─── KB Documents & Chunks ──────────────────────────
|
|
1539
|
+
async insertKBDocument(doc) {
|
|
1540
|
+
await this.db.run(`
|
|
1541
|
+
INSERT INTO kb_documents (id, knowledge_base_id, name, source_type, source_url, mime_type, size, metadata, status, error, created_at, updated_at)
|
|
1542
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
1543
|
+
`, [
|
|
1544
|
+
doc.id,
|
|
1545
|
+
doc.knowledgeBaseId,
|
|
1546
|
+
doc.name,
|
|
1547
|
+
doc.sourceType,
|
|
1548
|
+
doc.sourceUrl || null,
|
|
1549
|
+
doc.mimeType,
|
|
1550
|
+
doc.size,
|
|
1551
|
+
JSON.stringify(doc.metadata),
|
|
1552
|
+
doc.status,
|
|
1553
|
+
doc.error || null,
|
|
1554
|
+
doc.createdAt,
|
|
1555
|
+
doc.updatedAt
|
|
1556
|
+
]);
|
|
1557
|
+
for (const chunk of doc.chunks) {
|
|
1558
|
+
await this.db.run(`
|
|
1559
|
+
INSERT INTO kb_chunks (id, document_id, content, token_count, position, embedding, metadata)
|
|
1560
|
+
VALUES (?, ?, ?, ?, ?, ?, ?)
|
|
1561
|
+
`, [
|
|
1562
|
+
chunk.id,
|
|
1563
|
+
doc.id,
|
|
1564
|
+
chunk.content,
|
|
1565
|
+
chunk.tokenCount,
|
|
1566
|
+
chunk.position,
|
|
1567
|
+
chunk.embedding ? Buffer.from(new Float32Array(chunk.embedding).buffer) : null,
|
|
1568
|
+
JSON.stringify(chunk.metadata)
|
|
1569
|
+
]);
|
|
1570
|
+
}
|
|
1571
|
+
}
|
|
1572
|
+
async getKBDocuments(kbId) {
|
|
1573
|
+
const docs = await this.db.all("SELECT * FROM kb_documents WHERE knowledge_base_id = ?", [kbId]);
|
|
1574
|
+
const result = [];
|
|
1575
|
+
for (const d of docs) {
|
|
1576
|
+
const chunks = await this.db.all("SELECT * FROM kb_chunks WHERE document_id = ? ORDER BY position", [d.id]);
|
|
1577
|
+
result.push({
|
|
1578
|
+
id: d.id,
|
|
1579
|
+
knowledgeBaseId: d.knowledge_base_id,
|
|
1580
|
+
name: d.name,
|
|
1581
|
+
sourceType: d.source_type,
|
|
1582
|
+
sourceUrl: d.source_url,
|
|
1583
|
+
mimeType: d.mime_type,
|
|
1584
|
+
size: d.size,
|
|
1585
|
+
metadata: JSON.parse(d.metadata),
|
|
1586
|
+
status: d.status,
|
|
1587
|
+
error: d.error,
|
|
1588
|
+
createdAt: d.created_at,
|
|
1589
|
+
updatedAt: d.updated_at,
|
|
1590
|
+
chunks: chunks.map((c) => ({
|
|
1591
|
+
id: c.id,
|
|
1592
|
+
documentId: c.document_id,
|
|
1593
|
+
content: c.content,
|
|
1594
|
+
tokenCount: c.token_count,
|
|
1595
|
+
position: c.position,
|
|
1596
|
+
embedding: c.embedding ? Array.from(new Float32Array(c.embedding)) : void 0,
|
|
1597
|
+
metadata: JSON.parse(c.metadata)
|
|
1598
|
+
}))
|
|
1599
|
+
});
|
|
1600
|
+
}
|
|
1601
|
+
return result;
|
|
1602
|
+
}
|
|
1603
|
+
async deleteKBDocument(docId) {
|
|
1604
|
+
await this.db.run("DELETE FROM kb_documents WHERE id = ?", [docId]);
|
|
1605
|
+
}
|
|
1606
|
+
// ─── Tool Calls (Activity) ──────────────────────────
|
|
1607
|
+
async insertToolCall(record) {
|
|
1608
|
+
await this.db.run(`
|
|
1609
|
+
INSERT INTO tool_calls (id, agent_id, org_id, session_id, tool_id, tool_name, parameters, result, timing, cost, permission, created_at)
|
|
1610
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
1611
|
+
`, [
|
|
1612
|
+
record.id,
|
|
1613
|
+
record.agentId,
|
|
1614
|
+
record.orgId,
|
|
1615
|
+
record.sessionId || null,
|
|
1616
|
+
record.toolId,
|
|
1617
|
+
record.toolName,
|
|
1618
|
+
JSON.stringify(record.parameters),
|
|
1619
|
+
record.result ? JSON.stringify(record.result) : null,
|
|
1620
|
+
JSON.stringify(record.timing),
|
|
1621
|
+
record.cost ? JSON.stringify(record.cost) : null,
|
|
1622
|
+
JSON.stringify(record.permission),
|
|
1623
|
+
record.timing.startedAt
|
|
1624
|
+
]);
|
|
1625
|
+
}
|
|
1626
|
+
async updateToolCallResult(id, result, timing, cost) {
|
|
1627
|
+
await this.db.run(
|
|
1628
|
+
"UPDATE tool_calls SET result = ?, timing = ?, cost = ? WHERE id = ?",
|
|
1629
|
+
[JSON.stringify(result), JSON.stringify(timing), cost ? JSON.stringify(cost) : null, id]
|
|
1630
|
+
);
|
|
1631
|
+
}
|
|
1632
|
+
async getToolCalls(opts) {
|
|
1633
|
+
const conditions = [];
|
|
1634
|
+
const params = [];
|
|
1635
|
+
if (opts.agentId) {
|
|
1636
|
+
conditions.push("agent_id = ?");
|
|
1637
|
+
params.push(opts.agentId);
|
|
1638
|
+
}
|
|
1639
|
+
if (opts.orgId) {
|
|
1640
|
+
conditions.push("org_id = ?");
|
|
1641
|
+
params.push(opts.orgId);
|
|
1642
|
+
}
|
|
1643
|
+
if (opts.toolId) {
|
|
1644
|
+
conditions.push("tool_id = ?");
|
|
1645
|
+
params.push(opts.toolId);
|
|
1646
|
+
}
|
|
1647
|
+
if (opts.since) {
|
|
1648
|
+
conditions.push("created_at >= ?");
|
|
1649
|
+
params.push(opts.since);
|
|
1650
|
+
}
|
|
1651
|
+
const where = conditions.length > 0 ? "WHERE " + conditions.join(" AND ") : "";
|
|
1652
|
+
params.push(opts.limit || 50);
|
|
1653
|
+
const rows = await this.db.all(`SELECT * FROM tool_calls ${where} ORDER BY created_at DESC LIMIT ?`, params);
|
|
1654
|
+
return rows.map((r) => ({
|
|
1655
|
+
id: r.id,
|
|
1656
|
+
agentId: r.agent_id,
|
|
1657
|
+
orgId: r.org_id,
|
|
1658
|
+
sessionId: r.session_id,
|
|
1659
|
+
toolId: r.tool_id,
|
|
1660
|
+
toolName: r.tool_name,
|
|
1661
|
+
parameters: JSON.parse(r.parameters || "{}"),
|
|
1662
|
+
result: r.result ? JSON.parse(r.result) : void 0,
|
|
1663
|
+
timing: JSON.parse(r.timing),
|
|
1664
|
+
cost: r.cost ? JSON.parse(r.cost) : void 0,
|
|
1665
|
+
permission: JSON.parse(r.permission)
|
|
1666
|
+
}));
|
|
1667
|
+
}
|
|
1668
|
+
// ─── Activity Events ────────────────────────────────
|
|
1669
|
+
async insertActivityEvent(event) {
|
|
1670
|
+
await this.db.run(`
|
|
1671
|
+
INSERT INTO activity_events (id, agent_id, org_id, session_id, type, data, created_at)
|
|
1672
|
+
VALUES (?, ?, ?, ?, ?, ?, ?)
|
|
1673
|
+
`, [event.id, event.agentId, event.orgId, event.sessionId || null, event.type, JSON.stringify(event.data), event.timestamp]);
|
|
1674
|
+
}
|
|
1675
|
+
async getActivityEvents(opts) {
|
|
1676
|
+
const conditions = [];
|
|
1677
|
+
const params = [];
|
|
1678
|
+
if (opts.agentId) {
|
|
1679
|
+
conditions.push("agent_id = ?");
|
|
1680
|
+
params.push(opts.agentId);
|
|
1681
|
+
}
|
|
1682
|
+
if (opts.orgId) {
|
|
1683
|
+
conditions.push("org_id = ?");
|
|
1684
|
+
params.push(opts.orgId);
|
|
1685
|
+
}
|
|
1686
|
+
if (opts.types?.length) {
|
|
1687
|
+
conditions.push(`type IN (${opts.types.map(() => "?").join(",")})`);
|
|
1688
|
+
params.push(...opts.types);
|
|
1689
|
+
}
|
|
1690
|
+
if (opts.since) {
|
|
1691
|
+
conditions.push("created_at >= ?");
|
|
1692
|
+
params.push(opts.since);
|
|
1693
|
+
}
|
|
1694
|
+
const where = conditions.length > 0 ? "WHERE " + conditions.join(" AND ") : "";
|
|
1695
|
+
params.push(opts.limit || 50);
|
|
1696
|
+
const rows = await this.db.all(`SELECT * FROM activity_events ${where} ORDER BY created_at DESC LIMIT ?`, params);
|
|
1697
|
+
return rows.map((r) => ({
|
|
1698
|
+
id: r.id,
|
|
1699
|
+
agentId: r.agent_id,
|
|
1700
|
+
orgId: r.org_id,
|
|
1701
|
+
sessionId: r.session_id,
|
|
1702
|
+
type: r.type,
|
|
1703
|
+
data: JSON.parse(r.data),
|
|
1704
|
+
timestamp: r.created_at
|
|
1705
|
+
}));
|
|
1706
|
+
}
|
|
1707
|
+
// ─── Conversations ──────────────────────────────────
|
|
1708
|
+
async insertConversation(entry) {
|
|
1709
|
+
await this.db.run(`
|
|
1710
|
+
INSERT INTO conversations (id, agent_id, session_id, role, content, channel, token_count, tool_calls, created_at)
|
|
1711
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
1712
|
+
`, [
|
|
1713
|
+
entry.id,
|
|
1714
|
+
entry.agentId,
|
|
1715
|
+
entry.sessionId,
|
|
1716
|
+
entry.role,
|
|
1717
|
+
entry.content,
|
|
1718
|
+
entry.channel || null,
|
|
1719
|
+
entry.tokenCount,
|
|
1720
|
+
entry.toolCalls ? JSON.stringify(entry.toolCalls) : null,
|
|
1721
|
+
entry.timestamp
|
|
1722
|
+
]);
|
|
1723
|
+
}
|
|
1724
|
+
async getConversation(sessionId, limit = 50) {
|
|
1725
|
+
const rows = await this.db.all(
|
|
1726
|
+
"SELECT * FROM conversations WHERE session_id = ? ORDER BY created_at ASC LIMIT ?",
|
|
1727
|
+
[sessionId, limit]
|
|
1728
|
+
);
|
|
1729
|
+
return rows.map((r) => ({
|
|
1730
|
+
id: r.id,
|
|
1731
|
+
agentId: r.agent_id,
|
|
1732
|
+
sessionId: r.session_id,
|
|
1733
|
+
role: r.role,
|
|
1734
|
+
content: r.content,
|
|
1735
|
+
channel: r.channel,
|
|
1736
|
+
tokenCount: r.token_count,
|
|
1737
|
+
toolCalls: r.tool_calls ? JSON.parse(r.tool_calls) : void 0,
|
|
1738
|
+
timestamp: r.created_at
|
|
1739
|
+
}));
|
|
1740
|
+
}
|
|
1741
|
+
// ─── Approval Requests ──────────────────────────────
|
|
1742
|
+
async insertApprovalRequest(req, orgId) {
|
|
1743
|
+
await this.db.run(`
|
|
1744
|
+
INSERT INTO approval_requests (id, agent_id, agent_name, org_id, tool_id, tool_name, reason, risk_level, side_effects, parameters, context, status, decision, expires_at, created_at)
|
|
1745
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
1746
|
+
`, [
|
|
1747
|
+
req.id,
|
|
1748
|
+
req.agentId,
|
|
1749
|
+
req.agentName,
|
|
1750
|
+
orgId,
|
|
1751
|
+
req.toolId,
|
|
1752
|
+
req.toolName,
|
|
1753
|
+
req.reason,
|
|
1754
|
+
req.riskLevel,
|
|
1755
|
+
JSON.stringify(req.sideEffects),
|
|
1756
|
+
req.parameters ? JSON.stringify(req.parameters) : null,
|
|
1757
|
+
req.context || null,
|
|
1758
|
+
req.status,
|
|
1759
|
+
req.decision ? JSON.stringify(req.decision) : null,
|
|
1760
|
+
req.expiresAt,
|
|
1761
|
+
req.createdAt
|
|
1762
|
+
]);
|
|
1763
|
+
}
|
|
1764
|
+
async updateApprovalRequest(id, status, decision) {
|
|
1765
|
+
await this.db.run(
|
|
1766
|
+
"UPDATE approval_requests SET status = ?, decision = ? WHERE id = ?",
|
|
1767
|
+
[status, decision ? JSON.stringify(decision) : null, id]
|
|
1768
|
+
);
|
|
1769
|
+
}
|
|
1770
|
+
async getApprovalRequests(opts) {
|
|
1771
|
+
const conditions = [];
|
|
1772
|
+
const params = [];
|
|
1773
|
+
if (opts.orgId) {
|
|
1774
|
+
conditions.push("org_id = ?");
|
|
1775
|
+
params.push(opts.orgId);
|
|
1776
|
+
}
|
|
1777
|
+
if (opts.status) {
|
|
1778
|
+
conditions.push("status = ?");
|
|
1779
|
+
params.push(opts.status);
|
|
1780
|
+
}
|
|
1781
|
+
if (opts.agentId) {
|
|
1782
|
+
conditions.push("agent_id = ?");
|
|
1783
|
+
params.push(opts.agentId);
|
|
1784
|
+
}
|
|
1785
|
+
const where = conditions.length > 0 ? "WHERE " + conditions.join(" AND ") : "";
|
|
1786
|
+
params.push(opts.limit || 50);
|
|
1787
|
+
const rows = await this.db.all(`SELECT * FROM approval_requests ${where} ORDER BY created_at DESC LIMIT ?`, params);
|
|
1788
|
+
return rows.map((r) => ({
|
|
1789
|
+
id: r.id,
|
|
1790
|
+
agentId: r.agent_id,
|
|
1791
|
+
agentName: r.agent_name,
|
|
1792
|
+
toolId: r.tool_id,
|
|
1793
|
+
toolName: r.tool_name,
|
|
1794
|
+
reason: r.reason,
|
|
1795
|
+
riskLevel: r.risk_level,
|
|
1796
|
+
sideEffects: JSON.parse(r.side_effects),
|
|
1797
|
+
parameters: r.parameters ? JSON.parse(r.parameters) : void 0,
|
|
1798
|
+
context: r.context,
|
|
1799
|
+
status: r.status,
|
|
1800
|
+
decision: r.decision ? JSON.parse(r.decision) : void 0,
|
|
1801
|
+
createdAt: r.created_at,
|
|
1802
|
+
expiresAt: r.expires_at
|
|
1803
|
+
}));
|
|
1804
|
+
}
|
|
1805
|
+
// ─── Approval Policies ──────────────────────────────
|
|
1806
|
+
async upsertApprovalPolicy(orgId, policy) {
|
|
1807
|
+
await this.db.run(`
|
|
1808
|
+
INSERT INTO approval_policies (id, org_id, name, description, triggers, approvers, timeout, notify, enabled, created_at, updated_at)
|
|
1809
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
1810
|
+
ON CONFLICT(id) DO UPDATE SET
|
|
1811
|
+
name = excluded.name, description = excluded.description,
|
|
1812
|
+
triggers = excluded.triggers, approvers = excluded.approvers,
|
|
1813
|
+
timeout = excluded.timeout, notify = excluded.notify,
|
|
1814
|
+
enabled = excluded.enabled, updated_at = excluded.updated_at
|
|
1815
|
+
`, [
|
|
1816
|
+
policy.id,
|
|
1817
|
+
orgId,
|
|
1818
|
+
policy.name,
|
|
1819
|
+
policy.description || null,
|
|
1820
|
+
JSON.stringify(policy.triggers),
|
|
1821
|
+
JSON.stringify(policy.approvers),
|
|
1822
|
+
JSON.stringify(policy.timeout),
|
|
1823
|
+
JSON.stringify(policy.notify),
|
|
1824
|
+
policy.enabled ? 1 : 0,
|
|
1825
|
+
(/* @__PURE__ */ new Date()).toISOString(),
|
|
1826
|
+
(/* @__PURE__ */ new Date()).toISOString()
|
|
1827
|
+
]);
|
|
1828
|
+
}
|
|
1829
|
+
async getApprovalPolicies(orgId) {
|
|
1830
|
+
const rows = await this.db.all("SELECT * FROM approval_policies WHERE org_id = ? ORDER BY name", [orgId]);
|
|
1831
|
+
return rows.map((r) => ({
|
|
1832
|
+
id: r.id,
|
|
1833
|
+
name: r.name,
|
|
1834
|
+
description: r.description,
|
|
1835
|
+
triggers: JSON.parse(r.triggers),
|
|
1836
|
+
approvers: JSON.parse(r.approvers),
|
|
1837
|
+
timeout: JSON.parse(r.timeout),
|
|
1838
|
+
notify: JSON.parse(r.notify),
|
|
1839
|
+
enabled: !!r.enabled
|
|
1840
|
+
}));
|
|
1841
|
+
}
|
|
1842
|
+
async getAllApprovalPolicies() {
|
|
1843
|
+
const rows = await this.db.all("SELECT * FROM approval_policies WHERE enabled = 1 ORDER BY name");
|
|
1844
|
+
return rows.map((r) => ({
|
|
1845
|
+
id: r.id,
|
|
1846
|
+
name: r.name,
|
|
1847
|
+
description: r.description,
|
|
1848
|
+
triggers: JSON.parse(r.triggers),
|
|
1849
|
+
approvers: JSON.parse(r.approvers),
|
|
1850
|
+
timeout: JSON.parse(r.timeout),
|
|
1851
|
+
notify: JSON.parse(r.notify),
|
|
1852
|
+
enabled: !!r.enabled
|
|
1853
|
+
}));
|
|
1854
|
+
}
|
|
1855
|
+
async deleteApprovalPolicy(id) {
|
|
1856
|
+
await this.db.run("DELETE FROM approval_policies WHERE id = ?", [id]);
|
|
1857
|
+
}
|
|
1858
|
+
// ─── SSO Integrations ─────────────────────────────
|
|
1859
|
+
async upsertSsoIntegration(integration) {
|
|
1860
|
+
await this.db.run(`
|
|
1861
|
+
INSERT INTO sso_integrations (id, org_id, provider_type, name, enabled, config, metadata_url, created_at, updated_at)
|
|
1862
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
1863
|
+
ON CONFLICT(id) DO UPDATE SET
|
|
1864
|
+
name = excluded.name, enabled = excluded.enabled,
|
|
1865
|
+
config = excluded.config, metadata_url = excluded.metadata_url,
|
|
1866
|
+
updated_at = excluded.updated_at
|
|
1867
|
+
`, [
|
|
1868
|
+
integration.id,
|
|
1869
|
+
integration.orgId,
|
|
1870
|
+
integration.providerType,
|
|
1871
|
+
integration.name,
|
|
1872
|
+
integration.enabled ? 1 : 0,
|
|
1873
|
+
JSON.stringify(integration.config),
|
|
1874
|
+
integration.metadataUrl || null,
|
|
1875
|
+
(/* @__PURE__ */ new Date()).toISOString(),
|
|
1876
|
+
(/* @__PURE__ */ new Date()).toISOString()
|
|
1877
|
+
]);
|
|
1878
|
+
}
|
|
1879
|
+
async getSsoIntegration(id) {
|
|
1880
|
+
const row = await this.db.get("SELECT * FROM sso_integrations WHERE id = ?", [id]);
|
|
1881
|
+
return row ? this.rowToSso(row) : null;
|
|
1882
|
+
}
|
|
1883
|
+
async getSsoIntegrationsByOrg(orgId) {
|
|
1884
|
+
const rows = await this.db.all("SELECT * FROM sso_integrations WHERE org_id = ? ORDER BY name", [orgId]);
|
|
1885
|
+
return rows.map((r) => this.rowToSso(r));
|
|
1886
|
+
}
|
|
1887
|
+
async getSsoIntegrationByType(orgId, providerType) {
|
|
1888
|
+
const row = await this.db.get("SELECT * FROM sso_integrations WHERE org_id = ? AND provider_type = ? AND enabled = 1", [orgId, providerType]);
|
|
1889
|
+
return row ? this.rowToSso(row) : null;
|
|
1890
|
+
}
|
|
1891
|
+
async deleteSsoIntegration(id) {
|
|
1892
|
+
await this.db.run("DELETE FROM sso_integrations WHERE id = ?", [id]);
|
|
1893
|
+
}
|
|
1894
|
+
rowToSso(row) {
|
|
1895
|
+
return {
|
|
1896
|
+
id: row.id,
|
|
1897
|
+
orgId: row.org_id,
|
|
1898
|
+
providerType: row.provider_type,
|
|
1899
|
+
name: row.name,
|
|
1900
|
+
enabled: !!row.enabled,
|
|
1901
|
+
config: JSON.parse(row.config),
|
|
1902
|
+
metadataUrl: row.metadata_url,
|
|
1903
|
+
createdAt: row.created_at,
|
|
1904
|
+
updatedAt: row.updated_at
|
|
1905
|
+
};
|
|
1906
|
+
}
|
|
1907
|
+
// ─── OIDC State Tracking ─────────────────────────
|
|
1908
|
+
async saveOidcState(state, providerId, opts) {
|
|
1909
|
+
const expiresAt = new Date(Date.now() + (opts.ttlSeconds || 600) * 1e3).toISOString();
|
|
1910
|
+
await this.db.run(`
|
|
1911
|
+
INSERT INTO oidc_states (state, provider_id, redirect_uri, nonce, code_verifier, created_at, expires_at)
|
|
1912
|
+
VALUES (?, ?, ?, ?, ?, ?, ?)
|
|
1913
|
+
`, [state, providerId, opts.redirectUri || null, opts.nonce || null, opts.codeVerifier || null, (/* @__PURE__ */ new Date()).toISOString(), expiresAt]);
|
|
1914
|
+
}
|
|
1915
|
+
async getOidcState(state) {
|
|
1916
|
+
const row = await this.db.get("SELECT * FROM oidc_states WHERE state = ?", [state]);
|
|
1917
|
+
if (!row) return null;
|
|
1918
|
+
if (new Date(row.expires_at) < /* @__PURE__ */ new Date()) {
|
|
1919
|
+
await this.db.run("DELETE FROM oidc_states WHERE state = ?", [state]);
|
|
1920
|
+
return null;
|
|
1921
|
+
}
|
|
1922
|
+
return {
|
|
1923
|
+
state: row.state,
|
|
1924
|
+
providerId: row.provider_id,
|
|
1925
|
+
redirectUri: row.redirect_uri,
|
|
1926
|
+
nonce: row.nonce,
|
|
1927
|
+
codeVerifier: row.code_verifier,
|
|
1928
|
+
expiresAt: row.expires_at
|
|
1929
|
+
};
|
|
1930
|
+
}
|
|
1931
|
+
async deleteOidcState(state) {
|
|
1932
|
+
await this.db.run("DELETE FROM oidc_states WHERE state = ?", [state]);
|
|
1933
|
+
}
|
|
1934
|
+
async cleanupExpiredOidcStates() {
|
|
1935
|
+
await this.db.run("DELETE FROM oidc_states WHERE expires_at < ?", [(/* @__PURE__ */ new Date()).toISOString()]);
|
|
1936
|
+
}
|
|
1937
|
+
// ─── Deploy Credentials ─────────────────────────
|
|
1938
|
+
async upsertDeployCredential(cred) {
|
|
1939
|
+
await this.db.run(`
|
|
1940
|
+
INSERT INTO deploy_credentials (id, org_id, name, target_type, config, created_by, created_at, updated_at)
|
|
1941
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?)
|
|
1942
|
+
ON CONFLICT(id) DO UPDATE SET
|
|
1943
|
+
name = excluded.name, target_type = excluded.target_type,
|
|
1944
|
+
config = excluded.config, updated_at = excluded.updated_at
|
|
1945
|
+
`, [
|
|
1946
|
+
cred.id,
|
|
1947
|
+
cred.orgId,
|
|
1948
|
+
cred.name,
|
|
1949
|
+
cred.targetType,
|
|
1950
|
+
JSON.stringify(cred.config),
|
|
1951
|
+
cred.createdBy,
|
|
1952
|
+
(/* @__PURE__ */ new Date()).toISOString(),
|
|
1953
|
+
(/* @__PURE__ */ new Date()).toISOString()
|
|
1954
|
+
]);
|
|
1955
|
+
}
|
|
1956
|
+
async getDeployCredential(id) {
|
|
1957
|
+
const row = await this.db.get("SELECT * FROM deploy_credentials WHERE id = ?", [id]);
|
|
1958
|
+
return row ? this.rowToDeployCred(row) : null;
|
|
1959
|
+
}
|
|
1960
|
+
async getDeployCredentialsByOrg(orgId) {
|
|
1961
|
+
const rows = await this.db.all("SELECT * FROM deploy_credentials WHERE org_id = ? ORDER BY name", [orgId]);
|
|
1962
|
+
return rows.map((r) => this.rowToDeployCred(r));
|
|
1963
|
+
}
|
|
1964
|
+
async getDeployCredentialsByType(orgId, targetType) {
|
|
1965
|
+
const rows = await this.db.all("SELECT * FROM deploy_credentials WHERE org_id = ? AND target_type = ?", [orgId, targetType]);
|
|
1966
|
+
return rows.map((r) => this.rowToDeployCred(r));
|
|
1967
|
+
}
|
|
1968
|
+
async deleteDeployCredential(id) {
|
|
1969
|
+
await this.db.run("DELETE FROM deploy_credentials WHERE id = ?", [id]);
|
|
1970
|
+
}
|
|
1971
|
+
rowToDeployCred(row) {
|
|
1972
|
+
return {
|
|
1973
|
+
id: row.id,
|
|
1974
|
+
orgId: row.org_id,
|
|
1975
|
+
name: row.name,
|
|
1976
|
+
targetType: row.target_type,
|
|
1977
|
+
config: JSON.parse(row.config),
|
|
1978
|
+
createdBy: row.created_by,
|
|
1979
|
+
createdAt: row.created_at,
|
|
1980
|
+
updatedAt: row.updated_at
|
|
1981
|
+
};
|
|
1982
|
+
}
|
|
1983
|
+
// ─── Aggregate Stats ───────────────────────────────
|
|
1984
|
+
async getEngineStats(orgId) {
|
|
1985
|
+
const today = (/* @__PURE__ */ new Date()).toISOString().split("T")[0];
|
|
1986
|
+
const [agents, running, toolCalls, activity, approvals, kbs] = await Promise.all([
|
|
1987
|
+
this.db.get("SELECT COUNT(*) as c FROM managed_agents WHERE org_id = ?", [orgId]),
|
|
1988
|
+
this.db.get("SELECT COUNT(*) as c FROM managed_agents WHERE org_id = ? AND state = ?", [orgId, "running"]),
|
|
1989
|
+
this.db.get("SELECT COUNT(*) as c FROM tool_calls WHERE org_id = ? AND created_at >= ?", [orgId, today]),
|
|
1990
|
+
this.db.get("SELECT COUNT(*) as c FROM activity_events WHERE org_id = ? AND created_at >= ?", [orgId, today]),
|
|
1991
|
+
this.db.get("SELECT COUNT(*) as c FROM approval_requests WHERE org_id = ? AND status = ?", [orgId, "pending"]),
|
|
1992
|
+
this.db.get("SELECT COUNT(*) as c FROM knowledge_bases WHERE org_id = ?", [orgId])
|
|
1993
|
+
]);
|
|
1994
|
+
return {
|
|
1995
|
+
totalManagedAgents: agents?.c || 0,
|
|
1996
|
+
runningAgents: running?.c || 0,
|
|
1997
|
+
totalToolCallsToday: toolCalls?.c || 0,
|
|
1998
|
+
totalActivityToday: activity?.c || 0,
|
|
1999
|
+
pendingApprovals: approvals?.c || 0,
|
|
2000
|
+
totalKnowledgeBases: kbs?.c || 0
|
|
2001
|
+
};
|
|
2002
|
+
}
|
|
2003
|
+
/**
|
|
2004
|
+
* Cleanup old data based on retention
|
|
2005
|
+
*/
|
|
2006
|
+
async cleanup(retainDays) {
|
|
2007
|
+
const cutoff = new Date(Date.now() - retainDays * 864e5).toISOString();
|
|
2008
|
+
const tc = await this.db.get("SELECT COUNT(*) as c FROM tool_calls WHERE created_at < ?", [cutoff]);
|
|
2009
|
+
const ev = await this.db.get("SELECT COUNT(*) as c FROM activity_events WHERE created_at < ?", [cutoff]);
|
|
2010
|
+
const cv = await this.db.get("SELECT COUNT(*) as c FROM conversations WHERE created_at < ?", [cutoff]);
|
|
2011
|
+
await this.db.run("DELETE FROM tool_calls WHERE created_at < ?", [cutoff]);
|
|
2012
|
+
await this.db.run("DELETE FROM activity_events WHERE created_at < ?", [cutoff]);
|
|
2013
|
+
await this.db.run("DELETE FROM conversations WHERE created_at < ?", [cutoff]);
|
|
2014
|
+
return {
|
|
2015
|
+
toolCalls: tc?.c || 0,
|
|
2016
|
+
events: ev?.c || 0,
|
|
2017
|
+
conversations: cv?.c || 0
|
|
2018
|
+
};
|
|
2019
|
+
}
|
|
2020
|
+
// ─── Community Skill Index ──────────────────────────
|
|
2021
|
+
async upsertCommunitySkill(skill) {
|
|
2022
|
+
const now = (/* @__PURE__ */ new Date()).toISOString();
|
|
2023
|
+
await this.db.run(`
|
|
2024
|
+
INSERT INTO community_skill_index (id, name, description, version, author, repository, license, category, risk, icon, tags, tools, config_schema, min_engine_version, homepage, downloads, rating, rating_count, verified, featured, created_at, updated_at)
|
|
2025
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
2026
|
+
ON CONFLICT(id) DO UPDATE SET
|
|
2027
|
+
name = excluded.name, description = excluded.description, version = excluded.version,
|
|
2028
|
+
author = excluded.author, repository = excluded.repository, license = excluded.license,
|
|
2029
|
+
category = excluded.category, risk = excluded.risk, icon = excluded.icon,
|
|
2030
|
+
tags = excluded.tags, tools = excluded.tools, config_schema = excluded.config_schema,
|
|
2031
|
+
min_engine_version = excluded.min_engine_version, homepage = excluded.homepage,
|
|
2032
|
+
downloads = excluded.downloads, rating = excluded.rating, rating_count = excluded.rating_count,
|
|
2033
|
+
verified = excluded.verified, featured = excluded.featured,
|
|
2034
|
+
updated_at = excluded.updated_at
|
|
2035
|
+
`, [
|
|
2036
|
+
skill.id,
|
|
2037
|
+
skill.name,
|
|
2038
|
+
skill.description,
|
|
2039
|
+
skill.version,
|
|
2040
|
+
skill.author,
|
|
2041
|
+
skill.repository,
|
|
2042
|
+
skill.license,
|
|
2043
|
+
skill.category || null,
|
|
2044
|
+
skill.risk || "medium",
|
|
2045
|
+
skill.icon || null,
|
|
2046
|
+
JSON.stringify(skill.tags || []),
|
|
2047
|
+
JSON.stringify(skill.tools || []),
|
|
2048
|
+
JSON.stringify(skill.configSchema || {}),
|
|
2049
|
+
skill.minEngineVersion || null,
|
|
2050
|
+
skill.homepage || null,
|
|
2051
|
+
skill.downloads || 0,
|
|
2052
|
+
skill.rating || 0,
|
|
2053
|
+
skill.ratingCount || 0,
|
|
2054
|
+
skill.verified ? 1 : 0,
|
|
2055
|
+
skill.featured ? 1 : 0,
|
|
2056
|
+
now,
|
|
2057
|
+
now
|
|
2058
|
+
]);
|
|
2059
|
+
}
|
|
2060
|
+
async getCommunitySkill(id) {
|
|
2061
|
+
const row = await this.db.get("SELECT * FROM community_skill_index WHERE id = ?", [id]);
|
|
2062
|
+
return row ? this.rowToCommunitySkill(row) : null;
|
|
2063
|
+
}
|
|
2064
|
+
async getAllCommunitySkills(opts) {
|
|
2065
|
+
const conditions = [];
|
|
2066
|
+
const params = [];
|
|
2067
|
+
if (opts?.category) {
|
|
2068
|
+
conditions.push("category = ?");
|
|
2069
|
+
params.push(opts.category);
|
|
2070
|
+
}
|
|
2071
|
+
if (opts?.risk) {
|
|
2072
|
+
conditions.push("risk = ?");
|
|
2073
|
+
params.push(opts.risk);
|
|
2074
|
+
}
|
|
2075
|
+
if (opts?.author) {
|
|
2076
|
+
conditions.push("author = ?");
|
|
2077
|
+
params.push(opts.author);
|
|
2078
|
+
}
|
|
2079
|
+
if (opts?.verified !== void 0) {
|
|
2080
|
+
conditions.push("verified = ?");
|
|
2081
|
+
params.push(opts.verified ? 1 : 0);
|
|
2082
|
+
}
|
|
2083
|
+
if (opts?.featured !== void 0) {
|
|
2084
|
+
conditions.push("featured = ?");
|
|
2085
|
+
params.push(opts.featured ? 1 : 0);
|
|
2086
|
+
}
|
|
2087
|
+
if (opts?.tag) {
|
|
2088
|
+
conditions.push("tags LIKE ?");
|
|
2089
|
+
params.push(`%"${opts.tag}"%`);
|
|
2090
|
+
}
|
|
2091
|
+
if (opts?.search) {
|
|
2092
|
+
conditions.push("(name LIKE ? OR description LIKE ? OR author LIKE ?)");
|
|
2093
|
+
const q = `%${opts.search}%`;
|
|
2094
|
+
params.push(q, q, q);
|
|
2095
|
+
}
|
|
2096
|
+
const where = conditions.length > 0 ? "WHERE " + conditions.join(" AND ") : "";
|
|
2097
|
+
const sortCol = opts?.sortBy === "popular" ? "downloads" : opts?.sortBy === "rating" ? "rating" : opts?.sortBy === "name" ? "name" : "created_at";
|
|
2098
|
+
const sortOrder = opts?.order === "asc" ? "ASC" : "DESC";
|
|
2099
|
+
const limit = opts?.limit || 50;
|
|
2100
|
+
const offset = opts?.offset || 0;
|
|
2101
|
+
const countRow = await this.db.get(`SELECT COUNT(*) as c FROM community_skill_index ${where}`, params);
|
|
2102
|
+
const rows = await this.db.all(
|
|
2103
|
+
`SELECT * FROM community_skill_index ${where} ORDER BY ${sortCol} ${sortOrder} LIMIT ? OFFSET ?`,
|
|
2104
|
+
[...params, limit, offset]
|
|
2105
|
+
);
|
|
2106
|
+
return { skills: rows.map((r) => this.rowToCommunitySkill(r)), total: countRow?.c || 0 };
|
|
2107
|
+
}
|
|
2108
|
+
async deleteCommunitySkill(id) {
|
|
2109
|
+
await this.db.run("DELETE FROM community_skill_index WHERE id = ?", [id]);
|
|
2110
|
+
}
|
|
2111
|
+
async incrementDownloads(skillId) {
|
|
2112
|
+
await this.db.run("UPDATE community_skill_index SET downloads = downloads + 1 WHERE id = ?", [skillId]);
|
|
2113
|
+
}
|
|
2114
|
+
// ─── Community Skill Installed ──────────────────────
|
|
2115
|
+
async upsertInstalledSkill(install) {
|
|
2116
|
+
const now = (/* @__PURE__ */ new Date()).toISOString();
|
|
2117
|
+
await this.db.run(`
|
|
2118
|
+
INSERT INTO community_skill_installed (id, org_id, skill_id, version, enabled, config, installed_by, installed_at, updated_at)
|
|
2119
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
2120
|
+
ON CONFLICT(id) DO UPDATE SET
|
|
2121
|
+
version = excluded.version, enabled = excluded.enabled,
|
|
2122
|
+
config = excluded.config, updated_at = excluded.updated_at
|
|
2123
|
+
`, [
|
|
2124
|
+
install.id,
|
|
2125
|
+
install.orgId,
|
|
2126
|
+
install.skillId,
|
|
2127
|
+
install.version,
|
|
2128
|
+
install.enabled ? 1 : 0,
|
|
2129
|
+
JSON.stringify(install.config),
|
|
2130
|
+
install.installedBy,
|
|
2131
|
+
now,
|
|
2132
|
+
now
|
|
2133
|
+
]);
|
|
2134
|
+
}
|
|
2135
|
+
async getInstalledSkill(orgId, skillId) {
|
|
2136
|
+
const row = await this.db.get(
|
|
2137
|
+
"SELECT * FROM community_skill_installed WHERE org_id = ? AND skill_id = ?",
|
|
2138
|
+
[orgId, skillId]
|
|
2139
|
+
);
|
|
2140
|
+
return row ? this.rowToInstalledSkill(row) : null;
|
|
2141
|
+
}
|
|
2142
|
+
async getInstalledSkillsByOrg(orgId) {
|
|
2143
|
+
const rows = await this.db.all(
|
|
2144
|
+
"SELECT * FROM community_skill_installed WHERE org_id = ? ORDER BY installed_at DESC",
|
|
2145
|
+
[orgId]
|
|
2146
|
+
);
|
|
2147
|
+
return rows.map((r) => this.rowToInstalledSkill(r));
|
|
2148
|
+
}
|
|
2149
|
+
async deleteInstalledSkill(orgId, skillId) {
|
|
2150
|
+
await this.db.run(
|
|
2151
|
+
"DELETE FROM community_skill_installed WHERE org_id = ? AND skill_id = ?",
|
|
2152
|
+
[orgId, skillId]
|
|
2153
|
+
);
|
|
2154
|
+
}
|
|
2155
|
+
// ─── Community Skill Reviews ────────────────────────
|
|
2156
|
+
async insertReview(review) {
|
|
2157
|
+
const existing = await this.db.get(
|
|
2158
|
+
"SELECT id FROM community_skill_reviews WHERE skill_id = ? AND user_id = ?",
|
|
2159
|
+
[review.skillId, review.userId]
|
|
2160
|
+
);
|
|
2161
|
+
if (existing) {
|
|
2162
|
+
await this.db.run(`
|
|
2163
|
+
UPDATE community_skill_reviews SET rating = ?, review_text = ?, user_name = ?, created_at = ? WHERE id = ?
|
|
2164
|
+
`, [review.rating, review.reviewText || null, review.userName || null, (/* @__PURE__ */ new Date()).toISOString(), existing.id]);
|
|
2165
|
+
} else {
|
|
2166
|
+
await this.db.run(`
|
|
2167
|
+
INSERT INTO community_skill_reviews (id, skill_id, org_id, user_id, user_name, rating, review_text, created_at)
|
|
2168
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?)
|
|
2169
|
+
`, [
|
|
2170
|
+
review.id,
|
|
2171
|
+
review.skillId,
|
|
2172
|
+
"global",
|
|
2173
|
+
review.userId,
|
|
2174
|
+
review.userName || null,
|
|
2175
|
+
review.rating,
|
|
2176
|
+
review.reviewText || null,
|
|
2177
|
+
(/* @__PURE__ */ new Date()).toISOString()
|
|
2178
|
+
]);
|
|
2179
|
+
}
|
|
2180
|
+
}
|
|
2181
|
+
async getReviews(skillId, limit = 50) {
|
|
2182
|
+
const rows = await this.db.all(
|
|
2183
|
+
"SELECT * FROM community_skill_reviews WHERE skill_id = ? ORDER BY created_at DESC LIMIT ?",
|
|
2184
|
+
[skillId, limit]
|
|
2185
|
+
);
|
|
2186
|
+
return rows.map((r) => ({
|
|
2187
|
+
id: r.id,
|
|
2188
|
+
skillId: r.skill_id,
|
|
2189
|
+
userId: r.user_id,
|
|
2190
|
+
userName: r.user_name || void 0,
|
|
2191
|
+
rating: r.rating,
|
|
2192
|
+
reviewText: r.review_text,
|
|
2193
|
+
createdAt: r.created_at
|
|
2194
|
+
}));
|
|
2195
|
+
}
|
|
2196
|
+
async getAverageRating(skillId) {
|
|
2197
|
+
const row = await this.db.get(
|
|
2198
|
+
"SELECT AVG(rating) as avg, COUNT(*) as count FROM community_skill_reviews WHERE skill_id = ?",
|
|
2199
|
+
[skillId]
|
|
2200
|
+
);
|
|
2201
|
+
return { avg: row?.avg || 0, count: row?.count || 0 };
|
|
2202
|
+
}
|
|
2203
|
+
// ─── Row Mappers ────────────────────────────────────
|
|
2204
|
+
rowToCommunitySkill(row) {
|
|
2205
|
+
return {
|
|
2206
|
+
id: row.id,
|
|
2207
|
+
name: row.name,
|
|
2208
|
+
description: row.description,
|
|
2209
|
+
version: row.version,
|
|
2210
|
+
author: row.author,
|
|
2211
|
+
repository: row.repository,
|
|
2212
|
+
license: row.license,
|
|
2213
|
+
category: row.category,
|
|
2214
|
+
risk: row.risk,
|
|
2215
|
+
icon: row.icon,
|
|
2216
|
+
tags: JSON.parse(row.tags || "[]"),
|
|
2217
|
+
tools: JSON.parse(row.tools || "[]"),
|
|
2218
|
+
configSchema: JSON.parse(row.config_schema || "{}"),
|
|
2219
|
+
minEngineVersion: row.min_engine_version,
|
|
2220
|
+
homepage: row.homepage,
|
|
2221
|
+
downloads: row.downloads,
|
|
2222
|
+
rating: row.rating,
|
|
2223
|
+
ratingCount: row.rating_count,
|
|
2224
|
+
verified: !!row.verified,
|
|
2225
|
+
featured: !!row.featured,
|
|
2226
|
+
createdAt: row.created_at,
|
|
2227
|
+
updatedAt: row.updated_at
|
|
2228
|
+
};
|
|
2229
|
+
}
|
|
2230
|
+
rowToInstalledSkill(row) {
|
|
2231
|
+
return {
|
|
2232
|
+
id: row.id,
|
|
2233
|
+
orgId: row.org_id,
|
|
2234
|
+
skillId: row.skill_id,
|
|
2235
|
+
version: row.version,
|
|
2236
|
+
enabled: !!row.enabled,
|
|
2237
|
+
config: JSON.parse(row.config || "{}"),
|
|
2238
|
+
installedBy: row.installed_by,
|
|
2239
|
+
installedAt: row.installed_at,
|
|
2240
|
+
updatedAt: row.updated_at
|
|
2241
|
+
};
|
|
2242
|
+
}
|
|
2243
|
+
rowToManagedAgent(row) {
|
|
2244
|
+
return {
|
|
2245
|
+
id: row.id,
|
|
2246
|
+
orgId: row.org_id,
|
|
2247
|
+
config: JSON.parse(row.config),
|
|
2248
|
+
state: row.state,
|
|
2249
|
+
stateHistory: [],
|
|
2250
|
+
// Loaded separately via getStateHistory
|
|
2251
|
+
health: JSON.parse(row.health || "{}"),
|
|
2252
|
+
usage: JSON.parse(row.usage || "{}"),
|
|
2253
|
+
createdAt: row.created_at,
|
|
2254
|
+
updatedAt: row.updated_at,
|
|
2255
|
+
lastDeployedAt: row.last_deployed_at,
|
|
2256
|
+
lastHealthCheckAt: row.last_health_check_at,
|
|
2257
|
+
version: row.version
|
|
2258
|
+
};
|
|
2259
|
+
}
|
|
2260
|
+
rowToOrg(row) {
|
|
2261
|
+
return {
|
|
2262
|
+
id: row.id,
|
|
2263
|
+
name: row.name,
|
|
2264
|
+
slug: row.slug,
|
|
2265
|
+
plan: row.plan,
|
|
2266
|
+
limits: JSON.parse(row.limits || "{}"),
|
|
2267
|
+
usage: JSON.parse(row.usage || "{}"),
|
|
2268
|
+
settings: JSON.parse(row.settings || "{}"),
|
|
2269
|
+
ssoConfig: row.sso_config ? JSON.parse(row.sso_config) : void 0,
|
|
2270
|
+
allowedDomains: JSON.parse(row.allowed_domains || "[]"),
|
|
2271
|
+
billing: row.billing ? JSON.parse(row.billing) : void 0,
|
|
2272
|
+
createdAt: row.created_at,
|
|
2273
|
+
updatedAt: row.updated_at
|
|
2274
|
+
};
|
|
2275
|
+
}
|
|
2276
|
+
};
|
|
2277
|
+
|
|
2278
|
+
export {
|
|
2279
|
+
ENGINE_TABLES,
|
|
2280
|
+
ENGINE_TABLES_POSTGRES,
|
|
2281
|
+
MIGRATIONS_TABLE,
|
|
2282
|
+
MIGRATIONS_TABLE_POSTGRES,
|
|
2283
|
+
MIGRATIONS,
|
|
2284
|
+
sqliteToPostgres,
|
|
2285
|
+
sqliteToMySQL,
|
|
2286
|
+
EngineDatabase
|
|
2287
|
+
};
|