/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* vim: set ts=8 sts=2 et sw=2 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 mozilla_ipc_backgroundutils_h__ #define mozilla_ipc_backgroundutils_h__ #include "ipc/IPCMessageUtils.h" #include "mozilla/Attributes.h" #include "mozilla/BasePrincipal.h" #include "nsCOMPtr.h" #include "nscore.h" class nsILoadInfo; class nsIPrincipal; class nsIRedirectHistoryEntry; namespace IPC { namespace detail { template struct OriginAttributesParamTraits { typedef ParamType paramType; static void Write(Message* aMsg, const paramType& aParam) { nsAutoCString suffix; aParam.CreateSuffix(suffix); WriteParam(aMsg, suffix); } static bool Read(const Message* aMsg, PickleIterator* aIter, paramType* aResult) { nsAutoCString suffix; return ReadParam(aMsg, aIter, &suffix) && aResult->PopulateFromSuffix(suffix); } }; } // namespace detail template <> struct ParamTraits : public detail::OriginAttributesParamTraits {}; } // namespace IPC namespace mozilla { namespace net { class ChildLoadInfoForwarderArgs; class LoadInfoArgs; class ParentLoadInfoForwarderArgs; class RedirectHistoryEntryInfo; } // namespace net namespace ipc { class ContentSecurityPolicy; class PrincipalInfo; /** * Convert a PrincipalInfo to an nsIPrincipal. * * MUST be called on the main thread only. */ already_AddRefed PrincipalInfoToPrincipal( const PrincipalInfo& aPrincipalInfo, nsresult* aOptionalResult = nullptr); /** * Populate an array of ContentSecurityPolicy objects from a CSP object. * * MUST be called on the main thread only. */ nsresult PopulateContentSecurityPolicies( nsIContentSecurityPolicy* aCSP, nsTArray& aPolicies); /** * Convert an nsIPrincipal to a PrincipalInfo. * * MUST be called on the main thread only. */ nsresult PrincipalToPrincipalInfo(nsIPrincipal* aPrincipal, PrincipalInfo* aPrincipalInfo); /** * Return true if this PrincipalInfo is a content principal and it has * a privateBrowsing id in its OriginAttributes */ bool IsPincipalInfoPrivate(const PrincipalInfo& aPrincipalInfo); /** * Convert an RedirectHistoryEntryInfo to a nsIRedirectHistoryEntry. */ already_AddRefed RHEntryInfoToRHEntry( const mozilla::net::RedirectHistoryEntryInfo& aRHEntryInfo); /** * Convert an nsIRedirectHistoryEntry to a RedirectHistoryEntryInfo. */ nsresult RHEntryToRHEntryInfo( nsIRedirectHistoryEntry* aRHEntry, mozilla::net::RedirectHistoryEntryInfo* aRHEntryInfo); /** * Convert a LoadInfo to LoadInfoArgs struct. */ nsresult LoadInfoToLoadInfoArgs( nsILoadInfo* aLoadInfo, Maybe* outOptionalLoadInfoArgs); /** * Convert LoadInfoArgs to a LoadInfo. */ nsresult LoadInfoArgsToLoadInfo( const Maybe& aOptionalLoadInfoArgs, nsILoadInfo** outLoadInfo); /** * Fills ParentLoadInfoForwarderArgs with properties we want to carry to child * processes. */ void LoadInfoToParentLoadInfoForwarder( nsILoadInfo* aLoadInfo, mozilla::net::ParentLoadInfoForwarderArgs* aForwarderArgsOut); /** * Merges (replaces) properties of an existing LoadInfo on a child process * with properties carried down through ParentLoadInfoForwarderArgs. */ nsresult MergeParentLoadInfoForwarder( mozilla::net::ParentLoadInfoForwarderArgs const& aForwarderArgs, nsILoadInfo* aLoadInfo); /** * Fills ChildLoadInfoForwarderArgs with properties we want to carry to the * parent process after the initial channel creation. */ void LoadInfoToChildLoadInfoForwarder( nsILoadInfo* aLoadInfo, mozilla::net::ChildLoadInfoForwarderArgs* aForwarderArgsOut); /** * Merges (replaces) properties of an existing LoadInfo on the parent process * with properties contained in a ChildLoadInfoForwarderArgs. */ nsresult MergeChildLoadInfoForwarder( const mozilla::net::ChildLoadInfoForwarderArgs& aForwardArgs, nsILoadInfo* aLoadInfo); } // namespace ipc } // namespace mozilla #endif // mozilla_ipc_backgroundutils_h__