Я делаю flask restful api, у меня проблемы с зефиром-sqlalchemy и webargs
короче, вот моя модель sqlalchemy:
class User(Model):
id = Column(String, primary_key=True)
name = Column(String(64), nullable=False)
email = Column(String(120), nullable=False)
password = Column(String(128))
creation_date = Column(DateTime, default=datetime.utcnow)
а это моя схема
class UserSchema(ModelSchema):
class Meta:
model = User
strict = True
sqla_session = db.session
user_schema = UserSchema()
и пример моих маршрутов с использованием flask-classful и webargs:
class UserView(FlaskView):
trailing_slash = False
model = User
schema = user_schema
@use_kwargs(schema.fields)
def post(self, **kwargs):
try:
entity = self.model()
for d in kwargs:
if kwargs[d] is not missing:
entity.__setattr__(d, kwargs[d])
db.session.add(entity)
db.session.commit()
o = self.schema.dump(entity).data
return jsonify({'{}'.format(self.model.__table__.name): o})
except IntegrityError:
return jsonify({'message': '{} exist in the database. choose another id'
.format(self.model.__table__.name)}), 409
@use_kwargs(schema.fields)
def put(self, id, **kwargs):
entity = self.model.query.filter_by(id=id).first_or_404()
for d in kwargs:
if kwargs[d] is not missing:
entity.__setattr__(d, kwargs[d])
db.session.commit()
o = self.schema.dump(entity).data
return jsonify({'{}'.format(self.model.__table__.name): o})
UserView.register(app)
Проблема: как вы можете видеть в моей модели sqlalchemy, некоторые поля не могут принимать значения NULL, поэтому моя зефирная схема помечает их как обязательные. Все мои методы get
, index
, delete
и post
работают отлично. Но я включил пост по одной причине:
например, когда я пытаюсь опубликовать нового пользователя без имени, возникает HTTP-код 422, потому что требуется поле name
, чего я и хочу, и это делается отлично.
НО при редактировании полей с запросом put
я хочу, чтобы ВСЕ в моей схеме стало необязательным.. прямо сейчас, если я хочу обновить пользователя, я должен предоставить не только идентификатор.. но ВСЮ другую информацию, требуемую по умолчанию, даже если я этого не сделал менять их вообще.
Короче, как пометить все поля как «необязательные», когда метод «положен»?
EDIT: как и в случае с решением, предоставленным @Mekicha, я внес следующие изменения:
измените схему, чтобы обязательные поля в моей модели принимали значение None. как это:
class UserSchema(ModelSchema):
class Meta:
model = User
...
name = fields.Str(missing=None, required=True)
email = fields.Email(missing=None, required=True)
...
измените мое условие метода put и post с этого:
if kwargs[d] is not missing:
к этому:
if kwargs[d] is not missing and kwargs[d] is not None:
use_kwargs
, чтобы ВСЕ поля были необязательными? Я попытался выполнить @use_kwargs(partial=True) и установить частичное значение для набора полей, но это не сработало :( - person RRR   schedule 20.05.2018@use_kwargs(UserSchema(partial=True))
- person andho   schedule 09.11.2018@use_kwargs(user_schema.fields)
, а не@use_kwargs(user_schema)
, и я не помню, почему. Но заменаuser_schema = UserSchema(strict=True)
наuser_schema = UserSchema(strict=True, partial=True)
ничего не изменила. Я бы хотел использоватьpartial
, а не указывать отдельные поля здесь и там. - person antgel   schedule 15.02.2019