Index: components/update_client/update_response.h |
diff --git a/components/update_client/update_response.h b/components/update_client/update_response.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..003474f075505d5813d0abac912e012f4d14e173 |
--- /dev/null |
+++ b/components/update_client/update_response.h |
@@ -0,0 +1,135 @@ |
+// Copyright 2014 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 COMPONENTS_UPDATE_CLIENT_UPDATE_RESPONSE_H_ |
+#define COMPONENTS_UPDATE_CLIENT_UPDATE_RESPONSE_H_ |
+ |
+#include <string> |
+#include <vector> |
+ |
+#include "base/macros.h" |
+#include "url/gurl.h" |
+ |
+namespace update_client { |
+ |
+// Parses responses for the update protocol version 3. |
+// (http://code.google.com/p/omaha/wiki/ServerProtocol) |
+// |
+// An update response looks like this: |
+// |
+// <?xml version="1.0" encoding="UTF-8"?> |
+// <response protocol="3.0" server="prod"> |
+// <daystart elapsed_seconds="56508"/> |
+// <app appid="{430FD4D0-B729-4F61-AA34-91526481799D}" status="ok"> |
+// <updatecheck status="noupdate"/> |
+// <ping status="ok"/> |
+// </app> |
+// <app appid="{D0AB2EBC-931B-4013-9FEB-C9C4C2225C8C}" status="ok"> |
+// <updatecheck status="ok"> |
+// <urls> |
+// <url codebase="http://host/edgedl/chrome/install/782.112/" |
+// <url codebasediff="http://fallback/chrome/diff/782.112/"/> |
+// </urls> |
+// <manifest version="13.0.782.112" prodversionmin="2.0.143.0"> |
+// <packages> |
+// <package name="component.crx" |
+// namediff="diff_1.2.3.4.crx" |
+// fp="1.123" |
+// hash_sha256="9830b4245c4..." size="23963192" |
+// hashdiff_sha256="cfb6caf3d0..." sizediff="101"/> |
+// </packages> |
+// </manifest> |
+// </updatecheck> |
+// <ping status="ok"/> |
+// </app> |
+// </response> |
+// |
+// The <daystart> tag contains a "elapsed_seconds" attribute which refers to |
+// the server's notion of how many seconds it has been since midnight. |
+// |
+// The "appid" attribute of the <app> tag refers to the unique id of the |
+// extension. The "codebase" attribute of the <updatecheck> tag is the url to |
+// fetch the updated crx file, and the "prodversionmin" attribute refers to |
+// the minimum version of the chrome browser that the update applies to. |
+// |
+// The diff data members correspond to the differential update package, if |
+// a differential update is specified in the response. |
+class UpdateResponse { |
+ public: |
+ // The result of parsing one <app> tag in an xml update check response. |
+ struct Result { |
+ struct Manifest { |
+ struct Package { |
+ Package(); |
+ ~Package(); |
+ |
+ std::string fingerprint; |
+ |
+ // Attributes for the full update. |
+ std::string name; |
+ std::string hash_sha256; |
+ int size; |
+ |
+ // Attributes for the differential update. |
+ std::string namediff; |
+ std::string hashdiff_sha256; |
+ int sizediff; |
+ }; |
+ |
+ Manifest(); |
+ ~Manifest(); |
+ |
+ std::string version; |
+ std::string browser_min_version; |
+ std::vector<Package> packages; |
+ }; |
+ |
+ Result(); |
+ ~Result(); |
+ |
+ std::string extension_id; |
+ |
+ // The list of fallback urls, for full and diff updates respectively. |
+ // These urls are base urls; they don't include the filename. |
+ std::vector<GURL> crx_urls; |
+ std::vector<GURL> crx_diffurls; |
+ |
+ Manifest manifest; |
+ }; |
+ |
+ static const int kNoDaystart = -1; |
+ struct Results { |
+ Results(); |
+ ~Results(); |
+ |
+ // This will be >= 0, or kNoDaystart if the <daystart> tag was not present. |
+ int daystart_elapsed_seconds; |
+ std::vector<Result> list; |
+ }; |
+ |
+ UpdateResponse(); |
+ ~UpdateResponse(); |
+ |
+ // Parses an update response xml string into Result data. Returns a bool |
+ // indicating success or failure. On success, the results are available by |
+ // calling results(). The details for any failures are available by calling |
+ // errors(). |
+ bool Parse(const std::string& manifest_xml); |
+ |
+ const Results& results() const { return results_; } |
+ const std::string& errors() const { return errors_; } |
+ |
+ private: |
+ Results results_; |
+ std::string errors_; |
+ |
+ // Adds parse error details to |errors_| string. |
+ void ParseError(const char* details, ...); |
+ |
+ DISALLOW_COPY_AND_ASSIGN(UpdateResponse); |
+}; |
+ |
+} // namespace update_client |
+ |
+#endif // COMPONENTS_UPDATE_CLIENT_UPDATE_RESPONSE_H_ |