Source code

Revision control

Copy as Markdown

Other Tools

/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim:set ts=2 sw=2 sts=2 et cindent: */
/* 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 nsUpdateSyncManager_h__
#define nsUpdateSyncManager_h__
#include "mozilla/AlreadyAddRefed.h"
#include "nsIObserver.h"
#include "nsIUpdateService.h"
#include "MultiInstanceLock.h"
// The update sync manager is responsible for making sure that only one
// instance of the application is running at the time we want to start updating
// it. It does this by taking a multi-instance lock very early during the
// application's startup process. Then, when app update tasks are ready to run,
// the update service asks us whether anything else has also taken that lock,
// which, if true, would mean another instance of the application is currently
// running and performing update tasks should be avoided (the update service
// also runs a timeout and eventually goes ahead with the update in order to
// prevent an external program from effectively disabling updates).
class nsUpdateSyncManager final : public nsIUpdateSyncManager,
public nsIObserver {
public:
explicit nsUpdateSyncManager(nsIFile* anAppFile = nullptr);
NS_DECL_THREADSAFE_ISUPPORTS
NS_DECL_NSIUPDATESYNCMANAGER
NS_DECL_NSIOBSERVER
static already_AddRefed<nsUpdateSyncManager> GetSingleton();
private:
~nsUpdateSyncManager();
nsUpdateSyncManager(nsUpdateSyncManager&) = delete;
nsUpdateSyncManager(nsUpdateSyncManager&&) = delete;
nsUpdateSyncManager& operator=(nsUpdateSyncManager&) = delete;
nsUpdateSyncManager& operator=(nsUpdateSyncManager&&) = delete;
nsresult OpenLock(nsIFile* anAppFile = nullptr);
void ReleaseLock();
mozilla::MultiInstLockHandle mLock = MULTI_INSTANCE_LOCK_HANDLE_ERROR;
};
#endif // nsUpdateSyncManager_h__