Mercurial > libervia-desktop-kivy
changeset 280:b0461363bc65
core: certificate validation can be disabled:
By using "no_certificate_validation=true" in sat.conf in [cagou] section, certificate validation can be disabled.
This is mainly useful for developping on local machines with self-signed certificates.
author | Goffi <goffi@goffi.org> |
---|---|
date | Wed, 20 Mar 2019 09:29:44 +0100 |
parents | aea973de55d9 |
children | ef77423ce500 |
files | cagou/core/cagou_main.py cagou/core/patches.py |
diffstat | 2 files changed, 48 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- a/cagou/core/cagou_main.py Wed Mar 20 09:29:44 2019 +0100 +++ b/cagou/core/cagou_main.py Wed Mar 20 09:29:44 2019 +0100 @@ -429,6 +429,14 @@ self._visible_widgets = {} # visible widgets by classes self.version = C.APP_VERSION # will be replaced by getVersion() + if C.bool(config.getConfig(main_config, + C.CONFIG_SECTION, + 'no_certificate_validation', + C.BOOL_FALSE)): + from cagou.core import patches + patches.apply() + log.warning(u"SSL certificate validation is disabled, this is unsecure!") + @property def visible_widgets(self): for w_list in self._visible_widgets.itervalues():
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/cagou/core/patches.py Wed Mar 20 09:29:44 2019 +0100 @@ -0,0 +1,40 @@ +#!/usr//bin/env python2 +# -*- coding: utf-8 -*- + +# Cagou: desktop/mobile frontend for Salut à Toi XMPP client +# Copyright (C) 2016-2019 Jérôme Poisson (goffi@goffi.org) + +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU Affero General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Affero General Public License for more details. + +# You should have received a copy of the GNU Affero General Public License +# along with this program. If not, see <http://www.gnu.org/licenses/>. + +import urllib2 +import ssl + + +def apply(): + # allow to disable certificate validation + ctx_no_verify = ssl.create_default_context() + ctx_no_verify.check_hostname = False + ctx_no_verify.verify_mode = ssl.CERT_NONE + + class HTTPSHandler(urllib2.HTTPSHandler): + no_certificate_check = False + + def __init__(self, *args, **kwargs): + urllib2._HTTPSHandler_ori.__init__(self, *args, **kwargs) + if self.no_certificate_check: + self._context = ctx_no_verify + + urllib2._HTTPSHandler_ori = urllib2.HTTPSHandler + urllib2.HTTPSHandler = HTTPSHandler + urllib2.HTTPSHandler.no_certificate_check = True