forked from restlet/restlet-framework-java
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathServerHelper.java
More file actions
108 lines (97 loc) · 3.02 KB
/
ServerHelper.java
File metadata and controls
108 lines (97 loc) · 3.02 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
/**
* Copyright 2005-2013 Restlet S.A.S.
*
* The contents of this file are subject to the terms of one of the following
* open source licenses: Apache 2.0 or LGPL 3.0 or LGPL 2.1 or CDDL 1.0 or EPL
* 1.0 (the "Licenses"). You can select the license that you prefer but you may
* not use this file except in compliance with one of these Licenses.
*
* You can obtain a copy of the Apache 2.0 license at
* http://www.opensource.org/licenses/apache-2.0
*
* You can obtain a copy of the LGPL 3.0 license at
* http://www.opensource.org/licenses/lgpl-3.0
*
* You can obtain a copy of the LGPL 2.1 license at
* http://www.opensource.org/licenses/lgpl-2.1
*
* You can obtain a copy of the CDDL 1.0 license at
* http://www.opensource.org/licenses/cddl1
*
* You can obtain a copy of the EPL 1.0 license at
* http://www.opensource.org/licenses/eclipse-1.0
*
* See the Licenses for the specific language governing permissions and
* limitations under the Licenses.
*
* Alternatively, you can obtain a royalty free commercial license with less
* limitations, transferable or non-transferable, directly at
* http://www.restlet.com/products/restlet-framework
*
* Restlet is a registered trademark of Restlet S.A.S.
*/
package org.restlet.engine;
import org.restlet.Request;
import org.restlet.Response;
import org.restlet.Server;
/**
* Server connector helper.
*
* @author Jerome Louvel
*/
public class ServerHelper extends ConnectorHelper<Server> {
/**
* Constructor.
*
* @param server
* The client to help.
*/
public ServerHelper(Server server) {
super(server);
// Clear the ephemeral port
getAttributes().put("ephemeralPort", -1);
}
/**
* Handles a call by invoking the helped Server's
* {@link Server#handle(Request, Response)} method.
*
* @param request
* The request to handle.
* @param response
* The response to update.
*/
@Override
public void handle(Request request, Response response) {
super.handle(request, response);
getHelped().handle(request, response);
}
/**
* Sets the ephemeral port in the attributes map if necessary.
*
* @param localPort
* The ephemeral local port.
*/
public void setEphemeralPort(int localPort) {
// If an ephemeral port is used, make sure we update the attribute for
// the API
if (getHelped().getPort() == 0) {
getAttributes().put("ephemeralPort", localPort);
}
}
// [ifndef gae] method
/**
* Sets the ephemeral port in the attributes map if necessary.
*
* @param socket
* The bound server socket.
*/
public void setEphemeralPort(java.net.ServerSocket socket) {
setEphemeralPort(socket.getLocalPort());
}
@Override
public synchronized void stop() throws Exception {
super.stop();
// Clear the ephemeral port
getAttributes().put("ephemeralPort", -1);
}
}