o
    e"                     @   s   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 eeddeed	d
eedddZG dd deZG dd dZdS )    N)settings)ValidationError)validate_ipv46_address)to_path   )CityCountry
GEOIP_PATH
GEOIP_CITYzGeoLite2-City.mmdbGEOIP_COUNTRYzGeoLite2-Country.mmdb)r	   r
   r   c                   @   s   e Zd ZdS )GeoIP2ExceptionN)__name__
__module____qualname__ r   r   Q/var/www/html/venv/lib/python3.10/site-packages/django/contrib/gis/geoip2/base.pyr      s    r   c                   @   s   e Zd ZdZdZdZdZdZeeeeeefZ	dZ
dZdZdZd*dd	Zed
d Zedd Zdd Zdd Zd+ddZdd Zdd Zdd Zdd Zd,ddZd d! Zd"d# Zd$d% Zed&d' Zed(d) ZdS )-GeoIP2r   r             Nc           	      C   s&  || j vrtd| |ptd }|stdt|}| r^||p%td  }| r9tjjt	||d| _
|| _||p?td  }| rStjjt	||d| _|| _| js\td| dS | rtjjt	||d}| j}d|v r}|| _|| _dS d	|v r|| _
|| _dS td
| td)aI  
        Initialize the GeoIP object. No parameters are required to use default
        settings. Keyword arguments may be passed in to customize the locations
        of the GeoIP datasets.

        * path: Base directory to where GeoIP data is located or the full path
            to where the city or country data files (*.mmdb) are located.
            Assumes that both the city and country data sets are located in
            this directory; overrides the GEOIP_PATH setting.

        * cache: The cache settings when opening up the GeoIP datasets. May be
            an integer in (0, 1, 2, 4, 8) corresponding to the MODE_AUTO,
            MODE_MMAP_EXT, MODE_MMAP, MODE_FILE, and MODE_MEMORY,
            `GeoIPOptions` C API settings,  respectively. Defaults to 0,
            meaning MODE_AUTO.

        * country: The name of the GeoIP country data file. Defaults to
            'GeoLite2-Country.mmdb'; overrides the GEOIP_COUNTRY setting.

        * city: The name of the GeoIP city data file. Defaults to
            'GeoLite2-City.mmdb'; overrides the GEOIP_CITY setting.
        z Invalid GeoIP caching option: %sr	   zDGeoIP path must be provided via parameter or the GEOIP_PATH setting.r   )moder
   z"Could not load a database from %s.r   r   z(Unable to recognize database edition: %sz-GeoIP path must be a valid file or directory.N)cache_optionsr   GEOIP_SETTINGSr   is_diris_filegeoip2databaseReaderstr_country_country_file_city
_city_file_readermetadatadatabase_type)	selfpathcachecountrycity
country_dbcity_dbreaderdb_typer   r   r   __init__0   sB   



zGeoIP2.__init__c                 C   s   | j p| jS N)r    r"   r'   r   r   r   r$   x      zGeoIP2._readerc                 C   s   | j r| j jS | jjS r1   )r    r*   r"   r+   r2   r   r   r   _country_or_city|   s   zGeoIP2._country_or_cityc                 C   s   | j r
| j   d S d S r1   )r$   closer2   r   r   r   __del__   s   zGeoIP2.__del__c                 C   s4   | j  }d|j|jf }d| jj|| j| jd S )Nz[v%s.%s]zH<%(cls)s %(version)s _country_file="%(country)s", _city_file="%(city)s">)clsversionr*   r+   )r$   r%   binary_format_major_versionbinary_format_minor_version	__class__r   r!   r#   )r'   metar8   r   r   r   __repr__   s   
zGeoIP2.__repr__Fc                 C   sz   t |tstdt|j |r| js| jstd|r&| js&td| j zt	| W |S  t
y<   t|}Y |S w )z*Check the query and database availability.z)GeoIP query must be a string, not type %sz*Invalid GeoIP country and city data files.z Invalid GeoIP city data file: %s)
isinstancer   	TypeErrortyper   r    r"   r   r#   r   r   socketgethostbyname)r'   queryr+   city_or_countryr   r   r   _check_query   s   


zGeoIP2._check_queryc                 C   s   | j |dd}t| j|S )z
        Return a dictionary of city information for the given IP address or
        Fully Qualified Domain Name (FQDN). Some information in the dictionary
        may be undefined (None).
        T)r+   )rE   r   r"   r+   r'   rC   	enc_queryr   r   r   r+      s   zGeoIP2.cityc                 C      |  |d S )z9Return the country code for the given IP Address or FQDN.country_coder*   r'   rC   r   r   r   rI         zGeoIP2.country_codec                 C   rH   )z9Return the country name for the given IP Address or FQDN.country_namerJ   rK   r   r   r   rM      rL   zGeoIP2.country_namec                 C   s   | j |dd}t| |S )z
        Return a dictionary with the country code and name when given an
        IP address or a Fully Qualified Domain Name (FQDN). For example, both
        '24.124.1.80' and 'djangoproject.com' are valid parameters.
        T)rD   )rE   r   r4   rF   r   r   r   r*      s   zGeoIP2.country	longitudelatitudec                    s,   |  |  d u rd S t fdd|D S )Nc                 3   s    | ]} | V  qd S r1   r   ).0ocdictr   r   	<genexpr>   s    z GeoIP2.coords.<locals>.<genexpr>)r+   tuple)r'   rC   orderingr   rS   r   coords   s   
zGeoIP2.coordsc                 C   s
   |  |S )z@Return a tuple of the (longitude, latitude) for the given query.rX   rK   r   r   r   lon_lat      
zGeoIP2.lon_latc                 C   s   |  |dS )z@Return a tuple of the (latitude, longitude) for the given query.)rP   rO   rY   rK   r   r   r   lat_lon   r3   zGeoIP2.lat_lonc                 C   s*   |  |}|rddlm} ||ddS dS )z/Return a GEOS Point object for the given query.r   )Pointi  )sridN)rZ   django.contrib.gis.geosr]   )r'   rC   llr]   r   r   r   geos   s
   
zGeoIP2.geosc                 C   s   | j  }d|j|jf S )z@Return information about the GeoIP library and databases in use.zGeoIP Library:
	%s.%s
)r$   r%   r9   r:   )r'   r<   r   r   r   info   s
   
zGeoIP2.infoc                 C   s
   t ||S r1   )r   )r7   	full_pathr)   r   r   r   open   r[   zGeoIP2.open)Nr   NN)FF)rN   ) r   r   r   	MODE_AUTOMODE_MMAP_EXT	MODE_MMAP	MODE_FILEMODE_MEMORY	frozensetr   r#   r!   r"   r    r0   propertyr$   r4   r6   r=   rE   r+   rI   rM   r*   rX   rZ   r\   ra   rb   classmethodrd   r   r   r   r   r      sB    
H


	

r   )rA   geoip2.databaser   django.confr   django.core.exceptionsr   django.core.validatorsr   django.utils._osr   	resourcesr   r   getattrr   	Exceptionr   r   r   r   r   r   <module>   s    


