mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-07-24 17:32:48 +00:00
Moving to root below branch label
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@2005 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
299
source/java/org/alfresco/filesys/smb/server/PacketHandler.java
Normal file
299
source/java/org/alfresco/filesys/smb/server/PacketHandler.java
Normal file
@@ -0,0 +1,299 @@
|
||||
/*
|
||||
* Copyright (C) 2005 Alfresco, Inc.
|
||||
*
|
||||
* Licensed under the Mozilla Public License version 1.1
|
||||
* with a permitted attribution clause. You may obtain a
|
||||
* copy of the License at
|
||||
*
|
||||
* http://www.alfresco.org/legal/license.txt
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
package org.alfresco.filesys.smb.server;
|
||||
|
||||
import java.io.DataInputStream;
|
||||
import java.io.DataOutputStream;
|
||||
import java.io.IOException;
|
||||
import java.net.InetAddress;
|
||||
import java.net.Socket;
|
||||
|
||||
/**
|
||||
* Protocol Packet Handler Interface
|
||||
*/
|
||||
public abstract class PacketHandler
|
||||
{
|
||||
|
||||
// Protocol type and name
|
||||
|
||||
private int m_protoType;
|
||||
private String m_protoName;
|
||||
private String m_shortName;
|
||||
|
||||
// Socket that this session is using.
|
||||
|
||||
private Socket m_socket;
|
||||
|
||||
// Input/output streams for receiving/sending SMB requests.
|
||||
|
||||
private DataInputStream m_in;
|
||||
private DataOutputStream m_out;
|
||||
|
||||
// Client caller name
|
||||
|
||||
private String m_clientName;
|
||||
|
||||
/**
|
||||
* Class constructor
|
||||
*
|
||||
* @param sock Socket
|
||||
* @param typ int
|
||||
* @param name String
|
||||
* @param shortName String
|
||||
* @exception IOException If a network error occurs
|
||||
*/
|
||||
public PacketHandler(Socket sock, int typ, String name, String shortName) throws IOException
|
||||
{
|
||||
m_socket = sock;
|
||||
m_protoType = typ;
|
||||
m_protoName = name;
|
||||
m_shortName = shortName;
|
||||
|
||||
// Set socket options
|
||||
|
||||
sock.setTcpNoDelay(true);
|
||||
|
||||
// Open the input/output streams
|
||||
|
||||
m_in = new DataInputStream(m_socket.getInputStream());
|
||||
m_out = new DataOutputStream(m_socket.getOutputStream());
|
||||
}
|
||||
|
||||
/**
|
||||
* Class constructor
|
||||
*
|
||||
* @param typ int
|
||||
* @param name String
|
||||
* @param shortName String
|
||||
*/
|
||||
public PacketHandler(int typ, String name, String shortName, String clientName)
|
||||
{
|
||||
m_protoType = typ;
|
||||
m_protoName = name;
|
||||
m_shortName = shortName;
|
||||
|
||||
m_clientName = clientName;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the protocol type
|
||||
*
|
||||
* @return int
|
||||
*/
|
||||
public final int isProtocol()
|
||||
{
|
||||
return m_protoType;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the protocol name
|
||||
*
|
||||
* @return String
|
||||
*/
|
||||
public final String isProtocolName()
|
||||
{
|
||||
return m_protoName;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the short protocol name
|
||||
*
|
||||
* @return String
|
||||
*/
|
||||
public final String getShortName()
|
||||
{
|
||||
return m_shortName;
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if there is a remote address available
|
||||
*
|
||||
* @return boolean
|
||||
*/
|
||||
public final boolean hasRemoteAddress()
|
||||
{
|
||||
return m_socket != null ? true : false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the remote address for the socket connection
|
||||
*
|
||||
* @return InetAddress
|
||||
*/
|
||||
public final InetAddress getRemoteAddress()
|
||||
{
|
||||
return m_socket != null ? m_socket.getInetAddress() : null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine if the client name is available
|
||||
*
|
||||
* @return boolean
|
||||
*/
|
||||
public final boolean hasClientName()
|
||||
{
|
||||
return m_clientName != null ? true : false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the client name
|
||||
*
|
||||
* @return
|
||||
*/
|
||||
public final String getClientName()
|
||||
{
|
||||
return m_clientName;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the count of available bytes in the receive input stream
|
||||
*
|
||||
* @return int
|
||||
* @exception IOException If a network error occurs.
|
||||
*/
|
||||
public final int availableBytes() throws IOException
|
||||
{
|
||||
if (m_in != null)
|
||||
return m_in.available();
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Read a packet
|
||||
*
|
||||
* @param pkt byte[]
|
||||
* @param off int
|
||||
* @param len int
|
||||
* @return int
|
||||
* @exception IOException If a network error occurs.
|
||||
*/
|
||||
public final int readPacket(byte[] pkt, int off, int len) throws IOException
|
||||
{
|
||||
|
||||
// Read a packet of data
|
||||
|
||||
if (m_in != null)
|
||||
return m_in.read(pkt, off, len);
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Receive an SMB request packet
|
||||
*
|
||||
* @param pkt SMBSrvPacket
|
||||
* @return int
|
||||
* @exception IOException If a network error occurs.
|
||||
*/
|
||||
public abstract int readPacket(SMBSrvPacket pkt) throws IOException;
|
||||
|
||||
/**
|
||||
* Send an SMB request packet
|
||||
*
|
||||
* @param pkt byte[]
|
||||
* @param off int
|
||||
* @param len int
|
||||
* @exception IOException If a network error occurs.
|
||||
*/
|
||||
public final void writePacket(byte[] pkt, int off, int len) throws IOException
|
||||
{
|
||||
|
||||
// Output the raw packet
|
||||
|
||||
if (m_out != null)
|
||||
m_out.write(pkt, off, len);
|
||||
}
|
||||
|
||||
/**
|
||||
* Send an SMB response packet
|
||||
*
|
||||
* @param pkt SMBSrvPacket
|
||||
* @param len int
|
||||
* @exception IOException If a network error occurs.
|
||||
*/
|
||||
public abstract void writePacket(SMBSrvPacket pkt, int len) throws IOException;
|
||||
|
||||
/**
|
||||
* Send an SMB response packet
|
||||
*
|
||||
* @param pkt SMBSrvPacket
|
||||
* @exception IOException If a network error occurs.
|
||||
*/
|
||||
public final void writePacket(SMBSrvPacket pkt) throws IOException
|
||||
{
|
||||
writePacket(pkt, pkt.getLength());
|
||||
}
|
||||
|
||||
/**
|
||||
* Flush the output socket
|
||||
*
|
||||
* @exception IOException If a network error occurs
|
||||
*/
|
||||
public final void flushPacket() throws IOException
|
||||
{
|
||||
if (m_out != null)
|
||||
m_out.flush();
|
||||
}
|
||||
|
||||
/**
|
||||
* Close the protocol handler
|
||||
*/
|
||||
public void closeHandler()
|
||||
{
|
||||
|
||||
// Close the input stream
|
||||
|
||||
if (m_in != null)
|
||||
{
|
||||
try
|
||||
{
|
||||
m_in.close();
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
}
|
||||
m_in = null;
|
||||
}
|
||||
|
||||
// Close the output stream
|
||||
|
||||
if (m_out != null)
|
||||
{
|
||||
try
|
||||
{
|
||||
m_out.close();
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
}
|
||||
m_out = null;
|
||||
}
|
||||
|
||||
// Close the socket
|
||||
|
||||
if (m_socket != null)
|
||||
{
|
||||
try
|
||||
{
|
||||
m_socket.close();
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
}
|
||||
m_socket = null;
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user