|  | package main | 
|  |  | 
|  | /* | 
|  | * Licensed to the Apache Software Foundation (ASF) under one | 
|  | * or more contributor license agreements. See the NOTICE file | 
|  | * distributed with this work for additional information | 
|  | * regarding copyright ownership. The ASF licenses this file | 
|  | * to you under the Apache License, Version 2.0 (the | 
|  | * "License"); you may not use this file except in compliance | 
|  | * with the License. You may obtain a copy of the License at | 
|  | * | 
|  | *   http://www.apache.org/licenses/LICENSE-2.0 | 
|  | * | 
|  | * Unless required by applicable law or agreed to in writing, | 
|  | * software distributed under the License is distributed on an | 
|  | * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | 
|  | * KIND, either express or implied. See the License for the | 
|  | * specific language governing permissions and limitations | 
|  | * under the License. | 
|  | */ | 
|  |  | 
|  | import ( | 
|  | "crypto/tls" | 
|  | "flag" | 
|  | "fmt" | 
|  | "os" | 
|  |  | 
|  | "github.com/apache/thrift/lib/go/thrift" | 
|  | ) | 
|  |  | 
|  | func Usage() { | 
|  | fmt.Fprint(os.Stderr, "Usage of ", os.Args[0], ":\n") | 
|  | flag.PrintDefaults() | 
|  | fmt.Fprint(os.Stderr, "\n") | 
|  | } | 
|  |  | 
|  | func main() { | 
|  | flag.Usage = Usage | 
|  | server := flag.Bool("server", false, "Run server") | 
|  | protocol := flag.String("P", "binary", "Specify the protocol (binary, compact, json, simplejson)") | 
|  | framed := flag.Bool("framed", false, "Use framed transport") | 
|  | buffered := flag.Bool("buffered", false, "Use buffered transport") | 
|  | addr := flag.String("addr", "localhost:9090", "Address to listen to") | 
|  | secure := flag.Bool("secure", false, "Use tls secure transport") | 
|  |  | 
|  | flag.Parse() | 
|  |  | 
|  | var protocolFactory thrift.TProtocolFactory | 
|  | switch *protocol { | 
|  | case "compact": | 
|  | protocolFactory = thrift.NewTCompactProtocolFactoryConf(nil) | 
|  | case "simplejson": | 
|  | protocolFactory = thrift.NewTSimpleJSONProtocolFactoryConf(nil) | 
|  | case "json": | 
|  | protocolFactory = thrift.NewTJSONProtocolFactory() | 
|  | case "binary", "": | 
|  | protocolFactory = thrift.NewTBinaryProtocolFactoryConf(nil) | 
|  | default: | 
|  | fmt.Fprint(os.Stderr, "Invalid protocol specified", protocol, "\n") | 
|  | Usage() | 
|  | os.Exit(1) | 
|  | } | 
|  |  | 
|  | var transportFactory thrift.TTransportFactory | 
|  | cfg := &thrift.TConfiguration{ | 
|  | TLSConfig: &tls.Config{ | 
|  | InsecureSkipVerify: true, | 
|  | }, | 
|  | } | 
|  | if *buffered { | 
|  | transportFactory = thrift.NewTBufferedTransportFactory(8192) | 
|  | } else { | 
|  | transportFactory = thrift.NewTTransportFactory() | 
|  | } | 
|  |  | 
|  | if *framed { | 
|  | transportFactory = thrift.NewTFramedTransportFactoryConf(transportFactory, cfg) | 
|  | } | 
|  |  | 
|  | if *server { | 
|  | if err := runServer(transportFactory, protocolFactory, *addr, *secure); err != nil { | 
|  | fmt.Println("error running server:", err) | 
|  | } | 
|  | } else { | 
|  | if err := runClient(transportFactory, protocolFactory, *addr, *secure, cfg); err != nil { | 
|  | fmt.Println("error running client:", err) | 
|  | } | 
|  | } | 
|  | } |