@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
package/src/engine/db-schema.ts
CHANGED
|
@@ -261,29 +261,977 @@ export const MIGRATIONS: Migration[] = [
|
|
|
261
261
|
sql: ENGINE_TABLES,
|
|
262
262
|
postgres: ENGINE_TABLES_POSTGRES,
|
|
263
263
|
},
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
264
|
+
{
|
|
265
|
+
version: 2,
|
|
266
|
+
name: 'sso_and_deploy_credentials',
|
|
267
|
+
sql: `
|
|
268
|
+
-- SSO integrations (SAML, OIDC configs per org)
|
|
269
|
+
CREATE TABLE IF NOT EXISTS sso_integrations (
|
|
270
|
+
id TEXT PRIMARY KEY,
|
|
271
|
+
org_id TEXT NOT NULL,
|
|
272
|
+
provider_type TEXT NOT NULL,
|
|
273
|
+
name TEXT NOT NULL,
|
|
274
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
275
|
+
config JSON NOT NULL DEFAULT '{}',
|
|
276
|
+
metadata_url TEXT,
|
|
277
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
278
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
279
|
+
);
|
|
280
|
+
CREATE INDEX IF NOT EXISTS idx_sso_org ON sso_integrations(org_id);
|
|
281
|
+
CREATE INDEX IF NOT EXISTS idx_sso_type ON sso_integrations(provider_type);
|
|
282
|
+
|
|
283
|
+
-- Deploy credentials (encrypted tokens for Docker/SSH/Fly/Railway)
|
|
284
|
+
CREATE TABLE IF NOT EXISTS deploy_credentials (
|
|
285
|
+
id TEXT PRIMARY KEY,
|
|
286
|
+
org_id TEXT NOT NULL,
|
|
287
|
+
name TEXT NOT NULL,
|
|
288
|
+
target_type TEXT NOT NULL,
|
|
289
|
+
config JSON NOT NULL DEFAULT '{}',
|
|
290
|
+
created_by TEXT NOT NULL,
|
|
291
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
292
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
293
|
+
);
|
|
294
|
+
CREATE INDEX IF NOT EXISTS idx_deploy_creds_org ON deploy_credentials(org_id);
|
|
295
|
+
CREATE INDEX IF NOT EXISTS idx_deploy_creds_type ON deploy_credentials(target_type);
|
|
296
|
+
|
|
297
|
+
-- OIDC state tracking (prevents replay attacks)
|
|
298
|
+
CREATE TABLE IF NOT EXISTS oidc_states (
|
|
299
|
+
state TEXT PRIMARY KEY,
|
|
300
|
+
provider_id TEXT NOT NULL,
|
|
301
|
+
redirect_uri TEXT,
|
|
302
|
+
nonce TEXT,
|
|
303
|
+
code_verifier TEXT,
|
|
304
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
305
|
+
expires_at TEXT NOT NULL
|
|
306
|
+
);
|
|
307
|
+
`,
|
|
308
|
+
postgres: `
|
|
309
|
+
CREATE TABLE IF NOT EXISTS sso_integrations (
|
|
310
|
+
id TEXT PRIMARY KEY,
|
|
311
|
+
org_id TEXT NOT NULL,
|
|
312
|
+
provider_type TEXT NOT NULL,
|
|
313
|
+
name TEXT NOT NULL,
|
|
314
|
+
enabled BOOLEAN NOT NULL DEFAULT TRUE,
|
|
315
|
+
config JSONB NOT NULL DEFAULT '{}',
|
|
316
|
+
metadata_url TEXT,
|
|
317
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
318
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
319
|
+
);
|
|
320
|
+
CREATE INDEX IF NOT EXISTS idx_sso_org ON sso_integrations(org_id);
|
|
321
|
+
CREATE INDEX IF NOT EXISTS idx_sso_type ON sso_integrations(provider_type);
|
|
322
|
+
|
|
323
|
+
CREATE TABLE IF NOT EXISTS deploy_credentials (
|
|
324
|
+
id TEXT PRIMARY KEY,
|
|
325
|
+
org_id TEXT NOT NULL,
|
|
326
|
+
name TEXT NOT NULL,
|
|
327
|
+
target_type TEXT NOT NULL,
|
|
328
|
+
config JSONB NOT NULL DEFAULT '{}',
|
|
329
|
+
created_by TEXT NOT NULL,
|
|
330
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
331
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
332
|
+
);
|
|
333
|
+
CREATE INDEX IF NOT EXISTS idx_deploy_creds_org ON deploy_credentials(org_id);
|
|
334
|
+
CREATE INDEX IF NOT EXISTS idx_deploy_creds_type ON deploy_credentials(target_type);
|
|
335
|
+
|
|
336
|
+
CREATE TABLE IF NOT EXISTS oidc_states (
|
|
337
|
+
state TEXT PRIMARY KEY,
|
|
338
|
+
provider_id TEXT NOT NULL,
|
|
339
|
+
redirect_uri TEXT,
|
|
340
|
+
nonce TEXT,
|
|
341
|
+
code_verifier TEXT,
|
|
342
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
343
|
+
expires_at TIMESTAMPTZ NOT NULL
|
|
344
|
+
);
|
|
345
|
+
`,
|
|
346
|
+
},
|
|
347
|
+
{
|
|
348
|
+
version: 3,
|
|
349
|
+
name: 'autonomous_employee_trust',
|
|
350
|
+
sql: `
|
|
351
|
+
-- Per-agent budget config (extends managed_agents)
|
|
352
|
+
ALTER TABLE managed_agents ADD COLUMN budget_config JSON DEFAULT '{}';
|
|
353
|
+
|
|
354
|
+
-- Budget alerts log
|
|
355
|
+
CREATE TABLE IF NOT EXISTS budget_alerts (
|
|
356
|
+
id TEXT PRIMARY KEY,
|
|
357
|
+
org_id TEXT NOT NULL,
|
|
358
|
+
agent_id TEXT NOT NULL,
|
|
359
|
+
alert_type TEXT NOT NULL,
|
|
360
|
+
budget_type TEXT NOT NULL,
|
|
361
|
+
current_value REAL NOT NULL,
|
|
362
|
+
limit_value REAL NOT NULL,
|
|
363
|
+
acknowledged INTEGER NOT NULL DEFAULT 0,
|
|
364
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
365
|
+
);
|
|
366
|
+
CREATE INDEX IF NOT EXISTS idx_budget_alerts_org ON budget_alerts(org_id);
|
|
367
|
+
CREATE INDEX IF NOT EXISTS idx_budget_alerts_agent ON budget_alerts(agent_id);
|
|
368
|
+
|
|
369
|
+
-- Escalation chains (multi-level approval workflows)
|
|
370
|
+
CREATE TABLE IF NOT EXISTS escalation_chains (
|
|
371
|
+
id TEXT PRIMARY KEY,
|
|
372
|
+
org_id TEXT NOT NULL,
|
|
373
|
+
name TEXT NOT NULL,
|
|
374
|
+
description TEXT,
|
|
375
|
+
levels JSON NOT NULL,
|
|
376
|
+
fallback_action TEXT NOT NULL DEFAULT 'deny',
|
|
377
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
378
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
379
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
380
|
+
);
|
|
381
|
+
CREATE INDEX IF NOT EXISTS idx_escalation_org ON escalation_chains(org_id);
|
|
382
|
+
|
|
383
|
+
-- Escalation tracking on approval requests
|
|
384
|
+
ALTER TABLE approval_requests ADD COLUMN escalation_chain_id TEXT;
|
|
385
|
+
ALTER TABLE approval_requests ADD COLUMN escalation_level INTEGER DEFAULT 0;
|
|
386
|
+
ALTER TABLE approval_requests ADD COLUMN escalation_history JSON DEFAULT '[]';
|
|
387
|
+
|
|
388
|
+
-- DLP rules
|
|
389
|
+
CREATE TABLE IF NOT EXISTS dlp_rules (
|
|
390
|
+
id TEXT PRIMARY KEY,
|
|
391
|
+
org_id TEXT NOT NULL,
|
|
392
|
+
name TEXT NOT NULL,
|
|
393
|
+
description TEXT,
|
|
394
|
+
pattern_type TEXT NOT NULL,
|
|
395
|
+
pattern TEXT NOT NULL,
|
|
396
|
+
action TEXT NOT NULL DEFAULT 'block',
|
|
397
|
+
applies_to TEXT NOT NULL DEFAULT 'both',
|
|
398
|
+
severity TEXT NOT NULL DEFAULT 'high',
|
|
399
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
400
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
401
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
402
|
+
);
|
|
403
|
+
CREATE INDEX IF NOT EXISTS idx_dlp_rules_org ON dlp_rules(org_id);
|
|
404
|
+
|
|
405
|
+
-- DLP violations log
|
|
406
|
+
CREATE TABLE IF NOT EXISTS dlp_violations (
|
|
407
|
+
id TEXT PRIMARY KEY,
|
|
408
|
+
org_id TEXT NOT NULL,
|
|
409
|
+
agent_id TEXT NOT NULL,
|
|
410
|
+
rule_id TEXT NOT NULL,
|
|
411
|
+
tool_id TEXT NOT NULL,
|
|
412
|
+
action_taken TEXT NOT NULL,
|
|
413
|
+
match_context TEXT,
|
|
414
|
+
direction TEXT NOT NULL,
|
|
415
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
416
|
+
);
|
|
417
|
+
CREATE INDEX IF NOT EXISTS idx_dlp_violations_org ON dlp_violations(org_id);
|
|
418
|
+
CREATE INDEX IF NOT EXISTS idx_dlp_violations_agent ON dlp_violations(agent_id);
|
|
419
|
+
|
|
420
|
+
-- Agent-to-agent messages
|
|
421
|
+
CREATE TABLE IF NOT EXISTS agent_messages (
|
|
422
|
+
id TEXT PRIMARY KEY,
|
|
423
|
+
org_id TEXT NOT NULL,
|
|
424
|
+
from_agent_id TEXT NOT NULL,
|
|
425
|
+
to_agent_id TEXT NOT NULL,
|
|
426
|
+
type TEXT NOT NULL DEFAULT 'message',
|
|
427
|
+
subject TEXT,
|
|
428
|
+
content TEXT NOT NULL,
|
|
429
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
430
|
+
status TEXT NOT NULL DEFAULT 'pending',
|
|
431
|
+
parent_id TEXT,
|
|
432
|
+
priority TEXT NOT NULL DEFAULT 'normal',
|
|
433
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
434
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
435
|
+
);
|
|
436
|
+
CREATE INDEX IF NOT EXISTS idx_agent_messages_org ON agent_messages(org_id);
|
|
437
|
+
CREATE INDEX IF NOT EXISTS idx_agent_messages_to ON agent_messages(to_agent_id);
|
|
438
|
+
CREATE INDEX IF NOT EXISTS idx_agent_messages_from ON agent_messages(from_agent_id);
|
|
439
|
+
CREATE INDEX IF NOT EXISTS idx_agent_messages_status ON agent_messages(status);
|
|
440
|
+
|
|
441
|
+
-- Interventions (pause/resume/kill records)
|
|
442
|
+
CREATE TABLE IF NOT EXISTS interventions (
|
|
443
|
+
id TEXT PRIMARY KEY,
|
|
444
|
+
org_id TEXT NOT NULL,
|
|
445
|
+
agent_id TEXT NOT NULL,
|
|
446
|
+
type TEXT NOT NULL,
|
|
447
|
+
reason TEXT NOT NULL,
|
|
448
|
+
triggered_by TEXT NOT NULL,
|
|
449
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
450
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
451
|
+
);
|
|
452
|
+
CREATE INDEX IF NOT EXISTS idx_interventions_org ON interventions(org_id);
|
|
453
|
+
CREATE INDEX IF NOT EXISTS idx_interventions_agent ON interventions(agent_id);
|
|
454
|
+
|
|
455
|
+
-- Anomaly detection rules
|
|
456
|
+
CREATE TABLE IF NOT EXISTS anomaly_rules (
|
|
457
|
+
id TEXT PRIMARY KEY,
|
|
458
|
+
org_id TEXT NOT NULL,
|
|
459
|
+
name TEXT NOT NULL,
|
|
460
|
+
description TEXT,
|
|
461
|
+
rule_type TEXT NOT NULL,
|
|
462
|
+
config JSON NOT NULL,
|
|
463
|
+
action TEXT NOT NULL DEFAULT 'alert',
|
|
464
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
465
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
466
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
467
|
+
);
|
|
468
|
+
CREATE INDEX IF NOT EXISTS idx_anomaly_rules_org ON anomaly_rules(org_id);
|
|
469
|
+
|
|
470
|
+
-- Action journal (for rollback)
|
|
471
|
+
CREATE TABLE IF NOT EXISTS action_journal (
|
|
472
|
+
id TEXT PRIMARY KEY,
|
|
473
|
+
org_id TEXT NOT NULL,
|
|
474
|
+
agent_id TEXT NOT NULL,
|
|
475
|
+
session_id TEXT,
|
|
476
|
+
tool_id TEXT NOT NULL,
|
|
477
|
+
tool_name TEXT NOT NULL,
|
|
478
|
+
action_type TEXT NOT NULL,
|
|
479
|
+
forward_data JSON NOT NULL,
|
|
480
|
+
reverse_data JSON,
|
|
481
|
+
reversible INTEGER NOT NULL DEFAULT 0,
|
|
482
|
+
reversed INTEGER NOT NULL DEFAULT 0,
|
|
483
|
+
reversed_at TEXT,
|
|
484
|
+
reversed_by TEXT,
|
|
485
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
486
|
+
);
|
|
487
|
+
CREATE INDEX IF NOT EXISTS idx_action_journal_org ON action_journal(org_id);
|
|
488
|
+
CREATE INDEX IF NOT EXISTS idx_action_journal_agent ON action_journal(agent_id);
|
|
489
|
+
CREATE INDEX IF NOT EXISTS idx_action_journal_reversible ON action_journal(reversible);
|
|
490
|
+
|
|
491
|
+
-- Compliance reports
|
|
492
|
+
CREATE TABLE IF NOT EXISTS compliance_reports (
|
|
493
|
+
id TEXT PRIMARY KEY,
|
|
494
|
+
org_id TEXT NOT NULL,
|
|
495
|
+
type TEXT NOT NULL,
|
|
496
|
+
title TEXT NOT NULL,
|
|
497
|
+
parameters JSON NOT NULL DEFAULT '{}',
|
|
498
|
+
status TEXT NOT NULL DEFAULT 'generating',
|
|
499
|
+
data JSON,
|
|
500
|
+
format TEXT NOT NULL DEFAULT 'json',
|
|
501
|
+
generated_by TEXT NOT NULL,
|
|
502
|
+
error TEXT,
|
|
503
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
504
|
+
);
|
|
505
|
+
CREATE INDEX IF NOT EXISTS idx_compliance_reports_org ON compliance_reports(org_id);
|
|
506
|
+
CREATE INDEX IF NOT EXISTS idx_compliance_reports_type ON compliance_reports(type);
|
|
507
|
+
`,
|
|
508
|
+
},
|
|
509
|
+
{
|
|
510
|
+
version: 4,
|
|
511
|
+
name: 'communication_topology',
|
|
512
|
+
sql: `
|
|
513
|
+
-- Add direction and channel columns to agent_messages for traffic classification
|
|
514
|
+
ALTER TABLE agent_messages ADD COLUMN direction TEXT DEFAULT 'internal';
|
|
515
|
+
ALTER TABLE agent_messages ADD COLUMN channel TEXT DEFAULT 'direct';
|
|
516
|
+
CREATE INDEX IF NOT EXISTS idx_agent_messages_direction ON agent_messages(direction);
|
|
517
|
+
CREATE INDEX IF NOT EXISTS idx_agent_messages_channel ON agent_messages(channel);
|
|
518
|
+
`,
|
|
519
|
+
},
|
|
520
|
+
{
|
|
521
|
+
version: 5,
|
|
522
|
+
name: 'communication_task_fields_and_compliance',
|
|
523
|
+
sql: `
|
|
524
|
+
-- Add task lifecycle columns to agent_messages
|
|
525
|
+
ALTER TABLE agent_messages ADD COLUMN deadline TEXT;
|
|
526
|
+
ALTER TABLE agent_messages ADD COLUMN claimed_at TEXT;
|
|
527
|
+
ALTER TABLE agent_messages ADD COLUMN completed_at TEXT;
|
|
528
|
+
|
|
529
|
+
-- Add completed_at to compliance reports
|
|
530
|
+
ALTER TABLE compliance_reports ADD COLUMN completed_at TEXT;
|
|
531
|
+
`,
|
|
532
|
+
},
|
|
533
|
+
{
|
|
534
|
+
version: 6,
|
|
535
|
+
name: 'community_skill_registry',
|
|
536
|
+
sql: `
|
|
537
|
+
-- Community skill index (global marketplace catalog)
|
|
538
|
+
CREATE TABLE IF NOT EXISTS community_skill_index (
|
|
539
|
+
id TEXT PRIMARY KEY,
|
|
540
|
+
name TEXT NOT NULL,
|
|
541
|
+
description TEXT NOT NULL,
|
|
542
|
+
version TEXT NOT NULL DEFAULT '1.0.0',
|
|
543
|
+
author TEXT NOT NULL,
|
|
544
|
+
repository TEXT NOT NULL,
|
|
545
|
+
license TEXT NOT NULL DEFAULT 'MIT',
|
|
546
|
+
category TEXT,
|
|
547
|
+
risk TEXT DEFAULT 'medium',
|
|
548
|
+
icon TEXT,
|
|
549
|
+
tags JSON NOT NULL DEFAULT '[]',
|
|
550
|
+
tools JSON NOT NULL DEFAULT '[]',
|
|
551
|
+
config_schema JSON NOT NULL DEFAULT '{}',
|
|
552
|
+
min_engine_version TEXT,
|
|
553
|
+
homepage TEXT,
|
|
554
|
+
downloads INTEGER NOT NULL DEFAULT 0,
|
|
555
|
+
rating REAL NOT NULL DEFAULT 0,
|
|
556
|
+
rating_count INTEGER NOT NULL DEFAULT 0,
|
|
557
|
+
verified INTEGER NOT NULL DEFAULT 0,
|
|
558
|
+
featured INTEGER NOT NULL DEFAULT 0,
|
|
559
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
560
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
561
|
+
);
|
|
562
|
+
CREATE INDEX IF NOT EXISTS idx_csi_category ON community_skill_index(category);
|
|
563
|
+
CREATE INDEX IF NOT EXISTS idx_csi_author ON community_skill_index(author);
|
|
564
|
+
CREATE INDEX IF NOT EXISTS idx_csi_featured ON community_skill_index(featured);
|
|
565
|
+
CREATE INDEX IF NOT EXISTS idx_csi_verified ON community_skill_index(verified);
|
|
566
|
+
CREATE INDEX IF NOT EXISTS idx_csi_downloads ON community_skill_index(downloads);
|
|
567
|
+
|
|
568
|
+
-- Per-org installed community skills
|
|
569
|
+
CREATE TABLE IF NOT EXISTS community_skill_installed (
|
|
570
|
+
id TEXT PRIMARY KEY,
|
|
571
|
+
org_id TEXT NOT NULL,
|
|
572
|
+
skill_id TEXT NOT NULL,
|
|
573
|
+
version TEXT NOT NULL,
|
|
574
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
575
|
+
config JSON NOT NULL DEFAULT '{}',
|
|
576
|
+
installed_by TEXT NOT NULL,
|
|
577
|
+
installed_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
578
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
579
|
+
);
|
|
580
|
+
CREATE INDEX IF NOT EXISTS idx_csinst_org ON community_skill_installed(org_id);
|
|
581
|
+
CREATE INDEX IF NOT EXISTS idx_csinst_skill ON community_skill_installed(skill_id);
|
|
582
|
+
CREATE UNIQUE INDEX IF NOT EXISTS idx_csinst_org_skill ON community_skill_installed(org_id, skill_id);
|
|
583
|
+
|
|
584
|
+
-- Reviews and ratings for community skills (global, not org-scoped)
|
|
585
|
+
CREATE TABLE IF NOT EXISTS community_skill_reviews (
|
|
586
|
+
id TEXT PRIMARY KEY,
|
|
587
|
+
skill_id TEXT NOT NULL,
|
|
588
|
+
org_id TEXT NOT NULL DEFAULT 'global',
|
|
589
|
+
user_id TEXT NOT NULL,
|
|
590
|
+
user_name TEXT,
|
|
591
|
+
rating INTEGER NOT NULL CHECK (rating >= 1 AND rating <= 5),
|
|
592
|
+
review_text TEXT,
|
|
593
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
594
|
+
);
|
|
595
|
+
CREATE INDEX IF NOT EXISTS idx_csrev_skill ON community_skill_reviews(skill_id);
|
|
596
|
+
`,
|
|
597
|
+
},
|
|
598
|
+
{
|
|
599
|
+
version: 7,
|
|
600
|
+
name: 'domain_registration',
|
|
601
|
+
sql: `
|
|
602
|
+
ALTER TABLE company_settings ADD COLUMN deployment_key_hash TEXT;
|
|
603
|
+
ALTER TABLE company_settings ADD COLUMN domain_registration_id TEXT;
|
|
604
|
+
ALTER TABLE company_settings ADD COLUMN domain_dns_challenge TEXT;
|
|
605
|
+
ALTER TABLE company_settings ADD COLUMN domain_verified_at TEXT;
|
|
606
|
+
ALTER TABLE company_settings ADD COLUMN domain_registered_at TEXT;
|
|
607
|
+
ALTER TABLE company_settings ADD COLUMN domain_status TEXT DEFAULT 'unregistered';
|
|
608
|
+
`,
|
|
609
|
+
postgres: `
|
|
610
|
+
ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS deployment_key_hash TEXT;
|
|
611
|
+
ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS domain_registration_id TEXT;
|
|
612
|
+
ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS domain_dns_challenge TEXT;
|
|
613
|
+
ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS domain_verified_at TIMESTAMPTZ;
|
|
614
|
+
ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS domain_registered_at TIMESTAMPTZ;
|
|
615
|
+
ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS domain_status TEXT DEFAULT 'unregistered';
|
|
616
|
+
`,
|
|
617
|
+
mysql: `
|
|
618
|
+
ALTER TABLE company_settings ADD COLUMN deployment_key_hash TEXT;
|
|
619
|
+
ALTER TABLE company_settings ADD COLUMN domain_registration_id VARCHAR(255);
|
|
620
|
+
ALTER TABLE company_settings ADD COLUMN domain_dns_challenge TEXT;
|
|
621
|
+
ALTER TABLE company_settings ADD COLUMN domain_verified_at DATETIME;
|
|
622
|
+
ALTER TABLE company_settings ADD COLUMN domain_registered_at DATETIME;
|
|
623
|
+
ALTER TABLE company_settings ADD COLUMN domain_status VARCHAR(20) DEFAULT 'unregistered';
|
|
624
|
+
`,
|
|
625
|
+
nosql: async () => {
|
|
626
|
+
// MongoDB and DynamoDB are schema-less; new fields added dynamically via updateSettings()
|
|
627
|
+
},
|
|
628
|
+
},
|
|
629
|
+
{
|
|
630
|
+
version: 8,
|
|
631
|
+
name: 'workforce_management',
|
|
632
|
+
sql: `
|
|
633
|
+
-- Work schedules (per-agent shift configuration)
|
|
634
|
+
CREATE TABLE IF NOT EXISTS work_schedules (
|
|
635
|
+
id TEXT PRIMARY KEY,
|
|
636
|
+
agent_id TEXT NOT NULL UNIQUE,
|
|
637
|
+
org_id TEXT NOT NULL,
|
|
638
|
+
timezone TEXT NOT NULL DEFAULT 'UTC',
|
|
639
|
+
schedule_type TEXT NOT NULL DEFAULT 'standard',
|
|
640
|
+
config JSON NOT NULL DEFAULT '{}',
|
|
641
|
+
enforce_clock_in INTEGER NOT NULL DEFAULT 1,
|
|
642
|
+
enforce_clock_out INTEGER NOT NULL DEFAULT 1,
|
|
643
|
+
auto_wake_enabled INTEGER NOT NULL DEFAULT 1,
|
|
644
|
+
off_hours_action TEXT NOT NULL DEFAULT 'pause',
|
|
645
|
+
grace_period_minutes INTEGER NOT NULL DEFAULT 5,
|
|
646
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
647
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
648
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
649
|
+
);
|
|
650
|
+
CREATE INDEX IF NOT EXISTS idx_work_schedules_agent ON work_schedules(agent_id);
|
|
651
|
+
CREATE INDEX IF NOT EXISTS idx_work_schedules_org ON work_schedules(org_id);
|
|
652
|
+
|
|
653
|
+
-- Clock records (audit trail for clock-in/out events)
|
|
654
|
+
CREATE TABLE IF NOT EXISTS clock_records (
|
|
655
|
+
id TEXT PRIMARY KEY,
|
|
656
|
+
agent_id TEXT NOT NULL,
|
|
657
|
+
org_id TEXT NOT NULL,
|
|
658
|
+
type TEXT NOT NULL,
|
|
659
|
+
triggered_by TEXT NOT NULL,
|
|
660
|
+
scheduled_at TEXT,
|
|
661
|
+
actual_at TEXT NOT NULL,
|
|
662
|
+
reason TEXT,
|
|
663
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
664
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
665
|
+
);
|
|
666
|
+
CREATE INDEX IF NOT EXISTS idx_clock_records_agent ON clock_records(agent_id);
|
|
667
|
+
CREATE INDEX IF NOT EXISTS idx_clock_records_org ON clock_records(org_id);
|
|
668
|
+
CREATE INDEX IF NOT EXISTS idx_clock_records_type ON clock_records(type);
|
|
669
|
+
CREATE INDEX IF NOT EXISTS idx_clock_records_time ON clock_records(created_at);
|
|
670
|
+
|
|
671
|
+
-- Task queue (work continuity between sessions)
|
|
672
|
+
CREATE TABLE IF NOT EXISTS task_queue (
|
|
673
|
+
id TEXT PRIMARY KEY,
|
|
674
|
+
agent_id TEXT NOT NULL,
|
|
675
|
+
org_id TEXT NOT NULL,
|
|
676
|
+
type TEXT NOT NULL DEFAULT 'continue',
|
|
677
|
+
title TEXT NOT NULL,
|
|
678
|
+
description TEXT,
|
|
679
|
+
context JSON NOT NULL DEFAULT '{}',
|
|
680
|
+
priority TEXT NOT NULL DEFAULT 'normal',
|
|
681
|
+
status TEXT NOT NULL DEFAULT 'queued',
|
|
682
|
+
source TEXT NOT NULL DEFAULT 'system',
|
|
683
|
+
scheduled_for TEXT,
|
|
684
|
+
started_at TEXT,
|
|
685
|
+
completed_at TEXT,
|
|
686
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
687
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
688
|
+
);
|
|
689
|
+
CREATE INDEX IF NOT EXISTS idx_task_queue_agent ON task_queue(agent_id);
|
|
690
|
+
CREATE INDEX IF NOT EXISTS idx_task_queue_org ON task_queue(org_id);
|
|
691
|
+
CREATE INDEX IF NOT EXISTS idx_task_queue_status ON task_queue(status);
|
|
692
|
+
`,
|
|
693
|
+
postgres: `
|
|
694
|
+
CREATE TABLE IF NOT EXISTS work_schedules (
|
|
695
|
+
id TEXT PRIMARY KEY,
|
|
696
|
+
agent_id TEXT NOT NULL UNIQUE,
|
|
697
|
+
org_id TEXT NOT NULL,
|
|
698
|
+
timezone TEXT NOT NULL DEFAULT 'UTC',
|
|
699
|
+
schedule_type TEXT NOT NULL DEFAULT 'standard',
|
|
700
|
+
config JSONB NOT NULL DEFAULT '{}',
|
|
701
|
+
enforce_clock_in BOOLEAN NOT NULL DEFAULT TRUE,
|
|
702
|
+
enforce_clock_out BOOLEAN NOT NULL DEFAULT TRUE,
|
|
703
|
+
auto_wake_enabled BOOLEAN NOT NULL DEFAULT TRUE,
|
|
704
|
+
off_hours_action TEXT NOT NULL DEFAULT 'pause',
|
|
705
|
+
grace_period_minutes INTEGER NOT NULL DEFAULT 5,
|
|
706
|
+
enabled BOOLEAN NOT NULL DEFAULT TRUE,
|
|
707
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
708
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
709
|
+
);
|
|
710
|
+
CREATE INDEX IF NOT EXISTS idx_work_schedules_agent ON work_schedules(agent_id);
|
|
711
|
+
CREATE INDEX IF NOT EXISTS idx_work_schedules_org ON work_schedules(org_id);
|
|
712
|
+
|
|
713
|
+
CREATE TABLE IF NOT EXISTS clock_records (
|
|
714
|
+
id TEXT PRIMARY KEY,
|
|
715
|
+
agent_id TEXT NOT NULL,
|
|
716
|
+
org_id TEXT NOT NULL,
|
|
717
|
+
type TEXT NOT NULL,
|
|
718
|
+
triggered_by TEXT NOT NULL,
|
|
719
|
+
scheduled_at TIMESTAMPTZ,
|
|
720
|
+
actual_at TIMESTAMPTZ NOT NULL,
|
|
721
|
+
reason TEXT,
|
|
722
|
+
metadata JSONB NOT NULL DEFAULT '{}',
|
|
723
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
724
|
+
);
|
|
725
|
+
CREATE INDEX IF NOT EXISTS idx_clock_records_agent ON clock_records(agent_id);
|
|
726
|
+
CREATE INDEX IF NOT EXISTS idx_clock_records_org ON clock_records(org_id);
|
|
727
|
+
CREATE INDEX IF NOT EXISTS idx_clock_records_type ON clock_records(type);
|
|
728
|
+
CREATE INDEX IF NOT EXISTS idx_clock_records_time ON clock_records(created_at);
|
|
729
|
+
|
|
730
|
+
CREATE TABLE IF NOT EXISTS task_queue (
|
|
731
|
+
id TEXT PRIMARY KEY,
|
|
732
|
+
agent_id TEXT NOT NULL,
|
|
733
|
+
org_id TEXT NOT NULL,
|
|
734
|
+
type TEXT NOT NULL DEFAULT 'continue',
|
|
735
|
+
title TEXT NOT NULL,
|
|
736
|
+
description TEXT,
|
|
737
|
+
context JSONB NOT NULL DEFAULT '{}',
|
|
738
|
+
priority TEXT NOT NULL DEFAULT 'normal',
|
|
739
|
+
status TEXT NOT NULL DEFAULT 'queued',
|
|
740
|
+
source TEXT NOT NULL DEFAULT 'system',
|
|
741
|
+
scheduled_for TIMESTAMPTZ,
|
|
742
|
+
started_at TIMESTAMPTZ,
|
|
743
|
+
completed_at TIMESTAMPTZ,
|
|
744
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
745
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
746
|
+
);
|
|
747
|
+
CREATE INDEX IF NOT EXISTS idx_task_queue_agent ON task_queue(agent_id);
|
|
748
|
+
CREATE INDEX IF NOT EXISTS idx_task_queue_org ON task_queue(org_id);
|
|
749
|
+
CREATE INDEX IF NOT EXISTS idx_task_queue_status ON task_queue(status);
|
|
750
|
+
`,
|
|
751
|
+
},
|
|
752
|
+
{
|
|
753
|
+
version: 9,
|
|
754
|
+
name: 'guardrails_policies_memory_onboarding',
|
|
755
|
+
sql: `
|
|
756
|
+
-- Organization policies (the "employee handbook" for AI agents)
|
|
757
|
+
CREATE TABLE IF NOT EXISTS org_policies (
|
|
758
|
+
id TEXT PRIMARY KEY,
|
|
759
|
+
org_id TEXT NOT NULL,
|
|
760
|
+
name TEXT NOT NULL,
|
|
761
|
+
category TEXT NOT NULL,
|
|
762
|
+
description TEXT,
|
|
763
|
+
content TEXT NOT NULL,
|
|
764
|
+
priority INTEGER NOT NULL DEFAULT 0,
|
|
765
|
+
version INTEGER NOT NULL DEFAULT 1,
|
|
766
|
+
enforcement TEXT NOT NULL DEFAULT 'mandatory',
|
|
767
|
+
applies_to JSON NOT NULL DEFAULT '["*"]',
|
|
768
|
+
tags JSON NOT NULL DEFAULT '[]',
|
|
769
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
770
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
771
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
772
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
773
|
+
);
|
|
774
|
+
CREATE INDEX IF NOT EXISTS idx_org_policies_org ON org_policies(org_id);
|
|
775
|
+
CREATE INDEX IF NOT EXISTS idx_org_policies_category ON org_policies(category);
|
|
776
|
+
|
|
777
|
+
-- Agent memory entries (persistent learning and growth)
|
|
778
|
+
CREATE TABLE IF NOT EXISTS agent_memory (
|
|
779
|
+
id TEXT PRIMARY KEY,
|
|
780
|
+
agent_id TEXT NOT NULL,
|
|
781
|
+
org_id TEXT NOT NULL,
|
|
782
|
+
category TEXT NOT NULL,
|
|
783
|
+
title TEXT NOT NULL,
|
|
784
|
+
content TEXT NOT NULL,
|
|
785
|
+
source TEXT NOT NULL DEFAULT 'interaction',
|
|
786
|
+
importance TEXT NOT NULL DEFAULT 'normal',
|
|
787
|
+
confidence REAL NOT NULL DEFAULT 1.0,
|
|
788
|
+
access_count INTEGER NOT NULL DEFAULT 0,
|
|
789
|
+
last_accessed_at TEXT,
|
|
790
|
+
expires_at TEXT,
|
|
791
|
+
tags JSON NOT NULL DEFAULT '[]',
|
|
792
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
793
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
794
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
795
|
+
);
|
|
796
|
+
CREATE INDEX IF NOT EXISTS idx_agent_memory_agent ON agent_memory(agent_id);
|
|
797
|
+
CREATE INDEX IF NOT EXISTS idx_agent_memory_org ON agent_memory(org_id);
|
|
798
|
+
CREATE INDEX IF NOT EXISTS idx_agent_memory_category ON agent_memory(category);
|
|
799
|
+
|
|
800
|
+
-- Onboarding records (tracking policy acknowledgment per agent)
|
|
801
|
+
CREATE TABLE IF NOT EXISTS onboarding_records (
|
|
802
|
+
id TEXT PRIMARY KEY,
|
|
803
|
+
agent_id TEXT NOT NULL,
|
|
804
|
+
org_id TEXT NOT NULL,
|
|
805
|
+
policy_id TEXT NOT NULL,
|
|
806
|
+
status TEXT NOT NULL DEFAULT 'pending',
|
|
807
|
+
acknowledged_at TEXT,
|
|
808
|
+
memory_entry_id TEXT,
|
|
809
|
+
verification_hash TEXT,
|
|
810
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
811
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
812
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
813
|
+
);
|
|
814
|
+
CREATE INDEX IF NOT EXISTS idx_onboarding_agent ON onboarding_records(agent_id);
|
|
815
|
+
CREATE INDEX IF NOT EXISTS idx_onboarding_policy ON onboarding_records(policy_id);
|
|
816
|
+
CREATE UNIQUE INDEX IF NOT EXISTS idx_onboarding_agent_policy ON onboarding_records(agent_id, policy_id);
|
|
817
|
+
|
|
818
|
+
-- Extended guardrail rules (superset of anomaly_rules with more categories)
|
|
819
|
+
CREATE TABLE IF NOT EXISTS guardrail_rules (
|
|
820
|
+
id TEXT PRIMARY KEY,
|
|
821
|
+
org_id TEXT NOT NULL,
|
|
822
|
+
name TEXT NOT NULL,
|
|
823
|
+
description TEXT,
|
|
824
|
+
category TEXT NOT NULL,
|
|
825
|
+
rule_type TEXT NOT NULL,
|
|
826
|
+
conditions JSON NOT NULL DEFAULT '{}',
|
|
827
|
+
action TEXT NOT NULL DEFAULT 'alert',
|
|
828
|
+
severity TEXT NOT NULL DEFAULT 'medium',
|
|
829
|
+
cooldown_minutes INTEGER NOT NULL DEFAULT 0,
|
|
830
|
+
last_triggered_at TEXT,
|
|
831
|
+
trigger_count INTEGER NOT NULL DEFAULT 0,
|
|
832
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
833
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
834
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
835
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
836
|
+
);
|
|
837
|
+
CREATE INDEX IF NOT EXISTS idx_guardrail_rules_org ON guardrail_rules(org_id);
|
|
838
|
+
CREATE INDEX IF NOT EXISTS idx_guardrail_rules_category ON guardrail_rules(category);
|
|
839
|
+
`,
|
|
840
|
+
postgres: `
|
|
841
|
+
CREATE TABLE IF NOT EXISTS org_policies (
|
|
842
|
+
id TEXT PRIMARY KEY,
|
|
843
|
+
org_id TEXT NOT NULL,
|
|
844
|
+
name TEXT NOT NULL,
|
|
845
|
+
category TEXT NOT NULL,
|
|
846
|
+
description TEXT,
|
|
847
|
+
content TEXT NOT NULL,
|
|
848
|
+
priority INTEGER NOT NULL DEFAULT 0,
|
|
849
|
+
version INTEGER NOT NULL DEFAULT 1,
|
|
850
|
+
enforcement TEXT NOT NULL DEFAULT 'mandatory',
|
|
851
|
+
applies_to JSONB NOT NULL DEFAULT '["*"]',
|
|
852
|
+
tags JSONB NOT NULL DEFAULT '[]',
|
|
853
|
+
enabled BOOLEAN NOT NULL DEFAULT TRUE,
|
|
854
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
855
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
856
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
857
|
+
);
|
|
858
|
+
CREATE INDEX IF NOT EXISTS idx_org_policies_org ON org_policies(org_id);
|
|
859
|
+
CREATE INDEX IF NOT EXISTS idx_org_policies_category ON org_policies(category);
|
|
860
|
+
|
|
861
|
+
CREATE TABLE IF NOT EXISTS agent_memory (
|
|
862
|
+
id TEXT PRIMARY KEY,
|
|
863
|
+
agent_id TEXT NOT NULL,
|
|
864
|
+
org_id TEXT NOT NULL,
|
|
865
|
+
category TEXT NOT NULL,
|
|
866
|
+
title TEXT NOT NULL,
|
|
867
|
+
content TEXT NOT NULL,
|
|
868
|
+
source TEXT NOT NULL DEFAULT 'interaction',
|
|
869
|
+
importance TEXT NOT NULL DEFAULT 'normal',
|
|
870
|
+
confidence REAL NOT NULL DEFAULT 1.0,
|
|
871
|
+
access_count INTEGER NOT NULL DEFAULT 0,
|
|
872
|
+
last_accessed_at TIMESTAMPTZ,
|
|
873
|
+
expires_at TIMESTAMPTZ,
|
|
874
|
+
tags JSONB NOT NULL DEFAULT '[]',
|
|
875
|
+
metadata JSONB NOT NULL DEFAULT '{}',
|
|
876
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
877
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
878
|
+
);
|
|
879
|
+
CREATE INDEX IF NOT EXISTS idx_agent_memory_agent ON agent_memory(agent_id);
|
|
880
|
+
CREATE INDEX IF NOT EXISTS idx_agent_memory_org ON agent_memory(org_id);
|
|
881
|
+
CREATE INDEX IF NOT EXISTS idx_agent_memory_category ON agent_memory(category);
|
|
882
|
+
|
|
883
|
+
CREATE TABLE IF NOT EXISTS onboarding_records (
|
|
884
|
+
id TEXT PRIMARY KEY,
|
|
885
|
+
agent_id TEXT NOT NULL,
|
|
886
|
+
org_id TEXT NOT NULL,
|
|
887
|
+
policy_id TEXT NOT NULL,
|
|
888
|
+
status TEXT NOT NULL DEFAULT 'pending',
|
|
889
|
+
acknowledged_at TIMESTAMPTZ,
|
|
890
|
+
memory_entry_id TEXT,
|
|
891
|
+
verification_hash TEXT,
|
|
892
|
+
metadata JSONB NOT NULL DEFAULT '{}',
|
|
893
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
894
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
895
|
+
);
|
|
896
|
+
CREATE INDEX IF NOT EXISTS idx_onboarding_agent ON onboarding_records(agent_id);
|
|
897
|
+
CREATE INDEX IF NOT EXISTS idx_onboarding_policy ON onboarding_records(policy_id);
|
|
898
|
+
CREATE UNIQUE INDEX IF NOT EXISTS idx_onboarding_agent_policy ON onboarding_records(agent_id, policy_id);
|
|
899
|
+
|
|
900
|
+
CREATE TABLE IF NOT EXISTS guardrail_rules (
|
|
901
|
+
id TEXT PRIMARY KEY,
|
|
902
|
+
org_id TEXT NOT NULL,
|
|
903
|
+
name TEXT NOT NULL,
|
|
904
|
+
description TEXT,
|
|
905
|
+
category TEXT NOT NULL,
|
|
906
|
+
rule_type TEXT NOT NULL,
|
|
907
|
+
conditions JSONB NOT NULL DEFAULT '{}',
|
|
908
|
+
action TEXT NOT NULL DEFAULT 'alert',
|
|
909
|
+
severity TEXT NOT NULL DEFAULT 'medium',
|
|
910
|
+
cooldown_minutes INTEGER NOT NULL DEFAULT 0,
|
|
911
|
+
last_triggered_at TIMESTAMPTZ,
|
|
912
|
+
trigger_count INTEGER NOT NULL DEFAULT 0,
|
|
913
|
+
enabled BOOLEAN NOT NULL DEFAULT TRUE,
|
|
914
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
915
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
916
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
917
|
+
);
|
|
918
|
+
CREATE INDEX IF NOT EXISTS idx_guardrail_rules_org ON guardrail_rules(org_id);
|
|
919
|
+
CREATE INDEX IF NOT EXISTS idx_guardrail_rules_category ON guardrail_rules(category);
|
|
920
|
+
`,
|
|
921
|
+
},
|
|
922
|
+
{
|
|
923
|
+
version: 10,
|
|
924
|
+
name: 'vault_storage_policy_import',
|
|
925
|
+
sql: `
|
|
926
|
+
-- Vault entries (encrypted secrets at rest)
|
|
927
|
+
CREATE TABLE IF NOT EXISTS vault_entries (
|
|
928
|
+
id TEXT PRIMARY KEY,
|
|
929
|
+
org_id TEXT NOT NULL,
|
|
930
|
+
name TEXT NOT NULL,
|
|
931
|
+
category TEXT NOT NULL DEFAULT 'custom',
|
|
932
|
+
encrypted_value TEXT NOT NULL,
|
|
933
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
934
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
935
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
936
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
937
|
+
rotated_at TEXT,
|
|
938
|
+
expires_at TEXT
|
|
939
|
+
);
|
|
940
|
+
CREATE INDEX IF NOT EXISTS idx_vault_org ON vault_entries(org_id);
|
|
941
|
+
CREATE INDEX IF NOT EXISTS idx_vault_category ON vault_entries(category);
|
|
942
|
+
CREATE UNIQUE INDEX IF NOT EXISTS idx_vault_org_name ON vault_entries(org_id, name);
|
|
943
|
+
|
|
944
|
+
-- Vault audit log (tracks every secret access for compliance)
|
|
945
|
+
CREATE TABLE IF NOT EXISTS vault_audit_log (
|
|
946
|
+
id TEXT PRIMARY KEY,
|
|
947
|
+
org_id TEXT NOT NULL,
|
|
948
|
+
vault_entry_id TEXT,
|
|
949
|
+
action TEXT NOT NULL,
|
|
950
|
+
actor TEXT NOT NULL,
|
|
951
|
+
ip TEXT,
|
|
952
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
953
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
954
|
+
);
|
|
955
|
+
CREATE INDEX IF NOT EXISTS idx_vault_audit_org ON vault_audit_log(org_id);
|
|
956
|
+
CREATE INDEX IF NOT EXISTS idx_vault_audit_entry ON vault_audit_log(vault_entry_id);
|
|
957
|
+
|
|
958
|
+
-- Org storage configurations
|
|
959
|
+
CREATE TABLE IF NOT EXISTS org_storage_config (
|
|
960
|
+
id TEXT PRIMARY KEY,
|
|
961
|
+
org_id TEXT NOT NULL,
|
|
962
|
+
storage_type TEXT NOT NULL DEFAULT 'local',
|
|
963
|
+
config JSON NOT NULL DEFAULT '{}',
|
|
964
|
+
vault_credential_id TEXT,
|
|
965
|
+
enabled INTEGER NOT NULL DEFAULT 1,
|
|
966
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
967
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
968
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
969
|
+
);
|
|
970
|
+
CREATE UNIQUE INDEX IF NOT EXISTS idx_org_storage_org ON org_storage_config(org_id);
|
|
971
|
+
|
|
972
|
+
-- Storage objects metadata
|
|
973
|
+
CREATE TABLE IF NOT EXISTS storage_objects (
|
|
974
|
+
id TEXT PRIMARY KEY,
|
|
975
|
+
org_id TEXT NOT NULL,
|
|
976
|
+
storage_key TEXT NOT NULL,
|
|
977
|
+
original_name TEXT NOT NULL,
|
|
978
|
+
content_type TEXT NOT NULL DEFAULT 'application/octet-stream',
|
|
979
|
+
size INTEGER NOT NULL DEFAULT 0,
|
|
980
|
+
related_type TEXT,
|
|
981
|
+
related_id TEXT,
|
|
982
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
983
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
984
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now'))
|
|
985
|
+
);
|
|
986
|
+
CREATE INDEX IF NOT EXISTS idx_storage_objects_org ON storage_objects(org_id);
|
|
987
|
+
CREATE INDEX IF NOT EXISTS idx_storage_objects_related ON storage_objects(related_type, related_id);
|
|
988
|
+
|
|
989
|
+
-- Policy import job tracking
|
|
990
|
+
CREATE TABLE IF NOT EXISTS policy_import_jobs (
|
|
991
|
+
id TEXT PRIMARY KEY,
|
|
992
|
+
org_id TEXT NOT NULL,
|
|
993
|
+
format TEXT NOT NULL,
|
|
994
|
+
status TEXT NOT NULL DEFAULT 'pending',
|
|
995
|
+
progress JSON NOT NULL DEFAULT '{}',
|
|
996
|
+
errors JSON NOT NULL DEFAULT '[]',
|
|
997
|
+
policy_ids JSON NOT NULL DEFAULT '[]',
|
|
998
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
999
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
1000
|
+
completed_at TEXT
|
|
1001
|
+
);
|
|
1002
|
+
CREATE INDEX IF NOT EXISTS idx_import_jobs_org ON policy_import_jobs(org_id);
|
|
1003
|
+
`,
|
|
1004
|
+
postgres: `
|
|
1005
|
+
CREATE TABLE IF NOT EXISTS vault_entries (
|
|
1006
|
+
id TEXT PRIMARY KEY,
|
|
1007
|
+
org_id TEXT NOT NULL,
|
|
1008
|
+
name TEXT NOT NULL,
|
|
1009
|
+
category TEXT NOT NULL DEFAULT 'custom',
|
|
1010
|
+
encrypted_value TEXT NOT NULL,
|
|
1011
|
+
metadata JSONB NOT NULL DEFAULT '{}',
|
|
1012
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
1013
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
1014
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
1015
|
+
rotated_at TIMESTAMPTZ,
|
|
1016
|
+
expires_at TIMESTAMPTZ
|
|
1017
|
+
);
|
|
1018
|
+
CREATE INDEX IF NOT EXISTS idx_vault_org ON vault_entries(org_id);
|
|
1019
|
+
CREATE INDEX IF NOT EXISTS idx_vault_category ON vault_entries(category);
|
|
1020
|
+
CREATE UNIQUE INDEX IF NOT EXISTS idx_vault_org_name ON vault_entries(org_id, name);
|
|
1021
|
+
|
|
1022
|
+
CREATE TABLE IF NOT EXISTS vault_audit_log (
|
|
1023
|
+
id TEXT PRIMARY KEY,
|
|
1024
|
+
org_id TEXT NOT NULL,
|
|
1025
|
+
vault_entry_id TEXT,
|
|
1026
|
+
action TEXT NOT NULL,
|
|
1027
|
+
actor TEXT NOT NULL,
|
|
1028
|
+
ip TEXT,
|
|
1029
|
+
metadata JSONB NOT NULL DEFAULT '{}',
|
|
1030
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
1031
|
+
);
|
|
1032
|
+
CREATE INDEX IF NOT EXISTS idx_vault_audit_org ON vault_audit_log(org_id);
|
|
1033
|
+
CREATE INDEX IF NOT EXISTS idx_vault_audit_entry ON vault_audit_log(vault_entry_id);
|
|
1034
|
+
|
|
1035
|
+
CREATE TABLE IF NOT EXISTS org_storage_config (
|
|
1036
|
+
id TEXT PRIMARY KEY,
|
|
1037
|
+
org_id TEXT NOT NULL,
|
|
1038
|
+
storage_type TEXT NOT NULL DEFAULT 'local',
|
|
1039
|
+
config JSONB NOT NULL DEFAULT '{}',
|
|
1040
|
+
vault_credential_id TEXT,
|
|
1041
|
+
enabled BOOLEAN NOT NULL DEFAULT TRUE,
|
|
1042
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
1043
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
1044
|
+
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
1045
|
+
);
|
|
1046
|
+
CREATE UNIQUE INDEX IF NOT EXISTS idx_org_storage_org ON org_storage_config(org_id);
|
|
1047
|
+
|
|
1048
|
+
CREATE TABLE IF NOT EXISTS storage_objects (
|
|
1049
|
+
id TEXT PRIMARY KEY,
|
|
1050
|
+
org_id TEXT NOT NULL,
|
|
1051
|
+
storage_key TEXT NOT NULL,
|
|
1052
|
+
original_name TEXT NOT NULL,
|
|
1053
|
+
content_type TEXT NOT NULL DEFAULT 'application/octet-stream',
|
|
1054
|
+
size INTEGER NOT NULL DEFAULT 0,
|
|
1055
|
+
related_type TEXT,
|
|
1056
|
+
related_id TEXT,
|
|
1057
|
+
metadata JSONB NOT NULL DEFAULT '{}',
|
|
1058
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
1059
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
1060
|
+
);
|
|
1061
|
+
CREATE INDEX IF NOT EXISTS idx_storage_objects_org ON storage_objects(org_id);
|
|
1062
|
+
CREATE INDEX IF NOT EXISTS idx_storage_objects_related ON storage_objects(related_type, related_id);
|
|
1063
|
+
|
|
1064
|
+
CREATE TABLE IF NOT EXISTS policy_import_jobs (
|
|
1065
|
+
id TEXT PRIMARY KEY,
|
|
1066
|
+
org_id TEXT NOT NULL,
|
|
1067
|
+
format TEXT NOT NULL,
|
|
1068
|
+
status TEXT NOT NULL DEFAULT 'pending',
|
|
1069
|
+
progress JSONB NOT NULL DEFAULT '{}',
|
|
1070
|
+
errors JSONB NOT NULL DEFAULT '[]',
|
|
1071
|
+
policy_ids JSONB NOT NULL DEFAULT '[]',
|
|
1072
|
+
created_by TEXT NOT NULL DEFAULT 'system',
|
|
1073
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
1074
|
+
completed_at TIMESTAMPTZ
|
|
1075
|
+
);
|
|
1076
|
+
CREATE INDEX IF NOT EXISTS idx_import_jobs_org ON policy_import_jobs(org_id);
|
|
1077
|
+
`,
|
|
1078
|
+
},
|
|
1079
|
+
{
|
|
1080
|
+
version: 11,
|
|
1081
|
+
name: 'reviews_global_add_user_name',
|
|
1082
|
+
sql: `ALTER TABLE community_skill_reviews ADD COLUMN user_name TEXT;`,
|
|
1083
|
+
postgres: `ALTER TABLE community_skill_reviews ADD COLUMN IF NOT EXISTS user_name TEXT;`,
|
|
1084
|
+
},
|
|
1085
|
+
{
|
|
1086
|
+
version: 12,
|
|
1087
|
+
name: 'tool_security_config',
|
|
1088
|
+
sql: `ALTER TABLE company_settings ADD COLUMN tool_security_config TEXT DEFAULT '{}';`,
|
|
1089
|
+
postgres: `ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS tool_security_config TEXT DEFAULT '{}';`,
|
|
1090
|
+
mysql: `ALTER TABLE company_settings ADD COLUMN tool_security_config TEXT DEFAULT '{}';`,
|
|
1091
|
+
nosql: async () => {
|
|
1092
|
+
// MongoDB and DynamoDB are schema-less; new fields added dynamically via updateSettings()
|
|
1093
|
+
},
|
|
1094
|
+
},
|
|
1095
|
+
{
|
|
1096
|
+
version: 13,
|
|
1097
|
+
name: 'firewall_config',
|
|
1098
|
+
sql: `ALTER TABLE company_settings ADD COLUMN firewall_config TEXT DEFAULT '{}';`,
|
|
1099
|
+
postgres: `ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS firewall_config TEXT DEFAULT '{}';`,
|
|
1100
|
+
mysql: `ALTER TABLE company_settings ADD COLUMN firewall_config TEXT DEFAULT '{}';`,
|
|
1101
|
+
nosql: async () => {},
|
|
1102
|
+
},
|
|
1103
|
+
{
|
|
1104
|
+
version: 14,
|
|
1105
|
+
name: 'agent_runtime_sessions',
|
|
1106
|
+
sql: `
|
|
1107
|
+
-- Agent runtime sessions (standalone agent execution)
|
|
1108
|
+
CREATE TABLE IF NOT EXISTS agent_sessions (
|
|
1109
|
+
id TEXT PRIMARY KEY,
|
|
1110
|
+
agent_id TEXT NOT NULL,
|
|
1111
|
+
org_id TEXT NOT NULL DEFAULT 'default',
|
|
1112
|
+
status TEXT NOT NULL DEFAULT 'active',
|
|
1113
|
+
token_count INTEGER DEFAULT 0,
|
|
1114
|
+
turn_count INTEGER DEFAULT 0,
|
|
1115
|
+
parent_session_id TEXT,
|
|
1116
|
+
created_at INTEGER NOT NULL,
|
|
1117
|
+
updated_at INTEGER NOT NULL
|
|
1118
|
+
);
|
|
1119
|
+
CREATE INDEX IF NOT EXISTS idx_agent_sessions_agent ON agent_sessions(agent_id);
|
|
1120
|
+
CREATE INDEX IF NOT EXISTS idx_agent_sessions_status ON agent_sessions(status);
|
|
1121
|
+
CREATE INDEX IF NOT EXISTS idx_agent_sessions_parent ON agent_sessions(parent_session_id);
|
|
1122
|
+
|
|
1123
|
+
-- Agent session messages (conversation history per session)
|
|
1124
|
+
CREATE TABLE IF NOT EXISTS agent_session_messages (
|
|
1125
|
+
id TEXT PRIMARY KEY,
|
|
1126
|
+
session_id TEXT NOT NULL,
|
|
1127
|
+
role TEXT NOT NULL,
|
|
1128
|
+
content TEXT NOT NULL,
|
|
1129
|
+
tool_calls TEXT,
|
|
1130
|
+
tool_results TEXT,
|
|
1131
|
+
created_at INTEGER NOT NULL,
|
|
1132
|
+
FOREIGN KEY (session_id) REFERENCES agent_sessions(id) ON DELETE CASCADE
|
|
1133
|
+
);
|
|
1134
|
+
CREATE INDEX IF NOT EXISTS idx_session_messages_session ON agent_session_messages(session_id);
|
|
1135
|
+
CREATE INDEX IF NOT EXISTS idx_session_messages_time ON agent_session_messages(created_at);
|
|
1136
|
+
`,
|
|
1137
|
+
postgres: `
|
|
1138
|
+
CREATE TABLE IF NOT EXISTS agent_sessions (
|
|
1139
|
+
id TEXT PRIMARY KEY,
|
|
1140
|
+
agent_id TEXT NOT NULL,
|
|
1141
|
+
org_id TEXT NOT NULL DEFAULT 'default',
|
|
1142
|
+
status TEXT NOT NULL DEFAULT 'active',
|
|
1143
|
+
token_count INTEGER DEFAULT 0,
|
|
1144
|
+
turn_count INTEGER DEFAULT 0,
|
|
1145
|
+
parent_session_id TEXT,
|
|
1146
|
+
created_at BIGINT NOT NULL,
|
|
1147
|
+
updated_at BIGINT NOT NULL
|
|
1148
|
+
);
|
|
1149
|
+
CREATE INDEX IF NOT EXISTS idx_agent_sessions_agent ON agent_sessions(agent_id);
|
|
1150
|
+
CREATE INDEX IF NOT EXISTS idx_agent_sessions_status ON agent_sessions(status);
|
|
1151
|
+
CREATE INDEX IF NOT EXISTS idx_agent_sessions_parent ON agent_sessions(parent_session_id);
|
|
1152
|
+
|
|
1153
|
+
CREATE TABLE IF NOT EXISTS agent_session_messages (
|
|
1154
|
+
id TEXT PRIMARY KEY,
|
|
1155
|
+
session_id TEXT NOT NULL,
|
|
1156
|
+
role TEXT NOT NULL,
|
|
1157
|
+
content TEXT NOT NULL,
|
|
1158
|
+
tool_calls TEXT,
|
|
1159
|
+
tool_results TEXT,
|
|
1160
|
+
created_at BIGINT NOT NULL,
|
|
1161
|
+
FOREIGN KEY (session_id) REFERENCES agent_sessions(id) ON DELETE CASCADE
|
|
1162
|
+
);
|
|
1163
|
+
CREATE INDEX IF NOT EXISTS idx_session_messages_session ON agent_session_messages(session_id);
|
|
1164
|
+
CREATE INDEX IF NOT EXISTS idx_session_messages_time ON agent_session_messages(created_at);
|
|
1165
|
+
`,
|
|
1166
|
+
},
|
|
1167
|
+
{
|
|
1168
|
+
version: 15,
|
|
1169
|
+
name: 'long_running_sessions',
|
|
1170
|
+
sql: `
|
|
1171
|
+
-- Add heartbeat tracking to agent sessions
|
|
1172
|
+
ALTER TABLE agent_sessions ADD COLUMN last_heartbeat_at INTEGER;
|
|
1173
|
+
ALTER TABLE agent_sessions ADD COLUMN cost_usd REAL DEFAULT 0;
|
|
1174
|
+
CREATE INDEX IF NOT EXISTS idx_agent_sessions_heartbeat ON agent_sessions(last_heartbeat_at);
|
|
1175
|
+
|
|
1176
|
+
-- Persistent follow-ups (survive restarts)
|
|
1177
|
+
CREATE TABLE IF NOT EXISTS agent_followups (
|
|
1178
|
+
id TEXT PRIMARY KEY,
|
|
1179
|
+
agent_id TEXT NOT NULL,
|
|
1180
|
+
session_id TEXT,
|
|
1181
|
+
message TEXT NOT NULL,
|
|
1182
|
+
execute_at INTEGER NOT NULL,
|
|
1183
|
+
status TEXT NOT NULL DEFAULT 'pending',
|
|
1184
|
+
created_at INTEGER NOT NULL
|
|
1185
|
+
);
|
|
1186
|
+
CREATE INDEX IF NOT EXISTS idx_agent_followups_status ON agent_followups(status);
|
|
1187
|
+
CREATE INDEX IF NOT EXISTS idx_agent_followups_execute ON agent_followups(execute_at);
|
|
1188
|
+
CREATE INDEX IF NOT EXISTS idx_agent_followups_agent ON agent_followups(agent_id);
|
|
1189
|
+
`,
|
|
1190
|
+
postgres: `
|
|
1191
|
+
ALTER TABLE agent_sessions ADD COLUMN IF NOT EXISTS last_heartbeat_at BIGINT;
|
|
1192
|
+
ALTER TABLE agent_sessions ADD COLUMN IF NOT EXISTS cost_usd DOUBLE PRECISION DEFAULT 0;
|
|
1193
|
+
CREATE INDEX IF NOT EXISTS idx_agent_sessions_heartbeat ON agent_sessions(last_heartbeat_at);
|
|
1194
|
+
|
|
1195
|
+
CREATE TABLE IF NOT EXISTS agent_followups (
|
|
1196
|
+
id TEXT PRIMARY KEY,
|
|
1197
|
+
agent_id TEXT NOT NULL,
|
|
1198
|
+
session_id TEXT,
|
|
1199
|
+
message TEXT NOT NULL,
|
|
1200
|
+
execute_at BIGINT NOT NULL,
|
|
1201
|
+
status TEXT NOT NULL DEFAULT 'pending',
|
|
1202
|
+
created_at BIGINT NOT NULL
|
|
1203
|
+
);
|
|
1204
|
+
CREATE INDEX IF NOT EXISTS idx_agent_followups_status ON agent_followups(status);
|
|
1205
|
+
CREATE INDEX IF NOT EXISTS idx_agent_followups_execute ON agent_followups(execute_at);
|
|
1206
|
+
CREATE INDEX IF NOT EXISTS idx_agent_followups_agent ON agent_followups(agent_id);
|
|
1207
|
+
`,
|
|
1208
|
+
mysql: `
|
|
1209
|
+
ALTER TABLE agent_sessions ADD COLUMN last_heartbeat_at BIGINT;
|
|
1210
|
+
ALTER TABLE agent_sessions ADD COLUMN cost_usd DOUBLE DEFAULT 0;
|
|
1211
|
+
CREATE INDEX idx_agent_sessions_heartbeat ON agent_sessions(last_heartbeat_at);
|
|
1212
|
+
|
|
1213
|
+
CREATE TABLE IF NOT EXISTS agent_followups (
|
|
1214
|
+
id VARCHAR(255) PRIMARY KEY,
|
|
1215
|
+
agent_id VARCHAR(255) NOT NULL,
|
|
1216
|
+
session_id VARCHAR(255),
|
|
1217
|
+
message TEXT NOT NULL,
|
|
1218
|
+
execute_at BIGINT NOT NULL,
|
|
1219
|
+
status VARCHAR(50) NOT NULL DEFAULT 'pending',
|
|
1220
|
+
created_at BIGINT NOT NULL
|
|
1221
|
+
);
|
|
1222
|
+
CREATE INDEX idx_agent_followups_status ON agent_followups(status);
|
|
1223
|
+
CREATE INDEX idx_agent_followups_execute ON agent_followups(execute_at);
|
|
1224
|
+
CREATE INDEX idx_agent_followups_agent ON agent_followups(agent_id);
|
|
1225
|
+
`,
|
|
1226
|
+
},
|
|
1227
|
+
{
|
|
1228
|
+
version: 16,
|
|
1229
|
+
name: 'model_pricing_config',
|
|
1230
|
+
sql: `ALTER TABLE company_settings ADD COLUMN model_pricing_config TEXT DEFAULT '{}';`,
|
|
1231
|
+
postgres: `ALTER TABLE company_settings ADD COLUMN IF NOT EXISTS model_pricing_config TEXT DEFAULT '{}';`,
|
|
1232
|
+
mysql: `ALTER TABLE company_settings ADD COLUMN model_pricing_config TEXT DEFAULT '{}';`,
|
|
1233
|
+
nosql: async () => {},
|
|
1234
|
+
},
|
|
287
1235
|
];
|
|
288
1236
|
|
|
289
1237
|
// ─── Dynamic Table Definitions ─────────────────────────
|