Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
What's new
10
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Open sidebar
p2p
go-p2p-pubsub
Commits
dd50a31c
Commit
dd50a31c
authored
Feb 19, 2018
by
vyzo
Committed by
Steven Allen
Jun 12, 2018
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add gossipsub control messages
parent
375c4176
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
159 additions
and
3 deletions
+159
-3
pb/rpc.pb.go
pb/rpc.pb.go
+133
-3
pb/rpc.proto
pb/rpc.proto
+26
-0
No files found.
pb/rpc.pb.go
View file @
dd50a31c
...
...
@@ -11,6 +11,11 @@ It is generated from these files:
It has these top-level messages:
RPC
Message
ControlMessage
ControlIHave
ControlIWant
ControlGraft
ControlPrune
TopicDescriptor
*/
package
floodsub_pb
...
...
@@ -97,9 +102,10 @@ func (x *TopicDescriptor_EncOpts_EncMode) UnmarshalJSON(data []byte) error {
}
type
RPC
struct
{
Subscriptions
[]
*
RPC_SubOpts
`protobuf:"bytes,1,rep,name=subscriptions" json:"subscriptions,omitempty"`
Publish
[]
*
Message
`protobuf:"bytes,2,rep,name=publish" json:"publish,omitempty"`
XXX_unrecognized
[]
byte
`json:"-"`
Subscriptions
[]
*
RPC_SubOpts
`protobuf:"bytes,1,rep,name=subscriptions" json:"subscriptions,omitempty"`
Publish
[]
*
Message
`protobuf:"bytes,2,rep,name=publish" json:"publish,omitempty"`
Control
*
ControlMessage
`protobuf:"bytes,3,opt,name=control" json:"control,omitempty"`
XXX_unrecognized
[]
byte
`json:"-"`
}
func
(
m
*
RPC
)
Reset
()
{
*
m
=
RPC
{}
}
...
...
@@ -120,6 +126,13 @@ func (m *RPC) GetPublish() []*Message {
return
nil
}
func
(
m
*
RPC
)
GetControl
()
*
ControlMessage
{
if
m
!=
nil
{
return
m
.
Control
}
return
nil
}
type
RPC_SubOpts
struct
{
Subscribe
*
bool
`protobuf:"varint,1,opt,name=subscribe" json:"subscribe,omitempty"`
Topicid
*
string
`protobuf:"bytes,2,opt,name=topicid" json:"topicid,omitempty"`
...
...
@@ -184,6 +197,118 @@ func (m *Message) GetTopicIDs() []string {
return
nil
}
type
ControlMessage
struct
{
Ihave
[]
*
ControlIHave
`protobuf:"bytes,1,rep,name=ihave" json:"ihave,omitempty"`
Iwant
[]
*
ControlIWant
`protobuf:"bytes,2,rep,name=iwant" json:"iwant,omitempty"`
Graft
[]
*
ControlGraft
`protobuf:"bytes,3,rep,name=graft" json:"graft,omitempty"`
Prune
[]
*
ControlPrune
`protobuf:"bytes,4,rep,name=prune" json:"prune,omitempty"`
XXX_unrecognized
[]
byte
`json:"-"`
}
func
(
m
*
ControlMessage
)
Reset
()
{
*
m
=
ControlMessage
{}
}
func
(
m
*
ControlMessage
)
String
()
string
{
return
proto
.
CompactTextString
(
m
)
}
func
(
*
ControlMessage
)
ProtoMessage
()
{}
func
(
m
*
ControlMessage
)
GetIhave
()
[]
*
ControlIHave
{
if
m
!=
nil
{
return
m
.
Ihave
}
return
nil
}
func
(
m
*
ControlMessage
)
GetIwant
()
[]
*
ControlIWant
{
if
m
!=
nil
{
return
m
.
Iwant
}
return
nil
}
func
(
m
*
ControlMessage
)
GetGraft
()
[]
*
ControlGraft
{
if
m
!=
nil
{
return
m
.
Graft
}
return
nil
}
func
(
m
*
ControlMessage
)
GetPrune
()
[]
*
ControlPrune
{
if
m
!=
nil
{
return
m
.
Prune
}
return
nil
}
type
ControlIHave
struct
{
TopicID
*
string
`protobuf:"bytes,1,opt,name=topicID" json:"topicID,omitempty"`
MessageIDs
[]
string
`protobuf:"bytes,2,rep,name=messageIDs" json:"messageIDs,omitempty"`
XXX_unrecognized
[]
byte
`json:"-"`
}
func
(
m
*
ControlIHave
)
Reset
()
{
*
m
=
ControlIHave
{}
}
func
(
m
*
ControlIHave
)
String
()
string
{
return
proto
.
CompactTextString
(
m
)
}
func
(
*
ControlIHave
)
ProtoMessage
()
{}
func
(
m
*
ControlIHave
)
GetTopicID
()
string
{
if
m
!=
nil
&&
m
.
TopicID
!=
nil
{
return
*
m
.
TopicID
}
return
""
}
func
(
m
*
ControlIHave
)
GetMessageIDs
()
[]
string
{
if
m
!=
nil
{
return
m
.
MessageIDs
}
return
nil
}
type
ControlIWant
struct
{
MessageIDs
[]
string
`protobuf:"bytes,1,rep,name=messageIDs" json:"messageIDs,omitempty"`
XXX_unrecognized
[]
byte
`json:"-"`
}
func
(
m
*
ControlIWant
)
Reset
()
{
*
m
=
ControlIWant
{}
}
func
(
m
*
ControlIWant
)
String
()
string
{
return
proto
.
CompactTextString
(
m
)
}
func
(
*
ControlIWant
)
ProtoMessage
()
{}
func
(
m
*
ControlIWant
)
GetMessageIDs
()
[]
string
{
if
m
!=
nil
{
return
m
.
MessageIDs
}
return
nil
}
type
ControlGraft
struct
{
TopicID
*
string
`protobuf:"bytes,1,opt,name=topicID" json:"topicID,omitempty"`
XXX_unrecognized
[]
byte
`json:"-"`
}
func
(
m
*
ControlGraft
)
Reset
()
{
*
m
=
ControlGraft
{}
}
func
(
m
*
ControlGraft
)
String
()
string
{
return
proto
.
CompactTextString
(
m
)
}
func
(
*
ControlGraft
)
ProtoMessage
()
{}
func
(
m
*
ControlGraft
)
GetTopicID
()
string
{
if
m
!=
nil
&&
m
.
TopicID
!=
nil
{
return
*
m
.
TopicID
}
return
""
}
type
ControlPrune
struct
{
TopicID
*
string
`protobuf:"bytes,1,opt,name=topicID" json:"topicID,omitempty"`
XXX_unrecognized
[]
byte
`json:"-"`
}
func
(
m
*
ControlPrune
)
Reset
()
{
*
m
=
ControlPrune
{}
}
func
(
m
*
ControlPrune
)
String
()
string
{
return
proto
.
CompactTextString
(
m
)
}
func
(
*
ControlPrune
)
ProtoMessage
()
{}
func
(
m
*
ControlPrune
)
GetTopicID
()
string
{
if
m
!=
nil
&&
m
.
TopicID
!=
nil
{
return
*
m
.
TopicID
}
return
""
}
// topicID = hash(topicDescriptor); (not the topic.name)
type
TopicDescriptor
struct
{
Name
*
string
`protobuf:"bytes,1,opt,name=name" json:"name,omitempty"`
...
...
@@ -269,6 +394,11 @@ func init() {
proto
.
RegisterType
((
*
RPC
)(
nil
),
"floodsub.pb.RPC"
)
proto
.
RegisterType
((
*
RPC_SubOpts
)(
nil
),
"floodsub.pb.RPC.SubOpts"
)
proto
.
RegisterType
((
*
Message
)(
nil
),
"floodsub.pb.Message"
)
proto
.
RegisterType
((
*
ControlMessage
)(
nil
),
"floodsub.pb.ControlMessage"
)
proto
.
RegisterType
((
*
ControlIHave
)(
nil
),
"floodsub.pb.ControlIHave"
)
proto
.
RegisterType
((
*
ControlIWant
)(
nil
),
"floodsub.pb.ControlIWant"
)
proto
.
RegisterType
((
*
ControlGraft
)(
nil
),
"floodsub.pb.ControlGraft"
)
proto
.
RegisterType
((
*
ControlPrune
)(
nil
),
"floodsub.pb.ControlPrune"
)
proto
.
RegisterType
((
*
TopicDescriptor
)(
nil
),
"floodsub.pb.TopicDescriptor"
)
proto
.
RegisterType
((
*
TopicDescriptor_AuthOpts
)(
nil
),
"floodsub.pb.TopicDescriptor.AuthOpts"
)
proto
.
RegisterType
((
*
TopicDescriptor_EncOpts
)(
nil
),
"floodsub.pb.TopicDescriptor.EncOpts"
)
...
...
pb/rpc.proto
View file @
dd50a31c
...
...
@@ -8,6 +8,8 @@ message RPC {
optional
bool
subscribe
=
1
;
// subscribe or unsubcribe
optional
string
topicid
=
2
;
}
optional
ControlMessage
control
=
3
;
}
message
Message
{
...
...
@@ -17,6 +19,30 @@ message Message {
repeated
string
topicIDs
=
4
;
}
message
ControlMessage
{
repeated
ControlIHave
ihave
=
1
;
repeated
ControlIWant
iwant
=
2
;
repeated
ControlGraft
graft
=
3
;
repeated
ControlPrune
prune
=
4
;
}
message
ControlIHave
{
optional
string
topicID
=
1
;
repeated
string
messageIDs
=
2
;
}
message
ControlIWant
{
repeated
string
messageIDs
=
1
;
}
message
ControlGraft
{
optional
string
topicID
=
1
;
}
message
ControlPrune
{
optional
string
topicID
=
1
;
}
// topicID = hash(topicDescriptor); (not the topic.name)
message
TopicDescriptor
{
optional
string
name
=
1
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment