Skip to content

📟 An application layer protocol compiler - faster than Google's protobuf

License

Notifications You must be signed in to change notification settings

ultrasilicon/parsly

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

82 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Parsely

Describe & deploy net protocol with simply a JSON file.

  • Parsely is a library which helps developer serialize runtime application data into network packets, according to the network protocol defined by the user in a JSON file.

Get Started:

  • Step 1: Design and define your protocol in a json file

    • How proto.json is defined (example):
    {
    	"version" : [0, 0, 0],
    	"protocol" : {
    		"header" : 4,
    		"flags" : ["HeartBeat", "ConnectionInfo", "TextMessage", "ImageMessage"]
    	},
    
    	"fields" : {
    		"HeartBeat" : [
    			["string", "uuid"],
    			["string", "usrName"],
    			["string", "publicKey"],
    			["uint32", "timestamp"]
    		],
    	
    		"ConnectionInfo" : [
    			["string", "uuid"],
    			["string", "peers"]
    		],
    		
    		"TextMessage" : [
    			["string", "uuid"],
    			["string", "msgId"],
    			["string", "msg"]
    		],
    		
    		"ImageMessage" : [
    			["string", "uuid"],
    			["string", "msgId"],
    			["string", "msg"]
    		]
    	}
    }
    • version : POP version.
    • protocol : An overview of the protocol.
    • header : The size of header, which packetize the TCP stream. It is the size of the whole packet except the size of it self.
    • flags : Flags are used for application to determine what type of message the packet is transmitting. Different type of message has different fields, defined in fields.
    • fields : The message fields of flags. Consisted of an order sensitive array of sub fields. So that the binary will be serialized and deserialized sequencially described here. The first element of a subfield, like in ["string", "uuid"], is the type of the subfield data. And the second is the same of the data, which is just a label for your and the pre-processor's reference when debugging.
  • STEP 2: Compile your protocol to ParseEngine:

    • It translates the given protocol description JSON file to C++ code, which is a part of what we called the Parse Engine
    $ python3 pop.py ./my_proto_v1.json ./my_proj/src/
    Pre-processor of Parsely v1.0.1 stable 
    pop: Parsing /home/han/my_proto_v1.json ...
    pop: Generating decoder in C++ ...
    pop: Injecting compiled code to ./my_proj/src/parse_engine_decode_pop.cpp
    Sucessful!
    $ make -j8
  • STEP 3: Encapsulate your own network stack:

    • The user first need to inherit his/her network class from our interface called the NetStack.
    • Note: you need to implement virtual int NetStack::write(char* data, string &ip) so that ParseEngine can automatically call NetStack to send out message
    #include "parsely/net_stack.h"
    using namespace std;
    
    class ChatServer : public NetStack
    {
    public:
    	ChatServer(string &ip, const int &port);
    	
    	virtual int NetStack::write(char* data, string &ip);
    }
  • STEP 4: Send message with ParseEngine:

    • How ParseEngine is used (example):
    #include "chat_server.h"
    #include "parse_engine.h"
    
    enum ProtoMsgType {
        HeartBeat,
        Text,
        Image,
    }
    
    void readMessage(Packet* p){
        // Do something...
    }
    
    int main(int argc, char **argv  ){
        // User code...
        
        ChatServer  *s = new ChatServer();
        ParseEngine *e = new ParseEngine(s);
        //bind read message callback
        e->onMessage = &readMessage;
        
        // construct packet according to the protocol
        Packet *p = new Packet{ 
            {
                "{cfceb206-290e-4b60-b596-1a08a2c8d36a}", // UUID
                "731948", 								  // Message ID
                "Hello?"								  // Message Text
            },
            Text
        };
        e->message(p, Text}, "155.246.104.55");
        
        // User code...
    }

What's next for Parsely

About

📟 An application layer protocol compiler - faster than Google's protobuf

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published