ofxSocketIO
Description
ofxSocketIO
is an ofxaddon that wraps socket.io-client-cpp
. It is still under active development.
Installation
ofxSocketIO
provides the compiled libraries for osx
and linux64
out of the box. If you have to compile socket.io-client-cpp yourself
, follow the installation instructions.
TLS/SSL
socket.io-client-cpp
compiles with SSL support by default. However, we had issues with certificates and thus removed the SSL support. The provided libs (osx and linux64) does not support TLS/SSL.
FYI, we simply removed the find_package(OpenSSL)
call in the CMakeLists.txt
.
Usage
Take a look at our example.
You'll need a socket.io server to communicate with. (check out our test server)
API
ofxSocketIO
setup(std::string& address)
→ Creates a websocket connection with the address
remote.
bindEvent(ofEvent<ofxSocketIOData&>& event, std::string eventName)
→ Binds an ofEvent
to string
trigger. Typically, you'd do:
std::string eventName = "server-event";
socketIO.bindEvent(serverEvent, eventName);
ofAddListener(serverEvent, this, &ofApp::onServerEvent);
void ofApp::onServerEvent (ofxSocketIOData& data) {
// Will be triggered when the server emits a "server-event" event
// See the `ofxSocketIOData` API on how to use the `data` parameter here
}
getStatus()
→ Returns the current status. Either connected
, closed
, reconnecting
or errored
.
connectionEvent
→ An ofEvent
triggered when the socket is connected to the server
notifyEvent
→ An ofEvent
triggered when the socket is connected, closed, errored, or when the socket is trying to reconnect. Comes with std::string
status parameter.
emit(std::string& eventName, std::string& data)
→ Emits an event with the specified event name and a string parameter (you'll have to cast your non-string datas).
closeConnection()
→ Force closes the socket.
ofxSocketIOData
getStringValue(std::string key)
→ Get the std::string
value for the specified key.
getIntValue(std::string key)
→ Get the int
value for the specified key.
getFloatValue(std::string key)
→ Get the float
value for the specified key.
getDoubleValue(std::string key)
→ Get the double
value for the specified key.
getBoolValue(std::string key)
→ Get the bool
value for the specified key.
getVector()
→ Get the raw vector if the message is not a map.
Troubleshooting
ping pong
You may experience issues with 'ping'
and 'pong'
events, as they are used internally by socket.io:
- `ping`. Fired when a ping packet is written out to the server.
- `pong`. Fired when a pong is received from the server.
Credits
ofxSocketIO
is maintained by Soixante circuits and hugohil.
It exists thanks to the great work of the socket.io-client-cpp contributors.
These folks have made some useful contributions to ofxSocketIO
too: