#616: M1658214 M1637745 M1648372

This commit is contained in:
Cameron Kaiser 2020-08-21 20:31:11 -07:00
parent 6e4dd2257a
commit 5ec6460efb
6 changed files with 29 additions and 1 deletions

View File

@ -4855,6 +4855,12 @@ nsContentUtils::TriggerLink(nsIContent *aContent,
fileName.SetIsVoid(true); // No actionable download attribute was found. fileName.SetIsVoid(true); // No actionable download attribute was found.
} }
// Sanitize fileNames containing null characters by replacing them with
// underscores.
if (!fileName.IsVoid()) {
fileName.ReplaceChar(char16_t(0), '_');
}
nsDocShell::Cast(docShell)->OnLinkClick(aContent, aLinkURI, nsDocShell::Cast(docShell)->OnLinkClick(aContent, aLinkURI,
fileName.IsVoid() ? aTargetSpec.get() : EmptyString().get(), fileName.IsVoid() ? aTargetSpec.get() : EmptyString().get(),
fileName, nullptr, nullptr, aIsTrusted); fileName, nullptr, nullptr, aIsTrusted);

View File

@ -2290,6 +2290,12 @@ ConstructJSImplementation(JSContext* aCx, const char* aContractId,
{ {
AutoNoJSAPI nojsapi; AutoNoJSAPI nojsapi;
nsCOMPtr<nsPIDOMWindow> window = do_QueryInterface(aGlobal);
if (!window->IsCurrentInnerWindow()) {
aRv.Throw(NS_ERROR_FAILURE);
return;
}
// Get the XPCOM component containing the JS implementation. // Get the XPCOM component containing the JS implementation.
nsresult rv; nsresult rv;
nsCOMPtr<nsISupports> implISupports = do_CreateInstance(aContractId, &rv); nsCOMPtr<nsISupports> implISupports = do_CreateInstance(aContractId, &rv);
@ -2304,7 +2310,6 @@ ConstructJSImplementation(JSContext* aCx, const char* aContractId,
// and our global is a window. // and our global is a window.
nsCOMPtr<nsIDOMGlobalPropertyInitializer> gpi = nsCOMPtr<nsIDOMGlobalPropertyInitializer> gpi =
do_QueryInterface(implISupports); do_QueryInterface(implISupports);
nsCOMPtr<nsPIDOMWindow> window = do_QueryInterface(aGlobal);
if (gpi) { if (gpi) {
JS::Rooted<JS::Value> initReturn(aCx); JS::Rooted<JS::Value> initReturn(aCx);
rv = gpi->Init(window, &initReturn); rv = gpi->Init(window, &initReturn);

View File

@ -397,6 +397,7 @@ NS_IMETHODIMP
nsTextInputSelectionImpl::SetCaretReadOnly(bool aReadOnly) nsTextInputSelectionImpl::SetCaretReadOnly(bool aReadOnly)
{ {
if (!mPresShellWeak) return NS_ERROR_NOT_INITIALIZED; if (!mPresShellWeak) return NS_ERROR_NOT_INITIALIZED;
if (!mFrameSelection) return NS_ERROR_FAILURE;
nsresult result; nsresult result;
nsCOMPtr<nsIPresShell> shell = do_QueryReferent(mPresShellWeak, &result); nsCOMPtr<nsIPresShell> shell = do_QueryReferent(mPresShellWeak, &result);
if (shell) if (shell)

View File

@ -575,6 +575,12 @@ NS_IMETHODIMP
nsBaseChannel::SetContentDispositionFilename(const nsAString &aContentDispositionFilename) nsBaseChannel::SetContentDispositionFilename(const nsAString &aContentDispositionFilename)
{ {
mContentDispositionFilename = new nsString(aContentDispositionFilename); mContentDispositionFilename = new nsString(aContentDispositionFilename);
// For safety reasons ensure the filename doesn't contain null characters and
// replace them with underscores. We may later pass the extension to system
// MIME APIs that expect null terminated strings.
mContentDispositionFilename->ReplaceChar(char16_t(0), '_');
return NS_OK; return NS_OK;
} }

View File

@ -509,6 +509,12 @@ NS_IMETHODIMP
HttpBaseChannel::SetContentDispositionFilename(const nsAString& aContentDispositionFilename) HttpBaseChannel::SetContentDispositionFilename(const nsAString& aContentDispositionFilename)
{ {
mContentDispositionFilename = new nsString(aContentDispositionFilename); mContentDispositionFilename = new nsString(aContentDispositionFilename);
// For safety reasons ensure the filename doesn't contain null characters and
// replace them with underscores. We may later pass the extension to system
// MIME APIs that expect null terminated strings.
mContentDispositionFilename->ReplaceChar(char16_t(0), '_');
return NS_OK; return NS_OK;
} }

View File

@ -1288,6 +1288,8 @@ nsExternalAppHandler::nsExternalAppHandler(nsIMIMEInfo * aMIMEInfo,
// replace platform specific path separator and illegal characters to avoid any confusion // replace platform specific path separator and illegal characters to avoid any confusion
mSuggestedFileName.ReplaceChar(KNOWN_PATH_SEPARATORS FILE_ILLEGAL_CHARACTERS, '_'); mSuggestedFileName.ReplaceChar(KNOWN_PATH_SEPARATORS FILE_ILLEGAL_CHARACTERS, '_');
// If null is in an extension, we should assert (see bug 1637745).
mSuggestedFileName.ReplaceChar(char16_t(0), '_');
mTempFileExtension.ReplaceChar(KNOWN_PATH_SEPARATORS FILE_ILLEGAL_CHARACTERS, '_'); mTempFileExtension.ReplaceChar(KNOWN_PATH_SEPARATORS FILE_ILLEGAL_CHARACTERS, '_');
// Remove unsafe bidi characters which might have spoofing implications (bug 511521). // Remove unsafe bidi characters which might have spoofing implications (bug 511521).
@ -2614,6 +2616,8 @@ NS_IMETHODIMP nsExternalHelperAppService::GetFromTypeAndExtension(const nsACStri
NS_PRECONDITION(!aMIMEType.IsEmpty() || NS_PRECONDITION(!aMIMEType.IsEmpty() ||
!aFileExt.IsEmpty(), !aFileExt.IsEmpty(),
"Give me something to work with"); "Give me something to work with");
MOZ_DIAGNOSTIC_ASSERT(aFileExt.FindChar('\0') == kNotFound,
"The extension should never contain null characters");
LOG(("Getting mimeinfo from type '%s' ext '%s'\n", LOG(("Getting mimeinfo from type '%s' ext '%s'\n",
PromiseFlatCString(aMIMEType).get(), PromiseFlatCString(aFileExt).get())); PromiseFlatCString(aMIMEType).get(), PromiseFlatCString(aFileExt).get()));