OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 #ifndef CHROME_BROWSER_AUTOFILL_PASSWORD_GENERATOR_H_ | 5 #ifndef CHROME_BROWSER_AUTOFILL_PASSWORD_GENERATOR_H_ |
6 #define CHROME_BROWSER_AUTOFILL_PASSWORD_GENERATOR_H_ | 6 #define CHROME_BROWSER_AUTOFILL_PASSWORD_GENERATOR_H_ |
7 #pragma once | 7 #pragma once |
8 | 8 |
9 #include <string> | 9 #include <string> |
10 | 10 |
11 #include "base/basictypes.h" | 11 #include "base/basictypes.h" |
12 | 12 |
13 namespace autofill { | 13 namespace autofill { |
14 | 14 |
15 // Class to generate random passwords. Currently we just use a generic algorithm | 15 // Class to generate random passwords. Currently we just use a generic algorithm |
16 // for all sites, but eventually we can incorporate additional information to | 16 // for all sites, but eventually we can incorporate additional information to |
17 // determine passwords that are likely to be accepted (i.e. use pattern field, | 17 // determine passwords that are likely to be accepted (i.e. use pattern field, |
18 // previous generated passwords, crowdsourcing, etc.) | 18 // previous generated passwords, crowdsourcing, etc.) |
19 class PasswordGenerator { | 19 class PasswordGenerator { |
20 public: | 20 public: |
21 PasswordGenerator(); | 21 // |max_length| is used as a hint for the generated password's length. |
22 explicit PasswordGenerator(size_t max_length); | |
22 ~PasswordGenerator(); | 23 ~PasswordGenerator(); |
23 | 24 |
24 // Returns a random password. The string is guaranteed to be printable and | 25 // Returns a random password such that: |
25 // will not include whitespace characters. | 26 // (1) Each character is guaranteed to be a non-whitespace printable ASCII |
26 std::string Generate(); | 27 // character. |
28 // (2) The generated password will contain AT LEAST one upper case letter, one | |
29 // lower case letter, one digit, and one other symbol. | |
30 // (3) The password length will be equal to |password_length_| (see comment | |
31 // for the constructor). | |
32 std::string Generate() const; | |
27 | 33 |
28 private: | 34 private: |
35 // Unit test also need to access |kDefaultPasswordLength_|. | |
36 const size_t kDefaultPasswordLength_; | |
Ilya Sherman
2012/06/04 21:17:52
nit: This variable should be static, and the name
zysxqn
2012/06/04 22:40:15
Done.
| |
37 friend class PasswordGeneratorTest; | |
Ilya Sherman
2012/06/04 21:17:52
nit: Please use the FRIEND_TEST_ALL_PREFIXES macro
zysxqn
2012/06/04 22:40:15
Done.
| |
38 | |
39 // The length of the generated password. | |
40 const size_t password_length_; | |
29 | 41 |
30 DISALLOW_COPY_AND_ASSIGN(PasswordGenerator); | 42 DISALLOW_COPY_AND_ASSIGN(PasswordGenerator); |
31 }; | 43 }; |
32 | 44 |
33 } // namespace autofill | 45 } // namespace autofill |
34 | 46 |
35 #endif // CHROME_BROWSER_AUTOFILL_PASSWORD_GENERATOR_H_ | 47 #endif // CHROME_BROWSER_AUTOFILL_PASSWORD_GENERATOR_H_ |
OLD | NEW |