/* Editor Settings: expandtabs and use 4 spaces for indentation
* ex: set softtabstop=4 tabstop=8 expandtab shiftwidth=4: *
* -*- mode: c, c-basic-offset: 4 -*- */
/*
* Copyright Likewise Software 2004-2008
* All rights reserved.
*
* This library is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation; either version 2.1 of the license, or (at
* your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser
* General Public License for more details. You should have received a copy
* of the GNU Lesser General Public License along with this program. If
* not, see .
*
* LIKEWISE SOFTWARE MAKES THIS SOFTWARE AVAILABLE UNDER OTHER LICENSING
* TERMS AS WELL. IF YOU HAVE ENTERED INTO A SEPARATE LICENSE AGREEMENT
* WITH LIKEWISE SOFTWARE, THEN YOU MAY ELECT TO USE THE SOFTWARE UNDER THE
* TERMS OF THAT SOFTWARE LICENSE AGREEMENT INSTEAD OF THE TERMS OF THE GNU
* LESSER GENERAL PUBLIC LICENSE, NOTWITHSTANDING THE ABOVE NOTICE. IF YOU
* HAVE QUESTIONS, OR WISH TO REQUEST A COPY OF THE ALTERNATE LICENSING
* TERMS OFFERED BY LIKEWISE SOFTWARE, PLEASE CONTACT LIKEWISE SOFTWARE AT
* license@likewisesoftware.com
*/
/*
* Copyright (C) Likewise Software. All rights reserved.
*
* Module Name:
*
* lwps-sid_p.h
*
* Abstract:
*
* Likewise Password Storage (LWPS)
*
* Security Identifier API
*
* Authors: Krishna Ganugapati (krishnag@likewisesoftware.com)
* Sriram Nambakam (snambakam@likewisesoftware.com)
* Brian Dunstan (bdunstan@likewisesoftware.com)
*
*/
#ifndef __LWPS_SID_P_H__
#define __LWPS_SID_P_H__
#define SECURITY_IDENTIFIER_HEADER_SIZE 8
#define SECURITY_IDENTIFIER_MINIMUM_SIZE ((SECURITY_IDENTIFIER_HEADER_SIZE) + (sizeof(DWORD)))
typedef enum {
PARSE_MODE_OPEN = 0,
PARSE_MODE_REVISION,
PARSE_MODE_AUTHORITY,
PARSE_MODE_TAIL,
PARSE_SENTINEL
} SecurityIdentifierParseState;
DWORD
HexCharToByte(
CHAR cHexChar,
UCHAR* pucByte
);
//format of string representation of SID in LWPS_SID:
//S----
//example: S-1-5-32-546 (Guests)
//See http://support.microsoft.com/kb/243330
//In binary format,
//the fields are encoded as unsigned integers of varying lenths and endianness:
//: 1-byte, big-endian
//: 1-byte, big-endian
//: a 6-byte, big-endian number containing the number of subsequent 4-byte, little endian, unsigned integers
//: a sequence of 4-byte, little-endian unsigned integers
//: 4-byte, little-endian, unsigned integer
//So for example, if your SID is S-1-5-21-2127521184-1604012920-1887927527-72713,
//then your raw hex SID is
// 01 05 000000000005 15000000 A065CF7E 784B9B5F E77C8770 091C0100
//This breaks down as follows:
// 01 S-1
// 05 (seven dashes, seven minus two = 5)
// 000000000005 (5 = 0x000000000005, written as big-endian) 6 bytes
// 15000000 (21 = 0x00000015, written as big-endian) 4 bytes
// A065CF7E (2127521184 = 0x7ECF65A0, written as big-endian) 4 bytes
// 784B9B5F (1604012920 = 0x5F9B4B78, written as big-endian) 4 bytes
// E77C8770 (1887927527 = 0X70877CE7, written as big-endian) 4 bytes
// 091C0100 (72713 = 0x00011c09, written as big-endian)
//This will calculate a hash of the last three RID's (if they exist) and the low 19
//bits of the RID
void
LwpsUidHashCalc(
PDWORD pdwAuthorities,
DWORD dwAuthorityCount,
PDWORD pdwHash
);
DWORD
LwpsStringToBytes(
PCSTR pszSidString,
UCHAR** ppucSidbytes,
DWORD* pdwSidBytesLength
);
DWORD
LwpsSidBytesToString(
UCHAR* pucSidBytes,
DWORD dwSidBytesLength,
PSTR* pszSidString
);
DWORD
LwpsBuildSIDString(
PCSTR pszRevision,
PCSTR pszAuth,
PBYTE pucSidBytes,
DWORD dwWordCount,
PSTR* ppszSidString
);
#endif /* __LWPS_SID_P_H__ */