U
    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   B/tmp/pip-unpacked-wheel-lctamlir/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 krtd| |p td }|s.tdt|}| r||pJtd  }| rrtjjt	||d| _
|| _||p~td  }| rtjjt	||d| _|| _| jstd| nl| rtjjt	||d}| j}d|kr|| _|| _n$d	|kr|| _
|| _ntd
| ntddS )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geoip2ZdatabaseReaderstr_country_country_file_city
_city_file_readermetadataZdatabase_type)	selfpathcachecountrycityZ
country_dbZcity_dbreaderZdb_typer   r   r   __init__0   s@    



zGeoIP2.__init__c                 C   s   | j p
| jS N)r   r!   r%   r   r   r   r#   x   s    zGeoIP2._readerc                 C   s   | j r| j jS | jjS d S r,   )r   r(   r!   r)   r-   r   r   r   _country_or_city|   s    zGeoIP2._country_or_cityc                 C   s   | j r| j   d S r,   )r#   closer-   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%   metar2   r   r   r   __repr__   s    
zGeoIP2.__repr__Fc                 C   s~   t |tstdt|j |r6| js6| js6tdn|rN| jsNtd| j zt	| W n t
k
rx   t|}Y nX |S )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)   )r?   r   r!   r)   r%   r=   Z	enc_queryr   r   r   r)      s    zGeoIP2.cityc                 C   s   |  |d S )z9Return the country code for the given IP Address or FQDN.country_coder(   r%   r=   r   r   r   rA      s    zGeoIP2.country_codec                 C   s   |  |d S )z9Return the country name for the given IP Address or FQDN.country_namerB   rC   r   r   r   rD      s    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)r>   )r?   r   r.   r@   r   r   r   r(      s    zGeoIP2.country	longitudelatitudec                    s0   |  |  d krd S t fdd|D S d S )Nc                 3   s   | ]} | V  qd S r,   r   ).0oZcdictr   r   	<genexpr>   s     z GeoIP2.coords.<locals>.<genexpr>)r)   tuple)r%   r=   Zorderingr   rJ   r   coords   s    
zGeoIP2.coordsc                 C   s
   |  |S )z@Return a tuple of the (longitude, latitude) for the given query.rM   rC   r   r   r   lon_lat   s    zGeoIP2.lon_latc                 C   s   |  |dS )z@Return a tuple of the (latitude, longitude) for the given query.)rG   rF   rN   rC   r   r   r   lat_lon   s    zGeoIP2.lat_lonc                 C   s.   |  |}|r&ddlm} ||ddS dS dS )z/Return a GEOS Point object for the given query.r   )Pointi  )ZsridN)rO   Zdjango.contrib.gis.geosrQ   )r%   r=   ZllrQ   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$   r3   r4   )r%   r6   r   r   r   info   s
    
zGeoIP2.infoc                 C   s
   t ||S r,   )r   )r1   	full_pathr'   r   r   r   open   s    zGeoIP2.open)Nr   NN)FF)rE   ) r   r   r   Z	MODE_AUTOZMODE_MMAP_EXTZ	MODE_MMAPZ	MODE_FILEZMODE_MEMORY	frozensetr   r"   r    r!   r   r+   propertyr#   r.   r0   r7   r?   r)   rA   rD   r(   rM   rO   rP   rR   rS   classmethodrU   r   r   r   r   r      s@   
H


	

r   )r;   Zgeoip2.databaser   Zdjango.confr   Zdjango.core.exceptionsr   Zdjango.core.validatorsr   Zdjango.utils._osr   	resourcesr   r   getattrr   	Exceptionr   r   r   r   r   r   <module>   s   


