2007-05-25 17:02:12 +02:00
|
|
|
/*******************************************************************************
|
|
|
|
*
|
|
|
|
* Copyright (c) 2000-2003 Intel Corporation
|
|
|
|
* 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 name of Intel Corporation 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 INTEL 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.
|
|
|
|
*
|
|
|
|
******************************************************************************/
|
2006-06-06 10:51:22 +02:00
|
|
|
|
|
|
|
|
|
|
|
#ifndef UPNP_TOOLS_H
|
|
|
|
#define UPNP_TOOLS_H
|
|
|
|
|
2008-06-02 05:43:25 +02:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* \file
|
|
|
|
*
|
2008-06-04 05:48:50 +02:00
|
|
|
* \defgroup UPnPTools Optional Tool API
|
2008-06-02 05:43:25 +02:00
|
|
|
*
|
2008-06-04 05:48:50 +02:00
|
|
|
* \brief Additional, optional utility API that can be helpful in writing
|
|
|
|
* applications.
|
|
|
|
*
|
|
|
|
* This additional API can be compiled out in order to save code size in the
|
|
|
|
* library. Refer to the file README for details.
|
2008-06-02 05:43:25 +02:00
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2008-06-10 05:23:08 +02:00
|
|
|
#include "ixml.h" /* for IXML_Document */
|
2011-10-20 13:27:55 +02:00
|
|
|
#include "upnpconfig.h" /* for UPNP_HAVE_TOOLS */
|
2008-06-10 05:23:08 +02:00
|
|
|
|
2006-06-06 10:51:22 +02:00
|
|
|
|
2007-05-25 17:02:12 +02:00
|
|
|
/* Function declarations only if tools compiled into the library */
|
2006-06-06 10:51:22 +02:00
|
|
|
#if UPNP_HAVE_TOOLS
|
|
|
|
|
2008-06-02 05:43:25 +02:00
|
|
|
|
2006-06-06 10:51:22 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2008-06-02 05:43:25 +02:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Converts an SDK error code into a string error message suitable for
|
|
|
|
* display. The memory returned from this function should NOT be freed.
|
2006-06-06 10:51:22 +02:00
|
|
|
*
|
2008-06-02 05:43:25 +02:00
|
|
|
* \return An ASCII text string representation of the error message associated
|
|
|
|
* with the error code or the string "Unknown error code"
|
|
|
|
*/
|
|
|
|
EXPORT_SPEC const char *UpnpGetErrorMessage(
|
|
|
|
/*! [in] The SDK error code to convert. */
|
|
|
|
int errorcode);
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Combines a base URL and a relative URL into a single absolute URL.
|
|
|
|
*
|
|
|
|
* The memory for \b AbsURL needs to be allocated by the caller and must
|
|
|
|
* be large enough to hold the \b BaseURL and \b RelURL combined.
|
|
|
|
*
|
|
|
|
* \return An integer representing one of the following:
|
|
|
|
* \li <tt>UPNP_E_SUCCESS</tt>: The operation completed successfully.
|
|
|
|
* \li <tt>UPNP_E_INVALID_PARAM</tt>: \b RelURL is <tt>NULL</tt>.
|
|
|
|
* \li <tt>UPNP_E_INVALID_URL</tt>: The \b BaseURL / \b RelURL
|
2006-06-06 10:51:22 +02:00
|
|
|
* combination does not form a valid URL.
|
2008-06-02 05:43:25 +02:00
|
|
|
* \li <tt>UPNP_E_OUTOF_MEMORY</tt>: Insufficient resources exist to
|
2006-06-06 10:51:22 +02:00
|
|
|
* complete this operation.
|
|
|
|
*/
|
2006-06-13 14:34:29 +02:00
|
|
|
EXPORT_SPEC int UpnpResolveURL(
|
2008-06-02 05:43:25 +02:00
|
|
|
/*! [in] The base URL to combine. */
|
|
|
|
const char *BaseURL,
|
|
|
|
/*! [in] The relative URL to \b BaseURL. */
|
|
|
|
const char *RelURL,
|
|
|
|
/*! [out] A pointer to a buffer to store the absolute URL. */
|
|
|
|
char *AbsURL);
|
2006-06-06 10:51:22 +02:00
|
|
|
|
2008-06-02 05:43:25 +02:00
|
|
|
|
2010-11-15 04:01:07 +01:00
|
|
|
/*!
|
|
|
|
* \brief Combines a base URL and a relative URL into a single absolute URL.
|
|
|
|
*
|
|
|
|
* The memory for \b AbsURL becomes owned by the caller and should be freed
|
|
|
|
* later.
|
|
|
|
*
|
|
|
|
* \return An integer representing one of the following:
|
|
|
|
* \li <tt>UPNP_E_SUCCESS</tt>: The operation completed successfully.
|
|
|
|
* \li <tt>UPNP_E_INVALID_PARAM</tt>: \b RelURL is <tt>NULL</tt>.
|
|
|
|
* \li <tt>UPNP_E_INVALID_URL</tt>: The \b BaseURL / \b RelURL
|
|
|
|
* combination does not form a valid URL.
|
|
|
|
* \li <tt>UPNP_E_OUTOF_MEMORY</tt>: Insufficient resources exist to
|
|
|
|
* complete this operation.
|
|
|
|
*/
|
|
|
|
EXPORT_SPEC int UpnpResolveURL2(
|
|
|
|
/*! [in] The base URL to combine. */
|
|
|
|
const char *BaseURL,
|
|
|
|
/*! [in] The relative URL to \b BaseURL. */
|
|
|
|
const char *RelURL,
|
|
|
|
/*! [out] A pointer to a pointer to a buffer to store the
|
|
|
|
* absolute URL. Must be freed later by the caller. */
|
|
|
|
char **AbsURL);
|
|
|
|
|
|
|
|
|
2008-06-02 05:43:25 +02:00
|
|
|
/*!
|
|
|
|
* \brief Creates an action request packet based on its input parameters
|
|
|
|
* (status variable name and value pair).
|
|
|
|
*
|
|
|
|
* Any number of input parameters can be passed to this function but every
|
|
|
|
* input variable name should have a matching value argument.
|
|
|
|
*
|
|
|
|
* It is a wrapper function that calls makeAction() function to create the
|
|
|
|
* action request.
|
|
|
|
*
|
|
|
|
* \return The action node of \b Upnp_Document type or <tt>NULL</tt> if the
|
|
|
|
* operation failed.
|
2006-06-06 10:51:22 +02:00
|
|
|
*/
|
2008-06-02 05:43:25 +02:00
|
|
|
EXPORT_SPEC IXML_Document *UpnpMakeAction(
|
|
|
|
/*! [in] Name of the action request or response. */
|
|
|
|
const char *ActionName,
|
|
|
|
/*! [in] The service type. */
|
|
|
|
const char *ServType,
|
|
|
|
/*! [in] Number of argument pairs to be passed. */
|
|
|
|
int NumArg,
|
|
|
|
/*! [in] pointer to the first argument. */
|
|
|
|
const char *Arg,
|
|
|
|
/*! [in] Argument list. */
|
|
|
|
...);
|
2006-06-06 10:51:22 +02:00
|
|
|
|
2008-06-02 05:43:25 +02:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Ceates an action response packet based on its output parameters
|
|
|
|
* (status variable name and value pair).
|
|
|
|
*
|
|
|
|
* Any number of input parameters can be passed to this function but every
|
|
|
|
* output variable name should have a matching value argument.
|
2006-06-06 10:51:22 +02:00
|
|
|
*
|
2008-06-02 05:43:25 +02:00
|
|
|
* It is a wrapper function that calls makeAction() function to create the
|
|
|
|
* action request.
|
|
|
|
*
|
|
|
|
* \return The action node of \b Upnp_Document type or <tt>NULL</tt> if the
|
|
|
|
* operation failed.
|
2006-06-06 10:51:22 +02:00
|
|
|
*/
|
2008-06-02 05:43:25 +02:00
|
|
|
EXPORT_SPEC IXML_Document *UpnpMakeActionResponse(
|
|
|
|
/*! [in] The action name. */
|
|
|
|
const char *ActionName,
|
|
|
|
/*! [in] The service type.. */
|
|
|
|
const char *ServType,
|
|
|
|
/*! [in] The number of argument pairs passed. */
|
|
|
|
int NumArg,
|
|
|
|
/*! [in] The status variable name and value pair. */
|
|
|
|
const char *Arg,
|
|
|
|
/*! [in] Other status variable name and value pairs. */
|
|
|
|
...);
|
2006-06-06 10:51:22 +02:00
|
|
|
|
|
|
|
|
2008-06-02 05:43:25 +02:00
|
|
|
/*!
|
|
|
|
* \brief Adds the argument in the action request.
|
|
|
|
*
|
|
|
|
* This API is specially suitable inside a loop to add any number input
|
|
|
|
* parameters into an existing action. If no action document exists in the
|
|
|
|
* beginning then a <b>Upnp_Document variable initialized with <tt>NULL</tt></b>
|
|
|
|
* should be passed as a parameter.
|
2006-06-06 10:51:22 +02:00
|
|
|
*
|
2008-06-02 05:43:25 +02:00
|
|
|
* It is a wrapper function that calls addToAction() function to add the
|
|
|
|
* argument in the action request.
|
|
|
|
*
|
|
|
|
* \return An integer representing one of the following:
|
|
|
|
* \li <tt>UPNP_E_SUCCESS</tt>: The operation completed successfully.
|
|
|
|
* \li <tt>UPNP_E_INVALID_PARAM</tt>: One or more of the parameters are invalid.
|
|
|
|
* \li <tt>UPNP_E_OUTOF_MEMORY</tt>: Insufficient resources exist to
|
|
|
|
* complete this operation.
|
2006-06-06 10:51:22 +02:00
|
|
|
*/
|
2008-06-02 05:43:25 +02:00
|
|
|
EXPORT_SPEC int UpnpAddToAction(
|
|
|
|
/*! [in,out] A pointer to store the action document node. */
|
|
|
|
IXML_Document **ActionDoc,
|
|
|
|
/*! [in] The action name. */
|
|
|
|
const char *ActionName,
|
|
|
|
/*! [in] The service type. */
|
|
|
|
const char *ServType,
|
|
|
|
/*! [in] The status variable name. */
|
|
|
|
const char *ArgName,
|
|
|
|
/*! [in] The status variable value. */
|
|
|
|
const char *ArgVal);
|
2006-06-06 10:51:22 +02:00
|
|
|
|
2008-06-02 05:43:25 +02:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Creates an action response packet based on its output parameters
|
|
|
|
* (status variable name and value pair).
|
|
|
|
*
|
|
|
|
* This API is especially suitable inside a loop to add any number of input
|
|
|
|
* parameters into an existing action response. If no action document exists
|
|
|
|
* in the beginning, a \b Upnp_Document variable initialized with <tt>NULL</tt>
|
|
|
|
* should be passed as a parameter.
|
2006-06-06 10:51:22 +02:00
|
|
|
*
|
2008-06-02 05:43:25 +02:00
|
|
|
* It is a wrapper function that calls addToAction() function to add the
|
|
|
|
* argument in the action request.
|
|
|
|
*
|
|
|
|
* \return An integer representing one of the following:
|
|
|
|
* \li <tt>UPNP_E_SUCCESS</tt>: The operation completed successfully.
|
|
|
|
* \li <tt>UPNP_E_INVALID_PARAM</tt>: One or more of the parameters are invalid.
|
|
|
|
* \li <tt>UPNP_E_OUTOF_MEMORY</tt>: Insufficient resources exist to
|
|
|
|
* complete this operation.
|
2006-06-06 10:51:22 +02:00
|
|
|
*/
|
2008-06-02 05:43:25 +02:00
|
|
|
EXPORT_SPEC int UpnpAddToActionResponse(
|
|
|
|
/*! [in,out] Pointer to a document to store the action document node. */
|
|
|
|
IXML_Document **ActionResponse,
|
|
|
|
/*! [in] The action name. */
|
|
|
|
const char *ActionName,
|
|
|
|
/*! [in] The service type. */
|
|
|
|
const char *ServType,
|
|
|
|
/*! [in] The status variable name. */
|
|
|
|
const char *ArgName,
|
|
|
|
/*! [in] The status variable value. */
|
|
|
|
const char *ArgVal);
|
2006-06-06 10:51:22 +02:00
|
|
|
|
|
|
|
|
2008-06-02 05:43:25 +02:00
|
|
|
/*!
|
|
|
|
* \brief Creates a property set message packet.
|
2006-06-06 10:51:22 +02:00
|
|
|
*
|
2008-06-02 05:43:25 +02:00
|
|
|
* Any number of input parameters can be passed to this function but every
|
|
|
|
* input variable name should have a matching value input argument.
|
|
|
|
*
|
|
|
|
* \return <tt>NULL</tt> on failure, or the property-set document node.
|
2006-06-06 10:51:22 +02:00
|
|
|
*/
|
2008-06-02 05:43:25 +02:00
|
|
|
EXPORT_SPEC IXML_Document *UpnpCreatePropertySet(
|
|
|
|
/*! [in] The number of argument pairs passed. */
|
|
|
|
int NumArg,
|
|
|
|
/*! [in] The status variable name and value pair. */
|
|
|
|
const char *Arg,
|
|
|
|
/*! [in] Variable sized list with the rest of the parameters. */
|
|
|
|
...);
|
2006-06-06 10:51:22 +02:00
|
|
|
|
|
|
|
|
2008-06-02 05:43:25 +02:00
|
|
|
/*!
|
|
|
|
* \brief Can be used when an application needs to transfer the status of many
|
|
|
|
* variables at once.
|
|
|
|
*
|
|
|
|
* It can be used (inside a loop) to add some extra status variables into an
|
|
|
|
* existing property set. If the application does not already have a property
|
|
|
|
* set document, the application should create a variable initialized with
|
|
|
|
* <tt>NULL</tt> and pass that as the first parameter.
|
|
|
|
*
|
|
|
|
* \return An integer representing one of the following:
|
|
|
|
* \li <tt>UPNP_E_SUCCESS</tt>: The operation completed successfully.
|
|
|
|
* \li <tt>UPNP_E_INVALID_PARAM</tt>: One or more of the parameters are invalid.
|
|
|
|
* \li <tt>UPNP_E_OUTOF_MEMORY</tt>: Insufficient resources exist to
|
|
|
|
* complete this operation.
|
|
|
|
*/
|
|
|
|
EXPORT_SPEC int UpnpAddToPropertySet(
|
|
|
|
/*! [in,out] A pointer to the document containing the property set document node. */
|
|
|
|
IXML_Document **PropSet,
|
|
|
|
/*! [in] The status variable name. */
|
|
|
|
const char *ArgName,
|
|
|
|
/*! [in] The status variable value. */
|
|
|
|
const char *ArgVal);
|
|
|
|
|
2006-06-06 10:51:22 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2008-06-02 05:43:25 +02:00
|
|
|
|
|
|
|
/*! @} */
|
|
|
|
|
|
|
|
|
2007-05-25 17:02:12 +02:00
|
|
|
#endif /* UPNP_HAVE_TOOLS */
|
2006-06-06 10:51:22 +02:00
|
|
|
|
2008-06-02 05:43:25 +02:00
|
|
|
|
2007-05-25 17:02:12 +02:00
|
|
|
#endif /* UPNP_TOOLS_H */
|
2006-06-06 10:51:22 +02:00
|
|
|
|