blob: ec49419ffb353d6503e100766d47701e04c87165 [file] [log] [blame]
// Copyright (c) 2012 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 CONTENT_PUBLIC_BROWSER_SESSION_STORAGE_NAMESPACE_H_
#define CONTENT_PUBLIC_BROWSER_SESSION_STORAGE_NAMESPACE_H_
#include <string>
#include "base/basictypes.h"
#include "base/callback.h"
#include "base/memory/ref_counted.h"
namespace content {
// This is a ref-counted class that represents a SessionStorageNamespace.
// On destruction it ensures that the storage namespace is destroyed.
class SessionStorageNamespace
: public base::RefCountedThreadSafe<SessionStorageNamespace> {
public:
// Returns the ID of the |SessionStorageNamespace|. The ID is unique among all
// SessionStorageNamespace objects, but not unique across browser runs.
virtual int64 id() const = 0;
// Returns the persistent ID for the |SessionStorageNamespace|. The ID is
// unique across browser runs.
virtual const std::string& persistent_id() const = 0;
// For marking that the sessionStorage will be needed or won't be needed by
// session restore.
virtual void SetShouldPersist(bool should_persist) = 0;
virtual bool should_persist() const = 0;
// SessionStorageNamespaces can be merged. These merges happen based on
// a transaction log of operations on the session storage namespace since
// this function has been called. Transaction logging will be restricted
// to the processes indicated.
virtual void AddTransactionLogProcessId(int process_id) = 0;
// When transaction logging for a process is no longer required, the log
// can be removed to save space.
virtual void RemoveTransactionLogProcessId(int process_id) = 0;
// Creates a new session storage namespace which is an alias of the current
// instance.
virtual SessionStorageNamespace* CreateAlias() = 0;
enum MergeResult {
MERGE_RESULT_NAMESPACE_NOT_FOUND,
MERGE_RESULT_NAMESPACE_NOT_ALIAS,
MERGE_RESULT_NOT_LOGGING,
MERGE_RESULT_NO_TRANSACTIONS,
MERGE_RESULT_TOO_MANY_TRANSACTIONS,
MERGE_RESULT_NOT_MERGEABLE,
MERGE_RESULT_MERGEABLE,
MERGE_RESULT_MAX_VALUE
};
typedef base::Callback<void(MergeResult)> MergeResultCallback;
// Determines whether the transaction log for the process specified can
// be merged into the other session storage namespace supplied.
// If actually_merge is set to true, the merge will actually be performed,
// if possible, and the result of the merge will be returned.
// If actually_merge is set to false, the result of whether a merge would be
// possible is returned.
virtual void Merge(bool actually_merge,
int process_id,
SessionStorageNamespace* other,
const MergeResultCallback& callback) = 0;
// Indicates whether this SessionStorageNamespace is an alias of |other|,
// i.e. whether they point to the same underlying data.
virtual bool IsAliasOf(SessionStorageNamespace* other) = 0;
protected:
friend class base::RefCountedThreadSafe<SessionStorageNamespace>;
virtual ~SessionStorageNamespace() {}
};
} // namespace content
#endif // CONTENT_PUBLIC_BROWSER_SESSION_STORAGE_NAMESPACE_H_