1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
|
# -*- coding: utf-8 -*-
# util.py
# Copyright (C) 2016 LEAP Encryption Acess Project
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU 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 General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
"""
Handy common utils
"""
import os
import platform
import sys
from twisted.logger import Logger
from leap.common.files import which
STANDALONE = getattr(sys, 'frozen', False)
logger = Logger()
def here(module=None):
global STANDALONE
if STANDALONE:
# we are running in a |PyInstaller| bundle
return sys._MEIPASS
else:
dirname = os.path.dirname
if module:
return dirname(module.__file__)
else:
return dirname(__file__)
def merge_status(children):
def key(service):
status = children[service]
level = {
"on": 0,
"off": 1,
"starting": 10,
"stopping": 11,
"failure": 100
}
return level.get(status["status"], -1)
service = max(children, key=key)
status = children[service]["status"]
error = children[service]["error"]
res = {}
for s in children.values():
res.update(s)
res['status'] = status
res['error'] = error
res['childrenStatus'] = children
return res
def get_gpg_bin_path():
"""
Return the path to gpg binary.
:returns: the gpg binary path
:rtype: str
"""
global STANDALONE
gpgbin = None
if STANDALONE:
if platform.system() == "Windows":
gpgbin = os.path.abspath(
os.path.join(here(), "apps", "mail", "gpg.exe"))
elif platform.system() == "Darwin":
gpgbin = os.path.abspath(
os.path.join(here(), "apps", "mail", "gpg"))
else:
gpgbin = os.path.abspath(
os.path.join(here(), "..", "apps", "mail", "gpg"))
else:
try:
path_ext = '/usr/bin/:/usr/local/opt/gnupg/bin/'
gpgbin_options = which("gpg", path_extension=path_ext)
# gnupg checks that the path to the binary is not a
# symlink, so we need to filter those and come up with
# just one option.
for opt in gpgbin_options:
# dereference a symlink, but will fail because
# no complete gpg2 support at the moment
# path = os.readlink(opt)
path = opt
if os.path.exists(path) and not os.path.islink(path):
gpgbin = path
break
except IndexError as e:
logger.debug("couldn't find the gpg binary!: %s" % (e,))
if gpgbin is not None:
return gpgbin
# During the transition towards gpg2, we can look for /usr/bin/gpg1
# binary, in case it was renamed using dpkg-divert or manually.
# We could just pick gpg2, but we need to solve #7564 first.
try:
path_ext = '/usr/bin/:/usr/local/opt/gnupg/bin/'
gpgbin_options = which("gpg1", path_extension=path_ext)
for opt in gpgbin_options:
if not os.path.islink(opt):
gpgbin = opt
break
except IndexError as e:
logger.debug("couldn't find the gpg1 binary!: %s" % (e,))
if gpgbin is None:
logger.debug("Could not find gpg1 binary")
return gpgbin
|