Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(761)

Side by Side Diff: extensions/common/permissions/permission_message_util.cc

Issue 404823009: Removing the * from hosts and adding the words 'all' and 'site'. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Addressing jww@ comment (generalize the max size of list) Created 6 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | extensions/common/permissions/permissions_data_unittest.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 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 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/permissions/permission_message_util.h" 5 #include "extensions/common/permissions/permission_message_util.h"
6 6
7 #include "base/strings/string_number_conversions.h" 7 #include "base/strings/string_number_conversions.h"
8 #include "base/strings/utf_string_conversions.h" 8 #include "base/strings/utf_string_conversions.h"
9 #include "extensions/common/permissions/permission_message.h" 9 #include "extensions/common/permissions/permission_message.h"
10 #include "extensions/common/permissions/permission_set.h" 10 #include "extensions/common/permissions/permission_set.h"
(...skipping 20 matching lines...) Expand all
31 if (a == "org") 31 if (a == "org")
32 return b != "com" && b != "net"; 32 return b != "com" && b != "net";
33 return false; 33 return false;
34 } 34 }
35 35
36 } // namespace 36 } // namespace
37 37
38 namespace permission_message_util { 38 namespace permission_message_util {
39 39
40 PermissionMessage CreateFromHostList(const std::set<std::string>& hosts) { 40 PermissionMessage CreateFromHostList(const std::set<std::string>& hosts) {
41 std::vector<std::string> host_list(hosts.begin(), hosts.end()); 41 std::vector<base::string16> host_list;
42 DCHECK(host_list.size());
43 PermissionMessage::ID message_id; 42 PermissionMessage::ID message_id;
44 base::string16 message; 43 base::string16 message;
45 base::string16 details; 44 base::string16 details;
45 uint32_t kMaxBeforeListOfHosts = 3;
jww 2014/07/22 21:31:56 This should be const, I think.
mhm 2014/07/22 23:37:28 Done.
46 std::vector<std::pair<PermissionMessage::ID, base::string16> > kMessagesList;
jww 2014/07/22 21:31:56 I don't see why this needs to be a vector since it
mhm 2014/07/22 21:53:34 So the main issue here is that to be able to creat
jww 2014/07/22 22:14:35 Ah, I see. Well, you can still do something more e
mhm 2014/07/22 23:37:28 Done.
47 int host_msg_id = hosts.size() <= kMaxBeforeListOfHosts
48 ? IDS_EXTENSION_PROMPT_WARNING_HOST_AND_SUBDOMAIN
49 : IDS_EXTENSION_PROMPT_WARNING_HOST_AND_SUBDOMAIN_LIST;
46 50
47 switch (host_list.size()) { 51 for (std::set<std::string>::const_iterator it = hosts.begin();
48 case 1: 52 it != hosts.end();
49 message_id = PermissionMessage::kHosts1; 53 ++it) {
50 message = l10n_util::GetStringFUTF16(IDS_EXTENSION_PROMPT_WARNING_1_HOST, 54 std::string host = *it;
51 base::UTF8ToUTF16(host_list[0])); 55 host_list.push_back(
52 break; 56 host[0] == '*' && host[1] == '.'
53 case 2: 57 ? l10n_util::GetStringFUTF16(host_msg_id,
54 message_id = PermissionMessage::kHosts2; 58 base::UTF8ToUTF16(host.erase(0, 2)))
55 message = l10n_util::GetStringFUTF16(IDS_EXTENSION_PROMPT_WARNING_2_HOSTS, 59 : base::UTF8ToUTF16(host));
56 base::UTF8ToUTF16(host_list[0]), 60 }
57 base::UTF8ToUTF16(host_list[1])); 61 DCHECK(host_list.size());
58 break;
59 case 3:
60 message_id = PermissionMessage::kHosts3;
61 message = l10n_util::GetStringFUTF16(IDS_EXTENSION_PROMPT_WARNING_3_HOSTS,
62 base::UTF8ToUTF16(host_list[0]),
63 base::UTF8ToUTF16(host_list[1]),
64 base::UTF8ToUTF16(host_list[2]));
65 break;
66 default:
67 message_id = PermissionMessage::kHosts4OrMore;
68 62
69 const int kRetainedFilesMessageIDs[6] = { 63 kMessagesList.push_back(std::make_pair(
70 IDS_EXTENSION_PROMPT_WARNING_HOSTS_DEFAULT, 64 PermissionMessage::kHosts1,
71 IDS_EXTENSION_PROMPT_WARNING_HOST_SINGULAR, 65 l10n_util::GetStringFUTF16(
72 IDS_EXTENSION_PROMPT_WARNING_HOSTS_ZERO, 66 IDS_EXTENSION_PROMPT_WARNING_1_HOST, host_list, NULL)));
73 IDS_EXTENSION_PROMPT_WARNING_HOSTS_TWO, 67 kMessagesList.push_back(std::make_pair(
74 IDS_EXTENSION_PROMPT_WARNING_HOSTS_FEW, 68 PermissionMessage::kHosts2,
75 IDS_EXTENSION_PROMPT_WARNING_HOSTS_MANY, }; 69 l10n_util::GetStringFUTF16(
76 std::vector<int> message_ids; 70 IDS_EXTENSION_PROMPT_WARNING_2_HOSTS, host_list, NULL)));
77 for (size_t i = 0; i < arraysize(kRetainedFilesMessageIDs); i++) { 71 kMessagesList.push_back(std::make_pair(
78 message_ids.push_back(kRetainedFilesMessageIDs[i]); 72 PermissionMessage::kHosts3,
79 } 73 l10n_util::GetStringFUTF16(
80 message = l10n_util::GetPluralStringFUTF16(message_ids, host_list.size()); 74 IDS_EXTENSION_PROMPT_WARNING_3_HOSTS, host_list, NULL)));
81 75
82 for (size_t i = 0; i < host_list.size(); ++i) { 76 if (host_list.size() <= kMaxBeforeListOfHosts) {
83 if (i > 0) 77 message_id = kMessagesList[host_list.size() - 1].first;
84 details += base::ASCIIToUTF16("\n"); 78 message = kMessagesList[host_list.size() - 1].second;
85 details += l10n_util::GetStringFUTF16( 79 } else {
86 IDS_EXTENSION_PROMPT_WARNING_HOST_LIST_ENTRY, 80 message_id = PermissionMessage::kHosts4OrMore;
87 base::UTF8ToUTF16(host_list[i])); 81 message = l10n_util::GetStringUTF16(
88 } 82 IDS_EXTENSION_PROMPT_WARNING_HOSTS_4_OR_MORE_HOSTS);
83 for (size_t i = 0; i < host_list.size(); ++i) {
84 if (i > 0)
85 details += base::ASCIIToUTF16("\n");
86 details += l10n_util::GetStringFUTF16(
87 IDS_EXTENSION_PROMPT_WARNING_HOST_LIST_ENTRY, host_list[i]);
88 }
89 } 89 }
90 90
91 return PermissionMessage(message_id, message, details); 91 return PermissionMessage(message_id, message, details);
92 } 92 }
93 93
94 std::set<std::string> GetDistinctHosts(const URLPatternSet& host_patterns, 94 std::set<std::string> GetDistinctHosts(const URLPatternSet& host_patterns,
95 bool include_rcd, 95 bool include_rcd,
96 bool exclude_file_scheme) { 96 bool exclude_file_scheme) {
97 // Use a vector to preserve order (also faster than a map on small sets). 97 // Use a vector to preserve order (also faster than a map on small sets).
98 // Each item is a host split into two parts: host without RCDs and 98 // Each item is a host split into two parts: host without RCDs and
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after
141 // Build up the final vector by concatenating hosts and RCDs. 141 // Build up the final vector by concatenating hosts and RCDs.
142 std::set<std::string> distinct_hosts; 142 std::set<std::string> distinct_hosts;
143 for (HostVector::iterator it = hosts_best_rcd.begin(); 143 for (HostVector::iterator it = hosts_best_rcd.begin();
144 it != hosts_best_rcd.end(); 144 it != hosts_best_rcd.end();
145 ++it) 145 ++it)
146 distinct_hosts.insert(it->first + it->second); 146 distinct_hosts.insert(it->first + it->second);
147 return distinct_hosts; 147 return distinct_hosts;
148 } 148 }
149 149
150 } // namespace permission_message_util 150 } // namespace permission_message_util
OLDNEW
« no previous file with comments | « no previous file | extensions/common/permissions/permissions_data_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698