Warning
This document is for an in-development version of Galaxy. You can alternatively view this page in the latest release if it exists or view the top of the latest release's documentation.
Source code for galaxy.webapps.galaxy.api.genomes
from typing import (
Any,
List,
)
from fastapi import (
Path,
Query,
)
from fastapi.responses import Response
from galaxy.managers.context import ProvidesUserContext
from galaxy.managers.genomes import GenomesManager
from . import (
depends,
DependsOnTrans,
Router,
)
router = Router(tags=["genomes"])
IdPathParam: str = Path(..., title="Genome ID", description="Genome ID")
ChromInfoQueryParam: bool = Query(
None, title="ChromInfo", description="If true, return genome keys with chromosome lengths"
)
NumQueryParam: int = Query(
None,
title="Number",
description="Limits size of returned data",
)
ChromQueryParam: Any = Query(
None,
title="Chrom",
description="Limits size of returned data",
)
LowQueryParam: int = Query(
None,
title="Low",
description="Limits size of returned data",
)
HighQueryParam: int = Query(
None,
title="High",
description="Limits size of returned data",
)
FormatQueryParam: str = Query(None, title="Format", description="Format")
ReferenceQueryParam: bool = Query(None, title="Reference", description="If true, return reference data")
IndexTypeQueryParam: str = Query(
"fasta_indexes", title="Index type", description="Index type" # currently this is the only supported index type
)
[docs]@router.cbv
class FastAPIGenomes:
manager: GenomesManager = depends(GenomesManager)
[docs] @router.get("/api/genomes", summary="Return a list of installed genomes", response_description="Installed genomes")
def index(
self, trans: ProvidesUserContext = DependsOnTrans, chrom_info: bool = ChromInfoQueryParam
) -> List[List[str]]:
return self.manager.get_dbkeys(trans.user, chrom_info)
[docs] @router.get(
"/api/genomes/{id}",
summary="Return information about build <id>",
response_description="Information about genome build <id>",
)
def show(
self,
trans: ProvidesUserContext = DependsOnTrans,
id: str = IdPathParam,
reference: bool = ReferenceQueryParam,
num: int = NumQueryParam,
chrom: str = ChromQueryParam,
low: int = LowQueryParam,
high: int = HighQueryParam,
format: str = FormatQueryParam,
) -> Any:
id = get_id(id, format)
return self.manager.get_genome(trans, id, num, chrom, low, high, reference)
[docs] @router.get(
"/api/genomes/{id}/indexes",
summary="Return all available indexes for a genome id for provided type",
response_description="Indexes for a genome id for provided type",
)
def indexes(
self,
trans: ProvidesUserContext = DependsOnTrans, # may want to get custom index in the future
id: str = IdPathParam,
type: str = IndexTypeQueryParam,
format: str = FormatQueryParam,
) -> Any:
id = get_id(id, format)
rval = self.manager.get_indexes(id, type)
return Response(rval)
[docs] @router.get(
"/api/genomes/{id}/sequences", summary="Return raw sequence data", response_description="Raw sequence data"
)
def sequences(
self,
trans: ProvidesUserContext = DependsOnTrans,
id: str = IdPathParam,
reference: bool = ReferenceQueryParam,
chrom: str = ChromQueryParam,
low: int = LowQueryParam,
high: int = HighQueryParam,
format: str = FormatQueryParam,
) -> Any:
id = get_id(id, format)
rval = self.manager.get_sequence(trans, id, chrom, low, high)
return Response(rval)