123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292 |
- #ifndef MYSQL_SERVICE_PARSER_INCLUDED
- #define MYSQL_SERVICE_PARSER_INCLUDED
- /* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
- This program is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License, version 2.0,
- as published by the Free Software Foundation.
- This program is also distributed with certain software (including
- but not limited to OpenSSL) that is licensed under separate terms,
- as designated in a particular file or component or in included license
- documentation. The authors of MySQL hereby grant you an additional
- permission to link the program and your derivative works with the
- separately licensed software that they have included with MySQL.
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License, version 2.0, for more details.
- You should have received a copy of the GNU General Public License
- along with this program; if not, write to the Free Software
- Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
- #include "my_md5_size.h"
- #include <mysql/mysql_lex_string.h>
- #ifndef MYSQL_ABI_CHECK
- #include <stdlib.h>
- #endif
- #ifdef __cplusplus
- class THD;
- class Item;
- #define MYSQL_THD THD*
- typedef Item* MYSQL_ITEM;
- #else
- #define MYSQL_THD void*
- typedef void* MYSQL_ITEM;
- #endif /* __cplusplus */
- #ifdef __cplusplus
- extern "C" {
- #endif
- /**
- @file service_parser
- Plugin service that provides access to the parser and some operations on the
- parse tree.
- */
- #define PARSER_SERVICE_DIGEST_LENGTH MD5_HASH_SIZE
- #define STATEMENT_TYPE_SELECT 1
- #define STATEMENT_TYPE_OTHER 2
- typedef
- int (*parse_node_visit_function)(MYSQL_ITEM item, unsigned char* arg);
- typedef
- int (*sql_condition_handler_function)(int sql_errno,
- const char* sqlstate,
- const char* msg,
- void *state);
- struct st_my_thread_handle;
- extern struct mysql_parser_service_st {
- MYSQL_THD (*mysql_current_session)();
- MYSQL_THD (*mysql_open_session)();
- void (*mysql_start_thread)(MYSQL_THD thd, void *(*callback_fun)(void*),
- void *arg,
- struct st_my_thread_handle *thread_handle);
- void (*mysql_join_thread)(struct st_my_thread_handle *thread_handle);
- void (*mysql_set_current_database)(MYSQL_THD thd, const MYSQL_LEX_STRING db);
- /**
- Parses the query.
- @param thd The session in which to parse.
- @param query The query to parse.
- @param is_prepared If non-zero, the query will be parsed as a prepared
- statement and won't throw errors when the query string contains '?'.
- @param handle_condition Callback function that is called if a condition is
- raised during the preparation, parsing or cleanup after parsing. If this
- argument is non-NULL, the diagnostics area will be cleared before this
- function returns.
- @param condition_handler_state Will be passed to handle_condition when
- called. Otherwise ignored.
- @retval 0 Success.
- @retval 1 Parse error.
- */
- int (*mysql_parse)(MYSQL_THD thd, const MYSQL_LEX_STRING query,
- unsigned char is_prepared,
- sql_condition_handler_function handle_condition,
- void *condition_handler_state);
- int (*mysql_get_statement_type)(MYSQL_THD thd);
- /**
- Returns the digest of the last parsed statement in the session.
- @param thd The session in which the statement was parsed.
- @param digest[out] An area of at least size PARSER_SERVICE_DIGEST_LENGTH,
- where the digest is written.
- @retval 0 Success.
- @retval 1 Parse error.
- */
- int (*mysql_get_statement_digest)(MYSQL_THD thd, unsigned char *digest);
- /**
- Returns the number of parameters ('?') in the parsed query.
- This works only if the last query was parsed as a prepared statement.
- @param thd The session in which the query was parsed.
- @return The number of parameter markers.
- */
- int (*mysql_get_number_params)(MYSQL_THD thd);
- /**
- Stores in 'positions' the positions in the last parsed query of each
- parameter marker('?'). Positions must be an already allocated array of at
- least mysql_parser_service_st::mysql_get_number_params() size. This works
- only if the last query was parsed as a prepared statement.
- @param thd The session in which the query was parsed.
- @param positions An already allocated array of at least
- mysql_parser_service_st::mysql_get_number_params() size.
- @return The number of parameter markers and hence number of written
- positions.
- */
- int (*mysql_extract_prepared_params)(MYSQL_THD thd, int *positions);
- /**
- Walks the tree depth first and applies a user defined function on each
- literal.
- @param thd The session in which the query was parsed.
- @param processor Will be called for each literal in the parse tree.
- @param arg Will be passed as argument to each call to 'processor'.
- */
- int (*mysql_visit_tree)(MYSQL_THD thd, parse_node_visit_function processor,
- unsigned char* arg);
- /**
- Renders the MYSQL_ITEM as a string and returns a reference in the form of
- a MYSQL_LEX_STRING. The string buffer is allocated by the server and must
- be freed by mysql_free_string().
- @param item The literal to print.
- @return The result of printing the literal.
- @see mysql_parser_service_st::mysql_free_string().
- */
- MYSQL_LEX_STRING (*mysql_item_string)(MYSQL_ITEM item);
- /**
- Frees a string buffer allocated by the server.
- @param The string whose buffer will be freed.
- */
- void (*mysql_free_string)(MYSQL_LEX_STRING string);
- /**
- Returns the current query string. This string is managed by the server and
- should @b not be freed by a plugin.
- @param thd The session in which the query was submitted.
- @return The query string.
- */
- MYSQL_LEX_STRING (*mysql_get_query)(MYSQL_THD thd);
- /**
- Returns the current query in normalized form. This string is managed by
- the server and should @b not be freed by a plugin.
- @param thd The session in which the query was submitted.
- @return The query string normalized.
- */
- MYSQL_LEX_STRING (*mysql_get_normalized_query)(MYSQL_THD thd);
- } *mysql_parser_service;
- #ifdef MYSQL_DYNAMIC_PLUGIN
- #define mysql_parser_current_session() \
- mysql_parser_service->mysql_current_session()
- #define mysql_parser_open_session() \
- mysql_parser_service->mysql_open_session()
- #define mysql_parser_start_thread(thd, func, arg, thread_handle) \
- mysql_parser_service->mysql_start_thread(thd, func, arg, thread_handle)
- #define mysql_parser_join_thread(thread_handle) \
- mysql_parser_service->mysql_join_thread(thread_handle)
- #define mysql_parser_set_current_database(thd, db) \
- mysql_parser_service->mysql_set_current_database(thd, db)
- #define mysql_parser_parse(thd, query, is_prepared, \
- condition_handler, condition_handler_state) \
- mysql_parser_service->mysql_parse(thd, query, is_prepared, \
- condition_handler, \
- condition_handler_state)
- #define mysql_parser_get_statement_type(thd) \
- mysql_parser_service->mysql_get_statement_type(thd)
- #define mysql_parser_get_statement_digest(thd, digest) \
- mysql_parser_service->mysql_get_statement_digest(thd, digest)
- #define mysql_parser_get_number_params(thd) \
- mysql_parser_service->mysql_get_number_params(thd)
- #define mysql_parser_extract_prepared_params(thd, positions) \
- mysql_parser_service->mysql_extract_prepared_params(thd, positions)
- #define mysql_parser_visit_tree(thd, processor, arg) \
- mysql_parser_service->mysql_visit_tree(thd, processor, arg)
- #define mysql_parser_item_string(item) \
- mysql_parser_service->mysql_item_string(item)
- #define mysql_parser_free_string(string) \
- mysql_parser_service->mysql_free_string(string)
- #define mysql_parser_get_query(thd) \
- mysql_parser_service->mysql_get_query(thd)
- #define mysql_parser_get_normalized_query(thd) \
- mysql_parser_service->mysql_get_normalized_query(thd)
- #else
- typedef void *(*callback_function)(void*);
- MYSQL_THD mysql_parser_current_session();
- MYSQL_THD mysql_parser_open_session();
- void mysql_parser_start_thread(MYSQL_THD thd, callback_function fun, void *arg,
- struct st_my_thread_handle *thread_handle);
- void mysql_parser_join_thread(struct st_my_thread_handle *thread_handle);
- void mysql_parser_set_current_database(MYSQL_THD thd,
- const MYSQL_LEX_STRING db);
- int mysql_parser_parse(MYSQL_THD thd, const MYSQL_LEX_STRING query,
- unsigned char is_prepared,
- sql_condition_handler_function handle_condition,
- void *condition_handler_state);
- int mysql_parser_get_statement_type(MYSQL_THD thd);
- int mysql_parser_get_statement_digest(MYSQL_THD thd, unsigned char *digest);
- int mysql_parser_get_number_params(MYSQL_THD thd);
- int mysql_parser_extract_prepared_params(MYSQL_THD thd, int *positions);
- int mysql_parser_visit_tree(MYSQL_THD thd, parse_node_visit_function processor,
- unsigned char* arg);
- MYSQL_LEX_STRING mysql_parser_item_string(MYSQL_ITEM item);
- void mysql_parser_free_string(MYSQL_LEX_STRING string);
- MYSQL_LEX_STRING mysql_parser_get_query(MYSQL_THD thd);
- MYSQL_LEX_STRING mysql_parser_get_normalized_query(MYSQL_THD thd);
- #endif /* MYSQL_DYNAMIC_PLUGIN */
- #ifdef __cplusplus
- }
- #endif
- #endif /* MYSQL_SERVICE_PARSER_INCLUDED */
|