U
    c9                     @   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 |sd S ttdd }dt_ddlm}m}m}m} t	 }i }	d|	d< ||	d< ||	d< ||	d< ||	d	< ||	d
< |
dd}zt|||	 W nb tk
r }
 zDt|
tjjr|
dd l}| }td|  d|
 d| dd W 5 d }
~
X Y nX |t_|	d S )Ndisable_raise_lazyloadTr   )datetimedate	timedeltatimezoneresultselfr   r   r   r   zreturn z	result = u<   Произошла ошибка при выполнении : 
abort)configBZPYTHON_ENABLEDgetattrgr   r   r   r   r   globalsreplaceexec	Exception
isinstancecmfZ
base_errorZCmfAbortError	traceback
format_exc	cmf_alert)r   codeobjprev_disable_raise_lazyloadr   r   r   r   Zglobler)   Ztracer   r   r   
_exec_code   s4    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loadsr3   boolr   )r   Zbql_strr-   ZmodelZ
filter_bqlr   r   r   _trans_ok_bql4   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 )NFr2   r3   r   wz_value_objINr4   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   r3   r"   Zcurrent_personwz_conditionr9   r'   Z	CmfPersonZCmfPersonGroupZrg_member_ofZCmfRoleZpersonZ
CmfOrgUnitsetZ
tree_nodesloadpopaddr+   r5   )
r   r   r-   resZ
search_objZ	value_objZnodesZchecked_nodesZnodeZ_noder   r   r   _trans_filter_ok_current_user@   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 )Nr;       r   !=><>=<=r:   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=)r!   wz_field_namevaluer@   r>   	partitionwz_value_textr7   recompileerrorr+   searchZwz_start_valueZwz_end_value)r   
trans_metar-   obj_valclean_wz_conditionZvalidator_valZregexpr0   r   r   r   _trans_field_compare_textx   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   r;   rE   r   rG   rH   rI   rJ   rK   r:   rP   r   uE    не поддерживается для цифровых полейrL   rM   rN   rO   rQ   rR   rS   rT   rU   zCDEV: FATAL _trans_field_compare_numeric unknown clean_wz_condition=)
r!   rV   rW   r   rY   
ValueErrorr+   r>   rX   r7   )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   даTrb   Q   : значние должно быть Boolean (0, 1, true, false, да, нет) r   r;   rE   r   rG   rH   rP   r   u<    не поддерживается для Boolean полейrI   rJ   rK   r:   rL   rM   rN   rO   rQ   rR   rS   rT   rU   zCDEV: FATAL _trans_field_compare_boolean unknown clean_wz_condition=)	r!   rV   rW   r7   rY   lowerr+   r>   rX   )r   r^   r-   r_   Zobj_val_boolre   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   r3   rW   .0or   r   r   
<listcomp>  s     z5CmfTrans._trans_field_compare_m2m.<locals>.<listcomp>c                 S   s   g | ]}|j jqS r   ro   rp   r   r   r   rs     s     r;   rE   r   rG   rH   rI   rJ   rK   r:   rL   rM   rP   r   u8    не поддерживается для m2m полейTr   rN   rO   rQ   rR   rS   rT   rU   z?DEV: FATAL _trans_field_compare_m2m unknown clean_wz_condition=)
r!   rV   rW   r@   r9   r?   r>   rX   r+   r7   )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   ro   rp   r   r   r   rs   H  s     z4CmfTrans._trans_field_compare_fk.<locals>.<listcomp>c                      s(   t dkr$td  d dd d S )N   rP   :    должен быть только один объект Tr   )lenr+   r   r^   rt   r   r   Z__check_one_itemJ  s
    z:CmfTrans._trans_field_compare_fk.<locals>.__check_one_itemr;   rE   r   r   rG   rH   rP   r   u7    не поддерживается для fk полейTr   rI   rJ   rK   r:   rL   rM   rN   rO   rQ   rR   rS   rT   rU   z#DEV: FATAL _trans_field_compare_fk z unknown clean_wz_condition=)r!   rV   rW   r@   r9   r?   r>   rX   r+   r3   r7   )r   r^   r-   r_   ru   Z_CmfTrans__check_one_itemr`   r   rz   r   _trans_field_compare_fkE  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: r;   Tr   uH   DEV: FATAL _trans_field_compare Неизвестный тип поля: )r5   cmf_model_namer>   r!   rV   rW   r'   r(   fields
CmfM2MBaserv   
CmfRelBaser{   CmfStrra   CmfIntrf   
CmfNumericCmfDateTimer+   typeCmfDateCmfBoolrn   )r   r^   r-   fieldr   r   r   _trans_field_comparex  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   )r8   bqlrW   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    r1   	eval_coderW   get_bzpython_jscache_timelifer"   jscache_timelifemin)r   r   r-   rC   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 )Nr   Tordernor   r9   
transitionZorderbyr}   r;   rE   Zcurrent_userr   Zalways_falseprev_statusr   evalZunion_orZ	union_andz5DEV: FATAL trans_filter_ok unknown filter.logic_type=r   )r!   r"   r   r<   r=   list
logic_typerW   rX   rD   r   r   _trans_prev_statusr   r   r   r   r+   )r   r-   r.   rC   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   s  |j  }|sdS |j j}|dd}|dd}|dd}d}|jjrRd}d}	|rx|jj|krjd}	|rt|	 S |	S |D ]}
ddd|
jj d	 g}|sddd
|
jj d	 g}|r|st	j
jdd|g|gd}|dkrd}	 qq|t	j
jdd|g|gds|d}	 qq||r|	 S |	S )NTinclude_current_statusFreverse_rulemost_recent_status_onlyZ
audit_dataz
SIMILAR TOz%{"status":{[^}]*"z"%z%{"status":{[^}]*old":"parentr   r4   rw   )r9   r@   wz_prev_status_optionsrW   r   statusZ
is_changedoldr3   r<   ZCmfAuditcount)r   r^   r-   Zstatus_listr   r   r   r   Z
audit_donerC   r   Zstatus_filterr   r   r   r   r     sL    
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-Валидатором     у объекта )	r8   r   rW   error_messager+   r   r@   namer,   )r   r   r-   rC   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    r1   r   rW   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   r;   rE   r   r   Ztrans_form_fieldr   r   z;DEV: FATAL trans_validator_ok unknown validator.logic_type=r   u7   Ошибка выполнения Валидатора u    для перехода r   r   )r!   r"   r   r<   ZCmfTransValidr   r   rW   rX   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 )NFr;   rE   clearT:=)ZaddItemrB   )ZdelItemdeluX   DEV: FATAL _trans_action_field_m2m неподдерживаемое действие в  wz_operate=r   )
wz_operaterW   rX   setattrrV   r9   r@   r!   appendremover+   r,   )r   actionr-   has_changesclean_wz_operatere   r   rt   r   r   r   _trans_action_field_m2mB  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 )Nr;   rE   r   Tr   rw   rb   rx   r   r   rB   Fr   uW   DEV: FATAL _trans_action_field_fk неподдерживаемое действие в r   )r   rW   rX   r   rV   r9   r@   ry   r+   r!   Zis_not_nullr,   )r   r   r-   r   re   r   rt   r   r   r   _trans_action_field_fk_  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 )Nr;   rE   r   Tr   rB   Fr   rF   uY   DEV: FATAL _trans_action_field_text неподдерживаемое действие в r   r   )
r   rW   rX   r   rV   rY   r!   r$   r+   r,   )r   r   r-   r   r   re   new_valr   r   r   _trans_action_field_text  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 )Nr;   rE   r   r   Trb   rc   r   r   )ZincrB   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   rW   rX   r!   rV   r   r   rY   rd   r+   sortedr   r   r,   )	r   r   r-   choice_limitr   Z
prev_valuere   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 )Nr;   rE   Frg   ri   Trb   rl   r   r   r   u\   DEV: FATAL _trans_action_field_boolean неподдерживаемое действие в r   )	r   rW   rX   rY   rm   r+   r   rV   r,   )r   r   r-   r   re   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: r;   Tr   u3   DEV: FATAL Неизвестный тип поля: )r5   r|   r   r!   rV   rW   r'   r(   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_webhook4  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   )r!   r"   r   r<   ZCmfTransActionr   r   r   r   r   r+   )r   r-   r.   r   r   r   r   r   trans_run_actions9  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,  )rZ   r]   )r   r   r   r   r   r   M  s    	z&CmfTrans.get_bzpython_jscache_timelife)NNN)(__name__
__module____qualname__classmethodr   r1   r8   rD   ra   rf   rn   rv   r{   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#6!%96r   )ZastrZ   Zdecimalr   Zcmf.includeZcommon.fieldsr   r   r   r   r   r   <module>   s
   