U
    Sd]D                    @   s  d dl mZ d dlT d dlZd dlZd dlmZ d dlZd dlm	Z	 d dl
Z
d dlmZmZmZmZmZmZmZ d dlmZ d dlmZ d d	lmZmZ d d
lmZ d dlmZ d dlmZ d dlm Z  eee!j" ee!j# ee!j$ f Z%ej&G dd dZ'dd Z(G dd de Z)dS )    )cmf_context)*N)Path)TemporaryDirectory)DictOptionalListCallableUnionTypeIterator)BeautifulSoup)cached_property)commit_all_dsinit_ds)	BaseModel)CmfPluginImportMixin)JiraApi)JiraBaseImportc                   @   s:   e Zd ZU dZeed< eed< eed< dd Zdd Zd	S )
EpicDatauD    Данные используемые при создании epic namekeyproject_keyc                 C   s
   t | jS N)hashr   self r   ./modules/jira/api_import.py__hash__   s    zEpicData.__hash__c                 C   s   | j |j kS r   )r   )r   otherr   r   r   __eq__"   s    zEpicData.__eq__N)__name__
__module____qualname____doc__str__annotations__r   r!   r   r   r   r   r      s   
r   c                    s    fdd}|S )Nc                    s    fdd}|S )Nc                    s~   zjz(| j d   | f||W W BS  tk
rf   |  jd7  _| j jd tjdd Y nX W 5 | j j  X d S )Nz==================    u   Ошибка Texc_info)
cmf_importdpcommitlog	Exception
has_errorsloggingERROR)objargskwargs)funcr   r   r   wrapper(   s    $z3catch_exception.<locals>.decorator.<locals>.wrapperr   )r6   r7   r   )r6   r   	decorator'   s    
z"catch_exception.<locals>.decoratorr   )r   r9   r   r8   r   catch_exception&   s    r:   c                       s   e Zd ZU dZeed< eeef ed< e	dd fddZ
eeeef dd	d
Zeeeeee  dddZdd Zeeeef  dddZedd Zedd Zdd ZedddZee dddZee dddZee edd d!Zed"eeef dd#d$d%Zdd(d)Zed*d+d, Zed-d.d/ Zed0eed1d2d3Z d4d5 Z!ed6dee"d7d8d9Z#ed:d;d< Z$ed=d>d? Z%e&j'dd@dAZ(dBdC Z)dDdE Z*dFdG Z+edHdIdJ Z,eedKdLdMZ-edNdOdP Z.edNdQdR Z/edSdTdU Z0edVdWdX Z1dYdZ Z2d[d\ Z3ed]ed^d_d`Z4ed^dadbZ5edcddde Z6edfddgdhZ7edidjdk Z8edldmdn Z9edoedpdqdrZ:edsdtdu Z;edvdwdx Z<edydzd{ Z=ed|d}d~ Z>eddd Z?edddZ@edddZAdd ZBdd ZCdd ZDdd ZEdd ZFdd ZGdd ZHdd ZIdd ZJed^ddZKed^ddZLed^ddZMed^ddZNdd ZOdd ZPeeQedddZRdd ZSeedddZTdd ZUdd ZVdd ZWdd ZXdd ZYdd ZZdd Z[dd Z\  Z]S )JiraAPIImportu;   Класс загрузки объектов через APIr0   _JiraAPIImport__jira_fieldsN)jirareturnc                    s   t  j|| || _d| _| jjjr*d| _tjjdd| _	i | _
i | _i | _i | _g | _g | _d| _|   td}| jjj|_d | _d S )Nr   	accountIdsoftdevcoder   zatlassian.rest_client)super__init__r=   user_keyconncloudmodelsCmfActivitygetdefault_activityjira_global_settingsZepicsissue_relationssubtasksboardsselected_projectsr0   _prepare_multiprocessingr1   Z	getLoggerr+   loggerZhandlersr<   )r   r=   r4   r5   rR   	__class__r   r   rD   <   s"    

zJiraAPIImport.__init__)r>   c              	   C   s|   | j r| j S | j d}| rFt|}t|| _ W 5 Q R X n0| j	 | _ t|d}t
| j | W 5 Q R X | j S )Nzfields.jsonw+)r<   r+   get_download_pathjoinpathexistsopenjsonloadr=   Z
get_fieldsdump)r   	file_pathfr   r   r   jira_fieldsQ   s    
zJiraAPIImport.jira_fields)model
field_namer>   c                 C   s&   |sd S | j |gd}|r"|d S d S )N)Zfields_namer   )Zimport_shop_fields)r`   ra   resr   r   r   _get_field_name`   s    zJiraAPIImport._get_field_namec                 C   s(   dd l }dd l}|| _ || _tj| _d S )Nr   )	threadingqueueZconfigZIMPORT_THREADSthreading_max_forks)r   rd   re   r   r   r   rQ   h   s    z&JiraAPIImport._prepare_multiprocessingc              	   C   sl   g }ddddddddd	}d
ddd}| j  D ]6\}}d| ||d }|||d|d q0|S )uO    Сопоставление настроек для модели models.CmfTaskr   textprioritystatusZ
alarm_dateZdeadlinecmf_modified_atcmf_created_at)Zsummarydescriptionrh   ri   Zcustomfield_10015Zduedateupdatedcreatedz.namez.watchCountz.votes)rh   watchesZvoteszfields. Nmodel_field	json_path)r_   itemsrJ   append)r   Zissue_settingsZdefault_local_attrs_mappingZadditional_json_pathZcustom_field_keyZcustom_fieldrs   r   r   r   _get_issue_import_settingso   s*    

z(JiraAPIImport._get_issue_import_settingsc                  C   s    dddddddddg} | S )Nr   displayNamerq   emailemailAddressdoes_not_workactiver   )Zuser_settingsr   r   r   _get_user_import_settings   s
    z'JiraAPIImport._get_user_import_settingsc                  C   s    dddddddddg} | S )Nrk   rn   rq   
cmf_authorauthorrg   renderedBodyr   )Zcomment_settingsr   r   r   _get_comment_import_settings   s
    z*JiraAPIImport._get_comment_import_settingsc                 C   sX   dddddddd}||kr$|| S | d	}t|d
kr>dS | j|d
 i ddS )N   ИмяZEmailu   Активныйu   Созданоu
   Автор
   Текстu   Ключ)rw   ry   r{   rn   r~   bodyr   .r(   rp   r   )splitlenr_   rJ   )r   Zjsonpathmappingr   r   r    _get_setting_title_from_jsonpath   s    	
z.JiraAPIImport._get_setting_title_from_jsonpathTc           	      C   s^  |sd S | dD ](}t| ts& d S | |} | s d S q|rvt| trvdddg}|D ]}|| krX| |   S qXdS |st| tri }d| kr| d |d< d| kr| d |d< d| kr| d |d< |S |rZt| trZg }| D ]l}d|kr||d d  qd	|kr"||d	 d  qd|kr<||d  q|r|t| qd
|S | S )Nr   r   rw   r   rp   ry   rx   inwardIssueoutwardIssue,)r   
isinstancedictrJ   listru   r&   join)	r3   rs   to_strra   Z
str_fieldsZ	str_fieldZnew_objresultZrelated_objr   r   r   _get_file_val   sH    






zJiraAPIImport._get_file_valc                    sN  g  t ttt f tg tt f ttd fdd}jdg j 	d}d}|
 r D ]$}|d D ]} qqz|rh qqhdD ]} qq|sd	d
 jjddD d }dd
 jdD d }|std||jtj |std||jtj ddddddg}||jtj  dg d  S )u-    Инициализация настроек )objssettings_funcr`   r>   c                    sz   | D ]p}| }|D ]H} ||d |d< ||d |d< |d |d< |j|d< q |j|d |  S d S )Nrs   Zfile_valrr   titleicon)r   fields)r   rc   r   r   ru   verbose_name)r   r   r`   r3   Zobj_settingssettingr   r   r   r   _get_settings   s    z:JiraAPIImport.tmplt_import_settings.<locals>._get_settingszplugin.plugin.*projectsNidusersc                 S   s   g | ]}|qS r   r   .0r3   r   r   r   
<listcomp>   s     z7JiraAPIImport.tmplt_import_settings.<locals>.<listcomp>r(   limitr   c                 S   s   g | ]}|qS r   r   r   r   r   r   r      s     uS   Не найдено ни одной задачи, импорт невозможенua   Не найдено ни одного пользователя, импорт невозможенz2022-05-22T15:22:22.593+0300r   u!   Электронная почта)rw   ry   r   )rn   r~   r   selectedObjects)r   value)r
   r   r   r   r	   	TypeModelr+   load_fieldsrV   rW   rX   _get_projects_get_project_tasks_simple_getr=   
get_issues	get_usersr/   rv   rH   CmfTaskr|   	CmfPersonr   
CmfCommentru   )r   r   Zdump_dirtaskprojectuserZcomment_exampler   r   r   tmplt_import_settings   sF      z#JiraAPIImport.tmplt_import_settingsc                 C   s   |  | jjd }ddg g gdg}| jjddD ]}t|tjj d D ]f\}}|d s\qJ| 	||d	 }| 
|d d
 |}|d d |d d  |d d d | qJq2|S )NZimport_settingsu   Задачиzcalendar-today)r   r   titlesrows   r   r   rr   rs   ra   r   r   captionr   )Z_normalize_settingsr+   Zjson_settingsr=   r   	enumeraterH   r   r   r   _normalize_jira_valueru   )r   settingsr   issueZnumr   r   r   r   r   preview  s    zJiraAPIImport.preview)r   r>   c                 C   sT   i }|D ]F}|d sq| j ||d dd}| |d d |}|||d d < q|S )uC    Преобразование настроек для модели rr   rs   F)r   ra   )r   r   )r   r3   r   Znormalized_objr   r   r   r   r   _normalize_obj!  s    zJiraAPIImport._normalize_obju:   Обработка исполнителей проекта)settings_usersr>   c                 C   s   i }i }| j |D ]j}|d |d  }}||krDtjj|d||< ||kr^tjj|d||< t| jtj	|| || d qd S )Nproject_nameZproject_member_emailr8   )rx   )leftright)
r=   Zget_project_membersrH   
CmfProjectrJ   r   r   process_any_table_fieldsr+   ZCmfProjectExecutors)r   r   Zproject_name_idsZmember_email_idsZproject_memberr   Zexecutor_emailr   r   r   _process_project_executors-  s    z(JiraAPIImport._process_project_executorssprintkanbanc           
      C   s   dd|j gg}|dr*|dddg n|dd|g tjj|d}| jjjj d|d  }tj	| jtj
|d	 ||||d
|d|ddd|gd\}}	|	r|d	 |_|jdd |S )NZtree_parent_id==completeDatesys_typearchivefilter::r   r   	startDateendDate)r   parenttree_parent	list_typeplan_start_dateplan_end_dateext_idr   Z
filter_objTZsave_import)r   rJ   ru   rH   	CmfFolderr+   pluginsource_hashr   r   CmfListr   save)
r   r   r   Zparent_sys_typer   _filterr   r   Zlist_objnewr   r   r   _process_list<  s*    


zJiraAPIImport._process_listu8   Обработка наблюдателей задачиc                 C   s   | j |d D ]j}| j jjr.| |d }n| |d }|sNtd| ||jks||jks||jkrnq|j	
| qt  dS )u;   Добавляем наблюдателей в задачуr   r?   r   uI   _process_watchers: Не найден наблюдатель задачи N)r=   Zget_watchersrF   rG   _get_personCmfErrorresponsibler}   	cmf_owner
spectatorsru   commit_with_event)r   	issue_objr   Zwatcherpersonr   r   r   _process_watchersU  s    
zJiraAPIImport._process_watchersu#   Обработка вложенийc                 C   s^  ddl m} dd l}t|d  d}d}| r||B}| D ]0}z|dr`W qJ|d d D ]}	|	d |krl qqltj	
|}
tjj|
|d	d
ddgd}|stj| j|d|
d}|jrH|	r| |	d | j |_|	d |_||L}|jdd ||  |jdd |	r8|j|	d ks8tt  W 5 Q R X W qJ   | jjd| tjddd |d7 }Y qJX qJW 5 Q R X | |D ]}ztj	
|d }
tjj|
|d}|stj| j|d|
d}|jr"|jdd |  t |d |j! tj"j#j$% }|&|j'}|(  W n0   | jjd| tjddd |d7 }Y nX q|S )Nr   )RDisk
issue_pathz /attachments/all_attachments.zip/r   
attachmentfilenameimport_originalurlZurl_preview_imgZurl_preview)r   r   r   T)r+   r   r   r   r~   rn   r   size:   Не удалось обработать вложение Z	anonymousr*   r(   	file_name)r   r   r]   ))Zrdisk.rdiskr   zipfiler   rX   ZipFileZnamelistendswithrH   CmfDocument_get_filenameCmfAttachmentrJ   r+   r   r   rE   r}   rk   rY   r   Zupload_filereadst_sizeAssertionErrorr   r.   r1   r2   _get_issue_attachmentsZ
upload_dirshutilcopyZfull_path_fileZCmfRFiler,   Zdata_driverZget_rdZ	get_rfileZ
_file_namemake_preview)r   r   
jira_issuer   r   Zall_attach_zip_patherrorsZmyzipZzip_attach_nameZattach_infoZattach_namer   Zattach_fattachment_infoZrdiskZrfiler   r   r   _process_attachmentse  st    




 z"JiraAPIImport._process_attachmentsuB   Обработка упоминаний пользователейrg   r>   c                 C   sx  ddl m}m} |sdS t|d}|jddidD ]:}z|jdrX| |jd }n||jd	r| |jd	 }|jd
 |jd< |jd	 |jd< n>||jd }||j}| 	|d d 
 }	| |	| j }|jd |jd< |j|jd< d|jd< |jj|jd
< |jj|jd	< W q2 tk
rl }
 z4|  jd7  _| jjd| d|
 tjddd W 5 d}
~
X Y q2X q2t|S )u]   
        Упоминания пользователей
        confluence-userlink
        r   urlparseparse_qsNhtml.parserclassz
user-hoverattrszdata-account-idzdata-usernamezdata-linked-resource-idzdata-linked-resource-id_origzdata-username_orighrefr   	href_origTcmf_convertedr(   u)   Ошибка обработки тега : r   )urllib.parser  r  r   find_allr  rJ   r   query_get_user_info_from_dumplowerrE   r  r   r   loginr/   r0   r+   r.   r1   r2   r&   )r   rg   r  r  Zdoc_souptagr   Z
parsed_urlr  	user_infoer   r   r   _process_mentions  s2    


6zJiraAPIImport._process_mentionsc                 C   sr   |  dD ]T}|dd |kr*|  S |dd |krF|  S || j|kr
|  S q
td| d S )Nr   r   rp   usernameuQ   Не нашли информацию по пользователю в дампе )r   rJ   r  rE   r/   )r   Zuser_idr  r   r   r   r    s    
z&JiraAPIImport._get_user_info_from_dumpu#   Конвертация ссылок)rg   r   c                    s  |s|S t |}|dd D ]x}|jdrF| jjd|  q|drv|jd drv| jjd|  q| jjd|  |dr|jd }n
|jd	 }t	j
|d
d dd }tdt	j
|dd }	|	r(|	d  |d d }
tt fdd|
d }|r(|d }tj|}tjj|dg|d}|r|d	r|jd	 |jd< |j|jd	< d|jd< t|jd	 }|r|d r|d drd|_d|jd< d|jd< d|jd< |dr|jd |jd< |j|jd< d|jd< | jjd|j  qd|jdd kr|jd d
d dd }| |}|r|jd |jd< |j|jd< d|jd< | jjd|j  qt|S )!Nc                 S   s   |  dp|  dS Nr  srchas_attrr  r   r   r   <lambda>      z.JiraAPIImport._process_links.<locals>.<lambda>r  u   Уже обработали r  #u   Это якорь u&   Обрабатываем ссылку r  r   ?r   (/attachment(?:/content)?/(\d+)(?:/)?(.*)r(   r   r   c                    s   |  d kS Nr   rJ   itemZ	attach_idr   r   r!    r"  r   r   )r   r   r   Zsrc_origTZvideoZcontrolsz100%widthZheightr  u   Заменили на z/people/rp   )r   r  r  rJ   r+   rR   infor  
startswithurllibparseunquoter   researchnextr   rH   r   r   r   sgetr   	mimetypes
guess_typer   r   r  r&   )r   rg   r   r  r   Z	text_soupr  r   r   	url_matchattachmentsattachZ
attach_obj	mime_type
account_idr   r   r+  r   _process_links  sd    

 
 





zJiraAPIImport._process_linksu-   Обработка пользователейc              
   C   sN  t  }| dD ]}| j r8d| j_| j   d S z| jjd|  | jj	j
r~|d dkr~| jjd|d   | || jtjj d }d| jjjj d|| j  d}d	}tjjd
d|d gdgd}|s<tjjddd| dgdgd}|s<tjjdd|d gd}|s|d d}t|dkrNdd|d g}	nHt|dkrddd|d gdd|d ggdd|d gdd|d ggg}	tjj|	d}t|dkr|  jd7  _| jjd|d  dt| tjdd | jjd|d   dt| tjddd! |r"|d }n| jd"|d  tj |sd}d}
|d }tjjd
d#| gdr| jd$| d%tj |d d&\}}| d'|
 d&| }|
d7 }
qRtj||| jdd(}|jr|D ]}t ||||  q|j!r
|jr
|jdd) |"dd*g |j#r>||j#krD|j# | |_#n||_#tj$% }tj$& }|j'(| |j'(| d|_)|d+ d, D ]}| jj	j
rd|d-  d}nd|d  d}d| jjjj | }tj$jddd| dgdgd}|stj$jdd|d gdgd}|s.tj$|| jd|d |d.}|jr@|d |_*|j#sP||_#n||j#krl|j# | |_#|jdd) |j'(| q|jdd/ | j j+d7  _+|j,r|j-s|j,.d0s|r|/|j,j0 W q   |  jd7  _| jjd1| tjdd | jjd1|| j  tjddd! Y qX q|rJt1tjj2|gd2 d S )3Nr   import-cancelingu0   Импортируем пользователя ZaccountTypeZ	atlassianu   Неизвестный тип r   r   Fr  r   rx   r   r   r   r   LIKE%r   r    r(   	last_namer      ORZ
first_nameu+   Пользователей с именем z > Tr)   u#   Пользователей с ид r   r   uM   Не нашли пользователя среди существующих ILIKEuQ   Обнаружена учетная запись с дублирующим email u   , добавляем цифру@+)r   r  r+   r   r   rg_member_ofgroupsrt   groupId)r   r+   r   r   import_raw_jsonZ	only_dataz.evateam.ruu@   Не удалось загрузить пользователя )r4   )3setr   r+   	is_cancelri   r   rR   r-  r=   rF   rG   warningr   r   rH   r   r   r   r   rE   rJ   r   r   r   r0   r.   r1   r2   INFOr  ZWARNINGr   setattr
is_changedr   r   CmfPersonGroup
jira_group
user_grouprI  ru   Z
user_localr   imported_object_countrx   rz   r   addr   Zcmf_deferred_taskZregister_persons)r   Znew_user_emailsr   Z	user_dictr   Z
is_createdr   Zpersonsr   r   nr  Zprefix_emaildomainr   rU  rV  Z
group_infogroupr   r   r   _process_users  s    

  (*
 

   
*zJiraAPIImport._process_usersu#   Обработка статусовc                 C   s  |  dD ]}| j r0d| j_| j   dS | jjjrD|d }n|d d }| jjjj	 d|d  }t
jj|d}|sdd	|d gd
d	dgg}t
jj|d}|st
j|d | jd}||_t||_|d |_|jdd | jj  | j jd7  _q
dS )uc   
        Грузим статусы из Jira и сопостовляем с нашими
        statusesr>  NstatusCategoryr   r   r   r   r   r   r   )r   r+   Tr   r(   )r   r+   rO  ri   r   r=   rF   rG   r   r   rH   CmfStatusCoderJ   r   r   get_status_typestatus_typer   r,   r-   rW  )r   ri   rb  r   Zcmf_status_coder   r   r   r   _process_statusesu  s.    





zJiraAPIImport._process_statusesc                 C   s  t  }d}d}| |d D ]}| jjjj d|d  d|d  }d|d  d|d  }tjjdd	|gd
}|d dkrd}	n|d dkrd}	nd}	|stjj|	d}
tj||
| jd}||_|j	dd |s|d dkr|}|s|d dkr|}d| jjjj d|d  d}|||< | j
|d dD ]6}|d r.|d |d d d kr.| || q.tjjdd|gdddggdgdD ]@}tjjdd|jgdd|gdddggd
sq|jdd qq| jjjj d|d  }d|d  }tjj|d}|s(tjjd d}
tj||
| jd}||_||_||_|j	dd tjj|d!D ]}|  qT| D ]t\}}| j rd"| j_| j	   qtjjdd#d$| d$gd
}||d%|| jd&}tjf |}|j	dd ql|S )'u)  
        У простого проекта воркфлоу привязан к issue type 1 к 1
        Поэтому надо получит все типы привязанные к проекту, на каждый тип создать WF и замапить через схему
        Nr   
::SIMPLE::r   (   Simple-схема для проекта r       и типа r   =r   hierarchyLevelr(   task.epic:defaultr   task.agile:defaultdefault.system:defaultrA   r   templater+   Tr   r$  
project_idZusagesZ
issueTypesworkflowr   rb  r?  !=forcer_  softdev:default	scheme_wfr>  r@  rA  r   
logic_typeZtarget_workflowcmf_model_namerv  r+   )r   _get_issue_types_for_projectr+   r   r   rH   CmfWorkflowrJ   r   r   _get_statuses_for_project_create_status	CmfStatusr   rb  deleteCmfSchemeWfdefault_task_workflowZ!default_subtask_workflow_workflowCmfSchemeWfRulert   rO  ri   CmfLogicType)r   Zjira_project_info	issue_mapZdefault_task_wfZdefault_subtask_wf
issue_typeworkflow_ext_idworkflow_namerp  rB   rm  issue_type_ext_idjira_statusri   Zscheme_ext_idZscheme_nameschemerulelogic_type_ext_idrx  	rule_dictr   r   r   #_create_schemewf_for_simple_project  s|    $$
 

 z1JiraAPIImport._create_schemewf_for_simple_projectc                 C   s0  | j jjj d|j d|d  }| j jjj d|d  }tjj|d}t|d }|srtj||d | j d}||_	|j
dd tjjd	d
|gd}|stjjdd|gdd|ggd}|stjjdd
|d gdd
|ggd}|stj|| j |d}||_|d |_|d |_||_||_	|j
|j d |S )Nr   r   r_  r^  r   )r   r   r+   Tr   r   r   r   rp  rg  status_code)rp  r+   r  rl   rM  )r+   r   r   r   rH   r`  rJ   r   ra  rb  r   r~  r   r   rg   r  is_new)r   Zjira_status_datarp  status_ext_idr   r  rb  ri   r   r   r   r}    s6    "

zJiraAPIImport._create_statusc                 C   s<  | j jjj d|d d  }tjj|d}|d d }|sztjjdd}tj|d ||d	d
|| j |d}|jdd t }| j|d dD ],}d|d kr| j jjj d|d  d|d  }d|d  d|d  }	tj	jdd|gd}
d| j jjj d|d  d}|
sxtj
jddd| dgd}tj	j|jdd  dd}|sftj	jdd}tj	||| j d}
|	|
_|
jdd |
||< |d D ]"}|d d  |d< | ||
 qqtjj|d!D ]}|  q| D ]P\}}
tj
jddd| dgd}||
d"|| j d#}tjf |}|jdd q|S )$Nr   jira_workflow_schemer   r_  r-  rt  rA   r   rl   rp   )r   r   rg   rL  r+   rm  Tr   rn  	issuetyper   rd  re  rf  r   rg  r   r@  rA  :r   z:defaultrk  rl  r]  r^  r   ru  r   rw  )r+   r   r   rH   r  rJ   r   r   r|  r{  r  rB   r   r   r}  r  r   r  rt   )r   project_infor   Z	wf_schemeZwf_scheme_inform  r  r  r  r  rp  r  rx  r  r  r  r  r   r   r   _process_wf_scheme  sZ    

$  z JiraAPIImport._process_wf_schemec              	   C   sV   d}t dd4 | j rq>| }|dkr.q>|| |7 }qW 5 Q R X || d S )Nr   FZinit_views_and_dsDONE)r   r+   rO  rJ   _process_issueput)r   issue_queueissue_queue_errorsr  r   r   r   r   _process_issue_fork/  s    
z!JiraAPIImport._process_issue_forku   Обработка теговc           
      C   s0  ddl m} t }| |d D ]F}| j rFd| j_| j   d S |d dr |	|d d  q |D ]}|
dd
d	d
}||ddd}z\dddd| dgdd|gddd| dgg}tjj|d}|stj|d}|jdd W ql tk
r( }	 ztd| d|	  W 5 d }	~	X Y qlX qld S )Nr   )translitr   r>  r   labelsrB  _r#  rp   ruT)Zlanguage_codereversedrE  aliasrF  ""%r   r   r8   r   u*   Не удалось создать тег r  )Ztransliterater  rN  r   r+   rO  ri   r   rJ   unionreplacerH   ZCmfTagr/   r1   rP  )
r   r  r  tagsr   Ztag_nameZ
name_aliasr   Ztag_objr  r   r   r   _process_tags;  s0    

zJiraAPIImport._process_tags)project_structr  c                 C   sZ  t jjdd|d gddgd}|r|jj|d ksF|jr|j|d kr|d  d|d  d|d< | jjd|j	 d	|d   n|js|d |_|
  t jj|d | d
}|st j| j|d |d d}|D ]}t||||  q|drd|_|
  | |d D ]H}| jjjj d|d  }t jj|d}|sht jjddd gdd|d ggd}|st j|d | jdd}||_|d |_	|d|_|j
dd t jj||d}|st j||| jd}g |_|j
dd |dg D ]X}	|	d dkr| jjjrRd| jjjj d|	d d  d}t jjddd| dgd}
nt jj|	d d }
|
rx|j|
 n| jjd!|	  n|	d d"krB| jjjrd|	d# d$  d}nd|	d  d}d| jjjj | }t jjddd| dgd}|r|j| n,| jjd%| d&tjddd' |  jd(7  _ntd)q|j
dd q|    | !| | "| |    | j#|d* | $||_%|j
dd g }| j&' }| j&' }| jj(d+ t)| j*D ]L}| j+j,| j-d,| ||d-d.}|| |.  | jj(d/|  q| /|d D ]"}| j0 rH qV|1| q2|D ]}|1d0 qZ| jj(d1 |D ]}|2  q~d2}|3 s|| 7 }q| jj(d3|  |  j|7  _t j4|d4d5}|j
dd d|_5|j
dd6 | j0 rd7| j_6| j
  d S t7  | 8| |    | 9| | j j:d(7  _:|    |S )8Nr   r   rx  r   r?  z ()u   Проект с именем u8    уже существует! Переименуем в r   r   )r+   r   r   	isPrivateprivater   r   r_  r   T)r   r+   r   rl   r   )r   project_role)r   r  r+   actorstypeatlassian-user-role-actorr  r?   r@  rA  rw   r8   uR   Не удалось привязать пользователя к проекту zatlassian-group-role-actorZ
actorGrouprK  u<   Не найдена группа пользователей u#    для проектной ролиr   r(   u&   Неизвестный тип ролиr  u>   Грузим задачи в несколько потоковr  )r  r  targetr   r5   u.   Параллельный обработчик r  u&   Ждем обработки задачr   u?   Закончили обработку задач, ошибок delmer   r   rM  r>  );rH   r   rJ   rx  r   r   r+   rR   rP  r   r   keysrR  Zperm_policy_get_project_rolesr   r   CmfProjectRolerg   ZCmfProjectRoleAssignmembersr=   rF   rG   r   ru   rT  r.   r1   r2   r0   r/   _calc_progress_process_versions_process_componentsr  _process_permissionsZproject_perm_schemere   Queuer-  rangerf   rd   Threadr  startr   rO  r  r   emptyr   cmf_deletedri   r   _process_boards_process_sprintsrW  )r   r  r  project_objr   	role_infor   roleZrole_assignactorr   Z	sub_groupZissue_processr  r  iprocr   r0   tr   r   r   _process_projectV  s    "

"
"








zJiraAPIImport._process_projectu#   Обработка проектовc              
   C   s^  t jjddjj}|  D ]<}z|d dd | jD kr@W qd }| j rd| j_	| j
  |rt j|dd}|j
d	d
 d	|_|j
d	d t  W  d S |di }|r| || j }n
ddd}|d dkrt jjdd}nP|d dkrt jjdd}n2|d dkr"t jjdd}ntd|d  d| jjjj d|d  |d< |d |jj|d ||d ||d |d}|d }	|	r| |}
|
|d < n0| jjjj d|d! d  }t jj|d"|d < | ||}W q tk
rV   |r"t j|dd}|j
d	d
 d	|_|j
d	d t  |  jd#7  _| jjd$| tjd	d	d% Y qX qd S )&Nr@   rA   r   c                 S   s   g | ]}|d  qS r   r   r   r   r   r   r     s     z3JiraAPIImport._process_projects.<locals>.<listcomp>r>  r  r  Tr   rM  leaddefault_import_jira@evateam.comdefault_import_jirarx   r   projectTypeKeybusinessproject.base:defaultsoftwareproject.agile:defaultservice_deskproject.servicedesk:defaultu$   ERROR! Проекты с типом 3    временно не поддерживаютсяr   r   r   rl   r   r   rx  rg   activityZtask_code_prefixr   r   rL  
simplifiedrv  r  r_  r(   <   Не удалось импортировать проект r   )rH   rI   rJ   r   r   r   rP   r+   rO  ri   r   r   r  r   r   rE   r  r/   r   r   r  r  r  r0   r.   r1   r2   )r   r  r  r  r  project_leadr   rx  r  Zproject_simplifiedr  r   r   r   r   _process_projects  sr    



zJiraAPIImport._process_projectsc           	   
   C   s  d }t jjddjj}|  D ]}zr| j r~d| j_| j	  t j
|dd}|j	dd d|_|j	dd t  W  d S |d	 d
d | jD krW q| jjjj d|d	  |d< |di }|r| || j }n
ddd}|d dkrt jjdd}nP|d dkr t jjdd}n2|d dkr>t jjdd}ntd|d  d|d |jj|d ||d ||d |d}| ||d< | ||}W q tk
r   |rt j
|dd}|j	dd d|_|j	dd t  |  jd 7  _| jjd!| tjddd" Y qX qd S )#Nr@   rA   r>  r  r  Tr   rM  r   c                 S   s   g | ]}|d  qS r  r   r   r   r   r   r   4  s     z7JiraAPIImport._process_projects_box.<locals>.<listcomp>r   r   r  r  r  r  r  r  r  r  r  r  r  u$   ERROR! Поректы с типом r  r   rl   r   r  rv  r(   r  r   )rH   rI   rJ   r   r   r   r+   rO  ri   r   r   r  r   rP   r   r   r   rE   r  r/   r  r  r0   r.   r1   r2   )	r   r  r  r  r  r  r   rx  r  r   r   r   _process_projects_box$  sf    

z#JiraAPIImport._process_projects_boxu   Обработка досокc           
      C   s  |  |d D ]|}| j r6d| j_| j   dS tjj|d d}| jjjj	 d|d  |d< tj
j|d ddd	d
gd}|stj
|d | jd}|d |_|d |_||_||_|jdd |jrv|jD ]}|  q|d d d D ]}tj|d || jdd}|jdd |d D ]D}| jjjj	 d|d  }tjj|d}	|	sXt|j|	 q"|jdd q| j jd7  _t  qdS )z
        https://bcrm.carbonsoft.ru/desk/favorites/Document/DOC-007367#spec-006348-b
        https://developer.atlassian.com/cloud/jira/software/rest/api-group-board/#api-rest-agile-1-0-board-boardid-quickfilter-get
        r   r>  Nr   r_  r   kanban_board_columnsrL  r   r   r  r   r+   r   r-  Tr   ZcolumnConfigcolumns)r   r   r+   r   r]  r(   )_get_project_boardsr+   rO  ri   r   rH   r   rJ   r   r   ZCmfKanbanBoardr   rL  r   r   r   r  r  ZCmfKanbanBoardColumnr`  r   Zmapped_status_codesru   rW  r   )
r   r  boardr   Z	board_objcolZ	board_colri   r  Zstatus_globalr   r   r   r  ]  sH    

 



 
zJiraAPIImport._process_boardsu#   Обработка спринтовc                 C   s0  t jj|d d}t jjdd|gdddggd}t jjdd|gdddggd	gd
}t jjdd}| |d D ]}| j rd| j_| j	   d S | jj
j
j d|d  }t jj|dddddddddg	d}|st j|d| j|d}|jr||_|d |_|d|_|d|_|jr.|j	dd |d dkrl||_|js\d|_|j	dd |jd|_n"||_|d d kr|jd!|_|jr|j	dd t  | jjd"|j d#t|d$   |d$ D ]0}	| jj
j
j d|	 }
t jj|
d%dd&gd}|r|d'r| jj
j
j d(|j }t jj|d)d*d+gd}|s\t j|| jd,}d-|_d.|j d/|j d0|_ ||_!|jr|j	|j" d1 |j#dkrt|j$d2kr|j%&| n|j%&| n4|  j'd27  _'| jj(d3|	 d4|d  t)j*ddd5 q|j	dd t  | j j+d27  _+qnd S )6Nr   r_  r   r   r   r   r   r   tree_node_is_branchr?  list.agile_sprint:defaultrA   r   r>  r   r   rx  r   r  r   r   ri   r  T)r   r   r+   rx  r   r   r   stateclosedCLOSEDr{   ZIN_PROGRESSu0   Добавляем задачи в спринт r  issueslistscache_status_typer   z::comment-sprint:	log_levelrg   r   r  rD  uB   Задача была в архивном спринте <a href="" target="_blank"></a>rM  r(   u-   Неизвестная задача issue_id=u    в спринте r   ),rH   r   rJ   r   r  _get_all_sprintsr+   rO  ri   r   r   r   r   r   rx  r   r   r   rS  r   r  rp  Zget_default_statusr   rR   r-  r   r   r   r   r  r  rg   r   r  r  r  r  ru   r0   r.   r1   r2   rW  )r   r  r   Zsprint_folderarchive_folderZsprint_logic_typer   r   Z
sprint_objZissue_idZissue_ext_idr   comment_ext_idcommentr   r   r   r    s~    "

     
$*zJiraAPIImport._process_sprintsc                 C   s$   |sd}|sd}| d| d| S )Nu   Не указаноr  u    ➔ r   )r   r   	old_valueZ	new_valuer   r   r   _simple_html_diff  s
    zJiraAPIImport._simple_html_diffc                 C   sn   |dkrd S d| j jjj d| d}tjjddd| dgd}|sj| j jd| d |  jd	7  _|S )
Nunknownr   r   r@  rA  r   u9   Не найден пользователь ext_id LIKE "%z%"r(   )	r+   r   r   rH   r   rJ   rR   errorr0   )r   r   r   r   r   r   r     s    zJiraAPIImport._get_personu,   Обработка журнала работ)r   c                 C   s*  dd l }| jjd | |D ]}t }d|d< | j|d< | |d | j |d< |d |d< | |d	 | j |d
< ||d< |d |d< |d d |d< |dd|d< | jj	j	j
 d|d  |d< ||d< d|d< tjj|d d}|s tjf |}|jj|j|jjd |_|jdd q d S )Nr   u*   Загружаем журнал работr  ri   r+   r~   r}   r   updateAuthorcmf_modified_byr   started
start_dateZtimeSpentSeconds<   
time_spentr  rp   rg   r   r   r   rL  Zremaining_estimater_  )ZminutesTr   )datetimer+   rR   r-  _get_issue_worklogsr   r   rE   rJ   r   r   rH   ZCmfTimeTrackerHistoryr   r   Z	timedeltar  Zend_dater   )r   r   r   r  worklogZtimetracker_historyhistoryr   r   r   _process_issue_worklog  s.    


z$JiraAPIImport._process_issue_worklogc                 C   sR  |  |D ]@}| jjjj d|d  }tjj|d}|rD|jsDq
|sVtj||d}| |d | j	 |_
|j
|_| |d | j	 |_|d |_|d |_| |d	 |_| |jj|||_||_|d
r@|d
 d dkrtjj|d
 d d}|j| d|_n0| jjd|d
  tjddd |  jd7  _q
|jdd q
d S )Nr   r   r_  )r   r   r~   r  rm   rn   r   Z
visibilityr  r  r   r8   TuL   Ошибка обработки приватного комментария r   r(   r   )_get_issue_commentsr+   r   r   rH   r   rJ   r   r   rE   r}   r   r  rj   rk   r  rg   r=  r   rL  r  r   ru   r  r.   r1   r2   r0   r   )r   r   r   r  r   Zcmf_commentr  r   r   r   _process_issue_comments  s0    


 z%JiraAPIImport._process_issue_commentsu0   Обработка плагинов задачиc           	      C   s   |j jp
d}| |D ]}|d dkr|d rt|d}|jdddid	}|d d
D ]N}|sbqX|drx|d}n|jdddid	}||dd   || qX|| t||j _q|j	r|j
dd d S )Nrp   r   z&com.railsware.SmartChecklist.checklistr   r	  Zulr
  ztox-checklistr  
-liztox-checklist--checkedr(   Tr   )rg   r   _get_issue_propertiesr   Znew_tagr   r.  ru   r&   rS  r   )	r   r   r   rg   Zissue_propertysoupZ	checklistvalr  r   r   r   _process_properties  s"    


z!JiraAPIImport._process_propertiesu   Обработка задачиc           "      C   sh  d}| j jjj d|d d d  }tjj|d}|sRtd|d d d  g }d	d
 | jtjj	 d D }|d d D ]}d}	|dr| 
|d | jtjj	 d }	n| j jd|  |d |	dd}
|d D ]n}|d }||d }|r
|d r
d}| ||d |d }d|
kr4||
d< q|
d  d| |
d< q||
 q~| 
|| jtjj	 d }tjjdd| j jjj d|d d d  gdgd |d< |d j|d!< | j|d"< d#|d$< | j jjj d|d  |d< |d |d%< |d d&r| |d d&| j|d'< |d' s|  jd7  _| j jd(|d d& tjd#d) | j jd(|d d&| j tjd#d#d* |d d+r*| |d d+| j|d,< |d, s*|  jd7  _| j jd-|d d+ tjd#d) | j jd-|d d+| j tjd#d#d* |d d.r| |d d.| j|d/< |d/ s|  jd7  _| j jd0|d d. tjd#d) | j jd0|d d.| j tjd#d#d* ||d1< |d r|d2 d3 |d< |d d4g }|D ]}| j jjj d|d  }d5|krdd|d i|d6< | j jjj d|d5 d  |d5 d< || j|< nJd6|krd|d i|d5< | j jjj d|d6 d  |d6 d< || j|< q||d1< |pg }|d d1}|r*| j jjj d|d  }| j|g }|| j jjj d|d   || j|< d| j jjj d|d d7 d  d}tjjddd8| d8gd9|d:< | j jd;|  tj| j tj|dd<|d gd=\}}|| ||7 }|  |j!j"|_!| #|j!j"|||_!|d d> d? r| $|| | j%d@r&|d dA d? r&| &|| |D ]}|j'| q*|d dBg |d dCg  D ]l}| j jjj dD|d  }tj(j|d}|s| j jdE| tjd#d#d* |  jd7  _n|j'| q^|d dFg D ]l}| j jjj dG|d  }tj(j|d}|s:| j jdH| tjd#d#d* |  jd7  _n|j'| q||_)|j*rd|j+d#dI t,  |d dJ dK r| -|| |d dLg }|rzt.| j || W n   | j j/dM Y nX | 0|| | j jjj dN|d  } tj1j| d}
|
stj1| | j dO}
||
_2| j3j4 dP|d  }!dQ|! dR|! dS|
_!dT|
_5|
j+d#dI |
j67  |S )Uu   
        Общая логика обработки которая потом разделяется на задачи и эпики
        r   r   r   r   r   r_  u$   Не проекта с ключем r   c                 S   s   i | ]}|d  |qS )r   r   )r   fieldr   r   r   
<dictcomp>3  s      z0JiraAPIImport._process_issue.<locals>.<dictcomp>Z	changelogZ	historiesNr~   u   Аудит без автора rn   r(   )rk   r}   r  rt   r  rr   rp   Z
fromStringZtoStringrg   z<br>r   r@  %::ri   rb  r?  r  r  TZapprovedrB   reporterr}   u*   Не найден автор задачи r)   r   Zcreatorr   u?   Не найден ответственный по задаче assigneer   u6   Не найден исполнитель задачи r   renderedFieldsrl   Z
issuelinksr   r   r  rA  r   rx  u2   Пытаемся создать задачу из r   r   r  totaltimeTrackingEnabledr  ZfixVersionsZversions
::version:u!   Не найдена версия Z
components::component:u%   Не найден компонент r   ro   Z
isWatchingr  u/   Не удалось привязать тегиz
::comment:r  zbrowse/u<   Задача импортирована из Jira: <a href="r  r  rD  )8r+   r   r   rH   r   rJ   r   r   r   r   r   r   rR   rP  r  ru   r~  rb  rK   r   rE   r0   r.   r1   r2   rM   rN   r  r-  r   r   r  r  rg   r   r=  r	  rL   r  r  r   rL  rS  r   r   r   Zprocess_tagsZexcepionr  r   r   r=   r   r  r,   r-   )"r   r   sprintsr  Zproject_ext_idr   commentsZjira_map_fieldsr  r}   r  r*  r   r  ZdiffZnormalized_issueZissue_linksZ
issue_linkZlink_ext_idZissue_parentparent_ext_idZ	sub_tasksr  r   r  r   versionr   Zversion_obj	componentZ	comp_listr  r  r  r   r   r   r  %  s    "



,

 
$. 
$. 
$.

&
&
 
& 
 $
zJiraAPIImport._process_issueu&   Обработка всех задачc                 C   sD   | j  }|D ]0}| j r4d| j_| j   d S | | qd S )Nr>  )r=   r   r+   rO  ri   r   r  )r   r  r   r   r   r   _process_issues  s    


zJiraAPIImport._process_issuesu3   Обработка связей всех задачc                 C   s  | j jdt| j  | jD ]}| j  rFd| j _| j    dS tj	j
|d}| j| D ]B}tj	j
|dgd}|s| j jd|  q^||_|jdd	 q^q | j j  d
dddd}| j jdt| j   | j D ]\}}| j  rd| j _| j    dS zB| j jjj d|d d  }|
|d d }	|	r^tjj
|	d}
ntjj
|d}
|
stjj
dd|d d gd}
|
stj|| j |d d d}
|d d |
_|d d |
_|
jdd	 | j jjj d|d  }tjj
|d}|stj|| j d}tj	j
|d d d|_tj	j
|d d d|_|
|_|jdd	 W q   |  jd7  _| j jd|d  d |d  d!|d  tjddd" Y qX q| j j  dS )#uD   
        Постобработка связей задач
        u   Подзадачи: r>  Nr_  parent_taskr  uq   Не удалось связать задачи, возможно задача не попала в импорт Tr   zsystem.finish:finishzsystem.duplicatezsystem.linkzsystem.clone)ZBlocksZ	DuplicateZRelatesZClonersu   Связи: r   r  r   r   rA   r   r   )r   r+   r   ZinwardZoutwardr  r   r   r   r(   u.   Не удалось создать связь z out=z in=r   )r+   rR   r-  r   rN   rO  ri   r   rH   r   rJ   rP  r!  r,   r-   rM   r  rt   r   r   ZCmfRelationTypeZin_type_nameZout_type_nameZCmfRelationOptionZin_linkZout_linkrelation_typer0   r.   r1   r2   )r   r  r!  Zchild_ext_idZ
child_taskZ	map_namesZrelation_ext_idZissue_relationr   Zrelation_coder"  Z
rel_ext_idZrelation_optionr   r   r   _process_relations  sv    





&  z JiraAPIImport._process_relationsu)   Обработка компонентовr  c              
   C   s4  t jj|d d}t jj|dd}| |d D ]}z| j rZd| j_| j  W  dS | jj	j	j
 d|d  }t jj|d}|st j|| jd	d
}t jjdd|_||_|d |_|dd|_||_|jr|jr|jd	d | j jd7  _W q0   |  jd7  _| jjd| tjd	d	d Y q0X q0dS )uG  https://docs.atlassian.com/software/jira/docs/api/REST/1000.824.0/#api/2/project-getProjectComponents
        Пока грузим как списки, после доработки будут отдельные обекты

        Args:
            project_info (dict): проект из джиры как есть
        r   r_  r   )r   r   r   r>  Nr  Tr   r+   r   r  rA   r   rl   rp   r   r(   u3   Ошибка загрузки компонента r   )rH   r   rJ   r   _get_project_componentsr+   rO  ri   r   r   r   r   r  rx  r   r   rg   r   r   rS  rW  r0   r.   r1   r2   )r   r  r  Zsprint_listr  r   Zcomponents_listr   r   r   r    s.    


z!JiraAPIImport._process_componentsu   Обработка версийc              
   C   s  t jj|d dgd}t jjd|d}t jjd|d}| j|d dD ]n}z0| j rtd	| j_| j  W  d S | jj	j	j
 d
|d  }t jj|d}|st j|| jdd}t jjdd|_||_|d |_|dd|_|jj|_|jr|jr|jdd |d r||_n||_|jrP|d s:|d rF|d n
|d |jrl|jrl|jdd | j jd7  _W qF   |  jd7  _| jjd| tjddd Y qFX qFd S )Nr   z"scheme_wf.default_release_workflowr  release)r   r   r   r   rn  r>  r  r_  Tr$  zlist.release:defaultrA   r   rl   rp   r   ZarchivedZreleasedr  ZOPENr(   u+   Ошибка загрузки версии r   )rH   r   rJ   r   _get_project_versionsr+   rO  ri   r   r   r   r   r  rx  r   r   rg   rv  Zdefault_release_workflowrp  r   rS  r   Zset_default_statusrW  r0   r.   r1   r2   )r   r  r  Zrelease_folderr  r  r   Zversion_listr   r   r   r  0  sB    





zJiraAPIImport._process_versionsu   Обработка аудитаc                 C   s   dS )u)   
        Грузим аудит
        Nr   r   r   r   r   _process_auditW  s    zJiraAPIImport._process_auditu2   Обработка логических типовc                 C   s  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 ]}| jjd|  | j rd| j_| j   dS | jjjj d|d  }t	j
jddd| dgd}|rqp||d }|rPt	j
jdd|d gdgd}|jr4d| |j |_nd| d|_|jdd qp| jjd|d  d t	j
jdd |d  gdgd}|r|jrd| |j |_nd| d|_|jdd qp| jjd! d}| jjjr|d" d#krd}n|d" d$krd}n|d% rd}t	j
jdd|gd}td| d|d  |d& d'|d(}t| jt	j
| t  | j jd$7  _qpdS ))u$   Маппим issueType в logic_type   Подзадачаztask.sub:default)r   rB   Z	UserStoryztask.userstory:defaultz
Task Agilerj  Bugztask.bug:defaultEpicri  )zSub-taskZSubtaskr)  ZStoryu   ИсторияZTasku   Задачаr*  u   Багu   Ошибкаu   Эпикr+  issue_typesu-   Обрабатываем тип задачи r>  Nr   r   r   r@  r  ::%r   r   rB   r   r?  TrM  u   Ищем по имени "r  rF  u*   Не нашли, создаем новыйrh  r$  r(   Zsubtaskrl   r   )r   r   rg   ry  rm  )r   r+   rR   r-  rO  ri   r   r   r   rH   r  rJ   r   stripr=   rF   rG   r   r   r   r   rW  )r   Z	name2coder  r  rx  Zlogic_type_dictZtemplate_coderm  r   r   r   _process_issue_type_  s~    



z!JiraAPIImport._process_issue_typeu2   Обработка бизнес-процессовc                    s  i }  dD ]}|||d < q  dD ]t} j rRd j_ j   dS  jj|d d    jjjj d|d d  d|d d  }t	j
j|d	st	j
jd
d}t	j
|| jd|d _|d d _jdd |d D ]} ||d   qt	jjddgdddggdgdD ]@}t	jjdd|jgddgdddggdsbq0|jdd q0|d D ]} j rd j_ j    dS  jjjj dj d|d  }t	jj|d}	|	st	j| jd}	|d |	_|d |	_ fdd|d D }
t	jjdd|
gd|	_t|	jt|
ksNtd jjjj dj d|d   }t	jj|d	|	_|	jdd qz j jd!7  _q*dS )"u   Импортируем workflowr]  r   	workflowsr>  Nr   r   ZentityIdr_  rj  rA   rl  rl   Tr   rp  r   r   rb  r?  rq  r   rr  Ztransitions)r   rp  )r   rp  r+   c                    s*   g | ]"} j jjj d j d | qS )r   )r+   r   r   r   )r   str   rp  r   r   r     s     z3JiraAPIImport._process_workflow.<locals>.<listcomp>fromINuN   DEV: Fatal Вероятно, сломали создание статусов!tor(   )r   r+   rO  ri   r   rR   r-  r   r   rH   r{  rJ   rg   r   r}  r~  r   rb  r  r   ZCmfTransZstatus_fromr   r   Z	status_torW  )r   Zjira_statusesr  Zjira_workflowZworkflow_idZtemplate_workflowri   Zjira_transitionZtransition_ext_idZ
transitionZstatus_from_ext_id_listZstatus_to_ext_idr   r2  r   _process_workflow  s\    

,

 

"

"zJiraAPIImport._process_workflowu    Обработка схем БПc              
   C   s  |  dD ]}| j r2d| j_| j   d S | jjjj d|d  }tjj	dd| dgd}|s|t
d	|d  |d
 |	dd| jjjj d|d  ddi||d}t| jtj|dd|d g\}}|stjj|dD ]}|  q|d  D ]\}}	| j r0d| j_| j    d S | jjjj d| }tjj	ddd| dgd}
tjj	dd| jjjj d|	 dgd}|
|d|| jd}tjf |}|jdd q| j jd7  _q
d S )Nworkflow_schemer>  r   ZdefaultWorkflowr   r@  r-  r   u+   Не импортировался workflow r   rl   rp   r   rB   rt  )r   rg   r   rm  r  Zdefault_subtask_workflowr   ru  ZissueTypeMappingsr  r   rw  Tr   r(   )r   r+   rO  ri   r   r   r   rH   r{  rJ   r   r   r   r  r  r   r  rt   r  rW  )r   r7  Zdefault_task_workflow_ext_idr  Zscheme_dictZworkflow_scheme_objr  r  r  r  rx  rp  r  r   r   r   _process_workflow_scheme  sX    


 

(z&JiraAPIImport._process_workflow_schemer8   c              	   C   s   | j  | d}| j  | d}| r8d S t|d6}| D ](}| j  jd7  _|t|d  qJW 5 Q R X t	
|| | j jdd t  d S )N.jsonz.json.dirtya+r(   r
  TrM  )r+   rV   rW   rX   rY   json_object_countwriterZ   dumpsr   mover   r   )r   Zapi_funcr   r]   Zfile_path_tmpr^   rowr   r   r   _simple_dump  s    
 zJiraAPIImport._simple_dumpc              	   c   sN   | j  | d}| rJt|d}|D ]}t|V  q.W 5 Q R X d S )Nr9  r+)r+   rV   rW   rX   rY   rZ   loads)r   r   r]   r^   r?  r   r   r   r     s    zJiraAPIImport._simple_getc              
   c   sf   | j  d}| rbt|D ]>}|dr2q"t| d| dd}t	|V  W 5 Q R X q"d S )Nr   .dirtyr   
/info.jsonrA  )
r+   rV   rW   rX   oslistdirr   rY   rZ   r[   )r   project_dirro  r^   r   r   r   r   $  s    
zJiraAPIImport._get_projectsc              	   c   sH   | j  d|}t| dd}|D ]}t|V  q(W 5 Q R X d S )Nr   /issue_types.jsonrA  r+   rV   rW   rY   rZ   rB  r   ro  rG  r^   r?  r   r   r   rz  -  s    z*JiraAPIImport._get_issue_types_for_projectc              	   c   sH   | j  d|}t| dd}|D ]}t|V  q(W 5 Q R X d S )Nr   /statuses.jsonrA  rI  rJ  r   r   r   r|  3  s    z'JiraAPIImport._get_statuses_for_projectc              	   c   sH   | j  d|}t| dd}|D ]}t|V  q(W 5 Q R X d S )Nr   /roles.jsonrA  rI  rJ  r   r   r   r  9  s    z JiraAPIImport._get_project_rolesc              
   c   sV   | j  d|d}t|D ]2}t| d| dd}t|V  W 5 Q R X qd S )Nr   rO   r   rD  rA  r+   rV   rW   rE  rF  rY   rZ   r[   )r   ro  	board_dirZboard_idr^   r   r   r   r  ?  s    z!JiraAPIImport._get_project_boardsc              
   c   sV   | j  d|d}t|D ]2}t| d| dd}t|V  W 5 Q R X qd S )Nr   r  r   rD  rA  rM  )r   ro  sprints_dirZ	sprint_idr^   r   r   r   r  E  s    zJiraAPIImport._get_all_sprintsc              	   c   sH   | j  d|}t| dd}|D ]}t|V  q(W 5 Q R X d S )Nr   /versions.jsonrA  rI  rJ  r   r   r   r'  K  s    z#JiraAPIImport._get_project_versionsc              	   c   sH   | j  d|}t| dd}|D ]}t|V  q(W 5 Q R X d S )Nr   /components.jsonrA  rI  rJ  r   r   r   r%  Q  s    z%JiraAPIImport._get_project_componentsc              
   c   sb   | j  d|d}t|D ]>}|dr.qt| d| dd}t|V  W 5 Q R X qd S )Nr   ZtasksrC  r   rD  rA  )	r+   rV   rW   rE  rF  r   rY   rZ   r[   )r   ro  	tasks_dirZtask_idr^   r   r   r   r   W  s    
z JiraAPIImport._get_project_tasksc                 c   sB   |d  d}t |D ]$}|dkr&q|| d| dV  qd S )Nr   z/attachmentsall_attachments.zipr   )r   r]   )rE  rF  )r   r   Zattachments_pathr   r   r   r   r   _  s
    z$JiraAPIImport._get_issue_attachmentsc              	   c   s>   |d  d}t |d}|D ]}t|V  qW 5 Q R X d S )Nr   z/comments.jsonrA  )rY   rZ   rB  )r   r   comments_file_pathr^   r?  r   r   r   r  f  s    z!JiraAPIImport._get_issue_commentsc              	   C   s6   |d  d}t |d}t|}W 5 Q R X |p4g S )Nr   z/worklog.jsonrA  rY   rZ   r[   )r   r   rT  r^   rb   r   r   r   r  l  s    z!JiraAPIImport._get_issue_worklogsc              
   C   s:   |d  d}t |d}t|W  5 Q R  S Q R X d S )Nr   z/properties.jsonrA  rU  )r   r   Zproperties_file_pathr^   r   r   r   r  r  s    z#JiraAPIImport._get_issue_propertiesc              
   C   sD   | j  d}| r@t|d}t|W  5 Q R  S Q R X i S )Nglobal_settings.jsonrA  )r+   rV   rW   rX   rY   rZ   r[   )r   global_settings_file_pathr^   r   r   r   _get_jira_global_settingsw  s
    z'JiraAPIImport._get_jira_global_settingsc              	   C   s@   | j  }| j d}t|d}t|| W 5 Q R X d S )NrV  rU   )r=   Zget_jira_global_settingsr+   rV   rW   rY   rZ   r\   )r   Zglobal_settings_datarW  r^   r   r   r   _dump_jira_global_settings~  s    
z(JiraAPIImport._dump_jira_global_settings)rg   attachments_dirr   c                    s\  |sd S | j jd t|ddd D ]*}d}|drBd}|j| }z|drr| j jd|  W q*|d	st	j
| jj|}|| jjs| j jd
|  W q*t|dd \}}|s| j jd|  W q*tdt	j
|}	|	rj|	d  |	d dd}
 |
d krj|d d }tt fdd|d }|rj| j jd|  W q*t	j
|dd dd }tj|}||}tjj||d | j jjjd}|stj| j ||d | j jjjd}||_||_d|_ |!  |j"#  W q* t$k
rT } z*| j j"%  | j jd| d|  W 5 d }~X Y q*X q*d S )Nu/   Обработка ссылок в текстеZlxmlc                 S   s   |  dp|  dS r  r  r   r   r   r   r!    r"  z+JiraAPIImport._dump_links.<locals>.<lambda>r  r  zmailto:u   Это почта: ZhttpuH   Это внешняя ссылка, оставляем как есть: r%  r   u   Это не файл: r&  r(   rD  r  r   r   c                    s   |  d kS r'  r(  r)  r+  r   r   r!    r"  uE   Этот файл уже обработан во вложениях: r   r$  r   r  
obj_ext_idr   r+   r  r\  r   Fu0   Не удалось скачать ссылку r  )&r+   rR   r-  r   r  r  r  r.  rP  r/  r0  Zurljoinr=   r   r6  r7  r   r2  r3  r1  r4  r   rH   r   r   rW   CmfImportDownloadrJ   r   r   pathr   
downloadedr   r,   r-   r/   Zrollback)r   rg   rZ  r   r  r   r   r;  encodingr8  Zattach_filenamer9  r:  r   r]   download_jobr  r   r+  r   _dump_links  sh    



 


zJiraAPIImport._dump_linksc                 C   sF  t dd0 ddlm}m} || _d}	| jjd| d|  | j|d ||D ]}
zz| j rd| j_| j  W W  W 5 Q R  d	S | jjd
|
d  d |t|
d }| rW W JqV|t|
d d }|jdd |d}|
d d rJ| jjdt|
d d   ztj| jjd|
d  d}| jjjrztj| jjd|
d  d}d}||}| jjjj d|
d  }tjj||| jjjjd}|stj| j||| jjjjd}||_||_d|_|  |j	
  W nD t k
rH } z$| jj!dt" d| t#j$dd W 5 d }~X Y nX | j%dr|d}| rvt&| t'|d }t()| j*|
d | W 5 Q R X | +|
d! d" ||
 |d#}| rt&| | jjd$ t'|d%T}| j,|
d D ]<}|-t(.|d&  | j j/d	7  _/| +|d' ||
 qW 5 Q R X | j0|
d }|d(}t'|d }t()|| W 5 Q R X t12|| |jdd |d)}t|3dd*|
d+< t'|d "}t()|
| | j j/d	7  _/W 5 Q R X W n(   |	d	7 }	| jj4d,|
  Y nX W 5 | jj	
  X qV|5|	 W 5 Q R X d S )-NFr  r   r  u   Задачи с u    до r   r>  r(   u   Задача 'r   'rC  Texist_okr9  r   r   u%   Обработка вложений: zsecure/attachmentzip/z.zipzsecure/issueAttachments/rS  r   r[  r]  r   r  r)   r  zworklog.jsonrU   r  rl   zcomments.jsonu#   Дампим комментарииr:  r
  r   zproperties.json	info.jsonrp   r   u0   Не удалось скачать задачу )6r   r  r  r  r=   r+   rR   r-  Zget_all_project_issuesr,   r-   rO  ri   r   rW   r&   rX   mkdirr   rE  r_  r   r   rF   rG   r   r   rH   r^  rJ   r   r`  r/   r.   r  r1   r2   rL   removerY   rZ   r\   Zissue_get_worklogrc  Zget_commentsr<  r=  r;  Zget_issue_propertiesr   r>  r  	exceptionr  )r   r  maxrR  r  r=   tasks_that_are_doner  r  r  r   Ztask_dirZtask_dir_tmprZ  r  r   Zattach_file_pathr   rb  r  Zworklog_file_namer^   Zcomments_file_namer  Z
propertiesZproperties_fileZ	info_pathr   r   r   _dump_task_part  s    



 


2


"


 

zJiraAPIImport._dump_task_partr  cntc           
      C   s>  t |d  d}|jdd | j }d}t|| j d }|sFd}d}g }|dkr| jj| jd| || || | ||t	| j
j| j
j| j
j| j
j| j
j| j
jjd	|d
d}	||	 |	  | jjd|	  |d7 }||8 }qN|D ]}	|	  q| jjd | s&|| 7 }q| jjd|  |S )NrG  z/tasksTre  r   r(   r   Z
dump_tasks)r   r  tokenpassword
verify_sslrG   )r  rk  rR  r  r=   rl  r  u$   Форкаем _dump_task_part proc=uI   Закончили паралельное скачивание задачu   Ошибок: )r   rh  re   r  intrf   rd   r  rm  r   r=   r   r  rp  rq  rr  rF   rG   ru   r  r+   rR   r-  r   r  rJ   )
r   r  ro  rR  rl  r  stepr  Zprocessr  r   r   r   _dump_tasks  sF    
 	



zJiraAPIImport._dump_tasksc           "      C   s*
  | j d d d }|d s"tddd |d D | _| j d	}|jd
d t| j}td| }| jD 	]}	z8| j	 rd| j_
| j  W  d S | j jd7  _| jjd|d  d |t|d }|d}| 	sP| jj|d }t||d  d|d< tj|d d
d | jjd t|d  d}	|	 r`t|	 t|	d"}
| j|d }t||
 W 5 Q R X | jjjrR|d s| j|d gd d |d< n| jjd t|d  d}| rt| t|dD}
| jj|d dD ]*}| j jd7  _|
t |d   qW 5 Q R X nT| j!| jj" d!|d   |d< | j!| jj" d"|d d   |d d#< |#d$}|r| j!|d%  |d$< | jjd& t|d  d'}| rt| t|dD}
| jj$|d dD ]*}| j jd7  _|
t |d   q W 5 Q R X | jjd( t|d  d)}| rt| t|d}
| jjj%|d d*& D ]}| j	 rd| j_
| j   W 5 Q R  W  d S | j jd7  _| j!| }| jjjr\|#d+g D ]>}|d, d-kr| jjj'|d. #d|d. #d/d0|d1< q|
t |d   qW 5 Q R X | jjd2 t|d  d3}| rt()| |  t|d  d4}| rt()| |  | jj*|d d*D ]}| j	 r(d| j_
| j   W  d S | j jd7  _| jjd5|d   | jj+|d |d#< | j!|d# d6 d%  |d# d6< | jjjrd7d | j,|d D |d# d8< |d |d9< |t|d }|jd
d |d}t|d:}
t||
 W 5 Q R X z`|d, d;krn| jjd< | j-|d D ],}| j	 rpd| j_
| j   W  W  d S | j jd7  _|t|d }|jd
d |d}| r| jjd=|d  d> q>g |d?< | jjd=|d   | j.|d D ]F}| j	 r2d| j_
| j    W  W  d S |d? /|d  q t|d:}
t||
 W 5 Q R X q>W n(   | jj0d@| t1j2d
d
dA Y nX q| jjdB |d  dC}t|dt}
| j3|d D ]\}| j	 rd| j_
| j   W 5 Q R  W  d S | j jd7  _|
t |d   qW 5 Q R X | jjdD |d  dE} t| dt}
| j4|d D ]\}!| j	 rd| j_
| j   W 5 Q R  W  d S | j jd7  _|
t |!d   qvW 5 Q R X | j j5|7  _5| jjd
dF t6  t(7|d | t||d< |d  dG}t|d:}
t||
 W 5 Q R X n t|dH}
t8|
}W 5 Q R X | j9|d }| jjdI|  |  j:| j;||dJ7  _:W qn   |  j:d7  _:|#dK	r| jj0dL|d  dMt1j2d
d
dA n| jj0dN| t1j2d
d
dA Y qnX qn| jjdO d S )PNr   r   r   	isCheckedu5   Не выбрали ни одного проекта!c                 S   s$   g | ]}|d  r|d r|d  qS )r3   rv  r   )r   r  r   r   r   r   7  s       z0JiraAPIImport._dump_projects.<locals>.<listcomp>Zchildrenr   Tre  P   r>  r(   u   Дампим "r   r  r   rg  r   rC  rG  u   Дампим права/permissions.jsonr:  r  ZworkflowSchemer  u/   Дампим типы задач проектаrH  rn  r
  z$rest/projectconfig/1/workflowscheme/zrest/api/2/workflowscheme/r-  r  r   u*   Дампим статусы проектаrK  u$   Дампим роли проектаrL  )r   r  r  r  Z	actorUserr?   )r  r<  r  u&   Дампим доски проектаz/boards/z	/sprints/u   Доска r   c                 S   s   g | ]}|qS r   r   r   r   r   r   r     s     Zquick_filtersro  rU   )ZscrumZsimpleu&   Дампим спринты доскиu   Спринт u    уже скачанr  u4   Не удалось сдампить спринты r   u(   Дампим версии проектаrP  u!   Дампим компонентыrQ  rM  rD  ru*   Дампим задачи проекта: rn  r  u   Проект "u   " является приватным и не может быть импортирован, отключите приватность в Jira или предоставьте пользователю праваu2   Не удалось получить проект u0   Закончили дампить проекты)<r   r/   rP   r+   rV   rW   rh  r   rs  rO  ri   r   r;  rR   r-  r&   rX   r=   rF   Zget_projectrE  makedirsr   ri  rY   Zget_project_permission_schemerZ   r\   rG   Zget_project_schemeZget_issue_for_projectr<  r=  jira_requestr   rJ   get_statusesZget_project_rolesvaluesr   r   rmtreeZget_all_agile_boardsZget_agile_board_configurationZget_board_quick_filtersZget_sprintsZget_sprint_issuesru   r.   r1   r2   Zget_project_versions_paginatedZget_project_componentsprogressr   r>  r[   Zget_project_issues_countr0   ru  )"r   rootZprojects_dirro  rt  r   rG  Z	data_filer  permission_filer^   Zperm_schZ
types_filer  r  Zstatuses_filer?  Z	role_fileZrole_urir  r  Z
boards_dirrO  r  rN  Zboard_info_filer   Zsprint_pathZsprint_file_pathr   Zversion_list_filenamer  Zcomponents_list_filenamer  r   r   r   _dump_projects3  sX   









$


"


"





$




&
"
"$$zJiraAPIImport._dump_projectsc                 C   s<  | j  }t|\}}}|| d }| j d| d | j jd | j jd |   |  | _	| j jd | 
| jjd | j jd | 
| jjd	 | j jd
 | 
| jjd | jjjr
| j jd | 
| jjd | j jd | 
| jjd d| j _| j   t  | j jd |   dS )u_   
        Загружаем все данные из апи, кроме аттачей
        d   u   Свободно места: rA  u$   Скачаем данные из APIu9   Дампим глобальные настройки Jirau'   Дампим пользователейr   u   Дампим статусыr]  u    Дампим типы задачr,  u*   Дампим бизнес процессыr0  u7   Дампим схемы бизнес процессовr7     u   Дампим проектыN)r+   rV   r   
disk_usager.   rR   r-  rY  rX  rL   r@  r=   r   r|  Zget_issue_typesrF   rG   Zget_workflowsZget_workflow_schemer  r   r   r  )r   Zdownload_pathr  usedfreeZfree_percentr   r   r   download_data  s0    


zJiraAPIImport.download_datac                 C   s0   t | jj| jj d | j_| j  t  d S )Nr  )rs  r+   rW  r;  r  r   r   r   r   r   r   r  	  s    
zJiraAPIImport._calc_progressc                    s  t t d fdd}dddgddd	gg}d
D ]Z}tt| }|j|d} jjd|j d|  d}d}|dkr,|j|ddddg|| || | gd}|d7 }||8 }|D ]}	zt	|	dr||	j
j|	_|	jr|	  |	  n"||	j
j|	_
|	jr
|	jd	d |	jD ]8}
|
jdkr$q||
j
j|
_
|
jr|
jd	d qW q    jjd|	 tjd	d	d   jd7  _Y qX qqnq,dS )uU   
        Заменим ссылки на задачи и документы
        r  c                    s  | s| S t | d}|dD ]}|jdr0q|jdd jjjrd }d|jd krt	d|jd }|s j
jd|jd   q j
jjj d	|d
dd   }tjj|dgd}|sވ j
jd|  qnd|jd krt	d|jd }|s" j
jd|jd   qtjjddd|d
dd   dgdgd}|D ].}|jd |d
dd  krT|} qqT|s j
jd|d
dd    qnq|tj| qt|S )Nr	  ar  r  rp   z/wiki/z\/\d+u:   Не удалось найти ид документа в r   r   r(   r  u:   Не удалось найти документ по ид z/browse/z	\/\w+-\d+u4   Не удалось найти ид задачи в rL  r@  z%"key":"r  r?  r   u:   Не удалось найти задачу по коду )r   r  r  rJ   r.  r=   rF   r   r2  r3  r+   rR   rP  r   r   r[  rH   r   r   r   rL  Zreplace_withZCmfPluginCsvZcreate_tag_linkr&   )rg   r  r  r3   r   Zext_coder   r?  r   r   r   check_links	  sJ    
$
"z7JiraAPIImport._process_cross_links.<locals>.check_linksr+   rq  Nr   r   T)r   r   r   r   r   u)   Конвертируем ссылки в u=    на локальные задачи и документы: i  r   rg   zcomments.log_levelzcomments.text
text_draft)r   r   slicer(   rM  rD  uZ   Не удалось конвертировать перекрестные ссылки в r   )r&   varsrH   countr+   rR   r-  r   r   hasattrrg   r   r  rS  r   Z
do_approver  r  r.   r1   r2   r0   )r   r  r   Z	mode_namer`   ro  rt  r  r   r3   r  r   r   r   _process_cross_links	  sF    (



z"JiraAPIImport._process_cross_linksc              	   C   sD  ddl m} t|d  d}| }dd |d D }t|d}t|}W 5 Q R X | jjjj d	|d
  }t	j
j|d}	|	st	j
|d| jd}	|d |	_|	jdd |d D ]}
d	| jjjj d	|
d
  d	}||
d rt	jj||
d  dd}n| jjd|
  qddd| dg}ddddg}t	jj||d}|st	jj||	|d}|s| jjd|
 tjddd |  jd7  _q|jr|j | |_n||_|
d d  d!kr| jjjj d	|
d d! d
  }t	jj|d}|j| |jdd q|
d d  d"kr.d|_|jdd q|
d d  d#krTd|_|jdd q|
d d  d$krzd|_|jdd q|
d d  d%krd|_|jdd q|
d d  d&kr<| jjj r| !|
d d' }nt	j"jdd(|
d d)  gd*}|r|j#| |jdd n*| jjd+|
 tjddd |  jd7  _q|
d d  d,kr| jjj r~d	| jjjj d	|
d d'  d	}n&d	| jjjj d	|
d d, d  d	}t	j$jddd| dgd*}|r|j#| |jdd n*| jjd-|
 tjddd |  jd7  _q| jjd.|
d d   tjddd |  jd7  _q|	S )/Nr   )get_datarG  rx  c                 S   s   i | ]}|d  |d qS )Z	jira_coderB   r   r   r   r   r   r  d	  s      z6JiraAPIImport._process_permissions.<locals>.<dictcomp>Zproject_perm_permissionry  r   r   r_  T)r   r   r+   r   r   ZpermissionsZ
permission)rB   Zinclude_deletedu4   Не нашли соответствия права r   r@  rA  r   access_membersaccess_project_roler?  )permr   r   u*   Не найдено правило для r   r(   Zholderr  ZprojectRoleZapplicationRoleZprojectLeadr  r  r   r   r   Z	parameterr   u9   Не нашли пользователя для прав r[  u-   Не нашли группу для прав u'   Неизвестный тип прав )%Zcmf.system_datar  r   rY   rZ   r[   r+   r   r   rH   ZCmfProjectPermSchemerJ   r   r   ZCmfProjectPermPermissionrR   rP  ZCmfProjectPermSchemeRuler.   r1   r2   r0   r   r  r  ru   Zaccess_local_userZaccess_ownerZaccess_responsibleZaccess_authorr=   rF   rG   r   r   r  rT  )r   r  r  r  Zsystem_dataZmap_permr^   Zperm_scheme_dictr   Zperm_schemeZ	perm_dictr  r   r   Zscheme_ruleZrole_ext_idr  r   r[  r   r   r   r  `	  s    
"$&$z"JiraAPIImport._process_permissionsc           	      C   s8  t dd" | }|dkr"q*| j r0q*| jjd|d   | jj|d dd}z||  t	|d }|j
jddd	 t|d
"}|jddD ]}|| qW 5 Q R X | jjd|d   || W nB tk
r } z"| jjd|d  d|  W 5 d }~X Y nX W 5 Q R X qW 5 Q R X d S )NFr  r  u    Пытаемся скачать r  T)streamr_  )parentsrf  zwb+i    )Z
chunk_sizeu   Сохранили в u+   Неудалось скачать файл r  )r   rJ   r+   rO  rR   r-  r=   r{  Zraise_for_statusr   r   rh  rY   Ziter_contentr<  r  r/   rj  )	r   download_queue
done_queuerb  rb   Z	save_pathr^   chunkr  r   r   r   _download_file_worker	  s&    
z#JiraAPIImport._download_file_workerc           	      C   s  | j jd | j }| j }| j dg dd| j jjjgdddgg}tj	j
|dsl| j jd d S g }t| jD ]J}| jj| jd	| ||d
d}|| |  | j jd|  qztj	j|ddgdD ],}| j  r q||j|j|jd q|D ]}|d q| s<|D ]}|  q,| j  r^d| j _| j   d S | j jd | std | }tj	j|d d}d|_|  qld S )Nu=   Скачиваем все найденные вложенияzplugin.plugin.source_hashr   r   r`  Fr   u   Вложений нетr  )r  r  r  u    Запустили задачу r  r_  r?  )r   r  r_  r  r>  u%   Закончили скачиватьr   r   r  T)r+   rR   r-  re   r  r   r   r   rH   r^  r  r  rf   rd   r  r  ru   r  ZslistrO  r  r   r  r_  r  r   ri   r   printrJ   r`  )	r   r  r  r   Zprocsr  r  rb  Zdownload_idr   r   r   download_files	  sH    






zJiraAPIImport.download_filesc                 C   sR  d| j _d| j _| j   t  |   |   |   |   |   | 	  |   | 
  |   | jjjr|   |   |   |   |   n|   |   |   |   d| j _| j   t  |  D ]8}|d dd | jD krq| j jd|d  d q| j jd	| j tjd
d
d | j d| j j  | j S )Nr   r  r   c                 S   s   g | ]}|d  qS r  r   r   r   r   r   r   	
  s     z0JiraAPIImport.process_import.<locals>.<listcomp>u'   Импортирован проект 'r   rd  u#   Ошибок обнаружено: Tr   u-   Импортировано объектов: )r+   rW  r  r   r   r  r  r  r\  rc  r/  r=   rF   rG   r6  r8  r  r  r  r#  r(  r   rP   rR   r-  r.   r0   r1   r2   )r   r   r   r   r   process_import	  sB    



zJiraAPIImport.process_import)T)r   r   )T)N)^r"   r#   r$   r%   rs  r'   r   r&   r   r   rD   propertyr_   staticmethodr   r   r   rc   rQ   rv   r|   r   r   r   r   r   r   r:   r   r   r   r  r  r  r   r=  r\  rc  rH   r  r  r}  r  r  r  r  r  r  r  r  r  r   r  r	  r  r  r   r#  r  r  r(  r/  r6  r8  r@  r   r   rz  r|  r  r  r  r'  r%  r   r   r  r  r  rX  rY  r   rc  rm  ru  r  r  r  r  r  r  r  r  __classcell__r   r   rS   r   r;   7   s   


	,3  


: 
9
o
G'.
 
K
8
'
A
  
	
@
&

J
;
(	7V" =OO%r;   )*Zcmf.appr   Zcmf.includeZdataclassesr6  pathlibr   r   Ztempfiler   r/  typingr   r   r   r	   r
   r   r   Zbs4r   r   Zcmf.data_providers.baser   r   Z
cmf.modelsr   Z%common.models.cmf_plugin_import_mixinr   Zmodules.jira.apir   Zmodules.jira.base_importr   rH   r   r   r   r   Z	dataclassr   r:   r;   r   r   r   r   <module>   s(   $ 