OLD | NEW |
---|---|
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 NET_FTP_FTP_AUTH_CACHE_H_ | 5 #ifndef NET_FTP_FTP_AUTH_CACHE_H_ |
6 #define NET_FTP_FTP_AUTH_CACHE_H_ | 6 #define NET_FTP_FTP_AUTH_CACHE_H_ |
7 | 7 |
8 #include <list> | 8 #include <list> |
9 | 9 |
10 #include "net/base/auth.h" | 10 #include "net/base/auth.h" |
11 #include "net/base/net_export.h" | 11 #include "net/base/net_export.h" |
12 #include "url/gurl.h" | 12 #include "url/origin.h" |
13 | 13 |
14 namespace net { | 14 namespace net { |
15 | 15 |
16 // The FtpAuthCache class is a simple cache structure to store authentication | 16 // The FtpAuthCache class is a simple cache structure to store authentication |
17 // information for ftp. Provides lookup, insertion, and deletion of entries. | 17 // information for ftp. Provides lookup, insertion, and deletion of entries. |
18 // The parameter for doing lookups, insertions, and deletions is a GURL of the | 18 // The parameter for doing lookups, insertions, and deletions is a GURL of the |
19 // server's address (not a full URL with path, since FTP auth isn't per path). | 19 // server's address (not a full URL with path, since FTP auth isn't per path). |
20 // For example: | 20 // For example: |
21 // GURL("ftp://myserver") -- OK (implied port of 21) | 21 // GURL("ftp://myserver") -- OK (implied port of 21) |
22 // GURL("ftp://myserver:21") -- OK | 22 // GURL("ftp://myserver:21") -- OK |
23 // GURL("ftp://myserver/PATH") -- WRONG, paths not allowed | 23 // GURL("ftp://myserver/PATH") -- WRONG, paths not allowed |
24 class NET_EXPORT_PRIVATE FtpAuthCache { | 24 class NET_EXPORT_PRIVATE FtpAuthCache { |
25 public: | 25 public: |
26 // Maximum number of entries we allow in the cache. | 26 // Maximum number of entries we allow in the cache. |
27 static const size_t kMaxEntries; | 27 static const size_t kMaxEntries; |
28 | 28 |
29 struct Entry { | 29 struct Entry { |
30 Entry(const GURL& origin, const AuthCredentials& credentials); | 30 Entry(const url::Origin& origin, const AuthCredentials& credentials); |
31 ~Entry(); | 31 ~Entry(); |
32 | 32 |
33 GURL origin; | 33 url::Origin origin; |
34 AuthCredentials credentials; | 34 AuthCredentials credentials; |
35 }; | 35 }; |
36 | 36 |
37 FtpAuthCache(); | 37 FtpAuthCache(); |
38 ~FtpAuthCache(); | 38 ~FtpAuthCache(); |
39 | 39 |
40 // Return Entry corresponding to given |origin| or NULL if not found. | 40 // Return Entry corresponding to given |origin| or NULL if not found. |
41 Entry* Lookup(const GURL& origin); | 41 Entry* Lookup(const url::Origin& origin); |
42 | 42 |
43 // Add an entry for |origin| to the cache using |credentials|. If there is | 43 // Add an entry for |origin| to the cache using |credentials|. If there is |
44 // already an entry for |origin|, it will be overwritten. | 44 // already an entry for |origin|, it will be overwritten. |
45 void Add(const GURL& origin, const AuthCredentials& credentials); | 45 void Add(const url::Origin& origin, const AuthCredentials& credentials); |
46 | 46 |
47 // Remove the entry for |origin| from the cache, if one exists and matches | 47 // Remove the entry for |origin| from the cache, if one exists and matches |
48 // |credentials|. | 48 // |credentials|. |
49 void Remove(const GURL& origin, const AuthCredentials& credentials); | 49 void Remove(const url::Origin& origin, const AuthCredentials& credentials); |
Ryan Sleevi
2015/05/22 02:50:03
So, overall, changes like this make me... Generall
| |
50 | 50 |
51 private: | 51 private: |
52 typedef std::list<Entry> EntryList; | 52 typedef std::list<Entry> EntryList; |
53 | 53 |
54 // Internal representation of cache, an STL list. This makes lookups O(n), | 54 // Internal representation of cache, an STL list. This makes lookups O(n), |
55 // but we expect n to be very low. | 55 // but we expect n to be very low. |
56 EntryList entries_; | 56 EntryList entries_; |
57 }; | 57 }; |
58 | 58 |
59 } // namespace net | 59 } // namespace net |
60 | 60 |
61 #endif // NET_FTP_FTP_AUTH_CACHE_H_ | 61 #endif // NET_FTP_FTP_AUTH_CACHE_H_ |
OLD | NEW |