1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef COMPONENTS_UPDATE_CLIENT_UPDATE_RESPONSE_H_
6 #define COMPONENTS_UPDATE_CLIENT_UPDATE_RESPONSE_H_
11 #include "base/macros.h"
14 namespace update_client
{
16 // Parses responses for the update protocol version 3.
17 // (http://code.google.com/p/omaha/wiki/ServerProtocol)
19 // An update response looks like this:
21 // <?xml version="1.0" encoding="UTF-8"?>
22 // <response protocol="3.0" server="prod">
23 // <daystart elapsed_seconds="56508"/>
24 // <app appid="{430FD4D0-B729-4F61-AA34-91526481799D}" status="ok">
25 // <updatecheck status="noupdate"/>
26 // <ping status="ok"/>
28 // <app appid="{D0AB2EBC-931B-4013-9FEB-C9C4C2225C8C}" status="ok">
29 // <updatecheck status="ok">
31 // <url codebase="http://host/edgedl/chrome/install/782.112/"
32 // <url codebasediff="http://fallback/chrome/diff/782.112/"/>
34 // <manifest version="13.0.782.112" prodversionmin="2.0.143.0">
36 // <package name="component.crx"
37 // namediff="diff_1.2.3.4.crx"
39 // hash_sha256="9830b4245c4..." size="23963192"
40 // hashdiff_sha256="cfb6caf3d0..." sizediff="101"/>
44 // <ping status="ok"/>
48 // The <daystart> tag contains a "elapsed_seconds" attribute which refers to
49 // the server's notion of how many seconds it has been since midnight.
51 // The "appid" attribute of the <app> tag refers to the unique id of the
52 // extension. The "codebase" attribute of the <updatecheck> tag is the url to
53 // fetch the updated crx file, and the "prodversionmin" attribute refers to
54 // the minimum version of the chrome browser that the update applies to.
56 // The diff data members correspond to the differential update package, if
57 // a differential update is specified in the response.
58 class UpdateResponse
{
60 // The result of parsing one <app> tag in an xml update check response.
67 std::string fingerprint
;
69 // Attributes for the full update.
71 std::string hash_sha256
;
74 // Attributes for the differential update.
76 std::string hashdiff_sha256
;
84 std::string browser_min_version
;
85 std::vector
<Package
> packages
;
91 std::string extension_id
;
93 // The list of fallback urls, for full and diff updates respectively.
94 // These urls are base urls; they don't include the filename.
95 std::vector
<GURL
> crx_urls
;
96 std::vector
<GURL
> crx_diffurls
;
101 static const int kNoDaystart
= -1;
106 // This will be >= 0, or kNoDaystart if the <daystart> tag was not present.
107 int daystart_elapsed_seconds
;
108 std::vector
<Result
> list
;
114 // Parses an update response xml string into Result data. Returns a bool
115 // indicating success or failure. On success, the results are available by
116 // calling results(). The details for any failures are available by calling
118 bool Parse(const std::string
& manifest_xml
);
120 const Results
& results() const { return results_
; }
121 const std::string
& errors() const { return errors_
; }
127 // Adds parse error details to |errors_| string.
128 void ParseError(const char* details
, ...);
130 DISALLOW_COPY_AND_ASSIGN(UpdateResponse
);
133 } // namespace update_client
135 #endif // COMPONENTS_UPDATE_CLIENT_UPDATE_RESPONSE_H_