Skip to content

location

pokelance.ext.location ⚓︎

Location(client) ⚓︎

Bases: BaseExtension

Extension for location related endpoints.

Attributes:

Name Type Description
cache Location

The cache for this extension.

Initializes the extension.

Parameters:

Name Type Description Default
client HttpClient

The client to use for requests.

required
Source code in pokelance/ext/_base.py
Python
def __init__(self, client: "HttpClient") -> None:
    """Initializes the extension.

    Parameters
    ----------
    client: pokelance.http.HttpClient
        The client to use for requests.
    """
    self._client = client
    self._cache = self._client.cache
    self.cache = getattr(self._cache, self.__class__.__name__.lower())

fetch_location(name) async ⚓︎

Fetches a location from the API.

Parameters:

Name Type Description Default
name Union[str, int]

The name or id of the location.

required

Returns:

Type Description
Location

The location if it exists in the API, else raises ResourceNotFound.

Raises:

Type Description
ResourceNotFound

The name or id of the location is invalid.

Examples:

Python Console Session
>>> from pokelance import PokeLance
>>> import asyncio
>>> client = PokeLance()
>>> async def main() -> None:
...     location = await client.location.fetch_location(1)
...     print(location.name)
...     await client.close()
>>> asyncio.run(main())
canalave-city
Source code in pokelance/ext/location.py
Python
async def fetch_location(self, name: t.Union[str, int]) -> LocationModel:
    """Fetches a location from the API.

    Parameters
    ----------
    name: typing.Union[str, int]
        The name or id of the location.

    Returns
    -------
    LocationModel
        The location if it exists in the API, else raises ResourceNotFound.

    Raises
    ------
    pokelance.exceptions.ResourceNotFound
        The name or id of the location is invalid.

    Examples
    --------

    >>> from pokelance import PokeLance
    >>> import asyncio
    >>> client = PokeLance()
    >>> async def main() -> None:
    ...     location = await client.location.fetch_location(1)
    ...     print(location.name)
    ...     await client.close()
    >>> asyncio.run(main())
    canalave-city
    """
    route = Endpoint.get_location(name)
    self._validate_resource(self.cache.location, name, route)
    data = await self._client.request(route)
    return self.cache.location.setdefault(route, LocationModel.from_payload(data))

fetch_location_area(name) async ⚓︎

Fetches a location area from the API.

Parameters:

Name Type Description Default
name Union[str, int]

The name or id of the location area.

required

Returns:

Type Description
LocationArea

The location area if it exists in the API, else raises ResourceNotFound.

Raises:

Type Description
ResourceNotFound

The name or id of the location area is invalid.

Examples:

Python Console Session
>>> from pokelance import PokeLance
>>> import asyncio
>>> client = PokeLance()
>>> async def main() -> None:
...     location_area = await client.location.fetch_location_area(1)
...     print(location_area.name)
...     await client.close()
>>> asyncio.run(main())
canalave-city-area
Source code in pokelance/ext/location.py
Python
async def fetch_location_area(self, name: t.Union[str, int]) -> LocationArea:
    """Fetches a location area from the API.

    Parameters
    ----------
    name: typing.Union[str, int]
        The name or id of the location area.

    Returns
    -------
    LocationArea
        The location area if it exists in the API, else raises ResourceNotFound.

    Raises
    ------
    pokelance.exceptions.ResourceNotFound
        The name or id of the location area is invalid.

    Examples
    --------

    >>> from pokelance import PokeLance
    >>> import asyncio
    >>> client = PokeLance()
    >>> async def main() -> None:
    ...     location_area = await client.location.fetch_location_area(1)
    ...     print(location_area.name)
    ...     await client.close()
    >>> asyncio.run(main())
    canalave-city-area
    """
    route = Endpoint.get_location_area(name)
    self._validate_resource(self.cache.location_area, name, route)
    data = await self._client.request(route)
    return self.cache.location_area.setdefault(route, LocationArea.from_payload(data))

fetch_pal_park_area(name) async ⚓︎

Fetches a pal park area from the API.

Parameters:

Name Type Description Default
name Union[str, int]

The name or id of the pal park area.

required

Returns:

Type Description
PalParkArea

The pal park area if it exists in the API, else raises ResourceNotFound.

Raises:

Type Description
ResourceNotFound

The name or id of the pal park area is invalid.

Examples:

Python Console Session
>>> from pokelance import PokeLance
>>> import asyncio
>>> client = PokeLance()
>>> async def main() -> None:
...     pal_park_area = await client.location.fetch_pal_park_area(1)
...     print(pal_park_area.name)
...     await client.close()
>>> asyncio.run(main())
forest
Source code in pokelance/ext/location.py
Python
async def fetch_pal_park_area(self, name: t.Union[str, int]) -> PalParkArea:
    """Fetches a pal park area from the API.

    Parameters
    ----------
    name: typing.Union[str, int]
        The name or id of the pal park area.

    Returns
    -------
    PalParkArea
        The pal park area if it exists in the API, else raises ResourceNotFound.

    Raises
    ------
    pokelance.exceptions.ResourceNotFound
        The name or id of the pal park area is invalid.

    Examples
    --------

    >>> from pokelance import PokeLance
    >>> import asyncio
    >>> client = PokeLance()
    >>> async def main() -> None:
    ...     pal_park_area = await client.location.fetch_pal_park_area(1)
    ...     print(pal_park_area.name)
    ...     await client.close()
    >>> asyncio.run(main())
    forest
    """
    route = Endpoint.get_pal_park_area(name)
    self._validate_resource(self.cache.pal_park_area, name, route)
    data = await self._client.request(route)
    return self.cache.pal_park_area.setdefault(route, PalParkArea.from_payload(data))

fetch_region(name) async ⚓︎

Fetches a region from the API.

Parameters:

Name Type Description Default
name Union[str, int]

The name or id of the region.

required

Returns:

Type Description
Region

The region if it exists in the API, else raises ResourceNotFound.

Raises:

Type Description
ResourceNotFound

The name or id of the region is invalid.

Examples:

Python Console Session
>>> from pokelance import PokeLance
>>> import asyncio
>>> client = PokeLance()
>>> async def main() -> None:
...     region = await client.location.fetch_region(1)
...     print(region.name)
...     await client.close()
>>> asyncio.run(main())
kanto
Source code in pokelance/ext/location.py
Python
async def fetch_region(self, name: t.Union[str, int]) -> Region:
    """Fetches a region from the API.

    Parameters
    ----------
    name: typing.Union[str, int]
        The name or id of the region.

    Returns
    -------
    Region
        The region if it exists in the API, else raises ResourceNotFound.

    Raises
    ------
    pokelance.exceptions.ResourceNotFound
        The name or id of the region is invalid.

    Examples
    --------

    >>> from pokelance import PokeLance
    >>> import asyncio
    >>> client = PokeLance()
    >>> async def main() -> None:
    ...     region = await client.location.fetch_region(1)
    ...     print(region.name)
    ...     await client.close()
    >>> asyncio.run(main())
    kanto
    """
    route = Endpoint.get_region(name)
    self._validate_resource(self.cache.region, name, route)
    data = await self._client.request(route)
    return self.cache.region.setdefault(route, Region.from_payload(data))

get_location(name) ⚓︎

Gets a location from the cache.

Parameters:

Name Type Description Default
name Union[str, int]

The name or id of the location.

required

Returns:

Type Description
Optional[Location]

The location if it exists in the cache, else None.

Raises:

Type Description
ResourceNotFound

The name or id of the item pocket is invalid.

Examples:

Python Console Session
>>> from pokelance import PokeLance
>>> client = PokeLance()
>>> location = client.location.get_location(1)
>>> location.name
'canalave-city'
Source code in pokelance/ext/location.py
Python
def get_location(self, name: t.Union[str, int]) -> t.Optional[LocationModel]:
    """Gets a location from the cache.

    Parameters
    ----------
    name: typing.Union[str, int]
        The name or id of the location.

    Returns
    -------
    typing.Optional[pokelance.models.Location]
        The location if it exists in the cache, else None.

    Raises
    ------
    pokelance.exceptions.ResourceNotFound
        The name or id of the item pocket is invalid.

    Examples
    --------

    >>> from pokelance import PokeLance
    >>> client = PokeLance()
    >>> location = client.location.get_location(1)
    >>> location.name
    'canalave-city'
    """
    route = Endpoint.get_location(name)
    self._validate_resource(self.cache.location, name, route)
    return self.cache.location.get(route, None)

get_location_area(name) ⚓︎

Gets a location area from the cache.

Parameters:

Name Type Description Default
name Union[str, int]

The name or id of the location area.

required

Returns:

Type Description
Optional[LocationArea]

The location area if it exists in the cache, else None.

Raises:

Type Description
ResourceNotFound

The name or id of the location area is invalid.

Examples:

Python Console Session
>>> from pokelance import PokeLance
>>> client = PokeLance()
>>> location_area = client.location.get_location_area(1)
>>> location_area.name
'canalave-city-area'
Source code in pokelance/ext/location.py
Python
def get_location_area(self, name: t.Union[str, int]) -> t.Optional[LocationArea]:
    """Gets a location area from the cache.

    Parameters
    ----------
    name: typing.Union[str, int]
        The name or id of the location area.

    Returns
    -------
    typing.Optional[pokelance.models.LocationArea]
        The location area if it exists in the cache, else None.

    Raises
    ------
    pokelance.exceptions.ResourceNotFound
        The name or id of the location area is invalid.

    Examples
    --------

    >>> from pokelance import PokeLance
    >>> client = PokeLance()
    >>> location_area = client.location.get_location_area(1)
    >>> location_area.name
    'canalave-city-area'
    """
    route = Endpoint.get_location_area(name)
    self._validate_resource(self.cache.location_area, name, route)
    return self.cache.location_area.get(route, None)

get_message(case, data) staticmethod ⚓︎

Gets the error message for a resource not found error.

Parameters:

Name Type Description Default
case str

The case to use for the error message.

required
data Set[str]

The data to use for the error message.

required

Returns:

Type Description
str

The error message.

Source code in pokelance/ext/_base.py
Python
@staticmethod
def get_message(case: str, data: t.Set[str]) -> str:
    """Gets the error message for a resource not found error.

    Parameters
    ----------
    case: str
        The case to use for the error message.
    data: typing.Set[str]
        The data to use for the error message.

    Returns
    -------
    str
        The error message.
    """
    matches = get_close_matches(case, data, n=10, cutoff=0.5)
    if matches:
        return f"Resource not found. Did you mean {', '.join(matches)}?"
    return "Resource not found."

get_pal_park_area(name) ⚓︎

Gets a pal park area from the cache.

Parameters:

Name Type Description Default
name Union[str, int]

The name or id of the pal park area.

required

Returns:

Type Description
Optional[PalParkArea]

The pal park area if it exists in the cache, else None.

Raises:

Type Description
ResourceNotFound

The name or id of the pal park area is invalid.

Examples:

Python Console Session
>>> from pokelance import PokeLance
>>> client = PokeLance()
>>> pal_park_area = client.location.get_pal_park_area(1)
>>> pal_park_area.name
'forest'
Source code in pokelance/ext/location.py
Python
def get_pal_park_area(self, name: t.Union[str, int]) -> t.Optional[PalParkArea]:
    """Gets a pal park area from the cache.

    Parameters
    ----------
    name: typing.Union[str, int]
        The name or id of the pal park area.

    Returns
    -------
    typing.Optional[pokelance.models.PalParkArea]
        The pal park area if it exists in the cache, else None.

    Raises
    ------
    pokelance.exceptions.ResourceNotFound
        The name or id of the pal park area is invalid.

    Examples
    --------

    >>> from pokelance import PokeLance
    >>> client = PokeLance()
    >>> pal_park_area = client.location.get_pal_park_area(1)
    >>> pal_park_area.name
    'forest'
    """
    route = Endpoint.get_pal_park_area(name)
    self._validate_resource(self.cache.pal_park_area, name, route)
    return self.cache.pal_park_area.get(route, None)

get_region(name) ⚓︎

Gets a region from the cache.

Parameters:

Name Type Description Default
name Union[str, int]

The name or id of the region.

required

Returns:

Type Description
Optional[Region]

The region if it exists in the cache, else None.

Raises:

Type Description
ResourceNotFound

The name or id of the region is invalid.

Examples:

Python Console Session
>>> from pokelance import PokeLance
>>> client = PokeLance()
>>> region = client.location.get_region(1)
>>> region.name
'kanto'
Source code in pokelance/ext/location.py
Python
def get_region(self, name: t.Union[str, int]) -> t.Optional[Region]:
    """Gets a region from the cache.

    Parameters
    ----------
    name: typing.Union[str, int]
        The name or id of the region.

    Returns
    -------
    typing.Optional[pokelance.models.Region]
        The region if it exists in the cache, else None.

    Raises
    ------
    pokelance.exceptions.ResourceNotFound
        The name or id of the region is invalid.

    Examples
    --------

    >>> from pokelance import PokeLance
    >>> client = PokeLance()
    >>> region = client.location.get_region(1)
    >>> region.name
    'kanto'
    """
    route = Endpoint.get_region(name)
    self._validate_resource(self.cache.region, name, route)
    return self.cache.region.get(route, None)

setup() async ⚓︎

Sets up the extension.

Source code in pokelance/ext/_base.py
Python
async def setup(self) -> None:
    """Sets up the extension."""
    for item in dir(self):
        if item.startswith("fetch_"):
            data = await self._client.request(
                t.cast(t.Callable[[], "Route"], getattr(Endpoint, f"get_{item[6:]}_endpoints"))()
            )
            self._cache.load_documents(str(self.__class__.__name__), item[6:], data["results"])

setup(lance) ⚓︎

Sets up the location cog.

Source code in pokelance/ext/location.py
Python
def setup(lance: "PokeLance") -> None:
    """Sets up the location cog."""
    lance.add_extension("location", Location(lance.http))