B
    f                 @   s   d dl Z d dlZd dlmZ d dlZd dlZd dlmZ d dlmZ d dl	m
Z
 d dlmZ d dlmZ d dlT d dlZd	ZG d
d dejjjZddlmZ dS )    N)copy)fields)person)desc)func)relativedelta)*zLST-filter_is_nonec                   s
  e Zd ZdZdddddddd	d
ddddddddddddgZdgZdZejj	j
jddddg Zejj	j
jd ZG dd dejj	j
jZG dd dejjZejjejjd d!dd"Zejjejjd#dd!dd$Zejjejjd%dd!dd$Zejjejjd&dd!dd$Zejjejjd'dd!dd$Zejjejjd(d)dd*Zejjejjd+dd,Zejjejjd-dddd.d/Zejjejjd0d1gdd2ZG d3d dejjZ ejjejj!d4d5d6d7d1d8gddd9d:d;d<gd=Z"ejjejj!d>d5d6d7d1d8gddd9d:d;d<gd=Z#ejjejj$d?d!d@Z%ejjejj!ddAdBdCdBd!dDdEgdFZ&ejjejj'dGdHgddIZ(ejjejjdJd1gdd2Z)ejjejj*dKdLdMdNdOdPdQdRdSd!dTZ+ejjejj,dUdVdWdXdYdZd[d\Z-ejjejjd]dd,Z.ejjejjd^dd,Z/ejjejjd_d`Z0ejjejjdad`Z1ejjejjdbd`Z2ejjejj,dcdddedfdgdhdidjd\Z3ejjejjdkddlZ4ejjejj$d!dmdndd!ddoZ5ejjejjdpdd5dqdrdsdtdugdvZ6ejjejj$dmdwdxddygd!dzZ7ejjejjd{d|dd!d}Z8ejjejj$d~d!d!dZ9ejjejj,dddddddd!dddZ:ejjejjdddCd!ddZ;ejej<dd!dddZ=G dd dejj$Z>ejjejj?ddddZ@ fddZAeBdd ZCd{ddZDdd ZEdd ZFdd ZGdd ZHdd ZIdd ZJdd ZKdd ZLdd ZMdd ZNdd ZOdd ZPdd ZQdd ZRdd ZSdd ZTdd ZUdd ZVd| fdd	ZWeXd}ddZYeXd~ fddĄ	ZZeXd fddƄ	Z[eXd fddȄ	Z\eXd fddʄ	Z]eBdd̄ Z^e^j_dd̄ Z^d!dΜddЄZ`dd҄ ZaddԄ Zbddք Zcdd؄ Zdddڄ Ze fdd܄Zf fddބZgdd Zhdd Zidd Zjdd Zkdd Zldd Zm fddZn fddZo fddZp fddZq fddZrdd Zsdd Ztdd ZudddevdddZwdd  Zxdd Zydd Zzdd Z{dd Z|dd	d
 fdd
Z} fddZ~ fddZ fddZ fddZeXdd fdd
ZeXdd fdd
Zdd ZeX fddZd!d!ddeeed fd d!Zejjejj,d!d"d#d!d$d%d&d'd(d)Zejjejj,d!d*d#d!d$d+d,d-d.d/d)Zejjejj,d!d0d#d!d$d+d,d-d.d/d)Zejjejj,d!d1d#d!d$d+d,d-d.d/d)Zdd2d3Zd4d5 Zejjejjd6d7d7d!d8Zd9d: Zd;d< Z fd=d>Zd?d@ Z fdAdBZ fdCdDZdEdF ZddGdHZddIdJZ fdKdLZ fdMdNZd	dOedP fdQdRZ fdSdTZeeedUdVdWZdXdY ZeXdZd[ Z fd\d]ZeXdd^d_ZeXdedadbdcZddde Zedfdg Zdhdi Zeedjdkdldm ZddodpZeXdqdr ZeXddd!d!d!dsdtdudvZeXd fdwdx	Zdydz Z  ZS (  CmfActiveEntityTcodenamestatus	cmf_ownerresponsiblepriority
alarm_datetags	executors
spectators
no_controlwaiting_formarkZtime_estimateplan_start_dateplan_end_dateperiod_intervalperiod_next_datedeadlineparentcompanyz-ordernoarchivedisable_aclmacros_page_tree_gettask_transition_run)CmfAttachmentc                   s   e Zd Z fddZ  ZS )zCmfActiveEntity.logic_typec                sD   t  | | jr@| jr@| jr@| jj  | jjdd | j_d S )N:r   )super
_set_valueinstancevaluer
   logic_prefixload	partition)selfr'   )	__class__ $./common/models/cmf_active_entity.pyr%   <   s
    z%CmfActiveEntity.logic_type._set_value)__name__
__module____qualname__r%   __classcell__r-   r-   )r,   r.   
logic_type;   s   r3   c                   s<   e Zd ZdZdZddgZdZ fddZ fdd	Z  Z	S )
zCmfActiveEntity.statusu   СтатусTworkflow_ididc                s(   t  | | jr$| r| jpd | j_d S )N)r$   r%   r&   status_typecache_status_type)r+   r'   )r,   r-   r.   r%   K   s    z!CmfActiveEntity.status._set_valuec                sB   t |tr6| jr6| jj r6| jjj|dd}|r6|S t |S )NF)r7   raise_error)
isinstancestrr&   workflowr)   get_default_statusr$   cast)r+   r'   r   )r,   r-   r.   r>   P   s
    zCmfActiveEntity.status.cast)
r/   r0   r1   captionnullableoptions_list_params	log_levelr%   r>   r2   r-   r-   )r,   r.   r   D   s   u"   Дата смены статусаF)r?   visibleno_aclu"   Дата начала работы)r?   readonlyrC   rD   u(   Дата окончания работыu(   Дата на подтверждениеu   Дата закрытияu   КонтрагентZ
CmfCompany)r?   modellinkableu   Название)r?   indexu
   Номерu3   Код в реальном мире из жизни)r?   uniquerH   rE   commentu   Постановщик	CmfPerson)r?   modelsrG   c               @   s$   e Zd ZdZdgZdZdgZdZdS )zCmfActiveEntity.responsibleu   ИсполнительrK   T	parent_idN)r/   r0   r1   r?   rL   rG   rA   Zoptions_list_query_allr-   r-   r-   r.   r   |   s
   u   Соисполнители
CmfProjectZ
CmfOrgUnitCmfPersonGroupZCmfRolezCmfProject.executorszCmfOrgUnit.tree_nodeszCmfPersonGroup.rg_memberszCmfRole.person)r?   rL   leftrG   Znested_fieldsu   Наблюдателиu!   Без подтверждения)r?   defaultu   ТэгиZCmfTagmembersactivity_idrM   )rightr?   rF   backrefwidgetrG   rA   u   Вложенияr"   )r?   rL   rU   u   Ждем ответаu   Приоритетu   Минимальныйu   Низкийu   Обычныйu   Высокийu   Критичныйu   Блокирующий)r6   r            0)r?   choicesrQ   r@   u   Оценка12345)r]   r^   r_   r`   ra   )r?   r\   u   Будильникu   Крайний срокu&   Плановая дата начала)r?   u.   Плановая дата завершенияu   Дата повторенияu%   Интервал повторенияu   Ежедневноu   Раз в 2 дняu   Еженедельноu   Ежемесячноu   Ежеквартальноu   Ежегодно)r]   r^   7Z30Z90Z365u   Склонирован из)r?   rE   CmfBoolu   Шаблон)rC   rV   r?   rE   rQ   rH   u!   Родительская нода	CmfFolderZCmfActiveEntityFilterCmfDocumentCmfTaskZCmfComponent)r?   r@   rL   u   Сделаноu!   Значение чекбоксаr8   )rV   r?   rJ   ZvirtualZrequired_fieldsrC   u   Вид деятельностиCmfActivity)r?   rF   r@   rG   u!   Задача просрочена)r?   rC   rQ   u   Кеш: Тип статусаu   Открытu   В работеu+   Подтверждение закрытияu   Закрыто)OPENIN_PROGRESS	IN_REVIEWCLOSEDalways)r?   r\   	load_moderC   rH   rD   u!   Настройка статусаZCmfStatusOpt)r?   rF   rU   rC   rD   u   кэш полейZlazy)r?   rC   rm   rD   c               @   s$   e Zd ZdZdZdZdZdd ZdS )zCmfActiveEntity.approvedu1   Согласовано руководителемTFc             C   sZ   g }| r| d n
| d tjj }|r<| |jj | tjjjpLd d|S )Nu   Согласовано.u&   Отмена согласования.  )appendgcurrent_personZprimary_roler)   r   r'   join)r+   Z	msg_partsZroler-   r-   r.   	html_diff  s    
z"CmfActiveEntity.approved.html_diffN)r/   r0   r1   r?   rH   r@   rQ   rt   r-   r-   r-   r.   approved  s
   ru   u   ПодписчикиZCmfFollower)r?   rU   rF   c                s   t  j|f||}|dkr |S |dkr4| jjr4dS |dkr@dS |dkrT| jjrTdS |dkrh| jjrhdS tj|  krd}| j	j
|  krd}| jdkrd}|rdS dS | jr| jtjkrdS |d	kr| jrdS dS dS )
NrY   r   r6   r   TFri   rX   r   )r$   _get_field_log_levelr   
is_changedr   r   rq   rr   
get_ownerscmf_modified_byr'   r8   r   )r+   
field_nameargskwargsrB   Zsilent_owner_changes)r,   r-   r.   rv     s6    	
z$CmfActiveEntity._get_field_log_levelc             C   s   | j jS )N)ZnotifyZ_value)r+   r-   r-   r.   _notifyW  s    zCmfActiveEntity._notifyrh   c             O   s   | j  |}|| _| S )N)r<   r)   r=   r   )r+   r7   r{   r|   r   r-   r-   r.   set_default_status[  s    z"CmfActiveEntity.set_default_statusc             O   s.   x(t jjdd| gdD ]}|j|| qW d S )Nr   z==)filter)rL   
CmfCommentlistdelete)r+   r{   r|   rJ   r-   r-   r.   _delete_comments`  s    z CmfActiveEntity._delete_commentsc             O   s.   x(t jjdd| gdD ]}|j|| qW d S )Nr   z==)r   )rL   r"   r   r   )r+   r{   r|   attachr-   r-   r.   _delete_attachmentsd  s    z#CmfActiveEntity._delete_attachmentsc             K   s   | j }| j|d|ddd}t|dr>|jjr>d|kr>|d= x*| D ]\}}||jkrHt||| qHW d|_	| |_
d|j_|  | j	r| jjr| jjr| j| j }n| j| j }tjjtjjd| |_| j	r| jjrtjjtjjd|_|jdd |S )	uC   
        Создание задачи по шаблону
        Tis_dummyN)r   copy_allr   listsF)tz)	only_data)r   r   gethasattrr   r'   itemsr   setattris_templatecloned_fromr   rw   saver   Zis_not_nullr   cmf_created_atdatetimenowtimezoneutc)r+   r|   Znew_obj_namer&   attrr'   Zdeadline_deltar-   r-   r.   create_from_templateh  s(    
z$CmfActiveEntity.create_from_templatec             C   s   d S )Nr-   )r+   r-   r-   r.   _calc_wf_simple_logic  s    z%CmfActiveEntity._calc_wf_simple_logicc             C   s>   | j js| jjs| jrdS | jjr,| jr,dS | j p6| j| _dS )u   
        Вычисляем человека от которого требуются действия по задаче
        :return:
        N)r   rw   r   r   )r+   r-   r-   r.   _calc_waiting_for  s    z!CmfActiveEntity._calc_waiting_forc             C   s   dS )u   
        Общая функция вычисления диапазона плана и будильника
        :return:
        Nr-   )r+   r-   r-   r.   
_calc_plan  s    zCmfActiveEntity._calc_planc             C   s:   | j jsd S | j r0t| j jtr0| j j | _nd | _d S )N)r   rw   r:   r'   r	   r(   r)   Zparent_logic_prefix)r+   r-   r-   r.   _calc_parent_logic_prefix  s    z)CmfActiveEntity._calc_parent_logic_prefixc             C   sb   | j js8| j js8| j j| jks8| j j| jks8| jjs8d S | j rR| jj| j d| _ n| j | _ d S )N)r   )r   rw   is_nullr7   r8   r<   r=   )r+   r-   r-   r.   _calc_status  s    zCmfActiveEntity._calc_statusc             C   s   | j js| j j| jkr| j  | j j| _| jjr| jjdkrT| jjdkrT| j  | jdkrn| j	sn| j	  | jdkrd | _
d | _| jdkr| j
  | jdkr| j  d S )N)rj   rk   ri   rj   rk   )r   rw   r7   r8   status_modified_atset_nowoldnewstatus_in_progress_endstatus_in_progress_startstatus_review_atstatus_closed_at)r+   r-   r-   r.   _calc_status_timestamps  s     







z'CmfActiveEntity._calc_status_timestampsc             C   s&   | j s
d S | js"| j  |   d S )N)r   r   r   _cacl_next_period)r+   r-   r-   r.   _calc_periodic  s
    
zCmfActiveEntity._calc_periodicc             C   s   t j t jj}| j|krt| jjdk rbt jt| jjd}| jj| | _| j	r| j	j| | _	n<t
tt| jjd d}| jj| | _| j	r| j	j| | _	| j  d S )N   )days)Zmonths)r   r   r   r   r   intr   r'   	timedeltar   r   r   r   )r+   Zcur_dateZ
shift_daysZshift_monthsr-   r-   r.   r     s    
z!CmfActiveEntity._cacl_next_periodc             C   s$   | j jsd S | j jr tddd d S )NuE   Задача не может быть без постановщикаT)abort)r   rw   r   	cmf_alert)r+   r-   r-   r.   _calc_owner  s    zCmfActiveEntity._calc_ownerc             C   sh   dddg}| j r&ddddgdddgg}|dd| jgg}x,tjj|ddd	d
dgdD ]}||  qRW dS )u\   
        Запуск триггеров для create или save
        :return:
        Zcache_action=r   ORcreateZ	cmf_modelZjson_filterZjson_entry_pointZjson_actionZ	func_nameZ	json_data)r   r   N)is_new
class_namerL   Z
CmfTriggerr   Zcheck)r+   _filterZtriggerr-   r-   r.   _exec_trigger  s    
zCmfActiveEntity._exec_triggerc             C   sH   | j jrD| j rD|  }|rD|| jkrD|ddddg || _|   d S )Nr   cmf_owner_assistantsactivity
project_id)tree_parentrw   Z_node_parentr   load_fieldsZsave_prepare)r+   r   r-   r-   r.   _calc_parent#  s    zCmfActiveEntity._calc_parentc             C   s   | j jr| jr| j r | j jdk r| jjdks8tj| jkr| j rZ| j j| jjt	j
dd krd}| jtjkrt|d7 }n|d7 }t|dd	 | j jr| jd
krtj|  kr| j jdk rtddd	 d S )Nr   i     )Zhoursu`   Нельзя передвигать будильник дальше крайнего срока.uz    Обратитесь к постановщику для разрешения на сдвиг крайнего срока.uB    Сдвиньте крайний срок если уверены.T)r   rY   u   Нельзя сдвигать будильник блокирующей задачи вперед.Возьмите в работу или обратитесь к постановщику.)r   rw   r   ager   rq   rr   r   r'   r   r   r   r   rx   )r+   msgr-   r-   r.   _check_alarm_date_valid,  s     "

z'CmfActiveEntity._check_alarm_date_validc             C   sh  |  ddddddddd	d
dddddddg tjG dd d}| }| jr| jjjdkr| j|_d| jj |_| jj	j|_	| jj
j|_
| jjj|_| jjj|_| jjj|_| jjj|_| jjj|_| jrD| jjrD| j|_d| jj |_| jj	j|_	| jj
j|_
| jjj|_| jjj|_| jjj|_| jjj|_| jjj|_| jrd| jjj|_| jjj|_|S )Nzparent.sl_deadline_shiftzparent.sl_only_owner_approvezparent.sl_deny_no_approvez0parent.sl_allow_executor_change_nofatal_deadlinezparent.sl_task_need_approvezparent.sl_task_only_owner_closezparent.sl_readonly_closed_taskzworkflow.enable_sl_controlzworkflow.sl_deadline_shiftzworkflow.sl_only_owner_approvezworkflow.sl_deny_no_approvez2workflow.sl_allow_executor_change_nofatal_deadlinezworkflow.sl_task_need_approvez!workflow.sl_task_only_owner_closez workflow.sl_readonly_closed_taskz5workflow.sl_deny_closing_task_before_closing_subtasksu.   workflow.sl_сlose_task_after_closing_subtasksc               @   s   e Zd ZU dZeed< dZeed< dZeed< dZ	eed< dZ
eed< dZeed< dZeed< dZeed	< dZeed
< dZdZdS )z;CmfActiveEntity._get_sl_options.<locals>.SimpleLogicOptionsNsl_deadline_shiftsl_only_owner_approvesl_deny_no_approve)sl_allow_executor_change_nofatal_deadlinesl_task_need_approvesl_task_only_owner_closesl_readonly_closed_task,sl_deny_closing_task_before_closing_subtasks%   sl_сlose_task_after_closing_subtasks)r/   r0   r1   r   r   __annotations__r   boolr   r   r   r   r   r   r   sl_controllersl_controller_strr-   r-   r-   r.   SimpleLogicOptionsa  s   
r   rN   u   Проект: u   Бизнес-процесс: )r   dataclassesZ	dataclassr   r'   r   r   r   r   r   r   r   r   r   r   r   r<   Zenable_sl_controlr   r   )r+   r   optionsr-   r-   r.   _get_sl_optionsK  sX    zCmfActiveEntity._get_sl_optionsc             C   s   | j jsd S | jrd S | jr| j r| jjdkr| j jr| j jtjj	 k r| 
 jpVd}| j tj|d | _| jjdkr| j  | jtjkrtjtjkr| j| j| jdtjj d| j j d| j j d| j d| jj dtjj	tjjd	d
d d S )Nr   )r   ro   u^    сдвинул крайний срок задачи<br>
                Было:&nbsp;&nbsp;u)   <br>
                Стало:<b>&nbsp;z1<b><br>
                <a target="_blank" href="z">z</a>
                )r   rY   )r   r   r   r   r   )r   rw   r   r   r   r   cmfr   CmfDateTimer   r   r   r   r   r   r   rq   rr   Zsystem_personZ_place_notifyr   r   Zhrefr'   r   r   )r+   shiftr-   r-   r.   _calc_deadline  s     4
4zCmfActiveEntity._calc_deadlinec             O   s   t jj|| d d S )N)	person_idobj)rL   Z	CmfNotifyZclose_open_notifies)r+   r   r{   r|   r-   r-   r.   _clear_notify  s    zCmfActiveEntity._clear_notifyNc          	      s|  |  dddddddg tt jf d|i|}| jrR| jj |d	 || j | jrr| jj |d	 || j | jj|d	}|r|s| j	r| j	j
jd
kr| j	jj|d	}|| | jj|d	}|r|s| j	r| j	j
jd
kr| j	jj|d	}|| |rB| j	rB| j	j
jd
krB| j	jrB| j	jj |d	 || j	jg t }	x.|D ]&}
|dksh|
j|krN|	|
 qNW |	S )u   
        Получение списка конечных пользователей затронутых обьектом
        zcmf_owner.user_localzwaiting_for.user_localzresponsible.user_localzspectators.user_localzexecutors.user_localzcmf_author.user_localzparent.cmf_owner.user_localr   )r   rN   N)r   setr$   all_relation_personsr   addr   r   
all_nestedr   r'   r   updater   r   r   
user_localrp   )r+   r   r   Zwith_parent_ownerZinherit_executorsr|   resultr   r   retu)r,   r-   r.   r     s6    


"
z$CmfActiveEntity.all_relation_personsc                sr   |sg }|sdg}t jjf |dd |dd |d|d|} rV fdd|D }|rn||d |d	  }|S )
Norderno	object_idr4   T)Zobj_idr4   r   Zclosed_lastorder_byc                s*   g | ]"}|j r  |j j kr|qS r-   )r   lowerr'   ).0r   )searchr-   r.   
<listcomp>  s    z7CmfActiveEntity.status_options_list.<locals>.<listcomp>r   rX   )rL   ZCmfWorkflowZget_status_listr   )clsobject_fieldsr   r   slicer   r|   r   r-   )r   r.   status_options_list  s     

z#CmfActiveEntity.status_options_listc                s~   |d krg }|o| d}|o&| d}|dddd gdd|gggdddd gdd|gggdd| jgg}t j|f||d	|S )
Nlogic_type_idr   r   ft_logic_typesz==INft_projectsft_model)r   r   )r   r   r$   field_options_list)r   relation_field_namer   r   r|   Zft_logic_type_idZft_project_id)r,   r-   r.   resolution_options_list  s    z'CmfActiveEntity.resolution_options_listc                sh   |sg }|rNt jj|dgd}d }|r4|jr4|jj}|ddd|gdddggg}t j|f||d|S )	Nzproject.security_level_scheme)r5   r   r   r   z==systemT)r   r   )rL   rf   r   projectsecurity_level_schemer$   r   )r   r   r   r   r|   Ztaskr   )r,   r-   r.    perm_security_level_options_list  s    
z0CmfActiveEntity.perm_security_level_options_listc          	      s  |sg }|sg }|si }|s"dg}|o.| d}|rB|drBtjj |dddddgd	}	|	rB|rn|	jrBd }
|	jrtjj|	jj	d|d
d}
|
rB|	j
r|	j
j	j|
krt |
|	j
j	j< |
|	j
j	j |	j
j	jj	 x8|	jD ].}|j|
krt |
|j< |
|j |jj	 qW x0|D ](}||g dd|
 |g gg||< qW |ddd
gg}|d t j| jjf||||||d|S )NrK   rM   rN   Zproject_typer   r   filter_responsibler   )r5   r   T)Zchild_modelsZ
return_setr5   r   r   z==roles)r   all_optionsmodels_listmodels_filtersr   r   )r   
startswithrL   rN   r   r   ZRelationCacheZget_children_dictr5   r'   r   r   r   r   r   
setdefaultrp   r$   r   r   )r   r   r   r   r   r   r   r|   rM   r   Zchildren_dictZ	assistantZ
model_name)r,   r-   r.   responsible_options_list  sF    



z(CmfActiveEntity.responsible_options_listc                s  |sg }|sg }|dkr4| j f |||||d|S |dkrV| jf ||||d|S |dkrz| j|f||||d|S |dkr|sdg}d-|}| jd	kr^| jd
krd}| jdkrd}| jdkrd}d}	|o|dd}
|o|dd}|
r
tjj|
|gd}	n.|r8tj|d| gd}t	|dr8|j
}	|	r^t|	|r^|ddt|	|gg}|dd| jgg}|rFd|krF|ddd|d gdddggg}n|dkr|d n|d kr |o|d}|r|ddd!dgdd!|ggg}|o|d}|rF|dd"d!dgd"d!|ggg}n&|d#krF| j|f||||d|S |d$r| j|}|s|td%| d&|  | ||jd'kr|jd(krd}d)|kr|d) }|d)= |d*d+r|g}n|d)d|gg}t j|f|||||d,|S ).u  
        FIXME:
          потом мы сделаем эту штуку через
          глубокий поиск общую кэш-таблицу и все будет хорошо
        osv: а зачем это и так все кешируется дважды
        todo возможно надо вынести responsible status tag и тд в CmfTag и тп но не факт
        r   )r   r   r   r   r   r   )r   r   r   r   perm_security_levelr3   r   filter_activity_id)re   rf   CmfListre   Zstrict_document_logic_typerf   Zstrict_task_logic_typer  Zstrict_list_logic_typeNscheme_wf_idrM   )r5   r   z
scheme_wf.)r   	scheme_wfr5   r   cmf_model_namer   rS   r   Zfilter_activity)r   r   r   r   r   z==Zfilter_project
resolutionZcf_u   Не нашел поле u    в классе TZCmfCascadeChoicechoice_parent_idr   F)r   r   r   r   r   )r  )r  r   r   r   r   rL   CmfSchemeWfcmfutilget_obj_by_idr   r  getattrrp   r   r   r   
ValueErrorZcustomrV   r$   r   )r   r   r   r   r   r   r   r|   Zlt_field_namer  r  rM   r   rS   custom_fieldr	  )r,   r-   r.   r   D  s    









z"CmfActiveEntity.field_options_listc             C   s
   | j dkS )Nrk   )r8   )r+   r-   r-   r.   _is_checked  s    zCmfActiveEntity._is_checkedc             C   s\   |  ddg |dkr*| j d| _n.|dkrF| j d| _ntd| jj d S )Nr   r<   Trk   Frh   u:   Некорректное значение для поля )r   r<   r)   r=   r   ZCmfValidationError
is_checkedr?   )r+   r'   r-   r-   r.   r    s    )skip_tree_movec            O   s   |s|  dddg t| jjtjr\tjjdddg| jd}|sttj| jddd	}|	  ntjjdddg| jd
}|st
d|| _d| j_| jj	dd d| _| j	dd | j  x"| jD ]}|j|ddi| qW | S )Nz**zparent.tree_node_is_branchr<   sys_typez==r   )r   rM   u
   Архив)r   r   r  )r   tree_parent_idu4   В текущем проекте нет архиваT)r   r  )r   r:   r   r'   rL   rK   rd   r   rM   r   	Exceptionr   tree_node_is_branchZcmf_archived
tree_nodesr)   r   )r+   r  r{   r|   r   childr-   r-   r.   r     s*    

zCmfActiveEntity.archivec             C   s   dS )u   
        Отправляем во фронт события для реалтайм обновления
        :return:
        Nr-   )r+   r-   r-   r.   
emit_event  s    zCmfActiveEntity.emit_eventc             C   s   | j r
d S d }| jr6d| jjkr6| jdg | jj }| j sF|rF|| _ | j sptjj rptjj jdgd tjj | _ | j stjj	ddgdd| _ d S )Nr   z
activity.*r   )r   ZbusinessT)r
   r   cache_inmemory)
r   r   r   r   rq   rr   r)   rL   rg   r   )r+   Zparent_activityr-   r-   r.   _calc_activity  s    

zCmfActiveEntity._calc_activityc             C   s  | j s*| jjs*| jjs*| jjs*| jjs*d S | j s8| jjr| jjs| jjjs| jjdkrtj	
 }|jdkr~|jdddd| _q|jdddd| _n&| j  |  jtj| jjjd7  _d S tjs| jjr| j s| jjr| jjrtd d | _| jr| js| jjrtd | j  | jsL| jjdkrL| jjrBtd | j  | j s| jjr| jjr| jjjd	kr| jjjd	kr| jr| j | jkr| j  | jd
kr| jr| jjdk r| j  | jjr| jjdkrtjs| j  d S )Nr   r   )hourZminutesecond)Zsecondsu   Будильник сброшен т.к. у этого бизнес-процесса в статусе будильник не заданu   Будильник установлен. Задача с крайним сроком не может быть без будильника.)rh   rk   uW   Будильник установлен тк задача уже выполняетсяrh   rk   )r   r   rw   r   r   r<   Z
next_alarmr   rq   current_userZget_current_datetimer  replacer   r   r   r'   Zimport_moder   r   r   r7   r   r   r8   r   )r+   Zcurrent_timer-   r-   r.   _calc_alarm_date  sP    










"
z CmfActiveEntity._calc_alarm_datec             C   s   | j rd| _d S )NT)r   ru   )r+   r-   r-   r.   _calc_approved=  s    zCmfActiveEntity._calc_approvedc             C   s   d S )Nr-   )r+   r-   r-   r.   
_calc_nameC  s    zCmfActiveEntity._calc_namec                sn   | j r| jjs| jjsd S | j s.t   d S | j rD| j drDd S |   d| j j	dd  }|| _ d S )NzA--rY   )
r
   r3   rw   r   r$   
_calc_coder   get_code_prefixr'   
rpartition)r+   r
   )r,   r-   r.   r$  G  s    
 zCmfActiveEntity._calc_codec                s(   | j r| j j }|r|S tt|  S )N)r3   Zobj_code_prefixr)   r$   r	   r%  )r+   Zcode_prefix)r,   r-   r.   r%  b  s
    zCmfActiveEntity.get_code_prefixc             C   s6  |  ddddddddd	d
g
}dd | jD |d< dd | jD |d< d |d< | jrr| j dddddddg|d< d |d< | jr| j dddg|d< d |d< | jr| j ddddg|d< d |d< | jr| j ddddg|d< d |d< | jr
| j ddddg|d< d |d< | jr2| j ddddg|d< |S )Nr5   r   r
   textr   r   ru   r   r   Zcmf_modified_atc             S   s   g | ]}| d dddgqS )r5   r   r
   login)to_json)r   ir-   r-   r.   r   y  s    z9CmfActiveEntity.get_cache_fields_json.<locals>.<listcomp>r   c             S   s   g | ]}| d dddgqS )r5   r   r
   r(  )r)  )r   r*  r-   r-   r.   r   |  s    r   r   Zcolorr7   Z	card_namer   
cmf_authorr(  r   r   r   )	r)  r   r   r   r   r+  r   r   r   )r+   r   r-   r-   r.   get_cache_fields_jsonk  s@    z%CmfActiveEntity.get_cache_fields_jsonc             C   sz   | j r| jjsd S | j jr$| j r$d S | j s<| j| | _ d S | jjrh| jjrh| jj| }|| j krhd S | j| | _ d S )N)r3   r  rw   Zcalc_logic_typer   )r+   Zold_default_logic_typer-   r-   r.   _calc_logic_type  s    
z CmfActiveEntity._calc_logic_typec             C   s>   | j js| jjs| jrd S | jjr,| jr,d S tj| | _d S )N)r   rw   r   r  rL   r
  Zcalc_scheme)r+   r-   r-   r.   _calc_scheme_wf  s    zCmfActiveEntity._calc_scheme_wfc             C   sF   | j js"| jjs"| jjs"| jr"d S | jjr4| jr4d S | j | | _d S )N)r  rw   r3   r   r<   Zcalc_workflow)r+   r-   r-   r.   _calc_workflow  s    zCmfActiveEntity._calc_workflowc             C   s   d S )Nr-   )r+   r-   r-   r.   _calc_default_workflow  s    z&CmfActiveEntity._calc_default_workflowc             C   s   d S )Nr-   )r+   r-   r-   r.   _calc_responsible  s    z!CmfActiveEntity._calc_responsiblec                s*   t   p(| jjp(| jjp(| jjp(| jjS )N)r$   _acl_subjects_is_changedr   rw   r   r   r   )r+   )r,   r-   r.   r2    s    
z(CmfActiveEntity._acl_subjects_is_changedc                s>   t   }|| j | jr(|| j | jr:|| j |S )N)r$   _acl_subjects_list_level_writeextendr   r   rp   r   )r+   r   )r,   r-   r.   r3    s    
z.CmfActiveEntity._acl_subjects_list_level_writec                s   t   }|| j |S )N)r$   _acl_subjects_list_level_readr4  r   )r+   r   )r,   r-   r.   r5    s    
z-CmfActiveEntity._acl_subjects_list_level_readc          -      sf   t   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!d"d#d$d%d&d'd(d)d*d+g, S ),Nr   r   r   r   r<   r(   zparent.cmf_ownerzparent.cmf_owner_assistantszparent.activityr  r+  zstatus.ordernozstatus.workflowr   r   r   cache_status_optr   Z
cmf_importry   sharelink_hashzlogic_type.coder  r   zparent.sl_deadline_shiftzparent.sl_only_owner_approvezparent.sl_deny_no_approvez0parent.sl_allow_executor_change_nofatal_deadlinezparent.sl_task_need_approvezparent.sl_task_only_owner_closezworkflow.enable_sl_controlzworkflow.sl_deadline_shiftzworkflow.sl_only_owner_approvezworkflow.sl_deny_no_approvez2workflow.sl_allow_executor_change_nofatal_deadlinezworkflow.sl_task_need_approvez!workflow.sl_task_only_owner_closez5workflow.sl_deny_closing_task_before_closing_subtasksu.   workflow.sl_сlose_task_after_closing_subtasksui_view_formr  r   z,perm_security_level.access_task_fields_cache)r$   save_preload_fields)r+   )r,   r-   r.   r9    s4    
z#CmfActiveEntity.save_preload_fieldsc                s   t   ddg S )Nr8  Ztask_filters)r$   project_perm_allow_fields)r+   )r,   r-   r.   r:    s    z)CmfActiveEntity.project_perm_allow_fieldsc             C   s  t d| jrd S tjdr"d S | jrB| jjjdkrB| jjrBd S d}x@| j	ddD ]0}|j| 
 krT|jdsT|jdsTd}P qTW | jjr| jjrd}| js| jjr|  }|jsd}| jd	krd}|r|   d}x$| j	ddD ]}|jd
krd}P qW |rt|  }||   tj|krd| j d| jrH| jjpJd d| jr`| jjpbd d| jrx| jjpzd d	}t t!dd || j| j| jh }|r|dd"|d d  7 }t#|dkr|d7 }n|d7 }n|d7 }t$j%j&|d d S )NuG   Не используется! Оставлено для историиimportrN   FT)rw   Zcache__idrY   )r   r   r   r   Zchild_tasksZdepended_tasksZaffected_tasksu   Это действие над uC    разрешено только Владельцу объекта(r#  u    ) или Исполнителю(uW   ) или Временному исполнителю(поле "Ждем ответа": )c             S   s
   t | jS )N)r;   r   )xr-   r-   r.   <lambda>c      z4CmfActiveEntity._check_simple_perm.<locals>.<lambda>u   , а так же z, 
   u
   , и др..)message)'r  r   osenvironr   r   r'   r   Zdisable_simple_permvaluesZsimple_perm_allow_fieldsr   endswithr   rw   r   r   r   r   r   Zcheck_owner_permsr   r   r   rx   rq   rr   r
   r   r   r   r   sortedmaprs   lenrL   CmfAccessListZcheck_admin_mode)r+   Zneed_owners_checkZfieldZ
sl_optionsZneed_reluser_checkZall_relation_userr   Zothersr-   r-   r.   _check_simple_perm  sZ    

V

z"CmfActiveEntity._check_simple_permc             O   s4   |    |   |   |   |   |   d S )N)r  r.  r-  r/  r   r"  )r+   r{   r|   r-   r-   r.   _save_templatet  s    zCmfActiveEntity._save_templatec             C   sJ   | j jsd S | js.| jjr.| jj| jjkr.d S | j| | j j| j j d S )N)r   rw   r   r<   r   r   Zrun_transitionr'   )r+   r-   r-   r.   _exec_transition}  s
    z CmfActiveEntity._exec_transition)comment_appendchanged_fields)rP  c            O   sH   x |  D ]\}}t| || q
W | jdd |rDtj|| d  d S )NT)is_task_transition_run)r'  r   )r   r   r   rL   r   )r+   rO  rP  Z_args_kwargskeyvalr-   r-   r.   r!     s    z#CmfActiveEntity.task_transition_runc             C   s   | j r| jr| j | _ d S )N)r8  r   ui_namer   )r+   r-   r-   r.   _calc_ui_view_form  s    z"CmfActiveEntity._calc_ui_view_formc             K   s  |    td |   td |   td |   td |   |   td |   td | 	  td | 
  td |   td	 |   td
 |   td |   td |   td |   td |   td |   td |   td |   td |   td |   td |   td |   td |   td |   td |   td d S )Nz_calc_owner endz_calc_parent endz_calc_activity endz_calc_scheme_wf endz_calc_periodic endz_calc_logic_type endz_calc_tree_parent endz_calc_perm_security_level endz_calc_workflow endz_calc_default_workflow endz_calc_status endz_calc_status_history endz_calc_status_timestamps endz_calc_plan endz_calc_approved endz_calc_deadline endz_calc_alarm_date endz_calc_wf_simple_logic endz_calc_waiting_for endz_check_alarm_date_valid endz_calc_name endz_calc_parent_logic_prefix endz_calc_sharelink_hash endz_calc_ui_view_form endz/_calc_perm_security_level_allowed_ids_cache end)r   rq   debugr   r  r.  r1  r   r-  _calc_tree_parent_calc_perm_security_levelr/  r0  r   _calc_status_historyr   r   r!  r   r   r   r   r   r"  r   _calc_sharelink_hashrV  +_calc_perm_security_level_allowed_ids_cache)r+   rR  r-   r-   r.   recalc_fields  sf    























zCmfActiveEntity.recalc_fieldsc             C   s   d S )Nr-   )r+   r-   r-   r.   do_status_is_changed  s    z$CmfActiveEntity.do_status_is_changedc          
   C   sV   | j jsd S t 8 tj| | j j| j j| j	| | j j| j jd
  W d Q R X d S )N)r   Zfrom_statusZ	to_statusZ
transition)r   rw   r  r   rL   ZCmfStatusHistoryr   r   r<   Zcalc_transitionr   )r+   r-   r-   r.   rZ    s    
z$CmfActiveEntity._calc_status_historyc             C   s   | j r| j dddg | | }xp|d D ]d}|d | dsDq,|d | d d dkr^q,t| |}|jr,|js,t| ||d | d d  q,W d S )Nui_form_schemer(   cust_field_conf_scheme	ui_fieldsrQ   r'   Z_NONE_)r   r   _build_ui_formr   r  r   rw   r   )r+   ui_form_jsonZconf_field_nameZ	cur_fieldr-   r-   r.   _calc_default_field  s    

z#CmfActiveEntity._calc_default_fieldr   )rQ  depthc         	      s  | j r|   | j r:| jdkr:| js:t j|d|i|S | jjr| j s|stj	j
dd| jjjggdd| jjgdddggdd	}|stj	j
ddd gdd| jjgdddggdd	}|rtd
| j d|j d| jjj d| jj dd | jjr|   | jr.| j|| t j|d|i|}td |S | jf | |   td |   tjj| d t j|d|i|}td |S )Nrf   re  Zstatus_fromr   Z	status_tor   Ztrans_form_showT)r   r  zmust_transition_run ro   )r   zsuper().save endzhandle_mention_persons end)r   )r   rd  r   r   r$   r   r   rw   rL   ZCmfTransr   r   r5   r   r   r^  r   rM  rq   rW  r]  handle_mention_persons_calc_resolutionZCmfStatZdo_calc_statistics)r+   rQ  re  r{   r|   Ztransr   )r,   r-   r.   r     sB    

2



zCmfActiveEntity.savec                sn   t   | _td| j d t jf | | jr8| jsjd}| jrFd}t	| drZ| j
rZd}tj| |d d S )Nzsave start (r=  r   r   r   before_save)time_CmfActiveEntity__start_tsrq   rW  r5   r$   before_save_hookr   r   r   r   rL   CmfAutomationCrudTrigger	crud_hook)r+   r|   Zcrud_action)r,   r-   r.   rk  F  s    
z CmfActiveEntity.before_save_hookc                s   |    td tjrJ| jrJ| jj rJt| jjj	t
 t  td |   td | jrh| jstj| | jrzdndd td t jf | td| j d	t | j d
 d S )Nz_exec_transition endz_exec_bzpython endz_exec_trigger endr   r   
after_savez_CmfAutomationCrudTrigger endz
save end (z): z.3f)rN  rq   rW  ZconfigZBZPYTHON_ENABLEDr<   Zsave_eval_coder)   execr'   globalslocalsr   r   r   rL   rl  rm  r$   before_save_data_hookr5   ri  rj  )r+   r|   )r,   r-   r.   rr  V  s    



z%CmfActiveEntity.before_save_data_hookc                s2   t j| dd t j|| t j| dd d S )Nr   rh  rn  )rL   rl  rm  r$   r   )r+   r{   r|   )r,   r-   r.   r   n  s    zCmfActiveEntity.deletec                s   |   | _t   d S )N)r,  cache_fieldsr$   _update_cache_fields)r+   )r,   r-   r.   rt  s  s    
z$CmfActiveEntity._update_cache_fields)include_templatesc               s   |s| dd t j||S )Nr   F)r   r$   r   )r   ru  r{   r|   )r,   r-   r.   r   x  s    zCmfActiveEntity.listc               s   |s| dd t j||S )Nr   F)r   r$   slist)r   ru  r{   r|   )r,   r-   r.   rv  ~  s    zCmfActiveEntity.slistc          
   C   s|   | j dddgd xX| jD ]N}t|jd,}tj||jd}||  |	  W dQ R X |
|| qW |j	dd	 dS )
uD    Копирование вложений для CmfTask, CmfDocumentzattachments.url_previewzattachments.url_preview_imgzattachments.url)r   rb)r   r   NT)r   )r   attachmentsopenZfull_path_filerL   r"   r   Zupload_filereadr   _replace_attachment)r+   r   
attachmentfileZnew_attachmentr-   r-   r.   copy_attachments  s    z CmfActiveEntity.copy_attachmentsc                s0   d|j _|jdkr|j|_n|  t |S )NTdummy)r3   rw   r
   r5   r$  r$   _post_copy_hook)r   obj_copy)r,   r-   r.   r    s
    

zCmfActiveEntity._post_copy_hook)r~  r   r   )r   r~  r   c      	         sR   |rd}|  dddddg d}|r(d}t jf ||d	|}|rN| | |S )
u  Копирование

        Args:
            name (str): Новое имя
            copy_attachments (bool): Копировать вложения
            copy_relations (bool): Копировать связи
            copy_subtasks (bool): Копировать подзадачи

        Returns:
            CmfActiveEntity: Скопированный елемент

        Tz**zattachments.urlr   zattachments.url_previewzattachments.url_preview_imgNr  )r
   r   )r   r$   r   r~  )	r+   r   r~  r   r   r{   r|   r
   r  )r,   r-   r.   r     s    


zCmfActiveEntity.copyu   ACL ПраваrQ   u   Нетu   ACL Полныеu   ACL Только чтениеu   ACL Приватные)rQ   fullrE   private)rC   r?   rQ   r@   r\   u-   WEB Авторизованный доступu   Доступ запрещёнu2   Могут только просматриватьuE   Могут просматривать и комментироватьu   Полный доступ)rQ   denyrE   rJ   r  u#   WEB Анонимный доступu"   WEB Доступ по ссылкеc                s   | j js|sd S | j jdkr$|s$d S | jsfdd l}dd l|j|j  d fddt	dD | _xjt
 D ]^}xX|jdd| jjgd	dd ggd
dd	gdD ],}td|  |jdd |jdd qW qpW d S )NrQ   r   rn   c             3   s   | ]}  V  qd S )N)choice)r   _)alphabetsecretsr-   r.   	<genexpr>  s    z7CmfActiveEntity._calc_sharelink_hash.<locals>.<genexpr>r   r  r   r7  r5   perm_policy_sharelink)r   r   z#_calc_sharelink_hash child update: T)force)r   )r  rw   r   r7  stringr  Zascii_lettersdigitsrs   ranger	   Ziter_subclassesr   r5   r'   rq   rW  r[  r   )r+   r  r  	model_clsr  r-   )r  r  r.   r[    s      z$CmfActiveEntity._calc_sharelink_hashc             C   s   d| _ |   dS )u&   Метод сброса sharelink_hashN)r7  r[  )r+   r-   r-   r.   do_erase_sharelink_hash  s    z'CmfActiveEntity.do_erase_sharelink_hashCmfStr32zShareLink hash)rV   r?   rJ   rC   c             C   s   | j dkrdS tjd| jd}tj }|j| | j dkrFd|_n\| j dkrvd|_tjd| jd|gd	gd
	  n,| j dkrd|_nt
d| j  d d|_|	  dS )uG   Наполняем ACL правилами для ShareLink группыrQ   Nauto)r  r   rE   rz  rJ   writecomments)r  r   access_levelsubjectsr   r  z%WARN! Unknown perm_policy_sharelink: z. Set deny policyr  )r  rL   CmfAccessRuleperm_aclrO   sharelink_groupr  rp   r  r   rq   rW  )r+   Zacl_rule_sharelinkr  r-   r-   r.   _acl_scaffold_sharelink_rules  s,    




z-CmfActiveEntity._acl_scaffold_sharelink_rulesc             C   s8  | j dkr| jdkrdS tjd| jdd}tjjdd}|j| | j dkrVd	|_	nH| j d
krd	|_	tjd| jd|gdgd
  n| j dkrd|_	nd|_	|
  tjd| jdd}tj }|j| | jdkrd	|_	nL| jd
krd	|_	tjd| jd|gdgd
  n| jdkr&d|_	nd|_	|
  dS )uZ   Наполняем ACL правилами для публикации документовrQ   Nr  ZSETMEBUG)r  r   r  zanonymous@evateam.ru)r(  rE   rz  rJ   r  r  )r  r   r  r  r   r  r  )perm_policy_anonymousperm_policy_guestrL   r  r  rK   r   r  rp   r  r   rO   Zguest_group)r+   Zacl_rule_anonymousZanonymous_personZacl_rule_guestZguest_person_groupr-   r-   r.   _acl_scaffold_public_rules&  sN    






z*CmfActiveEntity._acl_scaffold_public_rulesc                s4  |    |   | dg | jdkrHtjd| jtj gdd	  n| jdkrt
t|  }|r~tjd| j|dd	  tjd| jtj gdd	  n| jdkr&t
t|  }|rtjd| j|dd	  t
t|  }|rtjd| j|dd	  tjd| jtj gd	d	  t   d
S )u   Наполним свой acl автоматическими правилами в зависимости от политикиr   r  r  )r  r   r  r  rE   Z	denyWriter  rz  r  N)r  r  r   perm_policyrL   r  r  rO   Z
user_groupr   r   r   r3  r5  r$   _acl_scaffold)r+   Zwriter_listZreader_list)r,   r-   r.   r  _  s>    

zCmfActiveEntity._acl_scaffoldc             C   s"   |  ddddddddd	d
g
 d S )Nr  perm_has_aclz
perm_acl.*Zperm_inheritperm_parentperm_inherit_acl_idperm_effective_acl_idr  r  r  )r   )r+   r-   r-   r.   _load_perm_fields  s
    z!CmfActiveEntity._load_perm_fieldsc                s@   t    | jjs| jjsd S |   | jr<| jdkr<d| _d S )NrQ   T)r$   _calc_perm_has_aclr  rw   r  r  )r+   )r,   r-   r.   r    s    
z"CmfActiveEntity._calc_perm_has_aclc                s|   | j jsD| jjsD| jjsD| jjsD| jjsD| jjsD| jjsD|  sDd S | jdksb| jdksb| jdkrn| j snd| _ t	 j
ddS )NrQ   T)r  )r  rw   r  r  r   r  r  r  r2  r$   _calc_perm_acl)r+   )r,   r-   r.   r    s    


zCmfActiveEntity._calc_perm_aclc             C   s   | j jrd S | jjrB| dg t| jdrB| jj rB| jj | _ d S | jdkr| jr| jjr| dg | j s| jjr| jjjr| jjj| _ d S d S )Nzperm_parent.perm_security_levelr  rf   z9project.security_level_scheme.default_task_security_level)	r  rw   r  r   r   r   r   r   Zdefault_task_security_level)r+   r-   r-   r.   rY    s    	


z)CmfActiveEntity._calc_perm_security_levelc          
   C   s  t  }ddg}|dkr*td| ddd |ds8d	S |d
krb| dddg | jrb|| j |dkr| dddg | jr|r|| jj|d n|| j |dkr| dddg | j	r|r|| j	j|d n|| j	 |dkr| dddg | j
r|| j
 |dkrF| dddg | jrF|| j |dkr| d d!d"d#g | jr| jj
r|| jj
 |d$kr| d%d&d'g | jr| jjr|| jj |d(kr|| d d!d"d%d&d'd)d*g | jr|| jjjd+kr|t }| jj
r|| jj
 | jjr.|| jj | jjrN|| jjj|d | jj	rn|| jj	j|d |t | |d,kr| d-d.d/g | jr|| j |d0kr| d1d2d3g | jr|| j |d4krTt| d5r| d5d6d7g | jr|| j t| d8rT| d9d:d;g x$| jD ]}|jr6||j q6W |d<krftjgS |d=kr~||   |d>kr|| j|d |d?krLt| d@rL| dAdBdCdDg t }| jjr|| jjj|d | jjr>xJ| jjD ]>}|jr||jj|d |jr||jj|d qW |t | g }	xn|D ]f}
|
jjdr|	| j |
jj|dE |dF qV|
j!rqVt|
dr|
j"rqV|	|
 qVW |	S )Gu?  
        Получение значение по шаблонным объектам.

        Возвращает список (в том числе пустой), если передан шаблонный объект
            или None, если объект не является шаблонным
        cmf_deleteddoes_not_workrA  un   Зацикливание рекурсии в раскрытии var-пользователя: extract_var_obj(r=  T)r   zvar:Nzvar:responsibler   zresponsible.cmf_deletedzresponsible.does_not_workzvar:executorsr   zexecutors.cmf_deletedzexecutors.does_not_work)r   zvar:spectatorsr   zspectators.cmf_deletedzspectators.does_not_workz	var:ownerr   zcmf_owner.cmf_deletedzcmf_owner.does_not_workzvar:owner_assistantsr   z cmf_owner_assistants.cmf_deletedz"cmf_owner_assistants.does_not_workzvar:project_ownerzparent.cmf_ownerzparent.cmf_owner.cmf_deletedzparent.cmf_owner.does_not_workzparent.cmf_owner.user_localzvar:project_owner_assistantszparent.cmf_owner_assistantsz'parent.cmf_owner_assistants.cmf_deletedz)parent.cmf_owner_assistants.does_not_workzvar:project_userszparent.executorszparent.spectatorsrN   z
var:authorr+  zcmf_author.cmf_deletedzcmf_author.does_not_workzvar:waiting_forr   zwaiting_for.cmf_deletedzwaiting_for.does_not_workzvar:component_ownerdefault_ownerzdefault_owner.cmf_deletedzdefault_owner.does_not_work
componentszcomponent.default_ownerz#component.default_owner.cmf_deletedz%component.default_owner.does_not_workzvar:current_userzvar:followerszvar:all_related_userszvar:approversr   zstatus.master_approverszstatus.approve_groupszstatus.approve_groups.approversz&status.approve_groups.master_approversrX   )	recursionall_nested_persons)#r   r   r   r   r   rp   r   r4  r   r   r   r   r   r'   r   r   r   r   r+  r   r   r  r  rq   r  get_all_followersr   r   Zmaster_approversZapprove_groupsZ	approversr
   extract_var_objr  r  )r+   Zobj_coder  r  Z	var_usersr   resZ	componentZagZres_var_usersZvar_userr-   r-   r.   r    s    






















zCmfActiveEntity.extract_var_objc             C   s^  | j js|s| jjs| jjs| jjs| jjs| jjs| jjs| jjs| j	js| j
sd}| j r| j jrx| j jD ]}| | jrnd}qnW |sd S td | j s| jrd | _td d S t }t }| ddddd	g xB| j jD ]4}|jrf| |jj}|d kr0|jr ||jj n||jj n6x4|D ],}|jrR||jj n||jj q6W |jr| |j x|jD ]}	| |	 sqtt| |	 tjrxh| |	 D ],}
|jr||
jj n||
jj qW n.|jr || |	 jj n|| |	 jj qW qW d |ks0d |kr<td
dd t |t |d| _td d S )NFTz1_calc_perm_security_level_allowed_ids_cache startz/_calc_perm_security_level_allowed_ids_cache endz;perm_security_level.security_level_rules.access_member.codez;perm_security_level.security_level_rules.access_task_fieldsz8perm_security_level.security_level_rules.access_readonlyzproject.cmf_ownerzproject.cmf_owner_assistantsuf   DEV: _calc_perm_security_level_allowed_ids_cache None должны отфильтровываться!)r   )r  rE   )!r  rw   r   r   r+  r   r   r   r   r   r   Zaccess_task_fields_cacherq   rW  %perm_security_level_allowed_ids_cacher   r   Zsecurity_level_rulesZaccess_memberr  r
   Zaccess_readonlyr   Zaccess_member_idr'   r5   Zaccess_task_fields
issubclasstyper   Z
CmfM2MBaser   r   )r+   r  Zcustom_changedr  Zallowed_idsZallowed_ids_readonlyZruleZextracted_membersZextracted_memberrz   r   r-   r-   r.   r\  F  sx    





z;CmfActiveEntity._calc_perm_security_level_allowed_ids_cachec                s   |    d| _t   d S )NrQ   )r  r  r$   r   )r+   rR  )r,   r-   r.   r     s    zCmfActiveEntity.disable_aclc                sF   t  jf | x2tjjjjdgdd| gdD ]}| j|f| q,W d S )Nr   r   r   )r   r   )r$   _direct_children_deleter   ZincluderL   r"   r   Z_delete_child_object)r+   r|   r|  )r,   r-   r.   r    s    "z'CmfActiveEntity._direct_children_delete)r  )returnc               sJ  |dkrt 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g t jf |}xXjD ]N}|jdkr|j|krd||j qd|dkr||j qd|j	rd||j qdW j
r|j
j|d d }jjjjjjjjj jjy&t fd!d"|D }W n tk
rD   t }Y nX |S )#Nr   u@   DEV: зацикливание рекурсии get_all_followersT)r   r   zcmf_owner.cmf_deletedzcmf_owner.does_not_workr   zwaiting_for.cmf_deletedzwaiting_for.does_not_workr   zresponsible.cmf_deletedzresponsible.does_not_workr   zspectators.cmf_deletedzspectators.does_not_workr   zexecutors.cmf_deletedzexecutors.does_not_workr+  zcmf_author.cmf_deletedzcmf_author.does_not_workzfollowers.personzfollowers.person.cmf_deletedzfollowers.person.does_not_workzfollowers.notify_volumezfollowers.follow_childrenr   Zoffr   rX   )r  c                s0   g | ](}t jj d d|d
r|qS )rz  F)
initial_acl_keyZobject_modelZobject_owner_idr   Zobject_parent_idr  r9   Zobject_instanceZchecking_personZperm_security_level_allowed_ids)rL   rK  Zcheck_access)r   r   )r   cmf_owner_idr  obj_parent_idr  r+   self_idr-   r.   r     s    z5CmfActiveEntity.get_all_followers.<locals>.<listcomp>)r   r   r$   r  	followersZnotify_volumer   remover   Zfollow_childrenr   unionr  r'   rM   r  r5   r   r  r   r   ZCmfACLNotInitializedError)r+   r  r{   r|   r  Zfollowerr  )r,   )r   r  r  r  r  r+   r  r.   r    sD    


$	z!CmfActiveEntity.get_all_followersc                s   |  | j |d| jr"| jjjp$d  |d| jr>| jjjp@d  |d| jjpTd d|krzddd | j	D |d< t
 jf |S )	NZobj_logic_type_codeZobj_activity_codeZobj_status_typerh   Zobj_tagsro   c             S   s   g | ]}t |jpd qS )rn   )r;   r   )r   tr-   r-   r.   r     s    z5CmfActiveEntity.full_search_index.<locals>.<listcomp>)r   Zfull_search_fieldsr   r3   r
   r'   r   r8   rs   r   r$   full_search_index)r+   r|   )r,   r-   r.   r    s    z!CmfActiveEntity.full_search_index)r'  r  c             C   sJ   t | d}g }x4|dd D ]"}t|jd }|r || q W |S )NZlxmlc             S   s
   |  dS )Nzdata-mention-type)Zhas_attr)tagr-   r-   r.   r?    r@  z,CmfActiveEntity.parse_text.<locals>.<lambda>zdata-object-id)bs4ZBeautifulSoupZfind_allr  r  Zattrsrp   )r'  bsr   r  r   r-   r-   r.   
parse_text  s    zCmfActiveEntity.parse_textc             C   s~   | j jsd S t }t }| j jr2t| | j j}| j jrLt| | j j}x,|| D ] }|jdkrVtjj	| d|d qVW d S )N)rO   rK   Zmention)Zevent_person)
r'  rw   r   r   r  r   r   rL   CmfEventdo_event)r+   Zobjs_oldZobjs_newr   r-   r-   r.   rf    s    
z&CmfActiveEntity.handle_mention_personsc                s   dddg}| j |kr tddd ddd	d
ddg}dddddddddddg}t| j j|dd |D d tjr jtjjkrt	d  dtj  tddd fdd|D d	 rd	 
| fd d|D d	< S )!Nre   rN   rd   ue   Попытка выполнить public_parent_ui_get к недозволенному объектуT)r   r   r
   public_html_schemeZdocument_header_textZdocument_footer_textZtree_text_overflowZheader_background_colorZheader_text_colorZcontent_background_colorZcontent_text_colorZfooter_background_colorZfooter_text_colorZsidebar_background_colorZsidebar_text_colorZfooter_textZ	custom_jsZ
custom_cssc             S   s   g | ]}d | qS )zparent.r-   )r   fr-   r-   r.   r   	  s    z8CmfActiveEntity.public_parent_ui_get.<locals>.<listcomp>)r5   r   uX   В public_get share api попытались запросить чужой объект z != u8   Нет прав public_get (ошибка доступа)c                s   i | ]}t  j||qS r-   )r  r   )r   r  )r  r-   r.   
<dictcomp>	  s    z8CmfActiveEntity.public_parent_ui_get.<locals>.<dictcomp>c                s   i | ]}t  d  ||qS )r  )r  )r   r  )r   r-   r.   r  	  s    )r   r   r  Zget_model_by_namer   rq   Zsharelink_access_requestr5   Zsharelink_access_objrW  r   )r   Zchild_idZallowed_objectsZallowed_fieldsZscheme_fieldsr-   )r  r   r.   public_parent_ui_get  s&    


 z$CmfActiveEntity.public_parent_ui_getc                s  |    td |   td |   td |   td |   |   td |   td | 	  td | 
  td |   td	 |   td
 |   td |   td |   td |   td |   td |   td |   td |   td |   td |   td |   td |   td t j|| d S )Nz_calc_owner endz_calc_parent endz_calc_activity endz_calc_scheme_wf endz_calc_periodic endz_calc_logic_type endz_calc_tree_parent endz_calc_perm_security_level endz_calc_workflow endz_calc_default_workflow endz_calc_status endz_calc_status_timestamps endz_calc_approved endz_calc_deadline endz_calc_alarm_date endz_calc_wf_simple_logic endz_calc_waiting_for endz_check_alarm_date_valid endz_calc_parent_logic_prefix endz_calc_sharelink_hash endz_calc_ui_view_form endz/_calc_perm_security_level_allowed_ids_cache end)r   rq   rW  r   r  r.  r1  r   r-  rX  rY  r/  r0  r   r   r!  r   r   r   r   r   r   r[  rV  r\  r$   _save_import)r+   r{   r|   )r,   r-   r.   r  	  s\    





















zCmfActiveEntity._save_importc       
      C   s   ddl m} g }ddddddg}|r.|d	 tj|d
|d}|d krJ|S x8|jD ].}	t|	drl|	jd k	rlqR|	jdkrR||	 qRW |j	||pd|d |S )Nr   )
attrgetterr  ztree_nodes.tree_node_is_branchztree_nodes.ordernoztree_nodes.cmf_created_atztree_nodes.cmf_modified_atztree_nodes.sys_typeztree_nodes.textT)simpler   r  )re   rd   r   )rS  reverse)
operatorr  rp   r  r  r  r   r  r   sort)
r   node_idr  sort_byinclude_contentr  	node_listr   r   noder-   r-   r.   _macros_page_tree_node_list_	  s$    

z+CmfActiveEntity._macros_page_tree_node_listrX   )re  c             C   sR   | j ||||d}|d8 }|dkrNx*|D ]"}|jr(| j|j||||d|_q(W |S )N)r  r  r  rX   r   )r  re  r  r  r  )r  r  r    r5   r  )r   r  re  r  r  r  r  r  r-   r-   r.   r    {	  s    

z$CmfActiveEntity.macros_page_tree_getc             C   s   |  | jj||| _d S )N)_replace_attach_urlr'  r'   )r+   r   
new_attachr-   r-   r.   r{  	  s    z#CmfActiveEntity._replace_attachmentc             C   s4  ddl m} | d k	r0| |jj|jj} |jj| krL| |jj|jj} n,||jj| krx| ||jj|jj} |jr|jj| kr| |jj|jj} n2|jr||jj| kr| ||jj|jj} |jr|jj| kr| |jj|jj} n6|jr0||jj| kr0| ||jj|jj} | S )Nr   )parse)	Zurllibr  r  r5   r'   ZurlZquoteZurl_previewZurl_preview_img)r'  r   r  r  r-   r-   r.   r  	  s$    


z#CmfActiveEntity._replace_attach_urlc             O   s  | j r tjj| df|| nt| dr| jjrtjj| df|| | jjr| jdkr| jjdkrtjj| df|| n| jdkr| jjdkrtjj| df|| nj| jdkr| jjdkrtjj| df|| n<| jdkr| jdkr| jjdkrtjj| d	f|| t| d
r2| j	jsHt| dr^| j
jr^tjj| df|| | jjr~tjj| df|| t| dr| jjrtjj| df|| t| drt| dr| jjs| jjrtjj| df|| tjj| df|| d S )NZcreatedr   Zchanged_statusrk   closedZreopenedri   Zwork_startedZwork_stoppedr   r   assignedZmovedresult_textZresolvedr  r  Zsharedupdated)r   rL   r  r  r   r   rw   r8   r   r   r   r   r  r  r  )r+   r{   r|   r-   r-   r.   _do_event_save	  s2    

zCmfActiveEntity._do_event_savezBaseModel:custom_field_sync)Zchannelc       
      K   s  t d ddlm}m} tt| d  }||d}t }xRtjj	dgdD ]<}t|j
jd||j
j< |jj||j
j d	< |jj||j
j d
< ||j
j d
 dr|jrd||j
j d< nd||j
j d< |jj||j
j d< |jj||j
j d< |jj||j
j d< |jj||j
j d< |jj||j
j d< |jjsR|jj||j
j d< |jjsp|jj||j
j d< |jjsN|jj||j
j d< qNW g }x&| D ]}	||j|	|d qW || |  t d d S )NzI====================================custom_field_sync_update_models STARTr   )CmfCustomClassCmfCustomFieldr  )r  r   )r   )r   r?   
field_typeZM2MTrT   rP   placeholderrJ   rQ   rC   rE   rL   rF   r\   )rF   zG====================================custom_field_sync_update_models END)rq   rW  Zcmf.models.base_modelr  r  varsrL   dictZCmfCustFieldr   r   r'   r?   r  rG  rT   r  rJ   rQ   rC   Zfield_readonlyr   rF   r\   rF  rp   Z	from_dictZmerge_fieldsZreload_models_and_fields)
datar|   r  r  r  Zcustom_classra  Z
cust_fieldZcustom_fieldsZcustom_field_datar-   r-   r.   custom_field_sync_update_models	  s<    




z/CmfActiveEntity.custom_field_sync_update_modelsr   c          	   C   sz   t jr| jr| jjjdksd S t jt jjjdg|| jj| jddt j| jjjd}t	d|d  ||d |d gd d S )	NrN   project_notifyT)rw   )ZinitiatorSessionTabIdZinitiatorCurrentPersonactionZinitiatorActionZinitiatorObjIdZinitiatorObjChangedFieldsu   initiatorСomponentId	projectIdzproject_notify-r  )ZroomZevent_persons)
rq   Zsession_tab_idr   r'   r   rr   r5   keysZcomponent_idZcmf_emit_event)r+   Zinitiator_actionZeventr-   r-   r.   r  	  s    
zCmfActiveEntity.project_notifyc             C   s   dS )u   
        Экран по умолчанию если нет никаких правил и схем экранов

        Returns:
            CmfUiForm: системный экран по умолчанию
        Nr-   )r+   r-   r-   r.   _get_default_ui_form	  s    z$CmfActiveEntity._get_default_ui_formZinline_save)tmp_objr   create_forminclude_deletedis_public_formui_form_modec         	   O   s  | d| j }	|}
|s>| j|dddddddgd	d
|}|rL|jrLd	}
| j|||	|d}|rfd}t|prddg}|d |d |d |d |d |r| dg }x|D ]}|| dg  qW | 	|}xB|D ]:}|t
jkrt
j| |d t
jkrt
j|d  qW | j||d|
d|}|r|jrZd|j |_||_|d |_|d |_||_|jsttdrtjj||d d}|S )ux   
        fields - список мета-правил для указания какие поля грузить
        r8  r3   r   zproject.ui_form_schemezproject.cust_field_conf_schemezproject.logic_prefixr  r   T)r   r  )r  tmp_is_public_formtmp_ui_view_formr  Zbutton_saver   r   r(   r  ui_group_fieldsr   r<  r  )full_fields_loadZmapperr  zDELETED r   r
   CmfAutomationUiForm)Zcmf_ui_form)r   rU  r   sgetr  rb  r   r   r   Z_build_load_planrq   Zapi_hack_fieldsr  Z_getr   rc  Zui_form_nameZui_form_coder  r   rL   r  Zui_get_hook)r   r  r   r  r  r  r  r{   r|   r  Ztmp_include_deletedrc  Z
fields_setgroupsZ
group_datar  Z_field_namer   r-   r-   r.   ui_get
  sP    











zCmfActiveEntity.ui_getc                s  d }|r|j rtt|j }|sJ|r<|r<|jr<|sF| j }ddg}d }|r~ddddddggddd gg}dddd g}dd| jgdd	d|jj	ggd	d
d ggddd
|j
j	gdd
d ggdd
|gdd
|gdd
|jj	gg}	|r|	| tjjddd	g|	dd}
x:|D ]2}x"|
D ]}|j|kr|j}P qW |rP qW |sJ|  }d }t|jj	}d}|rt|jj	}|jrt|jj	}t|j
j	}|rt|j	}|r|r|tjkr|jr|tj| krtj| | }||kr||| kr||| | kr|| | | }|s||rnt }|j|d< |j|d< |j	|d< tj|j	|d< tj|j	|d< |r||r|tj||||\}|d< x@|D ]8}||d krt |d |< |d | ||  qW t|j	}tj|st tj|< tj| |st tj| |< tj| | }||kr<t ||< ||| krXt || |< ||| | |< |S nt j|dS |S )Nr   rQ   r   crud_choicer   r   z==r  Zlogic_typesr   r   r  r8  r_  ztarget.ui_form_jsonT)r   r   r  Noner   r
   r<  r  ra  Zcust_field_config)r  )r   ZAPPZget_cache_projectr;   r_  rU  r   r   r3   r5   r   rp   rL   ZCmfUiFormSchemeRulerv  r  targetr  r`  Zcache_cust_field_config_schemer  r   r
   Z	CmfUiFormr  Zui_fields_jsonZCmfCustFieldConfSchemer   r   r$   rb  )r   r  r  r  r  Zui_formZtmp_projectZcrud_choice_orderZcrud_choice_filterr   Zui_form_scheme_rule_listr  Zui_form_scheme_rulerc  r   Z	scheme_idZproject_logic_typerS   Z
ui_form_idZconf_scheme_cachera  Zui_field_name)r,   r-   r.   rb  ;
  s    








*






zCmfActiveEntity._build_ui_formc             C   s   | j jr| j jdkr| jsdddd ggdd| jgggdddd ggdd| jgggdddd ggdd| jgggddd	gg}ddddg}tjj	||dgd
}|r|j
r|| _qtjj	d	d| _nd | _d S )Nrk   r   r   r   r   r   
is_defaultr   T)r   r   r   )r   )r8   rw   r   r  r3   r   r   rL   ZCmfResolutionr   r  )r+   r   r   r  r-   r-   r.   rg  
  s    
z CmfActiveEntity._calc_resolution)rh   )NTTF)NNNNN)NN)NN)NNNNNF)NNNNN)F)r   F)F)FNF)NrX   FNF)r   )FNFN)r/   r0   r1   ZabstractZfields_orderZorderingZ	api_allowcommonr   cmf_active_entityr	   Zapi_methodsZessential_child_modelsr3   r   Z	CmfStatusr   ZFieldr   r   r   r   r   r   ZCmfRelationr   Z	CmfStr256r   ZCmfStr64r
   ZCmfGenericRelationr   r   ZCmfGenericM2Mr   r   rc   r   r   ZCmfGenericBackrefrx  r   ZCmfChoiceIntr   Z	CmfChoicer   r   r   r   r   r   r   r   r   r   r  r   Z
is_penaltyr8   r6  ZCmfObjectJsonrs  ru   Z
CmfBackrefr  rv   propertyr}   r~   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   classmethodr   r   r   r  r   r  setterr   r  r  r   r!  r"  r$  r%  r,  r-  r.  r/  r0  r1  r2  r3  r5  r9  r:  rL  rM  rN  r  r!   rV  r]  r^  rZ  rd  r   rk  rr  r   rt  r   rv  r~  r  r;   r   r   r  r  r  r  r[  r  r  r7  r  r  r  r  r  r  rY  r  r\  r   r  r   r  r  staticmethodr  rf  r  r  r  r   r    r{  r  r  Zon_server_eventr  r  r  r  rb  rg  r2   r-   r-   )r,   r.   r	      s\  
	
::

	C  * 1i#C	-
(W	
N	B
( 
9$!zQ"0	 H$
4hr	   rY   )deploy_jobs)r   ri  r   r   r  r   r   modulesr   Z
sqlalchemyr   Zsqlalchemy.sqlr   Zdateutil.relativedeltar   Zcmf.includeZcommon.fields.cmf_active_entityr  Znot_in_any_listsr  r	   rn   r   r  r-   r-   r-   r.   <module>   sF                        7