1 /*
2 * Copyright (C) 2008-2009, Google Inc.
3 * and other copyright owners as documented in the project's IP log.
4 *
5 * This program and the accompanying materials are made available
6 * under the terms of the Eclipse Distribution License v1.0 which
7 * accompanies this distribution, is reproduced below, and is
8 * available at http://www.eclipse.org/org/documents/edl-v10.php
9 *
10 * All rights reserved.
11 *
12 * Redistribution and use in source and binary forms, with or
13 * without modification, are permitted provided that the following
14 * conditions are met:
15 *
16 * - Redistributions of source code must retain the above copyright
17 * notice, this list of conditions and the following disclaimer.
18 *
19 * - Redistributions in binary form must reproduce the above
20 * copyright notice, this list of conditions and the following
21 * disclaimer in the documentation and/or other materials provided
22 * with the distribution.
23 *
24 * - Neither the name of the Eclipse Foundation, Inc. nor the
25 * names of its contributors may be used to endorse or promote
26 * products derived from this software without specific prior
27 * written permission.
28 *
29 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
30 * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
31 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
32 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
33 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
34 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
35 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
36 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
37 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
38 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
39 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
40 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
41 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
42 */
43
44 package org.eclipse.jgit.transport;
45
46 import java.io.BufferedInputStream;
47 import java.io.BufferedOutputStream;
48 import java.io.IOException;
49 import java.io.InputStream;
50 import java.io.OutputStream;
51 import java.net.InetAddress;
52 import java.net.Socket;
53
54 import org.eclipse.jgit.transport.resolver.ServiceNotAuthorizedException;
55 import org.eclipse.jgit.transport.resolver.ServiceNotEnabledException;
56
57 /**
58 * Active network client of {@link org.eclipse.jgit.transport.Daemon}.
59 */
60 public class DaemonClient {
61 private final Daemon daemon;
62
63 private InetAddress peer;
64
65 private InputStream rawIn;
66
67 private OutputStream rawOut;
68
69 DaemonClient(final Daemon d) {
70 daemon = d;
71 }
72
73 void setRemoteAddress(final InetAddress ia) {
74 peer = ia;
75 }
76
77 /**
78 * Get the daemon which spawned this client.
79 *
80 * @return the daemon which spawned this client.
81 */
82 public Daemon getDaemon() {
83 return daemon;
84 }
85
86 /**
87 * Get Internet address of the remote client.
88 *
89 * @return Internet address of the remote client.
90 */
91 public InetAddress getRemoteAddress() {
92 return peer;
93 }
94
95 /**
96 * Get input stream to read from the connected client.
97 *
98 * @return input stream to read from the connected client.
99 */
100 public InputStream getInputStream() {
101 return rawIn;
102 }
103
104 /**
105 * Get output stream to send data to the connected client.
106 *
107 * @return output stream to send data to the connected client.
108 */
109 public OutputStream getOutputStream() {
110 return rawOut;
111 }
112
113 void execute(final Socket sock) throws IOException,
114 ServiceNotEnabledException, ServiceNotAuthorizedException {
115 rawIn = new BufferedInputStream(sock.getInputStream());
116 rawOut = new BufferedOutputStream(sock.getOutputStream());
117
118 if (0 < daemon.getTimeout())
119 sock.setSoTimeout(daemon.getTimeout() * 1000);
120 String cmd = new PacketLineIn(rawIn).readStringRaw();
121 final int nul = cmd.indexOf('\0');
122 if (nul >= 0) {
123 // Newer clients hide a "host" header behind this byte.
124 // Currently we don't use it for anything, so we ignore
125 // this portion of the command.
126 //
127 cmd = cmd.substring(0, nul);
128 }
129
130 final DaemonService srv = getDaemon().matchService(cmd);
131 if (srv == null)
132 return;
133 sock.setSoTimeout(0);
134 srv.execute(this, cmd);
135 }
136 }