
    Dh\                        d Z ddlmZ ddlmZ dZdZdZi ddd	d
dd
ddddddddddddddddddddddddddddi d dd!dd"dd#dd$dd%dd&dd'dd(dd)dd*dd+dd,dd-dd.dd/dZd0Z	g d1Z
d2 Z G d3 d4e      Z G d5 d6e      Z G d7 d8e      Z G d9 d:e      Z G d; d<e      Z G d= d>e      Z G d? d@e      Z G dA dBe      Z G dC dDe      Z G dE dFe      Z G dG dHe      Zy)Iz+Various MySQL constants and character sets
   )ProgrammingError)MYSQL_CHARACTER_SETSi        databaseNuser passwordhostz	127.0.0.1porti  unix_socketuse_unicodeTcharsetutf8	collationconverter_class
autocommitF	time_zonesql_modeget_warningsraise_on_warningsconnection_timeoutclient_flags    compressbufferedrawssl_cassl_certssl_keyssl_verify_cert
ssl_cipherpasswddbconnect_timeoutdsn
force_ipv6auth_pluginallow_local_infileconsume_results)	pool_name	pool_sizepool_reset_session)fabric_hostfabric_usernamefabric_passwordfabric_portfabric_connect_attemptsfabric_connect_delayfabric_report_errorsfabric_ssl_cafabric_ssl_keyfabric_ssl_certfabric_userc                     || z  dkD  ryy)z.Checks if the flag is set

    Returns booleanr   TF )flagflagss     Y/var/www/html/civilisation/venv/lib/python3.12/site-packages/mysql/connector/constants.pyflag_is_setr>   M   s     	    c                   N    e Zd ZdZdZi Zd Zed        Zed        Z	ed        Z
y)
_Constantsz"
    Base class for constants
    r	   c                 2    t        d| j                  z        )NzCan not instanciate from %s)	TypeError__name__clss    r=   __new__z_Constants.__new__]   s    5DEEr?   c                 6    	 | j                   |   d   S #  Y yxY w)z!Get description of given constantr   N)descrF   names     r=   get_descz_Constants.get_desc`   s$    	88D>!$$	s    c                 `    | j                   j                         D ]  \  }}|d   |k(  s|c S  y)z$Get information about given constantr   N)rI   items)rF   numrK   infos       r=   get_infoz_Constants.get_infoh   s7     ((..* 	JD$Aw#~	 r?   c                     d}	 | j                   j                         D cg c]  \  }}|d|d    }}}|S c c}}w # t        $ r}d|z  }Y d}~|S d}~ww xY w)z)get full information about given constantr:   z : r   z)No information found in constant class.%sN)rI   rN   	Exception)rF   reskverrs        r=   get_full_infoz_Constants.get_full_infop   sh     	F58XX^^5EFTQ1Q4(FCF 
	 G 	F>DC
	Fs%   A  :A  A   	A	AAN)rD   
__module____qualname____doc__prefixrI   rG   classmethodrL   rQ   rX   r:   r?   r=   rA   rA   V   sU     FDF      r?   rA   c                        e Zd ZdZed        Zy)_Flagsz,Base class for classes describing flags
    c                     g }| j                   j                         D ]  \  }}||d   z  s|j                  |       ! |S )z@Get the name of all bits set

        Returns a list of strings.r   )rI   rN   append)rF   valuerT   rK   rP   s        r=   get_bit_infoz_Flags.get_bit_info   sE    
 ((..* 	!JD$tAw

4 	! 
r?   N)rD   rY   rZ   r[   r]   rc   r:   r?   r=   r_   r_   |   s      r?   r_   c                   D   e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZi ddd d!d"d#d$d%d&d'd(d)d*d+d,d-d.d/d0d1d2d3d4d5d6d7d8d9d:d;d<d=d>d?d@dAdBdCdDdEdFdGdHdIdJ
Z e!dK        Z"e!dL        Z#e!dM        Z$e!dN        Z%yO)P	FieldTypezMySQL Field Types
    FIELD_TYPE_r   r                        	   
                                                   DECIMAL)r   r   TINY)r   r   SHORT)rg   r   LONG)rh   r   FLOAT)ri   r   DOUBLE)rj   r   NULL)rk   r   	TIMESTAMP)rl   r   LONGLONG)rm   r   INT24)rn   r   DATE)ro   r   TIME)rp   r   DATETIME)rq   r   YEAR)rr   r   NEWDATE)rs   r   VARCHAR)rt   r   BIT)ru   r   )rv   
NEWDECIMAL)rw   ENUM)rx   SET)ry   	TINY_BLOB)rz   MEDIUM_BLOB)r{   	LONG_BLOB)r|   BLOB)r}   
VAR_STRING)r~   STRING)r   GEOMETRY)
r   r   r   r   r   r   r   r   r   r   c                 ^    | j                   | j                  | j                  | j                  gS )z Get the list of all string types)r   r   r   r   rE   s    r=   get_string_typeszFieldType.get_string_types   s)     KKHHNNCJJ
 	
r?   c                 ^    | j                   | j                  | j                  | j                  gS )z Get the list of all binary types)r   r   r   r   rE   s    r=   get_binary_typeszFieldType.get_binary_types   s(     MM3??MM388
 	
r?   c                     | j                   | j                  | j                  | j                  | j                  | j
                  | j                  | j                  | j                  | j                  | j                  gS )z Get the list of all number types)r   r   r   r   r   r   r   r   r   r   r   rE   s    r=   get_number_typeszFieldType.get_number_types   sV     KKHHciiIIszzLL#))GGHH
 	
r?   c                 2    | j                   | j                  gS )z#Get the list of all timestamp types)r   r   rE   s    r=   get_timestamp_typeszFieldType.get_timestamp_types   s     LL#--
 	
r?   N)&rD   rY   rZ   r[   r\   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   rI   r]   r   r   r   r   r:   r?   r=   re   re      s   FGDEDEFDIHEDDHDGG
CJD
CIKIDJFH$ 	 		
 	 	" 	 	( 	& 	 	 	 	& 	 	$  	$!" 	}#$ +(,(*"&7D< 
 
 
 
 	
 	
 
 
r?   re   c                       e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZi dddddddd d!d"d#d$d%d&d'd(d)d*d+d,d-d.d/d0d1d2d3d4d5d6d7d8d9d:d;d<d=d>d?d@dAZyB)C	FieldFlagz_MySQL Field Flags

    Field flags as found in MySQL sources mysql-src/include/mysql_com.h
    r	   r   rg   ri   rm   ru       @                  r   r    @                        NOT_NULL)r   zField can't be NULLPRI_KEY)rg   zField is part of a primary key
UNIQUE_KEY)ri   zField is part of a unique keyMULTIPLE_KEY)rm   zField is part of a keyr   )ru   zField is a blobUNSIGNED)r   zField is unsignedZEROFILL)r   zField is zerofillBINARY)r   zField is binary  r   )r   zfield is an enumAUTO_INCREMENT)r   zfield is a autoincrement fieldr   )r   zField is a timestampr   )r   zfield is a setNO_DEFAULT_VALUE)r   z Field doesn't have default valueON_UPDATE_NOW)r   zField is set to NOW on UPDATENUM)r   zField is num (for clients)PART_KEY)r   zIntern; Part of some keyGROUP)r   zIntern: Group field)r   Intern: Used by sql_yacc)r   r   )r   zUsed to get fields in item tree)r   zField part of partition func)r   zIntern: Field used in ADD INDEX)r   zIntern: Field is being renamed)UNIQUEBINCMPGET_FIXED_FIELDSFIELD_IN_PART_FUNCFIELD_IN_ADD_INDEXFIELD_IS_RENAMEDN)rD   rY   rZ   r[   _prefixr   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   rI   r:   r?   r=   r   r      s    GHGJLDHHFDNI
CM
CHEFF  3= 	? 	:	
 	+ 	1 	1 	/ 	, 	D 	6 	* 	I 	C 	6" 	9#$ 	1%& 87HGJG1Dr?   r   c                   "   e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZ dZ!d Z"d!Z#d"Z$i d#d$d%d&d'd(d)d*d+d,d-d.d/d0d1d2d3d4d5d6d7d8d9d:d;d<d=d>d?d@dAdBdCdDdEdFdGdHdIdJdKdLdMdNdOdPdQdRdSdTZ%yU)V	ServerCmdzMySQL Server Commands
    COM_r   r   rg   rh   ri   rj   rk   rl   rm   rn   ro   rp   rq   rr   rs   rt   ru                                                SLEEP)r   r   QUIT)r   r   INIT_DB)rg   r   QUERY)rh   r   
FIELD_LIST)ri   r   	CREATE_DB)rj   r   DROP_DB)rk   r   REFRESH)rl   r   SHUTDOWN)rm   r   
STATISTICS)rn   r   PROCESS_INFO)ro   r   CONNECT)rp   r   PROCESS_KILL)rq   r   DEBUG)rr   r   PING)rs   r   r   )rt   r   DELAYED_INSERT)ru   r   )r   CHANGE_USER)r   BINLOG_DUMP)r   
TABLE_DUMP)r   CONNECT_OUT)r   REGISTER_SLAVE)r   STMT_PREPARE)r   STMT_EXECUTE)r   STMT_SEND_LONG_DATA)r   
STMT_CLOSE)r   
STMT_RESET)r   
SET_OPTION)r   
STMT_FETCH)r   DAEMON)r   BINLOG_DUMP_GTID)r   RESET_CONNECTION)r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   N)&rD   rY   rZ   r[   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   rI   r:   r?   r=   r   r   ,  s   GEDGEJIGGHJLGLEDDNKKJKNLLJJJJF!!! 	>! 		!
 	'! 	%! 	>! 	>! 	O! 	'! 	,! 	?! 	,! 	! 	!  	!!" 	0#!$ +*(*0,,:(((( 44A!Dr?   r   c                   &   e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZi dddd d!d"d#d$d%d&d'd(d)d*d+d,d-d.d/d0d1d2d3d4d5d6d7d8d9d:d;d<d=d>d?d@dAdBdCdDdEdFdGdHdI
Zeeeeeeeeeg	Z e!dJ        Z"yK)L
ClientFlagzgMySQL Client Flags

    Client options as found in the MySQL sources mysql-src/include/mysql_com.h
    r   rg   ri   rm   ru   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r     @          @        LONG_PASSWD)r   zNew more secure passwords
FOUND_ROWS)rg   zFound instead of affected rows	LONG_FLAG)ri   zGet all column flagsCONNECT_WITH_DB)rm   zOne can specify db on connect	NO_SCHEMA)ru   z!Don't allow database.table.columnCOMPRESS)r   zCan use compression protocolODBC)r   zODBC clientLOCAL_FILES)r   zCan use LOAD DATA LOCALIGNORE_SPACE)r   zIgnore spaces before ''PROTOCOL_41)r   zNew 4.1 protocolINTERACTIVE)r   zThis is an interactive clientSSL)r   zSwitch to SSL after handshakeIGNORE_SIGPIPE)r   zIGNORE sigpipesTRANSACTIONS)r   zClient knows about transactionsRESERVED)r   zOld flag for 4.1 protocolSECURE_CONNECTION)r   zNew 4.1 authenticationMULTI_STATEMENTS)r   z!Enable/disable multi-stmt support)r   zEnable/disable multi-results)r   zMulti-results in PS-protocol)r   z%Client supports plugin authentication)r   z%Client supports connection attributes)r   zAEnable authentication response packet to be larger than 255 bytes)r   zADon't close the connection for a connection with expired password)r   z3Capable of handling server state change information)r   z!Client no longer needs EOF packet)r   r	   )r   r	   )
MULTI_RESULTSPS_MULTI_RESULTSPLUGIN_AUTHCONNECT_ARGSPLUGIN_AUTH_LENENC_CLIENT_DATACAN_HANDLE_EXPIRED_PASSWORDSSESION_TRACKDEPRECATE_EOFSSL_VERIFY_SERVER_CERTREMEMBER_OPTIONSc                 6    d}| j                   D ]  }||z  }	 |S )zbGet the default client options set

        Returns a flag with all the default client options setr   )default)rF   r<   options      r=   get_defaultzClientFlag.get_default  s*    
 kk 	FVOE	r?   N)#rD   rY   rZ   r[   r  r  r  r  r  r  r  r  r	  r
  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  rI   r  r]   r  r:   r?   r=   r   r   u  s    KJIOIHDKLKK
CNLHMKL%,"#* LM$<@ 	5 	D	
 	B 	< 	' 	: 	; 	3 	A 	9 	6 	D 	:  	@!" 	J#$ CEIJ+p(vXG"/)9D@ 	
G  r?   r   c            
       P    e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdZdddddddddd	Zy)
ServerFlagzeMySQL Server Flags

    Server flags as found in the MySQL sources mysql-src/include/mysql_com.h
    SERVER_r   rg   rm   ru   r   r   r   r   r   )r   zTransaction has started)rg   zServer in auto_commit mode)rm   zMulti query - next query exists)ru   r	   )r   r	   )r   r	   )r   r	   )r   zA database was dropped)r   r	   )	SERVER_STATUS_IN_TRANSSERVER_STATUS_AUTOCOMMITSERVER_MORE_RESULTS_EXISTSSERVER_QUERY_NO_GOOD_INDEX_USEDSERVER_QUERY_NO_INDEX_USEDSERVER_STATUS_CURSOR_EXISTSSERVER_STATUS_LAST_ROW_SENTSERVER_STATUS_DB_DROPPED"SERVER_STATUS_NO_BACKSLASH_ESCAPESN)rD   rY   rZ   r[   r   STATUS_IN_TRANSSTATUS_AUTOCOMMITMORE_RESULTS_EXISTSQUERY_NO_GOOD_INDEX_USEDQUERY_NO_INDEX_USEDSTATUS_CURSOR_EXISTSSTATUS_LAST_ROW_SENTSTATUS_DB_DROPPEDSTATUS_NO_BACKSLASH_ESCAPESrI   r:   r?   r=   r!  r!    sn     GO % !!"(#>%C'< ,8&2'3'3$F.:Dr?   r!  c                   D    e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
dddddddZy)RefreshOptionzaMySQL Refresh command options

    Options used when sending the COM_REFRESH server command.
    REFRESH_r   rg   ri   rm   ru   r   r   )r   zRefresh grant tables)rg   zStart on new log file)ri   zclose all tables)rm   zFlush host cache)ru   zFlush status variables)r   zFlush thread cache)r   z*Reset master info and restart slave thread)GRANTLOGTABLESHOSTSSTATUSTHREADSSLAVEN)rD   rY   rZ   r[   r   r8  r9  r:  HOSTr<  r=  r>  rI   r:   r?   r=   r6  r6    sO     GE
CFDFGE 20.-41GDr?   r6  c            	       j    e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
Zedfedfedfedfe	dfe
dfedfedfdZy)ShutdownTypezVMySQL Shutdown types

    Shutdown types used by the COM_SHUTDOWN server command.
    r	   r   r   rg   rm   ru   r   r~   r   z%defaults to SHUTDOWN_WAIT_ALL_BUFFERSz'wait for existing connections to finishz!wait for existing trans to finishz#wait for existing updates to finishz-flush InnoDB and other storage engine buffersz@don't flush InnoDB buffers, flush other storage engines' buffersz(no description))SHUTDOWN_DEFAULTSHUTDOWN_WAIT_CONNECTIONSSHUTDOWN_WAIT_TRANSACTIONSSHUTDOWN_WAIT_UPDATESSHUTDOWN_WAIT_ALL_BUFFERSSHUTDOWN_WAIT_CRITICAL_BUFFERS
KILL_QUERYKILL_CONNECTIONN)rD   rY   rZ   r[   r   rB  rC  rD  rE  rF  rG  rH  rI  rI   r:   r?   r=   rA  rA    s     G !!" "%'"JO 35 &5&7 '/'1 "1"3 &;&= +3+4
    /Dr?   rA  c                   j    e Zd ZdZeZdZed        Zed        Z	ed        Z
ed	d       Zed        Zy)
CharacterSetaL  MySQL supported character sets and collations

    List of character sets with their collations supported by MySQL. This
    maps to the character set we get from the server within the handshake
    packet.

    The list is hardcode so we avoid a database query when getting the
    name of the used character set or collation.
    )r   rr   r   T   W   X   c                 v    	 | j                   |   dd S # t        $ r t        dj                  |            w xY w)a  Retrieves character set information as tuple using an ID

        Retrieves character set and collation information based on the
        given MySQL ID.

        Raises ProgrammingError when character set is not supported.

        Returns a tuple.
        r   rg   zCharacter set '{0}' unsupported)rI   
IndexErrorr   formatrF   setids     r=   rQ   zCharacterSet.get_infoA  sK    	A88E?1Q'' 	A"188?A A	As    $8c                 8    	 d| j                  |      z  S #   xY w)zRetrieves character set information as string using an ID

        Retrieves character set and collation information based on the
        given MySQL ID.

        Returns a tuple.
        z%s/%s)rQ   rR  s     r=   rL   zCharacterSet.get_descR  s%    	S\\%000	s    c                    t        |t              r	 | j                  |   }|d   |d   |fS t	        | j                        D ]%  \  }}|	|d   |k(  s|d   du s|d   |d   |fc S  t        d|z        #  t        d|z         Y ]xY w)zRetrieves the default collation for given character set

        Raises ProgrammingError when character set is not supported.

        Returns list (collation, charset, index)
        r   r   z"Character set ID '%s' unsupported.rg   TzCharacter set '%s' unsupported.)
isinstanceintrI   r   	enumerate)rF   r   rP   cids       r=   get_default_collationz"CharacterSet.get_default_collation`  s     gs#xx(AwQ00
 #388, 	-IC|Aw'!d1goAwQ,,		- @GLMM !E" s   A7 7B	Nc                 F   t        |t              r	 | j                  |   }||d   |d   fS |!|| j                  |      }|d   |d   |d   fS |Q|Ot        | j                        D ]  \  }}|	||d   k(  s||d   |d   fc S  t	        dj                  |            t        | j                        D ]&  \  }}|	|d   |k(  s|d   |k(  s||d   |d   fc S  t	        dj                  |            # t        $ r t	        dj                  |             Y w xY w)aE  Get character set information using charset name and/or collation

        Retrieves character set and collation information given character
        set name and/or a collation name.
        If charset is an integer, it will look up the character set based
        on the MySQL's ID.
        For example:
            get_charset_info('utf8',None)
            get_charset_info(collation='utf8_general_ci')
            get_charset_info(47)

        Raises ProgrammingError when character set is not supported.

        Returns a tuple with (id, characterset name, collation)
        r   r   zCharacter set ID {0} unknown.rg   zCollation '{0}' unknown.zCharacter set '{0}' unknown.)rV  rW  rI   rP  r   rQ  rZ  rX  )rF   r   r   rP   rY  s        r=   get_charset_infozCharacterSet.get_charset_infox  sn   " gs#xx(a$q'22
 9#4,,W5DGT!Wd1g.._!6&sxx0 3	T<Q'a$q'22	3
 ##=#D#DY#OPP&sxx0 3	T<7g%$q'Y*>a$q'22	3
 ##A#H#H$  )   !@!G!G" s   C: :#D D c                 |    g }| j                   D ]!  }|s|d   |vs|j                  |d          # t        |      S )z^Retrieves a list with names of all supproted character sets

        Returns a tuple.
        r   )rI   ra   tuple)rF   rT   rP   s      r=   get_supportedzCharacterSet.get_supported  sF     HH 	$DQs*

47#	$ Szr?   )NN)rD   rY   rZ   r[   r   rI   slash_charsetsr]   rQ   rL   rZ  r\  r_  r:   r?   r=   rK  rK  2  s|      D -NA A    N N. ) )V 	 	r?   rK  c                       e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZ dZ!d Z"d!Z#d"Z$e%d#        Z&e%d$        Z'e%d%        Z(y&)'SQLModezMySQL SQL Modes

    The numeric values of SQL Modes are not interesting, only the names
    are used when setting the SQL_MODE system variable using the MySQL
    SET command.

    See http://dev.mysql.com/doc/refman/5.6/en/server-sql-mode.html
    MODE_REAL_AS_FLOATPIPES_AS_CONCATANSI_QUOTESr	  NOT_USEDONLY_FULL_GROUP_BYNO_UNSIGNED_SUBTRACTIONNO_DIR_IN_CREATE
POSTGRESQLORACLEMSSQLDB2MAXDBNO_KEY_OPTIONSNO_TABLE_OPTIONSNO_FIELD_OPTIONSMYSQL323MYSQL40ANSINO_AUTO_VALUE_ON_ZERONO_BACKSLASH_ESCAPESSTRICT_TRANS_TABLESSTRICT_ALL_TABLESNO_ZERO_IN_DATENO_ZERO_DATEINVALID_DATESERROR_FOR_DIVISION_BY_ZEROTRADITIONALNO_AUTO_CREATE_USERHIGH_NOT_PRECEDENCENO_ENGINE_SUBSTITUTIONPAD_CHAR_TO_FULL_LENGTHc                     t         NNotImplementedErrorrJ   s     r=   rL   zSQLMode.get_desc      !!r?   c                     t         r  r  )rF   numbers     r=   rQ   zSQLMode.get_info  r  r?   c                     g }t        |       j                         D ]<  }|j                  d      rt        t	        | |      d      r,|j                  |       > t        t        |            S )zReturns a sequence of all available SQL Modes

        This class method returns a tuple containing all SQL Mode names. The
        names will be alphabetically sorted.

        Returns a tuple.
        ___call__)varskeys
startswithhasattrgetattrra   r^  sorted)rF   rT   keys      r=   rX   zSQLMode.get_full_info  s\     9>># 	 C>>#&#GC$5zB

3	  VC[!!r?   N))rD   rY   rZ   r[   r   rd  re  rf  r	  rg  rh  ri  rj  rk  rl  rm  rn  ro  rp  rq  rr  rs  rt  ru  rv  rw  rx  ry  rz  r{  r|  r}  r~  r  r  r  r  r]   rL   rQ   rX   r:   r?   r=   rb  rb    s     G#M'OK!LH-7)JFE
CE%N))HGD31/+'O!L#M!=K//57" " " " " "r?   rb  )r[   errorsr   charsetsr   MAX_PACKET_LENGTHNET_BUFFER_LENGTHMAX_MYSQL_TABLE_COLUMNSDEFAULT_CONFIGURATIONCNX_POOL_ARGSCNX_FABRIC_ARGSr>   objectrA   r_   re   r   r   r   r!  r6  rA  rK  rb  r:   r?   r=   <module>r     sc  0 % *   ""
B" " K	"
 D" 4" 4" v" " t" %" " " E" "  $!"" A#"$ %"& '"( 
5)"* d+", -". t/"0 u1"2 $3"4 d5"6 	$7"8 t9": 
4;"< %="> 4?"@ $A"B uC" H A"# #LZ  `

 `
F: :zF
 FRT Tn BJ 2): )X|: |~A"j A"r?   