You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
443 lines
9.0 KiB
443 lines
9.0 KiB
//+---------------------------------------------------------------------------
|
|
//
|
|
// Microsoft Windows
|
|
// Copyright (C) Microsoft Corporation, 1992 - 1997.
|
|
//
|
|
// File: odssz.cxx
|
|
//
|
|
// Contents: DSObject Size Routines
|
|
//
|
|
// Functions:
|
|
//
|
|
// History: 25-Feb-97 KrishnaG Created.
|
|
//
|
|
//----------------------------------------------------------------------------
|
|
#include "ldapc.hxx"
|
|
|
|
DWORD
|
|
AdsTypeDNStringSize(
|
|
PADSVALUE lpAdsSrcValue
|
|
)
|
|
{
|
|
DWORD dwSize = 0;
|
|
|
|
if(lpAdsSrcValue->dwType != ADSTYPE_DN_STRING){
|
|
return(0);
|
|
}
|
|
|
|
//
|
|
// strings must be WCHAR (WORD) aligned
|
|
//
|
|
dwSize = (wcslen(lpAdsSrcValue->DNString) + 1)*sizeof(WCHAR) +
|
|
(ALIGN_WORD-1);
|
|
|
|
return(dwSize);
|
|
}
|
|
|
|
DWORD
|
|
AdsTypeCaseExactStringSize(
|
|
PADSVALUE lpAdsSrcValue
|
|
)
|
|
{
|
|
DWORD dwSize = 0;
|
|
|
|
if(lpAdsSrcValue->dwType != ADSTYPE_CASE_EXACT_STRING){
|
|
return(0);
|
|
}
|
|
|
|
//
|
|
// strings must be WCHAR (WORD) aligned
|
|
//
|
|
dwSize = (wcslen(lpAdsSrcValue->CaseExactString) + 1) *sizeof(WCHAR) +
|
|
(ALIGN_WORD-1);
|
|
|
|
return(dwSize);
|
|
}
|
|
|
|
|
|
DWORD
|
|
AdsTypeCaseIgnoreStringSize(
|
|
PADSVALUE lpAdsSrcValue
|
|
)
|
|
|
|
{
|
|
DWORD dwSize = 0;
|
|
|
|
if(lpAdsSrcValue->dwType != ADSTYPE_CASE_IGNORE_STRING){
|
|
return(0);
|
|
}
|
|
|
|
//
|
|
// strings must be WCHAR (WORD) aligned
|
|
//
|
|
dwSize = (wcslen(lpAdsSrcValue->CaseIgnoreString) + 1) *sizeof(WCHAR) +
|
|
(ALIGN_WORD-1);
|
|
|
|
return(dwSize);
|
|
}
|
|
|
|
|
|
DWORD
|
|
AdsTypePrintableStringSize(
|
|
PADSVALUE lpAdsSrcValue
|
|
)
|
|
{
|
|
DWORD dwSize = 0;
|
|
|
|
if(lpAdsSrcValue->dwType != ADSTYPE_PRINTABLE_STRING){
|
|
return(0);
|
|
}
|
|
|
|
//
|
|
// strings must be WCHAR (WORD) aligned
|
|
//
|
|
dwSize = (wcslen(lpAdsSrcValue->PrintableString) + 1) *sizeof(WCHAR) +
|
|
(ALIGN_WORD-1);
|
|
|
|
return(dwSize);
|
|
}
|
|
|
|
DWORD
|
|
AdsTypeNumericStringSize(
|
|
PADSVALUE lpAdsSrcValue
|
|
)
|
|
{
|
|
|
|
DWORD dwSize = 0;
|
|
|
|
if(lpAdsSrcValue->dwType != ADSTYPE_NUMERIC_STRING){
|
|
return(0);
|
|
}
|
|
|
|
//
|
|
// strings must be WCHAR (WORD) aligned
|
|
//
|
|
dwSize = (wcslen(lpAdsSrcValue->NumericString) + 1)* sizeof(WCHAR) +
|
|
(ALIGN_WORD-1);
|
|
|
|
return(dwSize);
|
|
}
|
|
|
|
|
|
|
|
DWORD
|
|
AdsTypeBooleanSize(
|
|
PADSVALUE lpAdsSrcValue
|
|
)
|
|
{
|
|
if(lpAdsSrcValue->dwType != ADSTYPE_BOOLEAN){
|
|
return(0);
|
|
}
|
|
|
|
return(0);
|
|
}
|
|
|
|
|
|
DWORD
|
|
AdsTypeIntegerSize(
|
|
PADSVALUE lpAdsSrcValue
|
|
)
|
|
{
|
|
|
|
if(lpAdsSrcValue->dwType != ADSTYPE_INTEGER){
|
|
return(0);
|
|
}
|
|
|
|
return(0);
|
|
}
|
|
|
|
DWORD
|
|
AdsTypeOctetStringSize(
|
|
PADSVALUE lpAdsSrcValue
|
|
)
|
|
{
|
|
DWORD dwNumBytes = 0;
|
|
|
|
if(lpAdsSrcValue->dwType != ADSTYPE_OCTET_STRING){
|
|
return(0);
|
|
}
|
|
|
|
//
|
|
// Add bytes to the size as we need to align all the
|
|
// OctetStrings on at least 8 byte boundaries. We'll
|
|
// worst-case align to be conservative for IA64.
|
|
// ALIGN_WORST is defined in priv inc which also defines
|
|
// the ROUND_UP macro used.
|
|
//
|
|
dwNumBytes = lpAdsSrcValue->OctetString.dwLength + ALIGN_WORST - 1;
|
|
|
|
return(dwNumBytes);
|
|
}
|
|
|
|
|
|
DWORD
|
|
AdsTypeSecurityDescriptorSize(
|
|
PADSVALUE lpAdsSrcValue
|
|
)
|
|
{
|
|
DWORD dwNumBytes = 0;
|
|
|
|
if(lpAdsSrcValue->dwType != ADSTYPE_NT_SECURITY_DESCRIPTOR){
|
|
return(0);
|
|
}
|
|
|
|
//
|
|
// Security Descriptors need to be DWORD aligned but we
|
|
// provide worst case alignment as C structs have 8 bytes alignment
|
|
// (at least on x86).
|
|
// ALIGN_WORST defined in align.h in priv inc, which also
|
|
// has the round up macro used.
|
|
//
|
|
dwNumBytes = lpAdsSrcValue->SecurityDescriptor.dwLength + ALIGN_WORST - 1;
|
|
|
|
return(dwNumBytes);
|
|
}
|
|
|
|
|
|
DWORD
|
|
AdsTypeTimeSize(
|
|
PADSVALUE lpAdsSrcValue
|
|
)
|
|
{
|
|
if(lpAdsSrcValue->dwType != ADSTYPE_UTC_TIME){
|
|
return(0);
|
|
}
|
|
|
|
return(0);
|
|
}
|
|
|
|
DWORD
|
|
AdsTypeLargeIntegerSize(
|
|
PADSVALUE lpAdsSrcValue
|
|
)
|
|
{
|
|
|
|
if(lpAdsSrcValue->dwType != ADSTYPE_LARGE_INTEGER){
|
|
return(0);
|
|
}
|
|
|
|
return(0);
|
|
}
|
|
|
|
DWORD
|
|
AdsTypeProvSpecificSize(
|
|
PADSVALUE lpAdsSrcValue
|
|
)
|
|
{
|
|
DWORD dwNumBytes = 0;
|
|
|
|
if(lpAdsSrcValue->dwType != ADSTYPE_PROV_SPECIFIC){
|
|
return(0);
|
|
}
|
|
|
|
//
|
|
// We don't know what it contains, so assume worst-case alignment
|
|
//
|
|
dwNumBytes = lpAdsSrcValue->ProviderSpecific.dwLength + (ALIGN_WORST-1);
|
|
|
|
return(dwNumBytes);
|
|
}
|
|
|
|
|
|
//
|
|
// Computes size of the data in the DNWithBinary object
|
|
//
|
|
DWORD
|
|
AdsTypeDNWithBinarySize(
|
|
PADSVALUE lpAdsSrcValue
|
|
)
|
|
{
|
|
DWORD dwSize = 0;
|
|
DWORD dwStrLen = 0;
|
|
|
|
if (lpAdsSrcValue->dwType != ADSTYPE_DN_WITH_BINARY) {
|
|
return 0;
|
|
}
|
|
|
|
if (!lpAdsSrcValue->pDNWithBinary) {
|
|
return(0);
|
|
}
|
|
|
|
//
|
|
// The length is EncodedBinLen+dnlen+:+:+:+B+10 (for int len)
|
|
//
|
|
|
|
if (lpAdsSrcValue->pDNWithBinary->pszDNString) {
|
|
dwStrLen = (wcslen(lpAdsSrcValue->pDNWithBinary->pszDNString)+1);
|
|
|
|
//
|
|
// strings must be WCHAR (WORD) aligned
|
|
//
|
|
dwSize += dwStrLen * sizeof(WCHAR) + (ALIGN_WORD-1);
|
|
|
|
}
|
|
|
|
//
|
|
// Each byte is 2 wchars in the final string
|
|
//
|
|
if (lpAdsSrcValue->pDNWithBinary->dwLength) {
|
|
dwSize += (lpAdsSrcValue->pDNWithBinary->dwLength);
|
|
//
|
|
// our cushion when reading from string encoded binary value
|
|
// to byte array and one WCHAR for \0 of string
|
|
//
|
|
// worst-case align the binary data, since we don't know
|
|
// how it will be accessed
|
|
//
|
|
dwSize += sizeof(DWORD) + sizeof(WCHAR) + (ALIGN_WORST-1);
|
|
}
|
|
|
|
//
|
|
// provide worst-case alignment of the structure
|
|
//
|
|
dwSize += sizeof(ADS_DN_WITH_BINARY) + (ALIGN_WORST-1);
|
|
return dwSize;
|
|
}
|
|
|
|
//
|
|
// Computes size of the data in the DNWithString object.
|
|
//
|
|
DWORD
|
|
AdsTypeDNWithStringSize(
|
|
PADSVALUE pAdsSrcValue
|
|
)
|
|
{
|
|
DWORD dwSize = 0;
|
|
DWORD dwStrLen = 0;
|
|
|
|
if (pAdsSrcValue->dwType != ADSTYPE_DN_WITH_STRING) {
|
|
return 0;
|
|
}
|
|
|
|
if (!pAdsSrcValue->pDNWithString) {
|
|
return(0);
|
|
}
|
|
|
|
//
|
|
// align the strings on WCHAR (WORD) boundaries
|
|
// provide worst-case alignment for the structure
|
|
//
|
|
if (pAdsSrcValue->pDNWithString->pszDNString) {
|
|
dwStrLen = wcslen(pAdsSrcValue->pDNWithString->pszDNString) + 1;
|
|
dwSize += dwStrLen * sizeof(WCHAR) + (ALIGN_WORD-1);
|
|
}
|
|
|
|
if (pAdsSrcValue->pDNWithString->pszStringValue) {
|
|
dwStrLen = wcslen(pAdsSrcValue->pDNWithString->pszStringValue) + 1;
|
|
dwSize += dwStrLen * sizeof(WCHAR) + (ALIGN_WORD-1);
|
|
}
|
|
|
|
//
|
|
// Now for the strcut itself.
|
|
//
|
|
|
|
dwSize += sizeof(ADS_DN_WITH_STRING) + (ALIGN_WORST-1);
|
|
|
|
return dwSize;
|
|
}
|
|
|
|
|
|
DWORD
|
|
AdsTypeSize(
|
|
PADSVALUE lpAdsSrcValue
|
|
)
|
|
{
|
|
|
|
DWORD dwSize = 0;
|
|
|
|
switch (lpAdsSrcValue->dwType){
|
|
|
|
case ADSTYPE_DN_STRING:
|
|
dwSize = AdsTypeDNStringSize(
|
|
lpAdsSrcValue
|
|
);
|
|
break;
|
|
|
|
case ADSTYPE_CASE_EXACT_STRING:
|
|
dwSize = AdsTypeCaseExactStringSize(
|
|
lpAdsSrcValue
|
|
);
|
|
break;
|
|
|
|
|
|
case ADSTYPE_CASE_IGNORE_STRING:
|
|
dwSize = AdsTypeCaseIgnoreStringSize(
|
|
lpAdsSrcValue
|
|
);
|
|
break;
|
|
|
|
case ADSTYPE_PRINTABLE_STRING:
|
|
dwSize = AdsTypePrintableStringSize(
|
|
lpAdsSrcValue
|
|
);
|
|
break;
|
|
|
|
case ADSTYPE_NUMERIC_STRING:
|
|
dwSize = AdsTypeNumericStringSize(
|
|
lpAdsSrcValue
|
|
);
|
|
break;
|
|
|
|
|
|
case ADSTYPE_BOOLEAN:
|
|
dwSize = AdsTypeBooleanSize(
|
|
lpAdsSrcValue
|
|
);
|
|
break;
|
|
|
|
case ADSTYPE_INTEGER:
|
|
dwSize = AdsTypeIntegerSize(
|
|
lpAdsSrcValue
|
|
);
|
|
break;
|
|
|
|
|
|
case ADSTYPE_OCTET_STRING:
|
|
dwSize = AdsTypeOctetStringSize(
|
|
lpAdsSrcValue
|
|
);
|
|
break;
|
|
|
|
case ADSTYPE_UTC_TIME:
|
|
dwSize = AdsTypeTimeSize(
|
|
lpAdsSrcValue
|
|
);
|
|
break;
|
|
|
|
case ADSTYPE_LARGE_INTEGER:
|
|
dwSize = AdsTypeLargeIntegerSize(
|
|
lpAdsSrcValue
|
|
);
|
|
break;
|
|
|
|
case ADSTYPE_PROV_SPECIFIC:
|
|
dwSize = AdsTypeProvSpecificSize(
|
|
lpAdsSrcValue
|
|
);
|
|
break;
|
|
|
|
case ADSTYPE_NT_SECURITY_DESCRIPTOR:
|
|
dwSize = AdsTypeSecurityDescriptorSize(
|
|
lpAdsSrcValue
|
|
);
|
|
break;
|
|
|
|
case ADSTYPE_DN_WITH_BINARY:
|
|
dwSize = AdsTypeDNWithBinarySize(
|
|
lpAdsSrcValue
|
|
);
|
|
break;
|
|
|
|
case ADSTYPE_DN_WITH_STRING:
|
|
dwSize = AdsTypeDNWithStringSize(
|
|
lpAdsSrcValue
|
|
);
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return(dwSize);
|
|
}
|
|
|