// Copyright (c) 2012 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef PPAPI_SHARED_IMPL_URL_REQUEST_INFO_DATA_H_ #define PPAPI_SHARED_IMPL_URL_REQUEST_INFO_DATA_H_ #include #include #include "base/memory/ref_counted.h" #include "ppapi/c/pp_stdint.h" #include "ppapi/c/pp_time.h" #include "ppapi/shared_impl/host_resource.h" #include "ppapi/shared_impl/ppapi_shared_export.h" namespace ppapi { class Resource; struct PPAPI_SHARED_EXPORT URLRequestInfoData { struct PPAPI_SHARED_EXPORT BodyItem { BodyItem(); explicit BodyItem(const std::string& data); BodyItem(Resource* file_ref, int64_t start_offset, int64_t number_of_bytes, PP_Time expected_last_modified_time); // Set if the input is a file, false means the |data| is valid. bool is_file; std::string data; // Is is_file is set, these variables are set. Note that the resource // may still be NULL in some cases, such as deserialization errors. // // This is a bit tricky. In the plugin side of the proxy, both the file ref // and the file_ref_host_resource will be set and valid. The scoped_refptr // ensures that the resource is alive for as long as the BodyItem is. // // When we deserialize this in the renderer, only the // file_ref_host_resource's are serialized over IPC. The file_refs won't be // valid until the host resources are converted to Resource pointers in the // PPB_URLRequestInfo_Impl. scoped_refptr file_ref; HostResource file_ref_host_resource; int64_t start_offset; int64_t number_of_bytes; PP_Time expected_last_modified_time; // If you add more stuff here, be sure to modify the serialization rules in // ppapi_messages.h }; URLRequestInfoData(); ~URLRequestInfoData(); std::string url; std::string method; std::string headers; bool stream_to_file; bool follow_redirects; bool record_download_progress; bool record_upload_progress; // |has_custom_referrer_url| is set to false if a custom referrer hasn't been // set (or has been set to an Undefined Var) and the default referrer should // be used. (Setting the custom referrer to an empty string indicates that no // referrer header should be generated.) bool has_custom_referrer_url; std::string custom_referrer_url; bool allow_cross_origin_requests; bool allow_credentials; // Similar to the custom referrer (above), but for custom content transfer // encoding and custom user agent, respectively. bool has_custom_content_transfer_encoding; std::string custom_content_transfer_encoding; bool has_custom_user_agent; std::string custom_user_agent; int32_t prefetch_buffer_upper_threshold; int32_t prefetch_buffer_lower_threshold; std::vector body; // If you add more stuff here, be sure to modify the serialization rules in // ppapi_messages.h }; } // namespace ppapi #endif // PPAPI_SHARED_IMPL_URL_REQUEST_INFO_DATA_H_