2020-09-30 16:53:55 +02:00

179 lines
2.5 KiB
C++

/*++
Copyright (c) 2001 Microsoft Corporation
Module Name:
cmdchan.cpp
Abstract:
This module implements the Cmd console session class that
is used by sacsess.
Author:
Brian Guarraci (briangu), 2001
Revision History:
--*/
#include <emsapip.h>
#include <emsapi.h>
#include <ntddsac.h>
EMSCmdChannel::EMSCmdChannel(
VOID
)
/*++
Routine Description:
Constructor
Arguments:
None
Return Value:
N/A
--*/
{
NOTHING;
}
EMSCmdChannel::~EMSCmdChannel()
/*++
Routine Description:
Desctructor
Arguments:
N/A
Return Value:
N/A
--*/
{
NOTHING;
}
EMSCmdChannel*
EMSCmdChannel::Construct(
IN SAC_CHANNEL_OPEN_ATTRIBUTES ChannelAttributes
)
/*++
Routine Description:
Create a new channel object
Arguments:
EMSCmdChannelName - The name of the newly created channel
Return Value:
Status
TRUE --> pHandle is valid
--*/
{
EMSCmdChannel *Channel;
//
// Force the appropriate channel attributes
//
ChannelAttributes.Type = ChannelTypeCmd;
//
// Attempt to open the channel
//
Channel = (EMSCmdChannel*) EMSChannel::Construct(
ChannelAttributes
);
return Channel;
}
BOOL
EMSCmdChannel::Write(
IN PCBYTE Buffer,
IN ULONG BufferSize
)
/*++
Routine Description:
Write the given buffer to the specified SAC Channel
Arguments:
String - Unicode string to write
Return Value:
Status
TRUE --> the buffer was sent
--*/
{
return SacChannelRawWrite(
GetEMSChannelHandle(),
Buffer,
BufferSize
);
}
BOOL
EMSCmdChannel::Read(
OUT PBYTE Buffer,
IN ULONG BufferSize,
OUT PULONG ByteCount
)
/*++
Routine Description:
This routine reads data from the channel specified.
Arguments:
Buffer - destination buffer
BufferSize - size of the destination buffer (bytes)
ByteCount - the actual # of byte read
Return Value:
Status
TRUE --> the buffer was sent
--*/
{
return SacChannelRawRead(
GetEMSChannelHandle(),
Buffer,
BufferSize,
ByteCount
);
}