twink is a python openflow library.
twink uses plain openflow binary message instead of forcing
you mastering a bundled complicated openflow protocol classes.
You may use whatever openflow message parsing, building libraries.
twink supports all openflow versions (1.0--1.4).
twink.threading provides a threading-based server implementation.
You can get started with python standard libraries.
twink.gevent has a gevent based openflow server, so for example,
you can create an openflow controller server with websocket support.
twink.ovs offers you ovs-ofctl based openflow message creation.
twink.ext provides utility functionalities.
For convenience, twink has ofp4 openflow 1.3 message parser/builder
as twink.ofp4, and twink.ofp5 for openflow 1.4.
twink.gevent or twink.threading enables openflow message parallel handling.
While processing some openflow message with ovs-ofctl and suspend the process
waiting for reply, another openflow message can be handled in another handler.
If you use threading based controller, be sure using mutex.
It does not matter because Openflow protocol is symmetric in syntax.
Not only creating server-controller or client-switch, twink helps
creating server-switch and client-controller, which are not standard style.
You can use this library even in python interactive mode.
twink is useful in debugging openflow protocol.
The most import part in creating server, is writing a handler function,
which symbol is func(openflow_message, channel_instance) and
passed to Channel class as handle member.
This software is licensed under Apache software license 2.0 http://www.apache.org/licenses/LICENSE-2.0