blob: 7730d7b3202f6947a6589de2ae6ad84657ff5755 [file] [log] [blame]
Jens Geyer0e87c462013-06-18 22:25:07 +02001package main
Christian Lavoieafc6d8f2011-02-20 02:39:19 +00002
3/*
4 * Licensed to the Apache Software Foundation (ASF) under one
5 * or more contributor license agreements. See the NOTICE file
6 * distributed with this work for additional information
7 * regarding copyright ownership. The ASF licenses this file
8 * to you under the Apache License, Version 2.0 (the
9 * "License"); you may not use this file except in compliance
10 * with the License. You may obtain a copy of the License at
11 *
12 * http://www.apache.org/licenses/LICENSE-2.0
13 *
14 * Unless required by applicable law or agreed to in writing,
15 * software distributed under the License is distributed on an
16 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
17 * KIND, either express or implied. See the License for the
18 * specific language governing permissions and limitations
19 * under the License.
20 */
21
Christian Lavoieafc6d8f2011-02-20 02:39:19 +000022import (
Jens Geyer0e87c462013-06-18 22:25:07 +020023 "flag"
24 "fmt"
D. Can Celasun9ee29512018-10-17 08:44:48 +020025 "github.com/apache/thrift/lib/go/thrift"
Jens Geyer0e87c462013-06-18 22:25:07 +020026 "os"
Christian Lavoieafc6d8f2011-02-20 02:39:19 +000027)
28
29func Usage() {
Jens Geyer0e87c462013-06-18 22:25:07 +020030 fmt.Fprint(os.Stderr, "Usage of ", os.Args[0], ":\n")
31 flag.PrintDefaults()
32 fmt.Fprint(os.Stderr, "\n")
Christian Lavoieafc6d8f2011-02-20 02:39:19 +000033}
34
35func main() {
Jens Geyer0e87c462013-06-18 22:25:07 +020036 flag.Usage = Usage
37 server := flag.Bool("server", false, "Run server")
Jens Geyerc9495142013-09-08 00:31:20 +020038 protocol := flag.String("P", "binary", "Specify the protocol (binary, compact, json, simplejson)")
Jens Geyer0e87c462013-06-18 22:25:07 +020039 framed := flag.Bool("framed", false, "Use framed transport")
Jens Geyer44b19df2013-07-26 23:05:00 +020040 buffered := flag.Bool("buffered", false, "Use buffered transport")
41 addr := flag.String("addr", "localhost:9090", "Address to listen to")
Jens Geyer4c835952013-08-13 21:34:17 +020042 secure := flag.Bool("secure", false, "Use tls secure transport")
Jens Geyer0e87c462013-06-18 22:25:07 +020043
44 flag.Parse()
45
46 var protocolFactory thrift.TProtocolFactory
47 switch *protocol {
48 case "compact":
49 protocolFactory = thrift.NewTCompactProtocolFactory()
50 case "simplejson":
51 protocolFactory = thrift.NewTSimpleJSONProtocolFactory()
52 case "json":
53 protocolFactory = thrift.NewTJSONProtocolFactory()
54 case "binary", "":
55 protocolFactory = thrift.NewTBinaryProtocolFactoryDefault()
56 default:
57 fmt.Fprint(os.Stderr, "Invalid protocol specified", protocol, "\n")
58 Usage()
59 os.Exit(1)
60 }
Jens Geyer44b19df2013-07-26 23:05:00 +020061
62 var transportFactory thrift.TTransportFactory
63 if *buffered {
64 transportFactory = thrift.NewTBufferedTransportFactory(8192)
65 } else {
66 transportFactory = thrift.NewTTransportFactory()
67 }
68
Jens Geyer0e87c462013-06-18 22:25:07 +020069 if *framed {
70 transportFactory = thrift.NewTFramedTransportFactory(transportFactory)
71 }
72
73 if *server {
Jens Geyer4c835952013-08-13 21:34:17 +020074 if err := runServer(transportFactory, protocolFactory, *addr, *secure); err != nil {
Jens Geyer0e87c462013-06-18 22:25:07 +020075 fmt.Println("error running server:", err)
76 }
77 } else {
Jens Geyer4c835952013-08-13 21:34:17 +020078 if err := runClient(transportFactory, protocolFactory, *addr, *secure); err != nil {
Jens Geyer0e87c462013-06-18 22:25:07 +020079 fmt.Println("error running client:", err)
80 }
81 }
Christian Lavoieafc6d8f2011-02-20 02:39:19 +000082}