2014-08-22 20:05:56 -07:00
|
|
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* vim: set sw=2 ts=8 et tw=80 : */
|
|
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
|
|
|
|
#ifndef nsOfflineObserver_h__
|
|
|
|
#define nsOfflineObserver_h__
|
|
|
|
|
|
|
|
#include "nsIObserver.h"
|
|
|
|
|
|
|
|
namespace mozilla {
|
|
|
|
namespace net {
|
|
|
|
|
|
|
|
/**
|
2015-10-17 22:24:48 -07:00
|
|
|
* Parents should extend this class and have a RefPtr<OfflineObserver> member.
|
2014-08-22 20:05:56 -07:00
|
|
|
* The constructor should initialize the member to new OfflineObserver(this)
|
|
|
|
* and the destructor should call RemoveObserver on the member.
|
|
|
|
*
|
|
|
|
* GetAppId and OfflineDisconnect are called from the default implementation
|
|
|
|
* of OfflineNotification. These should be overridden by classes that don't
|
|
|
|
* provide an implementation of OfflineNotification.
|
|
|
|
*/
|
|
|
|
class DisconnectableParent
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
// This is called on the main thread, by the OfflineObserver.
|
|
|
|
// aSubject is of type nsAppOfflineInfo and contains appId and offline mode.
|
|
|
|
virtual nsresult OfflineNotification(nsISupports *aSubject);
|
|
|
|
|
|
|
|
// GetAppId returns the appId for the app associated with the parent
|
2014-08-22 10:15:00 -07:00
|
|
|
virtual uint32_t GetAppId() = 0;
|
2014-08-22 20:05:56 -07:00
|
|
|
|
|
|
|
// OfflineDisconnect cancels all existing connections in the parent when
|
|
|
|
// the app becomes offline.
|
|
|
|
virtual void OfflineDisconnect() { }
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This class observes the "network:app-offline-status-changed" topic and calls
|
|
|
|
* OfflineNotification on the DisconnectableParent with the subject.
|
|
|
|
*/
|
|
|
|
class OfflineObserver
|
|
|
|
: public nsIObserver
|
|
|
|
{
|
|
|
|
NS_DECL_THREADSAFE_ISUPPORTS
|
|
|
|
NS_DECL_NSIOBSERVER
|
|
|
|
public:
|
|
|
|
// A nsRefPtr to this object should be kept by the disconnectable parent.
|
|
|
|
|
2014-12-10 14:49:42 -08:00
|
|
|
explicit OfflineObserver(DisconnectableParent * parent);
|
2014-08-22 20:05:56 -07:00
|
|
|
// This method needs to be called in the destructor of the parent
|
|
|
|
// It removes the observer from the nsObserverService list, and it clears
|
|
|
|
// the pointer it holds to the disconnectable parent.
|
|
|
|
void RemoveObserver();
|
|
|
|
private:
|
|
|
|
|
|
|
|
// These methods are called to register and unregister the observer.
|
|
|
|
// If they are called on the main thread they register the observer right
|
|
|
|
// away, otherwise they dispatch and event to the main thread
|
|
|
|
void RegisterOfflineObserver();
|
|
|
|
void RemoveOfflineObserver();
|
|
|
|
void RegisterOfflineObserverMainThread();
|
|
|
|
void RemoveOfflineObserverMainThread();
|
|
|
|
private:
|
|
|
|
virtual ~OfflineObserver() { }
|
|
|
|
DisconnectableParent * mParent;
|
|
|
|
};
|
|
|
|
|
2015-07-13 08:25:42 -07:00
|
|
|
} // namespace net
|
|
|
|
} // namespace mozilla
|
2014-08-22 20:05:56 -07:00
|
|
|
|
|
|
|
#endif // nsOfflineObserver_h__
|