| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "extensions/common/manifest_handlers/kiosk_mode_info.h" | 5 #include "extensions/common/manifest_handlers/kiosk_mode_info.h" |
| 6 | 6 |
| 7 #include "base/memory/scoped_ptr.h" | 7 #include "base/memory/scoped_ptr.h" |
| 8 #include "base/strings/string16.h" | 8 #include "base/strings/string16.h" |
| 9 #include "base/strings/string_util.h" | 9 #include "base/strings/string_util.h" |
| 10 #include "base/strings/utf_string_conversions.h" | 10 #include "base/strings/utf_string_conversions.h" |
| 11 #include "base/values.h" | 11 #include "base/values.h" |
| 12 #include "base/version.h" |
| 12 #include "extensions/common/api/extensions_manifest_types.h" | 13 #include "extensions/common/api/extensions_manifest_types.h" |
| 13 #include "extensions/common/manifest_constants.h" | 14 #include "extensions/common/manifest_constants.h" |
| 14 | 15 |
| 16 namespace { |
| 17 |
| 18 // Whether the given |version_string| is a valid ChromeOS platform version. |
| 19 // The acceptable format is major[.minor[.micro]]. |
| 20 bool IsValidPlatformVersion(const std::string& version_string) { |
| 21 const base::Version version(version_string); |
| 22 return version.IsValid() && version.components().size() <= 3u; |
| 23 } |
| 24 |
| 25 } // namespace |
| 26 |
| 15 namespace extensions { | 27 namespace extensions { |
| 16 | 28 |
| 17 namespace keys = manifest_keys; | 29 namespace keys = manifest_keys; |
| 18 | 30 |
| 19 using api::extensions_manifest_types::KioskSecondaryAppsType; | 31 using api::extensions_manifest_types::KioskSecondaryAppsType; |
| 20 | 32 |
| 21 KioskModeInfo::KioskModeInfo(KioskStatus kiosk_status, | 33 KioskModeInfo::KioskModeInfo(KioskStatus kiosk_status, |
| 22 const std::vector<std::string>& secondary_app_ids) | 34 const std::vector<std::string>& secondary_app_ids, |
| 23 : kiosk_status(kiosk_status), secondary_app_ids(secondary_app_ids) {} | 35 const std::string& required_platform_version) |
| 36 : kiosk_status(kiosk_status), |
| 37 secondary_app_ids(secondary_app_ids), |
| 38 required_platform_version(required_platform_version) {} |
| 24 | 39 |
| 25 KioskModeInfo::~KioskModeInfo() { | 40 KioskModeInfo::~KioskModeInfo() { |
| 26 } | 41 } |
| 27 | 42 |
| 28 // static | 43 // static |
| 29 KioskModeInfo* KioskModeInfo::Get(const Extension* extension) { | 44 KioskModeInfo* KioskModeInfo::Get(const Extension* extension) { |
| 30 return static_cast<KioskModeInfo*>( | 45 return static_cast<KioskModeInfo*>( |
| 31 extension->GetManifestData(keys::kKioskMode)); | 46 extension->GetManifestData(keys::kKioskMode)); |
| 32 } | 47 } |
| 33 | 48 |
| 34 // static | 49 // static |
| 35 bool KioskModeInfo::IsKioskEnabled(const Extension* extension) { | 50 bool KioskModeInfo::IsKioskEnabled(const Extension* extension) { |
| 36 KioskModeInfo* info = Get(extension); | 51 KioskModeInfo* info = Get(extension); |
| 37 return info ? info->kiosk_status != NONE : false; | 52 return info ? info->kiosk_status != NONE : false; |
| 38 } | 53 } |
| 39 | 54 |
| 40 // static | 55 // static |
| 41 bool KioskModeInfo::IsKioskOnly(const Extension* extension) { | 56 bool KioskModeInfo::IsKioskOnly(const Extension* extension) { |
| 42 KioskModeInfo* info = Get(extension); | 57 KioskModeInfo* info = Get(extension); |
| 43 return info ? info->kiosk_status == ONLY : false; | 58 return info ? info->kiosk_status == ONLY : false; |
| 44 } | 59 } |
| 45 | 60 |
| 46 // static | 61 // static |
| 47 bool KioskModeInfo::HasSecondaryApps(const Extension* extension) { | 62 bool KioskModeInfo::HasSecondaryApps(const Extension* extension) { |
| 48 KioskModeInfo* info = Get(extension); | 63 KioskModeInfo* info = Get(extension); |
| 49 return info && !info->secondary_app_ids.empty(); | 64 return info && !info->secondary_app_ids.empty(); |
| 50 } | 65 } |
| 51 | 66 |
| 52 KioskModeHandler::KioskModeHandler() { | 67 KioskModeHandler::KioskModeHandler() { |
| 68 supported_keys_.push_back(keys::kKiosk); |
| 53 supported_keys_.push_back(keys::kKioskEnabled); | 69 supported_keys_.push_back(keys::kKioskEnabled); |
| 54 supported_keys_.push_back(keys::kKioskOnly); | 70 supported_keys_.push_back(keys::kKioskOnly); |
| 55 supported_keys_.push_back(keys::kKioskSecondaryApps); | 71 supported_keys_.push_back(keys::kKioskSecondaryApps); |
| 56 } | 72 } |
| 57 | 73 |
| 58 KioskModeHandler::~KioskModeHandler() { | 74 KioskModeHandler::~KioskModeHandler() { |
| 59 } | 75 } |
| 60 | 76 |
| 61 bool KioskModeHandler::Parse(Extension* extension, base::string16* error) { | 77 bool KioskModeHandler::Parse(Extension* extension, base::string16* error) { |
| 62 const Manifest* manifest = extension->manifest(); | 78 const Manifest* manifest = extension->manifest(); |
| (...skipping 23 matching lines...) Expand all Loading... |
| 86 // All other use cases should be already filtered out by manifest feature | 102 // All other use cases should be already filtered out by manifest feature |
| 87 // checks. | 103 // checks. |
| 88 DCHECK(extension->is_platform_app()); | 104 DCHECK(extension->is_platform_app()); |
| 89 | 105 |
| 90 KioskModeInfo::KioskStatus kiosk_status = KioskModeInfo::NONE; | 106 KioskModeInfo::KioskStatus kiosk_status = KioskModeInfo::NONE; |
| 91 if (kiosk_enabled) | 107 if (kiosk_enabled) |
| 92 kiosk_status = kiosk_only ? KioskModeInfo::ONLY : KioskModeInfo::ENABLED; | 108 kiosk_status = kiosk_only ? KioskModeInfo::ONLY : KioskModeInfo::ENABLED; |
| 93 | 109 |
| 94 // Kiosk secondary apps key is optional. | 110 // Kiosk secondary apps key is optional. |
| 95 std::vector<std::string> ids; | 111 std::vector<std::string> ids; |
| 96 if (extension->manifest()->HasKey(keys::kKioskSecondaryApps)) { | 112 if (manifest->HasKey(keys::kKioskSecondaryApps)) { |
| 97 const base::Value* secondary_apps = nullptr; | 113 const base::Value* secondary_apps = nullptr; |
| 98 const base::ListValue* list = nullptr; | 114 const base::ListValue* list = nullptr; |
| 99 if (!extension->manifest()->Get(keys::kKioskSecondaryApps, | 115 if (!manifest->Get(keys::kKioskSecondaryApps, &secondary_apps) || |
| 100 &secondary_apps) || | |
| 101 !secondary_apps->GetAsList(&list)) { | 116 !secondary_apps->GetAsList(&list)) { |
| 102 *error = base::ASCIIToUTF16(manifest_errors::kInvalidKioskSecondaryApps); | 117 *error = base::ASCIIToUTF16(manifest_errors::kInvalidKioskSecondaryApps); |
| 103 return false; | 118 return false; |
| 104 } | 119 } |
| 105 | 120 |
| 106 for (const base::Value* value : *list) { | 121 for (const base::Value* value : *list) { |
| 107 scoped_ptr<KioskSecondaryAppsType> app = | 122 scoped_ptr<KioskSecondaryAppsType> app = |
| 108 KioskSecondaryAppsType::FromValue(*value, error); | 123 KioskSecondaryAppsType::FromValue(*value, error); |
| 109 if (!app) { | 124 if (!app) { |
| 110 *error = base::ASCIIToUTF16( | 125 *error = base::ASCIIToUTF16( |
| 111 manifest_errors::kInvalidKioskSecondaryAppsBadAppId); | 126 manifest_errors::kInvalidKioskSecondaryAppsBadAppId); |
| 112 return false; | 127 return false; |
| 113 } | 128 } |
| 114 ids.push_back(app->id); | 129 ids.push_back(app->id); |
| 115 } | 130 } |
| 116 } | 131 } |
| 117 | 132 |
| 118 extension->SetManifestData(keys::kKioskMode, | 133 // Optional kiosk.required_platform_version key. |
| 119 new KioskModeInfo(kiosk_status, ids)); | 134 std::string required_platform_version; |
| 135 if (manifest->HasPath(keys::kKioskRequiredPlatformVersion) && |
| 136 (!manifest->GetString(keys::kKioskRequiredPlatformVersion, |
| 137 &required_platform_version) || |
| 138 !IsValidPlatformVersion(required_platform_version))) { |
| 139 *error = base::ASCIIToUTF16( |
| 140 manifest_errors::kInvalidKioskRequiredPlatformVersion); |
| 141 return false; |
| 142 } |
| 143 |
| 144 extension->SetManifestData( |
| 145 keys::kKioskMode, |
| 146 new KioskModeInfo(kiosk_status, ids, required_platform_version)); |
| 120 | 147 |
| 121 return true; | 148 return true; |
| 122 } | 149 } |
| 123 | 150 |
| 124 const std::vector<std::string> KioskModeHandler::Keys() const { | 151 const std::vector<std::string> KioskModeHandler::Keys() const { |
| 125 return supported_keys_; | 152 return supported_keys_; |
| 126 } | 153 } |
| 127 | 154 |
| 128 } // namespace extensions | 155 } // namespace extensions |
| OLD | NEW |