Wystarczy ruszania z kolbą, stosując się przy http://flask.pocoo.org/docs/views/Flask - zagnieżdżony api api - użyj czegoś innego niż widok metodyczny lub czy zrobiłem zły projekt?
Say Mam podstawowe API REST, w tym przypadku do objawów:
/
GET - list
POST - create
/<symptomid>
GET - detail
PUT - replace
PATCH - patch
DELETE - delete
mogę wdrożyć to dość gładko z kolbą na MethodView
następująco:
from flask import Blueprint, request, g
from flask.views import MethodView
#...
mod = Blueprint('api', __name__, url_prefix='/api')
class SymptomAPI(MethodView):
""" ... """
url = "/symptoms/"
def get(self, uid):
if uid is None:
return self.list()
else:
return self.detail(uid)
def list(self):
# ...
def post(self):
# ...
def detail(self, uid):
# ...
def put(self, uid):
# ...
def patch(self, uid):
# ...
def delete(self, uid):
# ...
@classmethod
def register(cls, mod):
symfunc = cls.as_view("symptom_api")
mod.add_url_rule(cls.url, defaults={"uid": None}, view_func=symfunc,
methods=["GET"])
mod.add_url_rule(cls.url, view_func=symfunc, methods=["POST"])
mod.add_url_rule('%s<int:uid>' % cls.url, view_func=symfunc,
methods=['GET', 'PUT', 'PATCH', 'DELETE'])
SymptomAPI.register(mod)
Ale, powiedzmy, że chciałbym dołączyć kolejny api na tych poszczególnych objawów:
/<symptomid>/diagnoses/
GET - list diags for symptom
POST - {id: diagid} - create relation with diagnosis
/<symptomid>/diagnoses/<diagnosisid>
GET - probability symptom given diag
PUT - update probability of symptom given diag
DELETE - remove diag - symptom relation
Będę wtedy mieć 4 GET zamiast dwóch jak wyżej.
- Czy uważasz, że to zły projekt aplikacji?
- Czy byłby to obiekt odpowiedni do tego projektu? (jeśli wzór nie jest zły)
- Jak wdrożysz te trasy?
Więc ... pisząc to pytanie, znalazłem przyzwoite rozwiązanie. Dopóki tu jestem, równie dobrze mogę opublikować pytanie i znaleźć rozwiązanie. Wszelkie opinie będą nadal bardzo mile widziane.