19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/* 29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Copyright (C) 2007 The Android Open Source Project 39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License"); 59066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you may not use this file except in compliance with the License. 69066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * You may obtain a copy of the License at 79066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * http://www.apache.org/licenses/LICENSE-2.0 99066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Unless required by applicable law or agreed to in writing, software 119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS, 129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * See the License for the specific language governing permissions and 149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * limitations under the License. 159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpackage android.net; 189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 19065b299df4159602327977dd007cb2cd6b64ab20Jeff Sharkeyimport java.io.Closeable; 209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.io.FileDescriptor; 219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.io.IOException; 229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.io.InputStream; 239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.io.OutputStream; 249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.net.SocketOptions; 259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/** 279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Creates a (non-server) socket in the UNIX-domain namespace. The interface 289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * here is not entirely unlike that of java.net.Socket 299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 30065b299df4159602327977dd007cb2cd6b64ab20Jeff Sharkeypublic class LocalSocket implements Closeable { 319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private LocalSocketImpl impl; 339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private volatile boolean implCreated; 349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private LocalSocketAddress localAddress; 359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private boolean isBound; 369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private boolean isConnected; 37e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood private final int sockType; 38e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood 39e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood /** unknown socket type (used for constructor with existing file descriptor) */ 40e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood /* package */ static final int SOCKET_UNKNOWN = 0; 41e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood /** Datagram socket type */ 42e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood public static final int SOCKET_DGRAM = 1; 43e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood /** Stream socket type */ 44e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood public static final int SOCKET_STREAM = 2; 45e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood /** Sequential packet socket type */ 46e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood public static final int SOCKET_SEQPACKET = 3; 479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Creates a AF_LOCAL/UNIX domain stream socket. 509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LocalSocket() { 52e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood this(SOCKET_STREAM); 53e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood } 54e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood 55e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood /** 56e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood * Creates a AF_LOCAL/UNIX domain stream socket with given socket type 57e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood * 58e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood * @param sockType either {@link #SOCKET_DGRAM}, {@link #SOCKET_STREAM} 59e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood * or {@link #SOCKET_SEQPACKET} 60e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood */ 61e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood public LocalSocket(int sockType) { 62e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood this(new LocalSocketImpl(), sockType); 639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project isBound = false; 649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project isConnected = false; 659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 66e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood 673b147b770269173d5d711d6c33f142dc5e723824zzy /** 683b147b770269173d5d711d6c33f142dc5e723824zzy * Creates a AF_LOCAL/UNIX domain stream socket with FileDescriptor. 693b147b770269173d5d711d6c33f142dc5e723824zzy * @hide 703b147b770269173d5d711d6c33f142dc5e723824zzy */ 713b147b770269173d5d711d6c33f142dc5e723824zzy public LocalSocket(FileDescriptor fd) throws IOException { 72e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood this(new LocalSocketImpl(fd), SOCKET_UNKNOWN); 733b147b770269173d5d711d6c33f142dc5e723824zzy isBound = true; 743b147b770269173d5d711d6c33f142dc5e723824zzy isConnected = true; 753b147b770269173d5d711d6c33f142dc5e723824zzy } 769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * for use with AndroidServerSocket 799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param impl a SocketImpl 809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 81e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood /*package*/ LocalSocket(LocalSocketImpl impl, int sockType) { 829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project this.impl = impl; 83e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood this.sockType = sockType; 849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project this.isConnected = false; 859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project this.isBound = false; 869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** {@inheritDoc} */ 899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project @Override 909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public String toString() { 919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return super.toString() + " impl:" + impl; 929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * It's difficult to discern from the spec when impl.create() should be 969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * called, but it seems like a reasonable rule is "as soon as possible, 979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * but not in a context where IOException cannot be thrown" 989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @throws IOException from SocketImpl.create() 1009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private void implCreateIfNeeded() throws IOException { 1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (!implCreated) { 1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project synchronized (this) { 1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (!implCreated) { 105c59a66238261778b3fbc496e9b21dfa043ee9160Jesse Wilson try { 106e7d309a929bf87a5752cd1fb2d48c72e47a671a2Mike Lockwood impl.create(sockType); 107c59a66238261778b3fbc496e9b21dfa043ee9160Jesse Wilson } finally { 108c59a66238261778b3fbc496e9b21dfa043ee9160Jesse Wilson implCreated = true; 109c59a66238261778b3fbc496e9b21dfa043ee9160Jesse Wilson } 1109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Connects this socket to an endpoint. May only be called on an instance 1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * that has not yet been connected. 1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param endpoint endpoint address 1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @throws IOException if socket is in invalid state or the address does 1219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * not exist. 1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void connect(LocalSocketAddress endpoint) throws IOException { 1249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project synchronized (this) { 1259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (isConnected) { 1269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project throw new IOException("already connected"); 1279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project implCreateIfNeeded(); 1309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project impl.connect(endpoint, 0); 1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project isConnected = true; 1329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project isBound = true; 1339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Binds this socket to an endpoint name. May only be called on an instance 1389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * that has not yet been bound. 1399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param bindpoint endpoint address 1419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @throws IOException 1429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void bind(LocalSocketAddress bindpoint) throws IOException { 1449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project implCreateIfNeeded(); 1459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project synchronized (this) { 1479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (isBound) { 1489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project throw new IOException("already bound"); 1499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project localAddress = bindpoint; 1529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project impl.bind(localAddress); 1539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project isBound = true; 1549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Retrieves the name that this socket is bound to, if any. 1599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return Local address or null if anonymous 1619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LocalSocketAddress getLocalSocketAddress() { 1639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return localAddress; 1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Retrieves the input stream for this instance. 1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return input stream 1709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @throws IOException if socket has been closed or cannot be created. 1719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public InputStream getInputStream() throws IOException { 1739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project implCreateIfNeeded(); 1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return impl.getInputStream(); 1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Retrieves the output stream for this instance. 1799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return output stream 1819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @throws IOException if socket has been closed or cannot be created. 1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 1839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public OutputStream getOutputStream() throws IOException { 1849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project implCreateIfNeeded(); 1859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return impl.getOutputStream(); 1869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 1899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Closes the socket. 1909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 1919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @throws IOException 1929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 193065b299df4159602327977dd007cb2cd6b64ab20Jeff Sharkey @Override 1949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void close() throws IOException { 1959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project implCreateIfNeeded(); 1969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project impl.close(); 1979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Shuts down the input side of the socket. 2019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @throws IOException 2039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void shutdownInput() throws IOException { 2059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project implCreateIfNeeded(); 2069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project impl.shutdownInput(); 2079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Shuts down the output side of the socket. 2119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @throws IOException 2139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void shutdownOutput() throws IOException { 2159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project implCreateIfNeeded(); 2169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project impl.shutdownOutput(); 2179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setReceiveBufferSize(int size) throws IOException { 2209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project impl.setOption(SocketOptions.SO_RCVBUF, Integer.valueOf(size)); 2219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int getReceiveBufferSize() throws IOException { 2249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return ((Integer) impl.getOption(SocketOptions.SO_RCVBUF)).intValue(); 2259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setSoTimeout(int n) throws IOException { 2289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project impl.setOption(SocketOptions.SO_TIMEOUT, Integer.valueOf(n)); 2299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int getSoTimeout() throws IOException { 2329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return ((Integer) impl.getOption(SocketOptions.SO_TIMEOUT)).intValue(); 2339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setSendBufferSize(int n) throws IOException { 2369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project impl.setOption(SocketOptions.SO_SNDBUF, Integer.valueOf(n)); 2379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public int getSendBufferSize() throws IOException { 2409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return ((Integer) impl.getOption(SocketOptions.SO_SNDBUF)).intValue(); 2419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //???SEC 2449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public LocalSocketAddress getRemoteSocketAddress() { 2459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project throw new UnsupportedOperationException(); 2469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //???SEC 2499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public synchronized boolean isConnected() { 2509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return isConnected; 2519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //???SEC 2549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public boolean isClosed() { 2559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project throw new UnsupportedOperationException(); 2569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //???SEC 2599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public synchronized boolean isBound() { 2609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return isBound; 2619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //???SEC 2649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public boolean isOutputShutdown() { 2659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project throw new UnsupportedOperationException(); 2669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //???SEC 2699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public boolean isInputShutdown() { 2709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project throw new UnsupportedOperationException(); 2719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //???SEC 2749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void connect(LocalSocketAddress endpoint, int timeout) 2759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project throws IOException { 2769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project throw new UnsupportedOperationException(); 2779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Enqueues a set of file descriptors to send to the peer. The queue 2819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * is one deep. The file descriptors will be sent with the next write 2829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * of normal data, and will be delivered in a single ancillary message. 2839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * See "man 7 unix" SCM_RIGHTS on a desktop Linux machine. 2849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @param fds non-null; file descriptors to send. 2869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 2879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public void setFileDescriptorsForSend(FileDescriptor[] fds) { 2889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project impl.setFileDescriptorsForSend(fds); 2899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 2929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Retrieves a set of file descriptors that a peer has sent through 2939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * an ancillary message. This method retrieves the most recent set sent, 2949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * and then returns null until a new set arrives. 2959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * File descriptors may only be passed along with regular data, so this 2969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * method can only return a non-null after a read operation. 2979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 2989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return null or file descriptor array 2999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @throws IOException 3009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public FileDescriptor[] getAncillaryFileDescriptors() throws IOException { 3029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return impl.getAncillaryFileDescriptors(); 3039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Retrieves the credentials of this socket's peer. Only valid on 3079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * connected sockets. 3089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 3099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return non-null; peer credentials 3109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @throws IOException 3119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public Credentials getPeerCredentials() throws IOException { 3139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return impl.getPeerCredentials(); 3149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project /** 3179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Returns file descriptor or null if not yet open/already closed 3189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 3199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @return fd or null 3209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 3219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public FileDescriptor getFileDescriptor() { 3229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return impl.getFileDescriptor(); 3239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project} 325