Chromium Code Reviews| Index: chrome/browser/extensions/api/sessions/session_id.h |
| diff --git a/chrome/common/extensions/permissions/media_galleries_permission_data.h b/chrome/browser/extensions/api/sessions/session_id.h |
| similarity index 19% |
| copy from chrome/common/extensions/permissions/media_galleries_permission_data.h |
| copy to chrome/browser/extensions/api/sessions/session_id.h |
| index 896242d6d9f0344b786e089d040770420c53a623..7394351912cd8d18d8ea6bc1886fae5018d3fb95 100644 |
| --- a/chrome/common/extensions/permissions/media_galleries_permission_data.h |
| +++ b/chrome/browser/extensions/api/sessions/session_id.h |
| @@ -2,50 +2,50 @@ |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| -#ifndef CHROME_COMMON_EXTENSIONS_PERMISSIONS_MEDIA_GALLERIES_PERMISSION_DATA_H_ |
| -#define CHROME_COMMON_EXTENSIONS_PERMISSIONS_MEDIA_GALLERIES_PERMISSION_DATA_H_ |
| +#ifndef CHROME_BROWSER_EXTENSIONS_API_SESSIONS_SESSION_ID_H__ |
| +#define CHROME_BROWSER_EXTENSIONS_API_SESSIONS_SESSION_ID_H__ |
| #include <string> |
| #include "base/basictypes.h" |
| #include "base/memory/scoped_ptr.h" |
| -#include "chrome/common/extensions/permissions/api_permission.h" |
| - |
| -namespace base { |
| -class Value; |
| -} |
| namespace extensions { |
| -// A MediaGalleriesPermissionData instance represents a single part of the |
| -// MediaGalleriesPermission. e.g. "read" or "allAutoDetected". |
| -class MediaGalleriesPermissionData { |
| +class SessionId { |
| public: |
| - MediaGalleriesPermissionData(); |
| + // Constructs a SessionId object for the given session information. |
|
not at google - send to devlin
2013/08/15 20:16:24
wow. git. weird. damn.
can worry about fixing thi
|
| + // |session_tag| is the string used to uniquely identify a synced foreign |
| + // session from the SessionModelAssociator. In the case that SessionId |
| + // represents a local session, |session_tag_| will be the empty string. |id| |
| + // uniquely identifies either a window or tab object in the local or the |
| + // |session_tag| session. |
| + SessionId(const std::string& session_tag, int id); |
| - // Check if |param| (which must be a MediaGalleriesPermission::CheckParam) |
| - // matches the encapsulated attribute. |
| - bool Check(const APIPermission::CheckParam* param) const; |
| + // Returns a SessionId, representing either a local or a foreign session. |
| + // In the case that the session is local, |session_tag_| will be empty string. |
| + static scoped_ptr<SessionId> Parse(const std::string& session_string); |
|
not at google - send to devlin
2013/08/15 20:16:24
put static methods first. You should also mention
Kristen Dwan
2013/08/16 22:03:06
Done.
|
| - // Convert |this| into a base::Value. |
| - scoped_ptr<base::Value> ToValue() const; |
| + // Returns true if the SessionId represents a foreign session. |
| + bool IsForeign() const; |
| - // Populate |this| from a base::Value. |
| - bool FromValue(const base::Value* value); |
| + // Returns the compressed std::string representation of a SessionId. |
| + std::string ToString() const; |
| - bool operator<(const MediaGalleriesPermissionData& rhs) const; |
| - bool operator==(const MediaGalleriesPermissionData& rhs) const; |
| + const std::string& session_tag() const { return session_tag_; } |
| + int id() const { return id_; } |
| - std::string permission() const { return permission_; } |
| + private: |
| + // The unique identifier for a foreign session, given by the |
| + // SessionModelAssociator. |
| + std::string session_tag_; |
| - // This accessor is provided for IPC_STRUCT_TRAITS_MEMBER. Please think |
| - // twice before using it for anything else. |
| - std::string& permission() { return permission_; } |
| + // ID corresponding to a window or tab object. |
| + int id_; |
| - private: |
| - std::string permission_; |
| + DISALLOW_COPY_AND_ASSIGN(SessionId); |
| }; |
| } // namespace extensions |
| -#endif // CHROME_COMMON_EXTENSIONS_PERMISSIONS_MEDIA_GALLERIES_PERMISSION_DATA_H_ |
| +#endif // CHROME_BROWSER_EXTENSIONS_API_SESSIONS_SESSION_ID_H__ |