更新了我项目中的依赖项
前
marshmallow-sqlalchemy==0.17.0
marshmallow==3.0.0b6
后
marshmallow-sqlalchemy==0.21.0
marshmallow==3.5.0
我有这样一个模型(简化):
from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()
class MyModel(Base):
__tablename__ = 'my_model'
id = Column(BigInteger, primary_key=True)
field_name = Column(String)
password = Column(String)
和架构:
from marshmallow import fields
from marshmallow_sqlalchemy import (
ModelSchema,
field_for,
)
class RegistrarSchema(ModelSchema):
class Meta:
model = MyModel
other_field_name = fields.Function(lambda obj: obj.field_name)
field_name = field_for(MyModel, 'field_name', load_from='other_field_name')
password = fields.Method("get_password")
def get_password(self, obj):
return decrypt_password(obj)
def load(self, data, session=None, instance=None, transient=False, *args, **kwargs):
if 'password' in data:
password = data['password']
instance = encrypt_password(password, instance)
return super(ModelSchema, self).load(
data, *args, session=session, instance=instance,
transient=transient, **kwargs
)
并使用此代码我可以调用
RegistrarSchema.load(data={'other_field_name': 'my_value'}, instance=instance, session=session)
这个值将被保存到我数据库中的 field_name 中。
更新后我失去了这个功能 - 现在我得到了
File "myfile.py", line 116, in load
transient=transient, **kwargs
File "/usr/local/lib/python3.7/dist-packages/marshmallow_sqlalchemy/schema.py", line 214, in load
return super().load(data, **kwargs)
File "/usr/local/lib/python3.7/dist-packages/marshmallow/schema.py", line 723, in load
data, many=many, partial=partial, unknown=unknown, postprocess=True
File "/usr/local/lib/python3.7/dist-packages/marshmallow/schema.py", line 904, in _do_load
raise exc
marshmallow.exceptions.ValidationError: {'other_field_name': ['Unknown field.']}
更新密码时出现完全相同的错误 -
RegistrarSchema.load(data={'password': 'my_value'}, instance=instance, session=session)
我自己没有编写此代码,也无法联系编写此代码的开发人员。
据我所知,第一种情况的目标是赋予以两种方式编写的能力 -data={'my_field': 'value'}
和data={'other_field_name': 'value'}
. 第一个场景仍在开发新版本,但第二个没有。
如果使用密码 - 目标是通过加密/解密数据使序列化/反序列化更加复杂。
我阅读了更新说明,但找不到任何特定于此问题的信息,有人可以帮忙吗?