Jens Geyer | 0e87c46 | 2013-06-18 22:25:07 +0200 | [diff] [blame] | 1 | package main |
Christian Lavoie | afc6d8f | 2011-02-20 02:39:19 +0000 | [diff] [blame] | 2 | |
| 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 Lavoie | afc6d8f | 2011-02-20 02:39:19 +0000 | [diff] [blame] | 22 | import ( |
Jens Geyer | 0e87c46 | 2013-06-18 22:25:07 +0200 | [diff] [blame] | 23 | "flag" |
| 24 | "fmt" |
Jens Geyer | 0e87c46 | 2013-06-18 22:25:07 +0200 | [diff] [blame] | 25 | "os" |
Yuxuan 'fishy' Wang | b71f11e | 2021-03-22 15:01:00 -0700 | [diff] [blame^] | 26 | |
| 27 | "github.com/apache/thrift/lib/go/thrift" |
Christian Lavoie | afc6d8f | 2011-02-20 02:39:19 +0000 | [diff] [blame] | 28 | ) |
| 29 | |
| 30 | func Usage() { |
Jens Geyer | 0e87c46 | 2013-06-18 22:25:07 +0200 | [diff] [blame] | 31 | fmt.Fprint(os.Stderr, "Usage of ", os.Args[0], ":\n") |
| 32 | flag.PrintDefaults() |
| 33 | fmt.Fprint(os.Stderr, "\n") |
Christian Lavoie | afc6d8f | 2011-02-20 02:39:19 +0000 | [diff] [blame] | 34 | } |
| 35 | |
| 36 | func main() { |
Jens Geyer | 0e87c46 | 2013-06-18 22:25:07 +0200 | [diff] [blame] | 37 | flag.Usage = Usage |
| 38 | server := flag.Bool("server", false, "Run server") |
Jens Geyer | c949514 | 2013-09-08 00:31:20 +0200 | [diff] [blame] | 39 | protocol := flag.String("P", "binary", "Specify the protocol (binary, compact, json, simplejson)") |
Jens Geyer | 0e87c46 | 2013-06-18 22:25:07 +0200 | [diff] [blame] | 40 | framed := flag.Bool("framed", false, "Use framed transport") |
Jens Geyer | 44b19df | 2013-07-26 23:05:00 +0200 | [diff] [blame] | 41 | buffered := flag.Bool("buffered", false, "Use buffered transport") |
| 42 | addr := flag.String("addr", "localhost:9090", "Address to listen to") |
Jens Geyer | 4c83595 | 2013-08-13 21:34:17 +0200 | [diff] [blame] | 43 | secure := flag.Bool("secure", false, "Use tls secure transport") |
Jens Geyer | 0e87c46 | 2013-06-18 22:25:07 +0200 | [diff] [blame] | 44 | |
| 45 | flag.Parse() |
| 46 | |
| 47 | var protocolFactory thrift.TProtocolFactory |
| 48 | switch *protocol { |
| 49 | case "compact": |
| 50 | protocolFactory = thrift.NewTCompactProtocolFactory() |
| 51 | case "simplejson": |
| 52 | protocolFactory = thrift.NewTSimpleJSONProtocolFactory() |
| 53 | case "json": |
| 54 | protocolFactory = thrift.NewTJSONProtocolFactory() |
| 55 | case "binary", "": |
| 56 | protocolFactory = thrift.NewTBinaryProtocolFactoryDefault() |
| 57 | default: |
| 58 | fmt.Fprint(os.Stderr, "Invalid protocol specified", protocol, "\n") |
| 59 | Usage() |
| 60 | os.Exit(1) |
| 61 | } |
Jens Geyer | 44b19df | 2013-07-26 23:05:00 +0200 | [diff] [blame] | 62 | |
| 63 | var transportFactory thrift.TTransportFactory |
| 64 | if *buffered { |
| 65 | transportFactory = thrift.NewTBufferedTransportFactory(8192) |
| 66 | } else { |
| 67 | transportFactory = thrift.NewTTransportFactory() |
| 68 | } |
| 69 | |
Jens Geyer | 0e87c46 | 2013-06-18 22:25:07 +0200 | [diff] [blame] | 70 | if *framed { |
| 71 | transportFactory = thrift.NewTFramedTransportFactory(transportFactory) |
| 72 | } |
| 73 | |
| 74 | if *server { |
Jens Geyer | 4c83595 | 2013-08-13 21:34:17 +0200 | [diff] [blame] | 75 | if err := runServer(transportFactory, protocolFactory, *addr, *secure); err != nil { |
Jens Geyer | 0e87c46 | 2013-06-18 22:25:07 +0200 | [diff] [blame] | 76 | fmt.Println("error running server:", err) |
| 77 | } |
| 78 | } else { |
Jens Geyer | 4c83595 | 2013-08-13 21:34:17 +0200 | [diff] [blame] | 79 | if err := runClient(transportFactory, protocolFactory, *addr, *secure); err != nil { |
Jens Geyer | 0e87c46 | 2013-06-18 22:25:07 +0200 | [diff] [blame] | 80 | fmt.Println("error running client:", err) |
| 81 | } |
| 82 | } |
Christian Lavoie | afc6d8f | 2011-02-20 02:39:19 +0000 | [diff] [blame] | 83 | } |