summaryrefslogtreecommitdiffstats
path: root/MdeModulePkg/Include
diff options
context:
space:
mode:
authorNagaraj Hegde <nagaraj-p.hegde@hpe.com>2016-04-04 18:09:27 +0800
committerFu Siyuan <siyuan.fu@intel.com>2016-04-27 10:43:08 +0800
commite297a0a498139cedca232aff69c41c8996151f0b (patch)
treef88024dbac07681cf9197642dd5a0b3f2427857b /MdeModulePkg/Include
parent0aa0beca37c686c028da47a801b0db6c770b81e8 (diff)
downloadedk2-e297a0a498139cedca232aff69c41c8996151f0b.tar.gz
edk2-e297a0a498139cedca232aff69c41c8996151f0b.tar.bz2
edk2-e297a0a498139cedca232aff69c41c8996151f0b.zip
MdeModulePkg:DxeHttpLib: Update to DxeHttpLib API
Rename and update the logic of HttpGenRequestString API provided by DxeHttpLib. The RequestString size is returned as an argument. The user is not expected to do a AsciiStrLen anymore, and is not logical too, since request string can contain message body and using AsciiStrLen on such a string can provide truncated lengths. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Nagaraj Hegde <nagaraj-p.hegde@hpe.com> Reviewed-by: Fu Siyuan <siyuan.fu@intel.com> Reviewed-by: Samer El-Haj-Mahmoud <elhaj@hpe.com>
Diffstat (limited to 'MdeModulePkg/Include')
-rw-r--r--MdeModulePkg/Include/Library/HttpLib.h19
1 files changed, 14 insertions, 5 deletions
diff --git a/MdeModulePkg/Include/Library/HttpLib.h b/MdeModulePkg/Include/Library/HttpLib.h
index af9ab5f012..853982025c 100644
--- a/MdeModulePkg/Include/Library/HttpLib.h
+++ b/MdeModulePkg/Include/Library/HttpLib.h
@@ -417,12 +417,20 @@ HttpFreeHeaderFields (
);
/**
- Generate HTTP request string.
+ Generate HTTP request message.
- @param[in] Message Pointer to storage containing HTTP message data.
+ This function will allocate memory for the whole HTTP message and generate a
+ well formatted HTTP Request message in it, include the Request-Line, header
+ fields and also the message body. It is the caller's responsibility to free
+ the buffer returned in *RequestMsg.
+
+ @param[in] Message Pointer to the EFI_HTTP_MESSAGE structure which
+ contains the required information to generate
+ the HTTP request message.
@param[in] Url The URL of a remote host.
- @param[out] RequestString Pointer to the created HTTP request string.
+ @param[out] RequestMsg Pointer to the created HTTP request message.
NULL if any error occured.
+ @param[out] RequestMsgSize Size of the RequestMsg (in bytes).
@return EFI_SUCCESS If HTTP request string was created successfully
@retval EFI_OUT_OF_RESOURCES Failed to allocate resources.
@@ -431,10 +439,11 @@ HttpFreeHeaderFields (
**/
EFI_STATUS
EFIAPI
-HttpGenRequestString (
+HttpGenRequestMessage (
IN CONST EFI_HTTP_MESSAGE *Message,
IN CONST CHAR8 *Url,
- OUT CHAR8 **RequestString
+ OUT CHAR8 **RequestMsg,
+ OUT UINTN *RequestMsgSize
);
/**