ihxhurl.h
上传用户:dangjiwu
上传日期:2013-07-19
资源大小:42019k
文件大小:6k
源码类别:

Symbian

开发平台:

Visual C++

  1. /* ***** BEGIN LICENSE BLOCK *****
  2.  * Source last modified: $Id: ihxhurl.h,v 1.1.1.1.50.3 2004/07/09 01:45:13 hubbe Exp $
  3.  * 
  4.  * Portions Copyright (c) 1995-2004 RealNetworks, Inc. All Rights Reserved.
  5.  * 
  6.  * The contents of this file, and the files included with this file,
  7.  * are subject to the current version of the RealNetworks Public
  8.  * Source License (the "RPSL") available at
  9.  * http://www.helixcommunity.org/content/rpsl unless you have licensed
  10.  * the file under the current version of the RealNetworks Community
  11.  * Source License (the "RCSL") available at
  12.  * http://www.helixcommunity.org/content/rcsl, in which case the RCSL
  13.  * will apply. You may also obtain the license terms directly from
  14.  * RealNetworks.  You may not use this file except in compliance with
  15.  * the RPSL or, if you have a valid RCSL with RealNetworks applicable
  16.  * to this file, the RCSL.  Please see the applicable RPSL or RCSL for
  17.  * the rights, obligations and limitations governing use of the
  18.  * contents of the file.
  19.  * 
  20.  * Alternatively, the contents of this file may be used under the
  21.  * terms of the GNU General Public License Version 2 or later (the
  22.  * "GPL") in which case the provisions of the GPL are applicable
  23.  * instead of those above. If you wish to allow use of your version of
  24.  * this file only under the terms of the GPL, and not to allow others
  25.  * to use your version of this file under the terms of either the RPSL
  26.  * or RCSL, indicate your decision by deleting the provisions above
  27.  * and replace them with the notice and other provisions required by
  28.  * the GPL. If you do not delete the provisions above, a recipient may
  29.  * use your version of this file under the terms of any one of the
  30.  * RPSL, the RCSL or the GPL.
  31.  * 
  32.  * This file is part of the Helix DNA Technology. RealNetworks is the
  33.  * developer of the Original Code and owns the copyrights in the
  34.  * portions it created.
  35.  * 
  36.  * This file, and the files included with this file, is distributed
  37.  * and made available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY
  38.  * KIND, EITHER EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS
  39.  * ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES
  40.  * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET
  41.  * ENJOYMENT OR NON-INFRINGEMENT.
  42.  * 
  43.  * Technology Compatibility Kit Test Suite(s) Location:
  44.  *    http://www.helixcommunity.org/content/tck
  45.  * 
  46.  * Contributor(s):
  47.  * 
  48.  * ***** END LICENSE BLOCK ***** */
  49. /*
  50.  *
  51.  * IHXHurl interface : Encapsulates the process of 'hurling'
  52.  * the user to a web page. The URL to hurl to can be a script
  53.  * returing a redirect URL. Data can be attached to the URL
  54.  * before the hurling.
  55.  *
  56.  *
  57.  */
  58. #ifndef _IHXHURL_H
  59. #define _IHXHURL_H
  60. #include "hxcom.h"
  61. // these are common parameter definitions when using SetData()
  62. // ADD ALPHABETICALLY by value, we don't want to duplicate a field name
  63. #define HXHURL_AUTHFAILEDCOMP      "AC"
  64. #define HXHURL_AUTHFAILEDVERS      "AV"
  65. #define HXHURL_PRIMARYBROWSER     "BR"
  66. #define HXHURL_PRIMARYBROWSERVER    "BV"
  67. #define HXHURL_CPU      "CP"
  68. #define HXHURL_CONNECTSPEED     "CS"
  69. #define HXHURL_DISTCODE     "DC"
  70. #define HXHURL_DDRAWVER      "DR"
  71. #define HXHURL_EXTRAINFO      "EI"
  72. #define HXHURL_ERROR      "ER"
  73. #define HXHURL_FREERAM      "FM"
  74. #define HXHURL_GUID      "GU"
  75. #define HXHURL_INSTCOMPONENTS     "IC"
  76. #define HXHURL_ITEMID      "ID"
  77. #define HXHURL_LANGPREF      "LP"
  78. #define HXHURL_PRODLANG      "LI"
  79. #define HXHURL_USERERRSTRING     "MI" // user-supplied error text
  80. #define HXHURL_MOREINFOURL     "MU" // user-supplied URL 
  81. #define HXHURL_ORIGCODE      "OC"
  82. #define HXHURL_OS      "OS"
  83. #define HXHURL_OSLANG      "OL"
  84. #define HXHURL_PRODNAME      "PN"
  85. #define HXHURL_PRODTYPE      "PT"
  86. #define HXHURL_PRODVER      "PV"
  87. #define HXHURL_PHYSRAM      "PR"
  88. #define HXHURL_SNDCARD      "SC"
  89. #define HXHURL_SNDCARD_DRVVER     "SV"
  90. #define HXHURL_PRODSERIAL      "SN"
  91. #define HXHURL_USERCODE     "UC"
  92. #define HXHURL_LASTURL      "UR"
  93. #define HXHURL_VIRTRAM      "VR"
  94. #define HXHURL_VIDCARD      "VC"
  95. #define HXHURL_VIDCARD_DRVVER "VV"
  96. #define HXHURL_COUNTRY     "CO"
  97. #define HXHURL_REGION      "RGN"
  98. // {A3028581-DB10-11d1-8F39-0060083BE561}
  99. DEFINE_GUID(IID_IHXHurlResponse, 
  100. 0xa3028581, 0xdb10, 0x11d1, 0x8f, 0x39, 0x0, 0x60, 0x8, 0x3b, 0xe5, 0x61);
  101. #undef  INTERFACE
  102. #define INTERFACE IHXHurlResponse
  103. DECLARE_INTERFACE_(IHXHurlResponse, IUnknown)
  104. {
  105.     STDMETHOD(QueryInterface) (THIS_ REFIID riid, void** ppvObj) PURE;
  106.     STDMETHOD_(ULONG32, AddRef) (THIS) PURE;
  107.     STDMETHOD_(ULONG32, Release) (THIS) PURE;
  108.     // Callback to say whether the hurl suceeded or not.
  109.     STDMETHOD(OnHurlDone) (THIS_ HX_RESULT status) PURE;
  110. };
  111. // {B16C0330-B2EC-11d1-8EFD-0060083BE561}
  112. DEFINE_GUID(IID_IHXHurl, 0xb16c0330, 0xb2ec, 0x11d1, 0x8e, 0xfd, 0x0, 0x60, 0x8, 0x3b, 0xe5, 0x61);
  113. #undef  INTERFACE
  114. #define INTERFACE IHXHurl
  115. DECLARE_INTERFACE_(IHXHurl, IUnknown)
  116. {
  117.     STDMETHOD(QueryInterface) (THIS_ REFIID riid, void** ppvObj) PURE;
  118.     STDMETHOD_(ULONG32, AddRef) (THIS) PURE;
  119.     STDMETHOD_(ULONG32, Release) (THIS) PURE;
  120. // add name/value pairs to the hurl.
  121. STDMETHOD(SetData) (THIS_
  122. const char* szName,
  123. const char* szValue
  124. ) PURE;
  125. STDMETHOD(SetDataUINT32) (THIS_
  126. const char* szName,
  127. UINT32 nValue
  128. ) PURE;
  129. // After Setting any additional data you want sent with the
  130. // hurl, perform the hurl.
  131. STDMETHOD(Hurl) (THIS) PURE;
  132. // set the URL to which to hurl  ;-)..
  133. STDMETHOD(SetUrl) ( THIS_ const char* szUrl ) PURE;
  134. STDMETHOD(GetUrl) ( THIS_ const char** szUrl) PURE;
  135. // Get the Hurl ready to do another hurl, cancels any pending
  136. // hurl that this object is managing.
  137. STDMETHOD(Reset) (THIS) PURE;
  138. // Register response object if needed.
  139. STDMETHOD(SetResponse) ( THIS_ IHXHurlResponse* pIResponse) PURE;
  140. };
  141. // {7F108C4B-A684-4cad-A97A-E3AC2898ABC5}
  142. DEFINE_GUID(IID_IHXHurl2, 0x7f108c4b, 0xa684, 0x4cad, 0xa9, 0x7a, 0xe3, 0xac, 0x28, 0x98, 0xab, 0xc5);
  143. DECLARE_INTERFACE_(IHXHurl2, IHXHurl)
  144. {
  145.     //sets the target window for hurling
  146.     STDMETHOD(SetTarget) ( THIS_ const char* szTarget) PURE;
  147. };
  148. #endif