File: passwords_private_utils.h

package info (click to toggle)
chromium 73.0.3683.75-1~deb9u1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 1,792,156 kB
  • sloc: cpp: 13,473,466; ansic: 1,577,080; python: 898,539; javascript: 655,737; xml: 341,883; asm: 306,070; java: 289,969; perl: 80,911; objc: 67,198; sh: 43,184; cs: 27,853; makefile: 12,092; php: 11,064; yacc: 10,373; tcl: 8,875; ruby: 3,941; lex: 1,800; pascal: 1,473; lisp: 812; awk: 41; jsp: 39; sed: 19; sql: 3
file content (58 lines) | stat: -rw-r--r-- 2,239 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
// Copyright 2017 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 CHROME_BROWSER_EXTENSIONS_API_PASSWORDS_PRIVATE_PASSWORDS_PRIVATE_UTILS_H_
#define CHROME_BROWSER_EXTENSIONS_API_PASSWORDS_PRIVATE_PASSWORDS_PRIVATE_UTILS_H_

#include <map>
#include <string>

#include "base/containers/flat_map.h"
#include "chrome/common/extensions/api/passwords_private.h"

namespace autofill {
struct PasswordForm;
}

namespace extensions {

// Obtains a collection of URLs from the passed in form. This includes an origin
// URL used for internal logic, a human friendly string shown to the user as
// well as a URL that is linked to.
api::passwords_private::UrlCollection CreateUrlCollectionFromForm(
    const autofill::PasswordForm& form);

// This class serves as an identifier for strings created by CreateSortKey() in
// the password_manager namespace. It is similar to base::IDMap, but also allows
// to get the id for an already inserted element.
// TODO(https://crbug.com/778146): This class should be an implementation detail
// of PasswordManagerPresenter. Move this class there once Android uses a
// similar logic.
class SortKeyIdGenerator {
 public:
  SortKeyIdGenerator();
  ~SortKeyIdGenerator();

  // This method generates an id corresponding to |sort_key|. Additionally it
  // remembers ids generated in the past, so that this method is idempotent.
  // Furthermore, it is guaranteed that different ids are returned for different
  // |sort_key| arguments. This implies GenerateId(a) == GenerateId(b) if and
  // only if a == b.
  int GenerateId(const std::string& sort_key);

  // This method tries to return the sort key corresponding to |id|. In case
  // |id| was not generated by GenerateId() before, this method returns nullptr.
  // Otherwise it returns a pointer s to a sort key, such that |id| ==
  // GenerateId(*s).
  const std::string* TryGetSortKey(int id) const;

 private:
  std::map<std::string, int> sort_key_cache_;
  base::flat_map<int, const std::string*> id_cache_;
  int next_id_ = 0;
};

}  // namespace extensions

#endif  // CHROME_BROWSER_EXTENSIONS_API_PASSWORDS_PRIVATE_PASSWORDS_PRIVATE_UTILS_H_