C++程序  |  156行  |  4.97 KB

/**
 * Copyright(c) 2012 Trusted Logic.   All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *
 *  * Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 *  * Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in
 *    the documentation and/or other materials provided with the
 *    distribution.
 *  * Neither the name Trusted Logic nor the names of its
 *    contributors may be used to endorse or promote products derived
 *    from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

#ifndef __LIB_UUID_H__
#define __LIB_UUID_H__


#include "s_type.h"


#ifdef __cplusplus
extern "C" {
#endif
#if 0
}  /* balance curly quotes */
#endif

/**
 * LIB_UUID is deprecated use S_UUID instead.
 * @deprecated
 */
typedef S_UUID LIB_UUID;
/**
 * LIB_UUID_STRING_SIZE is deprecated use UUID_STRING_SIZE instead.
 * @deprecated
 */
#define LIB_UUID_STRING_SIZE  36

/**
 * Defines the UUID string size in characters
 *
 * E.g. "f81d4fae-7dec-11d0-a765-00a0c91e6bf6"
 **/
#define UUID_STRING_SIZE  36

/**
 * Converts the string representation of an UUID to the binary representation as
 * a S_UUID type. The binary UUID structure must be provided by the caller.
 *
 * @param   pIdentifierString  The UTF-8 representation of the identifier. This
 *          string does not need to be zero terminated. The decoder reads only
 *          the {UUID_STRING_SIZE} first bytes.
 *
 * @param   pIdentifier  The identifer structure receiving the binary value of
 *          the identifier.
 *
 * @return  TRUE in case of success, FALSE if the string does not conform to the
 *          syntax of UUID as defined in RFC 4122
 *          (http://www.ietf.org/rfc/rfc4122.txt)
 **/
bool libUUIDFromString(
      IN  const uint8_t* pIdentifierString,
      OUT S_UUID* pIdentifier);

/**
 * Converts the binary representation of an UUID to the string representation.
 *
 * @param   pIdentifier  The identifer structure with the binary value of the
 *          identifier.
 *
 * @param   pIdentifierString  The buffer receiving the UTF-8 representation of
 *          the identifier. This string is not zero terminated. The encoder
 *          writes only the first {UUID_STRING_SIZE} bytes.
 *
 **/
void libUUIDToString(
      IN  const S_UUID* pIdentifier,
      OUT uint8_t* pIdentifierString);

/**
 * Generates an UUID from the specified MD5 hash value, as specified in section
 * 4.3, Algorithm for Creating a Name-Based UUID, of RFC 4122.
 *
 * This function assumes that the hash value is 128-bit long.
 *
 * @param pHashData A pointer to the first byte of the MD5 hash data. Only the
 * first 16 bytes of this hash data will be used to generate the UUID.
 *
 * @param pIdentifier A pointer to the placeholder receiving the generated
 * identifier.
 **/
void libUUIDFromMD5Hash(
      IN  const uint8_t* pHashData,
      OUT S_UUID* pIdentifier);

/**
 * Generates an UUID from the specified SHA-1 hash value, as specified in
 * section 4.3, Algorithm for Creating a Name-Based UUID, of RFC 4122.
 *
 * This function assumes that the hash value is 128-bit long.
 *
 * @param pHashData A pointer to the first byte of the SHA-1 hash data. Only the
 * first 16 bytes of this hash data will be used to generate the UUID.
 *
 * @param pIdentifier A pointer to the placeholder receiving the generated
 * identifier.
 **/
void libUUIDFromSHA1Hash(
      IN  const uint8_t* pHashData,
      OUT S_UUID* pIdentifier);

/**
 * Checks if an identifier is the nil identifier as specified in RFC 4122.
 *
 * @param   pIdentifier  The identifier to check.
 *
 * @return  TRUE if the identifier is the nil identifier, FALSE otherwise.
 **/
bool libUUIDIsNil(
      IN  const S_UUID* pIdentifier);

/**
 * Sets an identifier to the nil value as specified in RFC 4122.
 *
 * @param   pIdentifier  The identifier to set to nil.
 **/
void libUUIDSetToNil(
      OUT S_UUID* pIdentifier);

#if 0
{  /* balance curly quotes */
#endif
#ifdef __cplusplus
}  /* closes extern "C" */
#endif


#endif  /* !defined(__LIB_UUID_H__) */