Module kibicara.webapi.hoods.badwords
REST API endpoints for managing badwords.
Provides API endpoints for adding, removing and reading regular expressions that block a received message to be dropped by a censor. This provides a message filter customizable by the hood admins.
Expand source code
# Copyright (C) 2020 by Thomas Lindner <tom@dl6tom.de>
# Copyright (C) 2020 by Cathy Hu <cathy.hu@fau.de>
#
# SPDX-License-Identifier: 0BSD
""" REST API endpoints for managing badwords.
Provides API endpoints for adding, removing and reading regular expressions that block a
received message to be dropped by a censor. This provides a message filter customizable
by the hood admins.
"""
from fastapi import APIRouter, Depends, HTTPException, Response, status
from kibicara.model import BadWord
from kibicara.webapi.hoods import get_hood
from ormantic.exceptions import NoMatch
from pydantic import BaseModel
from re import compile as regex_compile, error as RegexError
from sqlite3 import IntegrityError
class BodyBadWord(BaseModel):
pattern: str
async def get_badword(badword_id: int, hood=Depends(get_hood)):
try:
return await BadWord.objects.get(id=badword_id, hood=hood)
except NoMatch:
raise HTTPException(status_code=status.HTTP_404_NOT_FOUND)
router = APIRouter()
@router.get(
'/',
# TODO response_model,
operation_id='get_badwords',
)
async def badword_read_all(hood=Depends(get_hood)):
""" Get all badwords of hood with id **hood_id**. """
return await BadWord.objects.filter(hood=hood).all()
@router.post(
'/',
status_code=status.HTTP_201_CREATED,
# TODO response_model,
operation_id='create_badword',
)
async def badword_create(
values: BodyBadWord, response: Response, hood=Depends(get_hood)
):
"""Creates a new badword for hood with id **hood_id**.
- **pattern**: Regular expression which is used to match a badword.
"""
try:
regex_compile(values.pattern)
badword = await BadWord.objects.create(hood=hood, **values.__dict__)
response.headers['Location'] = '%d' % badword.id
return badword
except IntegrityError:
raise HTTPException(status_code=status.HTTP_409_CONFLICT)
except RegexError:
raise HTTPException(status_code=status.HTTP_422_UNPROCESSABLE_ENTITY)
@router.get(
'/{badword_id}',
# TODO response_model,
operation_id='get_badword',
)
async def badword_read(badword=Depends(get_badword)):
""" Reads badword with id **badword_id** for hood with id **hood_id**. """
return badword
@router.put(
'/{badword_id}',
status_code=status.HTTP_204_NO_CONTENT,
operation_id='update_badword',
)
async def badword_update(values: BodyBadWord, badword=Depends(get_badword)):
"""Updates badword with id **badword_id** for hood with id **hood_id**.
- **pattern**: Regular expression which is used to match a badword
"""
await badword.update(**values.__dict__)
return Response(status_code=status.HTTP_204_NO_CONTENT)
@router.delete(
'/{badword_id}',
status_code=status.HTTP_204_NO_CONTENT,
operation_id='delete_badword',
)
async def badword_delete(badword=Depends(get_badword)):
""" Deletes badword with id **badword_id** for hood with id **hood_id**. """
await badword.delete()
return Response(status_code=status.HTTP_204_NO_CONTENT)
Functions
async def badword_create(values: BodyBadWord, response: starlette.responses.Response, hood=Depends(get_hood))
-
Creates a new badword for hood with id hood_id.
- pattern: Regular expression which is used to match a badword.
Expand source code
@router.post( '/', status_code=status.HTTP_201_CREATED, # TODO response_model, operation_id='create_badword', ) async def badword_create( values: BodyBadWord, response: Response, hood=Depends(get_hood) ): """Creates a new badword for hood with id **hood_id**. - **pattern**: Regular expression which is used to match a badword. """ try: regex_compile(values.pattern) badword = await BadWord.objects.create(hood=hood, **values.__dict__) response.headers['Location'] = '%d' % badword.id return badword except IntegrityError: raise HTTPException(status_code=status.HTTP_409_CONFLICT) except RegexError: raise HTTPException(status_code=status.HTTP_422_UNPROCESSABLE_ENTITY)
async def badword_delete(badword=Depends(get_badword))
-
Deletes badword with id badword_id for hood with id hood_id.
Expand source code
@router.delete( '/{badword_id}', status_code=status.HTTP_204_NO_CONTENT, operation_id='delete_badword', ) async def badword_delete(badword=Depends(get_badword)): """ Deletes badword with id **badword_id** for hood with id **hood_id**. """ await badword.delete() return Response(status_code=status.HTTP_204_NO_CONTENT)
async def badword_read(badword=Depends(get_badword))
-
Reads badword with id badword_id for hood with id hood_id.
Expand source code
@router.get( '/{badword_id}', # TODO response_model, operation_id='get_badword', ) async def badword_read(badword=Depends(get_badword)): """ Reads badword with id **badword_id** for hood with id **hood_id**. """ return badword
async def badword_read_all(hood=Depends(get_hood))
-
Get all badwords of hood with id hood_id.
Expand source code
@router.get( '/', # TODO response_model, operation_id='get_badwords', ) async def badword_read_all(hood=Depends(get_hood)): """ Get all badwords of hood with id **hood_id**. """ return await BadWord.objects.filter(hood=hood).all()
async def badword_update(values: BodyBadWord, badword=Depends(get_badword))
-
Updates badword with id badword_id for hood with id hood_id.
- pattern: Regular expression which is used to match a badword
Expand source code
@router.put( '/{badword_id}', status_code=status.HTTP_204_NO_CONTENT, operation_id='update_badword', ) async def badword_update(values: BodyBadWord, badword=Depends(get_badword)): """Updates badword with id **badword_id** for hood with id **hood_id**. - **pattern**: Regular expression which is used to match a badword """ await badword.update(**values.__dict__) return Response(status_code=status.HTTP_204_NO_CONTENT)
async def get_badword(badword_id: int, hood=Depends(get_hood))
-
Expand source code
async def get_badword(badword_id: int, hood=Depends(get_hood)): try: return await BadWord.objects.get(id=badword_id, hood=hood) except NoMatch: raise HTTPException(status_code=status.HTTP_404_NOT_FOUND)
Classes
class BodyBadWord (**data: Any)
-
Create a new model by parsing and validating input data from keyword arguments.
Raises ValidationError if the input data cannot be parsed to form a valid model.
Expand source code
class BodyBadWord(BaseModel): pattern: str
Ancestors
- pydantic.main.BaseModel
- pydantic.utils.Representation
Class variables
var pattern : str