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.
217 lines
13 KiB
217 lines
13 KiB
/***************************************************************************/
|
|
/* */
|
|
/* Project: OpenSLP - OpenSource implementation of Service Location */
|
|
/* Protocol */
|
|
/* */
|
|
/* File: slp_database.h */
|
|
/* */
|
|
/* Abstract: An SLP message database. The SLP message database holds */
|
|
/* actual SLP "wire" message buffers as well as structures */
|
|
/* that interpret the message buffer. The database exposes */
|
|
/* an interface suitable linked-list based implementation */
|
|
/* */
|
|
/*-------------------------------------------------------------------------*/
|
|
/* */
|
|
/* Please submit patches to http://www.openslp.org */
|
|
/* */
|
|
/*-------------------------------------------------------------------------*/
|
|
/* */
|
|
/* Copyright (C) 2000 Caldera Systems, Inc */
|
|
/* 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 of Caldera Systems 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 CALDERA */
|
|
/* SYSTEMS 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 SLP_DATABASE_H_INCLUDED
|
|
#define SLP_DATABASE_H_INCLUDED
|
|
|
|
#include "slp_message.h"
|
|
#include "slp_buffer.h"
|
|
#include "slp_linkedlist.h"
|
|
|
|
|
|
/*=========================================================================*/
|
|
typedef struct _SLPDatabaseEntry
|
|
/*=========================================================================*/
|
|
{
|
|
SLPListItem listitem;
|
|
SLPMessage msg;
|
|
SLPBuffer buf;
|
|
}SLPDatabaseEntry;
|
|
|
|
|
|
/*=========================================================================*/
|
|
typedef SLPList SLPDatabase;
|
|
/*=========================================================================*/
|
|
|
|
|
|
/*=========================================================================*/
|
|
typedef struct _SLPDatabaseHandle
|
|
/*=========================================================================*/
|
|
{
|
|
SLPDatabase* database;
|
|
SLPDatabaseEntry* current;
|
|
}*SLPDatabaseHandle;
|
|
|
|
|
|
/*=========================================================================*/
|
|
int SLPDatabaseInit(SLPDatabase* database);
|
|
/* Initialize a SLPDatabase. */
|
|
/* */
|
|
/* Parameters: database (IN) pointer to the database to initialize */
|
|
/* */
|
|
/* */
|
|
/* Returns: zero on success. Non-zero on error */
|
|
/*=========================================================================*/
|
|
|
|
|
|
/*=========================================================================*/
|
|
void SLPDatabaseDeinit(SLPDatabase* database);
|
|
/* Deinitialze a SLPDatabase */
|
|
/* */
|
|
/* Parameters: database (IN) pointer to the database to de-initialize */
|
|
/* */
|
|
/* Returns: none */
|
|
/*=========================================================================*/
|
|
|
|
|
|
/*=========================================================================*/
|
|
SLPDatabaseEntry* SLPDatabaseEntryCreate(SLPMessage msg,
|
|
SLPBuffer buf);
|
|
/* Create a SLPDatabaseEntry. */
|
|
/* */
|
|
/* Parameters: msg (IN) The interpreting message structure for buf */
|
|
/* buf (IN) The SLP message buffer */
|
|
/* */
|
|
/* Returns: Pointer to a new SLPDatabaseEntry. NULL if out of memory */
|
|
/* */
|
|
/* Note: VERY IMPORTANT. The msg and especially the buf are owned by the */
|
|
/* returned SLPDatabaseEntry and MUST NOT be freed by the caller */
|
|
/* via SLPMessageFree() or SLPBufferFree()! Instead, the caller */
|
|
/* should use SLPDatabaseEntryDestroy() only to free memory */
|
|
/*=========================================================================*/
|
|
|
|
/*=========================================================================*/
|
|
void SLPDatabaseEntryDestroy(SLPDatabaseEntry* entry);
|
|
/* Free resources associated with the specified entry */
|
|
/* */
|
|
/* Parameters: entry (IN) pointer to the entry to destroy */
|
|
/* */
|
|
/* Returns: none */
|
|
/*=========================================================================*/
|
|
|
|
|
|
/*=========================================================================*/
|
|
SLPDatabaseHandle SLPDatabaseOpen(SLPDatabase* database);
|
|
/* Open a handle that is used with subsequent calls to SLPDatabaseEnum(), */
|
|
/* SLPDatabaseAdd() and SLPDatabaseRemove() */
|
|
/* */
|
|
/* Parameters (IN) pointer an initialized SLPDatabase */
|
|
/* */
|
|
/* Returns: Valid handle. NULL on error. */
|
|
/* */
|
|
/* Note: It is important to make sure that handles returned by this */
|
|
/* function are used and closed as quickly as possible. Future */
|
|
/* may use handles to ensure syncronized access to the database */
|
|
/* in threaded environments */
|
|
/*=========================================================================*/
|
|
|
|
|
|
/*=========================================================================*/
|
|
SLPDatabaseEntry* SLPDatabaseEnum(SLPDatabaseHandle dh);
|
|
/* Used to enumerate through entries of a SLPDatabase */
|
|
/* */
|
|
/* Parameters: dh (IN) A handle obtained via SLPDatabaseOpen() */
|
|
/* */
|
|
/* Returns: Pointer to a SLPDatabase entry or NULL if end of enumeration */
|
|
/* has been reached. */
|
|
/*=========================================================================*/
|
|
|
|
|
|
/*=========================================================================*/
|
|
void SLPDatabaseRewind(SLPDatabaseHandle dh);
|
|
/* Reset handle so SLPDatabaseEnum starts at the beginning again */
|
|
/* */
|
|
/* Parameters: eh (IN) A handle obtained via SLPDatabaseOpen() */
|
|
/* */
|
|
/* Returns: None */
|
|
/*=========================================================================*/
|
|
|
|
|
|
/*=========================================================================*/
|
|
void SLPDatabaseClose(SLPDatabaseHandle dh);
|
|
/* Closes a handle obtained from SLPDatabaseOpen() */
|
|
/* */
|
|
/* Parameters: dh (IN) a handle obtained from SLPDatabaseOpenEnum() */
|
|
/* */
|
|
/* Returns: None */
|
|
/*=========================================================================*/
|
|
|
|
/*=========================================================================*/
|
|
void SLPDatabaseRemove(SLPDatabaseHandle dh,
|
|
SLPDatabaseEntry* entry);
|
|
/* Removes the specified entry */
|
|
/* */
|
|
/* Parameters: dh (IN) The SLPDatabaseEnumHandle used to obtain */
|
|
/* the entry in the first place */
|
|
/* entry (IN) The entry to remove */
|
|
/* */
|
|
/* Returns: None */
|
|
/* */
|
|
/* Note: During removal SLPDatabaseEntryDestroy() is called on entry. */
|
|
/* This means that you MUST NOT use entry after it is removed */
|
|
/*=========================================================================*/
|
|
|
|
|
|
/*=========================================================================*/
|
|
void SLPDatabaseAdd(SLPDatabaseHandle dh,
|
|
SLPDatabaseEntry* entry);
|
|
/* Add the specified entry */
|
|
/* */
|
|
/* Parameters: dh (IN) handle obtained from SLPDatabseOpen() */
|
|
/* entry (IN) the entry to add */
|
|
/* */
|
|
/* Return: None */
|
|
/* */
|
|
/* Note: DO NOT call SLPDatabaseEntryDestroy() on an entry that has been */
|
|
/* added to the database. Instead call SLPDatabaseDeinit() or */
|
|
/* SLPDatabaseRemove() to free resources associated with an added */
|
|
/* entry */
|
|
/*=========================================================================*/
|
|
|
|
|
|
/*=========================================================================*/
|
|
int SLPDatabaseCount(SLPDatabaseHandle dh);
|
|
/* Returns the number of entries that are in the database */
|
|
/*=========================================================================*/
|
|
|
|
|
|
#endif
|