2015-05-03 22:32:37 +03:00
|
|
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
2014-09-27 03:21:57 +04:00
|
|
|
/* 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 mozilla_dom_ipc_BlobChild_h
|
|
|
|
#define mozilla_dom_ipc_BlobChild_h
|
|
|
|
|
|
|
|
#include "mozilla/Attributes.h"
|
|
|
|
#include "mozilla/dom/PBlobChild.h"
|
|
|
|
#include "nsCOMPtr.h"
|
|
|
|
#include "nsID.h"
|
|
|
|
|
|
|
|
class nsIEventTarget;
|
|
|
|
class nsIRemoteBlob;
|
|
|
|
class nsString;
|
|
|
|
|
|
|
|
namespace mozilla {
|
|
|
|
namespace ipc {
|
|
|
|
|
|
|
|
class PBackgroundChild;
|
|
|
|
|
|
|
|
} // namespace ipc
|
|
|
|
|
|
|
|
namespace dom {
|
|
|
|
|
2015-06-23 02:31:28 +03:00
|
|
|
class Blob;
|
2015-05-12 15:11:03 +03:00
|
|
|
class BlobImpl;
|
2014-09-27 03:21:57 +04:00
|
|
|
class ContentChild;
|
|
|
|
class nsIContentChild;
|
|
|
|
class PBlobStreamChild;
|
|
|
|
|
2016-03-20 05:44:22 +03:00
|
|
|
enum BlobDirState : uint32_t;
|
|
|
|
|
2015-03-21 19:28:04 +03:00
|
|
|
class BlobChild final
|
2014-09-27 03:21:57 +04:00
|
|
|
: public PBlobChild
|
|
|
|
{
|
|
|
|
typedef mozilla::ipc::PBackgroundChild PBackgroundChild;
|
|
|
|
|
|
|
|
class RemoteBlobImpl;
|
|
|
|
friend class RemoteBlobImpl;
|
|
|
|
|
2014-10-08 03:09:55 +04:00
|
|
|
class RemoteBlobSliceImpl;
|
|
|
|
friend class RemoteBlobSliceImpl;
|
|
|
|
|
2015-05-12 15:11:03 +03:00
|
|
|
BlobImpl* mBlobImpl;
|
2014-09-27 03:21:57 +04:00
|
|
|
RemoteBlobImpl* mRemoteBlobImpl;
|
|
|
|
|
|
|
|
// One of these will be null and the other non-null.
|
|
|
|
PBackgroundChild* mBackgroundManager;
|
|
|
|
nsCOMPtr<nsIContentChild> mContentManager;
|
|
|
|
|
|
|
|
nsCOMPtr<nsIEventTarget> mEventTarget;
|
|
|
|
|
|
|
|
nsID mParentID;
|
|
|
|
|
|
|
|
bool mOwnsBlobImpl;
|
|
|
|
|
|
|
|
public:
|
|
|
|
class FriendKey;
|
|
|
|
|
|
|
|
static void
|
|
|
|
Startup(const FriendKey& aKey);
|
|
|
|
|
|
|
|
// These create functions are called on the sending side.
|
|
|
|
static BlobChild*
|
2015-05-12 15:11:03 +03:00
|
|
|
GetOrCreate(nsIContentChild* aManager, BlobImpl* aBlobImpl);
|
2014-09-27 03:21:57 +04:00
|
|
|
|
|
|
|
static BlobChild*
|
2015-05-12 15:11:03 +03:00
|
|
|
GetOrCreate(PBackgroundChild* aManager, BlobImpl* aBlobImpl);
|
2014-09-27 03:21:57 +04:00
|
|
|
|
|
|
|
// These create functions are called on the receiving side.
|
|
|
|
static BlobChild*
|
|
|
|
Create(nsIContentChild* aManager, const ChildBlobConstructorParams& aParams);
|
|
|
|
|
|
|
|
static BlobChild*
|
|
|
|
Create(PBackgroundChild* aManager,
|
|
|
|
const ChildBlobConstructorParams& aParams);
|
|
|
|
|
|
|
|
static void
|
|
|
|
Destroy(PBlobChild* aActor)
|
|
|
|
{
|
|
|
|
delete static_cast<BlobChild*>(aActor);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
HasManager() const
|
|
|
|
{
|
|
|
|
return mBackgroundManager || mContentManager;
|
|
|
|
}
|
|
|
|
|
|
|
|
PBackgroundChild*
|
|
|
|
GetBackgroundManager() const
|
|
|
|
{
|
|
|
|
return mBackgroundManager;
|
|
|
|
}
|
|
|
|
|
|
|
|
nsIContentChild*
|
|
|
|
GetContentManager() const
|
|
|
|
{
|
|
|
|
return mContentManager;
|
|
|
|
}
|
|
|
|
|
|
|
|
const nsID&
|
|
|
|
ParentID() const;
|
|
|
|
|
2015-05-12 15:11:03 +03:00
|
|
|
// Get the BlobImpl associated with this actor. This may always be called
|
2014-09-27 03:21:57 +04:00
|
|
|
// on the sending side. It may also be called on the receiving side unless
|
|
|
|
// this is a "mystery" blob that has not yet received a SetMysteryBlobInfo()
|
|
|
|
// call.
|
2015-05-12 15:11:03 +03:00
|
|
|
already_AddRefed<BlobImpl>
|
2014-09-27 03:21:57 +04:00
|
|
|
GetBlobImpl();
|
|
|
|
|
|
|
|
// Use this for files.
|
|
|
|
bool
|
|
|
|
SetMysteryBlobInfo(const nsString& aName,
|
|
|
|
const nsString& aContentType,
|
|
|
|
uint64_t aLength,
|
2016-03-20 05:44:22 +03:00
|
|
|
int64_t aLastModifiedDate,
|
|
|
|
BlobDirState aDirState);
|
2014-09-27 03:21:57 +04:00
|
|
|
|
|
|
|
// Use this for non-file blobs.
|
|
|
|
bool
|
|
|
|
SetMysteryBlobInfo(const nsString& aContentType, uint64_t aLength);
|
|
|
|
|
|
|
|
void
|
|
|
|
AssertIsOnOwningThread() const
|
|
|
|
#ifdef DEBUG
|
|
|
|
;
|
|
|
|
#else
|
|
|
|
{ }
|
|
|
|
#endif
|
|
|
|
|
|
|
|
private:
|
|
|
|
// These constructors are called on the sending side.
|
2015-05-12 15:11:03 +03:00
|
|
|
BlobChild(nsIContentChild* aManager, BlobImpl* aBlobImpl);
|
2014-09-27 03:21:57 +04:00
|
|
|
|
2015-05-12 15:11:03 +03:00
|
|
|
BlobChild(PBackgroundChild* aManager, BlobImpl* aBlobImpl);
|
2014-09-27 03:21:57 +04:00
|
|
|
|
|
|
|
BlobChild(nsIContentChild* aManager, BlobChild* aOther);
|
|
|
|
|
2015-05-12 15:11:03 +03:00
|
|
|
BlobChild(PBackgroundChild* aManager, BlobChild* aOther, BlobImpl* aBlobImpl);
|
2014-09-27 03:21:57 +04:00
|
|
|
|
|
|
|
// These constructors are called on the receiving side.
|
|
|
|
BlobChild(nsIContentChild* aManager,
|
|
|
|
const ChildBlobConstructorParams& aParams);
|
|
|
|
|
|
|
|
BlobChild(PBackgroundChild* aManager,
|
|
|
|
const ChildBlobConstructorParams& aParams);
|
|
|
|
|
2014-10-08 03:09:55 +04:00
|
|
|
// These constructors are called for slices.
|
|
|
|
BlobChild(nsIContentChild* aManager,
|
|
|
|
const nsID& aParentID,
|
|
|
|
RemoteBlobSliceImpl* aRemoteBlobSliceImpl);
|
|
|
|
|
|
|
|
BlobChild(PBackgroundChild* aManager,
|
|
|
|
const nsID& aParentID,
|
|
|
|
RemoteBlobSliceImpl* aRemoteBlobSliceImpl);
|
|
|
|
|
2014-09-27 03:21:57 +04:00
|
|
|
// Only called by Destroy().
|
|
|
|
~BlobChild();
|
|
|
|
|
|
|
|
void
|
2015-05-12 15:11:03 +03:00
|
|
|
CommonInit(BlobImpl* aBlobImpl);
|
2014-09-27 03:21:57 +04:00
|
|
|
|
|
|
|
void
|
2015-05-12 15:11:03 +03:00
|
|
|
CommonInit(BlobChild* aOther, BlobImpl* aBlobImpl);
|
2014-09-27 03:21:57 +04:00
|
|
|
|
|
|
|
void
|
|
|
|
CommonInit(const ChildBlobConstructorParams& aParams);
|
|
|
|
|
2014-10-08 03:09:55 +04:00
|
|
|
void
|
|
|
|
CommonInit(const nsID& aParentID, RemoteBlobImpl* aRemoteBlobImpl);
|
|
|
|
|
2014-09-27 03:21:57 +04:00
|
|
|
template <class ChildManagerType>
|
|
|
|
static BlobChild*
|
2015-05-12 15:11:03 +03:00
|
|
|
GetOrCreateFromImpl(ChildManagerType* aManager, BlobImpl* aBlobImpl);
|
2014-09-27 03:21:57 +04:00
|
|
|
|
|
|
|
template <class ChildManagerType>
|
|
|
|
static BlobChild*
|
|
|
|
CreateFromParams(ChildManagerType* aManager,
|
|
|
|
const ChildBlobConstructorParams& aParams);
|
|
|
|
|
|
|
|
template <class ChildManagerType>
|
|
|
|
static BlobChild*
|
|
|
|
SendSliceConstructor(ChildManagerType* aManager,
|
2014-10-08 03:09:55 +04:00
|
|
|
RemoteBlobSliceImpl* aRemoteBlobSliceImpl,
|
|
|
|
const ParentBlobConstructorParams& aParams);
|
2014-09-27 03:21:57 +04:00
|
|
|
|
|
|
|
static BlobChild*
|
|
|
|
MaybeGetActorFromRemoteBlob(nsIRemoteBlob* aRemoteBlob,
|
2014-12-17 09:26:15 +03:00
|
|
|
nsIContentChild* aManager,
|
2015-05-12 15:11:03 +03:00
|
|
|
BlobImpl* aBlobImpl);
|
2014-09-27 03:21:57 +04:00
|
|
|
|
|
|
|
static BlobChild*
|
|
|
|
MaybeGetActorFromRemoteBlob(nsIRemoteBlob* aRemoteBlob,
|
2014-12-17 09:26:15 +03:00
|
|
|
PBackgroundChild* aManager,
|
2015-05-12 15:11:03 +03:00
|
|
|
BlobImpl* aBlobImpl);
|
2014-09-27 03:21:57 +04:00
|
|
|
|
|
|
|
void
|
|
|
|
NoteDyingRemoteBlobImpl();
|
|
|
|
|
|
|
|
nsIEventTarget*
|
|
|
|
EventTarget() const
|
|
|
|
{
|
|
|
|
return mEventTarget;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
IsOnOwningThread() const;
|
|
|
|
|
|
|
|
// These methods are only called by the IPDL message machinery.
|
|
|
|
virtual void
|
2015-03-21 19:28:04 +03:00
|
|
|
ActorDestroy(ActorDestroyReason aWhy) override;
|
2014-09-27 03:21:57 +04:00
|
|
|
|
|
|
|
virtual PBlobStreamChild*
|
2014-10-08 03:09:55 +04:00
|
|
|
AllocPBlobStreamChild(const uint64_t& aStart,
|
2015-03-21 19:28:04 +03:00
|
|
|
const uint64_t& aLength) override;
|
2014-09-27 03:21:57 +04:00
|
|
|
|
|
|
|
virtual bool
|
2015-03-21 19:28:04 +03:00
|
|
|
DeallocPBlobStreamChild(PBlobStreamChild* aActor) override;
|
2015-11-28 13:48:28 +03:00
|
|
|
|
|
|
|
virtual bool
|
|
|
|
RecvCreatedFromKnownBlob() override;
|
2014-09-27 03:21:57 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
// Only let ContentChild call BlobChild::Startup() and ensure that
|
|
|
|
// ContentChild can't access any other BlobChild internals.
|
2015-03-21 19:28:04 +03:00
|
|
|
class BlobChild::FriendKey final
|
2014-09-27 03:21:57 +04:00
|
|
|
{
|
|
|
|
friend class ContentChild;
|
|
|
|
|
|
|
|
private:
|
|
|
|
FriendKey()
|
|
|
|
{ }
|
|
|
|
|
|
|
|
FriendKey(const FriendKey& /* aOther */)
|
|
|
|
{ }
|
|
|
|
|
|
|
|
public:
|
|
|
|
~FriendKey()
|
|
|
|
{ }
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace dom
|
|
|
|
} // namespace mozilla
|
|
|
|
|
|
|
|
#endif // mozilla_dom_ipc_BlobChild_h
|