// 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 CONTENT_PUBLIC_COMMON_MANIFEST_H_ #define CONTENT_PUBLIC_COMMON_MANIFEST_H_ #include #include #include #include "base/strings/nullable_string16.h" #include "content/common/content_export.h" #include "third_party/WebKit/public/platform/WebDisplayMode.h" #include "third_party/WebKit/public/platform/modules/screen_orientation/WebScreenOrientationLockType.h" #include "ui/gfx/geometry/size.h" #include "url/gurl.h" namespace content { // The Manifest structure is an internal representation of the Manifest file // described in the "Manifest for Web Application" document: // http://w3c.github.io/manifest/ struct CONTENT_EXPORT Manifest { // Structure representing an icon as per the Manifest specification, see: // http://w3c.github.io/manifest/#dfn-icon-object struct CONTENT_EXPORT Icon { Icon(); ~Icon(); // MUST be a valid url. If an icon doesn't have a valid URL, it will not be // successfully parsed, thus will not be represented in the Manifest. GURL src; // Null if the parsing failed or the field was not present. The type can be // any string and doesn't have to be a valid image MIME type at this point. // It is up to the consumer of the object to check if the type matches a // supported type. base::NullableString16 type; // Default value is 1.0 if the value is missing or invalid. double density; // Empty if the parsing failed, the field was not present or empty. // The special value "any" is represented by gfx::Size(0, 0). std::vector sizes; // Default density. Set to 1.0. static const double kDefaultDensity; }; // Structure representing a related application. struct CONTENT_EXPORT RelatedApplication { RelatedApplication(); ~RelatedApplication(); // The platform on which the application can be found. This can be any // string, and is interpreted by the consumer of the object. Empty if the // parsing failed. base::NullableString16 platform; // URL at which the application can be found. One of |url| and |id| must be // present. Empty if the parsing failed or the field was not present. GURL url; // An id which is used to represent the application on the platform. One of // |url| and |id| must be present. Empty if the parsing failed or the field // was not present. base::NullableString16 id; }; Manifest(); ~Manifest(); // Returns whether this Manifest had no attribute set. A newly created // Manifest is always empty. bool IsEmpty() const; // Null if the parsing failed or the field was not present. base::NullableString16 name; // Null if the parsing failed or the field was not present. base::NullableString16 short_name; // Empty if the parsing failed or the field was not present. GURL start_url; // Set to WebDisplayModeUndefined if the parsing failed or the field was not // present. blink::WebDisplayMode display; // Set to blink::WebScreenOrientationLockDefault if the parsing failed or the // field was not present. blink::WebScreenOrientationLockType orientation; // Empty if the parsing failed, the field was not present, empty or all the // icons inside the JSON array were invalid. std::vector icons; // Empty if the parsing failed, the field was not present, empty or all the // applications inside the array were invalid. The order of the array // indicates the priority of the application to use. std::vector related_applications; // A boolean that is used as a hint for the user agent to say that related // applications should be preferred over the web application. False if missing // or there is a parsing failure. bool prefer_related_applications; // This is a 64 bit integer because we need to represent an error state. The // color itself should only be 32 bits long if the value is not // kInvalidOrMissingColor and can be safely cast to SkColor if is valid. // Set to kInvalidOrMissingColor if parsing failed or field is not // present. int64_t theme_color; // This is a 64 bit integer because we need to represent an error state. The // color itself should only be 32 bits long if the value is not // kInvalidOrMissingColor and can be safely cast to SkColor if is valid. // Set to kInvalidOrMissingColor if parsing failed or field is not // present. int64_t background_color; // This is a proprietary extension of the web Manifest, double-check that it // is okay to use this entry. // Null if parsing failed or the field was not present. base::NullableString16 gcm_sender_id; // Maximum length for all the strings inside the Manifest when it is sent over // IPC. The renderer process should truncate the strings before sending the // Manifest and the browser process must do the same when receiving it. static const size_t kMaxIPCStringLength; // Constant representing an invalid color. Set to a value outside the // range of a 32-bit integer. static const int64_t kInvalidOrMissingColor; }; } // namespace content #endif // CONTENT_PUBLIC_COMMON_MANIFEST_H_