Closed
Bug 1055238
Opened 10 years ago
Closed 10 years ago
[B2G][Browser] Self-Signed/Untrusted/Expired SSL certificate warnings are not displaying
Categories
(Core :: Security: PSM, defect)
Core
Security: PSM
Tracking
()
People
(Reporter: jdegeus, Assigned: keeler)
References
Details
(Keywords: regression, Whiteboard: [2.1-flame-test-run-1] [2.1-flame-test-run-2])
Attachments
(6 files, 1 obsolete file)
310.23 KB,
text/plain
|
Details | |
25.19 KB,
image/png
|
Details | |
15.67 KB,
patch
|
rbarnes
:
review+
bajaj
:
approval-mozilla-aurora+
|
Details | Diff | Splinter Review |
6.93 KB,
patch
|
keeler
:
review+
bajaj
:
approval-mozilla-aurora+
|
Details | Diff | Splinter Review |
953.63 KB,
video/mp4
|
Details | |
2.25 MB,
video/3gpp
|
Details |
Description:
When navigating to a website that has a untrusted/expired SSL certificate, users will observe the page loads to a blank screen and not display the SSL certificate.
Repro Steps:
1) Update a Flame to 20140818040201
2) Navigate to https://tv.eurosport.com
3) Observe lack of SSL warning
Actual:
Expired SSL certificate webpage is not displaying
Expected:
Webpage with warnings for the expired SSL certificate displays
Environmental Variables:
Device: Flame Master (319mb)
Build ID: 20140818040201
Gaia: aa8aace12d65956dd9525da5dac66e0d3b28597f
Gecko: 0aaa2d3d15cc
Version: 34.0a1 (Master)
Firmware Version: v123
User Agent: Mozilla/5.0 (Mobile; rv:34.0) Gecko/34.0 Firefox/34.0
Repro frequency: 3/3
Link to failed test case: https://moztrap.mozilla.org/manage/case/6757/
See attached: Screenshot and logcat
Reporter | ||
Comment 1•10 years ago
|
||
This issue DOES occur on Flame 2.1 (512mb) and Buri 2.1
Actual: Expired/untrusted SSL certificate warning page is not displaying
Flame 2.1 (512mb)
Environmental Variables:
Device: Flame Master
BuildID: 20140818040201
Gaia: aa8aace12d65956dd9525da5dac66e0d3b28597f
Gecko: 0aaa2d3d15cc
Version: 34.0a1 (Master)
Firmware Version: v123
User Agent: Mozilla/5.0 (Mobile; rv:34.0) Gecko/34.0 Firefox/34.0
Buri 2.1
Environmental Variables:
Device: Buri 2.1 Master
BuildID: 20140818073016
Gaia: ba1992f2addc5a84afc2eab426f222a6bf2962ba
Gecko: bf27e27c994d
Version: 34.0a1 (2.1 Master)
Firmware: v1.2device.cfg
User Agent: Mozilla/5.0 (Mobile; rv:33.0) Gecko/33.0 Firefox/33.0
--------------------------------------------------------------------------------
This issue DOES NOT occur on Flame 2.0 (319mb), Flame 1.4 (319mb), Buri 2.1, Buri 2.0, Buri 1.4, Open C 2.0, and Open C 1.4
Actual: Expired SSL Certificate displays correctly
Flame 2.0 (319mb)
Device: Flame 2.0
BuildID: 20140818000201
Gaia: fb2dd31abed2803eb7ad67eb4c52abb48de1e0f7
Gecko: 09f7a7184c71
Version: 32.0 (2.0)
Firmware Version: v123
User Agent: Mozilla/5.0 (Mobile; rv:32.0) Gecko/32.0 Firefox/32.0
Buri 2.0
Environmental Variables:
Device: Buri 2.0
Build ID: 20140818063008
Gaia: 640ce38ca03f1e26a4524ff4215b8b3f7731e2f0
Gecko: 692c93509dc9
Version: 32.0 (2.0)
Firmware Version: v1.2device.cfg
User Agent: Mozilla/5.0 (Mobile; rv:32.0) Gecko/32.0 Firefox/32.0
Flags: needinfo?(ktucker)
Reporter | ||
Updated•10 years ago
|
QA Whiteboard: [QAnalyst-Triage?]
Keywords: regression
Updated•10 years ago
|
Component: Gaia::Browser → Gaia::System
Reporter | ||
Updated•10 years ago
|
Summary: [B2G][Browser] Expired SSL certificate warnings are not displaying → [B2G][Browser] Self-Signed/Untrusted/Expired SSL certificate warnings are not displaying
Comment 2•10 years ago
|
||
Please correct your branch checks. You are missing environmental variables.
QA Whiteboard: [QAnalyst-Triage?] → [QAnalyst-Triage-]
Flags: needinfo?(ktucker) → needinfo?(jdegeus)
Reporter | ||
Comment 3•10 years ago
|
||
Please ignore comment 1 as my environmental variables were not correct.
This DOES OCCUR on Flame 2.1(512mb), Buri 2.1, Open C 2.1
Actual: Expired/untrusted SSL certificate warning page is not displaying
Flame 2.1 (512mb)
Environmental Variables:
Device: Flame Master
BuildID: 20140820040203193
Gaia: df39c463259d348396ef7f143c2c780eeb8f02d8
Gecko: ffdd1a398105
Version: 34.0a1 (Master)
Firmware Version: v123
User Agent: Mozilla/5.0 (Mobile; rv:34.0) Gecko/34.0 Firefox/34.0
Buri 2.1
Environmental Variables:
Device: Buri Master
Build ID: 20140820073027
Gaia: 33d4b999f464fbad1c23d488da4689c5de9967ec
Gecko: cbbc380f1e1c
Version: 34.0a1 (Master)
Firmware Version: v1.2device.cfg
User Agent: Mozilla/5.0 (Mobile; rv:34.0) Gecko/34.0 Firefox/34.0
Open C 2.1
Environmental Variables:
Device: Open_C Master
Build ID: 20140820040203
Gaia: df39c463259d348396ef7f143c2c780eeb8f02d8
Gecko: ffdd1a398105
Version: 34.0a1 (Master)
Firmware Version: P821A10V1.0.0B06_LOG_DL
User Agent: Mozilla/5.0 (Mobile; rv:34.0) Gecko/34.0 Firefox/34.0
---------------------------------------------------------------------
This does NOT occur on Flame 2.0(319mb), Flame 1.4 (319mb), Buri 2.0, Open C 2.0
Flame 2.0 (319mb)
Environmental Variables:
Device: Flame 2.0
BuildID: 20140820000201
Gaia: 88db39a0826086024631049d83ae6aa397f0918d
Gecko: 2092ac87eceb
Version: 32.0 (2.0)
Firmware Version: v123
User Agent: Mozilla/5.0 (Mobile; rv:32.0) Gecko/32.0 Firefox/32.0
Flame 1.4 (319mb)
Environmental Variables:
Device: Flame 1.4
Build ID: 20140820003001
Gaia: 4f92950e6d96326785a249e8acb704da3647616b
Gecko: e1de5a959089
Version: 30.0 (1.4)
Firmware Version: v123
User Agent: Mozilla/5.0 (Mobile; rv:30.0) Gecko/30.0 Firefox/30.0
Buri 2.0
Environmental Variables:
Device: Buri 2.0
BuildID: 20140819183013
Gaia: 88db39a0826086024631049d83ae6aa397f0918d
Gecko: 2092ac87eceb
Version: 32.0 (2.0)
Firmware: v1.2device.cfg
User Agent: Mozilla/5.0 (Mobile; rv:32.0) Gecko/32.0 Firefox/32.0
Open C 2.0
Environmental Variables:
Device: Open_C 2.0
BuildID: 20140820000201
Gaia: 88db39a0826086024631049d83ae6aa397f0918d
Gecko: 2092ac87eceb
Version: 32.0 (2.0)
Firmware Version: P821A10V1.0.0B06_LOG_DL
User Agent: Mozilla/5.0 (Mobile; rv:32.0) Gecko/32.0 Firefox/32.0
QA Whiteboard: [QAnalyst-Triage-] → [QAnalyst-Triage?]
Flags: needinfo?(jdegeus) → needinfo?(ktucker)
Comment 4•10 years ago
|
||
[Blocking Requested - why for this release]:
Possibly a dupe of bug 1055328
This is a regression from 2.0 and the page just loads to a blank page so nominating to block 2.1?
blocking-b2g: --- → 2.1?
QA Whiteboard: [QAnalyst-Triage?]
Flags: needinfo?(ktucker)
Keywords: regressionwindow-wanted
Updated•10 years ago
|
QA Contact: ckreinbring
Comment 5•10 years ago
|
||
Regression window
Last working
BuildID: 20140816143114
Gaia: 325f68045e7abacdd80f28cce53315d469e82469
Gecko: c3eb1b5ad4e4
Platform Version: 34.0a1
Firmware Version: V123
User Agent: Mozilla/5.0 (Mobile; rv:33.0) Gecko/33.0 Firefox/33.0
First broken
BuildID: 20140816144415
Gaia: 325f68045e7abacdd80f28cce53315d469e82469
Gecko: 94ba78a42305
Platform Version: 34.0a1
Firmware Version: V123
User Agent: Mozilla/5.0 (Mobile; rv:33.0) Gecko/33.0 Firefox/33.0
Working Gaia / Broken Gecko = Repro
Gaia: 325f68045e7abacdd80f28cce53315d469e82469
Gecko: 94ba78a42305
Broken Gaia / Working Gecko = No repro
Gaia: 325f68045e7abacdd80f28cce53315d469e82469
Gecko: c3eb1b5ad4e4
Gecko pushlog: http://hg.mozilla.org/mozilla-central/pushloghtml?fromchange=c3eb1b5ad4e4&tochange=94ba78a42305
Mozilla inbound
Last working
BuildID: 20140815111214
Gaia: d0d773c277a9105288ee35da2121f4ae62709be8
Gecko: fd08e61066de
Platform Version: 34.0a1
Firmware Version: V123
User Agent: Mozilla/5.0 (Mobile; rv:33.0) Gecko/33.0 Firefox/33.0
First broken
BuildID: 20140815112915
Gaia: d0d773c277a9105288ee35da2121f4ae62709be8
Gecko: 229181c88a3c
Platform Version: 34.0a1
Firmware Version: V123
User Agent: Mozilla/5.0 (Mobile; rv:33.0) Gecko/33.0 Firefox/33.0
Working Gaia / Broken Gecko = Repro
Gaia: d0d773c277a9105288ee35da2121f4ae62709be8
Gecko: 229181c88a3c
Broken Gaia / Working Gecko = No repro
Gaia: d0d773c277a9105288ee35da2121f4ae62709be8
Gecko: fd08e61066de
Gecko pushlog: http://hg.mozilla.org/integration/mozilla-inbound/pushloghtml?fromchange=fd08e61066de&tochange=229181c88a3c
Comment 6•10 years ago
|
||
Broken by bug 1029155 - Garrett?
Blocks: 1029155
Flags: needinfo?(jmitchell) → needinfo?(grobinson)
Comment 7•10 years ago
|
||
First of all, initial comment is incorrect - the test case URL's cert is not expired, it is invalid for the given domain.
Note: this test case wfm on desktop, and passed try when it landed a few weeks ago. I see a MozTrap test is failing - what are those, and why aren't they included in the results from try?
Anyway, I would guess the problem is here, where you guys re-implement certificate checks for error pages: http://dxr.mozilla.org/mozilla-central/source/b2g/components/ErrorPage.jsm#75 While this code has the potential to be incorrect (no guarantee that you'll get the same cert on a subsequent request to one that served a bad one), it should work most of the time. Specifically, you are checking whether the channel can provide an nsISSLStatus, and using that as the signal as to whether your connection succeeded or not. When I wrote the patch for bug 1029155, I took specific care not to disturb that (unfortunate) assumption - when I did, it broke unit tests in PSM. It seems strange that those tests would pass but the problem would occur elsewhere in the code. Perhaps there are some other differences in cert handling on B2G.
Anyway, I'll try to look into this more later but I am leaving Mozilla and today is my last day, so there are no guarantees. I'm going to punt this to keeler, who is familiar with PSM (sorry keeler).
Flags: needinfo?(grobinson) → needinfo?(dkeeler)
Assignee | ||
Comment 8•10 years ago
|
||
Hmmm - looks like ErrorPage.jsm needs to be re-written in the style of bug 1025332 (i.e. pass in the failed channel and get its sslStatus - don't attempt an xhr to get the sslStatus). In general, I would be wary of modeling any new code on old code in security/manager/pki - there's a lot that needs to be updated/replaced there, and if we add new code that behaves like it, that just means more work.
Flags: needinfo?(dkeeler)
Comment 9•10 years ago
|
||
Josh - Can you finish triaging the QAnalyst-Triage flag here?
Flags: needinfo?(jmitchell)
Updated•10 years ago
|
QA Whiteboard: [QAnalyst-Triage?] → [QAnalyst-Triage+]
Flags: needinfo?(jmitchell)
Updated•10 years ago
|
QA Whiteboard: [QAnalyst-Triage+] → [QAnalyst-Triage+][lead-review+]
Comment 10•10 years ago
|
||
doug, can you help with triage here and an assignee if we have to fix this for 2.1?
Flags: needinfo?(dougt)
Comment 13•10 years ago
|
||
I can take care after two days.
Assignee | ||
Comment 14•10 years ago
|
||
Actually, I was wrong about what was going on here. When loading a page, the parent notifies the child of events and includes a serialized security info structure. The child deserializes this. When this happens, if the serialization includes an nsIX509Cert, a different object is created than if it were in the parent process (see nsNSSCertificate vs nsNSSCertificateFakeTransport). This is because we don't want to initialize NSS in the child process (any more than we already do due to webrtc, etc., but that's another story), and so we basically create a fake certificate object. It can't do anything, really, but at least it won't cause NSS initialization (or, rather, cause assertion failures because it attempts to do so in the child process). When we added the failedCertChain (backed by nsIX509CertList/nsNSSCertList), we neglected to include a fake nsNSSCertList that could be created in the child process that would prevent assertions as a result of attempting NSS initialization.
Assignee: kk1fff → dkeeler
Component: Gaia::System → Security: PSM
Product: Firefox OS → Core
Assignee | ||
Comment 15•10 years ago
|
||
(Note that this can be reproduced with e10s on desktop.)
OS: Gonk (Firefox OS) → All
Hardware: ARM → All
Assignee | ||
Comment 16•10 years ago
|
||
This is just some clean-up I thought it would be nice to do while we're here.
Attachment #8487573 -
Flags: review?(rlb)
Assignee | ||
Comment 17•10 years ago
|
||
This is the actual fix.
Attachment #8487575 -
Flags: review?(rlb)
Assignee | ||
Comment 18•10 years ago
|
||
Updated•10 years ago
|
QA Whiteboard: [QAnalyst-Triage+][lead-review+] → [QAnalyst-Triage?][lead-review+]
Flags: needinfo?(ktucker)
Whiteboard: [2.1-flame-test-run-1] → [2.1-flame-test-run-1] [2.1-flame-test-run-2]
Updated•10 years ago
|
Flags: needinfo?(tlee)
Updated•10 years ago
|
QA Whiteboard: [QAnalyst-Triage?][lead-review+] → [QAnalyst-Triage+][lead-review+]
Flags: needinfo?(ktucker)
Comment 19•10 years ago
|
||
Comment on attachment 8487573 [details] [diff] [review]
patch 1/2: some clean-up
Review of attachment 8487573 [details] [diff] [review]:
-----------------------------------------------------------------
::: security/manager/ssl/src/nsNSSCertificateFakeTransport.cpp
@@ +113,3 @@
> {
> NS_NOTREACHED("Unimplemented on content process");
> return NS_ERROR_NOT_IMPLEMENTED;
Seems like it would be handy to macro-ize these method bodies, but not essential.
Attachment #8487573 -
Flags: review?(rlb) → review+
Comment 20•10 years ago
|
||
Comment on attachment 8487575 [details] [diff] [review]
patch 2/2: nsNSSCertListFakeTransport
Review of attachment 8487575 [details] [diff] [review]:
-----------------------------------------------------------------
The only thing that was unclear to me was how an nsNSSCertListFakeTransport object gets created. Keeler pointed out to me the "CONSTRUCTOR_BY_PROCESS" line in nsNSSModule.cpp, but I wonder if it might be helpful to have a comment somewhere to this effect. (Or maybe it's obvious.)
::: security/manager/ssl/src/nsNSSCertificateFakeTransport.cpp
@@ +448,5 @@
> +
> + for (size_t i = 0; i < certListLen; i++) {
> + nsCOMPtr<nsIX509Cert> cert = mFakeCertList[i];
> + nsCOMPtr<nsISerializable> serializableCert = do_QueryInterface(cert);
> + rv = aStream->WriteCompoundObject(serializableCert, NS_GET_IID(nsIX509Cert),
Line break before NS_GET_IID? This wraps in splinter at least.
@@ +482,5 @@
> + return rv;
> +}
> +
> +NS_IMETHODIMP
> +nsNSSCertListFakeTransport::GetEnumerator(nsISimpleEnumerator**)
Might be a little more readable for these methods to be with the other nsIX509CertList methods above.
Attachment #8487575 -
Flags: review?(rlb) → review+
Assignee | ||
Comment 21•10 years ago
|
||
Addressed comments and eventually got to pass try:
https://tbpl.mozilla.org/?tree=Try&rev=5e32b1f7b5d6
https://tbpl.mozilla.org/?tree=Try&rev=1b2391a430ae
Attachment #8487575 -
Attachment is obsolete: true
Attachment #8490433 -
Flags: review+
Assignee | ||
Comment 22•10 years ago
|
||
Comment 23•10 years ago
|
||
https://hg.mozilla.org/mozilla-central/rev/dfdc5be13a2f
https://hg.mozilla.org/mozilla-central/rev/89c373278e79
Status: NEW → RESOLVED
Closed: 10 years ago
Resolution: --- → FIXED
Target Milestone: --- → mozilla35
Comment 24•10 years ago
|
||
Triage group reviewed, blocking+ because regression.
blocking-b2g: 2.1? → 2.1+
Comment 25•10 years ago
|
||
Please request Aurora approval on this when you get a chance.
status-b2g-v2.2:
--- → fixed
status-firefox33:
--- → wontfix
status-firefox34:
--- → affected
status-firefox35:
--- → fixed
Flags: needinfo?(dkeeler)
Assignee | ||
Comment 27•10 years ago
|
||
Comment on attachment 8490433 [details] [diff] [review]
patch 2/2: nsNSSCertListFakeTransport v2
Approval Request Comment
[Feature/regressing bug #]: bug 1029155
[User impact if declined]: certificate overrides are broken in b2g/e10s
[Describe test coverage new/current, TBPL]: there are tests for this in non-e10s, so we shouldn't break desktop cert overrides, but unfortunately we have no direct tests for this in b2g/e10s
[Risks and why]: low - I can't really think of a way this would make things worse
[String/UUID change made/needed]: none
Attachment #8490433 -
Flags: approval-mozilla-aurora?
Flags: needinfo?(dkeeler)
Assignee | ||
Comment 28•10 years ago
|
||
Comment on attachment 8487573 [details] [diff] [review]
patch 1/2: some clean-up
Approval Request Comment
(see previous comment - this is just some limited cleanup and changes no functionality)
Attachment #8487573 -
Flags: approval-mozilla-aurora?
Updated•10 years ago
|
Attachment #8487573 -
Flags: approval-mozilla-aurora? → approval-mozilla-aurora+
Updated•10 years ago
|
Attachment #8490433 -
Flags: approval-mozilla-aurora? → approval-mozilla-aurora+
Comment 29•10 years ago
|
||
Comment 30•10 years ago
|
||
This issue has been verified successfully on Flame 2.1.
See attachment: Verify_Video_Flame v2.1.MP4
Reproducing rate: 0/10
Flame v2.1 version:
Gaia-Rev afdfa629be209dd53a1b7b6d6c95eab7077ffcd9
Gecko-Rev https://hg.mozilla.org/releases/mozilla-b2g34_v2_1/rev/dc3018cbdbe6
Build-ID 20141123001201
Version 34.0
Updated•10 years ago
|
Comment 31•10 years ago
|
||
Comment 32•10 years ago
|
||
This issue has been verified as pass on latest build of Flame 2.2 and nexus5 2.2.
Repro Steps:
1) Update a Flame to 20140818040201
2) Navigate to https://tv.eurosport.com
3) Observe lack of SSL warning
Rate:0/5
Device: Flame2.2[pass]
Build ID 20150615162504
Gaia Revision e7a0c6d5f4df04d45fb3f726efb9e8223600cb79
Gaia Date 2015-06-15 06:12:18
Gecko Revision https://hg.mozilla.org/releases/mozilla-b2g37_v2_2/rev/8045028bf400
Gecko Version 37.0
Device Name flame
Firmware(Release) 4.4.2
Firmware(Incremental) eng.cltbld.20150615.194936
Firmware Date Mon Jun 15 19:49:47 EDT 2015
Bootloader L1TC000118D0
Device: Nexus5 2.2[pass]
Build ID 20150615002503
Gaia Revision e7a0c6d5f4df04d45fb3f726efb9e8223600cb79
Gaia Date 2015-06-15 06:12:18
Gecko Revision https://hg.mozilla.org/releases/mozilla-b2g37_v2_2/rev/f278c675d51f
Gecko Version 37.0
Device Name hammerhead
Firmware(Release) 5.1
Firmware(Incremental) eng.cltbld.20150615.040818
Firmware Date Mon Jun 15 04:08:47 EDT 2015
Bootloader HHZ12d
You need to log in
before you can comment on or make changes to this bug.
Description
•