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__ |