📄 slp_spi.h
字号:
/***************************************************************************//* *//* Project: OpenSLP - OpenSource implementation of Service Location *//* Protocol Version 2 *//* *//* File: slp_spi.h *//* *//* Abstract: Functions for fetching SPI information from the filesystem *//* Current implementation uses OpenSSL. For details see *//* (see http://www.openssl.org *//* *//*-------------------------------------------------------------------------*//* *//* 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_SPI_H_INCLUDED#define SLP_SPI_H_INCLUDED#include "slp_linkedlist.h"#include "slp_crypto.h"/*-------------------------------------------------------------------------*/typedef struct _SLPSpiEntry/*-------------------------------------------------------------------------*/{ SLPListItem listitem; int spistrlen; char* spistr; char* keyfilename; SLPCryptoDSAKey* key; int keytype;}SLPSpiEntry;/*-----------------*//* Key type values *//*-----------------*/#define SLPSPI_KEY_TYPE_ANY 0#define SLPSPI_KEY_TYPE_PUBLIC 1#define SLPSPI_KEY_TYPE_PRIVATE 2/*=========================================================================*/typedef struct _SLPSpiHandle/*=========================================================================*/{ char* spifile; int cacheprivate; SLPList cache;}* SLPSpiHandle;/*=========================================================================*/SLPSpiHandle SLPSpiOpen(const char* spifile, int cacheprivate);/* Initializes SLP SPI data storage. *//* *//* Parameters: spifile (IN) path of slp.spi file *//* cacheprivate (IN) should private keys be cached in handle *//* *//* Returns: valid pointer. NULL on failure *//*=========================================================================*//*=========================================================================*/void SLPSpiClose(SLPSpiHandle hspi);/* Release SLP SPI data storage associated with the specified SLPSpiHandle *//* *//* Parameters: hspi (IN) SLPSpiHandle to deinitialize *//*=========================================================================*//*=========================================================================*/SLPCryptoDSAKey* SLPSpiGetDSAKey(SLPSpiHandle hspi, int keytype, int spistrlen, const char* spistr, SLPCryptoDSAKey **key);/* Fetches a copy of the private key file used to sign SLP messages. *//* *//* Parameters: hspi (IN) handle obtained from call to SLPSpiOpen() *//* keytype (IN) the type of key desired *//* spistrlen (IN) the length of the spistr *//* spistr (IN) spistr associated with the key *//* key (OUT) the private key. Caller should use *//* SLPCryptoDSAKeyDestroy() to free key memory *//* *//* Returns: A valid pointer. NULL on failure. Caller should use *//* SLPCryptoDSAKeyDestroy() to free key memory */ /*=========================================================================*//*=========================================================================*/char* SLPSpiGetDefaultSPI(SLPSpiHandle hspi, int keytype, int* spistrlen, char** spistr);/* Gets a reference to the default SPI string for the specified keytype *//* *//* Parameters: hspi (IN) handle obtained from call to SLPSpiOpen() *//* keytype (IN) type of key *//* spistrlen (OUT) length or the returned spistr *//* spistr (OUT) pointer to spistr. MUST be freed by *//* caller!! *//* *//* Returns: Pointer to the default SPI string. Pointer may *not* be NULL *//* terminated *//*=========================================================================*//*=========================================================================*/int SLPSpiCanVerify(SLPSpiHandle hspi, int spistrlen, const char* spistr);/* Determine if we understand the specified SPI. No SPI is always *//* returns true *//* *//* Parameters: hspi (IN) handle obtained from call to SLPSpiOpen() *//* spistrlen (IN) the length of the spistr *//* spistr (IN) the SPI string *//* *//* Returns Non-zero if we verify specified the SPI *//*=========================================================================*//*=========================================================================*/int SLPSpiCanSign(SLPSpiHandle hspi, int spistrlen, const char* spistr);/* Determine if we understand the specified SPI. No SPI is always *//* return true *//* *//* Parameters: hspi (IN) handle obtained from call to SLPSpiOpen() *//* spistrlen (IN) the length of the spistr *//* spistr (IN) the SPI string *//* *//* Returns Non-zero if we sign using the specified SPI *//*=========================================================================*/#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -