@sonde/packs 0.1.0 → 0.1.1
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/.turbo/turbo-build.log +6 -0
- package/.turbo/turbo-test.log +814 -0
- package/.turbo/turbo-typecheck.log +4 -0
- package/CHANGELOG.md +10 -0
- package/dist/index.d.ts +16 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +40 -2
- package/dist/index.js.map +1 -1
- package/dist/integrations/citrix.d.ts +13 -0
- package/dist/integrations/citrix.d.ts.map +1 -0
- package/dist/integrations/citrix.js +420 -0
- package/dist/integrations/citrix.js.map +1 -0
- package/dist/integrations/citrix.test.d.ts +2 -0
- package/dist/integrations/citrix.test.d.ts.map +1 -0
- package/dist/integrations/citrix.test.js +464 -0
- package/dist/integrations/citrix.test.js.map +1 -0
- package/dist/integrations/graph.d.ts +9 -0
- package/dist/integrations/graph.d.ts.map +1 -0
- package/dist/integrations/graph.js +290 -0
- package/dist/integrations/graph.js.map +1 -0
- package/dist/integrations/graph.test.d.ts +2 -0
- package/dist/integrations/graph.test.d.ts.map +1 -0
- package/dist/integrations/graph.test.js +356 -0
- package/dist/integrations/graph.test.js.map +1 -0
- package/dist/integrations/httpbin.d.ts +3 -0
- package/dist/integrations/httpbin.d.ts.map +1 -0
- package/dist/integrations/httpbin.js +70 -0
- package/dist/integrations/httpbin.js.map +1 -0
- package/dist/integrations/nutanix.d.ts +18 -0
- package/dist/integrations/nutanix.d.ts.map +1 -0
- package/dist/integrations/nutanix.js +1121 -0
- package/dist/integrations/nutanix.js.map +1 -0
- package/dist/integrations/nutanix.test.d.ts +2 -0
- package/dist/integrations/nutanix.test.d.ts.map +1 -0
- package/dist/integrations/nutanix.test.js +978 -0
- package/dist/integrations/nutanix.test.js.map +1 -0
- package/dist/integrations/proxmox.d.ts +12 -0
- package/dist/integrations/proxmox.d.ts.map +1 -0
- package/dist/integrations/proxmox.js +733 -0
- package/dist/integrations/proxmox.js.map +1 -0
- package/dist/integrations/proxmox.test.d.ts +2 -0
- package/dist/integrations/proxmox.test.d.ts.map +1 -0
- package/dist/integrations/proxmox.test.js +697 -0
- package/dist/integrations/proxmox.test.js.map +1 -0
- package/dist/integrations/servicenow.d.ts +3 -0
- package/dist/integrations/servicenow.d.ts.map +1 -0
- package/dist/integrations/servicenow.js +257 -0
- package/dist/integrations/servicenow.js.map +1 -0
- package/dist/integrations/servicenow.test.d.ts +2 -0
- package/dist/integrations/servicenow.test.d.ts.map +1 -0
- package/dist/integrations/servicenow.test.js +217 -0
- package/dist/integrations/servicenow.test.js.map +1 -0
- package/dist/integrations/splunk.d.ts +9 -0
- package/dist/integrations/splunk.d.ts.map +1 -0
- package/dist/integrations/splunk.js +242 -0
- package/dist/integrations/splunk.js.map +1 -0
- package/dist/integrations/splunk.test.d.ts +2 -0
- package/dist/integrations/splunk.test.d.ts.map +1 -0
- package/dist/integrations/splunk.test.js +323 -0
- package/dist/integrations/splunk.test.js.map +1 -0
- package/dist/mysql/index.d.ts +3 -0
- package/dist/mysql/index.d.ts.map +1 -0
- package/dist/mysql/index.js +13 -0
- package/dist/mysql/index.js.map +1 -0
- package/dist/mysql/manifest.d.ts +3 -0
- package/dist/mysql/manifest.d.ts.map +1 -0
- package/dist/mysql/manifest.js +69 -0
- package/dist/mysql/manifest.js.map +1 -0
- package/dist/mysql/probes/databases-list.d.ts +13 -0
- package/dist/mysql/probes/databases-list.d.ts.map +1 -0
- package/dist/mysql/probes/databases-list.js +31 -0
- package/dist/mysql/probes/databases-list.js.map +1 -0
- package/dist/mysql/probes/databases-list.test.d.ts +2 -0
- package/dist/mysql/probes/databases-list.test.d.ts.map +1 -0
- package/dist/mysql/probes/databases-list.test.js +54 -0
- package/dist/mysql/probes/databases-list.test.js.map +1 -0
- package/dist/mysql/probes/processlist.d.ts +18 -0
- package/dist/mysql/probes/processlist.d.ts.map +1 -0
- package/dist/mysql/probes/processlist.js +36 -0
- package/dist/mysql/probes/processlist.js.map +1 -0
- package/dist/mysql/probes/processlist.test.d.ts +2 -0
- package/dist/mysql/probes/processlist.test.d.ts.map +1 -0
- package/dist/mysql/probes/processlist.test.js +41 -0
- package/dist/mysql/probes/processlist.test.js.map +1 -0
- package/dist/mysql/probes/status.d.ts +14 -0
- package/dist/mysql/probes/status.d.ts.map +1 -0
- package/dist/mysql/probes/status.js +40 -0
- package/dist/mysql/probes/status.js.map +1 -0
- package/dist/mysql/probes/status.test.d.ts +2 -0
- package/dist/mysql/probes/status.test.d.ts.map +1 -0
- package/dist/mysql/probes/status.test.js +43 -0
- package/dist/mysql/probes/status.test.js.map +1 -0
- package/dist/nginx/index.d.ts +3 -0
- package/dist/nginx/index.d.ts.map +1 -0
- package/dist/nginx/index.js +13 -0
- package/dist/nginx/index.js.map +1 -0
- package/dist/nginx/manifest.d.ts +3 -0
- package/dist/nginx/manifest.d.ts.map +1 -0
- package/dist/nginx/manifest.js +68 -0
- package/dist/nginx/manifest.js.map +1 -0
- package/dist/nginx/probes/access-log-tail.d.ts +9 -0
- package/dist/nginx/probes/access-log-tail.d.ts.map +1 -0
- package/dist/nginx/probes/access-log-tail.js +14 -0
- package/dist/nginx/probes/access-log-tail.js.map +1 -0
- package/dist/nginx/probes/access-log-tail.test.d.ts +2 -0
- package/dist/nginx/probes/access-log-tail.test.d.ts.map +1 -0
- package/dist/nginx/probes/access-log-tail.test.js +40 -0
- package/dist/nginx/probes/access-log-tail.test.js.map +1 -0
- package/dist/nginx/probes/config-test.d.ts +8 -0
- package/dist/nginx/probes/config-test.d.ts.map +1 -0
- package/dist/nginx/probes/config-test.js +18 -0
- package/dist/nginx/probes/config-test.js.map +1 -0
- package/dist/nginx/probes/config-test.test.d.ts +2 -0
- package/dist/nginx/probes/config-test.test.d.ts.map +1 -0
- package/dist/nginx/probes/config-test.test.js +35 -0
- package/dist/nginx/probes/config-test.test.js.map +1 -0
- package/dist/nginx/probes/error-log-tail.d.ts +9 -0
- package/dist/nginx/probes/error-log-tail.d.ts.map +1 -0
- package/dist/nginx/probes/error-log-tail.js +14 -0
- package/dist/nginx/probes/error-log-tail.js.map +1 -0
- package/dist/nginx/probes/error-log-tail.test.d.ts +2 -0
- package/dist/nginx/probes/error-log-tail.test.d.ts.map +1 -0
- package/dist/nginx/probes/error-log-tail.test.js +34 -0
- package/dist/nginx/probes/error-log-tail.test.js.map +1 -0
- package/dist/postgres/index.d.ts +3 -0
- package/dist/postgres/index.d.ts.map +1 -0
- package/dist/postgres/index.js +13 -0
- package/dist/postgres/index.js.map +1 -0
- package/dist/postgres/manifest.d.ts +3 -0
- package/dist/postgres/manifest.d.ts.map +1 -0
- package/dist/postgres/manifest.js +90 -0
- package/dist/postgres/manifest.js.map +1 -0
- package/dist/postgres/probes/connections-active.d.ts +17 -0
- package/dist/postgres/probes/connections-active.d.ts.map +1 -0
- package/dist/postgres/probes/connections-active.js +37 -0
- package/dist/postgres/probes/connections-active.js.map +1 -0
- package/dist/postgres/probes/connections-active.test.d.ts +2 -0
- package/dist/postgres/probes/connections-active.test.d.ts.map +1 -0
- package/dist/postgres/probes/connections-active.test.js +36 -0
- package/dist/postgres/probes/connections-active.test.js.map +1 -0
- package/dist/postgres/probes/databases-list.d.ts +14 -0
- package/dist/postgres/probes/databases-list.d.ts.map +1 -0
- package/dist/postgres/probes/databases-list.js +34 -0
- package/dist/postgres/probes/databases-list.js.map +1 -0
- package/dist/postgres/probes/databases-list.test.d.ts +2 -0
- package/dist/postgres/probes/databases-list.test.d.ts.map +1 -0
- package/dist/postgres/probes/databases-list.test.js +49 -0
- package/dist/postgres/probes/databases-list.test.js.map +1 -0
- package/dist/postgres/probes/query-slow.d.ts +17 -0
- package/dist/postgres/probes/query-slow.d.ts.map +1 -0
- package/dist/postgres/probes/query-slow.js +37 -0
- package/dist/postgres/probes/query-slow.js.map +1 -0
- package/dist/postgres/probes/query-slow.test.d.ts +2 -0
- package/dist/postgres/probes/query-slow.test.d.ts.map +1 -0
- package/dist/postgres/probes/query-slow.test.js +30 -0
- package/dist/postgres/probes/query-slow.test.js.map +1 -0
- package/dist/proxmox/index.d.ts +3 -0
- package/dist/proxmox/index.d.ts.map +1 -0
- package/dist/proxmox/index.js +23 -0
- package/dist/proxmox/index.js.map +1 -0
- package/dist/proxmox/manifest.d.ts +3 -0
- package/dist/proxmox/manifest.d.ts.map +1 -0
- package/dist/proxmox/manifest.js +75 -0
- package/dist/proxmox/manifest.js.map +1 -0
- package/dist/proxmox/probes/ceph-status.d.ts +36 -0
- package/dist/proxmox/probes/ceph-status.d.ts.map +1 -0
- package/dist/proxmox/probes/ceph-status.js +71 -0
- package/dist/proxmox/probes/ceph-status.js.map +1 -0
- package/dist/proxmox/probes/ceph-status.test.d.ts +2 -0
- package/dist/proxmox/probes/ceph-status.test.d.ts.map +1 -0
- package/dist/proxmox/probes/ceph-status.test.js +115 -0
- package/dist/proxmox/probes/ceph-status.test.js.map +1 -0
- package/dist/proxmox/probes/cluster-config.d.ts +31 -0
- package/dist/proxmox/probes/cluster-config.d.ts.map +1 -0
- package/dist/proxmox/probes/cluster-config.js +72 -0
- package/dist/proxmox/probes/cluster-config.js.map +1 -0
- package/dist/proxmox/probes/cluster-config.test.d.ts +2 -0
- package/dist/proxmox/probes/cluster-config.test.d.ts.map +1 -0
- package/dist/proxmox/probes/cluster-config.test.js +107 -0
- package/dist/proxmox/probes/cluster-config.test.js.map +1 -0
- package/dist/proxmox/probes/ha-status.d.ts +18 -0
- package/dist/proxmox/probes/ha-status.d.ts.map +1 -0
- package/dist/proxmox/probes/ha-status.js +38 -0
- package/dist/proxmox/probes/ha-status.js.map +1 -0
- package/dist/proxmox/probes/ha-status.test.d.ts +2 -0
- package/dist/proxmox/probes/ha-status.test.d.ts.map +1 -0
- package/dist/proxmox/probes/ha-status.test.js +66 -0
- package/dist/proxmox/probes/ha-status.test.js.map +1 -0
- package/dist/proxmox/probes/lvm.d.ts +35 -0
- package/dist/proxmox/probes/lvm.d.ts.map +1 -0
- package/dist/proxmox/probes/lvm.js +75 -0
- package/dist/proxmox/probes/lvm.js.map +1 -0
- package/dist/proxmox/probes/lvm.test.d.ts +2 -0
- package/dist/proxmox/probes/lvm.test.d.ts.map +1 -0
- package/dist/proxmox/probes/lvm.test.js +128 -0
- package/dist/proxmox/probes/lvm.test.js.map +1 -0
- package/dist/proxmox/probes/lxc-config.d.ts +29 -0
- package/dist/proxmox/probes/lxc-config.d.ts.map +1 -0
- package/dist/proxmox/probes/lxc-config.js +67 -0
- package/dist/proxmox/probes/lxc-config.js.map +1 -0
- package/dist/proxmox/probes/lxc-config.test.d.ts +2 -0
- package/dist/proxmox/probes/lxc-config.test.d.ts.map +1 -0
- package/dist/proxmox/probes/lxc-config.test.js +77 -0
- package/dist/proxmox/probes/lxc-config.test.js.map +1 -0
- package/dist/proxmox/probes/lxc-list.d.ts +20 -0
- package/dist/proxmox/probes/lxc-list.d.ts.map +1 -0
- package/dist/proxmox/probes/lxc-list.js +49 -0
- package/dist/proxmox/probes/lxc-list.js.map +1 -0
- package/dist/proxmox/probes/lxc-list.test.d.ts +2 -0
- package/dist/proxmox/probes/lxc-list.test.d.ts.map +1 -0
- package/dist/proxmox/probes/lxc-list.test.js +51 -0
- package/dist/proxmox/probes/lxc-list.test.js.map +1 -0
- package/dist/proxmox/probes/vm-config.d.ts +21 -0
- package/dist/proxmox/probes/vm-config.d.ts.map +1 -0
- package/dist/proxmox/probes/vm-config.js +58 -0
- package/dist/proxmox/probes/vm-config.js.map +1 -0
- package/dist/proxmox/probes/vm-config.test.d.ts +2 -0
- package/dist/proxmox/probes/vm-config.test.d.ts.map +1 -0
- package/dist/proxmox/probes/vm-config.test.js +80 -0
- package/dist/proxmox/probes/vm-config.test.js.map +1 -0
- package/dist/proxmox/probes/vm-locks.d.ts +16 -0
- package/dist/proxmox/probes/vm-locks.d.ts.map +1 -0
- package/dist/proxmox/probes/vm-locks.js +35 -0
- package/dist/proxmox/probes/vm-locks.js.map +1 -0
- package/dist/proxmox/probes/vm-locks.test.d.ts +2 -0
- package/dist/proxmox/probes/vm-locks.test.d.ts.map +1 -0
- package/dist/proxmox/probes/vm-locks.test.js +54 -0
- package/dist/proxmox/probes/vm-locks.test.js.map +1 -0
- package/dist/redis/index.d.ts +3 -0
- package/dist/redis/index.d.ts.map +1 -0
- package/dist/redis/index.js +13 -0
- package/dist/redis/index.js.map +1 -0
- package/dist/redis/manifest.d.ts +3 -0
- package/dist/redis/manifest.d.ts.map +1 -0
- package/dist/redis/manifest.js +51 -0
- package/dist/redis/manifest.js.map +1 -0
- package/dist/redis/probes/info.d.ts +15 -0
- package/dist/redis/probes/info.d.ts.map +1 -0
- package/dist/redis/probes/info.js +32 -0
- package/dist/redis/probes/info.js.map +1 -0
- package/dist/redis/probes/info.test.d.ts +2 -0
- package/dist/redis/probes/info.test.d.ts.map +1 -0
- package/dist/redis/probes/info.test.js +64 -0
- package/dist/redis/probes/info.test.js.map +1 -0
- package/dist/redis/probes/keys-count.d.ts +13 -0
- package/dist/redis/probes/keys-count.d.ts.map +1 -0
- package/dist/redis/probes/keys-count.js +24 -0
- package/dist/redis/probes/keys-count.js.map +1 -0
- package/dist/redis/probes/keys-count.test.d.ts +2 -0
- package/dist/redis/probes/keys-count.test.d.ts.map +1 -0
- package/dist/redis/probes/keys-count.test.js +37 -0
- package/dist/redis/probes/keys-count.test.js.map +1 -0
- package/dist/redis/probes/memory-usage.d.ts +16 -0
- package/dist/redis/probes/memory-usage.d.ts.map +1 -0
- package/dist/redis/probes/memory-usage.js +31 -0
- package/dist/redis/probes/memory-usage.js.map +1 -0
- package/dist/redis/probes/memory-usage.test.d.ts +2 -0
- package/dist/redis/probes/memory-usage.test.d.ts.map +1 -0
- package/dist/redis/probes/memory-usage.test.js +48 -0
- package/dist/redis/probes/memory-usage.test.js.map +1 -0
- package/dist/runbooks/nutanix.d.ts +3 -0
- package/dist/runbooks/nutanix.d.ts.map +1 -0
- package/dist/runbooks/nutanix.js +619 -0
- package/dist/runbooks/nutanix.js.map +1 -0
- package/dist/runbooks/nutanix.test.d.ts +2 -0
- package/dist/runbooks/nutanix.test.d.ts.map +1 -0
- package/dist/runbooks/nutanix.test.js +971 -0
- package/dist/runbooks/nutanix.test.js.map +1 -0
- package/dist/runbooks/proxmox.d.ts +3 -0
- package/dist/runbooks/proxmox.d.ts.map +1 -0
- package/dist/runbooks/proxmox.js +451 -0
- package/dist/runbooks/proxmox.js.map +1 -0
- package/dist/runbooks/proxmox.test.d.ts +2 -0
- package/dist/runbooks/proxmox.test.d.ts.map +1 -0
- package/dist/runbooks/proxmox.test.js +700 -0
- package/dist/runbooks/proxmox.test.js.map +1 -0
- package/dist/signatures.d.ts +2 -0
- package/dist/signatures.d.ts.map +1 -0
- package/dist/signatures.js +2 -0
- package/dist/signatures.js.map +1 -0
- package/dist/types.d.ts +53 -0
- package/dist/types.d.ts.map +1 -1
- package/dist/validation.d.ts +6 -1
- package/dist/validation.d.ts.map +1 -1
- package/dist/validation.js +10 -1
- package/dist/validation.js.map +1 -1
- package/package.json +1 -1
- package/src/index.ts +60 -6
- package/src/integrations/citrix.test.ts +592 -0
- package/src/integrations/citrix.ts +557 -0
- package/src/integrations/graph.test.ts +478 -0
- package/src/integrations/graph.ts +413 -0
- package/src/integrations/httpbin.ts +72 -0
- package/src/integrations/nutanix.test.ts +1508 -0
- package/src/integrations/nutanix.ts +1460 -0
- package/src/integrations/proxmox.test.ts +1020 -0
- package/src/integrations/proxmox.ts +989 -0
- package/src/integrations/servicenow.test.ts +314 -0
- package/src/integrations/servicenow.ts +285 -0
- package/src/integrations/splunk.test.ts +440 -0
- package/src/integrations/splunk.ts +356 -0
- package/src/mysql/index.ts +14 -0
- package/src/mysql/manifest.ts +70 -0
- package/src/mysql/probes/databases-list.test.ts +62 -0
- package/src/mysql/probes/databases-list.ts +45 -0
- package/src/mysql/probes/processlist.test.ts +47 -0
- package/src/mysql/probes/processlist.ts +55 -0
- package/src/mysql/probes/status.test.ts +50 -0
- package/src/mysql/probes/status.ts +56 -0
- package/src/nginx/index.ts +14 -0
- package/src/nginx/manifest.ts +69 -0
- package/src/nginx/probes/access-log-tail.test.ts +51 -0
- package/src/nginx/probes/access-log-tail.ts +23 -0
- package/src/nginx/probes/config-test.test.ts +47 -0
- package/src/nginx/probes/config-test.ts +24 -0
- package/src/nginx/probes/error-log-tail.test.ts +44 -0
- package/src/nginx/probes/error-log-tail.ts +23 -0
- package/src/postgres/index.ts +14 -0
- package/src/postgres/manifest.ts +91 -0
- package/src/postgres/probes/connections-active.test.ts +42 -0
- package/src/postgres/probes/connections-active.ts +55 -0
- package/src/postgres/probes/databases-list.test.ts +57 -0
- package/src/postgres/probes/databases-list.ts +49 -0
- package/src/postgres/probes/query-slow.test.ts +37 -0
- package/src/postgres/probes/query-slow.ts +55 -0
- package/src/proxmox/index.ts +24 -0
- package/src/proxmox/manifest.ts +76 -0
- package/src/proxmox/probes/ceph-status.test.ts +126 -0
- package/src/proxmox/probes/ceph-status.ts +116 -0
- package/src/proxmox/probes/cluster-config.test.ts +118 -0
- package/src/proxmox/probes/cluster-config.ts +97 -0
- package/src/proxmox/probes/ha-status.test.ts +76 -0
- package/src/proxmox/probes/ha-status.ts +56 -0
- package/src/proxmox/probes/lvm.test.ts +140 -0
- package/src/proxmox/probes/lvm.ts +121 -0
- package/src/proxmox/probes/lxc-config.test.ts +89 -0
- package/src/proxmox/probes/lxc-config.ts +90 -0
- package/src/proxmox/probes/lxc-list.test.ts +60 -0
- package/src/proxmox/probes/lxc-list.ts +67 -0
- package/src/proxmox/probes/vm-config.test.ts +93 -0
- package/src/proxmox/probes/vm-config.ts +77 -0
- package/src/proxmox/probes/vm-locks.test.ts +63 -0
- package/src/proxmox/probes/vm-locks.ts +49 -0
- package/src/redis/index.ts +14 -0
- package/src/redis/manifest.ts +52 -0
- package/src/redis/probes/info.test.ts +73 -0
- package/src/redis/probes/info.ts +46 -0
- package/src/redis/probes/keys-count.test.ts +44 -0
- package/src/redis/probes/keys-count.ts +38 -0
- package/src/redis/probes/memory-usage.test.ts +54 -0
- package/src/redis/probes/memory-usage.ts +46 -0
- package/src/runbooks/nutanix.test.ts +1138 -0
- package/src/runbooks/nutanix.ts +941 -0
- package/src/runbooks/proxmox.test.ts +838 -0
- package/src/runbooks/proxmox.ts +626 -0
- package/src/signatures.ts +1 -0
- package/src/types.ts +62 -0
- package/src/validation.ts +21 -1
- package/tsconfig.tsbuildinfo +1 -0
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
export const mysqlManifest = {
|
|
2
|
+
name: 'mysql',
|
|
3
|
+
version: '0.1.0',
|
|
4
|
+
description: 'MySQL probes: database listing, process list, server status',
|
|
5
|
+
requires: {
|
|
6
|
+
groups: [],
|
|
7
|
+
files: [],
|
|
8
|
+
commands: ['mysql'],
|
|
9
|
+
},
|
|
10
|
+
probes: [
|
|
11
|
+
{
|
|
12
|
+
name: 'databases.list',
|
|
13
|
+
description: 'List all MySQL databases with table counts and sizes',
|
|
14
|
+
capability: 'observe',
|
|
15
|
+
params: {
|
|
16
|
+
host: {
|
|
17
|
+
type: 'string',
|
|
18
|
+
description: 'Database host',
|
|
19
|
+
required: false,
|
|
20
|
+
default: 'localhost',
|
|
21
|
+
},
|
|
22
|
+
port: { type: 'number', description: 'Database port', required: false, default: 3306 },
|
|
23
|
+
user: { type: 'string', description: 'Database user', required: false, default: 'root' },
|
|
24
|
+
},
|
|
25
|
+
timeout: 15_000,
|
|
26
|
+
},
|
|
27
|
+
{
|
|
28
|
+
name: 'processlist',
|
|
29
|
+
description: 'Show active MySQL processes',
|
|
30
|
+
capability: 'observe',
|
|
31
|
+
params: {
|
|
32
|
+
host: {
|
|
33
|
+
type: 'string',
|
|
34
|
+
description: 'Database host',
|
|
35
|
+
required: false,
|
|
36
|
+
default: 'localhost',
|
|
37
|
+
},
|
|
38
|
+
port: { type: 'number', description: 'Database port', required: false, default: 3306 },
|
|
39
|
+
user: { type: 'string', description: 'Database user', required: false, default: 'root' },
|
|
40
|
+
},
|
|
41
|
+
timeout: 15_000,
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
name: 'status',
|
|
45
|
+
description: 'Get MySQL server status variables',
|
|
46
|
+
capability: 'observe',
|
|
47
|
+
params: {
|
|
48
|
+
host: {
|
|
49
|
+
type: 'string',
|
|
50
|
+
description: 'Database host',
|
|
51
|
+
required: false,
|
|
52
|
+
default: 'localhost',
|
|
53
|
+
},
|
|
54
|
+
port: { type: 'number', description: 'Database port', required: false, default: 3306 },
|
|
55
|
+
user: { type: 'string', description: 'Database user', required: false, default: 'root' },
|
|
56
|
+
},
|
|
57
|
+
timeout: 15_000,
|
|
58
|
+
},
|
|
59
|
+
],
|
|
60
|
+
runbook: {
|
|
61
|
+
category: 'mysql',
|
|
62
|
+
probes: ['databases.list', 'processlist', 'status'],
|
|
63
|
+
parallel: true,
|
|
64
|
+
},
|
|
65
|
+
detect: {
|
|
66
|
+
commands: ['mysql'],
|
|
67
|
+
},
|
|
68
|
+
};
|
|
69
|
+
//# sourceMappingURL=manifest.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"manifest.js","sourceRoot":"","sources":["../../src/mysql/manifest.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,aAAa,GAAiB;IACzC,IAAI,EAAE,OAAO;IACb,OAAO,EAAE,OAAO;IAChB,WAAW,EAAE,6DAA6D;IAC1E,QAAQ,EAAE;QACR,MAAM,EAAE,EAAE;QACV,KAAK,EAAE,EAAE;QACT,QAAQ,EAAE,CAAC,OAAO,CAAC;KACpB;IACD,MAAM,EAAE;QACN;YACE,IAAI,EAAE,gBAAgB;YACtB,WAAW,EAAE,sDAAsD;YACnE,UAAU,EAAE,SAAS;YACrB,MAAM,EAAE;gBACN,IAAI,EAAE;oBACJ,IAAI,EAAE,QAAQ;oBACd,WAAW,EAAE,eAAe;oBAC5B,QAAQ,EAAE,KAAK;oBACf,OAAO,EAAE,WAAW;iBACrB;gBACD,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,eAAe,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE;gBACtF,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,eAAe,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE;aACzF;YACD,OAAO,EAAE,MAAM;SAChB;QACD;YACE,IAAI,EAAE,aAAa;YACnB,WAAW,EAAE,6BAA6B;YAC1C,UAAU,EAAE,SAAS;YACrB,MAAM,EAAE;gBACN,IAAI,EAAE;oBACJ,IAAI,EAAE,QAAQ;oBACd,WAAW,EAAE,eAAe;oBAC5B,QAAQ,EAAE,KAAK;oBACf,OAAO,EAAE,WAAW;iBACrB;gBACD,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,eAAe,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE;gBACtF,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,eAAe,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE;aACzF;YACD,OAAO,EAAE,MAAM;SAChB;QACD;YACE,IAAI,EAAE,QAAQ;YACd,WAAW,EAAE,mCAAmC;YAChD,UAAU,EAAE,SAAS;YACrB,MAAM,EAAE;gBACN,IAAI,EAAE;oBACJ,IAAI,EAAE,QAAQ;oBACd,WAAW,EAAE,eAAe;oBAC5B,QAAQ,EAAE,KAAK;oBACf,OAAO,EAAE,WAAW;iBACrB;gBACD,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,eAAe,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE;gBACtF,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,eAAe,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE;aACzF;YACD,OAAO,EAAE,MAAM;SAChB;KACF;IACD,OAAO,EAAE;QACP,QAAQ,EAAE,OAAO;QACjB,MAAM,EAAE,CAAC,gBAAgB,EAAE,aAAa,EAAE,QAAQ,CAAC;QACnD,QAAQ,EAAE,IAAI;KACf;IACD,MAAM,EAAE;QACN,QAAQ,EAAE,CAAC,OAAO,CAAC;KACpB;CACF,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { ProbeHandler } from '../../types.js';
|
|
2
|
+
export interface MysqlDatabaseInfo {
|
|
3
|
+
name: string;
|
|
4
|
+
tables: number;
|
|
5
|
+
sizeMb: number;
|
|
6
|
+
}
|
|
7
|
+
export interface MysqlDatabasesListResult {
|
|
8
|
+
databases: MysqlDatabaseInfo[];
|
|
9
|
+
count: number;
|
|
10
|
+
}
|
|
11
|
+
export declare const databasesList: ProbeHandler;
|
|
12
|
+
export declare function parseDatabasesList(stdout: string): MysqlDatabasesListResult;
|
|
13
|
+
//# sourceMappingURL=databases-list.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"databases-list.d.ts","sourceRoot":"","sources":["../../../src/mysql/probes/databases-list.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAEnD,MAAM,WAAW,iBAAiB;IAChC,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,wBAAwB;IACvC,SAAS,EAAE,iBAAiB,EAAE,CAAC;IAC/B,KAAK,EAAE,MAAM,CAAC;CACf;AAED,eAAO,MAAM,aAAa,EAAE,YAkB3B,CAAC;AAEF,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,wBAAwB,CAW3E"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
export const databasesList = async (params, exec) => {
|
|
2
|
+
const host = params?.host ?? 'localhost';
|
|
3
|
+
const port = String(params?.port ?? 3306);
|
|
4
|
+
const user = params?.user ?? 'root';
|
|
5
|
+
const stdout = await exec('mysql', [
|
|
6
|
+
'-h',
|
|
7
|
+
host,
|
|
8
|
+
'-P',
|
|
9
|
+
port,
|
|
10
|
+
'-u',
|
|
11
|
+
user,
|
|
12
|
+
'--batch',
|
|
13
|
+
'--skip-column-names',
|
|
14
|
+
'-e',
|
|
15
|
+
'SELECT s.SCHEMA_NAME, COUNT(t.TABLE_NAME), ROUND(SUM(t.DATA_LENGTH + t.INDEX_LENGTH) / 1024 / 1024, 2) FROM information_schema.SCHEMATA s LEFT JOIN information_schema.TABLES t ON s.SCHEMA_NAME = t.TABLE_SCHEMA GROUP BY s.SCHEMA_NAME ORDER BY s.SCHEMA_NAME',
|
|
16
|
+
]);
|
|
17
|
+
return parseDatabasesList(stdout);
|
|
18
|
+
};
|
|
19
|
+
export function parseDatabasesList(stdout) {
|
|
20
|
+
const lines = stdout.trim().split('\n').filter(Boolean);
|
|
21
|
+
const databases = lines.map((line) => {
|
|
22
|
+
const parts = line.split('\t');
|
|
23
|
+
return {
|
|
24
|
+
name: parts[0] ?? '',
|
|
25
|
+
tables: Number(parts[1]) || 0,
|
|
26
|
+
sizeMb: Number(parts[2]) || 0,
|
|
27
|
+
};
|
|
28
|
+
});
|
|
29
|
+
return { databases, count: databases.length };
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=databases-list.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"databases-list.js","sourceRoot":"","sources":["../../../src/mysql/probes/databases-list.ts"],"names":[],"mappings":"AAaA,MAAM,CAAC,MAAM,aAAa,GAAiB,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE;IAChE,MAAM,IAAI,GAAI,MAAM,EAAE,IAAe,IAAI,WAAW,CAAC;IACrD,MAAM,IAAI,GAAG,MAAM,CAAE,MAAM,EAAE,IAAe,IAAI,IAAI,CAAC,CAAC;IACtD,MAAM,IAAI,GAAI,MAAM,EAAE,IAAe,IAAI,MAAM,CAAC;IAEhD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,OAAO,EAAE;QACjC,IAAI;QACJ,IAAI;QACJ,IAAI;QACJ,IAAI;QACJ,IAAI;QACJ,IAAI;QACJ,SAAS;QACT,qBAAqB;QACrB,IAAI;QACJ,iQAAiQ;KAClQ,CAAC,CAAC;IACH,OAAO,kBAAkB,CAAC,MAAM,CAAC,CAAC;AACpC,CAAC,CAAC;AAEF,MAAM,UAAU,kBAAkB,CAAC,MAAc;IAC/C,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACxD,MAAM,SAAS,GAAwB,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;QACxD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC/B,OAAO;YACL,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE;YACpB,MAAM,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YAC7B,MAAM,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;SAC9B,CAAC;IACJ,CAAC,CAAC,CAAC;IACH,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,CAAC,MAAM,EAAE,CAAC;AAChD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"databases-list.test.d.ts","sourceRoot":"","sources":["../../../src/mysql/probes/databases-list.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { databasesList, parseDatabasesList } from './databases-list.js';
|
|
3
|
+
const SAMPLE_OUTPUT = `information_schema\t79\t0.00
|
|
4
|
+
myapp\t15\t256.50
|
|
5
|
+
mysql\t38\t2.44`;
|
|
6
|
+
describe('parseDatabasesList', () => {
|
|
7
|
+
it('parses mysql output into structured data', () => {
|
|
8
|
+
const result = parseDatabasesList(SAMPLE_OUTPUT);
|
|
9
|
+
expect(result.count).toBe(3);
|
|
10
|
+
expect(result.databases[0]).toEqual({
|
|
11
|
+
name: 'information_schema',
|
|
12
|
+
tables: 79,
|
|
13
|
+
sizeMb: 0,
|
|
14
|
+
});
|
|
15
|
+
expect(result.databases[1]).toEqual({
|
|
16
|
+
name: 'myapp',
|
|
17
|
+
tables: 15,
|
|
18
|
+
sizeMb: 256.5,
|
|
19
|
+
});
|
|
20
|
+
});
|
|
21
|
+
it('handles empty output', () => {
|
|
22
|
+
const result = parseDatabasesList('');
|
|
23
|
+
expect(result.count).toBe(0);
|
|
24
|
+
expect(result.databases).toEqual([]);
|
|
25
|
+
});
|
|
26
|
+
});
|
|
27
|
+
describe('databasesList handler', () => {
|
|
28
|
+
it('calls mysql with default params', async () => {
|
|
29
|
+
const mockExec = async (cmd, args) => {
|
|
30
|
+
expect(cmd).toBe('mysql');
|
|
31
|
+
expect(args).toContain('-h');
|
|
32
|
+
expect(args).toContain('localhost');
|
|
33
|
+
expect(args).toContain('-P');
|
|
34
|
+
expect(args).toContain('3306');
|
|
35
|
+
expect(args).toContain('-u');
|
|
36
|
+
expect(args).toContain('root');
|
|
37
|
+
expect(args).toContain('--batch');
|
|
38
|
+
expect(args).toContain('--skip-column-names');
|
|
39
|
+
return SAMPLE_OUTPUT;
|
|
40
|
+
};
|
|
41
|
+
const result = (await databasesList(undefined, mockExec));
|
|
42
|
+
expect(result.count).toBe(3);
|
|
43
|
+
});
|
|
44
|
+
it('passes custom host/port/user', async () => {
|
|
45
|
+
const mockExec = async (cmd, args) => {
|
|
46
|
+
expect(args).toContain('db.example.com');
|
|
47
|
+
expect(args).toContain('3307');
|
|
48
|
+
expect(args).toContain('admin');
|
|
49
|
+
return SAMPLE_OUTPUT;
|
|
50
|
+
};
|
|
51
|
+
await databasesList({ host: 'db.example.com', port: 3307, user: 'admin' }, mockExec);
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
//# sourceMappingURL=databases-list.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"databases-list.test.js","sourceRoot":"","sources":["../../../src/mysql/probes/databases-list.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAG9C,OAAO,EAAE,aAAa,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAExE,MAAM,aAAa,GAAG;;gBAEN,CAAC;AAEjB,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;QAClD,MAAM,MAAM,GAAG,kBAAkB,CAAC,aAAa,CAAC,CAAC;QACjD,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC7B,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;YAClC,IAAI,EAAE,oBAAoB;YAC1B,MAAM,EAAE,EAAE;YACV,MAAM,EAAE,CAAC;SACV,CAAC,CAAC;QACH,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;YAClC,IAAI,EAAE,OAAO;YACb,MAAM,EAAE,EAAE;YACV,MAAM,EAAE,KAAK;SACd,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sBAAsB,EAAE,GAAG,EAAE;QAC9B,MAAM,MAAM,GAAG,kBAAkB,CAAC,EAAE,CAAC,CAAC;QACtC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC7B,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,EAAE,CAAC,iCAAiC,EAAE,KAAK,IAAI,EAAE;QAC/C,MAAM,QAAQ,GAAW,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;YAC3C,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC1B,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YAC7B,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;YACpC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YAC7B,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;YAC/B,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YAC7B,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;YAC/B,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;YAClC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,qBAAqB,CAAC,CAAC;YAC9C,OAAO,aAAa,CAAC;QACvB,CAAC,CAAC;QAEF,MAAM,MAAM,GAAG,CAAC,MAAM,aAAa,CAAC,SAAS,EAAE,QAAQ,CAAC,CAA6B,CAAC;QACtF,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE,KAAK,IAAI,EAAE;QAC5C,MAAM,QAAQ,GAAW,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;YAC3C,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;YACzC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;YAC/B,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;YAChC,OAAO,aAAa,CAAC;QACvB,CAAC,CAAC;QAEF,MAAM,aAAa,CAAC,EAAE,IAAI,EAAE,gBAAgB,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,QAAQ,CAAC,CAAC;IACvF,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { ProbeHandler } from '../../types.js';
|
|
2
|
+
export interface MysqlProcessInfo {
|
|
3
|
+
id: number;
|
|
4
|
+
user: string;
|
|
5
|
+
host: string;
|
|
6
|
+
db: string;
|
|
7
|
+
command: string;
|
|
8
|
+
time: number;
|
|
9
|
+
state: string;
|
|
10
|
+
info: string;
|
|
11
|
+
}
|
|
12
|
+
export interface MysqlProcesslistResult {
|
|
13
|
+
processes: MysqlProcessInfo[];
|
|
14
|
+
count: number;
|
|
15
|
+
}
|
|
16
|
+
export declare const processlist: ProbeHandler;
|
|
17
|
+
export declare function parseProcesslist(stdout: string): MysqlProcesslistResult;
|
|
18
|
+
//# sourceMappingURL=processlist.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"processlist.d.ts","sourceRoot":"","sources":["../../../src/mysql/probes/processlist.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAEnD,MAAM,WAAW,gBAAgB;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,sBAAsB;IACrC,SAAS,EAAE,gBAAgB,EAAE,CAAC;IAC9B,KAAK,EAAE,MAAM,CAAC;CACf;AAED,eAAO,MAAM,WAAW,EAAE,YAkBzB,CAAC;AAEF,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,sBAAsB,CAgBvE"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
export const processlist = async (params, exec) => {
|
|
2
|
+
const host = params?.host ?? 'localhost';
|
|
3
|
+
const port = String(params?.port ?? 3306);
|
|
4
|
+
const user = params?.user ?? 'root';
|
|
5
|
+
const stdout = await exec('mysql', [
|
|
6
|
+
'-h',
|
|
7
|
+
host,
|
|
8
|
+
'-P',
|
|
9
|
+
port,
|
|
10
|
+
'-u',
|
|
11
|
+
user,
|
|
12
|
+
'--batch',
|
|
13
|
+
'--skip-column-names',
|
|
14
|
+
'-e',
|
|
15
|
+
'SELECT ID, USER, HOST, IFNULL(DB, ""), COMMAND, TIME, IFNULL(STATE, ""), LEFT(IFNULL(INFO, ""), 200) FROM information_schema.PROCESSLIST ORDER BY TIME DESC',
|
|
16
|
+
]);
|
|
17
|
+
return parseProcesslist(stdout);
|
|
18
|
+
};
|
|
19
|
+
export function parseProcesslist(stdout) {
|
|
20
|
+
const lines = stdout.trim().split('\n').filter(Boolean);
|
|
21
|
+
const processes = lines.map((line) => {
|
|
22
|
+
const parts = line.split('\t');
|
|
23
|
+
return {
|
|
24
|
+
id: Number(parts[0]) || 0,
|
|
25
|
+
user: parts[1] ?? '',
|
|
26
|
+
host: parts[2] ?? '',
|
|
27
|
+
db: parts[3] ?? '',
|
|
28
|
+
command: parts[4] ?? '',
|
|
29
|
+
time: Number(parts[5]) || 0,
|
|
30
|
+
state: parts[6] ?? '',
|
|
31
|
+
info: parts[7] ?? '',
|
|
32
|
+
};
|
|
33
|
+
});
|
|
34
|
+
return { processes, count: processes.length };
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=processlist.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"processlist.js","sourceRoot":"","sources":["../../../src/mysql/probes/processlist.ts"],"names":[],"mappings":"AAkBA,MAAM,CAAC,MAAM,WAAW,GAAiB,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE;IAC9D,MAAM,IAAI,GAAI,MAAM,EAAE,IAAe,IAAI,WAAW,CAAC;IACrD,MAAM,IAAI,GAAG,MAAM,CAAE,MAAM,EAAE,IAAe,IAAI,IAAI,CAAC,CAAC;IACtD,MAAM,IAAI,GAAI,MAAM,EAAE,IAAe,IAAI,MAAM,CAAC;IAEhD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,OAAO,EAAE;QACjC,IAAI;QACJ,IAAI;QACJ,IAAI;QACJ,IAAI;QACJ,IAAI;QACJ,IAAI;QACJ,SAAS;QACT,qBAAqB;QACrB,IAAI;QACJ,6JAA6J;KAC9J,CAAC,CAAC;IACH,OAAO,gBAAgB,CAAC,MAAM,CAAC,CAAC;AAClC,CAAC,CAAC;AAEF,MAAM,UAAU,gBAAgB,CAAC,MAAc;IAC7C,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACxD,MAAM,SAAS,GAAuB,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;QACvD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC/B,OAAO;YACL,EAAE,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YACzB,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE;YACpB,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE;YACpB,EAAE,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE;YAClB,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE;YACvB,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YAC3B,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE;YACrB,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE;SACrB,CAAC;IACJ,CAAC,CAAC,CAAC;IACH,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,CAAC,MAAM,EAAE,CAAC;AAChD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"processlist.test.d.ts","sourceRoot":"","sources":["../../../src/mysql/probes/processlist.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { parseProcesslist, processlist } from './processlist.js';
|
|
3
|
+
const SAMPLE_OUTPUT = `42\troot\tlocalhost\tmyapp\tQuery\t120\texecuting\tSELECT * FROM large_table
|
|
4
|
+
99\tappuser\t192.168.1.10\tmyapp\tSleep\t5\t\t`;
|
|
5
|
+
describe('parseProcesslist', () => {
|
|
6
|
+
it('parses process list output', () => {
|
|
7
|
+
const result = parseProcesslist(SAMPLE_OUTPUT);
|
|
8
|
+
expect(result.count).toBe(2);
|
|
9
|
+
expect(result.processes[0]).toEqual({
|
|
10
|
+
id: 42,
|
|
11
|
+
user: 'root',
|
|
12
|
+
host: 'localhost',
|
|
13
|
+
db: 'myapp',
|
|
14
|
+
command: 'Query',
|
|
15
|
+
time: 120,
|
|
16
|
+
state: 'executing',
|
|
17
|
+
info: 'SELECT * FROM large_table',
|
|
18
|
+
});
|
|
19
|
+
expect(result.processes[1]?.command).toBe('Sleep');
|
|
20
|
+
});
|
|
21
|
+
it('handles empty output', () => {
|
|
22
|
+
const result = parseProcesslist('');
|
|
23
|
+
expect(result.count).toBe(0);
|
|
24
|
+
expect(result.processes).toEqual([]);
|
|
25
|
+
});
|
|
26
|
+
});
|
|
27
|
+
describe('processlist handler', () => {
|
|
28
|
+
it('calls mysql with correct args', async () => {
|
|
29
|
+
const mockExec = async (cmd, args) => {
|
|
30
|
+
expect(cmd).toBe('mysql');
|
|
31
|
+
expect(args).toContain('--batch');
|
|
32
|
+
expect(args).toContain('--skip-column-names');
|
|
33
|
+
const query = args[args.length - 1];
|
|
34
|
+
expect(query).toContain('PROCESSLIST');
|
|
35
|
+
return SAMPLE_OUTPUT;
|
|
36
|
+
};
|
|
37
|
+
const result = (await processlist(undefined, mockExec));
|
|
38
|
+
expect(result.count).toBe(2);
|
|
39
|
+
});
|
|
40
|
+
});
|
|
41
|
+
//# sourceMappingURL=processlist.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"processlist.test.js","sourceRoot":"","sources":["../../../src/mysql/probes/processlist.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAG9C,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAEjE,MAAM,aAAa,GAAG;+CACyB,CAAC;AAEhD,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,EAAE,CAAC,4BAA4B,EAAE,GAAG,EAAE;QACpC,MAAM,MAAM,GAAG,gBAAgB,CAAC,aAAa,CAAC,CAAC;QAC/C,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC7B,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;YAClC,EAAE,EAAE,EAAE;YACN,IAAI,EAAE,MAAM;YACZ,IAAI,EAAE,WAAW;YACjB,EAAE,EAAE,OAAO;YACX,OAAO,EAAE,OAAO;YAChB,IAAI,EAAE,GAAG;YACT,KAAK,EAAE,WAAW;YAClB,IAAI,EAAE,2BAA2B;SAClC,CAAC,CAAC;QACH,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sBAAsB,EAAE,GAAG,EAAE;QAC9B,MAAM,MAAM,GAAG,gBAAgB,CAAC,EAAE,CAAC,CAAC;QACpC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC7B,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;IACnC,EAAE,CAAC,+BAA+B,EAAE,KAAK,IAAI,EAAE;QAC7C,MAAM,QAAQ,GAAW,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;YAC3C,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC1B,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;YAClC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,qBAAqB,CAAC,CAAC;YAC9C,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YACpC,MAAM,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;YACvC,OAAO,aAAa,CAAC;QACvB,CAAC,CAAC;QAEF,MAAM,MAAM,GAAG,CAAC,MAAM,WAAW,CAAC,SAAS,EAAE,QAAQ,CAAC,CAA2B,CAAC;QAClF,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { ProbeHandler } from '../../types.js';
|
|
2
|
+
export interface MysqlStatusResult {
|
|
3
|
+
uptime: number;
|
|
4
|
+
threads: number;
|
|
5
|
+
questions: number;
|
|
6
|
+
slowQueries: number;
|
|
7
|
+
opens: number;
|
|
8
|
+
openTables: number;
|
|
9
|
+
queriesPerSecondAvg: number;
|
|
10
|
+
variables: Record<string, string>;
|
|
11
|
+
}
|
|
12
|
+
export declare const status: ProbeHandler;
|
|
13
|
+
export declare function parseMysqlStatus(stdout: string): MysqlStatusResult;
|
|
14
|
+
//# sourceMappingURL=status.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.d.ts","sourceRoot":"","sources":["../../../src/mysql/probes/status.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAEnD,MAAM,WAAW,iBAAiB;IAChC,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,MAAM,CAAC;IACnB,mBAAmB,EAAE,MAAM,CAAC;IAC5B,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACnC;AAED,eAAO,MAAM,MAAM,EAAE,YAkBpB,CAAC;AAEF,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,iBAAiB,CAsBlE"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
export const status = async (params, exec) => {
|
|
2
|
+
const host = params?.host ?? 'localhost';
|
|
3
|
+
const port = String(params?.port ?? 3306);
|
|
4
|
+
const user = params?.user ?? 'root';
|
|
5
|
+
const stdout = await exec('mysql', [
|
|
6
|
+
'-h',
|
|
7
|
+
host,
|
|
8
|
+
'-P',
|
|
9
|
+
port,
|
|
10
|
+
'-u',
|
|
11
|
+
user,
|
|
12
|
+
'--batch',
|
|
13
|
+
'--skip-column-names',
|
|
14
|
+
'-e',
|
|
15
|
+
'SHOW GLOBAL STATUS',
|
|
16
|
+
]);
|
|
17
|
+
return parseMysqlStatus(stdout);
|
|
18
|
+
};
|
|
19
|
+
export function parseMysqlStatus(stdout) {
|
|
20
|
+
const variables = {};
|
|
21
|
+
for (const line of stdout.split('\n')) {
|
|
22
|
+
const parts = line.split('\t');
|
|
23
|
+
if (parts.length >= 2) {
|
|
24
|
+
variables[parts[0]] = parts[1];
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
const uptime = Number(variables['Uptime']) || 0;
|
|
28
|
+
const questions = Number(variables['Questions']) || 0;
|
|
29
|
+
return {
|
|
30
|
+
uptime,
|
|
31
|
+
threads: Number(variables['Threads_connected']) || 0,
|
|
32
|
+
questions,
|
|
33
|
+
slowQueries: Number(variables['Slow_queries']) || 0,
|
|
34
|
+
opens: Number(variables['Opened_tables']) || 0,
|
|
35
|
+
openTables: Number(variables['Open_tables']) || 0,
|
|
36
|
+
queriesPerSecondAvg: uptime > 0 ? Math.round((questions / uptime) * 100) / 100 : 0,
|
|
37
|
+
variables,
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=status.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.js","sourceRoot":"","sources":["../../../src/mysql/probes/status.ts"],"names":[],"mappings":"AAaA,MAAM,CAAC,MAAM,MAAM,GAAiB,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE;IACzD,MAAM,IAAI,GAAI,MAAM,EAAE,IAAe,IAAI,WAAW,CAAC;IACrD,MAAM,IAAI,GAAG,MAAM,CAAE,MAAM,EAAE,IAAe,IAAI,IAAI,CAAC,CAAC;IACtD,MAAM,IAAI,GAAI,MAAM,EAAE,IAAe,IAAI,MAAM,CAAC;IAEhD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,OAAO,EAAE;QACjC,IAAI;QACJ,IAAI;QACJ,IAAI;QACJ,IAAI;QACJ,IAAI;QACJ,IAAI;QACJ,SAAS;QACT,qBAAqB;QACrB,IAAI;QACJ,oBAAoB;KACrB,CAAC,CAAC;IACH,OAAO,gBAAgB,CAAC,MAAM,CAAC,CAAC;AAClC,CAAC,CAAC;AAEF,MAAM,UAAU,gBAAgB,CAAC,MAAc;IAC7C,MAAM,SAAS,GAA2B,EAAE,CAAC;IAC7C,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;QACtC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC/B,IAAI,KAAK,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YACtB,SAAS,CAAC,KAAK,CAAC,CAAC,CAAE,CAAC,GAAG,KAAK,CAAC,CAAC,CAAE,CAAC;QACnC,CAAC;IACH,CAAC;IAED,MAAM,MAAM,GAAG,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC;IAChD,MAAM,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,CAAC;IAEtD,OAAO;QACL,MAAM;QACN,OAAO,EAAE,MAAM,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC,IAAI,CAAC;QACpD,SAAS;QACT,WAAW,EAAE,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC;QACnD,KAAK,EAAE,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC;QAC9C,UAAU,EAAE,MAAM,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC;QACjD,mBAAmB,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,SAAS,GAAG,MAAM,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;QAClF,SAAS;KACV,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.test.d.ts","sourceRoot":"","sources":["../../../src/mysql/probes/status.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { parseMysqlStatus, status } from './status.js';
|
|
3
|
+
const SAMPLE_OUTPUT = `Uptime\t86400
|
|
4
|
+
Threads_connected\t15
|
|
5
|
+
Questions\t1728000
|
|
6
|
+
Slow_queries\t42
|
|
7
|
+
Opened_tables\t500
|
|
8
|
+
Open_tables\t200`;
|
|
9
|
+
describe('parseMysqlStatus', () => {
|
|
10
|
+
it('parses status variables', () => {
|
|
11
|
+
const result = parseMysqlStatus(SAMPLE_OUTPUT);
|
|
12
|
+
expect(result.uptime).toBe(86400);
|
|
13
|
+
expect(result.threads).toBe(15);
|
|
14
|
+
expect(result.questions).toBe(1728000);
|
|
15
|
+
expect(result.slowQueries).toBe(42);
|
|
16
|
+
expect(result.opens).toBe(500);
|
|
17
|
+
expect(result.openTables).toBe(200);
|
|
18
|
+
expect(result.queriesPerSecondAvg).toBe(20);
|
|
19
|
+
});
|
|
20
|
+
it('stores all variables in map', () => {
|
|
21
|
+
const result = parseMysqlStatus(SAMPLE_OUTPUT);
|
|
22
|
+
expect(result.variables['Uptime']).toBe('86400');
|
|
23
|
+
expect(result.variables['Slow_queries']).toBe('42');
|
|
24
|
+
});
|
|
25
|
+
it('handles empty output', () => {
|
|
26
|
+
const result = parseMysqlStatus('');
|
|
27
|
+
expect(result.uptime).toBe(0);
|
|
28
|
+
expect(result.queriesPerSecondAvg).toBe(0);
|
|
29
|
+
});
|
|
30
|
+
});
|
|
31
|
+
describe('status handler', () => {
|
|
32
|
+
it('calls mysql SHOW GLOBAL STATUS', async () => {
|
|
33
|
+
const mockExec = async (cmd, args) => {
|
|
34
|
+
expect(cmd).toBe('mysql');
|
|
35
|
+
const query = args[args.length - 1];
|
|
36
|
+
expect(query).toContain('SHOW GLOBAL STATUS');
|
|
37
|
+
return SAMPLE_OUTPUT;
|
|
38
|
+
};
|
|
39
|
+
const result = (await status(undefined, mockExec));
|
|
40
|
+
expect(result.uptime).toBe(86400);
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
//# sourceMappingURL=status.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.test.js","sourceRoot":"","sources":["../../../src/mysql/probes/status.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAG9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAEvD,MAAM,aAAa,GAAG;;;;;iBAKL,CAAC;AAElB,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,EAAE,CAAC,yBAAyB,EAAE,GAAG,EAAE;QACjC,MAAM,MAAM,GAAG,gBAAgB,CAAC,aAAa,CAAC,CAAC;QAC/C,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAClC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAChC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACvC,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACpC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC/B,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACpC,MAAM,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6BAA6B,EAAE,GAAG,EAAE;QACrC,MAAM,MAAM,GAAG,gBAAgB,CAAC,aAAa,CAAC,CAAC;QAC/C,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACjD,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACtD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sBAAsB,EAAE,GAAG,EAAE;QAC9B,MAAM,MAAM,GAAG,gBAAgB,CAAC,EAAE,CAAC,CAAC;QACpC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC9B,MAAM,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;IAC9B,EAAE,CAAC,gCAAgC,EAAE,KAAK,IAAI,EAAE;QAC9C,MAAM,QAAQ,GAAW,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;YAC3C,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC1B,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YACpC,MAAM,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,oBAAoB,CAAC,CAAC;YAC9C,OAAO,aAAa,CAAC;QACvB,CAAC,CAAC;QAEF,MAAM,MAAM,GAAG,CAAC,MAAM,MAAM,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAsB,CAAC;QACxE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/nginx/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAMxC,eAAO,MAAM,SAAS,EAAE,IAOvB,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { nginxManifest } from './manifest.js';
|
|
2
|
+
import { accessLogTail } from './probes/access-log-tail.js';
|
|
3
|
+
import { configTest } from './probes/config-test.js';
|
|
4
|
+
import { errorLogTail } from './probes/error-log-tail.js';
|
|
5
|
+
export const nginxPack = {
|
|
6
|
+
manifest: nginxManifest,
|
|
7
|
+
handlers: {
|
|
8
|
+
'nginx.config.test': configTest,
|
|
9
|
+
'nginx.access.log.tail': accessLogTail,
|
|
10
|
+
'nginx.error.log.tail': errorLogTail,
|
|
11
|
+
},
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/nginx/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAE1D,MAAM,CAAC,MAAM,SAAS,GAAS;IAC7B,QAAQ,EAAE,aAAa;IACvB,QAAQ,EAAE;QACR,mBAAmB,EAAE,UAAU;QAC/B,uBAAuB,EAAE,aAAa;QACtC,sBAAsB,EAAE,YAAY;KACrC;CACF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"manifest.d.ts","sourceRoot":"","sources":["../../src/nginx/manifest.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAElD,eAAO,MAAM,aAAa,EAAE,YAkE3B,CAAC"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
export const nginxManifest = {
|
|
2
|
+
name: 'nginx',
|
|
3
|
+
version: '0.1.0',
|
|
4
|
+
description: 'Nginx web server probes: config validation, access/error log tailing',
|
|
5
|
+
requires: {
|
|
6
|
+
groups: [],
|
|
7
|
+
files: ['/etc/nginx/nginx.conf'],
|
|
8
|
+
commands: ['nginx'],
|
|
9
|
+
},
|
|
10
|
+
probes: [
|
|
11
|
+
{
|
|
12
|
+
name: 'config.test',
|
|
13
|
+
description: 'Test nginx configuration for syntax errors',
|
|
14
|
+
capability: 'observe',
|
|
15
|
+
timeout: 10_000,
|
|
16
|
+
},
|
|
17
|
+
{
|
|
18
|
+
name: 'access.log.tail',
|
|
19
|
+
description: 'Tail recent lines from the nginx access log',
|
|
20
|
+
capability: 'observe',
|
|
21
|
+
params: {
|
|
22
|
+
logPath: {
|
|
23
|
+
type: 'string',
|
|
24
|
+
description: 'Path to access log file',
|
|
25
|
+
required: false,
|
|
26
|
+
default: '/var/log/nginx/access.log',
|
|
27
|
+
},
|
|
28
|
+
lines: {
|
|
29
|
+
type: 'number',
|
|
30
|
+
description: 'Number of lines to tail',
|
|
31
|
+
required: false,
|
|
32
|
+
default: 100,
|
|
33
|
+
},
|
|
34
|
+
},
|
|
35
|
+
timeout: 10_000,
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
name: 'error.log.tail',
|
|
39
|
+
description: 'Tail recent lines from the nginx error log',
|
|
40
|
+
capability: 'observe',
|
|
41
|
+
params: {
|
|
42
|
+
logPath: {
|
|
43
|
+
type: 'string',
|
|
44
|
+
description: 'Path to error log file',
|
|
45
|
+
required: false,
|
|
46
|
+
default: '/var/log/nginx/error.log',
|
|
47
|
+
},
|
|
48
|
+
lines: {
|
|
49
|
+
type: 'number',
|
|
50
|
+
description: 'Number of lines to tail',
|
|
51
|
+
required: false,
|
|
52
|
+
default: 100,
|
|
53
|
+
},
|
|
54
|
+
},
|
|
55
|
+
timeout: 10_000,
|
|
56
|
+
},
|
|
57
|
+
],
|
|
58
|
+
runbook: {
|
|
59
|
+
category: 'nginx',
|
|
60
|
+
probes: ['config.test', 'error.log.tail'],
|
|
61
|
+
parallel: true,
|
|
62
|
+
},
|
|
63
|
+
detect: {
|
|
64
|
+
commands: ['nginx'],
|
|
65
|
+
files: ['/etc/nginx/nginx.conf'],
|
|
66
|
+
},
|
|
67
|
+
};
|
|
68
|
+
//# sourceMappingURL=manifest.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"manifest.js","sourceRoot":"","sources":["../../src/nginx/manifest.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,aAAa,GAAiB;IACzC,IAAI,EAAE,OAAO;IACb,OAAO,EAAE,OAAO;IAChB,WAAW,EAAE,sEAAsE;IACnF,QAAQ,EAAE;QACR,MAAM,EAAE,EAAE;QACV,KAAK,EAAE,CAAC,uBAAuB,CAAC;QAChC,QAAQ,EAAE,CAAC,OAAO,CAAC;KACpB;IACD,MAAM,EAAE;QACN;YACE,IAAI,EAAE,aAAa;YACnB,WAAW,EAAE,4CAA4C;YACzD,UAAU,EAAE,SAAS;YACrB,OAAO,EAAE,MAAM;SAChB;QACD;YACE,IAAI,EAAE,iBAAiB;YACvB,WAAW,EAAE,6CAA6C;YAC1D,UAAU,EAAE,SAAS;YACrB,MAAM,EAAE;gBACN,OAAO,EAAE;oBACP,IAAI,EAAE,QAAQ;oBACd,WAAW,EAAE,yBAAyB;oBACtC,QAAQ,EAAE,KAAK;oBACf,OAAO,EAAE,2BAA2B;iBACrC;gBACD,KAAK,EAAE;oBACL,IAAI,EAAE,QAAQ;oBACd,WAAW,EAAE,yBAAyB;oBACtC,QAAQ,EAAE,KAAK;oBACf,OAAO,EAAE,GAAG;iBACb;aACF;YACD,OAAO,EAAE,MAAM;SAChB;QACD;YACE,IAAI,EAAE,gBAAgB;YACtB,WAAW,EAAE,4CAA4C;YACzD,UAAU,EAAE,SAAS;YACrB,MAAM,EAAE;gBACN,OAAO,EAAE;oBACP,IAAI,EAAE,QAAQ;oBACd,WAAW,EAAE,wBAAwB;oBACrC,QAAQ,EAAE,KAAK;oBACf,OAAO,EAAE,0BAA0B;iBACpC;gBACD,KAAK,EAAE;oBACL,IAAI,EAAE,QAAQ;oBACd,WAAW,EAAE,yBAAyB;oBACtC,QAAQ,EAAE,KAAK;oBACf,OAAO,EAAE,GAAG;iBACb;aACF;YACD,OAAO,EAAE,MAAM;SAChB;KACF;IACD,OAAO,EAAE;QACP,QAAQ,EAAE,OAAO;QACjB,MAAM,EAAE,CAAC,aAAa,EAAE,gBAAgB,CAAC;QACzC,QAAQ,EAAE,IAAI;KACf;IACD,MAAM,EAAE;QACN,QAAQ,EAAE,CAAC,OAAO,CAAC;QACnB,KAAK,EAAE,CAAC,uBAAuB,CAAC;KACjC;CACF,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { ProbeHandler } from '../../types.js';
|
|
2
|
+
export interface AccessLogTailResult {
|
|
3
|
+
logPath: string;
|
|
4
|
+
lines: string[];
|
|
5
|
+
lineCount: number;
|
|
6
|
+
}
|
|
7
|
+
export declare const accessLogTail: ProbeHandler;
|
|
8
|
+
export declare function parseLogTail(logPath: string, stdout: string): AccessLogTailResult;
|
|
9
|
+
//# sourceMappingURL=access-log-tail.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"access-log-tail.d.ts","sourceRoot":"","sources":["../../../src/nginx/probes/access-log-tail.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAEnD,MAAM,WAAW,mBAAmB;IAClC,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,eAAO,MAAM,aAAa,EAAE,YAM3B,CAAC;AAEF,wBAAgB,YAAY,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,mBAAmB,CAMjF"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export const accessLogTail = async (params, exec) => {
|
|
2
|
+
const logPath = params?.logPath ?? '/var/log/nginx/access.log';
|
|
3
|
+
const lines = params?.lines ?? 100;
|
|
4
|
+
const stdout = await exec('tail', ['-n', String(lines), logPath]);
|
|
5
|
+
return parseLogTail(logPath, stdout);
|
|
6
|
+
};
|
|
7
|
+
export function parseLogTail(logPath, stdout) {
|
|
8
|
+
const lines = stdout.split('\n');
|
|
9
|
+
if (lines.length > 0 && lines[lines.length - 1] === '') {
|
|
10
|
+
lines.pop();
|
|
11
|
+
}
|
|
12
|
+
return { logPath, lines, lineCount: lines.length };
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=access-log-tail.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"access-log-tail.js","sourceRoot":"","sources":["../../../src/nginx/probes/access-log-tail.ts"],"names":[],"mappings":"AAQA,MAAM,CAAC,MAAM,aAAa,GAAiB,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE;IAChE,MAAM,OAAO,GAAI,MAAM,EAAE,OAAkB,IAAI,2BAA2B,CAAC;IAC3E,MAAM,KAAK,GAAI,MAAM,EAAE,KAAgB,IAAI,GAAG,CAAC;IAE/C,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC;IAClE,OAAO,YAAY,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;AACvC,CAAC,CAAC;AAEF,MAAM,UAAU,YAAY,CAAC,OAAe,EAAE,MAAc;IAC1D,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACjC,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC;QACvD,KAAK,CAAC,GAAG,EAAE,CAAC;IACd,CAAC;IACD,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,CAAC,MAAM,EAAE,CAAC;AACrD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"access-log-tail.test.d.ts","sourceRoot":"","sources":["../../../src/nginx/probes/access-log-tail.test.ts"],"names":[],"mappings":""}
|