U
    c                     @   sF   d dl Z d dlZd dlmZ d dlT d dlmZ G dd dejZdS )    N)Decimal)*)	cmf_transc                       s0  e Zd ZedE fdd	Zdd Zdd Zdd	 Zd
d Zdd Z	dd Z
dd Zdd Zdd Zdd Zdd Zdd Zdd Zdd Zd d! Zd"d# Zd$d% Zd&d' Zd(d) Zd*d+ Zd,d- Zd.d/ Zd0d1 Zd2d3 Zd4d5 Zg fd6d7Zd8d9 Zd:d; Z d<d= Z!d>d? Z"d@dA Z#e$e%dBdCdDZ&  Z'S )FCmfTransNc                    sR   |dkr6|sg }d }|r$| dd }|r6|dd|gg}t j|f|||d|S )N)Zstatus_fromZ	status_toworkflow_idZworkflow=)filtermodels_listobject_fields)getsuperfield_options_list)clsZrelation_field_namer   r	   r
   kwargsr   	__class__ ./common/models/cmf_trans.pyr   	   s    zCmfTrans.field_options_listc              
   C   s   t js
d S ddlm}m}m}m} t }i }d|d< ||d< ||d< ||d< ||d< ||d	< |d
d}zt||| W nP t	k
r }	 z2dd l
}
|
 }td|  d|	 d| dd W 5 d }	~	X Y nX |d S )Nr   )datetimedate	timedeltatimezoneTresultselfr   r   r   r   zreturn z	result = u<   Произошла ошибка при выполнении : 
abort)configIS_BOX_VERSIONr   r   r   r   globalsreplaceexec	Exception	traceback
format_exc	cmf_alert)r   codeobjr   r   r   r   gler$   Ztracer   r   r   
_exec_code   s&    0zCmfTrans._exec_codec                 C   s8   t |j}t|}ddd|jg|g}t|j|dS )NANDidr   r   )ZcmfutilZget_model_by_name
class_nameZjsonloadsr.   boolr   )r   Zbql_strr(   ZmodelZ
filter_bqlr   r   r   _trans_ok_bql,   s    
zCmfTrans._trans_ok_bqlc           
      C   s  d}t jjddd|jgddtjjgggd}|r4d}|jd	ksD|jsH|S | S d S ] }t|t j	rptj|k}nt|t j
r|tjjk}nt|t jrtj|jk}nt|t jrPt|j }t }|rj| }|| t|t jrtj|jk}|rLqjqt|t jr:|j D ]}	|	|kr||	 qqtd
| dd qntd| d|j dd |rR qvqR|jd	ks|js|S | S d S )NFr-   r.   r   wz_value_objINr/   T)z1 =z5 >=z6 <=z7 INz9 LIKEz	11 REGEXPz:DEV: FATAL _trans_filter_ok_current_user Unsupported obj: r   z@DEV: FATAL _trans_filter_ok_current_user Unsopported obj_class:  )modelsCmfTransFilterr   r.   r)   Zcurrent_personwz_conditionr4   
isinstanceZ	CmfPersonZCmfPersonGroupZrg_member_ofZCmfRoleZpersonZ
CmfOrgUnitsetZ
tree_nodesloadpopaddr&   r0   )
r   r   r(   resZ
search_objZ	value_objZnodesZchecked_nodesZnodeZ_noder   r   r   _trans_filter_ok_current_user8   sX    


z&CmfTrans._trans_filter_ok_current_userc              
   C   sX  t ||jj j}|jjdd }|jj}|d kr:d}|dkrX|sPt| S ||kS |dkrt|slt|S ||kS |dkr||kS |dkr||k S |dkr||kS |d	kr||kS |d
kr||kS |dkr||kS |dk r||kS |dk r||kS |dkrdzt	|}W nD tj
k
rT } z"td| d| d| dd W 5 d }~X Y nX t||S |dkrzt	|}W nD tj
k
r } z"td| d| d| dd W 5 d }~X Y nX t|| S |dkrt| S |dkrt|S |dkr||jjko||jjkS |dkrB||jjko>||jjk S td| dd d S )Nr6       r   !=><>=<=r5   NOT INLIKENOT LIKEREGEXP   Ошибка в условии uC   : некорректное регулярное выражение r   Tr   
NOT REGEXPIS_NULLNOT_NULLBETWEENNOT_BETWEENz@DEV: FATAL _trans_field_compare_text unknown clean_wz_condition=)getattrwz_field_namevaluer<   r9   	partitionwz_value_textr2   recompileerrorr&   searchZwz_start_valueZwz_end_value)r   
trans_metar(   obj_valclean_wz_conditionZvalidator_valZregexpr+   r   r   r   _trans_field_compare_textp   sd    



0
0




z"CmfTrans._trans_field_compare_textc                 C   s"  t ||jjj}zt|jj}W n0 tk
rP   td| d|jj dd Y nX |jjdd }|dkrt||kS |dkr||kS |d	kr||kS |d
kr||k S |dkr||kS |dkr||kS |dk rtd| d| ddd n2|dkrtd| d| ddd n
|dkr:td| d| ddd n|dkr`td| d| ddd n|dkrtd| d| ddd n|dkrtd| d| ddd nr|dkrt	| S |dkrt	|S |dkr||ko||kS |dkr||ko||k S td| dd d S )N!   Ошибка в Действии 4   : значние должно быть числом Tr   r6   rA   r   rC   rD   rE   rF   rG   r5   rL   r   uE    не поддерживается для цифровых полейrH   rI   rJ   rK   rM   rN   rO   rP   rQ   zCDEV: FATAL _trans_field_compare_numeric unknown clean_wz_condition=)
rR   rS   rT   r   rV   
ValueErrorr&   r9   rU   r2   )r   r[   r(   r\   valr]   r   r   r   _trans_field_compare_numeric   sT    










z%CmfTrans._trans_field_compare_numericc                 C   s  t ||jjj}t|}|jjs&d}nH|jj dkr<d}n2|jj dkrRd}ntd| d|jj dd |jjdd	 }|d
kr||kS |dkr||kS |dkrtd| d| ddd n|dkrtd| d| ddd n|dkrtd| d| ddd n|dkr<td| d| ddd nj|dkrdtd| d| ddd nB|dkrtd| d| ddd n|dkrtd| d| ddd n|dkrtd| d| ddd n|dkrtd| d| ddd n|dkr$td| d| ddd n|dkr6|d kS |dkrH|d k	S |dkrntd| d| ddd n8|dkrtd| d| ddd ntd| dd d S )NF0Zfalseu   нет1trueu   даTr_   Q   : значние должно быть Boolean (0, 1, true, false, да, нет) r   r6   rA   r   rC   rD   rL   r   u<    не поддерживается для Boolean полейrE   rF   rG   r5   rH   rI   rJ   rK   rM   rN   rO   rP   rQ   zCDEV: FATAL _trans_field_compare_boolean unknown clean_wz_condition=)	rR   rS   rT   r2   rV   lowerr&   r9   rU   )r   r[   r(   r\   Zobj_val_boolrb   r]   r   r   r   _trans_field_compare_boolean   s\    











z%CmfTrans._trans_field_compare_booleanc                 C   s  t ||jj j}|j }tdd |D }tdd |D }|jjdd }|dkrd||kS |dkrt||kS |dkr||kS |d	kr||k S |d
kr||kS |dkr||kS |dkr||kS |dkr||kS |dk rtd| d| ddd n|dkr td| d| ddd n|dkrFtd| d| ddd n|dkrltd| d| ddd n|dkrt	| S |dkrt	|S |dkrtd| d| ddd n8|dkrtd| d| ddd ntd| dd d S )Nc                 S   s   g | ]}|j jqS r   r.   rT   .0or   r   r   
<listcomp>  s     z5CmfTrans._trans_field_compare_m2m.<locals>.<listcomp>c                 S   s   g | ]}|j jqS r   rl   rm   r   r   r   rp     s     r6   rA   r   rC   rD   rE   rF   rG   r5   rH   rI   rL   r   u8    не поддерживается для m2m полейTr   rJ   rK   rM   rN   rO   rP   rQ   z?DEV: FATAL _trans_field_compare_m2m unknown clean_wz_condition=)
rR   rS   rT   r<   r4   r;   r9   rU   r&   r2   )r   r[   r(   r\   val_listZobj_val_id_setval_list_id_setr]   r   r   r   _trans_field_compare_m2m  sL    









z!CmfTrans._trans_field_compare_m2mc                    sr  t | jj j} j tdd D } fdd} jjdd }|dkrj|  |d kS |d	kr|  |d kS |d
krtd  d| ddd n|dkrtd  d| ddd n|dkrtd  d| ddd nx|dkrtd  d| ddd nP|dkr4|j	j|kS |dkrJ|j	j|kS |dkrrtd  d| ddd  n|dkrtd  d| ddd n|dkrtd  d| ddd n|dkrtd  d| ddd n|dkrt
| S |dkr
t
|S |dkr0td  d| ddd n>|dkrVtd  d| ddd ntd  d| dd d S )Nc                 S   s   g | ]}|j jqS r   rl   rm   r   r   r   rp   @  s     z4CmfTrans._trans_field_compare_fk.<locals>.<listcomp>c                      s(   t dkr$td  d dd d S )N   rL   :    должен быть только один объект Tr   )lenr&   r   r[   rq   r   r   Z__check_one_itemB  s
    z:CmfTrans._trans_field_compare_fk.<locals>.__check_one_itemr6   rA   r   r   rC   rD   rL   r   u7    не поддерживается для fk полейTr   rE   rF   rG   r5   rH   rI   rJ   rK   rM   rN   rO   rP   rQ   z#DEV: FATAL _trans_field_compare_fk z unknown clean_wz_condition=)rR   rS   rT   r<   r4   r;   r9   rU   r&   r.   r2   )r   r[   r(   r\   rr   Z_CmfTrans__check_one_itemr]   r   rw   r   _trans_field_compare_fk=  sP    












z CmfTrans._trans_field_compare_fkc                 C   s@  |j |jkrdS |jsdS t||jj}t|tjj	rB| 
||S t|tjjr\| ||S t|tjjrv| ||S t|tjjr| ||S t|tjjr| ||S t|tjjrtd| dt| dd nJt|tjjrtd| dt| dd nt|tjjr | ||S td| dt| dd d S )NFz0DEV: FATAL _trans_field_compare NotImplemented: r6   Tr   uH   DEV: FATAL _trans_field_compare Неизвестный тип поля: )r0   cmf_model_namer9   rR   rS   rT   r:   cmffields
CmfM2MBasers   
CmfRelBaserx   CmfStrr^   CmfIntrc   
CmfNumericCmfDateTimer&   typeCmfDateCmfBoolrk   )r   r[   r(   fieldr   r   r   _trans_field_comparep  s,    zCmfTrans._trans_field_comparec                 C   s   |  ||S Nr   r   r   r(   r   r   r   _trans_filter_ok_field  s    zCmfTrans._trans_filter_ok_fieldc                 C   s   dS NFr   r   r   r   r   _trans_filter_ok_always_false  s    z&CmfTrans._trans_filter_ok_always_falsec                 C   s   |  |jj|S r   )r3   bqlrT   r   r   r   r   _trans_filter_ok_bql  s    zCmfTrans._trans_filter_ok_bqlc                 C   sL   t jrH| |jj|}| |jj}|rDtjs6|t_nttj|t_|S dS r   )	r   r   r,   	eval_coderT   get_bzpython_jscache_timelifer)   jscache_timelifemin)r   r   r(   r?   r   r   r   r   _trans_filter_ok_eval  s    zCmfTrans._trans_filter_ok_evalc                 C   s   t ddd d S )Nz,DEV: Not supported _trans_filter_ok_union_orTr   r&   r   r   r   r   _trans_filter_ok_union_or  s    z"CmfTrans._trans_filter_ok_union_orc                 C   s   t ddd d S )Nz-DEV: Not supported _trans_filter_ok_union_andTr   r   r   r   r   r   _trans_filter_ok_union_and  s    z#CmfTrans._trans_filter_ok_union_andc                 C   s(  t tdd }dt_d}tjj| dgddgdD ]}|js:q.|jjdd }|d	krb| 	||}n|d
krx| 
||}n|dkr| ||}n|dkr| ||}nl|dkr| ||}nV|dkr| ||}n@|dkr| ||}n*|dkr| ||}ntd|j dd |s.|  S q.|t_|S )Ndisable_raise_lazyloadTordernor   r4   
transitionZorderbyr{   r6   rA   Zcurrent_userr   Zalways_falseprev_statusr   evalZunion_orZ	union_andz5DEV: FATAL trans_filter_ok unknown filter.logic_type=r   )rR   r)   r   r7   r8   list
logic_typerT   rU   r@   r   r   _trans_prev_statusr   r   r   r   r&   )r   r(   prev_disable_raise_lazyloadr?   r   clean_logic_typer   r   r   trans_filter_ok  s8    
zCmfTrans.trans_filter_okc                 C   s   |  ||S r   r   r   	validatorr(   r   r   r   _trans_validator_field  s    zCmfTrans._trans_validator_fieldc                 C   sV   |j  }|sdS d}|D ]6}tjjdd|gddd|jj d ggdsd	} qRq|S )
NTparentr   Z
audit_dataz
SIMILAR TOz%{"status":{[^}]*"z"%r/   F)r4   r<   r7   ZCmfAuditr   r.   rT   )r   r[   r(   Zstatus_listr?   statusr   r   r   r     s    
zCmfTrans._trans_prev_statusc                 C   s   t ddd dS )Nz4DEV: Not supported _trans_validator_trans_form_fieldTr   r   r   r   r   r   !_trans_validator_trans_form_field  s    z*CmfTrans._trans_validator_trans_form_fieldc                 C   s\   |  |jj|}|sX|jr(t|jdd |j  td|jj d|j d|j dd d S )NTr   u   Переход "u.   " запрещен BQL-Валидатором     у объекта )	r3   r   rT   error_messager&   r   r<   namer'   )r   r   r(   r?   r   r   r   _trans_validator_bql  s    
zCmfTrans._trans_validator_bqlc                 C   s   t jr| |jj|S dS r   r   r   r,   r   rT   r   r   r   r   _trans_validator_eval  s    zCmfTrans._trans_validator_evalc              	   C   s6  t tdd }dt_d}tjj| dgdgdD ]}|js8q,|jjdd }|dkr`| 	||}nl|d	krv| 
||}nV|d
kr| ||}n@|dkr| ||}n*|dkr| ||}ntd|j dd |s, qq,|t_|rd S |jrt|jdd |j  td|j d|jj d|jj d|j dd d S )Nr   Tr   r   r   r6   rA   r   r   Ztrans_form_fieldr   r   z;DEV: FATAL trans_validator_ok unknown validator.logic_type=r   u7   Ошибка выполнения Валидатора u    для перехода r   r   )rR   r)   r   r7   ZCmfTransValidr   r   rT   rU   r   r   r   r   r   r&   r   r   r<   r'   r   )r   r(   r   Zvalidr   r   r   r   r   trans_validator_ok  s6    
zCmfTrans.trans_validator_okc                 C   s  d}|j jdd }|dkr2t||jjg  dS |dkrX|j }t||jj| dS |dkrt||jj }|j }|D ]}||kr|| d}q|S |dkrt||jj }|j }|D ]}||kr|	| d}q|S t
d	|j d
| dd d S )NFr6   rA   clearT:=)ZaddItemr>   )ZdelItemdeluX   DEV: FATAL _trans_action_field_m2m неподдерживаемое действие в  wz_operate=r   )
wz_operaterT   rU   setattrrS   r4   r<   rR   appendremover&   r'   )r   actionr(   has_changesclean_wz_operaterb   r   rq   r   r   r   _trans_action_field_m2m  s4    




z CmfTrans._trans_action_field_m2mc                 C   s\  |j jdd }|dkr.t||jjd  dS |dkr||j }t|dkrdtd| d| dd	 t||jj|d
  dS |dkrt	||jj }|j
rdS |j }t|dkrtd| d| dd	 t||jj|d
  dS |dkr>t	||jj }|j }|D ](}||jkrt||jjd   dS qdS td|j d| dd	 d S )Nr6   rA   r   Tr   rt   r_   ru   r   r   r>   Fr   uW   DEV: FATAL _trans_action_field_fk неподдерживаемое действие в r   )r   rT   rU   r   rS   r4   r<   rv   r&   rR   Zis_not_nullr'   )r   r   r(   r   rb   r   rq   r   r   r   _trans_action_field_fk1  sD    




zCmfTrans._trans_action_field_fkc                 C   s  |j jdd }|dkr.t||jjd  dS |dkrLt||jj|j dS |dkrt||jj}|jj}|srdS |jd | }t||jj| dS |dkrt||jj}|jj}|sdS ||jkr|j|d	}t||jj| dS dS td
|j	 d| dd d S )Nr6   rA   r   Tr   r>   Fr   rB   uY   DEV: FATAL _trans_action_field_text неподдерживаемое действие в r   r   )
r   rT   rU   r   rS   rV   rR   r!   r&   r'   )r   r   r(   r   r   rb   new_valr   r   r   _trans_action_field_textV  s4    
z!CmfTrans._trans_action_field_textc           	         s  |j jdd }t||jjj}|s*d}|dkrFt||jjd  dS zt|jj}W n0 tk
r   t	d| d|jj dd Y nX |d	krt||jj| dS |d
kr0||  |r |kr }t
|}tt fdd|}|r|d  n|d  t	d|jj d| d   t||jj  dS |dkr||  |r |kr }t
|}tt fdd|}|r|d  n|d  t	d|jj d| d   t||jj  dS t	d|j d| dd d S )Nr6   rA   r   r   Tr_   r`   r   r   )Zincr>   c                    s   |  kS r   r   xr   r   r   <lambda>      z6CmfTrans._trans_action_field_numeric.<locals>.<lambda>u5   Действие пыталось выставить uC    в недопустимое значение для выбора: u<   . Выставили ближайшее доступное: )Zdecr   c                    s   |  kS r   r   r   r   r   r   r     r   u\   DEV: FATAL _trans_action_field_numeric неподдерживаемое действие в r   )r   rT   rU   rR   rS   r   r   rV   ra   r&   sortedr   r   r'   )	r   r   r(   choice_limitr   Z
prev_valuerb   Zbad_valZnew_val_tmpr   r   r   _trans_action_field_numeric  sT    



z$CmfTrans._trans_action_field_numericc                 C   s   |j jdd }|jjs d}nH|jj dkr6d}n2|jj dkrLd}ntd| d|jj dd	 |d
krt||jjd  dS |dkrt||jj| dS td|j d| dd	 d S )Nr6   rA   Frd   rf   Tr_   ri   r   r   r   u\   DEV: FATAL _trans_action_field_boolean неподдерживаемое действие в r   )	r   rT   rU   rV   rj   r&   r   rS   r'   )r   r   r(   r   rb   r   r   r   _trans_action_field_boolean  s$    z$CmfTrans._trans_action_field_booleanc                 C   sf  |j |jkrdS |jsdS t||jj}t|tjj	rB| 
||S t|tjjr\| ||S t|tjjrv| ||S t|tjjr| j|||j dS t|tjjr| ||S t|tjjr| ||S t|tjj rtd| dt| dd nJt|tjjr*td| dt| dd nt|tjjrF| ||S td| dt| dd d S )NF)r   zDEV: FATAL NotImplemented: r6   Tr   u3   DEV: FATAL Неизвестный тип поля: )r0   ry   r   rR   rS   rT   r:   rz   r{   r|   r   r}   r   r~   r   ZCmfChoiceIntr   choiceskeysr   r   r   r&   r   r   r   r   )r   r   r(   r   r   r   r   _trans_action_field  s0    zCmfTrans._trans_action_fieldc                 C   s   t jr| |jj| dS dS )NTFr   )r   r   r(   r   r   r   _trans_action_eval  s    zCmfTrans._trans_action_evalc                 C   s   d}t ddd |S )NFz(DEV: Not supported _trans_action_webhookTr   r   )r   r   r(   r   r   r   r   _trans_action_webhook  s    zCmfTrans._trans_action_webhookc                 C   s   t tdd }dt_d}tjj| dgdgdD ]v}|jdkrL|| ||O }q,|jdkrh|| ||O }q,|jd	kr|| 	||O }q,|jsq,q,t
d
|j dd q,|t_|S )Nr   TFr   r   r   r   r   Zwebhookz7DEV: FATAL trans_run_actions unknown action.logic_type=r   )rR   r)   r   r7   ZCmfTransActionr   r   r   r   r   r&   )r   r(   r   r   r   r   r   r   trans_run_actions  s    


zCmfTrans.trans_run_actions)bzpythonc                 C   s(   d}t d| rd}t d| r$d}|S )u   
        Рассчитываем допустимое время жизни кеша, путем анализа кода bzPython
        Nz\bdate\(ip  z\bnow\(i,  )rW   rZ   )r   r   r   r   r   r     s    	z&CmfTrans.get_bzpython_jscache_timelife)NNN)(__name__
__module____qualname__classmethodr   r,   r3   r@   r^   rc   rk   rs   rx   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   staticmethodstrr   __classcell__r   r   r   r   r      sF   8?.4,3#!%96r   )ZastrW   Zdecimalr   Zcmf.includeZcommon.fieldsr   r   r   r   r   r   <module>   s
   