summaryrefslogtreecommitdiff
path: root/service/pixelated
diff options
context:
space:
mode:
authorFolker Bernitt <fbernitt@thoughtworks.com>2015-04-01 17:45:42 +0200
committerFolker Bernitt <fbernitt@thoughtworks.com>2015-04-01 17:48:27 +0200
commit2df5bce9bf49d01a650ea54aa6e71842088b8130 (patch)
treed554847616d2e304022c9fd33b6564ab259001b2 /service/pixelated
parent0e4f6e51a6af43b9440ad17881c9ce136be4f924 (diff)
Fixed circular dependency when auto detecting provider ca.
Diffstat (limited to 'service/pixelated')
-rw-r--r--service/pixelated/bitmask_libraries/certs.py11
1 files changed, 9 insertions, 2 deletions
diff --git a/service/pixelated/bitmask_libraries/certs.py b/service/pixelated/bitmask_libraries/certs.py
index 31e68d1c..6d3c4c2a 100644
--- a/service/pixelated/bitmask_libraries/certs.py
+++ b/service/pixelated/bitmask_libraries/certs.py
@@ -14,7 +14,8 @@
# You should have received a copy of the GNU Affero General Public License
# along with Pixelated. If not, see <http://www.gnu.org/licenses/>.
import os
-
+import requests
+import json
from leap.common import ca_bundle
from .config import AUTO_DETECT_CA_BUNDLE
@@ -86,7 +87,13 @@ class LeapCertificate(object):
def _local_bootstrap_server_cert(self):
cert_file = os.path.join(self._certs_home, '%s.ca.crt' % self._server_name)
if not os.path.isfile(cert_file):
- self._download_server_cert(cert_file)
+ response = requests.get('https://%s/provider.json' % self._server_name)
+ provider_data = json.loads(response.content)
+ ca_cert_uri = str(provider_data['ca_cert_uri'])
+
+ response = requests.get(ca_cert_uri)
+ with open(cert_file, 'w') as file:
+ file.write(response.content)
return cert_file