buffer ~master
A protocol buffer & RPC library
To use this package, run the following command in your project's root directory:
Manual usage
Put the following dependency into your project's dependences section:
A simple and practical protocol buffer & RPC library.
At present, it has only dlang and C++ implementations, and will add more language support in the future, such as: Lua, Java, python, ruby, golang, rust...
C++ project on github:
https://github.com/shove70/shove.c
Quick Start:
import std.stdio;
import buffer.message;
mixin (LoadBufferFile!"message.buffer");
mixin (LoadBufferScript!`
message Sample {
string name;
int32 age;
int16 sex;
}
`);
// Simple:
void main()
{
Sample sample = new Sample();
sample.name = "Tom";
sample.age = 20;
sample.sex = 1;
ubyte[] buf = sample.serialize();
writeln(buf);
Sample sam = Message.deserialize!Sample(buf);
writeln("name:\t", sam.name);
writeln("age:\t", sam.age);
writeln("sex:\t", sam.sex);
}
// Advanced:
void main()
{
// Set magic number, encryption method and key.
Message.settings(1229, CryptType.XTEA, "1234");
Sample sample = new Sample();
sample.name = "Tom";
sample.age = 20;
sample.sex = 1;
ubyte[] buf = sample.serialize();
writeln(buf);
string name;
string method;
Message.getMessageInfo(buf, name, method);
switch (name)
{
case "Sample":
Sample sam = Message.deserialize!Sample(buf);
writeln("name:\t", sam.name);
writeln("age:\t", sam.age);
writeln("sex:\t", sam.sex);
break;
case "...":
break;
default:
break;
}
}
RPC Client:
mixin(LoadBufferScript!`
message LoginInfo {
string name;
string password;
}
message LoginRetInfo {
int32 id;
string name;
}
`);
void main()
{
Message.settings(1229, CryptType.XTEA, "1234");
Client.setServerHost("127.0.0.1", 10_000);
LoginRetInfo ret = Client.call!LoginRetInfo("login", "admin", "123456");
if (ret !is null)
{
writeln(ret.id);
writeln(ret.name);
}
// or:
long userId = Client.call!long("getUserId", "admin");
writeln(userId);
}
RPC Server:
class Business
{
mixin(LoadBufferScript!`
message LoginInfo {
string name;
string password;
}
message LoginRetInfo {
int32 id;
string name;
}
`);
long GetUserId(string name)
{
// Access the database, query the user's id by name, assuming the user's ID is 1
int userId = 1;
// ...
// Query OK.
return userId;
}
LoginRetInfo Login(string name, string password)
{
// Access the database, check the user name and password, assuming the validation passed, the user's ID is 1
int userId = 1;
// ...
// Check OK.
LoginRetInfo ret = new LoginRetInfo();
ret.id = userId;
ret.name = name;
return ret;
}
}
__gshared Server!(Business) server;
void main()
{
Message.settings(1229, CryptType.XTEA, "1234");
server = new Server!(Business)();
TcpSocket socket = new TcpSocket();
socket.bind(new InternetAddress("127.0.0.1", 10000));
socket.listen(10);
while (true)
{
Socket accept = socket.accept();
spawn(&acceptHandler, cast(shared Socket) accept);
}
}
void acceptHandler(shared Socket accept)
{
Socket socket = cast(Socket) accept;
while (true)
{
ubyte[] data = new ubyte[1024];
long len = socket.receive(data);
if (len > 0)
{
ubyte[] ret_data = server.Handler(data[0..len]);
if (ret_data != null)
socket.send(ret_data);
}
}
}
- Registered by shove
- ~master released 2 years ago
- shove70/buffer
- MIT
- Copyright © 2017-2020, Shove
- Authors:
- Dependencies:
- crypto
- Versions:
-
0.2.41 2022-Jan-25 0.2.40 2021-Jun-09 0.2.39 2020-Dec-03 0.2.38 2020-Oct-14 0.2.37 2020-Sep-01 - Download Stats:
-
-
0 downloads today
-
0 downloads this week
-
0 downloads this month
-
8301 downloads total
-
- Score:
- 2.0
- Short URL:
- buffer.dub.pm