mirror of https://github.com/sysown/proxysql
feature/aws-rds-monitor
v3.0_fix_ci-mysqlx-cache-and-soak
GH-Actions
v3.0
v3.0_fix_codecov-coverage-path-prefix
issue-1288-load-mysql-variables-feedback
ci/fix-pgsql-socket-g1-cache-key
v3.0_fix_ci-mysqlx-fetch-depth
cleanup/drop-unreachable-port-defaults
feature/pgsql-native-backend-protocol
fix/pgsql-unix-socket
ci-pgsql-socket-g1
v3.0_fix_coverage-gcov-prefix-strip
fix/pgsql-omit-port-zero
aws-rds-bg
fix/jemalloc-page-size-auto-detect
docs/passthrough-auth-spec
feature/ci-codecov-tap-all-groups-callers
fix/run-tests-backtick-leak
ci/zstd-level-15
feature/ci-codecov-tap-all-groups-callees
v3.0_partition-fairness
feature/ci-codecov-tap-legacy-g2
v3.0_partition-gate
fix/ci-cache-restore-path
v3.0_fix-stale-pause-until
feature/perf-improvements-test2
fix/kill-proxysqlgenai-build-flag
feat/passthrough-auth
ci-trigger-tolerate-cleanup-401
fix/5790-mariadb-collation-255
fix/parsersql-1.0.3-pg-set-fixes
issue_5639
pgsql_dns_cache
fix/5755-followup-typecast-digest-fixtures
v3.0_merge-5776-5784
v3.0_latency_consistency_improvement
fix/galera-g5-cluster-start
fix/ghcr-pull-retry
v3.0_cap_violation_5767
ci-mariadb10-galera-GH-Actions
ci/fix-gr-g5-cluster-start
ci-mysql84-gr-g1-g9-GH-Actions
perf/pull-ci-base-from-ghcr
fix/split-test-groups
fix/rename-set-parser-workflow
gh-actions/add-set-parser-algorithm-3-g1
fix/4760-advertise-lenenc-auth-capability
feature/mysqlx-stack-consolidated
feature/mysqlx-asan-coverage-docker-isolation
fix/ci-unit-tests-tsan-project-name
feature/mysqlx-tsan-v3-companion
feature/ci-builds-add-tsan-matrix
ci-reduce-polling-interval
feature/mysqlx-tsan-workflow-only
feature/mysqlx-ci-validation-workflows
feature/mysqlx-test-leak-cleanup
feature/mysqlx-behavioural-tap
feature/mysqlx-parity-cleanup
ci-g5-enable-cluster
feature/mysqlx-tls-passthrough
feature/mysqlx-asymmetric-tls
feature/mysqlx-state-machines
feature/build-tsan-plumbing
feature/mysqlx-observability-p0
fix/mysqlx-review-findings
v3.0-test-ci
ci/fix-mysql-apt-key-expired-v2
ci/fix-mysql-apt-key-expired
mariadb-rpl-helper
fix-fc-parsing
ci/fix-upload-artifact-eacces
ci/fix-cache-prune-permissions
ci/shrink-test-cache
ci/fix-tap-build-target
ci/gh-actions-readme-pointer
ci/fix-mysql84-infradb-label
ci/add-missing-group-reusables
infra-mysql57-binlog
feature/pgbouncer-compat
v3.0_pgsql_sslkeylog_5281
fix/5554-resolution-family-limitation
fix/3p-ci-error-handling
v3.0-5493
v3.0-ci260322_cluster
copilot/extract-server-selection-algorithm
copilot/extract-health-state-logic
copilot/extract-query-rule-matching-logic
copilot/extract-connection-pool-logic
v3.0-set_parser_v3
feature/arm-builds
release-notes-3.0.6-4.0.6-draft
v3.0.6-add-tap-test_stats_table_check
v2.7.3-test260221
v4.0-mcp-stats
copilot/uninstall-amazon-linux-2023
fix-prometheus-labels-test
tap-mcp-client
agent-skill-tap-test
v4.0-tsdb1
v3.0-fix_5256
gh-pages
feature/modern-docs
v4.0
v4.0-fix-vec-search
v4.0_rag_sys_prompt
v4.0_rag_mcp
v4.0-tsdb
feature/v4-docs-init
otel_system_libs
otel_clean
v3.0-5288
otel
otel_2
fix/postgresql-cluster-sync
v3.0-releate_notes_scripts_fixes
test_gh-actions_triggers
postgresql-digest-testing-improvement
v3.0_select_auto_commit
v3.0-5218
fix-5221
fix/5186-proxysql-stop-admin-crash
v3.0-4951
add-claude-github-actions-1763877527835
fix-rpm
v3.0-DS_crash
add-claude-github-actions-1763663272333
add-claude-github-actions-1763663091346
add-claude-github-actions-1763663091411
add-claude-github-actions-1763476725261
add-claude-github-actions-1763476725489
v3.0_optimizations_and_stability
v2.7.3.1
v3.0.3-upgrade_json
v3.0.sonar-cli
v3.0.sonar-config
otel-tracepoint
v3.0.2-merge-upgrade_deps-add_new_distros
v3.0.2-upgrade_deps
v3.0.2-add_new_distros
v3.0-add_more_testing_groups
v3.0-upgrade_prometheus-cpp
v3.0-upgrade_json
v3.0-upgrade_sqlite3
v3.0-upgrade_libmicrohttpd
v3.0-upgrade_curl
v3.0-add_centos10_builds
v3.0-add_fedora42_builds
v3.0_PG_PrepStmt
v3.0-sliced_groups
v3.0_auth_negotiation
v2.7
v2.7-fix_run_name
v3.0_4799_4827
v3.0-3687
v2.7-pmm_runtime_servers_metrics
v2.7-4839
v2.7-4841
v2.7-bump_version_to_2.7.3
2.6.6-4841
v2.x_pg_PrepStmtBase_240714
v3.0-4803-4817
v3.0-4803
v2.7-minorBugs
v3.0-privates
v2.x-logging_mem_2
v2.7_fix
v2.7_amd64_build_fix
v2.7-fix_aux_threads_ssl_leaks
v2.7-fix_ssl_params_leak
v2.7-rm_malloc_conf_on_version
v2.7_compression
v2.7-actions-add-3p-tests-parameter
none
v2.7-fix_hang_on_resume
v2.x-logging_mem
v2.7_servers_defaults
v2.7-mariadb_column_metadata_integrity_check
ssl_optimization
v2.7_reg_test_4716_single_semicolon
v2.7_issue_4707_threshold_resultset_size
v2.7_reg_test_4723_query_cache_stores_empty_result
2.7_randomized_cache_ttl
v3.0_fix_multiple_builds
v3.0_servers_defaults
v2.7-update_actions_triggers_v2
v2.7-update_actions_triggers
v2.6
v2.6.x-update_triggers
v2.6-4646
v2.7.1-update_actions
v2.x
v2.6.x-testing-global-multiplexing-disabled
use-wrlock-in-dns-cache-empty
v2.6.x-fix-darwin
v2.x-admin_list_ciphers
v2.x-sqlite3_pass_exts
v2.x-tap_tests_opt_ssl
v2.6.0-update_to_libhttpserver_v0.19
v2.x_router_2ports
v2.6.0-update_to_openssl_v3.1.5
v2.x-2411025
v2.x-profiling_poc1
v2.x_sha2pass_draft2
v2.x-webui_fixes
v2.6.0-more-makefile-fixes
v2.x-20230914_test
v2.x-20230913_test
v2.5.5-branch
v2.5.5-branch_255_patches
v2.x-aurora_autodiscovery-refactor_cluster_mysql_servers-gr_bootstrap_mode_2
v2.x_mysql_connector_j_fixes
v2.6-deprecate_old_clickhouse
v2.x_refactor_cluster_mysql_servers
v2.x-aurora_autodiscovery
v2.x-zd70545
v2.x-aurora_autodiscovery_shunned_promotion
v2.x-tap20230609
v2.x-test20230530
v2.x_sha2pass_draft2-TEST
v2.x-session_track_system_variables_v2
v2.x-status-variables-for-set-stmts
v2.x-enable_session_state_trackers
v2.x-increase-logging-eof_fast_forward-t
v2.x-3863-special-query
v2.x-session_track_system_variables
v2.x_refactor_read_only_action
v2.x_sha2pass_draft1
v2.2.0-sqliteserver_read_only
v2.x-digest_umap_aux-comparison
v2.4.8
v2.x-4105_4114
v2.x-3583-server_closed_conn
v2.x-group_replication_rework-SHUNNED_promotion
v2.1.0-var-global-multiplex
v2.x-CI-hostname-tap-test-fixes
v2.x-limit-version-check
v2.x-fix_deprecate_eof_warning
v2.x-3698
v2.x_tidb_replica_read
v2.x-HostGroups_attributes
v2.0.18.221009
v2.x-ci_reg_test_3273_ssl_con
TAP_test_restapi
v2.x-tap_tests_groups
v2.x-tap_test_sqlite3_server-t
PRS_3888_3903_2
PRS_3888_3903
v2.x_code_refactor_2206
v2.x-multipacket_poc_1
v2.x-impr_hg_latency_obsv
v2.x-gcc-warnings
v2.x-hg_lock_session_id
v2.x-3768
v2.x-3371
v2.x-ci_verifications
v2.x-thread_local_qps_limit
v2.x-parser_table
v2.1.1-3207
v2.x-qps_limits
v2.x-3711
v2.x-3642
v2.x-3674
v2.x-ssl3_warnings
V2
v2.3.2
v2.3.2_3646_3647
v2.x-client_err_limit_conn_timeout
v2.x-keep_multiplexing_regression_fix
v2.3.2-3628
v2.2.2-to-v2.3.0-7
v2.2.2-to-v2.3.0-7_merge
v2.2.2-to-v2.3.0-6
v2.2.2-to-v2.3.0-6_merge
v2.2.2-to-v2.3.0-5
v2.2.2-to-v2.3.0-4
v2.2.2-to-v2.3.0-3
v2.2.2-to-v2.3.0-2
v2.2.2-to-v2.3.0-1
v2.3.1
v2.0.14-70226
v2.3.0
v2.x-client_err_limit-gr_replication_lag_action
v2.2.2
v2.2.1-3603
v2.2.1-centos7-ASAN
v2.2.1
v2.2.1-3601
v2.2.1-3599
v2.2.1-3597
v2.2.1-3595
v2.2.0-restapi_server_exc_log
v2.x-3574
v2.x-3558
v2.2.0-3546-centos-7-gcc-8
v2.x-3549
v2.x-cluster_large_mysql_users
v2.x-cov_ci_verification
v2.0.14-tb1
v2.0.14-tb1-3494
v2.0.14-tb1-3488
v2.0.14-tb1-3117
v2.0.14-tb1-2762
v2.0.14-2762
v1.4.13-arm
v2.1.1-3296
v2.2.0
v2.0.18
v2.1.1
v2.0.18-3342
v2.0.18-3182
v2.1.1-3184
v2.1.0-revert-da7fdfe14
v2.0.18-revert-da7fdfe14
v1.4.13-70160
v2.0.18-3354
v2.0.18-3350
v2.0.14-3339
1.4.13-70160
v2.0.18-3339
v2.1.1-3317
v2.1.1-3319
v2.0.18-3317
v2.1.2-LBalgo
v2.0.18-1574
v2.1.2-hgman
v2.0.17
v2.1.0
v2.0.17-3288
v2.0.17-3276
v2.0.17-3273
v2.0.16
v2.0.16-3267
v2.0.16-3265
v2.0.16-3262
v2.0.16-3261
v2.1.1-3252
v2.1.1-collation
v2.0.16-3252
v2.0.16-collation
v2.1.0-parser
v2.0.16-3219
v2.0.16-3216
v2.0.16-3201
v2.0.16-2330
revert-3191-v2.0.16-3190
v2.0.16-3204
v2.0.16-3177
v2.0.16-2619
v2.0.16-3190
v2.0.16-3187
v2.1.0-70118
v2.0.16-3133
v2.0.16-3133_ci_verification
v2.0.16-3150
v2.0.16-change_user
v2.0.15
v2.0.15_amd64_fix
v2.0.15_arm64_packages
v1.4.14-ssl
v2.0.15_arm64
v2.1.0-2820
v2.0.15-sslbug
v2.0.15-KillTrx
v2.0.14
v2.0.14-ch_build_fix
v2.0.14-focal
v2.0.14-valgrind20200904
v2.1.0-3042
v2.0.14-3035
v2.0.14-3036
v2.0.14-2955
v2.0.14-vars
v2.0.14-3005
v2.0.14-3003
v2.0.14_2970_2979
v2.0.14-NOTSOCK
v2.1.0'
v2.0.14-2958
v1.4.10-zd
v2.0.13
v2.0.13-autocommit_fix
v2.1.0-2892
v2.0.13-2711
v2.0.13-duplicated_variables
v2.0.13-duplicated_variables_for_2.1.0
v2.0.12-deprecate_eof
v2.1.0-1377
v2.1.0-admin_queries
v2.0.12-var-global-multiplex
v2.1.0-var-foreign-key
v2.0.12
v2.0.12-tab-small-log
v2.0.12-var-foreign-key
v2.0.12-var-long-query-time
v2.0.12-galera-shunned
v2.1.0-admin_queries_2
v2.1.0-tap-rm-config
v2.0.12-tap-rm-config-test
v2.1.0-QP_stmt_3
v2.0.11-fix-multi-2-ci
v2.0.11-fix-multi
v2.0.11-266_0-3
2.1.0
v2.0.11
v2.1.0-track-vars
v2.1.0-track-variables
v2.0.11-track-variables
v2.0.11-2526
v2.0.11-tap-tests
v2.0.13-2698-commit1
v2.0.10-galera-pxc-maint-mode
v2.0.11-track-vars
v2.0.10-2647
v2.0.11-track
v2.0.11-track-session-vars
v2.0.9-var-array-review
v2.0.11-stats
v2.0.10
v2.0.10-centos67
v1.4.14.2
1.4.14.2
v1.4.14-show-warnings
v2.0.9
v2.0.9-var-array_2
v2.0.9-var-array
v1.4.16
v2.0.8
val214-changing_charset
v2.0.6
v1.4.16-1922_2
v1.4.13.2
v2.0.4-charset248
v2.0.5
v1.4.10-67841
v2.0.4
v2.0.4-sqlite327
v2.0.3
v2.0.2
v1.4.15
v2.0.1
v1.4.14
v2.0.0
v1.4.14-ping_shun
v1.4.14-1828
v1.4.14-latency_awareness
v1.4.12
v1.4.13-admin_deadlock
v2.0.0-improve_speed
v1.4.13
v1.4.13-autocommit_revert
v1.4.11.2
v1.4.13-ps
v2.0.0_bionic_deb_fix
v2_962
v1.4.12-1640
v1.4.11-names_tz
v1.4.12-1693
master
v1.4.11
v1.4.10
v1.4.6
v1.3.10
jenkins_test
v2.0.0-cachegrind
v1.4.9
v2.0-lab
v149_1511
v149_1382
v1.4.7-f2
v1.4.7-f1
v149_1491
v1.4.5-kub
v1.4.8
v2.0-web2
v1.4.3
v1.4.7
bsd_install_update
v1.4.2
v1.4.1-ch2
v1.4.1
v1.3.9
v1.4.1-ch
v1.3.8
v1.3.8-dev
v1.3.7
v1.3.7-dev
v1.3.6-dev
v1.4.0-clickhouse
v1.4.0
v1.3.6
v1.3.5
v1.3.5-dev
v1.4.0-955
v1.3.4
v1.3.4-dev
v1.3.3
v1.3.3-dev
v1.3.2
v1.3.2-dev
v1.3.2-766
v1.3.0h
v1.3.1-utf8mb4
1.4.0-840
v1.3.1
v1.2.6
v1.3.0
v1.4.0-797
v1.2.5-715
v1.2.5
v1.2.4-lowmem
v1.3.1-dev-mem
v1.2.0
connleak
lab-1.2.0
v1.1.2
T107_add_proxysql_consul_requirements
T89_write_consul_integration_doc
T98_consul_multi_table_config
mongoose
evhttp
SQLiteServer
1.0
3.0.9
3.0.8
3.0.7
3.0.6
3.0.5
3.0.4
3.0.3
3.0.2
2.7.3
2.6.6.1
3.0.1
2.7.2
3.0.0
2.6.6
2.7.1
2.7.0
2.6.5
2.6.4
2.6.3
2.6.2
2.6.1
2.5.5
2.6.0
2.5.4
2.5.3
2.5.2
2.5.1
2.4.8
2.5.0
2.4.7
2.4.6
2.4.5
2.4.4
2.4.3
2.4.2
2.4.1
2.4.0
2.3.2
2.3.1
2.3.0
2.2.2
2.2.1
2.2.0
2.0.18
2.1.1
2.0.17
2.0.16
2.0.15
2.0.14
2.0.13
2.0.12
2.0.11
2.1.0
2.0.10
2.0.9
2.0.8
2.0.7
2.0.6
2.0.5
2.0.4
2.0.3
2.0.2
1.4.16
1.4.15
2.0.1
1.4.14
1.4.13
1.4.12
1.4.11
1.4.10
1.3.10
1.4.9
2.0.0
1.4.8
1.4.7
1.4.6
1.4.4
1.4.3
1.4.2
1.3.9
1.3.8
1.4.1
1.3.7
1.4.0
1.3.6
1.3.5
1.3.4
1.3.3
1.3.2
1.3.1
1.3.0h
1.3.0g
1.3.0f
1.3.0e
1.3.0d
1.3.0c
v1.3.0b
1.4.5
v1.1.0
v1.1.0-rc
v1.1.1-beta
v1.1.1-beta.1
v1.1.1-beta.2
v1.1.1-beta.3
v1.1.1-beta.4
v1.1.1-beta.5
v1.1.1-beta.6
v1.1.2
v1.2.0a
v1.2.0b
v1.2.0c
v1.2.0d
v1.2.0e
v1.2.0f
v1.2.0g
v1.2.0h
v1.2.0i
v1.2.0j
v1.2.0k
v1.2.1
v1.2.2
v1.2.3
v1.2.4
v1.2.4.0923
v1.2.5
v1.2.6
v1.3.0
v1.3.0a
v1.3.0g
v1.3.0h
v1.3.1
v1.3.10
v1.3.2
v1.3.2-1
v1.3.3
v1.3.4
v1.3.5
v1.3.6
v1.3.7
v1.3.8
v1.3.9
v1.3.9-prev.1
v1.4.0
v1.4.1
v1.4.10
v1.4.11
v1.4.12
v1.4.13
v1.4.14
v1.4.15
v1.4.16
v1.4.2
v1.4.3
v1.4.4
v1.4.5
v1.4.6
v1.4.7
v1.4.8
v1.4.9
v2.0.0-beta.1
v2.0.0-rc1
v2.0.0-rc2
v2.0.1
v2.0.10
v2.0.11
v2.0.12
v2.0.13
v2.0.14
v2.0.15
v2.0.16
v2.0.17
v2.0.18
v2.0.2
v2.0.3
v2.0.4
v2.0.5
v2.0.6
v2.0.7
v2.0.8
v2.0.9
v2.1.0
v2.1.1
v2.2.0
v2.2.1
v2.2.2
v2.3.0
v2.3.1
v2.3.2
v2.4.0
v2.4.1
v2.4.2
v2.4.3
v2.4.4
v2.4.5
v2.4.6
v2.4.7
v2.4.8
v2.5.0
v2.5.1
v2.5.2
v2.5.3
v2.5.4
v2.5.5
v2.6.0
v2.6.1
v2.6.2
v2.6.3
v2.6.4
v2.6.5
v2.6.6
v2.7.0
v2.7.1
v2.7.2
v2.7.3
v3.0.0-alpha
v3.0.1
v3.0.2
v3.0.3
v3.0.4
v3.0.5
v3.0.6
v3.0.7
v3.0.8
v3.0.9
v3.1.6
v3.1.7
v3.1.8
v3.1.9
v4.0.6
v4.0.7
v4.0.8
${ noResults }
17 Commits (6cdd4e697eb86982e3dfd2ceab009ead5da0efcb)
| Author | SHA1 | Message | Date |
|---|---|---|---|
|
|
29402b4a42 |
docs(plugins/genai): close 3 small gaps from review
# 1. Real prepared statement in local_proxy_endpoint.cpp
read_global_variable's comment claimed "Parameterised lookup via
prepared statement" but the implementation did string concatenation:
"SELECT variable_value FROM main.global_variables WHERE
variable_name='" + std::string(var_name) + "'"
Today's only callers pass hardcoded "mysql-interfaces" /
"pgsql-interfaces", so the SQL injection surface is zero — but the
comment is a footgun for the next caller and we have a working
prepare_v2 / bind_text pattern right next door in plugin_main.cpp.
Replace with the proper prepared-statement form using
proxy_sqlite3_step + proxy_sqlite3_column_text; semantics
(empty-string on miss / error) are unchanged.
# 2. Concurrency contract on genai_refresh_runtime_components
The function (introduced in
|
2 months ago |
|
|
967ab401ec |
genai: fix lifecycle reloads and drop dead MCP stats registration
Load GenAI and MCP variables before runtime initialization, reinitialize the AI stack on reload, and make the anomaly hook obey the configured enable flags. Restore the missing MCP command aliases and the disk/config reload verbs, fix the MySQLX packaging filename mismatch, and update the unit harness for the plugin ABI. Also remove the stale stats_mcp_* registrations from the plugin surface. There is no plugin-side writer for those tables in this branch, so advertising them as live schema was misleading. Update the unit test and bootstrap comments to match the actual exposed surface. |
2 months ago |
|
|
978a6f8d2f |
fix(plugins/genai): blocker fixes from PR-#5701 review
Five concrete fixes uncovered by the four-agent review (architecture,
code-safety, build/packaging, test coverage):
# Blocker 1: per-row INSERT failure leaves transaction half-done
In the six MCP_Threads_Handler methods that follow the
BEGIN -> DELETE -> prepare -> loop INSERT -> COMMIT pattern, the
SAFE_SQLITE3_STEP2 macro inside the loop didn't check `rc`. If a
single INSERT failed (constraint violation, disk full, ...), the
loop would continue binding subsequent rows and the COMMIT below
would either succeed with partial data or be left dangling. Hoist
the per-row binding into three insert_*_row(stmt, row) -> bool
helpers in an anonymous namespace, then have every caller check the
return value and `ROLLBACK; return false/return;` on failure.
Affects save_auth_profiles_to_admin_table, save_target_profiles_to
_admin_table, save_query_rules_to_admin_table, project_auth_profiles
_to_runtime_view, project_target_profiles_to_runtime_view,
project_query_rules_to_runtime_view, plus the new save_profiles_to
_admin_table below.
# Blocker 2: cross-table install/save atomicity for profiles
target.auth_profile_id is an FK to auth.auth_profile_id. The old
mcp_load_target_auth_map_from_admindb / mcp_save_target_auth_map_to_
admindb wrappers ran the two installs / two saves as separate
operations under separate locks / transactions. A failure of the
second step (or a concurrent LOAD/SAVE racing in between) left
target_auth_map rebuilt from a (auth_v2, target_v1) mismatch, or
left main.mcp_target_profiles referencing auth_profile_ids that
didn't exist in main.mcp_auth_profiles.
Add atomic combined methods:
- install_profiles_from_admin: reads both source tables BEFORE
taking the wrlock (so a slow admindb doesn't gate the listener),
then under one wrlock swaps both vectors and rebuilds the joined
target_auth_map exactly once.
- save_profiles_to_admin_table: snapshots both vectors under one
rdlock, then deletes target before auth (FK direction-aware) and
inserts auth before target inside a single BEGIN ... COMMIT.
The plugin_main.cpp wrappers now route through these atomic methods.
The per-table install_*_from_admin / save_*_to_admin_table public
methods stay (used by future granular admin verbs and unit tests),
but each rebuilds target_auth_map after its own swap as before.
# Blocker 3: unit-test PROXYSQLGENAI autodetect probe
test/tap/tests/unit/Makefile had been probing libproxysql.a for the
`MCP_Tool_Handler` symbol to autodetect PROXYSQLGENAI. Step 7 of
the carve-out moved that symbol to plugins/genai/, so the probe
silently found 0 matches and stopped defining -DPROXYSQLGENAI for
unit-test builds. Switch the probe to invoke_register_schemas_phase
(the chassis-exclusive symbol that's already used to probe
PROXYSQL40) so the macro auto-defines whenever the chassis is
available — which matches when genai-plugin unit tests can actually
be built and exercised.
# Blocker 4: triplet coverage through dispatch surface
Extend genai_plugin_load_unit-t to drive the full install/save/project
flow through the production dispatch path:
- seed mcp_<X> tables in admindb
- dispatch "LOAD MCP PROFILES TO RUNTIME" via mgr.dispatch_admin_
command (same path admin SQL takes)
- manually invoke refresh_runtime_views_for_query (the chassis hook
that fires on every admin SELECT) and assert runtime_mcp_<X>
rows match the source
- mutate main.<X> directly to simulate an operator stomp, then
dispatch "SAVE MCP PROFILES TO MEMORY" and assert the in-memory
snapshot was written back over the stomp
This is the end-to-end coverage that plugin_runtime_views_unit-t
can't provide (it uses synthetic callbacks) and that a standalone
genai_mcp_config_store unit test would have provided at the cost of
stubbing 9 plugin classes. Plan bumped from 25 -> 36.
# Should-fix: atomic fence + GloGATH lifetime
genai_anomaly_embed_fn was std::atomic with relaxed ordering; the
comment claimed nothing else needed synchronising. Wrong: the
embed function dereferences GloGATH, a non-atomic global mutated by
genai_init / genai_stop. Pair the load with acquire and the stores
with release so a reader that observes the non-null pointer also
observes the prior `GloGATH = new ...`, and a reader that observes
the post-stop nullptr short-circuits before GloGATH's deletion is
visible. Acquire/release is free on x86_64 / arm64 — no perf
regression.
# Should-fix: harden DEB awk substitution + RPM glob
DEB entrypoint: replace the inline awk -v repl="$..." substitution
(which mangled paths containing awk metacharacters via gsub) with a
file-backed awk getline that reads the replacement block verbatim.
Add a fail-fast grep for the placeholder after substitution so a
silently-broken substitution can't ship a malformed package.
RPM (rhel + suse): the spec gates `/usr/lib/proxysql/*.so` on
%if 0%{?with_plugins}, but rpmbuild aborts on "File not found by
glob" if the directory is empty (silent plugin build failure +
with_plugins=1). Have the entrypoint compgen-check whether any .so
actually got staged and only pass --define "with_plugins 1" when
true.
|
2 months ago |
|
|
482ce386cd |
chore(genai-carveout): strip dead PROXYSQLGENAI blocks + plugin hardening
Two threads of cleanup that had to land together because they touch
both core (where the dead code lives) and the plugin (where the new
module-owned state lives):
# Strip dead #ifdef PROXYSQLGENAI from lib/, include/, src/ (Spec Q9)
Step 7 of the carve-out left PSQLGA empty in lib/Makefile, so every
#ifdef PROXYSQLGENAI block in the core build became permanently false.
The blocks remained as dead text (visible to readers, irrelevant to
the binary). Strip ~600 lines spanning:
src/main.cpp 2 sites
lib/Admin_Bootstrap.cpp 3 sites (mcpdb open + attach +
flush_*_variables hooks)
lib/Admin_FlushVariables.cpp 2 sites (~250 lines of stub +
#if 0 _ORIGINAL bodies)
lib/Admin_Handler.cpp 5 sites (LOAD/SAVE GENAI VARIABLES
dispatch + LOAD/SAVE MCP
VARIABLES dispatch +
MCP profiles handler)
lib/ProxySQL_Admin.cpp ~10 sites (init_*_variables +
load_mcp_server +
load/save_mcp_query_rules
+ GenericRefreshStatistics
MCP probes)
lib/ProxySQL_Admin_Stats.cpp 3 stats___mcp_* function bodies
include/proxysql_admin.h 7 method declarations
include/ProxySQL_Admin_Tables_Definitions.h 4 unused DDL macros
The plugin now owns LOAD/SAVE MCP VARIABLES, LOAD/SAVE GENAI VARIABLES,
LOAD/SAVE MCP PROFILES, LOAD/SAVE MCP QUERY RULES via its admin command
registry; the chassis dispatcher catches them before any of the dead
core branches would have fired.
Caveat — known break: the `stats_mcp_*` tables are still registered
(empty schema) but the populator path that fed them is gone. SELECTs
return empty result sets until a follow-up wires the populator into
the plugin (likely via register_runtime_view or a parallel stats-side
ABI). Tracked separately.
# Plugin hardening (review-feedback items 4-7)
* plugins/genai/Makefile: add -fvisibility=hidden,
-fvisibility-inlines-hidden, -fstack-protector-strong (mirrors
plugins/mysqlx). Tag proxysql_plugin_descriptor_v1 with
__attribute__((visibility("default"))) so the loader's dlsym still
resolves; without the explicit annotation the hidden-default flag
would also hide the entry point.
* plugins/genai/src/Anomaly_Detector.cpp: convert
genai_anomaly_embed_fn to std::atomic<…> with relaxed loads/stores.
The detector hot-path read races with init/stop on the lifecycle
thread; atomics give us a portable no-torn-pointer guarantee
without paying for acquire/release fences we don't need (no other
state synchronises with the pointer). Replaces the hand-wavy
"no mutex needed" comment with the actual reasoning.
* plugins/genai/src/{plugin_main,plugin_commands,plugin_tables}.cpp:
route the 17 fprintf(stderr, "genai plugin: ...") log lines
through a new genai_log() helper that calls
services->log_message when the chassis is wired up and falls back
to stderr for early-init / unit-test paths. Lines now land in
proxysql.log alongside the rest of the runtime.
* plugins/genai/include/MCP_Thread.h: add get_variable_string(name,
std::string&) returning a std::string, and switch
mcp_save_variables_to_admindb (plugin_main.cpp) to it. The legacy
get_variable(name, char*) had an unbounded sprintf into a stack
buffer and the SAVE path was passing char val[256] — a real
overflow risk for *_endpoint_auth bearer tokens.
* plugins/genai/src/plugin_main.cpp: rewrite the genai_init / genai_stop
comment block with the actual teardown ordering rationale (consumers
before producers; atomic-clear-then-delete for the embed hook;
why Prometheus counters stay registered).
|
2 months ago |
|
|
16253a1c99 |
feat(plugins/genai): adopt ABI-3 separation-of-duties for runtime_mcp_*
Wire the genai plugin into the plugin-chassis ABI-3 contract added in PR #5688: Admin owns the editable mcp_<X> tables, the module owns the in-memory snapshot under its own mutex, and runtime_mcp_<X> is a chassis-projected view repopulated lazily by a refresh callback before each admin SELECT. No more triple-storage of profile / query-rule data. # MCP_Threads_Handler: per-table install / save / project triplets Replaces the monolithic load_target_auth_map(joined-resultset) with three independent triplets, mirroring the mysqlx config_store rework: install_<X>_from_admin reads main.mcp_<X>, replaces the in-memory snapshot vector under wrlock, rebuilds the joined target_auth_map (for profiles) save_<X>_to_admin_table REPLACEs main.mcp_<X> from the snapshot project_<X>_to_runtime_view DELETE+INSERT runtime_mcp_<X> from the snapshot — invoked only by the chassis runtime-view refresh dispatcher Two new vectors (auth_profiles_, target_profiles_, query_rules_) hold the authoritative per-table rows; target_auth_map remains as the joined view consumed by the listener and is rebuilt whenever either profile vector changes. # Plugin descriptor + table registration genai_register_admin_tables now also calls services->register_runtime_view for runtime_mcp_auth_profiles, runtime_mcp_target_profiles, and runtime_mcp_query_rules, pointing each at a project_*_to_runtime_view trampoline. The runtime_mcp_<X> tables stay registered for their CREATE TABLE schema only — their rows are entirely owned by the per-SELECT projection callbacks from this point on. # Admin SQL surface LOAD MCP PROFILES TO RUNTIME / LOAD MCP QUERY RULES TO RUNTIME now go through install_<X>_from_admin and never touch runtime_mcp_<X>. SAVE MCP PROFILES TO MEMORY is added (was missing pre-ABI-3) and joins SAVE MCP QUERY RULES TO MEMORY in pulling from the module snapshot instead of the runtime view. Query_Tool_Handler::refresh_target_registry no longer re-reads runtime_mcp_<X> via SQLite on every refresh; it consumes the in-memory snapshot directly through GloMCPH->get_all_target_auth_contexts(). # Drop stale GENAI:-prefix tests test/tap/tests/genai_{async,embedding_rerank,live_validation}-t.cpp were left over from before Step 4.A removed the GENAI: query-prefix escape hatch — they would all have failed under ai-g1. Delete them and their groups.json / ai/README.md references; equivalent coverage now flows through the MCP /mcp/ai endpoint and the genai_module-t suite that already drives the plugin surface. |
2 months ago |
|
|
7f148940e3 |
feat(plugins/genai): Step 8b — wire LOAD/SAVE GENAI VARIABLES via plugin
Mirror of the 4.F MCP variable wiring, applied to genai-* variables.
Closes the gap that surfaced in the ai-g1 spot-check where
genai_module-t saw "default value" / "CHECKSUM GENAI VARIABLES" empty
because flush_genai_variables___* was stubbed in Step 5 and there
was no plugin-side replacement.
New helpers (plugins/genai/src/plugin_main.cpp + genai_plugin.h):
genai_load_variables_from_admindb(ctx)
SELECT variable_name, variable_value FROM main.global_variables
WHERE variable_name LIKE 'genai-%' →
GloGATH->set_variable(name + 6, value) for each row.
Mirrors the pre-Step-5 flush_genai_variables___database_to_runtime.
genai_save_variables_to_admindb(ctx)
Walks GloGATH->get_variables_list() and REPLACEs the
`genai-<name>` rows in main.global_variables. Mirrors the
pre-Step-5 flush_genai_variables___runtime_to_database.
Both helpers wrlock GloGATH for the duration of their walk, so
callers don't have to coordinate.
New plugin-registered admin SQL verbs (plugin_commands.cpp):
LOAD GENAI VARIABLES TO RUNTIME
aliases: FROM MEMORY, FROM MEM, TO RUN
SAVE GENAI VARIABLES TO MEMORY
aliases: TO MEM, FROM RUNTIME, FROM RUN
End-to-end verified against the running ai-g1 infra:
SET genai-llm_provider='openai';
LOAD GENAI VARIABLES TO RUNTIME;
SAVE GENAI VARIABLES TO MEMORY;
SELECT * FROM main.global_variables WHERE variable_name LIKE 'genai-%';
-> 32 rows (the full GenAI_Threads_Handler variable set, populated
by the SAVE FROM RUNTIME walk, including the value just SET).
This is a follow-up gap the unit tests don't catch (the pattern
mirrors LOAD/SAVE MCP VARIABLES which 4.F already validated end-to-end);
ai-g1 caught it because genai_module-t hits CHECKSUM GENAI VARIABLES
which evaluates over the populated row set.
The pre-Step-5 ProxySQL_Admin::flush_genai_variables___* functions
remain stubbed in core (no callers reach them now — the chassis
dispatcher routes LOAD/SAVE GENAI VARIABLES verbs to the plugin
before admin_handler_command_load_or_save can fire). Step 7's dead-
code cleanup pass can drop them entirely.
|
2 months ago |
|
|
62ed0660a7 |
feat(plugins/genai): Step 7 — drop PROXYSQLGENAI from core build
Last step of the GenAI plugin carve-out. The PROXYSQLGENAI macro is
no longer compiled into core: lib/libproxysql.a and the proxysql
binary build identically with or without `PROXYSQLGENAI=1`. The
user-facing build flag stays — it now means "also build the genai
plugin alongside proxysql" rather than "compile GenAI into the
binary".
What this commit does
plugins/genai/Makefile
Hardcodes -DPROXYSQLGENAI in the plugin's CXXFLAGS — the plugin
IS the GenAI surface, so the macro is always-on inside its own
compilation unit. Lets the existing `#ifdef PROXYSQLGENAI`
guards inside plugin source files keep working without a
massive guard-stripping pass (deferred follow-up cleanup).
lib/Makefile, src/Makefile
Drop the `PSQLGA := -DPROXYSQLGENAI` setter — core no longer
sees the macro on the compile line. PSQLGA stays as an empty
variable so the existing `$(PSQLGA)` cascades in CXXFLAGS
references stay structurally identical (cleanup deferred).
Also: lib/Makefile no longer compiles MCP_Tool_Handler.oo (the
base class moved to the plugin in this commit too — see below).
Top-level Makefile
Plugin-build rules switched from `$(if $(filter 1,$(PROXYSQL40))`
to `$(if $(filter 1,$(PROXYSQLGENAI))` — `PROXYSQL40=1` enables
the chassis but not necessarily the genai plugin. Skip-message
text updated to match. `PROXYSQLGENAI=1` still implies
`PROXYSQL40=1` per the existing tier hierarchy, so the user
invocation stays unchanged.
MCP_Tool_Handler base class
Moved to plugins/genai/ (`include/MCP_Tool_Handler.h` -> plugin
include, `lib/MCP_Tool_Handler.cpp` -> plugin tool_handlers).
Was the last GenAI-tier .cpp in core — only existed there
because AI/RAG_Tool_Handler still inherited from it before
Step 5. Now plugin-internal.
lib/proxy_sqlite3_symbols.cpp
Hook for sqlite_vec_init unconditional now (sqlite-vec extension
object always linked into proxysql, since the genai plugin
relies on it via this hook at dlopen time).
lib/MySQL_Thread.cpp / lib/PgSQL_Thread.cpp
`variables.ffto_enabled` default no longer flips to true when
PROXYSQLGENAI is set (the gate was: PROXYSQLFFTO + PROXYSQLGENAI
-> true; else false). With PROXYSQLGENAI removed, the default
is false everywhere; operators opt in via admin SQL.
CLAUDE.md
Feature-tier table now lists Plugin Chassis (PROXYSQL40) and
AI/MCP (PROXYSQLGENAI) separately, with a note explaining what
PROXYSQLGENAI=1 means post-carve-out. Conditional Components
section calls out that GenAI/MCP/RAG/LLM lives in plugins/genai/.
What this commit does NOT do (deferred)
- Stripping the `#ifdef PROXYSQLGENAI` guards from the plugin's
own source files (LLM_Bridge.cpp, GenAI_Thread.cpp, etc. all
have `#ifdef PROXYSQLGENAI ... #endif` brackets). The
plugin's Makefile force-defines the macro so they keep
expanding. A guard-stripping pass would be ~50 file edits
with zero behaviour change.
- Stripping the dead `#ifdef PROXYSQLGENAI` blocks from core
(lib/Admin_Handler.cpp etc. still have FIXME-stubbed blocks
inside `#ifdef PROXYSQLGENAI` from the 4.C / 5 surgery). With
the macro undefined in core's compile line, those blocks
silently expand to nothing — they're dead code already.
Cleanup follow-up.
- Removing the now-no-op stubs themselves
(init_mcp_variables, flush_mcp_variables___*, load_mcp_server,
stats___mcp_*, etc.). They linger as dead wrappers around
early-returns; their declarations in proxysql_admin.h linger
too. Cleanup follow-up.
All three plugin unit tests pass:
genai_plugin_load_unit-t : 25/25
genai_plugin_anomaly_unit-t : 6/6
genai_plugin_backend_client : 27/27
Carve-out scoreboard, FINAL:
Step 0-2 : infrastructure (chassis cherry-pick, ABI extensions)
Step 3 : ~1.1 K LOC Anomaly_Detector
Step 4.A : ~1 K LOC GENAI: / LLM: query-prefix removal
Step 4.B : ~0.5 K LOC backend_client helper
Step 4.C : ~13 K LOC MCP subsystem + 8 tool handlers + MySQL_FTS
Step 4.F : n/a runtime-reconfig admin SQL via plugin commands
Step 4.G : n/a MCP admin/config/stats tables via plugin ABI
Step 5 : ~7 K LOC GenAI/LLM/AI/RAG
Step 6 : ~5 K LOC AI_Vector_Storage / Discovery_Schema /
MySQL_Catalog / Static_Harvester pair
Step 7 : n/a PROXYSQLGENAI macro dropped from core build
Net core surface change: ~28 K LOC moved out of lib/ + include/
into plugins/genai/. src/proxysql binary shrunk from 197 MB
(pre-carve-out, all PROXYSQLGENAI compiled in) to 152 MB; plugin
.so grew to ~56 MB. Net process RSS roughly neutral.
|
2 months ago |
|
|
4552236700 |
feat(plugins/genai): Step 6 — move RAG/Vector/discovery surface into the plugin
Final file-move step in the carve-out: relocates the leaf modules
that didn't depend on (and weren't depended on by) anything still in
core. After this commit, the only PROXYSQLGENAI-guarded code
remaining in libproxysql.a is `MCP_Tool_Handler` — the base class
the plugin's AI_Tool_Handler / RAG_Tool_Handler inherit from — and
that lives in core only because removing it would force pulling
those derived plugin classes into core just for the inheritance
edge. Step 7 deletes the PROXYSQLGENAI macro entirely.
Files moved (git mv preserves history)
Headers (include/ -> plugins/genai/include/)
AI_Vector_Storage.h
MySQL_Catalog.h
Discovery_Schema.h
Static_Harvester.h
PgSQL_Static_Harvester.h
Sources (lib/ -> plugins/genai/src/)
AI_Vector_Storage.cpp
MySQL_Catalog.cpp
Discovery_Schema.cpp
Static_Harvester.cpp
PgSQL_Static_Harvester.cpp
Core changes were minimal because these are leaf modules:
include/proxysql.h: drop the AI_Vector_Storage.h include.
include/cpp.h: drop AI_Vector_Storage / Discovery_Schema /
MySQL_Catalog / Static_Harvester / PgSQL_Static_Harvester
includes (replaced with a single carve-out history comment that
Step 7 will delete entirely).
lib/ProxySQL_Admin.cpp: drop the Discovery_Schema.h include — its
only live use was via the now-#if-0'd save/load_mcp_query_rules
blocks 4.C left behind for follow-up reference.
lib/Makefile: drop AI_Vector_Storage.oo, MySQL_Catalog.oo,
Discovery_Schema.oo, Static_Harvester.oo, PgSQL_Static_Harvester.oo
from the GenAI _OBJ_CXX list.
Test fixture probe update
test/tap/tests/unit/Makefile: PROXYSQLGENAI auto-detect probe
switched from `AI_Vector_Storage` (now plugin-only) to
`MCP_Tool_Handler` (the last GenAI-tier symbol still in core).
Step 7 deletes the auto-detect entirely.
All three plugin unit tests pass:
genai_plugin_load_unit-t : 25/25
genai_plugin_anomaly_unit-t : 6/6
genai_plugin_backend_client : 27/27
Binary size deltas:
src/proxysql 159 MB -> 152 MB (-7 MB)
plugins/genai/...Plugin.so 47 MB -> 55 MB (+8 MB)
Net process RSS roughly neutral, as the design predicted.
Carve-out scoreboard:
Step 0-2 : infrastructure
Step 3 : ~1.1 K LOC (Anomaly_Detector)
Step 4.B : ~0.5 K LOC (backend_client)
Step 4.C : ~13 K LOC (MCP subsystem + tool handlers + MySQL_FTS)
Step 4.F : runtime-reconfig admin SQL routed through plugin commands
Step 4.G : MCP admin / config / stats tables registered via plugin ABI
Step 5 : ~7 K LOC (GenAI/LLM/AI/RAG)
Step 6 : ~5 K LOC (AI_Vector_Storage + Discovery_Schema +
MySQL_Catalog + Static_Harvester pair)
Pending: Step 7 — delete the PROXYSQLGENAI macro from build flags
and any remaining `#ifdef PROXYSQLGENAI` blocks.
|
2 months ago |
|
|
28cf4ceab8 |
feat(plugins/genai): Step 5 — move GenAI/LLM/AI surface into the plugin
Largest carve-out commit since 4.C: moves the GenAI / LLM / AI / RAG
surface (about 7K LOC) out of core into plugins/genai/. After this
commit, libproxysql.a no longer publishes any of GenAI_Threads_Handler,
LLM_Bridge, LLM_Clients, AI_Features_Manager, AI_Tool_Handler,
RAG_Tool_Handler, or the legacy GloGATH/GloAI globals.
Files moved (git mv preserves history)
Headers (include/ -> plugins/genai/include/)
GenAI_Thread.h
LLM_Bridge.h
AI_Features_Manager.h
AI_Tool_Handler.h
RAG_Tool_Handler.h (promoted from Step 6 — bidirectional
dep with AI_Features_Manager forced
the early move, same way MySQL_FTS.h
got promoted in 4.C)
Sources (lib/ -> plugins/genai/src/ or …/tool_handlers/)
GenAI_Thread.cpp
LLM_Bridge.cpp
LLM_Clients.cpp (.cpp without a header; class decls
live in LLM_Bridge.h)
AI_Features_Manager.cpp
AI_Tool_Handler.cpp -> tool_handlers/
RAG_Tool_Handler.cpp -> tool_handlers/
Plugin lifecycle takeover
plugins/genai/src/plugin_main.cpp:
- Defines plugin-local GloGATH and GloAI alongside the existing
GloMCPH (all three are .so-internal aliases for the contexts
genai_init constructs).
- genai_init now also constructs GenAI_Threads_Handler (calls
->init()) and AI_Features_Manager (calls ->init()), mirroring
the pre-Step-5 ProxySQL_Main_init_GenAI_module sequence.
- genai_stop tears them down in reverse order.
plugins/genai/src/ProxySQL_MCP_Server.cpp:
- AI / RAG endpoint registration re-enabled (was #if 0'd in 4.C
because the constructors weren't reachable from the plugin
then). /mcp/ai and /mcp/rag are once again live when the
operator has GloAI configured.
plugins/genai/src/Anomaly_Detector.cpp + plugin_main.cpp:
- get_query_embedding() now calls through a function-pointer
hook (genai_anomaly_embed_fn) that plugin_main installs in
genai_init and clears in genai_stop. This indirection lets
the test fixture (which compiles Anomaly_Detector.cpp directly
into a test binary, without GenAI_Thread.cpp) link cleanly —
the pointer stays null, the detector short-circuits to empty
embedding, and the existing nullptr-guard in
check_embedding_similarity does the rest.
Core neutralization
src/main.cpp:
- Drops the GloGATH / GloAI globals, ProxySQL_Main_init_GenAI_module
definition + call, the shutdown branch, and the
`if (GloGATH) init_genai_variables()` call.
lib/Admin_Bootstrap.cpp / Admin_FlushVariables.cpp / Admin_Handler.cpp /
ProxySQL_Admin.cpp / MySQL_Session.cpp / ProxySQL_Admin_Stats.cpp:
- Drop the corresponding `#include` and `extern` declarations.
- flush_genai_variables___* stubbed (mirrors the 4.C MCP pattern;
original bodies preserved in `#if 0` for the upcoming
LOAD/SAVE GENAI verbs port).
lib/Admin_Handler.cpp:
- Loose-prefix accept for `genai-*` in is_valid_global_variable
(mirrors the 4.F mcp-* fix), so SET genai-X=Y still reaches
main.global_variables; runtime push happens via the plugin's
LOAD GENAI VARIABLES TO RUNTIME (registered in a follow-up).
include/cpp.h, include/proxysql.h:
- Removed the AI_Features_Manager.h / LLM_Bridge.h / GenAI_Thread.h
/ AI_Tool_Handler.h / RAG_Tool_Handler.h includes that no
longer resolve from core's -I path.
test/tap/test_helpers/test_globals.cpp:
- Drops the matching `#include`s and stub globals.
Test fixture
test/tap/tests/unit/Makefile:
- PROXYSQLGENAI auto-detect probe switched from `GenAI_Thread`
(now plugin-only) to `AI_Vector_Storage` (still in core for
Step 6). After Step 6 the probe will switch again, and
Step 7 deletes the auto-detect entirely.
All three plugin unit tests pass:
- genai_plugin_load_unit-t : 25/25
- genai_plugin_anomaly_unit-t : 6/6
- genai_plugin_backend_client : 27/27
Carve-out scoreboard:
Step 0-2 : infrastructure
Step 3 : ~1.1 K LOC (Anomaly_Detector)
Step 4.B : ~0.5 K LOC (backend_client)
Step 4.C : ~13 K LOC (MCP subsystem)
Step 4.F : runtime-reconfig admin SQL routed through plugin commands
Step 4.G : MCP admin / config / stats tables registered via plugin ABI
Step 5 : ~7 K LOC (GenAI/LLM/AI/RAG)
Pending: Step 6 (AI_Vector_Storage, MySQL_Catalog, Discovery_Schema,
Static_Harvester, PgSQL_Static_Harvester) and Step 7 (delete the
PROXYSQLGENAI macro entirely).
|
2 months ago |
|
|
9078fd3150 |
feat(plugins/genai): Step 4.G — register MCP admin tables via plugin ABI
Moves MCP admin / config / stats SQLite table registration from
lib/Admin_Bootstrap.cpp into the plugin via the chassis
register_table service. Pure refactor: the same DDL strings produce
the same SQLite tables in the same SQLite DBs; only the registration
path changes.
New plugins/genai/src/plugin_tables.cpp registers 14 tables:
admin DB (6)
mcp_query_rules, runtime_mcp_query_rules
mcp_auth_profiles, runtime_mcp_auth_profiles
mcp_target_profiles, runtime_mcp_target_profiles
config DB (3)
mcp_query_rules, mcp_auth_profiles, mcp_target_profiles
(no runtime_* in config; matches the pre-4.G layout)
stats DB (5)
stats_mcp_query_tools_counters, _reset
stats_mcp_query_digest, _reset
stats_mcp_query_rules
The DDL strings still live in include/ProxySQL_Admin_Tables_Definitions.h
for now — plugin_tables.cpp #includes the header. Migrating the
macros into a plugin-private header is a follow-up gated on no
remaining core caller of the MCP table macros (Step 7 territory).
Core changes (lib/Admin_Bootstrap.cpp):
- Deleted the 9 admin/config insert_into_tables_defs() entries
inside `#ifdef PROXYSQLGENAI` for mcp_*.
- Deleted the 5 stats insert_into_tables_defs() entries similarly.
- Replaced both blocks with a one-line comment pointing at the new
plugin owner.
Plugin lifecycle:
- genai_init() now calls genai_register_admin_tables() right after
genai_register_admin_commands(). Both run during chassis Phase C
(init), before admin module bootstrap so the chassis dispatcher
merges plugin tables into the admin DB schema before any DML.
Test extension (test/tap/tests/unit/genai_plugin_load_unit-t.cpp):
- Updated the "skeleton registers no tables (yet)" assertions to
expect 6 admin / 3 config / 5 stats — matching plugin_tables.cpp.
- 25/25 tests passing.
What this changes for operators (no-op):
- Same SQL: SHOW TABLES still shows mcp_*, runtime_mcp_*, stats_mcp_*.
- Same DDL: column lists, primary keys, defaults — all preserved.
- Same admindb / configdb / statsdb attachment.
|
2 months ago |
|
|
f90307ad75 |
feat(plugins/genai): Step 4.F — register LOAD/SAVE MCP QUERY RULES TO/FROM RUNTIME
Adds the last LOAD/SAVE pair the pre-4.C admin SQL surface had:
the MCP query rules cache held by Query_Tool_Handler's
Discovery_Schema catalog.
New helpers in plugins/genai/src/plugin_main.cpp:
mcp_load_query_rules_to_runtime(ctx)
SELECT * FROM main.mcp_query_rules WHERE active=1 ORDER BY rule_id
→ catalog->load_mcp_query_rules(rs). Mirrors the pre-4.C
ProxySQL_Admin::load_mcp_query_rules_to_runtime.
mcp_save_query_rules_from_runtime(ctx, runtime)
Pulls catalog->get_mcp_query_rules() and REPLACEs the rows in
main.mcp_query_rules (or runtime_mcp_query_rules when runtime=true).
Mirrors the pre-4.C ProxySQL_Admin::save_mcp_query_rules_from_runtime.
Both helpers fail cleanly (return false, log to stderr) when the
MCP listener isn't running — there's no in-memory Query_Tool_Handler
cache to read or write. Pre-4.C behaviour was to attempt a
load_mcp_server() self-recovery in that case; we no longer have that
shortcut from outside the listener lifecycle, so callers get a clear
error instead of an opaque retry.
New verbs registered in plugin_commands.cpp:
LOAD MCP QUERY RULES TO RUNTIME
aliases: FROM MEMORY, FROM MEM, TO RUN
SAVE MCP QUERY RULES TO MEMORY
aliases: TO MEM, FROM RUNTIME, FROM RUN
Required new core-side includes in plugin_main.cpp for the
Discovery_Schema and Query_Tool_Handler types these helpers traffic in.
The .so already linked against them via the chassis --whole-archive
trick on libproxysql.a; this is just a header dependency.
Test extension (test/tap/tests/unit/genai_plugin_load_unit-t.cpp):
- 6 new assertions for the QUERY RULES canonical + 5 aliases.
- 25/25 tests passing.
Carve-out scoreboard, runtime reconfig surface restored:
LOAD MCP VARIABLES TO RUNTIME / FROM MEMORY / FROM MEM / TO RUN
LOAD MCP PROFILES TO RUNTIME / FROM MEMORY / FROM MEM / TO RUN
LOAD MCP QUERY RULES TO RUNTIME / FROM MEMORY / FROM MEM / TO RUN
SAVE MCP VARIABLES TO MEMORY / TO MEM / FROM RUNTIME / FROM RUN
SAVE MCP QUERY RULES TO MEMORY / TO MEM / FROM RUNTIME / FROM RUN
Still pending: SET mcp-X=Y (chassis ABI gap, separate enhancement).
|
2 months ago |
|
|
7a4f08416e |
feat(plugins/genai): Step 4.F — register SAVE MCP VARIABLES TO MEMORY
Adds the SAVE direction (runtime → main.global_variables) to the
plugin's admin SQL surface, mirroring the LOAD direction wired in
the previous commit.
New helper plugins/genai/src/plugin_main.cpp::mcp_save_variables_to_admindb
Walks ctx.mcp->get_variables_list(), reads each runtime value via
ctx.mcp->get_variable, and REPLACEs the corresponding "mcp-<name>"
rows in main.global_variables. Owns its own MCP_Threads_Handler
wrlock so callers don't have to coordinate.
Mirrors the pre-4.C flush_mcp_variables___runtime_to_database with
runtime=false (no runtime_global_variables view write).
New verb registered in plugins/genai/src/plugin_commands.cpp:
SAVE MCP VARIABLES TO MEMORY (canonical)
aliases:
SAVE MCP VARIABLES TO MEM
SAVE MCP VARIABLES FROM RUNTIME
SAVE MCP VARIABLES FROM RUN
Same alias convention as the LOAD verbs and as plugins/mysqlx.
The on-disk write ("SAVE MCP VARIABLES TO DISK") stays in core's
admin_handler_command_load_or_save — it's a pure SQL DML that copies
main.* to disk.* and doesn't need plugin runtime state.
Test extension (test/tap/tests/unit/genai_plugin_load_unit-t.cpp):
- 4 new TAP assertions for the SAVE canonical + 3 aliases.
- 19/19 tests passing.
Carve-out scoreboard, runtime reconfig surface restored:
LOAD MCP VARIABLES TO RUNTIME / FROM MEMORY / FROM MEM / TO RUN
LOAD MCP PROFILES TO RUNTIME / FROM MEMORY / FROM MEM / TO RUN
SAVE MCP VARIABLES TO MEMORY / TO MEM / FROM RUNTIME / FROM RUN
Still pending:
- SET mcp-X=Y (chassis ABI lacks per-variable namespace
registration; would need a new ABI surface).
- LOAD/SAVE MCP QUERY RULES TO/FROM RUNTIME (Query_Tool_Handler in
plugin owns the runtime cache; helpers come in next commit).
|
2 months ago |
|
|
ae13958995 |
feat(plugins/genai): Step 4.F (continued) — register LOAD MCP {VARIABLES,PROFILES} TO RUNTIME
Adds plugins/genai/src/plugin_commands.cpp registering two admin SQL
verbs through the chassis command registry, restoring runtime
reconfiguration that 4.C disabled.
Verbs registered (each with FROM MEMORY / FROM MEM / TO RUN aliases):
LOAD MCP VARIABLES TO RUNTIME
-> mcp_load_variables_from_admindb()
-> mcp_start_listener_if_enabled()
Re-pushes mcp-* values from main.global_variables into the running
MCP_Threads_Handler, then re-evaluates the listener state (start
if newly enabled). Replaces the FIXME-stubbed
ProxySQL_Admin::flush_mcp_variables___database_to_runtime path.
LOAD MCP PROFILES TO RUNTIME
-> mcp_load_target_auth_map_from_admindb()
Refreshes runtime_mcp_auth_profiles / runtime_mcp_target_profiles
from main.* and rebuilds the in-memory target_auth_map. Replaces
the FIXME-stubbed init_mcp_variables auth-map block.
The chassis dispatcher in lib/Admin_Handler.cpp:3987 runs BEFORE
admin_handler_command_load_or_save, so any admin SQL matching a
registered plugin verb routes to the plugin and the (now no-op)
hardcoded core handlers never fire. No core changes needed.
What's still stubbed (deferred to follow-up commits):
- SAVE MCP VARIABLES TO MEMORY / FROM RUNTIME (needs runtime ->
admindb push in plugin)
- SAVE MCP PROFILES TO DISK (writes runtime view back to disk.*)
- LOAD/SAVE MCP QUERY RULES (Query_Tool_Handler in plugin owns
them, but the runtime->admindb push isn't wired through plugin
yet)
- SET mcp-X=Y (chassis ABI has no
register_variable_namespace; would need either a new ABI surface
or per-variable register_command — defer to a chassis enhancement)
Refactor: moved mcp_load_variables_from_admindb,
mcp_load_target_auth_map_from_admindb, mcp_start_listener_if_enabled
out of the anonymous namespace in plugin_main.cpp so plugin_commands.cpp
can call them. Forward declarations added to genai_plugin.h.
Test extension (test/tap/tests/unit/genai_plugin_load_unit-t.cpp):
- 7 new TAP assertions verifying canonical SQL and aliases resolve
through the plugin manager's resolve_alias_to_canonical, which is
the same path admin SQL dispatch uses.
- 15/15 tests passing.
|
2 months ago |
|
|
5fe286e972 |
feat(plugins/genai): Step 4.C — move MCP subsystem into the plugin
Per docs/superpowers/plans/2026-04-19-step4-mcp-subsystem-move.md
"4.C / 4.D / 4.E merge" revision. This is the largest single carve-out
commit so far: ~13 K LOC physically relocated, plus surgical edits
across the core admin SQL surface to neutralize references to the
moved code.
What moved (git mv preserves history)
Tool handlers (lib/<name>.cpp -> plugins/genai/src/tool_handlers/<name>.cpp;
include/<name>.h -> plugins/genai/include/<name>.h)
Admin_Tool_Handler, Cache_Tool_Handler, Config_Tool_Handler,
MySQL_Tool_Handler, Observe_Tool_Handler, Query_Tool_Handler,
Stats_Tool_Handler.
MCP listener stack (lib/<name>.cpp -> plugins/genai/src/<name>.cpp;
include/<name>.h(pp) -> plugins/genai/include/...)
MCP_Endpoint, MCP_Thread, ProxySQL_MCP_Server.
Promoted from Step 6 (bidirectional dep with MySQL_Tool_Handler):
MySQL_FTS.
MCP_Tool_Handler base stays in core because AI_Tool_Handler and
RAG_Tool_Handler (Steps 5/6 scope) inherit from it; moving the base
would force pulling those in too.
Plugin lifecycle takeover
plugins/genai/include/genai_plugin.h: GenAIPluginContext now holds
the MCP_Threads_Handler*.
plugins/genai/src/plugin_main.cpp: genai_init constructs the
MCP_Threads_Handler and assigns to a plugin-local GloMCPH symbol
(the legacy global name, kept for the moved tool handlers that
still reference it; the symbol no longer exists in core).
genai_stop tears down on shutdown. genai_start is a no-op for now;
the MCP listener auto-start is gated on the admin-SQL surface that
4.F restores.
plugins/genai/src/ProxySQL_MCP_Server.cpp: AI_Tool_Handler and
RAG_Tool_Handler endpoint registration is disabled via stub
assignments (the headers stay included so member-pointer types
resolve). Steps 5/6 re-enable when those classes move into the
plugin.
Core neutralization (FIXME stubs awaiting 4.F/4.G)
src/main.cpp: GloMCPH global removed; ProxySQL_Main_init_MCP_module
removed; shutdown block deleted.
lib/ProxySQL_Admin.cpp: init_mcp_variables, load_mcp_server,
load_mcp_query_rules_to_runtime, save_mcp_query_rules_from_runtime
stubbed to no-ops; original bodies preserved inside `#if 0` for
4.F reference.
lib/Admin_FlushVariables.cpp: flush_mcp_variables___database_to_runtime
and flush_mcp_variables___runtime_to_database stubbed similarly.
lib/ProxySQL_Admin_Stats.cpp: stats___mcp_query_tools_counters,
stats___mcp_query_digest, stats___mcp_query_rules stubbed.
lib/Admin_Handler.cpp: has_variable("mcp-…") and the
load_target_auth_map call site in LOAD MCP PROFILES … stubbed.
Result: the MCP listener does NOT start automatically between this
commit and 4.F (mcp-* admin variables are not pushed into the
running plugin). Documented in the plan's "4.C/4.D/4.E merge"
section.
src link change: --whole-archive on libproxysql.a
src/Makefile: the proxysql binary now links libproxysql.a with
-Wl,--whole-archive so all symbols are exported via
-Wl,--export-dynamic, allowing the genai plugin .so to dlopen
cleanly even when core code paths don't reference moved-but-still-
in-core classes (LLM_Bridge, Discovery_Schema, MySQL_Catalog,
Static_Harvester, …) directly. test/tap/tests/unit/Makefile gets
the same change so unit tests can dlopen the plugin. Without this,
ld dead-code-eliminates the unreferenced symbols and dlopen fails
with "undefined symbol".
Tests passing
- genai_plugin_anomaly_unit-t : 6/6
- genai_plugin_load_unit-t : 8/8 (lifecycle init/start/stop +
admin table registration)
- genai_plugin_backend_client_unit-t : 27/27
Carve-out scoreboard
Step 0-2 : 0 (infrastructure only)
Step 3 : ~1.1 K (Anomaly_Detector)
Step 4.B : ~0.5 K (backend_client helper, no callers yet)
Step 4.C : ~13 K (this commit; MCP subsystem)
Pending : Steps 4.F, 4.G, 5, 6, 7
|
2 months ago |
|
|
4080606672 |
feat(plugins/genai): Step 4.B — add backend_client helper for local-proxy connections
Per docs/superpowers/plans/2026-04-19-step4-mcp-subsystem-move.md
"Sub-step 4.B", introduces the helper that 4.D will use to rewire
Query_Tool_Handler and MySQL_Tool_Handler from direct-to-backend dialing
to dialing 127.0.0.1:<local-proxy-port>.
This commit is functionally a no-op: nothing in the plugin or core
calls the new helper yet. The .so links it in for future use; only
the unit test exercises it.
New files:
plugins/genai/include/backend_client.h
BackendTarget, MySQL/PgSQLDialResult, dial_*, dial_*_local,
LocalProxyEndpoint, parse_interfaces_first_tcp,
resolve_*_endpoint.
plugins/genai/src/backend_client.cpp
dial_mysql / dial_pgsql: thin wrappers around mysql_real_connect /
PQconnectdb mirroring the dial sequence currently inlined in
Query_Tool_Handler.cpp. No CLIENT_MULTI_STATEMENTS change of
semantics relative to existing code.
dial_*_local: resolve local proxy endpoint via admindb, then dial.
plugins/genai/src/local_proxy_endpoint.cpp
Reads mysql-interfaces / pgsql-interfaces from global_variables,
parses the semicolon-separated host:port format (mirrors
MySQL_Thread::listener_add's parser at lib/MySQL_Thread.cpp ~L240),
canonicalises 0.0.0.0 -> 127.0.0.1 and :: -> ::1, skips Unix-socket
tokens. No caching today; trivial to add when 4.D wires real
callers.
test/tap/tests/unit/genai_plugin_backend_client_unit-t.cpp
27 TAP assertions: parser variants (IPv4/IPv6/wildcards/multi/Unix-
skip/whitespace/port-bounds), null-admindb guards on every public
entry point, invalid-host/zero-port guards on direct-dial. Full
MySQL handshake left for the 4.D integration coverage.
Plumbing:
- plugins/genai/Makefile: compile both new .cpp into the .so.
- test/tap/tests/unit/Makefile: build genai_plugin_backend_client_unit-t
using the same compile-twice trick as genai_plugin_anomaly_unit-t.
- test/tap/groups/groups.json: register the new test in unit-tests-g1
with @proxysql_min_version:4.0.
Resolves Q-svcuser and Q-localhost-port from the carve-out spec design,
choosing existing mcp_auth_profiles credentials and admindb-driven
endpoint discovery respectively (no new mechanisms).
|
2 months ago |
|
|
f1c0ea2dbc |
feat(genai): Step 3 — carve Anomaly_Detector out of core into plugins/genai/
Per docs/superpowers/specs/2026-04-16-genai-plugin-carveout-design.md
"Migration sequence — Step 3", this is the first step that actually
moves GenAI surface out of libproxysql.a. The Anomaly_Detector now
lives entirely inside the genai plugin and is exercised through the
plugin query-hook ABI added in Step 2; core has zero references to it.
Files moved (git mv preserves history):
include/Anomaly_Detector.h -> plugins/genai/include/Anomaly_Detector.h
lib/Anomaly_Detector.cpp -> plugins/genai/src/Anomaly_Detector.cpp
Plugin-side adjustments:
- Drop the `#ifdef PROXYSQLGENAI` guard from both files (the file only
compiles inside the plugin now; the macro remains a core build flag
but the carve-out gates these files by *location*, not by macro).
- Update the json-include relative path to the new depth.
- Replace `Anomaly_Detector::get_query_embedding` with a stub that
returns an empty vector. The previous implementation called
`GloGATH->embed_documents`, but `GloGATH` (the GenAI_Threads_Handler)
is still a core symbol at this point in the carve-out. The
embedding-similarity stage was already nullptr-guarded on
`vector_db`, so an empty embedding short-circuits cleanly to
"no anomaly". Step 5 reattaches the embedding back-end when
GenAI_Thread moves into the plugin.
Plugin lifecycle wiring (plugins/genai/src/plugin_main.cpp):
- `genai_init` now: registers two Prometheus counters
(`proxysql_genai_detected_anomalies_total`,
`proxysql_genai_blocked_queries_total`) against the shared registry
exposed by Step 2.3, registers the query hook for both MySQL and
PgSQL protocols, and constructs the Anomaly_Detector.
- `genai_start`: flips the started flag (the detector has no separate
start phase).
- `genai_stop`: closes and deletes the detector; counters stay
registered (prometheus-cpp has no Unregister).
Plugin query-hook adapter (plugins/genai/src/plugin_hooks.cpp, NEW):
- Bridges ProxySQL_PluginQueryHookPayload to Anomaly_Detector::analyze.
- Increments the appropriate Prometheus counter on detection / block.
- Translates AnomalyResult into ALLOW or DENY(message) per the ABI.
Core removals (the symmetric carve-out):
- lib/MySQL_Session.cpp: delete the in-core `#ifdef PROXYSQLGENAI`
anomaly-detection block in COM_QUERY (lines around 5370-5377 pre-edit)
and the `handler___status_WAITING_CLIENT_DATA___STATE_SLEEP___MYSQL_COM_QUERY_detect_ai_anomaly`
method. Same logic now runs inside the plugin via the query hook
added in Step 2.2.
- include/MySQL_Session.h: drop the matching method declaration.
- lib/AI_Features_Manager.{cpp,h}: remove the anomaly_detector field,
init_anomaly_detector(), close_anomaly_detector(),
get_anomaly_detector(), and the corresponding init() / shutdown()
call sites. AI_Features_Manager now owns only the LLM bridge and
vector_db (LLM_Bridge moves in Step 5; vector_db in Step 6).
- lib/AI_Tool_Handler.{cpp,h}: drop the anomaly_detector field and
the constructor parameter that fed it -- the field was stored but
never read, dead code that was awkward to keep alive across the
carve-out.
- lib/ProxySQL_MCP_Server.cpp: update the AI_Tool_Handler ctor call
site accordingly (one less argument).
- include/MySQL_Thread.h: remove `st_var_ai_detected_anomalies` /
`st_var_ai_blocked_queries` from `enum status_variable_id` and
`ai_detected_anomalies` / `ai_blocked_queries` from
`enum p_th_counter`. The plugin's Prometheus counters replace
these (the old ones were per-thread integer increments surfaced
by the legacy stats path; the plugin uses Prometheus directly).
- lib/MySQL_Thread.cpp: drop the matching entries from
MySQL_Thread_status_variables_counter_array and from
th_metrics_map (the prometheus registration table).
- include/proxysql.h, include/cpp.h: drop the now-stale
`#include "Anomaly_Detector.h"` lines.
- lib/Makefile: drop Anomaly_Detector.oo from the libproxysql object
list.
Tests:
- Delete the in-core TAP tests that linked against the removed symbols:
anomaly_detection-t, anomaly_detection_integration-t,
anomaly_detector_unit-t (Docker-dependent, won't link), plus the
unit test genai_anomaly_unit-t (linked against libproxysql's copy).
- Add test/tap/tests/unit/genai_plugin_anomaly_unit-t.cpp: replaces
the deleted unit test by compiling the plugin's
Anomaly_Detector.cpp directly into the test binary. The
friend-class helper pattern (Anomaly_Detector_TestHelper) is
preserved so private methods (normalize_query,
check_sql_injection) remain testable. Six assertions cover the
same surface plus a regression test that analyze() now runs
cleanly without a vector_db.
Plugin Makefile changes:
- Add Anomaly_Detector.cpp + plugin_hooks.cpp to SRCS.
- Pull in the include paths Anomaly_Detector.cpp's transitively-
included headers need (mariadb client for mysql.h, libev, libscram,
libusual, postgresql, jemalloc, microhttpd, libhttpserver, curl,
re2, pcre, zstd, libconfig, libdaemon, ssl). These mirror the
set already used by test/tap/tests/unit -- the test harness pulls
the same headers in transitively from libproxysql.a's headers.
Doxygen documentation added for every new function and for the new
header structures (GenAIPluginContext fields, genai_query_hook,
register_prometheus_counters, all three lifecycle callbacks, plus
file-level @brief blocks for plugin_main.cpp, plugin_hooks.cpp,
genai_plugin.h, and the moved Anomaly_Detector.{h,cpp}).
Verified end-to-end:
- Full clean rebuild of libproxysql.a + proxysql + ProxySQL_GenAI_Plugin.so.
- All 60 unit-test binaries pass (genai_anomaly_unit-t replaced by
genai_plugin_anomaly_unit-t; net same).
- Smoke test: launching proxysql with
plugins=("...ProxySQL_GenAI_Plugin.so") shows
"Anomaly: Initializing Anomaly Detector v0.1.0" /
"Anomaly Detector initialized with 11 injection patterns" in the
log on startup, and "Anomaly Detector closed" on SIGTERM -- the
plugin's lifecycle owns the detector cleanly.
Carve-out scoreboard so far (lines of GenAI surface moved out of core):
Step 0-2 : 0 (infrastructure prep only)
Step 3 : ~1100 (Anomaly_Detector.{h,cpp}) + counter/handler removals
|
2 months ago |
|
|
9d06ab90f5 |
feat(plugins/genai): Step 1 — empty plugin skeleton
Creates the GenAI plugin shell that subsequent steps will fill out
(per docs/superpowers/specs/2026-04-16-genai-plugin-carveout-design.md
"Migration sequence — Step 1").
plugins/genai/
├── Makefile (mirrors plugins/mysqlx/Makefile)
├── .gitignore
├── include/genai_plugin.h (shared plugin context, atomic started flag)
└── src/plugin_main.cpp (descriptor + empty init/start/stop/status_json)
Top-level Makefile: cd plugins/genai for every existing build_src* /
clean target that already cd's into plugins/mysqlx — release, debug,
legacy, and all test_* flavours (testaurora, testaurora_random,
testgalera, testgrouprep, testreadonly, testreplicationlag, testall).
Unit test: test/tap/tests/unit/genai_plugin_load_unit-t.cpp drives the
real .so through load → init → start → stop and asserts that the
skeleton currently registers no admin/config/stats tables. Wired into
the unit Makefile with an explicit build dependency on the .so so a
clean checkout can produce a passing test in one make invocation.
End-to-end smoke verified: launching proxysql with
plugins=("…/ProxySQL_GenAI_Plugin.so") in proxysql.cnf maps the .so
into /proc/PID/maps, leaves the admin port responsive, and shuts down
cleanly on SIGTERM.
All 58 unit-test binaries pass (+1 over baseline).
Notes on what is intentionally NOT in this commit:
- No GenAI code has moved out of core yet — that begins Step 3.
- The skeleton has no tables, no commands, no query hook, no status
vars — those are Step 2 (ABI extensions) and onwards.
- Pre-existing breakage in test/tap/tests/Makefile (the generic %-t
pattern can't link plugin tests because it doesn't pull the core
globals stub) is unchanged; the genai test sidesteps it by living
under test/tap/tests/unit/, which has the proper harness. The
mysqlx test in test/tap/tests/ remains broken in the same way and
is left for a separate fix.
|
2 months ago |