sachet/server/views_common.py: split off POST from ModelAPI

Now it's in ModelListAPI
This commit is contained in:
dogeystamp 2023-04-25 19:17:07 -04:00
parent 3473156417
commit bfd0cd8fdf
Signed by: dogeystamp
GPG Key ID: 7225FE3592EFFA38
2 changed files with 7 additions and 3 deletions

View File

@ -3,7 +3,7 @@ import io
from flask import Blueprint, request, jsonify, send_file from flask import Blueprint, request, jsonify, send_file
from flask.views import MethodView from flask.views import MethodView
from sachet.server.models import Share, Permissions from sachet.server.models import Share, Permissions
from sachet.server.views_common import ModelAPI, auth_required from sachet.server.views_common import ModelAPI, ModelListAPI, auth_required
from sachet.server import storage, db from sachet.server import storage, db
files_blueprint = Blueprint("files_blueprint", __name__) files_blueprint = Blueprint("files_blueprint", __name__)
@ -38,7 +38,7 @@ files_blueprint.add_url_rule(
) )
class FilesAPI(ModelAPI): class FilesAPI(ModelListAPI):
@auth_required(required_permissions=(Permissions.CREATE,)) @auth_required(required_permissions=(Permissions.CREATE,))
def post(self, auth_user=None): def post(self, auth_user=None):
data = request.get_json() data = request.get_json()

View File

@ -94,7 +94,7 @@ def patch(orig, diff):
class ModelAPI(MethodView): class ModelAPI(MethodView):
"""Generic REST API for interacting with models.""" """Generic REST API for the representation of a model instance."""
def get(self, model): def get(self, model):
if not model: if not model:
@ -190,6 +190,10 @@ class ModelAPI(MethodView):
return jsonify({"status": "success"}) return jsonify({"status": "success"})
class ModelListAPI(MethodView):
"""Generic API for representing all instances of a given model."""
def post(self, ModelClass, data={}): def post(self, ModelClass, data={}):
"""Create new instance of a class. """Create new instance of a class.