📄 idrawfunctions.pas
字号:
{ $HDR$}
{**********************************************************************}
{ Unit archived using Team Coherence }
{ Team Coherence is Copyright 2002 by Quality Software Components }
{ }
{ For further information / comments, visit our WEB site at }
{ http://www.TeamCoherence.com }
{**********************************************************************}
{}
{ $Log: 10293: IdRawFunctions.pas
{
{ Rev 1.0 2002.11.12 10:49:30 PM czhower
}
unit IdRawFunctions;
interface
uses
IdStack, IdRawHeaders;
// ARP
function IdRawBuildArp(AHwAddressFormat, AProtocolFormat: word; AHwAddressLen, AProtocolLen: byte;
AnOpType: word; ASenderHw: TIdEtherAddr; ASenderPr: TIdInAddr; ATargetHw: TIdEtherAddr; ATargetPr: TIdInAddr;
const APayload; APayloadSize: integer; var ABuffer): boolean;
// DNS
function IdRawBuildDns(AnId, AFlags, ANumQuestions, ANumAnswerRecs, ANumAuthRecs, ANumAddRecs: word;
const APayload; APayloadSize: integer; var ABuffer): boolean;
// Ethernet
function IdRawBuildEthernet(ADest, ASource: TIdEtherAddr; AType: word;
const APayload; APayloadSize: integer; var ABuffer): boolean;
// ICMP
function IdRawBuildIcmpEcho(AType, ACode: byte; AnId, ASeq: word;
const APayload; APayloadSize: integer; var ABuffer): boolean;
function IdRawBuildIcmpMask(AType, ACode: byte; AnId, ASeq: word; AMask: longword;
const APayload; APayloadSize: integer; var ABuffer): boolean;
function IdRawBuildIcmpRedirect(AType, ACode: byte; AGateway: TIdInAddr;
AnOrigLen: word; AnOrigTos: byte; AnOrigId, AnOrigFrag: word; AnOrigTtl, AnOrigProtocol: byte;
AnOrigSource, AnOrigDest: TIdInAddr; const AnOrigPayload; APayloadSize: integer; var ABuffer): boolean;
function IdRawBuildIcmpTimeExceed(AType, ACode: byte; AnOrigLen: word; AnOrigTos: byte;
AnOrigId, AnOrigFrag: word; AnOrigTtl: byte; AnOrigProtocol: byte;
AnOrigSource, AnOrigDest: TIdInAddr; const AnOrigPayload; APayloadSize: integer; var ABuffer): boolean;
function IdRawBuildIcmpTimestamp(AType, ACode: byte; AnId, ASeq: word;
AnOtime, AnRtime, ATtime: TIdNetTime; const APayload; APayloadSize: integer; var ABuffer): boolean;
function IdRawBuildIcmpUnreach(AType, ACode: byte; AnOrigLen: word;
AnOrigTos: byte; AnOrigId, AnOrigFrag: word; AnOrigTtl, AnOrigProtocol: byte;
AnOrigSource, AnOrigDest: TIdInAddr; const AnOrigPayload, APayloadSize: integer; var ABuffer): boolean;
// IGMP
function IdRawBuildIgmp(AType, ACode: byte; AnIp: TIdInAddr;
const APayload, APayloadSize: integer; var ABuffer): boolean;
// IP
function IdRawBuildIp(ALen: word; ATos: byte; AnId, AFrag: word; ATtl, AProtocol: byte;
ASource, ADest: TIdInAddr; const APayload; APayloadSize: integer; var ABuffer): boolean;
// RIP
function IdRawBuildRip(ACommand, AVersion: byte; ARoutingDomain, AnAddressFamily,
ARoutingTag: word; AnAddr, AMask, ANextHop, AMetric: longword;
const APayload; APayloadSize: integer; var ABuffer): boolean;
// TCP
function IdRawBuildTcp(ASourcePort, ADestPort: word; ASeq, AnAck: longword;
AControl: byte; AWindowSize, AnUrgent: word;
const APayload, APayloadSize: integer; var ABuffer): boolean;
// UDP
function IdRawBuildUdp(ASourcePort, ADestPort: word; const APayload;
APayloadSize: integer; var ABuffer): boolean;
implementation
// TODO: is it okay to call GStack?
function IdRawBuildArp(AHwAddressFormat, AProtocolFormat: word; AHwAddressLen, AProtocolLen: byte;
AnOpType: word; ASenderHw: TIdEtherAddr; ASenderPr: TIdInAddr; ATargetHw: TIdEtherAddr; ATargetPr: TIdInAddr;
const APayload; APayloadSize: integer; var ABuffer): boolean;
var
HdrArp: TIdArpHdr;
begin
// init result
Result := FALSE;
// check input
if (@ABuffer = nil) then
Exit;
// construct header
HdrArp.arp_hrd := GStack.WSHToNS(AHwAddressFormat);
HdrArp.arp_pro := GStack.WSHToNS(AProtocolFormat);
HdrArp.arp_hln := AHwAddressLen;
HdrArp.arp_pln := AProtocolLen;
HdrArp.arp_op := GStack.WSHToNS(AnOpType);
Move(ASenderHw, HdrArp.arp_sha, AHwAddressLen);
Move(ASenderPr, HdrArp.arp_spa, AProtocolLen);
Move(ATargetHw, HdrArp.arp_tha, AHwAddressLen);
Move(ATargetPr, HdrArp.arp_tpa, AProtocolLen);
// copy payload
if ((@APayload <> nil) and (APayloadSize > 0)) then
Move(APayload, pointer(integer(@ABuffer) + Id_ARP_HSIZE)^, APayloadSize);
// copy header
Move(HdrArp, ABuffer, sizeof(HdrArp));
Result := TRUE;
end;
function IdRawBuildDns(AnId, AFlags, ANumQuestions, ANumAnswerRecs, ANumAuthRecs, ANumAddRecs: word;
const APayload; APayloadSize: integer; var ABuffer): boolean;
var
HdrDns: TIdDnsHdr;
begin
// init result
Result := FALSE;
// check input
if (@ABuffer = nil) then
Exit;
// construct header
HdrDns.dns_id := GStack.WSHToNS(AnId);
HdrDns.dns_flags := GStack.WSHToNS(AFlags);
HdrDns.dns_num_q := GStack.WSHToNS(ANumQuestions);
HdrDns.dns_num_answ_rr := GStack.WSHToNS(ANumAnswerRecs);
HdrDns.dns_num_auth_rr := GStack.WSHToNS(ANumAuthRecs);
HdrDns.dns_num_addi_rr := GStack.WSHToNS(ANumAddRecs);
// copy payload
if ((@APayload <> nil) and (APayloadSize > 0)) then
Move(APayload, pointer(integer(@ABuffer) + Id_DNS_HSIZE)^, APayloadSize);
// copy header
Move(HdrDns, ABuffer, sizeof(HdrDns));
Result := TRUE;
end;
function IdRawBuildEthernet(ADest, ASource: TIdEtherAddr; AType: word;
const APayload; APayloadSize: integer; var ABuffer): boolean;
var
HdrEth: TIdEthernetHdr;
begin
// init result
Result := FALSE;
// check input
if (@ABuffer = nil) then
Exit;
// construct header
Move(ADest, HdrEth.ether_dhost, Id_ETHER_ADDR_LEN);
Move(ASource, HdrEth.ether_shost, Id_ETHER_ADDR_LEN);
HdrEth.ether_type := GStack.WSHToNS(AType);
// copy payload
if ((@APayload <> nil) and (APayloadSize > 0)) then
Move(APayload, pointer(integer(@ABuffer) + Id_ETH_HSIZE)^, APayloadSize);
// copy header
Move(HdrEth, ABuffer, sizeof(HdrEth));
Result := TRUE;
end;
// TODO: check nibbles in IP header
function IdRawBuildIp(ALen: word; ATos: byte; AnId, AFrag: word; ATtl, AProtocol: byte;
ASource, ADest: TIdInAddr; const APayload; APayloadSize: integer; var ABuffer): boolean;
var
HdrIp: TIdIpHdr;
begin
// init result
Result := FALSE;
// check input
if (@ABuffer = nil) then
Exit;
// construct header
HdrIp.ip_verlen := (4 shl 4) + (Id_IP_HSIZE div 4); // IPv4 shl 4, 20 bytes div 4
HdrIp.ip_tos := ATos;
HdrIp.ip_len := GStack.WSHToNs(Id_IP_HSIZE + ALen);
HdrIp.ip_id := GStack.WSHToNs(AnId);
HdrIp.ip_off := GStack.WSHToNs(AFrag);
HdrIp.ip_ttl := ATtl;
HdrIp.ip_p := AProtocol;
HdrIp.ip_sum := 0; // do checksum later
HdrIp.ip_src := ASource;
HdrIp.ip_dst := ADest;
// copy payload
if ((@APayload <> nil) and (APayloadSize > 0)) then
Move(APayload, pointer(integer(@ABuffer) + Id_IP_HSIZE)^, APayloadSize);
// copy header
Move(HdrIp, ABuffer, Id_IP_HSIZE);
Result := TRUE;
end;
function IdRawBuildIcmpEcho(AType, ACode: byte; AnId, ASeq: word;
const APayload; APayloadSize: integer; var ABuffer): boolean;
var
HdrIcmp: TIdIcmpHdr;
begin
// init result
Result := FALSE;
// check input
if (@ABuffer = nil) then
Exit;
// construct header
HdrIcmp.icmp_type := AType;
HdrIcmp.icmp_code := ACode;
HdrIcmp.icmp_hun.echo.id := GStack.WSHToNs(AnId);
HdrIcmp.icmp_hun.echo.seq := GStack.WSHToNs(ASeq);
// copy payload
if ((@APayload <> nil) and (APayloadSize > 0)) then
Move(APayload, pointer(integer(@ABuffer) + Id_ICMP_ECHO_HSIZE)^, APayloadSize);
// copy header
Move(HdrIcmp, ABuffer, Id_ICMP_ECHO_HSIZE);
Result := TRUE;
end;
function IdRawBuildIcmpMask(AType, ACode: byte; AnId, ASeq: word; AMask: longword;
const APayload; APayloadSize: integer; var ABuffer): boolean;
var
HdrIcmp: TIdIcmpHdr;
begin
// init result
Result := FALSE;
// check input
if (@ABuffer = nil) then
Exit;
// construct header
HdrIcmp.icmp_type := AType;
HdrIcmp.icmp_code := ACode;
HdrIcmp.icmp_hun.echo.id := GStack.WSHToNs(AnId);
HdrIcmp.icmp_hun.echo.seq := GStack.WSHToNs(ASeq);
HdrIcmp.icmp_dun.mask := GStack.WSHToNL(AMask);
// copy payload
if ((@APayload <> nil) and (APayloadSize > 0)) then
Move(APayload, pointer(integer(@ABuffer) + Id_ICMP_MASK_HSIZE)^, APayloadSize);
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -