Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions fishjam/_openapi_client/api/moq/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
"""Contains endpoint functions for accessing the API"""
165 changes: 165 additions & 0 deletions fishjam/_openapi_client/api/moq/create_moq_publisher_token.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,165 @@
from http import HTTPStatus
from typing import Any
from urllib.parse import quote

import httpx

from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.error import Error
from ...models.moq_token import MoqToken
from ...types import Response


def _get_kwargs(
stream_id: str,
) -> dict[str, Any]:
_kwargs: dict[str, Any] = {
"method": "post",
"url": "/moq/{stream_id}/publisher".format(
stream_id=quote(str(stream_id), safe=""),
),
}

return _kwargs


def _parse_response(
*, client: AuthenticatedClient | Client, response: httpx.Response
) -> Error | MoqToken | None:
if response.status_code == 200:
response_200 = MoqToken.from_dict(response.json())

return response_200

if response.status_code == 401:
response_401 = Error.from_dict(response.json())

return response_401

if response.status_code == 503:
response_503 = Error.from_dict(response.json())

return response_503

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[Error | MoqToken]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)


def sync_detailed(
stream_id: str,
*,
client: AuthenticatedClient,
) -> Response[Error | MoqToken]:
"""Creates a MoQ publisher token for the given stream

Args:
stream_id (str):

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[Error | MoqToken]
"""

kwargs = _get_kwargs(
stream_id=stream_id,
)

response = client.get_httpx_client().request(
**kwargs,
)

return _build_response(client=client, response=response)


def sync(
stream_id: str,
*,
client: AuthenticatedClient,
) -> Error | MoqToken | None:
"""Creates a MoQ publisher token for the given stream

Args:
stream_id (str):

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:
Error | MoqToken
"""

return sync_detailed(
stream_id=stream_id,
client=client,
).parsed


async def asyncio_detailed(
stream_id: str,
*,
client: AuthenticatedClient,
) -> Response[Error | MoqToken]:
"""Creates a MoQ publisher token for the given stream

Args:
stream_id (str):

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[Error | MoqToken]
"""

kwargs = _get_kwargs(
stream_id=stream_id,
)

response = await client.get_async_httpx_client().request(**kwargs)

return _build_response(client=client, response=response)


async def asyncio(
stream_id: str,
*,
client: AuthenticatedClient,
) -> Error | MoqToken | None:
"""Creates a MoQ publisher token for the given stream

Args:
stream_id (str):

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:
Error | MoqToken
"""

return (
await asyncio_detailed(
stream_id=stream_id,
client=client,
)
).parsed
165 changes: 165 additions & 0 deletions fishjam/_openapi_client/api/moq/create_moq_subscriber_token.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,165 @@
from http import HTTPStatus
from typing import Any
from urllib.parse import quote

import httpx

from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.error import Error
from ...models.moq_token import MoqToken
from ...types import Response


def _get_kwargs(
stream_id: str,
) -> dict[str, Any]:
_kwargs: dict[str, Any] = {
"method": "post",
"url": "/moq/{stream_id}/subscriber".format(
stream_id=quote(str(stream_id), safe=""),
),
}

return _kwargs


def _parse_response(
*, client: AuthenticatedClient | Client, response: httpx.Response
) -> Error | MoqToken | None:
if response.status_code == 200:
response_200 = MoqToken.from_dict(response.json())

return response_200

if response.status_code == 401:
response_401 = Error.from_dict(response.json())

return response_401

if response.status_code == 503:
response_503 = Error.from_dict(response.json())

return response_503

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[Error | MoqToken]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)


def sync_detailed(
stream_id: str,
*,
client: AuthenticatedClient,
) -> Response[Error | MoqToken]:
"""Creates a MoQ subscriber token for the given stream

Args:
stream_id (str):

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[Error | MoqToken]
"""

kwargs = _get_kwargs(
stream_id=stream_id,
)

response = client.get_httpx_client().request(
**kwargs,
)

return _build_response(client=client, response=response)


def sync(
stream_id: str,
*,
client: AuthenticatedClient,
) -> Error | MoqToken | None:
"""Creates a MoQ subscriber token for the given stream

Args:
stream_id (str):

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:
Error | MoqToken
"""

return sync_detailed(
stream_id=stream_id,
client=client,
).parsed


async def asyncio_detailed(
stream_id: str,
*,
client: AuthenticatedClient,
) -> Response[Error | MoqToken]:
"""Creates a MoQ subscriber token for the given stream

Args:
stream_id (str):

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[Error | MoqToken]
"""

kwargs = _get_kwargs(
stream_id=stream_id,
)

response = await client.get_async_httpx_client().request(**kwargs)

return _build_response(client=client, response=response)


async def asyncio(
stream_id: str,
*,
client: AuthenticatedClient,
) -> Error | MoqToken | None:
"""Creates a MoQ subscriber token for the given stream

Args:
stream_id (str):

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:
Error | MoqToken
"""

return (
await asyncio_detailed(
stream_id=stream_id,
client=client,
)
).parsed
2 changes: 2 additions & 0 deletions fishjam/_openapi_client/models/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
from .audio_sample_rate import AudioSampleRate
from .composition_info import CompositionInfo
from .error import Error
from .moq_token import MoqToken
from .peer import Peer
from .peer_config import PeerConfig
from .peer_details_response import PeerDetailsResponse
Expand Down Expand Up @@ -52,6 +53,7 @@
"AudioSampleRate",
"CompositionInfo",
"Error",
"MoqToken",
"Peer",
"PeerConfig",
"PeerDetailsResponse",
Expand Down
Loading
Loading