U
    Įwh                     @   s  d dl Z d dlZd dlZd dlZd dlZd dlZd dlZd dl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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mZ d dlZd d
l m!Z!m"Z" d dl#T d dl$m%Z% dd Z&e'e(dddd Z)e*j+ddddd Z,e*j+ddddd Z-e*j+ddddd Z.e*j+ddddd  Z/e*j+d!ddd"d# Z0e*j+d$ddd%d& Z1d'd( Z2d)d* Z3d+Z4G d,d- d-ej5j6Z7dS ).    N)OrderedDict)deepcopy)is_dataclass)isclass
isfunctionismethod	signature)time)uuid4)Responserequest)dumpsloads)commit_all_dsrollback_all_ds)*)	CMF_CACHEc                  C   sj   t jrt t j dk rt jS t jd} | sNttt }t jjd|dd n| 	 }|t _t t _t jS )N   redis_idT)Znx)
APPREDIS_DB_IDr	   ZREDIS_DB_ID_TIMERZREDIS_DBgetstrintsetdecode)Zraw_redis_idr    r   ./modules/api/views/index.pyget_redis_id   s    r   zCmfCache:flushdb)Zchannelc                  O   s   d t _td td d S )NzAPP.REDIS_DB_ID = NONE)r   r   logginginfogdebugargskwargsr   r   r   flush_redis_id/   s    
r&   zjshash-invalidate-confirm/)	namespacec                 O   s   t |  d S N)r   Zjshash_invalidate_confirm)Zconfirm_dictr$   r%   r   r   r   handle_message=   s    r*   Zuser_regisrtyc                 C   sR   ddl m}m} tdd|   | dd }|r:|| tjd| |d d S )Nr   	join_room
leave_room%szhandle_user_regisrty: user_idzMe registered: roomflask_socketior,   r-   r   r    r   socketioemitparamsr,   r-   r/   r   r   r   handle_user_regisrtyA   s    r8   r,   c                 C   s   ddl m} tdd|   || d  tjjjd| d d}tt	|}tj
d| d	  d
| d  d|i| d d tj
d| d  || d | d | d	 d| d d d S )Nr   )r,   r.   zhandle_user_join_room: 	room_namer'   r(   r1   zUser r/   z	 join to participantsr0   z
Joined to 	user_name
user_login)r;   r<   r=   r/   )r3   r,   r   r    r4   servermanagerget_participantslenlistr5   )r7   r,   r;   ZparticipantsSizer   r   r   handle_user_join_roomK   s    ,rC   r-   c                 C   sh   ddl m} tdd|   || d  tjjjd| d d}tjdd	t	t
|i| | d d
 d S )Nr   )r-   r.   zhandle_user_leave_room: r9   r'   r:   zUser leave roomr;   r0   )r3   r-   r   r    r4   r>   r?   r@   r5   rA   rB   )r7   r-   r;   r   r   r   handle_user_leave_room\   s
    rD   document_broadcastc                 C   s   t jd| | d tjjd d S )NrE   r9   )r1   Zskip_sid)r4   r5   flaskr   Zsid)r7   r   r   r   handle_document_broadcastd   s    rG   Z	user_pingc                 C   sF   ddl m}m} tdd|   | dd }|rBtd|  d S )Nr   r+   r.   zhandle_user_ping: r/   Z
user_pong_r2   r6   r   r   r   handle_user_pingi   s
    rH   c                    s   i  fdd}|S )Nc                     s4   t | t| f}|kr, | ||< | S r)   )pickler   sorteditems)r$   r%   hashfuncZmemoryr   r   memox   s    zmemoized.<locals>.memor   )rN   rO   r   rM   r   memoizedu   s    rP   c                 C   s   dt krt t _|t j| < d S )Nprofiler_data)r!   r   rQ   )keymsr   r   r   set_call_time   s    rT   z******c                       s  e Zd ZdZd5dd fddZd6ddZd7dd	Zd8d
dZdd Zd9ddZ	dd Z
d:ddZdd Zd;ddZed<edddZdd Zejjdd Zed Zd=d"d#Zd$d% Zd&d' Zd(d) Zd*d+ Zd,d- Zd.d/ Zd>e d0d1d2Z!ejjd3d4 Z"  Z#S )?ApiViewr'   N)returnc                    s   t    | j|d| _d S )Nextra_models_list)super__init__get_rpcrpc)selfrX   	__class__r   r   rZ      s    
zApiView.__init__c                 C   s   |rdd |j jD |d< |S )Nc                 S   s   g | ]
}|j qS r   )__name__).0Ze_clsr   r   r   
<listcomp>   s     z/ApiView._add_exception_info.<locals>.<listcomp>Zexception_types)r_   __mro__)r]   result	exceptionr   r   r   _add_exception_info   s    zApiView._add_exception_infoc                 C   s8   t d|| d||dtdtjd}| j||dS )Nz%s, exception=%s2.0)codemessagealert)jsonrpcerrorrj   callidre   )r   rl   r!   r   
api_callidrf   )r]   rh   ri   re   rd   r   r   r   _error   s    zApiView._errorc                 C   s   |sg }d|||t j|t dt dt d|t |t d}t jrPt j|d< |sh|sht jrht j|d< t jrvd|d	< | j||d
S )Nrg   rQ   rj   note)rk   rd   metajsverrm   jsurlrQ   rj   rq   abortversion
invalidater   jscache_timelifeshow_bg_progressbarTZlicense_requiredrn   )	r!   ro   r   Zcmf_get_versionr   rx   ry   Zapi_license_requiredrf   )r]   rd   rr   rs   rt   rw   ru   re   r   r   r   _ok   s.    

zApiView._okc                 C   s   |  ddS )NiDzParse errorrp   r]   r   r   r   parse_error   s    zApiView.parse_errorc                 C   s&   d}|  d|d kr|n| d| S )NzInvalid Requestiz: r{   )r]   ri   titler   r   r   invalid_request   s    zApiView.invalid_requestc                 C   s   |  ddS )NizMethod not foundr{   r|   r   r   r   method_not_found   s    zApiView.method_not_found c                 C   s   |  dd| S )NizInvalid params: r{   )r]   ri   r   r   r   invalid_params   s    zApiView.invalid_paramsc                 C   s   |  ddS )NizInternal errorr{   r|   r   r   r   internal_error   s    zApiView.internal_errorc                 C   s$   |t dddkst| j|||dS )Ni irn   )rangeAssertionErrorrp   )r]   rh   ri   re   r   r   r   server_error   s    zApiView.server_errorrW   c                 C   sJ  | s
g } nt | } | tjj ddd | D }tj|rJtj| S i tj|< t	t| D ]}t
|r|}t|d|j}n<tt|d pttj|d }t
|sq`t|tjjsq`|jrq`|dkrtdddd	d
dddddg
}n|jsq`n
t|j}i }tt	||@ }|D ]\}t||}t||}t|t}	t|t}
t|t}|| |	|
|dd}|||d < qt|tjjr |j D ]\}}g }t|tjjtjjfrddddg}nt|tjjrddg}|D ]D}| d| }t||}||t|ddddd|| d| < q֐q|||d}|tj| |d < q`tj| S )Nr   c                 S   s   g | ]}t |qS r   r   )ra   objr   r   r   rb      s     z#ApiView.get_rpc.<locals>.<listcomp>
class_name	BaseModelZall_models_metaZget_metaZget_ui_full_pathZubql2bqlZpublic_get_ui_full_pathZpublic_all_models_metaZpublic_noneZpublic_none_classmethodZsdesk_get_ui_full_pathZsdesk_all_models_metaF)_methodnameis_class_methodis_static_methodis_taskis_field_methodr   appendremoveextendZ
all_nested.T)r   r   r   r   r   r   r   )_classr   methods)rB   r   cmfmodelsr   joinr   Z
rpc_modelsr   dirr   getattrr`   
issubclassZabstractr   	api_allowZapi_methodsinspectZgetattr_static
isinstanceclassmethodstaticmethodZCmfDeferredJobWrapperlowerfieldsrK   ZCmfM2MZCmfGenericM2MZCmfJsonr   )rX   rR   Z
model_nameclsZapi_methods_setZrpc_methodsmethod_namemethodZmethod_attrr   r   r   Z
rpc_method
field_nameZ	field_clsZ
submethodsZ	submethodr   Z	rpc_modelr   r   r   r[      s    






	
zApiView.get_rpcc                 C   s   |dkS )NZ	qweqweqwer   )r]   tokenr   r   r   check_token@  s    zApiView.check_tokenc                 C   s   | j d| jtdS )Nz
index.html)r\   r
   )Zrender_with_paramsr\   r
   r|   r   r   r   r   C  s    zApiView.getz9"(?P<attr>(cmf|doc|obj|approved)_version)":(?P<value>\d+)Fc              
   C   s  t js|st|trt|dkrBtdt| dtj tj	d nDt|dkrt
j t
dddkrtd	t| dtj tj	d | |||||}|rt|}	t| jd
|	 }	nXzt|ddd}	W n4 tk
r }
 ztd|
|  W 5 d }
~
X Y nX t| jd
|	}	t js|st|	d}|dkrxtd| dtj tj	d td | j||||||ddS |dkrt
j t
dddkrtd| dtj tj	d td | j||||||ddS t|	ddS )Ni  u    !!!Блокирующая задача критикал баг! Обратитесь в техком!!! Используй slice u   , метод leveli,  i        uw   Разработчик внимание! Слишком много строк через API. Используй slice z"\g<attr>":"\g<value>"r   F)indentZensure_asciiz"Json dumps error: %s | response=%szutf-8i   uh   !!!Блокирующая задача критикал баг! Обратитесь в техком!!! u    байт, метод uI   response_ok: повторный вызов из-за размера >10MBT)orjson_rw   	recursioni   uq   Разработчик внимание! Слишком большой размер данных через API. uH   response_ok: повторный вызов из-за размера >1MBzapplication/json)Zmimetype)configZ
PRODUCTIONr   rB   rA   	cmf_alertr!   
api_methodr   WARNINGdatetimedateZtodayrz   cmfutilZ	cmf_dumpsresub_BIG_INT_JSON_HACK_REr   r   	TypeErrorrl   encoder"   response_okr   )r]   result_dictrr   rs   rt   r   rw   r   ZresponseZ	json_dataeZactual_sizer   r   r   r   J  sN    

$


$
zApiView.response_okc                 C   s   t jr
d S tjdrd S |ds2t d d S tj 	dd d t j
jjd}t|t|rzt d |d S t d	 d S )
NNO_CACHEjshash:z$api_cache_add failed, invalid jshash%Y%m%d%H%M%S%f)rs   Zcurrent_person_idzapi_cache_add endrs   zapi_cache_add failed)r!   Zno_jscache_forceosenvironr   
startswithr"   r   utcnowstrftimecurrent_personidvaluer   Z_obj_dict_setrI   r   )r]   rL   Z	res_cacher   r   r   api_cache_add  s    


zApiView.api_cache_addc                 C   sN   t jdrd S |dsd S t|}|s0d S t|}t	d|  |S )Nr   r   zAPI CACHE HIT )
r   r   r   r   r   _obj_dict_getrI   r   r   r    )r]   rL   Z_resresr   r   r   api_cache_get  s    


zApiView.api_cache_getc                 O   s   | j |f||S r)   full_cache_validationr]   jshash_list_args_kwargsr   r   r   public_full_cache_validation  s    z$ApiView.public_full_cache_validationc                 O   s   | j |f||S r)   r   r   r   r   r   sdesk_full_cache_validation  s    z#ApiView.sdesk_full_cache_validationc                 O   sn   dt j  dd d i}|D ]6}|ds0q t|}|r t|}|d||< q | j	|d d t
jddS )Notherr   r   r   rs   T)rr   rs   rt   r   )r   r   r   r   r   r   rI   r   r   r   r!   rt   )r]   r   r   r   rd   jshashZ
redis_data
cache_datar   r   r   r     s    


zApiView.full_cache_validationc                 C   s   t jrt jt jkrdS dS )u;   
        Проверяем доступ к апи
        FT)r!   r   Zanonymous_userr|   r   r   r   _check_access  s    zApiView._check_access)r   c                 C   s   z|j ddd\}}W n tk
r,   Y dS X |dkrH|dkrHd| }|| jkrVdS | j| }|d }d	}|d
kr|js|sd| }d}||d krdS |d | }||d< ||d< |S )u  
        Поиск метода rpc

        находит метод в rpc_json
        проверяет его разрешенность
        возвращает указатель на функцию

        Возвращает не метод, а структуру из self.get_rpc + доп.поля:
         - use_simple - когда решили использовать slist или sget
         - _class - указатель на модель
        r   r   maxsplitNZCmfAttachment)createupdatedeleteZapi_r   F)r   rB   sTr   _use_simple)split
ValueErrorr\   disable_simple)r]   r   r   Zproc_cls_nameproc_methodZproc_clsr   
use_simpler   r   r   rpc_prepare_method  s*    



zApiView.rpc_prepare_methodc           A      C   s  d t _|  s| ddS t jjrPt jjtjkrP| ddt jj dtj dS t dt j	j
j d tj }ttj}t dtj d	tj d
| d t|ts|  S |dt _|dt _|dt _|dt _t jstddtjd tt t _d|kr| dS |d t _ t jrFt!dt j  dt j" d |dd}|t _#|dpfi }|t _$t%|& }|dpi }t%|& }dddh}|'|s|'|rtjdkr| (d| d S |d!pg }	|	t _)|d"}
|
d#kr|d$pi }|r||d$< |d%d }|r8||d%< |d&d }|rR||d&< |d'd }|rl||d'< |d(d }|r||d(< |d)d }|r||d)< |d%g t _*d*d+d,d-d.d/d0d1d2d3h
}t j*D ]6}||kr|+| |d4 |kr|+|d4  q|t _,|d5i t _-t j-d6r0t.j/0  |d7d }|rT||d7< | (d8S tj1rt j2|d |	|3 t j-d9}|d 4 D ]H\}}t|trt5|d:krd;t5| d|d d<  |d |< qt6d=t78|  |d>}|d?d }|d@}|d }g }|dAkr$| j9|	|S |dBkr:| j:|	|S |dCkrP| j;|	|S d }|dDd }| <||}|sz| = S |dE }|dF }|dG } dH}!dID ]}"|"|d krd}!dHt _>t j?@|jA dJ|d kr|dH}#|
d#kr|r|dK dLkrt|dM trtBjC|dM ddN d}#|rBdL|krBtBjC|dL ddN d}#|rhdO|krhtBjC|dO ddN d}#|rd$|kr|d$ dK dLkrt|d$ dM trtBjC|d$ dM ddN d}#|d$ dK dOkrt|d$ dM trtBjC|d$ dM ddN d}#|	r"dP|	dK kr"tBjC|	dK ddN d}#dQ|d kr0dRdSdTdUdVg}$|$D ]}%|%|d krBd}# qbqB|#s|t dW|d    qqdR|d krdH}!|r|dXrdH}!tD|dYdHrdH}!|dZ}&|d[}'|'rt.jEF  |'t _G|!r|'d krtd\| dtjd dH}!|!r|r,t d] n|&rtj }t d^ | H|'}(tId_tj | jJd`  t da |(r|&|(dZkr|rtKL|}t db | jMd d |(dZ || |dcS t dd |de s|df s|dg rn|dh|! })t j Ndidj dkk}*|
d#k	rt dl d$|krdL|d$ kr|d$ dK dLkrt dm t }+|d$ |+d$< dLg|+d%< |*|+dn< |jf |+}t5|d$ dok	r~|d$= n|dLs|rt dm |j|dLg||*dp}n|	r<dL|k	r<|)rtBC|dL t }+dLdq|dLg|+d$< dLg|+d%< |*|+dn< |jf |+}|OdLd nB|	rr|3 }+g |+d$< dLg|+d%< |*|+dn< |jf |+}n| drdsS nt5|	dKk	sdP|	dK k	r| drdtS |	OdK},|)	rtBC|, t }+dLdq|,g|+d$< dLg|+d%< |*|+dn< t j duk
r|+d% @dv |dw dxk
r t jPQt|, |jf |+}|dw dxk
rtR|D ]~}-|jS|-}.|.
rB|.jT
stdy|- dztjd{ |O|- n<tU|jS|- tVjSjW
rB||- tXk
rBtd|tjd{ |O|- 
qB|r |)r tBC|jYj tZ|dOr |j
j[s tBC|j
j |s*t d} t\  | j]d i d |d~dS t|tVj.j^o@|j_j}/t|tVj.j`oX|jaj}0t|tVj.j`op|jbj}1t|tVj.j^o|jcjd}2t.j/je|/|jA|0|jYj|1|d|2dHd	st d t.jfjgd|jA|dd t\  | j]d i d |dth dS t d di|dw kr|dw jNdidd\}}3t.j/je|/|jA||0|jYj|1|d|2dHd
st d t.jfjgd|jA|dd t\  | j]d i d |dth dS tD||}4tD|4|3}ntD||dw }tIdtj | jJd`  tj }t d|d   z(|dg r|ji|	|d}5n
||	|}5W n tjk
r }6 zftk|6 tld t|6}7ttD|6d!d tRtmfrbdndd |6joD }7| j]d i d ||7|6d W Y S d }6~6X Y nh tpk
r }6 zHtqjrld tk|6 d|d  d}8|8tst 7 }8| jud|8|6d W Y S d }6~6X Y nX t d tIdtj | jJd`  tj }|r|jvrt d z|w  W n tjk
r }6 zftk|6 tld t|6}7ttD|6d!d tRtmfrdndd |6joD }7| j]d i d ||7|6d W Y S d }6~6X Y nX t d tIdtj | jJd`  tj }tk  tIdtj | jJd`  tj }|dw dkrD|5o@|5jYj}5n"|dw dxkrftZ|5dLrf|5jYj}5tBjx|5|d}9t d | r|9y  n|9N  tIdtj | jJd`  |9jz|9j{ }:};|dw dkrb|;rbd}<t|;tr|;ddkrd}<|jAdks|<dkrbt|;tr4t.jfjgd|jA|;dL |<d n.t||;rXt.jfjgd|jA|;jY|<d n
t}|;d|dw dkrd}<dH}=dH}>|;D ].}?t|?tr|?dd dkrd}=nd}>q|=r|>rd}<n
|=rd}<|jAdks|<dkrt.jfjgd|jA|<d tId|9j~ t d tj }|!r4tDt dd s4| |'}&|rDtKL|}z| jM|;|:|&||| d}@W n< tk
r }6 zt d| d|;   W 5 d }6~6X Y nX tIdtj | jJd`  t d |@S )Ni  u   Нет правu>   Версия Eva отличается от версии БД: z != u   . Вероятно была запущен несовместимый образ Eva, либо были проблемы во время обновления и патчи применились частично.zAPI request start ()zrequest.remote_addr=z request.url=z
 json_res= session_tab_idcomponent_idrm   TECHCOM_HACK3441zAPI: No callid specifiedT)Z
devel_onlyr   r   zNo method specifiedr.   z TECHCOM_HACK3441rt   r   r%   save_kwargsZ	only_dataauditnotifyz	127.0.0.1u!   SPEC0 Использование u#    через API запрещено.r$   rk   rg   filterr   sliceorder_bygroup_byinclude_deletedperm_effective_acl_idZperm_inherit_acl_idZperm_parent_idZperm_parent_owner_idZ
user_localZvacation_endZvacation_startZperm_encryptZimport_original%perm_security_level_allowed_ids_cacheZ_idflagsZ
admin_modeno_cacheu)   no_cache запрещен go to spec0 osv)loginr   r$   r%   r      zLONG_STRING    z
API_TRACE 
no_jscacheno_metacache_idzCache.full_cache_validationz"Cache.public_full_cache_validationz!Cache.sdesk_full_cache_validationr   r   r   r   F)z.getZ_getz.listZ_listz.selectZ_selectz.sumZ_sumz.count_countz.maxZ_maxz.minZ_minr   r   r      )readrh   :zCmfPersonVar.getZget_current_userZget_settingsZCmfRFilezCmfPersonVar.get_metaZCmfMenuTreez+Possible cache return invalid_data: method=Zsearch_stringZTEXKOM_no_cachers   r   ur   ошибка на frontend методы list get и тп должны быть с jshash, кроме тестов z$api_cache_get skip due to no_jscachezapi_cache_get startr   i  zapi_cache_get endzapi_cache_get hit!)r   rr   rs   rt   r   rw   zapi_cache_get jsver mismatch!r   r   r   
for_updater   r   ZrestorezAPI object get startu~   deprecated id объекта нужно передавать в kwargs или может вообще параметром RPCcmf_deleted   )r   r   r   r  z==i  u   Необходимо указать filter или kwargs для получения объекта перед вызовом его методаu1   Необходимо указать id в args[0]zCmfTask.updateZis_dummyr   r   u	   Поле u1    не доступно для изменения.r   uB   Не задано новое значение для пароля.zAPI object get Noneu>   Объект не найден, возможно удалён.)rd   rr   rs   rt   ru   r  )	initial_acl_keyobject_modelobject_owner_id	object_idobject_parent_idobject_instanceaccess_levelperm_security_level_allowed_idsraise_errorzAPI object access prohibitedZfail)operatecmf_model_nameparentresult_statusuE   Объект недоступен: недостаточно прав.)rd   rr   rs   rt   ru   re   zAPI object get endr   r   )
r  r	  Zobject_fieldr
  r  r  r  r  r  r  z"API object field access prohibiteduQ   Поле объекта не доступно: недостаточно прав.ZpreparezAPI method start r#   zUserError Trace:c                 S   s   g | ]}t |qS r   r   ra   ir   r   r   rb     s     z ApiView.post.<locals>.<listcomp>	Exceptionu/   Ошибка выполнения метода z

irn   zAPI method endZcall_method_mszAPI save startc                 S   s   g | ]}t |qS r   r   r  r   r   r   rb     s     zAPI save endsaveZcommit)r   ZupsertZcreate_from_template)r   zAPI json dump startZresult_to_dict_ms)r   sgetokZ_acl_objZdenyCmfAuditz$get result must be dict or dataclass)rB   ZslistZ	partially)r  r  r  number_of_objectszAPI json dump endZcache_store_error)rw   r   uQ   Ошибка конвертации результата запроса json_res=z result_dict=Zresult_to_response_mszAPI request end)r!   ro   r   rp   Zglobal_settingsZeva_versionr   ZEVA_VERSIONr"   r   rh   r   r   Znowr   r   dataZremote_addrurlr   dictr}   r   r   r   r   r   r   r   r   r
   r   r   r    Zcurrent_userrt   Z
api_kwargsr   keysintersectionr   Zapi_argsZ
api_fieldsr   api_hack_fieldsr   r   ZCmfAccessListZactivate_admin_modeZ	API_TRACEr   copyrK   rA   printZjsonr   r   r   r   r   r   Zin_memory_cacheZin_memory_cache_skip_modelsr   r   r   Zcache_obj_lock_getr   Z
CmfLicenseZlicense_api_notifyr   r   rT   Zmicrosecondsr   Zjshash_invalidate_confirm_listr   r   popZskipcache_select_for_updateaddrB   r   r   r   r   ZCmfPassword_PASSWORD_MASKr   hasattrZvirtualr   rz   Z	CmfEntityr   ZCmfModelZcmf_owner_idZ	parent_idr   oldZcheck_accessr  Zaudit_eventZCmfPermissionErrorZapply_asyncZCmfUserErrorr   re   tupler   r$   r  r   logger	traceback
format_excr   Z
is_changedr  ZCmfResultSplitterZsplit_simplerr   rd   r   r   r  r   r   )Ar]   Z
start_dateZjson_resrt   r%   Z
kwargs_setr   Zsave_kwargs_setZblock_kwargsr$   Zjsonrpc_verZ_filterr   r   r   r   r   r"  r   r   Z
trace_datakvr   r   r   r   Zinvalidate_listr   r   r   r   r   Zapi_use_cacher   Zcache_lock_okZ_cachelock_skip_methodsmrs   r   r   r  r  Z
tmp_kwargsr   argZfieldr  Zobj_owner_idZobj_parent_idr   Zfield_methodZ	obj_fieldrd   r   Z	abort_msgmsgZsplitterrr   r   Zcheck_result_statusZcheck_result_have_denyZcheck_result_have_okZ_objZrespr   r   r   post  s~    

"
 





       




(





.&&
   




 





 


*







$
        
    
     
    



     	&



     




  
  





zApiView.post)N)N)N)NNN)N)r   )N)N)FNF)F)$r`   
__module____qualname__Z__url__rZ   rf   rp   rz   r}   r   r   r   r   r   r   rB   r[   r   r   viewsactionr   r   compiler   r   r   r   r   r   r   r   r   r   r3  __classcell__r   r   r^   r   rU      s6   






m


=	,rU   )8decimal	ipaddressr   sysr   rI   stringZrandomr   r,  collectionsr   r#  r   Zdataclassesr   r   r   r   r   r   r	   Zuuidr
   rF   r   r   Zujsonr   r   Z
cmf.modelsr   Zcmf.data_providers.baser   r   Zcmf.includeZcmf.appr   r   r   Zon_server_eventr&   r4   Zonr*   r8   rC   rD   rG   rH   rP   rT   r'  r6  ZBaseViewrU   r   r   r   r   <module>   sR   

	



