nsJARChannel now gets its owner from the underlying nsJAR, for the correct security level. bug=7270 r=norris

This commit is contained in:
mstoltz%netscape.com 2000-01-29 00:06:15 +00:00
parent a5072b2c43
commit da00e27857
2 changed files with 24 additions and 0 deletions

View File

@ -28,6 +28,7 @@
#include "nsIMIMEService.h"
#include "nsAutoLock.h"
#include "nsIFileStreams.h"
#include "nsIPrincipal.h"
static NS_DEFINE_CID(kFileTransportServiceCID, NS_FILETRANSPORTSERVICE_CID);
static NS_DEFINE_CID(kMIMEServiceCID, NS_MIMESERVICE_CID);
@ -545,6 +546,17 @@ nsJARChannel::SetLoadGroup(nsILoadGroup* aLoadGroup)
NS_IMETHODIMP
nsJARChannel::GetOwner(nsISupports* *aOwner)
{
if (!mOwner)
{
nsIPrincipal* principal;
nsresult rv = mJAR->GetPrincipal(mJAREntry, &principal);
if (NS_SUCCEEDED(rv) && principal)
mOwner = do_QueryInterface(principal);
else
mOwner = null_nsCOMPtr();
NS_IF_RELEASE(principal);
}
*aOwner = mOwner.get();
NS_IF_ADDREF(*aOwner);
return NS_OK;

View File

@ -28,6 +28,7 @@
#include "nsIMIMEService.h"
#include "nsAutoLock.h"
#include "nsIFileStreams.h"
#include "nsIPrincipal.h"
static NS_DEFINE_CID(kFileTransportServiceCID, NS_FILETRANSPORTSERVICE_CID);
static NS_DEFINE_CID(kMIMEServiceCID, NS_MIMESERVICE_CID);
@ -545,6 +546,17 @@ nsJARChannel::SetLoadGroup(nsILoadGroup* aLoadGroup)
NS_IMETHODIMP
nsJARChannel::GetOwner(nsISupports* *aOwner)
{
if (!mOwner)
{
nsIPrincipal* principal;
nsresult rv = mJAR->GetPrincipal(mJAREntry, &principal);
if (NS_SUCCEEDED(rv) && principal)
mOwner = do_QueryInterface(principal);
else
mOwner = null_nsCOMPtr();
NS_IF_RELEASE(principal);
}
*aOwner = mOwner.get();
NS_IF_ADDREF(*aOwner);
return NS_OK;