blob: bd0a155881472b5bf1a92625cb26850eaafe33dd [file] [log] [blame]
David Reissea2cba82009-03-30 21:35:00 +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 */
19
Mark Sleecb39f082007-04-10 02:30:30 +000020// Generated code
21import tutorial.*;
22import shared.*;
23
Bryan Duxburyafa80ea2009-01-15 23:47:51 +000024import org.apache.thrift.TException;
Bryan Duxbury1b130832010-10-19 17:20:57 +000025import org.apache.thrift.transport.TSSLTransportFactory;
Bryan Duxburyafa80ea2009-01-15 23:47:51 +000026import org.apache.thrift.transport.TTransport;
27import org.apache.thrift.transport.TSocket;
Bryan Duxbury1b130832010-10-19 17:20:57 +000028import org.apache.thrift.transport.TSSLTransportFactory.TSSLTransportParameters;
Bryan Duxburyafa80ea2009-01-15 23:47:51 +000029import org.apache.thrift.protocol.TBinaryProtocol;
30import org.apache.thrift.protocol.TProtocol;
Mark Sleecb39f082007-04-10 02:30:30 +000031
Mark Sleecb39f082007-04-10 02:30:30 +000032public class JavaClient {
33 public static void main(String [] args) {
David Reiss0c90f6f2008-02-06 22:18:40 +000034
Bryan Duxbury1b130832010-10-19 17:20:57 +000035 if (args.length != 1) {
36 System.out.println("Please enter 'simple' or 'secure'");
37 System.exit(0);
Mark Sleecb39f082007-04-10 02:30:30 +000038 }
39
Bryan Duxbury1b130832010-10-19 17:20:57 +000040 try {
41 TTransport transport;
42 if (args[0].contains("simple")) {
43 transport = new TSocket("localhost", 9090);
44 transport.open();
45 }
46 else {
47 /*
Roger Meier3f067a82011-03-04 13:35:05 +000048 * Similar to the server, you can use the parameters to setup client parameters or
Bryan Duxbury1b130832010-10-19 17:20:57 +000049 * use the default settings. On the client side, you will need a TrustStore which
Jiayu Liueb62fa82022-05-08 13:01:41 +080050 * contains the trusted certificate along with the public key.
51 * For this example it's a self-signed cert.
Bryan Duxbury1b130832010-10-19 17:20:57 +000052 */
53 TSSLTransportParameters params = new TSSLTransportParameters();
Jiayu Liueb62fa82022-05-08 13:01:41 +080054 params.setTrustStore("../../lib/java/test/resources/.truststore", "thrift", "SunX509", "JKS");
Bryan Duxbury1b130832010-10-19 17:20:57 +000055 /*
56 * Get a client transport instead of a server transport. The connection is opened on
57 * invocation of the factory method, no need to specifically call open()
58 */
59 transport = TSSLTransportFactory.getClientSocket("localhost", 9091, 0, params);
60 }
61
62 TProtocol protocol = new TBinaryProtocol(transport);
63 Calculator.Client client = new Calculator.Client(protocol);
64
65 perform(client);
66
67 transport.close();
68 } catch (TException x) {
69 x.printStackTrace();
Jiayu Liueb62fa82022-05-08 13:01:41 +080070 }
Mark Sleecb39f082007-04-10 02:30:30 +000071 }
72
Bryan Duxbury1b130832010-10-19 17:20:57 +000073 private static void perform(Calculator.Client client) throws TException
74 {
75 client.ping();
76 System.out.println("ping()");
77
78 int sum = client.add(1,1);
79 System.out.println("1+1=" + sum);
80
81 Work work = new Work();
82
83 work.op = Operation.DIVIDE;
84 work.num1 = 1;
85 work.num2 = 0;
86 try {
87 int quotient = client.calculate(1, work);
88 System.out.println("Whoa we can divide by 0");
89 } catch (InvalidOperation io) {
90 System.out.println("Invalid operation: " + io.why);
91 }
92
93 work.op = Operation.SUBTRACT;
94 work.num1 = 15;
95 work.num2 = 10;
96 try {
97 int diff = client.calculate(1, work);
98 System.out.println("15-10=" + diff);
99 } catch (InvalidOperation io) {
100 System.out.println("Invalid operation: " + io.why);
101 }
102
103 SharedStruct log = client.getStruct(1);
104 System.out.println("Check log: " + log.value);
105 }
Mark Sleecb39f082007-04-10 02:30:30 +0000106}