我希望能够使用Google终端直接从邮件中自动插入带有引用另一个实体的实体。
要在消息中传输ReferenceProperty
,我使用Key
的编码字符串值。这对于发送消息很好,但是当接收消息并创建它的实体时,我不能只将编码的字符串作为参数传递给构造函数。
例如,假设我有两个继承自BaseModel
的类,它本身继承自db.models
class TestModel2(models.BaseModel):
test_string = db.StringProperty(required=True)
class TestModel(models.BaseModel):
test2 = db.ReferenceProperty(TestModel2)
test2_id = property(models.BaseModel._get_attr_id_builder('test2'),
models.BaseModel._set_attr_id_builder('test2'))
和消息类
class TestModelMessage(messages.Message):
test2_id = messages.StringField(4)
我希望能够直接在Entity
创建TestModel
TestModelMessage
。
我设法使用属性以另一种方式(从实体到消息)执行此操作。但另一方面它不起作用,因为我觉得db.models
的构造函数只会设置继承db.Property
的属性。因此,不会调用属性的setter ......
我怎么能这样做?
我想要覆盖__init__
中的BaseModel
,但是当调用__init__
的{{1}}时,它可能会覆盖db.models
。
答案 0 :(得分:0)
因此,我在_ref_properties
课程中添加了BaseModel
字段。
对于前面的示例,它将是_ref_properties = {'test2': 'test2_id'}
然后我添加了这个类方法
@classmethod
def from_message(cls, message, *args):
attributes = {attr: getattr(message, attr) for attr in args}
for attribute, property in cls._ref_properties.items():
attributes[attribute] = db.Key(encoded=getattr(message, property))
entity = cls(**attributes)
return entity
它似乎有效。可能不是最好的。任何言论或更好的解决方案?