Implement Openflow Protocol and Callback system
This commit is contained in:
parent
fc02a678de
commit
e52fe31b79
48 changed files with 937 additions and 244 deletions
|
|
@ -3,6 +3,7 @@ defmodule Openflow.Multipart.Aggregate.Reply do
|
|||
version: 4,
|
||||
xid: 0,
|
||||
datapath_id: nil, # virtual field
|
||||
aux_id: nil,
|
||||
flags: [],
|
||||
packet_count: 0,
|
||||
byte_count: 0,
|
||||
|
|
|
|||
|
|
@ -3,6 +3,7 @@ defmodule Openflow.Multipart.Desc.Reply do
|
|||
version: 4,
|
||||
xid: 0,
|
||||
datapath_id: nil, # virtual field
|
||||
aux_id: nil,
|
||||
flags: [],
|
||||
mfr_desc: "",
|
||||
hw_desc: "",
|
||||
|
|
|
|||
|
|
@ -3,6 +3,7 @@ defmodule Openflow.Multipart.Flow.Reply do
|
|||
version: 4,
|
||||
xid: 0,
|
||||
datapath_id: nil, # virtual field
|
||||
aux_id: nil,
|
||||
flags: [],
|
||||
flows: []
|
||||
)
|
||||
|
|
@ -19,6 +20,16 @@ defmodule Openflow.Multipart.Flow.Reply do
|
|||
flows = Openflow.Multipart.FlowStats.read(flows_bin)
|
||||
%Reply{flows: flows}
|
||||
end
|
||||
|
||||
def append_body(%Reply{flows: flows} = message, %Reply{flags: [:more], flows: continue}) do
|
||||
%{message|flows: [continue|flows]}
|
||||
end
|
||||
def append_body(%Reply{flows: flows} = message, %Reply{flags: [], flows: continue}) do
|
||||
new_flows = [continue|flows]
|
||||
|> Enum.reverse
|
||||
|> List.flatten
|
||||
%{message|flows: new_flows}
|
||||
end
|
||||
end
|
||||
|
||||
defmodule Openflow.Multipart.FlowStats do
|
||||
|
|
|
|||
|
|
@ -16,13 +16,13 @@ defmodule Openflow.Multipart.Flow.Request do
|
|||
|
||||
def ofp_type, do: 18
|
||||
|
||||
def new(options) do
|
||||
def new(options \\ []) do
|
||||
table_id = Keyword.get(options, :table_id, :all)
|
||||
out_port = Keyword.get(options, :out_port, :any)
|
||||
out_group = Keyword.get(options, :out_group, :any)
|
||||
cookie = Keyword.get(options, :cookie, 0)
|
||||
cookie_mask = Keyword.get(options, :cookie, 0)
|
||||
match = Keyword.get(options, :match, [])
|
||||
match = Keyword.get(options, :match, Openflow.Match.new)
|
||||
%Request{table_id: table_id,
|
||||
out_port: out_port,
|
||||
out_group: out_group,
|
||||
|
|
|
|||
|
|
@ -3,6 +3,7 @@ defmodule Openflow.Multipart.Group.Reply do
|
|||
version: 4,
|
||||
xid: 0,
|
||||
datapath_id: nil, # virtual field
|
||||
aux_id: nil,
|
||||
flags: [],
|
||||
groups: []
|
||||
)
|
||||
|
|
@ -19,6 +20,16 @@ defmodule Openflow.Multipart.Group.Reply do
|
|||
groups = Openflow.Multipart.Group.read(groups_bin)
|
||||
%Reply{groups: groups}
|
||||
end
|
||||
|
||||
def append_body(%Reply{groups: groups} = message, %Reply{flags: [:more], groups: continue}) do
|
||||
%{message|groups: [continue|groups]}
|
||||
end
|
||||
def append_body(%Reply{groups: groups} = message, %Reply{flags: [], groups: continue}) do
|
||||
new_groups = [continue|groups]
|
||||
|> Enum.reverse
|
||||
|> List.flatten
|
||||
%{message|groups: new_groups}
|
||||
end
|
||||
end
|
||||
|
||||
defmodule Openflow.Multipart.Group do
|
||||
|
|
|
|||
|
|
@ -19,6 +19,16 @@ defmodule Openflow.Multipart.GroupDesc.Reply do
|
|||
groups = Openflow.Multipart.GroupDescStats.read(groups_bin)
|
||||
%Reply{groups: groups}
|
||||
end
|
||||
|
||||
def append_body(%Reply{groups: groups} = message, %Reply{flags: [:more], groups: continue}) do
|
||||
%{message|groups: [continue|groups]}
|
||||
end
|
||||
def append_body(%Reply{groups: groups} = message, %Reply{flags: [], groups: continue}) do
|
||||
new_groups = [continue|groups]
|
||||
|> Enum.reverse
|
||||
|> List.flatten
|
||||
%{message|groups: new_groups}
|
||||
end
|
||||
end
|
||||
|
||||
defmodule Openflow.Multipart.GroupDescStats do
|
||||
|
|
|
|||
|
|
@ -3,6 +3,7 @@ defmodule Openflow.Multipart.GroupFeatures.Reply do
|
|||
version: 4,
|
||||
xid: 0,
|
||||
datapath_id: nil, # virtual field
|
||||
aux_id: nil,
|
||||
flags: [],
|
||||
types: 0,
|
||||
capabilities: [],
|
||||
|
|
|
|||
|
|
@ -3,6 +3,7 @@ defmodule Openflow.Multipart.Meter.Reply do
|
|||
version: 4,
|
||||
xid: 0,
|
||||
datapath_id: nil, # virtual field
|
||||
aux_id: nil,
|
||||
flags: [],
|
||||
meters: []
|
||||
)
|
||||
|
|
@ -15,6 +16,16 @@ defmodule Openflow.Multipart.Meter.Reply do
|
|||
meters = Openflow.Multipart.Meter.read(meters_bin)
|
||||
%Reply{meters: meters}
|
||||
end
|
||||
|
||||
def append_body(%Reply{meters: meters} = message, %Reply{flags: [:more], meters: continue}) do
|
||||
%{message|meters: [continue|meters]}
|
||||
end
|
||||
def append_body(%Reply{meters: meters} = message, %Reply{flags: [], meters: continue}) do
|
||||
new_meters = [continue|meters]
|
||||
|> Enum.reverse
|
||||
|> List.flatten
|
||||
%{message|meters: new_meters}
|
||||
end
|
||||
end
|
||||
|
||||
defmodule Openflow.Multipart.Meter do
|
||||
|
|
|
|||
33
lib/openflow/multipart/port_desc/reply.ex
Normal file
33
lib/openflow/multipart/port_desc/reply.ex
Normal file
|
|
@ -0,0 +1,33 @@
|
|||
defmodule Openflow.Multipart.PortDesc.Reply do
|
||||
defstruct(
|
||||
version: 4,
|
||||
xid: 0,
|
||||
datapath_id: nil, # virtual field
|
||||
aux_id: nil,
|
||||
flags: [],
|
||||
ports: []
|
||||
)
|
||||
|
||||
alias __MODULE__
|
||||
|
||||
def ofp_type, do: 18
|
||||
|
||||
def new(ports \\ []) do
|
||||
%Reply{ports: ports}
|
||||
end
|
||||
|
||||
def read(<<ports_bin::bytes>>) do
|
||||
ports = for (<<port_bin::64-bytes <- ports_bin>>), do: Openflow.Port.read(port_bin)
|
||||
%Reply{ports: Enum.reverse(ports)}
|
||||
end
|
||||
|
||||
def append_body(%Reply{ports: ports} = message, %Reply{flags: [:more], ports: continue}) do
|
||||
%{message|ports: [continue|ports]}
|
||||
end
|
||||
def append_body(%Reply{ports: ports} = message, %Reply{flags: [], ports: continue}) do
|
||||
new_ports = [continue|ports]
|
||||
|> Enum.reverse
|
||||
|> List.flatten
|
||||
%{message|ports: new_ports}
|
||||
end
|
||||
end
|
||||
24
lib/openflow/multipart/port_desc/request.ex
Normal file
24
lib/openflow/multipart/port_desc/request.ex
Normal file
|
|
@ -0,0 +1,24 @@
|
|||
defmodule Openflow.Multipart.PortDesc.Request do
|
||||
defstruct(
|
||||
version: 4,
|
||||
xid: 0,
|
||||
datapath_id: nil, # virtual field
|
||||
flags: []
|
||||
)
|
||||
|
||||
alias __MODULE__
|
||||
|
||||
def ofp_type, do: 18
|
||||
|
||||
def new do
|
||||
%Request{}
|
||||
end
|
||||
|
||||
def read("") do
|
||||
%Request{}
|
||||
end
|
||||
|
||||
def to_binary(%Request{} = msg) do
|
||||
Openflow.Multipart.Request.header(msg)
|
||||
end
|
||||
end
|
||||
|
|
@ -3,6 +3,7 @@ defmodule Openflow.Multipart.PortStats.Reply do
|
|||
version: 4,
|
||||
xid: 0,
|
||||
datapath_id: nil, # virtual field
|
||||
aux_id: nil,
|
||||
flags: [],
|
||||
ports: []
|
||||
)
|
||||
|
|
@ -19,6 +20,16 @@ defmodule Openflow.Multipart.PortStats.Reply do
|
|||
ports = Openflow.Multipart.PortStats.read(ports_bin)
|
||||
%Reply{ports: ports}
|
||||
end
|
||||
|
||||
def append_body(%Reply{ports: ports} = message, %Reply{flags: [:more], ports: continue}) do
|
||||
%{message|ports: [continue|ports]}
|
||||
end
|
||||
def append_body(%Reply{ports: ports} = message, %Reply{flags: [], ports: continue}) do
|
||||
new_ports = [continue|ports]
|
||||
|> Enum.reverse
|
||||
|> List.flatten
|
||||
%{message|ports: new_ports}
|
||||
end
|
||||
end
|
||||
|
||||
defmodule Openflow.Multipart.PortStats do
|
||||
|
|
|
|||
|
|
@ -3,6 +3,7 @@ defmodule Openflow.Multipart.Queue.Reply do
|
|||
version: 4,
|
||||
xid: 0,
|
||||
datapath_id: nil, # virtual field
|
||||
aux_id: nil,
|
||||
flags: [],
|
||||
queues: []
|
||||
)
|
||||
|
|
@ -19,6 +20,16 @@ defmodule Openflow.Multipart.Queue.Reply do
|
|||
queues = Openflow.Multipart.Queue.read(queues_bin)
|
||||
%Reply{queues: queues}
|
||||
end
|
||||
|
||||
def append_body(%Reply{queues: queues} = message, %Reply{flags: [:more], queues: continue}) do
|
||||
%{message|queues: [continue|queues]}
|
||||
end
|
||||
def append_body(%Reply{queues: queues} = message, %Reply{flags: [], queues: continue}) do
|
||||
new_queues = [continue|queues]
|
||||
|> Enum.reverse
|
||||
|> List.flatten
|
||||
%{message|queues: new_queues}
|
||||
end
|
||||
end
|
||||
|
||||
defmodule Openflow.Multipart.Queue do
|
||||
|
|
|
|||
|
|
@ -3,6 +3,7 @@ defmodule Openflow.Multipart.Table.Reply do
|
|||
version: 4,
|
||||
xid: 0,
|
||||
datapath_id: nil, # virtual field
|
||||
aux_id: nil,
|
||||
flags: [],
|
||||
tables: []
|
||||
)
|
||||
|
|
@ -15,6 +16,16 @@ defmodule Openflow.Multipart.Table.Reply do
|
|||
tables = Openflow.Multipart.TableStats.read(tables_bin)
|
||||
%Reply{tables: tables}
|
||||
end
|
||||
|
||||
def append_body(%Reply{tables: tables} = message, %Reply{flags: [:more], tables: continue}) do
|
||||
%{message|tables: [continue|tables]}
|
||||
end
|
||||
def append_body(%Reply{tables: tables} = message, %Reply{flags: [], tables: continue}) do
|
||||
new_tables = [continue|tables]
|
||||
|> Enum.reverse
|
||||
|> List.flatten
|
||||
%{message|tables: new_tables}
|
||||
end
|
||||
end
|
||||
|
||||
defmodule Openflow.Multipart.TableStats do
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue