IP : 3.141.201.46 Hostname : host45.registrar-servers.com Kernel : Linux host45.registrar-servers.com 4.18.0-513.18.1.lve.2.el8.x86_64 #1 SMP Sat Mar 30 15:36:11 UTC 2024 x86_64 Disable Function : None :) OS : Linux PATH: / home/ ../ ./ lib64/ hmaccalc/ ./ ../ ./ apache2/ ../ groff/ ../ python2.7/ bsddb/ dbtables.pyc/ /

�
{fc@s!dZddlZddlZddlZddlZddlZejddkrdddlZnzejd(kr�ddlZn\ddl Z e j
�Z e j �z)e j
ddd d
e�ddlZWde j�X[ ydd lmZWn!ek
rdd lmZnXd efd
��YZdefd��YZdd)d��YZdefd��YZdefd��YZdefd��YZdefd��YZdZdZd�ZdZdZ dZ!d �Z"d!�Z#d"�Z$d#�Z%d$�Z&d%�Z'd&d*d'��YZ(dS(+s$Id$i����Niiiitignoretmessages1the cPickle module has been removed in Python 3.0tcategory(tdbt TableDBErrorcBseZRS((t__name__t
__module__(((s&/usr/lib64/python2.7/bsddb/dbtables.pyR>stTableAlreadyExistscBseZRS((RR(((s&/usr/lib64/python2.7/bsddb/dbtables.pyR@stCondcBseZdZd�ZRS(s!This condition matches everythingcCsdS(Ni((tselfts((s&/usr/lib64/python2.7/bsddb/dbtables.pyt__call__Fs(RRt__doc__R (((s&/usr/lib64/python2.7/bsddb/dbtables.pyRDst ExactCondcBs eZdZd�Zd�ZRS(s)Acts as an exact match condition functioncCs
||_dS(N(t
strtomatch(R R((s&/usr/lib64/python2.7/bsddb/dbtables.pyt__init__KscCs
||jkS(N(R(R R
((s&/usr/lib64/python2.7/bsddb/dbtables.pyR Ms(RRR RR (((s&/usr/lib64/python2.7/bsddb/dbtables.pyR
Is t
PrefixCondcBs eZdZd�Zd�ZRS(s9Acts as a condition function for matching a string prefixcCs
||_dS(N(tprefix(R R((s&/usr/lib64/python2.7/bsddb/dbtables.pyRRscCs|t|j� |jkS(N(tlenR(R R
((s&/usr/lib64/python2.7/bsddb/dbtables.pyR Ts(RRR RR (((s&/usr/lib64/python2.7/bsddb/dbtables.pyRPs t PostfixCondcBs eZdZd�Zd�ZRS(s:Acts as a condition function for matching a string postfixcCs
||_dS(N(tpostfix(R R((s&/usr/lib64/python2.7/bsddb/dbtables.pyRYscCs|t|j� |jkS(N(RR(R R
((s&/usr/lib64/python2.7/bsddb/dbtables.pyR [s(RRR RR (((s&/usr/lib64/python2.7/bsddb/dbtables.pyRWs tLikeCondcBs&eZdZejd�Zd�ZRS(s�
Acts as a function that will match using an SQL 'LIKE' style
string. Case insensitive and % signs are wild cards.
This isn't perfect but it should work for the simple common cases.
cCsfd}x$|D]}|j|d|�}q
W|jdd�|_tjd|jd|�|_dS(Ns.*+()[]?s\t%s.*t^t$(treplacetlikestrtretcompile(R Rtre_flagstchars_to_escapetchar((s&/usr/lib64/python2.7/bsddb/dbtables.pyRds

cCs|jj|�S(N(Rtmatch(R R
((s&/usr/lib64/python2.7/bsddb/dbtables.pyR ls(RRR Rt
IGNORECASERR (((s&/usr/lib64/python2.7/bsddb/dbtables.pyR^st__TABLE_NAMES__s ._COLUMNS__cCs|tS(N(t_columns(ttable((s&/usr/lib64/python2.7/bsddb/dbtables.pyt _columns_keyuss._DATA_.s ._ROWID_.icCs|t|t|S(N(t_data(R$tcoltrowid((s&/usr/lib64/python2.7/bsddb/dbtables.pyt _data_key�scCs|t|tS(N(R&(R$R'((s&/usr/lib64/python2.7/bsddb/dbtables.pyt_search_col_data_key�scCs|tS(N(R&(R$((s&/usr/lib64/python2.7/bsddb/dbtables.pyt_search_all_data_key�scCs|t|tS(N(t_rowid(R$R(((s&/usr/lib64/python2.7/bsddb/dbtables.pyt
_rowid_key�scCs|tS(N(R,(R$((s&/usr/lib64/python2.7/bsddb/dbtables.pyt_search_rowid_key�scCs`|jt�dksT|jt�dksT|jt�dksT|jt�dkrXdSdSdS(s�Verify that the given string does not contain any
metadata strings that might interfere with dbtables database operation.
iiN(tfindt_table_names_keyR#R&R,(R
((s&/usr/lib64/python2.7/bsddb/dbtables.pytcontains_metastrings�s t
bsdTableDBcBs�eZdddddd�Zd�Zd�Zdd�Zd�Zd�Zd�Zd �Z d
�Z
d �Z d �Z d
�Z
d�Ziid�Zid�Zid�Zd�Zd�ZRS(ii�c s"d |_tj}|r(|tjO}ntjtjBtjBtjB|B} y|tjO}Wnt k
rnnX|r�| tj
B} ntj �|_ |j j
tj�|j j||| B�|r�|tjO}ntj|j �|_|jjd�|jjtj�|jj|tj||B|�||_tjddkr�dtfd��Y�dtf�fd��Y}
|
|j�|_n|j j�} yVt|jd�t| �s�t|jd |jj�ttjgd�d
| �nWn| j ��n X| j!�i|_"d S( s�bsdTableDB(filename, dbhome, create=0, truncate=0, mode=0600)

Open database name in the dbhome Berkeley DB directory.
Use keyword arguments when calling this constructor.
iiit cursor_py3kcBs,eZd�Zd�Zd�Zd�ZRS(cSs
||_dS(N(t _dbcursor(R tdbcursor((s&/usr/lib64/python2.7/bsddb/dbtables.pyR�scSs
|jj�S(N(R4tclose(R ((s&/usr/lib64/python2.7/bsddb/dbtables.pyR6�scSsT|jjt|d��}|dk rP|djd�|djd�f}n|S(Ns iso8859-1ii(R4t set_rangetbytestNonetdecode(R tsearchtv((s&/usr/lib64/python2.7/bsddb/dbtables.pyR7�s
 cSsNt|jd��}|dk rJ|djd�|djd�f}n|S(Ntnextis iso8859-1i(tgetattrR4R9R:(R R<((s&/usr/lib64/python2.7/bsddb/dbtables.pyt__next__�s
 (RRRR6R7R?(((s&/usr/lib64/python2.7/bsddb/dbtables.pyR3�s   tdb_py3kcs}eZd�Zd
�fd�Zd
d�Zdd
d�Zd
d�Zd
dd�Zd
dd�Z d
d�Z
d �Z RS( cSs
||_dS(N(t_db(R R((s&/usr/lib64/python2.7/bsddb/dbtables.pyR�scs�|jjd|��S(Nttxn(RAtcursor(R RB(R3(s&/usr/lib64/python2.7/bsddb/dbtables.pyRC�scSs%t|jd�t|d�d|�S(Nthas_keys iso8859-1RB(R>RAR8(R tkeyRB((s&/usr/lib64/python2.7/bsddb/dbtables.pyRD�sicSsLt|d�}|dk r-t|d�}n|jj||d|d|�S(Ns iso8859-1tflagsRB(R8R9RAtput(R REtvalueRFRB((s&/usr/lib64/python2.7/bsddb/dbtables.pyRG�s cSs(t|d�}|jj||d|�S(Ns iso8859-1RB(R8RARG(R RERHRB((s&/usr/lib64/python2.7/bsddb/dbtables.pyt put_bytes�scSsOt|d�}|jj|d|d|�}|dk rK|jd�}n|S(Ns iso8859-1RBRF(R8RAtgetR9R:(R RERBRFR<((s&/usr/lib64/python2.7/bsddb/dbtables.pyRJ�s
 cSs+t|d�}|jj|d|d|�S(Ns iso8859-1RBRF(R8RARJ(R RERBRF((s&/usr/lib64/python2.7/bsddb/dbtables.pyt get_bytes�scSs%t|d�}|jj|d|�S(Ns iso8859-1RB(R8RAtdelete(R RERB((s&/usr/lib64/python2.7/bsddb/dbtables.pyRL�scSs
|jj�S(N(RAR6(R ((s&/usr/lib64/python2.7/bsddb/dbtables.pyR6�sN( RRRR9RCRDRGRIRJRKRLR6((R3(s&/usr/lib64/python2.7/bsddb/dbtables.pyR@�s    RDRIRBN(#R9Rt DB_THREADt DB_CREATEt
DB_INIT_MPOOLt DB_INIT_LOCKt DB_INIT_LOGt DB_INIT_TXNtDB_AUTO_COMMITtAttributeErrort
DB_RECOVERtDBEnvtenvt
set_lk_detecttDB_LOCK_DEFAULTtopent DB_TRUNCATEtDBtset_get_returns_nonet set_flagstDB_DUPtDB_BTREEt
dbfilenametsyst version_infotobjectt txn_beginR>R0RGtpickletdumpstaborttcommitt_bsdTableDB__tablecolumns( R tfilenametdbhometcreatettruncatetmodetrecovertdbflagstmyflagst flagsforenvR@RB((R3s&/usr/lib64/python2.7/bsddb/dbtables.pyR�sF  "
  '#

cCs|j�dS(N(R6(R ((s&/usr/lib64/python2.7/bsddb/dbtables.pyt__del__scCsT|jdk r(|jj�d|_n|jdk rP|jj�d|_ndS(N(RR9R6RW(R ((s&/usr/lib64/python2.7/bsddb/dbtables.pyR6s 
 
cCs|jj|�dS(N(RWttxn_checkpoint(R tmins((s&/usr/lib64/python2.7/bsddb/dbtables.pyt
checkpointscCs|jj�dS(N(Rtsync(R ((s&/usr/lib64/python2.7/bsddb/dbtables.pyRx scCs�dGH|jj�}y^|j�\}}xEti||6�GH|j�}|r_|\}}q,|j�dSq,WWntjk
r�|j�nXdS(s*Print the database to stdout for debuggings5******** Printing raw database for debugging ********N(RRCtfirsttreprR=R6tDBNotFoundError(R tcurREtdataR=((s&/usr/lib64/python2.7/bsddb/dbtables.pyt _db_print#s 
 cCs�t|t�st�d }y^t|�r9td��nx)|D]!}t|�r@td��q@q@Wt|�}t|jd�|�r�t d�n|j
j �}t|jd|jj �|t
j|d�d|�t
jt|jd|jj�td|d tj��}|j|�|jjtd|�t|jd|jj �tt
j|d�d|�|j�d }WnXtjk
r�}|r�|j�ntjd
kr�t|d�q�t|jd�nXd S(s�CreateTable(table, columns) - Create a new table in the database.

raises TableDBError if it already exists or for other DB errors.
s-bad table name: contains reserved metastringss.bad column name: contains reserved metastringsRDstable already existsRIiRBRKRFiiN(ii(t
isinstancetlisttAssertionErrorR9R1t
ValueErrorR%R>RRRWReRGRfRgtloadsRJR0tDB_RMWtappendRLRitDBErrorRhRbRcRtargs(R R$tcolumnsRBtcolumntcolumnlist_keyt tablelisttdberror((s&/usr/lib64/python2.7/bsddb/dbtables.pyt CreateTable5s<  
   '



cCs�t|t�st�t|�r-td�nt|�}t|jd�|�sUgSt|jd|jj�|�}|r�t j
|�SgSdS(s\Return a list of columns in the given table.
[] if the table doesn't exist.
s-bad table name: contains reserved metastringsRDRKN( RtstrR�R1R�R%R>RRJRfR�(R R$R�tpickledcolumnlist((s&/usr/lib64/python2.7/bsddb/dbtables.pytListTableColumnses    
cCs-|jjt�}|r%tj|�SgSdS(s)Return a list of tables in this database.N(Rtget_getR0RfR�(R tpickledtablelist((s&/usr/lib64/python2.7/bsddb/dbtables.pyt
ListTablesws
c
Cs�t|t�st�y|j||�Wn�tk
r�d}y+t|�}|jj�}t j
t |j d|j j
�|d|dt j��}i}x|D]}|||<q�Wtj|�}x*|D]"}||kr�|j|�q�q�W||krL|j j|d|�t |j d|j j�|t j|d�d|�n|j�d}|j|�Wq�t jk
r�} |r�|j�ntjd kr�t| d�q�t| jd�q�XnXdS(
sCreateOrExtendTable(table, columns)

Create a new table in the database.

If a table of this name already exists, extend it to have any
additional columns present in the given list as well as
all of its current columns.
RKRBRFRIiiiN(ii(RR�R�R�RR9R%RWReRfR�R>RRJR�tcopyR�RLRGRgRit_bsdTableDB__load_column_infoR�RhRbRcRR�(
R R$R�RBR�t
oldcolumnlistt
oldcolumnhashtct
newcolumnlistR�((s&/usr/lib64/python2.7/bsddb/dbtables.pytCreateOrExtendTables@ 
  '

  


cCs�y+t|jd|jj�t|��}Wn$tjk
rQtd|f�nX|sktd|f�ntj|�|j|<dS(s'initialize the self.__tablecolumns dictRKsunknown table: %rN( R>RRJR%R{RRfR�Rj(R R$t tcolpickles((s&/usr/lib64/python2.7/bsddb/dbtables.pyt__load_column_info�s cCs�d}x�|s�g}x-tt�D]}|jtjdd��q"Wtjdt|�}tjddkr�|j d�}ny/|j
j t ||�d d|dt
j�Wnt
jk
r�q Xd}q W|S(
s"Create a new unique row identifierii�tBis iso8859-1RBRFiN(txranget_rowid_str_lenR�trandomtrandinttstructtpackRbRcR:RRGR-R9tDB_NOOVERWRITEtDBKeyExistError(R R$RBtuniquetblisttxtnewid((s&/usr/lib64/python2.7/bsddb/dbtables.pyt __new_rowid�s !
c Cs�d}yt|jd�t|��s3td�n||jkrR|j|�nx=|j�D]/}|j|j|�s_td|f�q_q_W|j j
�}|j |d|�}x?|j �D]1\}}|jj
t|||�|d|�q�W|j�d}Wn�tjk
r�}tj�}|rV|j�|jjt||��ntjd kr|t|d|d�q�t|jd|d�nXdS(
s�Insert(table, datadict) - Insert a new row into the table
using the keys+values from rowdict as the column values.
RDs
unknown tablesunknown column: %rRBiiiN(ii(R9R>RR%RRjR�tkeystcountRWRet_bsdTableDB__new_rowidtitemsRGR)RiR�Rbtexc_infoRhRLR-RcR�( R R$trowdictRBR�R(tdataitemR�tinfo((s&/usr/lib64/python2.7/bsddb/dbtables.pytInsert�s. )

 
c Cs�yA|j|g|�}|j�}x|j�D] }d}y�x�|D]�}|jj�}yJ|jjt|||�d|�} |jjt|||�d|�Wntj k
r�d} nX||| �} | dk r|jj
t|||�| d|�n|j �d}qGWWq1|r5|j �n�q1Xq1WWnEtj
k
r�}
tjdkrut|
d�q�t|
jd�nXdS(sModify(table, conditions={}, mappings={}) - Modify items in rows matching 'conditions' using mapping functions in 'mappings'

* table - the table name
* conditions - a dictionary keyed on column names containing
a condition callable expecting the data string as an
argument and returning a boolean.
* mappings - a dictionary keyed on column names containing a
condition callable expecting the data string as an argument and
returning the new string for that column.
RBiiiN(ii(t_bsdTableDB__SelectR�R9RWReRRJR)RLR{RGRiRhR�RbRcRR�( R R$t
conditionstmappingstmatching_rowidsR�R(RBR�R�R�((s&/usr/lib64/python2.7/bsddb/dbtables.pytModify s@  
    
  

c Csiy|j|g|�}|j|}x�|j�D]�}d}y�|jj�}xK|D]C}y&|jjt|||�d|�WqWtj k
r�qWXqWWy#|jjt
||�d|�Wntj k
r�nX|j �d}Wq2tj k
r}|r|j
�n�q2Xq2WWnEtj k
rd}tjdkrQt|d�qet|jd�nXdS(sDelete(table, conditions) - Delete items matching the given
conditions from the table.

* conditions - a dictionary keyed on column names containing
condition functions expecting the data string as an
argument and returning a boolean.
RBiiiN(ii(R�RjR�R9RWReRRLR)R{R-RiR�RhRbRcRR�( R R$R�R�R�R(RBR�R�((s&/usr/lib64/python2.7/bsddb/dbtables.pytDeleteBs6 

 #


cCs�yT||jkr"|j|�n|dkr>|j|}n|j|||�}WnEtjk
r�}tjdkr�t|d�q�t|j d�nX|j
�S(s�Select(table, columns, conditions) - retrieve specific row data
Returns a list of row column->value mapping dictionaries.

* columns - a list of which column data to return. If
columns is None, all columns will be returned.
* conditions - a dictionary keyed on column names
containing callable conditions expecting the data string as an
argument and returning a boolean.
iiiN(ii( RjR�R9R�RR�RbRcRR�tvalues(R R$R�R�R�R�((s&/usr/lib64/python2.7/bsddb/dbtables.pytSelectos
 cCs�||jkr|j|�n|dkr;|j|}nxA||j�D]/}|j|j|�sLtd|f�qLqLWi}i}d�}tjd kr�|j �}|j
|�nvg}xm|j �D]_} xVt |�D];\}
} || | �} | dkr�|j |
| �Pq�q�W|j
| �q�W|jj�}
d}xH|D]@\}}|d}t||�}||kr�d}nd}y�|
j|�\}}x�|t|� |krW|t }||krB| s�||�r||kri||<n|r?||||<q?qB||kr5||=n|||<n|
j�\}}q�WWqQtjk
r�}|jdtjkrQ�qQqQqQXqQW|
j�~t|�dkr�x�|j �D]�\}}x�|D]�}||kr�q�ny&|jjt|||��||<Wq�tjk
r{}tjd
krR|dtjkrn�qnn|jdtjkrn�nd||<q�Xq�Wq�Wn|S( s�__Select() - Used to implement Select and Delete (above)
Returns a dictionary keyed on rowids containing dicts
holding the row data for columns listed in the columns param
that match the given conditions.
* conditions is a dictionary keyed on column names
containing callable conditions expecting the data string as an
argument and returning a boolean.
sunknown column: %rcSs|d}|d}t|�t|�kr�d�}t|t�rrt|t�rr|t|j�t|j��St|t�r�t|t�r�|t|j�t|j��SdSt|t�r�dSt|t�r�dSt|t�r�dSt|t�r�dSdS(NicSs$||krdS||kr dSdS(Nii����i((tatb((s&/usr/lib64/python2.7/bsddb/dbtables.pytcmp�s
  ii����(ttypeRRRRRRR
(tatupletbtupleR�R�R�((s&/usr/lib64/python2.7/bsddb/dbtables.pytcmp_conditions�s$

 iiii����iN(ii(ii(RjR�R9t tablecolumnsR�R�RRbRcR�tsortt enumeratetinsertR�RRCR*R7RR�R=R�R�t DB_NOTFOUNDR6RJR)(R R$R�R�R�R�trejected_rowidsR�t
conditionlisttitjtktrR|t
column_numt conditiont searchkeytsavethiscolumndataRER}R(R�trowdata((s&/usr/lib64/python2.7/bsddb/dbtables.pyt__Select�s�
    
     
 

 

   c Cs8d}y�|jj�}|jjt|�d|�|jj|�}t|�}xYy|j|�\}}Wntj k
r�PnX|t
|� |kr�Pn|j�qUWt |�}xYy|j|�\}}Wntj k
r�PnX|t
|� |krPn|j�q�W|j �t
jt|jd|jj�td|dtj��}y|j|�Wntk
r}nX|jjtd|�t|jd|jj�tt
j|d�d|�|j�d}||jkr�|j|=nWn<tjk
r3}|r|j�nt|jd��nXdS(s(Remove an entire table from the databaseRBRKRFRIiN(R9RWReRRLR%RCR+R7R{RR.R6RfR�R>RJR0R�tremoveR�RGRgRiRjR�RhRR�( R R$RBR|t table_keyRER}R�R�((s&/usr/lib64/python2.7/bsddb/dbtables.pytDropsT  



(RRRRtR6RwRxR~R�R�R�R�R�R�R�R�R�R�R�R�(((s&/usr/lib64/python2.7/bsddb/dbtables.pyR2�s& r      0   :  ,6 -  �(ii((()t_cvsidRRbR�R�R�RcRftcPickletwarningstcatch_warningstwt __enter__tfilterwarningstDeprecationWarningt__exit__tbsddb3Rt ImportErrortbsddbt
StandardErrorRRRR
RRRR0R#R%R&R,R�R)R*R+R-R.R1R2(((s&/usr/lib64/python2.7/bsddb/dbtables.pyt<module>sV