U
    e                     @   s2   d dl T d dlmZ d dlZG dd dejZdS )    )*)cmf_project_perm_schemeNc                       s   e Zd ZdZ fddZ fddZ fddZedd	 Zed
d Z	e
edddd ZededddZededddZ  ZS )CmfProjectPermSchemeNc                    s   t j  | jrt jjdd}ddddddd	d
dddddg}t jj||dD ]6}t  }| |_|D ]}t||t	|| qb|
  qLt j
||S )Nsystem:defaultcodeproject_permissionaccess_project_roleaccess_membersaccess_local_useraccess_owneraccess_owner_assistantaccess_authoraccess_project_owneraccess_responsibleaccess_sdesk_clientaccess_anonymousaccess_guestaccess_sharelink_anonymousparentfields)modelsr   trigger_reloadis_newgetCmfProjectPermSchemeRulelistr   setattrgetattrsavesuper)selfargskwargsdefault_schemerule_fieldsdefault_rulerulefield	__class__ 3./modules/project/models/cmf_project_perm_scheme.pyr        s*    
      
zCmfProjectPermScheme.savec           
         s   | j }t j||}|rtjjdd}ddddddd	d
dddddg}tjj||dD ]:}t }| |_|D ]}	t	||	t
||	 qj|jdd qT|S )Nr   r   r   r	   r
   r   r   r   r   r   r   r   r   r   r   r   T)Zsave_import)r   r!   _save_importr   r   r   r   r   r   r   r   r    )
r"   r#   r$   r   resr%   r&   r'   r(   r)   r*   r,   r-   r.   3   s,          z!CmfProjectPermScheme._save_importc                    s   | dd}| dsTtjj| dgd}|r~ddd |D }td| d	d
 n*tjj| ||dD ]}d |_|jd	d qftjj| ||dD ]}|j	|| qt
 j	||S )NZTEXKOM_db_deleteFname)project_perm_schemer   z, c                 S   s   g | ]}d |j  d qS )")r0   ).0pr,   r,   r-   
<listcomp>L   s     z/CmfProjectPermScheme.delete.<locals>.<listcomp>u   Невозможно удалить Схему проектных прав, она используется в проектах: T)abort)r1   include_deletedinclude_system)Z	only_data)r   r7   r8   )r   r   
CmfProjectr   join	cmf_alertr1   r    r   deleter!   )r"   r#   r$   r7   Zused_projectsZused_projects_strprojectr(   r*   r,   r-   r<   G   s    
zCmfProjectPermScheme.deletec                 C   sZ  t   }i i i i i i i i i i i i d}i }tjjddddgdD ]}t t i t t t t t t t t t d}i }i }tjjdd|gd	d
gdD ]f}|jr|jsqg }	|jD ]4}
|
jdkr|
j	
 D ]}|	| qq|	|
 q|	sq|	||jjj< q|jjj|krPtjj|jddddddddddddddddgd||jjj< ||jjj D ]x}|jr|d |jjj |jr|d |jjj |jr|d |jjj |jr|d |jjj |jr|d |jjj |jr|d |jjj |jr(|d |jjj |jrD|d |jjj |jr|jrj|d |jjj njtjjdd }|jjj|d! krt |d! |jjj< ||jjg D ]"}|d! |jjj |jj q|jr|d |jjj |j r6tj!" }|jj|krt ||jj< ||jj |jjj |j#rR|d |jjj |j$r|j%jj|krzt ||j%jj< ||j%jj |jjj |j&D ]:}|jj|krt ||jj< ||jj |jjj q|j'rf|j'D ]}|jj(d"r.|jj|krt ||jj< ||jj |jjj n4|jj|krJt ||jj< ||jj |jjj q|j)r^|j)D ]`}|jj|krqt||jj D ]:}|jj|krt ||jj< ||jj |jjj qqtq^|* D ],\}}||kri ||< ||| |jj< q|* D ]\}}||| |jj< qq@|t+_,t-.d#t   |  d$ d S )%N)r   access_sdesk_publicaccess_sdesk_privater   r   r   r   access_executorsaccess_followersr   r   access_list_ownerr1   	cmf_ownercmf_owner_assistantsservicedesk_publicr   r   =memberszproject_role.codefilterr   Z
CmfCompanyr	   r
   r   r   r   r   r   r   r@   project_permission.coder   r   r   rA   r   rB   r   r>   zsdesk-client:defaultr   r?   zvar:zLoad time _PROJECT_PERM_DATA: Zsec)/timer   r9   r   setCmfProjectRoleAssignrH   project_role
class_nameZpersonsloadappendidvaluer1   r   r   addr   r   r   r   r   r   r@   rA   rB   r   rE   ZCmfProjectRoler   r   r   ZCmfPersonGroupZguest_groupr   r   rC   rD   r
   
startswithr	   itemsr   _PROJECT_PERM_DATAgdebug)clsZ
start_timeZ	perm_dataZloaded_scheme_rulesr=   Zproject_permsZproject_user_permsZproject_role_membersrZ_membersmr4   r(   Zsdesk_client_rolememberZguest_person_groupZproject_owner_assistantZroleZuser_idpermZperm_funr,   r,   r-   load_project_permission_dataW   s    


         	 



$
z1CmfProjectPermScheme.load_project_permission_datac                 C   s   t d tdd  d S )Nz"project_permission::reload triggerCmfProjectPermScheme:changed)printZcmf_emit_server_event)r[   r,   r,   r-   r     s    z#CmfProjectPermScheme.trigger_reloadra   )Zchannelc                  K   s"   dd }t d dat| d S )Nc                	   S   s~   t d td trrt d datj > tj	  t
jjdtt dddrftd	 t  W 5 Q R X nt d
 d S )Nz*project_permission::reload handler spawned   z,project_permission::reload handler do reloadFz&project_permission::clear_jscache:lockTi  )ZnxZpxz?project_permission::reload handler do CMF_CACHE.flush_jscache()z'project_permission::reload handler skip)rb   rL   sleep_project_permission_changedcmfZappZcmf_contextr   r   r`   ZREDIS_DBZredisrM   strosgetpidrY   rZ   Z	CMF_CACHEZflush_jscacher,   r,   r,   r-   handler  s    


zBCmfProjectPermScheme.on_project_permission_change.<locals>.handlerz(project_permission::reload spawn handlerT)rb   re   ZgeventZspawn)_kwargsrj   r,   r,   r-   on_project_permission_change  s    z1CmfProjectPermScheme.on_project_permission_changeT)r   c           
   
   C   s  |d krt j}|j  tjjdd|jgdd|ggdddddd	d
dgd}|sRdS |jrb|jrbdS |j	rv|t j
krvdS |jr||jkrdS |js|js|js|jr|std| d |r|jr||jkrdS |jr||jkrdS |jr||jkrdS |jr||jkrdS |jr,||j kr,dS |jrztjjdd|gdd|jggdgd}|D ]}||j kr\ dS q\|sdS tjj|dgd}	td|	j d|j d| d S )Nr   rG   rK   r	   r
   r   r   r   r   r   r   rI   Tu*   DEV: check_project_role_access Право u_    разрешено для объектного поля, но объект не переданrO   INrH   Fr0   r   r   N   У пользователя нет Проектного разрешения "   " в проекте     для объекта )rY   current_userr1   rQ   r   r   r   r   
user_localr   anonymous_userr   rC   r   r   r   r   r;   Zcmf_owner_assistant
cmf_authorresponsibler
   Z
all_nestedr	   rN   r   rH   CmfProjectPermPermissionCmfPermissionErrorr0   )
r[   r=   r   userobjraise_errorr_   Zrole_assignsZrole_assign	perm_infor,   r,   r-   check_project_role_access_old.  sn    
   





z2CmfProjectPermScheme.check_project_role_access_oldc                 C   sJ  t jst jrdS |d kr&t j}t j}ntjj|dd}|sN|rNtj	|dgd}t
|tjjrb|j}|rt
|tjjrz|j}|}	|}n|jdkrt|j}	nl|jjr|jjs|ddg |jjr|jjr|jjr|jj}	n|jj}	n"|jjr|jjr|jj}	n|jj}	|	| jd kr0t d	| d
|	  dS |jrP|| jd |	 krPdS |jj| jkr|	| j|jj kr|| j|jj |	 krdS |D ]<}
|
| jkr|	| j|
 kr|| j|
 |	 kr dS q|t jkr|| jd |	 krdS |s@|t jkr,|| jd |	 kr,t j|kr,dS || jd |	 krn|jjr^||jjkrndS n||jkrndS || jd |	 kr|j   |jjr||jjkrdS n||jkrdS || jd |	 kr|j!   |j!jr||j!jkrdS n||j!krdS || jd |	 kr\|j"   |j"jrL|j"jr\||j"jkr\dS n||j"kr\dS || jd |	 kr|j#   |j#jr|j#jr||j#jkrdS n||j#krdS |j#jr|j#jrt$|t$dd |j#jD @ rdS n"t$|t$dd |j#D @ rdS || jd |	 kr|j%}|j%jr:|j%j}|D ]\}||jksZ||j"kr` dS |D ]2}
|
|jjks|
dd |j"D krd  dS qdq>|| jd |	 kr||& krdS dD ]x}|| jkr|	| j| kr|| j| |	 kr|'|}||kr dS |D ]"}
|
dd |D kr  dS qqd}t(t drnt j)r\d}t*j+,drnd}|| jd |	 kr|j-r|rdS || jd |	 kr|jj| jd |	 | kr|rdS |D ]*}
|
| jd |	 | kr|r dS q|sdS d}|r|j.}tj/j0|d gd!}t1d"|j. d#| d$| d S )%NT)Zid_onlyrC   rF   r9   root_parent_id	parent_idr   uX   Пропустили проверку Проектных прав для объекта u3   , т.к. проект еще не загружен r   r   r   r   r   r   r@   c                 S   s   g | ]}|j jqS r,   rS   rT   r3   er,   r,   r-   r5     s     zBCmfProjectPermScheme.check_project_role_access.<locals>.<listcomp>c                 S   s   g | ]}|j jqS r,   r   r   r,   r,   r-   r5     s     rB   c                 S   s   g | ]
}|j qS r,   rS   r3   xr,   r,   r-   r5     s     rA   )zvar:responsiblezvar:executorszvar:spectatorsz	var:ownerzvar:owner_assistantszvar:project_ownerzvar:project_owner_assistantsz
var:authorZvar_waiting_forzvar:component_ownerzvar:current_userzvar:all_related_userszvar:followersu   var:Подпискиzvar:project_userszvar:approversc                 S   s   g | ]
}|j qS r,   r   r   r,   r,   r-   r5      s     Frequest_servicedeskz/filesr>   r?    r0   rn   ro   rp   rq   )2rY   Zdisable_permissionsZacl_admin_moderr   current_person__member_ofr   ZCmfAccessListZsubject_full_group_listZcmfutilZget_obj_by_id
isinstancerf   r   ZCmfTyperT   rP   rg   rS   r~   Z
is_definedr   Zload_fieldsZ
is_changedoldrX   rZ   rs   rt   Zsharelink_anonymous_userZsharelink_access_objrC   ru   rQ   rv   rD   Z	executorsrM   listsZget_all_followersZextract_var_objhasattrr   ZrequestpathrV   Zservicedesk_allowr0   rw   r   rx   )r[   r=   r   ry   rz   Zobj_idZproject_id_simplecheckr{   r   Zobj_parent_idZcontainer_idr   lZvar_user_codeZ	var_usersZis_request_servicedeskZtmp_project_namer|   r,   r,   r-   check_project_role_accessw  s   




 









*
$


z.CmfProjectPermScheme.check_project_role_access)NNT)NNNNT)__name__
__module____qualname__rX   r    r.   r<   classmethodr`   r   staticmethodZon_server_eventrl   rg   r}   r   __classcell__r,   r,   r*   r-   r      s&   
 9
H    r   )Zcmf.includeZmodules.project.fieldsr   rL   r   r,   r,   r,   r-   <module>   s   