from http import HTTPStatus
from typing import Any
import httpx
from ... import errors
from ...client import (
AuthenticatedClient,
Client,
)
from ...models.list_mgnify_studies_order_type_0 import ListMgnifyStudiesOrderType0
from ...models.ninja_pagination_response_schema_m_gnify_study import (
NinjaPaginationResponseSchemaMGnifyStudy,
)
from ...models.pipeline_versions import PipelineVersions
from ...types import (
UNSET,
Response,
Unset,
)
def _get_kwargs(
*,
order: ListMgnifyStudiesOrderType0 | None | Unset = UNSET,
biome_lineage: None | str | Unset = UNSET,
has_analyses_from_pipeline: None | PipelineVersions | Unset = UNSET,
search: None | str | Unset = UNSET,
page: int | Unset = 1,
page_size: int | None | Unset = UNSET,
) -> dict[str, Any]:
params: dict[str, Any] = {}
json_order: None | str | Unset
if isinstance(order, Unset):
json_order = UNSET
elif isinstance(order, ListMgnifyStudiesOrderType0):
json_order = order.value
else:
json_order = order
params["order"] = json_order
json_biome_lineage: None | str | Unset
if isinstance(biome_lineage, Unset):
json_biome_lineage = UNSET
else:
json_biome_lineage = biome_lineage
params["biome_lineage"] = json_biome_lineage
json_has_analyses_from_pipeline: None | str | Unset
if isinstance(has_analyses_from_pipeline, Unset):
json_has_analyses_from_pipeline = UNSET
elif isinstance(has_analyses_from_pipeline, PipelineVersions):
json_has_analyses_from_pipeline = has_analyses_from_pipeline.value
else:
json_has_analyses_from_pipeline = has_analyses_from_pipeline
params["has_analyses_from_pipeline"] = json_has_analyses_from_pipeline
json_search: None | str | Unset
if isinstance(search, Unset):
json_search = UNSET
else:
json_search = search
params["search"] = json_search
params["page"] = page
json_page_size: int | None | Unset
if isinstance(page_size, Unset):
json_page_size = UNSET
else:
json_page_size = page_size
params["page_size"] = json_page_size
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: dict[str, Any] = {
"method": "get",
"url": "/metagenomics/api/v2/studies/",
"params": params,
}
return _kwargs
def _parse_response(
*, client: AuthenticatedClient | Client, response: httpx.Response
) -> NinjaPaginationResponseSchemaMGnifyStudy | None:
if response.status_code == 200:
response_200 = NinjaPaginationResponseSchemaMGnifyStudy.from_dict(
response.json()
)
return response_200
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: AuthenticatedClient | Client, response: httpx.Response
) -> Response[NinjaPaginationResponseSchemaMGnifyStudy]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
[docs]
def sync_detailed(
*,
client: AuthenticatedClient | Client,
order: ListMgnifyStudiesOrderType0 | None | Unset = UNSET,
biome_lineage: None | str | Unset = UNSET,
has_analyses_from_pipeline: None | PipelineVersions | Unset = UNSET,
search: None | str | Unset = UNSET,
page: int | Unset = 1,
page_size: int | None | Unset = UNSET,
) -> Response[NinjaPaginationResponseSchemaMGnifyStudy]:
"""List all studies analysed by MGnify
MGnify studies inherit directly from studies (or projects) in ENA.
Args:
order (ListMgnifyStudiesOrderType0 | None | Unset):
biome_lineage (None | str | Unset): The lineage to match, including all descendant biomes
has_analyses_from_pipeline (None | PipelineVersions | Unset): If set, will only show
studies with analyses from the specified MGnify pipeline version
search (None | str | Unset): Search within study titles and accessions
page (int | Unset): Default: 1.
page_size (int | None | Unset):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[NinjaPaginationResponseSchemaMGnifyStudy]
"""
kwargs = _get_kwargs(
order=order,
biome_lineage=biome_lineage,
has_analyses_from_pipeline=has_analyses_from_pipeline,
search=search,
page=page,
page_size=page_size,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
[docs]
def sync(
*,
client: AuthenticatedClient | Client,
order: ListMgnifyStudiesOrderType0 | None | Unset = UNSET,
biome_lineage: None | str | Unset = UNSET,
has_analyses_from_pipeline: None | PipelineVersions | Unset = UNSET,
search: None | str | Unset = UNSET,
page: int | Unset = 1,
page_size: int | None | Unset = UNSET,
) -> NinjaPaginationResponseSchemaMGnifyStudy | None:
"""List all studies analysed by MGnify
MGnify studies inherit directly from studies (or projects) in ENA.
Args:
order (ListMgnifyStudiesOrderType0 | None | Unset):
biome_lineage (None | str | Unset): The lineage to match, including all descendant biomes
has_analyses_from_pipeline (None | PipelineVersions | Unset): If set, will only show
studies with analyses from the specified MGnify pipeline version
search (None | str | Unset): Search within study titles and accessions
page (int | Unset): Default: 1.
page_size (int | None | Unset):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
NinjaPaginationResponseSchemaMGnifyStudy
"""
return sync_detailed(
client=client,
order=order,
biome_lineage=biome_lineage,
has_analyses_from_pipeline=has_analyses_from_pipeline,
search=search,
page=page,
page_size=page_size,
).parsed
[docs]
async def asyncio_detailed(
*,
client: AuthenticatedClient | Client,
order: ListMgnifyStudiesOrderType0 | None | Unset = UNSET,
biome_lineage: None | str | Unset = UNSET,
has_analyses_from_pipeline: None | PipelineVersions | Unset = UNSET,
search: None | str | Unset = UNSET,
page: int | Unset = 1,
page_size: int | None | Unset = UNSET,
) -> Response[NinjaPaginationResponseSchemaMGnifyStudy]:
"""List all studies analysed by MGnify
MGnify studies inherit directly from studies (or projects) in ENA.
Args:
order (ListMgnifyStudiesOrderType0 | None | Unset):
biome_lineage (None | str | Unset): The lineage to match, including all descendant biomes
has_analyses_from_pipeline (None | PipelineVersions | Unset): If set, will only show
studies with analyses from the specified MGnify pipeline version
search (None | str | Unset): Search within study titles and accessions
page (int | Unset): Default: 1.
page_size (int | None | Unset):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[NinjaPaginationResponseSchemaMGnifyStudy]
"""
kwargs = _get_kwargs(
order=order,
biome_lineage=biome_lineage,
has_analyses_from_pipeline=has_analyses_from_pipeline,
search=search,
page=page,
page_size=page_size,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
[docs]
async def asyncio(
*,
client: AuthenticatedClient | Client,
order: ListMgnifyStudiesOrderType0 | None | Unset = UNSET,
biome_lineage: None | str | Unset = UNSET,
has_analyses_from_pipeline: None | PipelineVersions | Unset = UNSET,
search: None | str | Unset = UNSET,
page: int | Unset = 1,
page_size: int | None | Unset = UNSET,
) -> NinjaPaginationResponseSchemaMGnifyStudy | None:
"""List all studies analysed by MGnify
MGnify studies inherit directly from studies (or projects) in ENA.
Args:
order (ListMgnifyStudiesOrderType0 | None | Unset):
biome_lineage (None | str | Unset): The lineage to match, including all descendant biomes
has_analyses_from_pipeline (None | PipelineVersions | Unset): If set, will only show
studies with analyses from the specified MGnify pipeline version
search (None | str | Unset): Search within study titles and accessions
page (int | Unset): Default: 1.
page_size (int | None | Unset):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
NinjaPaginationResponseSchemaMGnifyStudy
"""
return (
await asyncio_detailed(
client=client,
order=order,
biome_lineage=biome_lineage,
has_analyses_from_pipeline=has_analyses_from_pipeline,
search=search,
page=page,
page_size=page_size,
)
).parsed