假设您有一个由多个不同类型的嵌入式节点组成的工作流。由于节点的类型不同,我想到在这里使用 Golang 接口并提出以下内容:
type Workflow struct {
CreatedAt time.Time
StartedAt time.Time
CreatedBy string
Nodes []Node
}
type Node interface {
Exec() (int, error)
}
type EmailNode struct {
From string
To string
Subject string
Body string
}
type TwitterNode struct {
Tweet string
Image []byte
}
func (n *EmailNode) Exec() (int, error){
//send email
return 0, nil
}
func (n *TwitterNode) Exec() (int, error) {
//send tweet
return 0, nil
}
这些工作流存储在 MongoDB 中,我在其中包含示例种子数据。使用 mgo,当我尝试查找工作流(给定其 ID)时:
w = &Workflow{}
collection.FindID(bson.ObjectIdHex(id)).One(w)
我收到错误 - bson.M 类型的值不可分配给 Node 类型。
我也觉得有点奇怪,mgo 如何在没有任何类型信息的情况下将嵌入的 Node 文档解组到 Go 结构中。可能是我需要从另一个角度来看问题。
翻阅古今
尚方宝剑之说
相关分类