| -module(server). |
| |
| -include("thrift.hrl"). |
| -include("thrift_logger.hrl"). |
| -include("transport/tSocket.hrl"). |
| -include("protocol/tBinaryProtocol.hrl"). |
| |
| -include("server/tErlServer.hrl"). |
| -include("transport/tErlAcceptor.hrl"). |
| |
| -include("calculator_thrift.hrl"). |
| |
| -export([start/0, start/1, stop/1, ping/0, add/2, calculate/2, getStruct/1, zip/0]). |
| |
| debug(Format, Data) -> |
| error_logger:info_msg(Format, Data). |
| |
| ping() -> |
| debug("ping()",[]), |
| ok. |
| |
| add(N1, N2) -> |
| debug("add(~p,~p)",[N1,N2]), |
| N1+N2. |
| |
| calculate(Logid, Work) -> |
| { Op, Num1, Num2 } = { Work#work.op, Work#work.num1, Work#work.num2 }, |
| debug("calculate(~p, {~p,~p,~p})", [Logid, Op, Num1, Num2]), |
| case Op of |
| ?tutorial_ADD -> Num1 + Num2; |
| ?tutorial_SUBTRACT -> Num1 - Num2; |
| ?tutorial_MULTIPLY -> Num1 * Num2; |
| |
| ?tutorial_DIVIDE when Num2 == 0 -> |
| throw(#invalidOperation{what=Op, why="Cannot divide by 0"}); |
| ?tutorial_DIVIDE -> |
| Num1 div Num2; |
| |
| _Else -> |
| throw(#invalidOperation{what=Op, why="Invalid operation"}) |
| |
| end. |
| |
| getStruct(Key) -> |
| debug("getStruct(~p)", [Key]), |
| #sharedStruct{key=Key, value="RARG"}. |
| |
| zip() -> |
| debug("zip", []), |
| ok. |
| |
| %% |
| |
| start() -> |
| start(9090). |
| |
| start(Port) -> |
| thrift_logger:install([#thrift_logger_state{ |
| force_one_line = false, %% should we collapse all errors to one line? |
| term_width = 110, %% if so, crop output at this width |
| omit = [oop_new, req_processed] %% don't show these kinds of infos |
| }]), |
| |
| Handler = ?MODULE, |
| Processor = calculator_thrift, |
| |
| TF = tBufferedTransportFactory:new(), |
| PF = tBinaryProtocolFactory:new(), |
| |
| ServerTransport = tErlAcceptor, |
| ServerFlavor = tErlServer, |
| |
| Server = oop:start_new(ServerFlavor, [Port, Handler, Processor, ServerTransport, TF, PF]), |
| |
| case ?R0(Server, effectful_serve) of |
| ok -> Server; |
| Error -> Error |
| end. |
| |
| stop(Server) -> |
| ?C0(Server, stop), |
| ok. |