summaryrefslogtreecommitdiff
path: root/src/leap/bitmask/cli/logs.py
blob: 59ed64d64de429cec746b0e0f740477fb346aa0a (plain)
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
# -*- coding: utf-8 -*-
# keys
# Copyright (C) 2016 LEAP
#
# 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/>.
"""
Bitmask Command Line interface: logs
"""
import argparse
import commands
import os.path
import sys

from colorama import Fore

from twisted.internet import defer
from twisted.python.procutils import which

from leap.bitmask.cli import command
from leap.common.config import get_path_prefix


class Logs(command.Command):
    usage = '''{name} logs <subcommand>

Bitmask Log Handling

SUBCOMMANDS:

   send       Send last bitmaskd log
'''.format(name=command.appname)

    def send(self, raw_args):
        _bin = which('pastebinit')
        if not _bin:
            error('pastebinit not found. install it to upload logs.')
            return defer.succeed(None)
        log_path = os.path.abspath(
            os.path.join(get_path_prefix(), 'leap', 'bitmaskd.log'))
        output = commands.getoutput('{0} -b {1} {2}'.format(
            _bin[0], 'paste.debian.net', log_path))
        uri = output.replace('debian.net/', 'debian.net/plain/')
        success(uri)
        return defer.succeed(None)


def error(msg):
    print Fore.RED + msg + Fore.RESET


def success(msg):
    print Fore.GREEN + '[+] Bitmaskd logs pasted to ' + msg + Fore.RESET