a
    Qhr                     @   s   d Z ddlZddlZddlmZ ddlmZ ddlm	Z	 ddl
mZ ddlmZmZ dd	 Zd
d ZddeefddZdd ZdefddZdS )zC
Creates permissions for all installed apps that need permissions.
    N)apps)get_permission_codename)create_contenttypes)
exceptions)DEFAULT_DB_ALIASrouterc                 C   s   g t | | jS )zH
    Return (codename, name) for all permissions in the given opts.
    )_get_builtin_permissionspermissions)opts r   `/var/www/sistema_ama/venv/lib/python3.9/site-packages/django/contrib/auth/management/__init__.py_get_all_permissions   s    r   c                 C   s2   g }| j D ]"}|t|| d|| jf f q
|S )z
    Return (codename, name) for all autogenerated permissions.
    By default, this is ('add', 'change', 'delete', 'view')
    z	Can %s %s)default_permissionsappendr   verbose_name_raw)r
   permsactionr   r   r   r      s    
r      Tc                 K   sr  | j s
d S t| f||||d| | j}z&||} |dd}|dd}W n tyd   Y d S 0 t||svd S g }	t }
| 	 D ]B}|j
|j|dd}|
| t|jD ]}|	||f qqt|j
|j|
dd	d
}g }|	D ]D\}\}}|j|f|vr| }||j_||_||_||_|| q|j
|| |dkrn|D ]}td|  qZd S )N)	verbosityinteractiveusingr   ZcontenttypesContentTypeauth
PermissionF)for_concrete_model)Zcontent_type__incontent_typecodenamer   zAdding permission '%s')models_moduler   labelget_app_config	get_modelLookupErrorr   allow_migrate_modelset
get_modelsobjects
db_managerget_for_modeladdr   _metar   r   filtervalues_listpk_statedbr   namer   bulk_createprint)
app_configr   r   r   r   kwargs	app_labelr   r   Zsearched_permsZctypesklassctypepermZ	all_permsr   ctr   r/   
permissionr   r   r   create_permissions%   sd    	


r:   c               	   C   s*   zt  } W n ttfy$   Y dS 0 | S )zt
    Return the current system user's username, or an empty string if the
    username could not be determined.
     )getpassZgetuserImportErrorKeyError)resultr   r   r   get_system_usernamer   s
    r@   c                 C   s   ddl m} |jjjrdS t }z*td|dd	d
dd }W n ty^   Y dS 0 z|jjd| W n tjy   Y dS 0 | r|rz|jj|j|d	 W n |jjy   Y n0 dS |S )
a  
    Try to determine the current system user's username to use as a default.

    :param check_db: If ``True``, requires that the username does not match an
        existing ``auth.User`` (otherwise returns an empty string).
    :param database: The database where the unique check will be performed.
    :returns: The username, or an empty string if no username can be
        determined or the suggested username is already taken.
    r   )modelsr;   NFKDasciiignore username)rF   )django.contrib.authrA   ZUserr)   swappedr@   unicodedata	normalizeencodedecodereplacelowerUnicodeDecodeError	get_fieldrun_validatorsr   ValidationError_default_managerr&   getDoesNotExist)Zcheck_dbdatabaseZauth_appZdefault_usernamer   r   r   get_default_username   s8    

rW   )__doc__r<   rI   django.appsr   Zglobal_appsrG   r   Z&django.contrib.contenttypes.managementr   django.corer   	django.dbr   r   r   r   r:   r@   rW   r   r   r   r   <module>   s    
M