summaryrefslogtreecommitdiff
path: root/src/frontend/gui/system.py
blob: c647625f588d631682fd4a23800f684736098787 (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
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
132
133
134
135
136
137
138
139
140
141
142
#!/usr/bin/python3
import sys, subprocess, sqlite3
from PyQt5 import QtCore, QtGui, QtWidgets, uic

class System(QtWidgets.QMainWindow):
    def __init__(self):
        super(System, self).__init__()
        uic.loadUi('ui/system.ui', self)
        self.centerOnScreen()
        self.show()
        self.load_packages()
    
        self.package_install.clicked.connect(self.install_package)
        self.package_uninstall.clicked.connect(self.uninstall_package)
        self.orphans_remove.clicked.connect(self.remove_orphans)
        self.category_exit.clicked.connect(self.exit_category)
    
    def centerOnScreen(self):
        resolution = QtWidgets.QDesktopWidget().screenGeometry()
        self.move((resolution.width() / 2) - (self.frameSize().width() / 2),
                    (resolution.height() / 2) - (self.frameSize().height() / 2))

    def install_package(self):
        pkgname = self.table_system.item(self.table_system.currentRow(), 1).text()
        subprocess.Popen(['xterm', '-e', 'sisyphus', 'auto-install'] + pkgname.split())
    
    def uninstall_package(self):
        pkgname = self.table_system.item(self.table_system.currentRow(), 1).text()
        subprocess.Popen(['xterm', '-e', 'sisyphus', 'auto-uninstall'] + pkgname.split())

    def remove_orphans(self):
        subprocess.Popen(['xterm', '-e', 'sisyphus', 'remove-orphans'])

    def exit_category(self):
        self.close()
 
    def load_packages(self):
        with sqlite3.connect('/var/lib/sisyphus/db/sisyphus.db') as db:
            cursor=db.cursor()
            cursor.execute('''SELECT
                            a.category AS cat,
                            a.name AS pn,
                            a.version AS av,
                            i.version AS iv,
                            a.description AS descr
                            FROM remote_packages AS a
                            LEFT JOIN local_packages AS i
                            ON a.category = i.category
                            AND a.name = i.name
                            AND a.slot = i.slot
                            WHERE  a.name IN
                                ('hddtemp',
                                'testdisk',
                                'system-config-printer',
                                'clamav',
                                'clamtk',
                                'kcdemu',
                                'aqemu',
                                'docker',
                                'libvirt',
                                'q4wine',
                                'qemu',
                                'spice',
                                'spice-protocol',
                                'virtualbox',
                                'virtualbox-extpack-oracle',
                                'virtualbox-guest-additions',
                                'virtualbox-modules',
                                'wine',
                                'winetricks',
                                'chkrootkit',
                                'rkhunter',
                                'laptop-mode-tools',
                                'gsmartcontrol',
                                'hdparm',
                                'lm_sensors',
                                'microcode-ctl',
                                'smartmontools',
                                'usb_modeswitch',
                                'ms-sys',
                                'isowriter',
                                'unetbootin-static',
                                'b43-firmware',
                                'b43legacy-firmware',
                                'intel-microcode',
                                'ovmf',
                                'btrfs-progs',
                                'cryptsetup',
                                'dosfstools',
                                'e2fsprogs',
                                'ncdu',
                                'ntfs3g',
                                'spl',
                                'squashfs-tools',
                                'xfsprogs',
                                'zfs',
                                'vhba',
                                'bumblebee',
                                'xhost',
                                'xrandr',
                                'radeontop',
                                'nvidia-drivers',
                                'xf86-input-evdev',
                                'xf86-input-joystick',
                                'xf86-input-keyboard',
                                'xf86-input-mouse',
                                'xf86-input-synaptics',
                                'xf86-input-wacom',
                                'xf86-video-amdgpu',
                                'xf86-video-ati',
                                'xf86-video-intel',
                                'xf86-video-nouveau',
                                'xf86-video-qxl',
                                'xf86-video-vesa',
                                'xf86-video-virtualbox',
                                'xf86-video-vmware',
                                'arandr',
                                'ccsm',
                                'compton',
                                'grsync',
                                'primus',
                                'simple-ccsm',
                                'slock',
                                'vdpauinfo',
                                'xscreensaver',
                                'qterminal',
                                'st',
                                'xterm',
                                'compiz-fusion',
                                'emerald',
                                'openbox')
                        ''')
            rows = cursor.fetchall()
            
            for row in rows:
                inx = rows.index(row)
                self.table_system.insertRow(inx)
                self.table_system.setItem(inx, 0, QtWidgets.QTableWidgetItem(row[0]))
                self.table_system.setItem(inx, 1, QtWidgets.QTableWidgetItem(row[1]))
                self.table_system.setItem(inx, 2, QtWidgets.QTableWidgetItem(row[2]))
                self.table_system.setItem(inx, 3, QtWidgets.QTableWidgetItem(row[3]))
                self.table_system.setItem(inx, 4, QtWidgets.QTableWidgetItem(row[4]))