blob: cbcedccf33a7d408b6fb1f5bbf8dfc2d01f9ae2d [file] [log] [blame]
Jake Farrellb95b0ff2012-03-22 21:49:10 +00001/*
2 * Licensed to the Apache Software Foundation (ASF) under one
3 * or more contributor license agreements. See the NOTICE file
4 * distributed with this work for additional information
5 * regarding copyright ownership. The ASF licenses this file
6 * to you under the Apache License, Version 2.0 (the
7 * "License"); you may not use this file except in compliance
8 * with the License. You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing,
13 * software distributed under the License is distributed on an
14 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15 * KIND, either express or implied. See the License for the
16 * specific language governing permissions and limitations
17 * under the License.
18 */
19module server;
20
21import std.conv : to;
22import std.stdio;
23import thrift.codegen.processor;
24import thrift.protocol.binary;
25import thrift.server.simple;
26import thrift.server.transport.socket;
27import thrift.transport.buffered;
28
29import share.SharedService;
30import share.shared_types;
31import tutorial.Calculator;
32import tutorial.tutorial_types;
33
34/**
35 * The actual implementation of the Calculator interface that is called by
36 * the server to answer the requests.
37 */
38class CalculatorHandler : Calculator {
39 void ping() {
40 writeln("ping()");
41 }
42
43 int add(int n1, int n2) {
44 writefln("add(%s,%s)", n1, n2);
45 return n1 + n2;
46 }
47
48 int calculate(int logid, ref const(Work) work) {
49 writefln("calculate(%s, {%s, %s, %s})", logid, work.op, work.num1, work.num2);
50 int val;
51
52 switch (work.op) {
53 case Operation.ADD:
54 val = work.num1 + work.num2;
55 break;
56 case Operation.SUBTRACT:
57 val = work.num1 - work.num2;
58 break;
59 case Operation.MULTIPLY:
60 val = work.num1 * work.num2;
61 break;
62 case Operation.DIVIDE:
63 if (work.num2 == 0) {
64 auto io = new InvalidOperation();
Konrad Grochowski3b115df2015-05-18 17:58:36 +020065 io.whatOp = work.op;
Jake Farrellb95b0ff2012-03-22 21:49:10 +000066 io.why = "Cannot divide by 0";
67 throw io;
68 }
69 val = work.num1 / work.num2;
70 break;
71 default:
72 auto io = new InvalidOperation();
Konrad Grochowski3b115df2015-05-18 17:58:36 +020073 io.whatOp = work.op;
Jake Farrellb95b0ff2012-03-22 21:49:10 +000074 io.why = "Invalid Operation";
75 throw io;
76 }
77
78 auto ss = SharedStruct();
79 ss.key = logid;
80 ss.value = to!string(val);
81 log[logid] = ss;
82
83 return val;
84 }
85
86 SharedStruct getStruct(int logid) {
87 writefln("getStruct(%s)", logid);
88 return log[logid];
89 }
90
91 void zip() {
92 writeln("zip()");
93 }
94
95protected:
96 SharedStruct[int] log;
97}
98
99void main() {
100 auto protocolFactory = new TBinaryProtocolFactory!();
101 auto processor = new TServiceProcessor!Calculator(new CalculatorHandler);
102 auto serverTransport = new TServerSocket(9090);
103 auto transportFactory = new TBufferedTransportFactory;
104
105 auto server = new TSimpleServer(
106 processor, serverTransport, transportFactory, protocolFactory);
107
108 writeln("Starting the server on port 9090...");
109 server.serve();
110 writeln("done.");
111}