View Javadoc
1   /*
2    * Copyright 2012 The Netty Project
3    *
4    * The Netty Project licenses this file to you under the Apache License,
5    * version 2.0 (the "License"); you may not use this file except in compliance
6    * with the License. You may obtain a copy of the License at:
7    *
8    *   https://www.apache.org/licenses/LICENSE-2.0
9    *
10   * Unless required by applicable law or agreed to in writing, software
11   * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12   * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13   * License for the specific language governing permissions and limitations
14   * under the License.
15   */
16  package io.netty.example.worldclock;
17  
18  import io.netty.bootstrap.Bootstrap;
19  import io.netty.channel.Channel;
20  import io.netty.channel.EventLoopGroup;
21  import io.netty.channel.nio.NioEventLoopGroup;
22  import io.netty.channel.socket.nio.NioSocketChannel;
23  import io.netty.example.util.ServerUtil;
24  import io.netty.handler.ssl.SslContext;
25  
26  import java.util.Arrays;
27  import java.util.List;
28  
29  /**
30   * Sends a list of continent/city pairs to a {@link WorldClockServer} to
31   * get the local times of the specified cities.
32   */
33  public final class WorldClockClient {
34  
35      static final String HOST = System.getProperty("host", "127.0.0.1");
36      static final int PORT = Integer.parseInt(System.getProperty("port", "8463"));
37      static final List<String> CITIES = Arrays.asList(System.getProperty(
38              "cities", "Asia/Seoul,Europe/Berlin,America/Los_Angeles").split(","));
39  
40      public static void main(String[] args) throws Exception {
41          // Configure SSL.
42          final SslContext sslCtx = ServerUtil.buildSslContext();
43  
44          EventLoopGroup group = new NioEventLoopGroup();
45          try {
46              Bootstrap b = new Bootstrap();
47              b.group(group)
48               .channel(NioSocketChannel.class)
49               .handler(new WorldClockClientInitializer(sslCtx));
50  
51              // Make a new connection.
52              Channel ch = b.connect(HOST, PORT).sync().channel();
53  
54              // Get the handler instance to initiate the request.
55              WorldClockClientHandler handler = ch.pipeline().get(WorldClockClientHandler.class);
56  
57              // Request and get the response.
58              List<String> response = handler.getLocalTimes(CITIES);
59  
60              // Close the connection.
61              ch.close();
62  
63              // Print the response at last but not least.
64              for (int i = 0; i < CITIES.size(); i ++) {
65                  System.out.format("%28s: %s%n", CITIES.get(i), response.get(i));
66              }
67          } finally {
68              group.shutdownGracefully();
69          }
70      }
71  }