-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.cc
115 lines (92 loc) · 3.51 KB
/
server.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
/**
* Service Session
*/
#include <iostream>
#include <memory>
#include <string>
#include <grpcpp/grpcpp.h>
#include "service.grpc.pb.h"
#include "config.h"
#include "session_data.h"
#include "storage.h"
using grpc::Server;
using grpc::ServerBuilder;
using grpc::ServerContext;
using grpc::Status;
using session::SaveRequest;
using session::SaveResponse;
using session::GetRequest;
using session::GetResponse;
using session::SessionService;
class ServiceSessionServer final : public SessionService::Service {
public:
ServiceSessionServer(Config* config) {
this->config = config;
}
Status Save(ServerContext* context, const SaveRequest* request, SaveResponse* response) override {
Storage* storage = this->getStorage();
SessionData sessionData(request->sessid(), request->userid(), request->access_token(), request->refresh_token());
int result = storage->save(&sessionData);
return Status::OK;
}
Status Get(ServerContext* context, const GetRequest* request, GetResponse* response) override {
std::cout << "receive message" << std::endl;
std::cout << "sessid: " << request->sessid() << std::endl;
Storage* storage = this->getStorage();
SessionData *sessionData = storage->getById(request->sessid());
if (sessionData != nullptr) {
response->set_userid(sessionData->userId);
response->set_access_token(sessionData->accessToken);
response->set_refresh_token(sessionData->refreshToken);
} else {
response->set_userid(777);
response->set_access_token("some-access-token");
response->set_refresh_token("some-refrech-token");
}
return Status::OK;
}
::grpc::Status Create(::grpc::ServerContext* context, const ::session::CreateRequest* request, ::session::CreateResponse* response) override {
Storage* storage = this->getStorage();
char* sessid = new char[65];
memset(sessid, 0, sizeof(char) * 65);
int result = storage->create(sessid);
if (result == 0) {
response->set_sessid(sessid);
}
return Status::OK;
}
private:
Storage* getStorage() {
TarantoolConfig* tConf = this->config->getTarantoolConfig();
Storage* storage = new Storage(tConf->getUri());
return storage;
}
Config* config;
};
void RunServer(Config* config) {
std::string server_address(config->getUri());
ServiceSessionServer service(config);
ServerBuilder builder;
// Listen on the given address without any authentication mechanism.
builder.AddListeningPort(server_address, grpc::InsecureServerCredentials());
// Register "service" as the instance through which we'll communicate with
// clients. In this case it corresponds to an *synchronous* service.
builder.RegisterService(&service);
// Finally assemble the server.
std::unique_ptr<Server> server(builder.BuildAndStart());
std::cout << "Server listening on " << server_address << std::endl;
// Wait for the server to shutdown. Note that some other thread must be
// responsible for shutting down the server for this call to ever return.
server->Wait();
}
int main (int argc, char** argv) {
Config config(argc, argv);
if (config.isHelp()) {
std::cout << "How usage it" << std::endl;
return 0;
}
TarantoolConfig* tConf = config.getTarantoolConfig();
std::cout << "Listen tarantool: " << tConf->getUri() << std::endl;
RunServer(&config);
return 0;
}