hardsploit_gui 2.2 → 2.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/bin/hardsploit_gui +2 -2
- data/lib/{Firmware → Firmwares}/FPGA/I2C/I2C_INTERACT/HARDSPLOIT_FIRMWARE_FPGA_I2C_INTERACT.rpd +0 -0
- data/lib/{Firmware/FPGA/SWD/SWD_INTERACT/HARDSPLOIT_FIRMWARE_FPGA_SWD_INTERACT.rpd → Firmwares/FPGA/PARALLEL/NO_MUX_PARALLEL_MEMORY/HARDSPLOIT_FIRMWARE_FPGA_NO_MUX_PARALLEL_MEMORY.rpd} +0 -0
- data/lib/Firmwares/FPGA/SPI/SPI_INTERACT/HARDSPLOIT_FIRMWARE_FPGA_SPI_INTERACT.rpd +0 -0
- data/lib/{Firmware/FPGA/SPI/SPI_INTERACT/HARDSPLOIT_FIRMWARE_FPGA_SPI_INTERACT.rpd → Firmwares/FPGA/SPI/SPI_SNIFFER/HARDSPLOIT_FIRMWARE_FPGA_SPI_SNIFFER.rpd} +0 -0
- data/lib/Firmwares/FPGA/SWD/SWD_INTERACT/HARDSPLOIT_FIRMWARE_FPGA_SWD_INTERACT.rpd +0 -0
- data/lib/{Firmware → Firmwares}/FPGA/TEST/TEST_INTERACT/HARDSPLOIT_FIRMWARE_FPGA_TEST_INTERACT.rpd +0 -0
- data/lib/Firmwares/FPGA/UART/UART_INTERACT/HARDSPLOIT_FIRMWARE_FPGA_UART_INTERACT.rpd +0 -0
- data/lib/{Firmware → Firmwares}/FPGA/VersionFPGA.rb +1 -1
- data/lib/{Firmware → Firmwares}/UC/HARDSPLOIT_FIRMWARE_UC.bin +0 -0
- data/lib/{Firmware → Firmwares}/UC/VersionUC.rb +1 -1
- data/lib/HardsploitAPI/Core/HardsploitAPI.rb +210 -0
- data/lib/HardsploitAPI/Core/HardsploitAPI_CONSTANT.rb +150 -0
- data/lib/HardsploitAPI/Core/HardsploitAPI_ERROR.rb +109 -0
- data/lib/HardsploitAPI/Core/HardsploitAPI_FIRMWARE.rb +305 -0
- data/lib/HardsploitAPI/{HardsploitAPI_PROGRESS.rb → Core/HardsploitAPI_PROGRESS.rb} +0 -0
- data/lib/HardsploitAPI/Core/HardsploitAPI_USB_COMMUNICATION.rb +166 -0
- data/lib/HardsploitAPI/Modules/I2C/HardsploitAPI_I2C.rb +356 -0
- data/lib/HardsploitAPI/{HardsploitAPI_NO_MUX_PARALLELE_MEMORY.rb → Modules/NO_MUX_PARALLEL_MEMORY/HardsploitAPI_NO_MUX_PARALLEL_MEMORY.rb} +26 -49
- data/lib/HardsploitAPI/Modules/NRF24L01/HardsploitAPI_NRF24L01.rb +306 -0
- data/lib/HardsploitAPI/Modules/SPI/HardsploitAPI_SPI.rb +340 -0
- data/lib/HardsploitAPI/Modules/SPI_SNIFFER/HardsploitAPI_SPI_SNIFFER.rb +83 -0
- data/lib/HardsploitAPI/Modules/SWD/HardsploitAPI_SWD.rb +367 -0
- data/lib/HardsploitAPI/Modules/SWD/HardsploitAPI_SWD_DEBUG.rb +89 -0
- data/lib/HardsploitAPI/Modules/SWD/HardsploitAPI_SWD_MEM_AP.rb +61 -0
- data/lib/HardsploitAPI/{SWD → Modules/SWD}/HardsploitAPI_SWD_STM32.rb +32 -15
- data/lib/HardsploitAPI/{HardsploitAPI_TEST_INTERACT.rb → Modules/TEST/HardsploitAPI_TEST_INTERACT.rb} +1 -1
- data/lib/HardsploitAPI/Modules/UART/HardsploitAPI_UART.rb +196 -0
- data/lib/Hardsploit_gui.rb +96 -0
- data/lib/class/Chip_editor.rb +186 -330
- data/lib/class/Chip_management.rb +496 -0
- data/lib/class/Command_editor.rb +130 -182
- data/lib/class/Command_table.rb +16 -22
- data/lib/class/Console.rb +0 -2
- data/lib/class/ErrorMsg.rb +312 -0
- data/lib/class/Export.rb +140 -0
- data/lib/class/Export_manager.rb +43 -43
- data/lib/class/Firmware.rb +52 -11
- data/lib/class/Generic_commands.rb +180 -190
- data/lib/class/Import.rb +193 -0
- data/lib/class/Progress_bar.rb +1 -0
- data/lib/class/Signal_mapper.rb +120 -0
- data/lib/class/Wire_helper.rb +132 -148
- data/lib/class/{I2C → i2c}/I2c_command.rb +16 -13
- data/lib/class/i2c/I2c_export.rb +95 -0
- data/lib/class/i2c/I2c_import.rb +117 -0
- data/lib/class/i2c/I2c_scanner.rb +114 -0
- data/lib/class/i2c/I2c_settings.rb +148 -0
- data/lib/class/parallel/Parallel_export.rb +118 -0
- data/lib/class/parallel/Parallel_import.rb +113 -0
- data/lib/class/parallel/Parallel_settings.rb +81 -0
- data/lib/class/spi/Spi_export.rb +108 -0
- data/lib/class/spi/Spi_import.rb +159 -0
- data/lib/class/spi/Spi_settings.rb +108 -0
- data/lib/class/spi/Spi_sniffer.rb +101 -0
- data/lib/class/swd/Swd.rb +125 -0
- data/lib/class/swd/Swd_scanner.rb +121 -0
- data/lib/class/swd/Swd_settings.rb +76 -0
- data/lib/class/uart/Uart_baudrate.rb +62 -0
- data/lib/class/uart/Uart_console.rb +115 -0
- data/lib/class/uart/Uart_settings.rb +102 -0
- data/lib/db/associations.rb +42 -29
- data/lib/db/database.rb +4 -0
- data/lib/db/development.sqlite3 +0 -0
- data/lib/db/migrate/004_create_manufacturers.rb +13 -0
- data/lib/db/migrate/005_create_packages.rb +13 -0
- data/lib/db/migrate/006_create_chip_types.rb +11 -0
- data/lib/db/migrate/007_create_buses.rb +11 -0
- data/lib/db/migrate/008_create_signals.rb +14 -0
- data/lib/db/migrate/009_create_chips.rb +25 -0
- data/lib/db/migrate/010_create_commands.rb +21 -0
- data/lib/db/migrate/011_create_bytes.rb +19 -0
- data/lib/db/migrate/012_create_i2c_settings.rb +21 -0
- data/lib/db/migrate/013_create_spi_settings.rb +26 -0
- data/lib/db/migrate/014_create_parallel_settings.rb +21 -0
- data/lib/db/migrate/015_create_pins.rb +19 -0
- data/lib/db/migrate/016_create_uses.rb +17 -0
- data/lib/db/migrate/017_create_swd_settings.rb +19 -0
- data/lib/db/migrate/018_create_uart_settings.rb +22 -0
- data/lib/db/schema.rb +157 -0
- data/lib/db/seeds.rb +161 -0
- data/lib/gui/gui_chip_editor.rb +23 -22
- data/lib/gui/gui_chip_management.rb +43 -38
- data/lib/gui/gui_command_editor.rb +2 -1
- data/lib/gui/gui_export.rb +132 -0
- data/lib/gui/gui_generic_commands.rb +69 -31
- data/lib/gui/gui_generic_export.rb +18 -2
- data/lib/gui/gui_generic_import.rb +18 -2
- data/lib/gui/gui_i2c_command.rb +2 -1
- data/lib/gui/gui_i2c_settings.rb +2 -2
- data/lib/gui/gui_import.rb +131 -0
- data/lib/gui/gui_parallel_settings.rb +2 -1
- data/lib/gui/gui_progress_bar.rb +2 -1
- data/lib/gui/gui_signal_mapper.rb +121 -0
- data/lib/gui/gui_signal_scanner.rb +146 -0
- data/lib/gui/gui_spi_settings.rb +6 -2
- data/lib/gui/gui_spi_sniffer.rb +112 -0
- data/lib/gui/gui_swd_settings.rb +166 -0
- data/lib/gui/gui_uart_baudrate.rb +114 -0
- data/lib/gui/gui_uart_console.rb +164 -0
- data/lib/gui/gui_uart_settings.rb +243 -0
- data/lib/gui_designer/gui_chip_editor.ui +9 -6
- data/lib/gui_designer/gui_chip_management.ui +79 -35
- data/lib/gui_designer/gui_command_editor.ui +3 -0
- data/lib/gui_designer/gui_export.ui +171 -0
- data/lib/gui_designer/gui_generic_commands.ui +274 -190
- data/lib/gui_designer/gui_generic_export.ui +24 -1
- data/lib/gui_designer/gui_generic_import.ui +25 -2
- data/lib/gui_designer/gui_i2c_command.ui +3 -0
- data/lib/gui_designer/gui_i2c_settings.ui +2 -2
- data/lib/gui_designer/gui_import.ui +168 -0
- data/lib/gui_designer/gui_parallel_settings.ui +4 -1
- data/lib/gui_designer/gui_progress_bar.ui +3 -0
- data/lib/gui_designer/gui_signal_mapper.ui +179 -0
- data/lib/gui_designer/gui_signal_scanner.ui +261 -0
- data/lib/gui_designer/gui_spi_settings.ui +15 -2
- data/lib/gui_designer/gui_spi_sniffer.ui +156 -0
- data/lib/gui_designer/gui_swd_settings.ui +189 -0
- data/lib/gui_designer/gui_uart_baudrate.ui +161 -0
- data/lib/gui_designer/gui_uart_console.ui +284 -0
- data/lib/gui_designer/gui_uart_settings.ui +280 -0
- data/lib/logs/error.log +63 -0
- data/lib/models/bus.rb +19 -0
- data/lib/models/byte.rb +29 -0
- data/lib/models/chip.rb +41 -0
- data/lib/models/chip_type.rb +14 -0
- data/lib/models/command.rb +20 -0
- data/lib/models/i2c_setting.rb +41 -0
- data/lib/models/manufacturer.rb +14 -0
- data/lib/models/package.rb +26 -0
- data/lib/models/parallel_setting.rb +37 -0
- data/lib/models/pin.rb +14 -0
- data/lib/models/signall.rb +20 -0
- data/lib/models/spi_setting.rb +67 -0
- data/lib/models/swd_setting.rb +25 -0
- data/lib/models/uart_setting.rb +52 -0
- data/lib/models/use.rb +6 -0
- data/lib/startHardsploit.rb +2 -2
- metadata +106 -41
- data/lib/Firmware/FPGA/PARALLEL/NO_MUX_PARALLEL_MEMORY/HARDSPLOIT_FIRMWARE_FPGA_NO_MUX_PARALLEL_MEMORY.rpd +0 -0
- data/lib/HardsploitAPI/HardsploitAPI.rb +0 -133
- data/lib/HardsploitAPI/HardsploitAPI_CONSTANT.rb +0 -145
- data/lib/HardsploitAPI/HardsploitAPI_ERROR.rb +0 -38
- data/lib/HardsploitAPI/HardsploitAPI_FIRMWARE.rb +0 -311
- data/lib/HardsploitAPI/HardsploitAPI_I2C.rb +0 -360
- data/lib/HardsploitAPI/HardsploitAPI_SPI.rb +0 -369
- data/lib/HardsploitAPI/HardsploitAPI_USB_COMMUNICATION.rb +0 -148
- data/lib/HardsploitAPI/LICENSE.txt +0 -674
- data/lib/HardsploitAPI/README.md +0 -22
- data/lib/HardsploitAPI/SWD/HardsploitAPI_SWD.rb +0 -249
- data/lib/HardsploitAPI/SWD/HardsploitAPI_SWD_DEBUG.rb +0 -102
- data/lib/HardsploitAPI/SWD/HardsploitAPI_SWD_MEM_AP.rb +0 -78
- data/lib/HardsploitAPI/TRADEMARK +0 -3
- data/lib/class/HardsploitGUI.rb +0 -463
- data/lib/class/I2C/I2c_export.rb +0 -118
- data/lib/class/I2C/I2c_import.rb +0 -79
- data/lib/class/I2C/I2c_settings.rb +0 -129
- data/lib/class/PARALLEL/Parallel_export.rb +0 -146
- data/lib/class/PARALLEL/Parallel_import.rb +0 -88
- data/lib/class/PARALLEL/Parallel_settings.rb +0 -102
- data/lib/class/SPI/Spi_export.rb +0 -138
- data/lib/class/SPI/Spi_import.rb +0 -113
- data/lib/class/SPI/Spi_settings.rb +0 -134
- data/lib/db/hs.db +0 -0
- data/lib/hardsploit.rb +0 -131
data/lib/HardsploitAPI/TRADEMARK
DELETED
data/lib/class/HardsploitGUI.rb
DELETED
@@ -1,463 +0,0 @@
|
|
1
|
-
#===================================================
|
2
|
-
# Hardsploit GUI - By Opale Security
|
3
|
-
# www.opale-security.com || www.hardsploit.io
|
4
|
-
# License: GNU General Public License v3
|
5
|
-
# License URI: http://www.gnu.org/licenses/gpl.txt
|
6
|
-
#===================================================
|
7
|
-
|
8
|
-
require_relative '../HardsploitAPI/HardsploitAPI'
|
9
|
-
class HardsploitGUI < Qt::MainWindow
|
10
|
-
VERSION = "2.2"
|
11
|
-
slots 'load_tree(int, int)'
|
12
|
-
slots 'load_chip_action(QTreeWidgetItem*, int)'
|
13
|
-
slots 'feed_chip_array()'
|
14
|
-
slots 'update_uc_firmware()'
|
15
|
-
slots 'get_hardsploit_versions()'
|
16
|
-
slots 'get_log_path()'
|
17
|
-
slots 'get_db_path()'
|
18
|
-
slots 'get_hardsploit_website()'
|
19
|
-
slots 'set_firmware()'
|
20
|
-
slots 'display_current_firmware()'
|
21
|
-
slots 'console_view()'
|
22
|
-
slots 'add_chip()'
|
23
|
-
slots 'edit_chip()'
|
24
|
-
slots 'wire_chip()'
|
25
|
-
slots 'delete_chip()'
|
26
|
-
slots 'swd_detect()'
|
27
|
-
slots 'swd_import()'
|
28
|
-
slots 'swd_export()'
|
29
|
-
slots 'swd_erase()'
|
30
|
-
|
31
|
-
def initialize(api)
|
32
|
-
super()
|
33
|
-
@cm = Ui_Chip_management.new
|
34
|
-
@cm.setupUi(self)
|
35
|
-
@api = api
|
36
|
-
@cm.img_search.setPixmap(Qt::Pixmap.new(File.expand_path(File.dirname(__FILE__)) + "/../images/search.png"))
|
37
|
-
inputRestrict(@cm.lie_search, 2)
|
38
|
-
feed_chip_array
|
39
|
-
feed_manufacturer_cbx
|
40
|
-
feed_type_cbx
|
41
|
-
@cm.tbl_chip.resizeColumnsToContents
|
42
|
-
@cm.tbl_chip.resizeRowsToContents
|
43
|
-
@cm.tbl_chip.horizontalHeader.stretchLastSection = true
|
44
|
-
@cm.tbl_console.horizontalHeader.stretchLastSection = true
|
45
|
-
@console = Console.new(@cm.tbl_console)
|
46
|
-
check_hardsploit_connection(api)
|
47
|
-
rescue Exception => msg
|
48
|
-
logger = Logger.new($logFilePath)
|
49
|
-
logger.error msg
|
50
|
-
Qt::MessageBox.new(Qt::MessageBox::Critical, "GUI Error", "Error while loading Hardsploit GUI").exec
|
51
|
-
end
|
52
|
-
|
53
|
-
def feed_type_cbx
|
54
|
-
manufacturer = Manufacturer.all
|
55
|
-
manufacturer.each do |m|
|
56
|
-
@cm.cbx_manufacturer.addItem(m.manufacturer_name)
|
57
|
-
end
|
58
|
-
rescue Exception => msg
|
59
|
-
logger = Logger.new($logFilePath)
|
60
|
-
logger.error msg
|
61
|
-
Qt::MessageBox.new(Qt::MessageBox::Critical, "Error", "Error while loading the manufacturer list from the database").exec
|
62
|
-
end
|
63
|
-
|
64
|
-
def feed_manufacturer_cbx
|
65
|
-
cType = CType.all
|
66
|
-
cType.each do |c|
|
67
|
-
@cm.cbx_type.addItem(c.cType_name)
|
68
|
-
end
|
69
|
-
rescue Exception => msg
|
70
|
-
logger = Logger.new($logFilePath)
|
71
|
-
logger.error msg
|
72
|
-
Qt::MessageBox.new(Qt::MessageBox::Critical, "Error", "Error while loading the type list from the database").exec
|
73
|
-
end
|
74
|
-
|
75
|
-
def console_view
|
76
|
-
if @cm.check_console.isChecked
|
77
|
-
@cm.tbl_console.show
|
78
|
-
else
|
79
|
-
@cm.tbl_console.hide
|
80
|
-
end
|
81
|
-
end
|
82
|
-
|
83
|
-
def get_chip_buses(chip)
|
84
|
-
chip_bus_name = []
|
85
|
-
chip_bus_id = []
|
86
|
-
chipSignalId = chip.pin.pluck(:pin_signal)
|
87
|
-
chipSignalId.delete(62) # NA
|
88
|
-
chipSignalId.each do |s|
|
89
|
-
chip_bus_id.push(Use.find_by(signal_id: s).bus_id)
|
90
|
-
end
|
91
|
-
chip_bus_id.uniq.each do |b|
|
92
|
-
chip_bus_name.push(Bus.find_by(bus_id: b).bus_name)
|
93
|
-
end
|
94
|
-
return chip_bus_name
|
95
|
-
rescue Exception => msg
|
96
|
-
logger = Logger.new($logFilePath)
|
97
|
-
logger.error msg
|
98
|
-
Qt::MessageBox.new(Qt::MessageBox::Critical, "Error", "Error while getting the bus list").exec
|
99
|
-
end
|
100
|
-
|
101
|
-
def load_tree(line, column)
|
102
|
-
return 0 unless column.zero?
|
103
|
-
@cm.tw_chip.clear
|
104
|
-
@chip_clicked = Chip.find_by(chip_reference: @cm.tbl_chip.item(line, column).text)
|
105
|
-
# CHIP LEVEL
|
106
|
-
chip_lvl = Qt::TreeWidgetItem.new
|
107
|
-
chip_lvl.setText(0, @cm.tbl_chip.item(line, column).text)
|
108
|
-
# ACTION LEVEL
|
109
|
-
action_lvl = Qt::TreeWidgetItem.new
|
110
|
-
action_lvl.setText(0, 'Manage')
|
111
|
-
chip_lvl.addChild(create_action_nodes(action_lvl))
|
112
|
-
# BUS LEVEL(S)
|
113
|
-
chip_bus = get_chip_buses(@chip_clicked)
|
114
|
-
chip_bus.each do |b|
|
115
|
-
bus_lvl = Qt::TreeWidgetItem.new
|
116
|
-
bus_lvl.setText(0, b)
|
117
|
-
chip_lvl.addChild(create_bus_nodes(b, bus_lvl))
|
118
|
-
end
|
119
|
-
# ADD THE PARENT NODE
|
120
|
-
@cm.tw_chip.addTopLevelItem(chip_lvl)
|
121
|
-
end
|
122
|
-
|
123
|
-
def create_action_nodes(parent_node)
|
124
|
-
wiring_lvl = Qt::TreeWidgetItem.new
|
125
|
-
wiring_lvl.setText(0, "Wiring")
|
126
|
-
parent_node.addChild(wiring_lvl)
|
127
|
-
edit_lvl = Qt::TreeWidgetItem.new
|
128
|
-
edit_lvl.setText(0, "Edit")
|
129
|
-
parent_node.addChild(edit_lvl)
|
130
|
-
template_lvl = Qt::TreeWidgetItem.new
|
131
|
-
template_lvl.setText(0, "Template")
|
132
|
-
parent_node.addChild(template_lvl)
|
133
|
-
delete_lvl = Qt::TreeWidgetItem.new
|
134
|
-
delete_lvl.setText(0, "Delete")
|
135
|
-
parent_node.addChild(delete_lvl)
|
136
|
-
return parent_node
|
137
|
-
end
|
138
|
-
|
139
|
-
def create_bus_nodes(bus, parent_node)
|
140
|
-
case bus
|
141
|
-
when 'SPI', 'I2C'
|
142
|
-
settings_lvl = Qt::TreeWidgetItem.new
|
143
|
-
settings_lvl.setText(0, "Settings")
|
144
|
-
parent_node.addChild(settings_lvl)
|
145
|
-
cmd_lvl = Qt::TreeWidgetItem.new
|
146
|
-
cmd_lvl.setText(0, "Commands")
|
147
|
-
parent_node.addChild(cmd_lvl)
|
148
|
-
import_lvl = Qt::TreeWidgetItem.new
|
149
|
-
import_lvl.setText(0, "Import")
|
150
|
-
parent_node.addChild(import_lvl)
|
151
|
-
export_lvl = Qt::TreeWidgetItem.new
|
152
|
-
export_lvl.setText(0, "Export")
|
153
|
-
parent_node.addChild(export_lvl)
|
154
|
-
when 'PARALLEL'
|
155
|
-
settings_lvl = Qt::TreeWidgetItem.new
|
156
|
-
settings_lvl.setText(0, "Settings")
|
157
|
-
parent_node.addChild(settings_lvl)
|
158
|
-
# Not implemented yet
|
159
|
-
#import_lvl = Qt::TreeWidgetItem.new
|
160
|
-
#import_lvl.setText(0, "Import")
|
161
|
-
#parent_node.addChild(import_lvl)
|
162
|
-
export_lvl = Qt::TreeWidgetItem.new
|
163
|
-
export_lvl.setText(0, "Export")
|
164
|
-
parent_node.addChild(export_lvl)
|
165
|
-
end
|
166
|
-
return parent_node
|
167
|
-
end
|
168
|
-
|
169
|
-
def feed_chip_array
|
170
|
-
@cm.tbl_chip.clearContents
|
171
|
-
ref = @cm.lie_search.text
|
172
|
-
if @cm.cbx_manufacturer.currentIndex != 0
|
173
|
-
manufacturer = Manufacturer.find_by(manufacturer_name: @cm.cbx_manufacturer.currentText).manufacturer_id
|
174
|
-
end
|
175
|
-
if @cm.cbx_type.currentIndex != 0
|
176
|
-
type = CType.find_by(cType_name: @cm.cbx_type.currentText).cType_id
|
177
|
-
end
|
178
|
-
if ref.empty?
|
179
|
-
chip = Chip.all
|
180
|
-
else
|
181
|
-
chip = Chip.where("chip_reference LIKE ?", "%#{ref}%")
|
182
|
-
end
|
183
|
-
chip = chip.where("chip_manufacturer = ?", manufacturer) unless manufacturer.nil?
|
184
|
-
chip = chip.where("chip_type = ?", type) unless type.nil?
|
185
|
-
@cm.tbl_chip.setRowCount(chip.count);
|
186
|
-
# Insert elements
|
187
|
-
chip.to_enum.with_index(0).each do |c, i|
|
188
|
-
item = Qt::TableWidgetItem.new(c.chip_reference)
|
189
|
-
item.setFlags(Qt::ItemIsSelectable|Qt::ItemIsEnabled)
|
190
|
-
@cm.tbl_chip.setItem(i, 0, item)
|
191
|
-
|
192
|
-
item2 = Qt::TableWidgetItem.new(CType.find(c.chip_type).cType_name)
|
193
|
-
item2.setFlags(Qt::ItemIsEnabled)
|
194
|
-
@cm.tbl_chip.setItem(i, 1, item2)
|
195
|
-
|
196
|
-
item3 = Qt::TableWidgetItem.new(Manufacturer.find(c.chip_manufacturer).manufacturer_name)
|
197
|
-
item3.setFlags(Qt::ItemIsEnabled)
|
198
|
-
@cm.tbl_chip.setItem(i, 2, item3)
|
199
|
-
bus_list = get_chip_buses(c)
|
200
|
-
bus_list_str = ''
|
201
|
-
bus_list.each do |b|
|
202
|
-
bus_list_str = bus_list_str + "#{b} "
|
203
|
-
end
|
204
|
-
|
205
|
-
item4 = Qt::TableWidgetItem.new(bus_list_str)
|
206
|
-
item4.setFlags(Qt::ItemIsEnabled)
|
207
|
-
@cm.tbl_chip.setItem(i, 3, item4)
|
208
|
-
end
|
209
|
-
rescue Exception => msg
|
210
|
-
logger = Logger.new($logFilePath)
|
211
|
-
logger.error msg
|
212
|
-
Qt::MessageBox.new(Qt::MessageBox::Critical, "Critical error", "Error occured while loading the chip array").exec
|
213
|
-
end
|
214
|
-
|
215
|
-
def load_chip_action(item, column)
|
216
|
-
return 0 unless item.childCount.zero?
|
217
|
-
if item.parent.text(0) == 'Manage'
|
218
|
-
case item.text(0)
|
219
|
-
when 'Wiring'
|
220
|
-
wire_chip
|
221
|
-
when 'Edit'
|
222
|
-
edit_chip
|
223
|
-
when 'Template'
|
224
|
-
add_chip
|
225
|
-
when 'Delete'
|
226
|
-
delete_chip
|
227
|
-
end
|
228
|
-
else
|
229
|
-
case item.parent.text(0)
|
230
|
-
when 'SPI'
|
231
|
-
load_spi_module(item.text(0))
|
232
|
-
when 'I2C'
|
233
|
-
load_i2c_module(item.text(0))
|
234
|
-
when 'PARALLEL'
|
235
|
-
load_parallel_module(item.text(0))
|
236
|
-
when 'SWD'
|
237
|
-
load_swd_module(item.text(0))
|
238
|
-
end
|
239
|
-
end
|
240
|
-
end
|
241
|
-
|
242
|
-
def load_spi_module(spi_module)
|
243
|
-
case spi_module
|
244
|
-
when 'Settings'
|
245
|
-
spi_settings_window = Spi_settings.new(@chip_clicked)
|
246
|
-
spi_settings_window.show
|
247
|
-
when 'Commands'
|
248
|
-
generic_command_window = Generic_commands.new(@api, @chip_clicked, 'SPI')
|
249
|
-
generic_command_window.show
|
250
|
-
when 'Import'
|
251
|
-
spi_import_window = Spi_import.new(@api, @chip_clicked)
|
252
|
-
spi_import_window.show
|
253
|
-
when 'Export'
|
254
|
-
spi_export_window = Spi_export.new(@api, @chip_clicked)
|
255
|
-
spi_export_window.show
|
256
|
-
end
|
257
|
-
end
|
258
|
-
|
259
|
-
def load_i2c_module(i2c_module)
|
260
|
-
case i2c_module
|
261
|
-
when 'Settings'
|
262
|
-
bus_settings_window = I2c_settings.new(@api, @chip_clicked)
|
263
|
-
bus_settings_window.show
|
264
|
-
when 'Commands'
|
265
|
-
bus_command_window = Generic_commands.new(@api, @chip_clicked, 'I2C')
|
266
|
-
bus_command_window.show
|
267
|
-
when 'Import'
|
268
|
-
bus_import_window = I2c_import.new(@api, @chip_clicked)
|
269
|
-
bus_import_window.show
|
270
|
-
when 'Export'
|
271
|
-
bus_export_window = I2c_export.new(@api, @chip_clicked)
|
272
|
-
bus_export_window.show
|
273
|
-
end
|
274
|
-
end
|
275
|
-
|
276
|
-
def load_parallel_module(parallel_module)
|
277
|
-
case parallel_module
|
278
|
-
when 'Settings'
|
279
|
-
bus_settings_window = Parallel_settings.new(@chip_clicked)
|
280
|
-
bus_settings_window.show
|
281
|
-
when 'Import'
|
282
|
-
bus_import_window = Parallel_import.new(@api, @chip_clicked)
|
283
|
-
bus_import_window.show
|
284
|
-
when 'Export'
|
285
|
-
bus_export_window = Parallel_export.new(@api, @chip_clicked)
|
286
|
-
bus_export_window.show
|
287
|
-
end
|
288
|
-
end
|
289
|
-
|
290
|
-
def add_chip
|
291
|
-
if sender.objectName == 'tw_chip'
|
292
|
-
unless @chip_clicked.nil?
|
293
|
-
add_chip = Chip_editor.new(self, @chip_clicked, 'temp')
|
294
|
-
else
|
295
|
-
Qt::MessageBox.new(Qt::MessageBox::Information, "Chip template", "No chip loaded").exec
|
296
|
-
return 0
|
297
|
-
end
|
298
|
-
else
|
299
|
-
add_chip = Chip_editor.new(self, 'none', 'new')
|
300
|
-
end
|
301
|
-
add_chip.setWindowModality(Qt::ApplicationModal)
|
302
|
-
add_chip.show
|
303
|
-
end
|
304
|
-
|
305
|
-
def edit_chip
|
306
|
-
unless @chip_clicked.nil?
|
307
|
-
edit_chip = Chip_editor.new(self, @chip_clicked, 'edit')
|
308
|
-
edit_chip.setWindowModality(Qt::ApplicationModal)
|
309
|
-
edit_chip.show
|
310
|
-
else
|
311
|
-
Qt::MessageBox.new(Qt::MessageBox::Information, "Edit chip", "No chip loaded").exec
|
312
|
-
end
|
313
|
-
end
|
314
|
-
|
315
|
-
def delete_chip
|
316
|
-
unless @chip_clicked.nil?
|
317
|
-
msg = Qt::MessageBox.new
|
318
|
-
msg.setWindowTitle("Delete this chip")
|
319
|
-
msg.setText("By deleting this chip, all the commands linked to it will be deleted too. Continue ?")
|
320
|
-
msg.setIcon(Qt::MessageBox::Question)
|
321
|
-
msg.setStandardButtons(Qt::MessageBox::Cancel | Qt::MessageBox::Ok)
|
322
|
-
msg.setDefaultButton(Qt::MessageBox::Cancel)
|
323
|
-
if msg.exec == Qt::MessageBox::Ok
|
324
|
-
@chip_clicked.destroy
|
325
|
-
feed_chip_array
|
326
|
-
@cm.tw_chip.clear
|
327
|
-
end
|
328
|
-
else
|
329
|
-
Qt::MessageBox.new(Qt::MessageBox::Information, "Delete chip", "No chip loaded").exec
|
330
|
-
end
|
331
|
-
end
|
332
|
-
|
333
|
-
def wire_chip
|
334
|
-
unless @chip_clicked.nil?
|
335
|
-
wire_helper = Wire_helper.new(@chip_clicked, @api)
|
336
|
-
wire_helper.setWindowModality(Qt::ApplicationModal)
|
337
|
-
wire_helper.show
|
338
|
-
else
|
339
|
-
Qt::MessageBox.new(Qt::MessageBox::Information, "Wire chip", "No chip loaded").exec
|
340
|
-
end
|
341
|
-
end
|
342
|
-
|
343
|
-
def swd_detect
|
344
|
-
Firmware.new(@api, 'SWD')
|
345
|
-
@api.runSWD
|
346
|
-
code = @api.obtainCodes
|
347
|
-
@console.print('New action: SWD Detect')
|
348
|
-
Qt::MessageBox.new(Qt::MessageBox::Information, "SWD detection", "Detected:\nDP.IDCODE: #{code[:DebugPortId].to_s(16)}\nAP.IDCODE: #{code[:AccessPortId].to_s(16)}\nCPU ID : #{code[:CpuId].to_s(16)}\nDEVICE ID : #{code[:DeviceId].to_s(16)}").exec
|
349
|
-
rescue Exception => msg
|
350
|
-
logger = Logger.new($logFilePath)
|
351
|
-
logger.error msg
|
352
|
-
Qt::MessageBox.new(Qt::MessageBox::Critical, "Critical error", "No device found, check the wiring").exec
|
353
|
-
end
|
354
|
-
|
355
|
-
def swd_export
|
356
|
-
Firmware.new(@api, 'SWD')
|
357
|
-
@api.runSWD
|
358
|
-
filepath = Qt::FileDialog.getSaveFileName(self, tr('Select a file'), '/', tr('Bin file (*.bin)'))
|
359
|
-
unless filepath.nil?
|
360
|
-
@api.dumpFlash(filepath)
|
361
|
-
Qt::MessageBox.new(Qt::MessageBox::Information, "Export status", "Dump finished").exec
|
362
|
-
end
|
363
|
-
rescue Exception => msg
|
364
|
-
logger = Logger.new($logFilePath)
|
365
|
-
logger.error msg
|
366
|
-
Qt::MessageBox.new(Qt::MessageBox::Critical, "Critical error", "No device found, check the wiring").exec
|
367
|
-
end
|
368
|
-
|
369
|
-
def swd_import
|
370
|
-
Firmware.new(@api, 'SWD')
|
371
|
-
@api.runSWD
|
372
|
-
filepath = Qt::FileDialog.getOpenFileName(self, tr('Select a file'), '/')
|
373
|
-
unless filepath.nil?
|
374
|
-
@api.writeFlash(filepath)
|
375
|
-
Qt::MessageBox.new(Qt::MessageBox::Information, "Import status", "Import finished").exec
|
376
|
-
end
|
377
|
-
rescue Exception => msg
|
378
|
-
logger = Logger.new($logFilePath)
|
379
|
-
logger.error msg
|
380
|
-
Qt::MessageBox.new(Qt::MessageBox::Critical, "Critical error", "No device found, check the wiring").exec
|
381
|
-
end
|
382
|
-
|
383
|
-
def swd_erase
|
384
|
-
msg = Qt::MessageBox.new
|
385
|
-
msg.setWindowTitle("Delete the data")
|
386
|
-
msg.setText("You are going to delete all the data. Continue?")
|
387
|
-
msg.setIcon(Qt::MessageBox::Critical)
|
388
|
-
msg.setStandardButtons(Qt::MessageBox::Cancel | Qt::MessageBox::Ok)
|
389
|
-
msg.setDefaultButton(Qt::MessageBox::Cancel)
|
390
|
-
if msg.exec == Qt::MessageBox::Ok
|
391
|
-
Firmware.new(@api, 'SWD')
|
392
|
-
@api.runSWD
|
393
|
-
@api.eraseFlash
|
394
|
-
Qt::MessageBox.new(Qt::MessageBox::Information, "Erase status", "Erase finished").exec
|
395
|
-
end
|
396
|
-
rescue Exception => msg
|
397
|
-
logger = Logger.new($logFilePath)
|
398
|
-
logger.error msg
|
399
|
-
Qt::MessageBox.new(Qt::MessageBox::Critical, "Critical error", "No device found, check the wiring").exec
|
400
|
-
end
|
401
|
-
|
402
|
-
def display_current_firmware
|
403
|
-
if $currentFirmware.nil?
|
404
|
-
Qt::MessageBox.new(Qt::MessageBox::Information, "Firmware", "No firmware loaded").exec
|
405
|
-
else
|
406
|
-
Qt::MessageBox.new(Qt::MessageBox::Information, "Firmware", "Actual firmware: #{$currentFirmware}").exec
|
407
|
-
end
|
408
|
-
end
|
409
|
-
|
410
|
-
def set_firmware
|
411
|
-
Firmware.new(@api,sender.objectName[6, sender.objectName.length])
|
412
|
-
Qt::MessageBox.new(Qt::MessageBox::Information, "Firmware", "#{sender.objectName[6, sender.objectName.length]} firmware loaded").exec
|
413
|
-
end
|
414
|
-
|
415
|
-
def update_uc_firmware
|
416
|
-
msg = Qt::MessageBox.new
|
417
|
-
msg.setWindowTitle("Microcontroler update")
|
418
|
-
msg.setText("Hardsploit must be launch in bootloader mod and dfu-util package must be installed in order to continue. Proceed ?")
|
419
|
-
msg.setIcon(Qt::MessageBox::Question)
|
420
|
-
msg.setStandardButtons(Qt::MessageBox::Cancel | Qt::MessageBox::Ok)
|
421
|
-
msg.setDefaultButton(Qt::MessageBox::Cancel)
|
422
|
-
if msg.exec == Qt::MessageBox::Ok
|
423
|
-
system("dfu-util -D 0483:df11 -a 0 -s 0x08000000 -R --download #{File.expand_path(File.dirname(__FILE__))}'/../Firmware/UC/HARDSPLOIT_FIRMWARE_UC.bin'")
|
424
|
-
end
|
425
|
-
end
|
426
|
-
|
427
|
-
def get_hardsploit_versions
|
428
|
-
if $usbConnected == true
|
429
|
-
Qt::MessageBox.new(Qt::MessageBox::Information, "Hardsploit versions", "GUI VERSION : #{VERSION}\nAPI VERSION : #{HardsploitAPI::VERSION::API}\nBOARD : #{@api.getVersionNumber}").exec
|
430
|
-
else
|
431
|
-
Qt::MessageBox.new(Qt::MessageBox::Information, "Hardsploit versions", "GUI VERSION : #{VERSION}\nAPI VERSION : #{HardsploitAPI::VERSION::API}").exec
|
432
|
-
end
|
433
|
-
end
|
434
|
-
|
435
|
-
def get_log_path
|
436
|
-
Qt::MessageBox.new(Qt::MessageBox::Information, 'Log path', "#{$logFilePath}").exec
|
437
|
-
end
|
438
|
-
|
439
|
-
def get_db_path
|
440
|
-
Qt::MessageBox.new(Qt::MessageBox::Information, 'Database path', "#{$dbFilePath}").exec
|
441
|
-
end
|
442
|
-
|
443
|
-
def get_hardsploit_website
|
444
|
-
Qt::MessageBox.new(Qt::MessageBox::Information, 'Hardsploit website', 'Find all the new about Hardsploit on our website: http://hardsploit.io').exec
|
445
|
-
end
|
446
|
-
|
447
|
-
def check_hardsploit_connection(api)
|
448
|
-
case api.connect
|
449
|
-
when HardsploitAPI::USB_STATE::NOT_CONNECTED
|
450
|
-
$usbConnected = false
|
451
|
-
@console.print('Hardsploit board unconnected, wiring and command execution disabled')
|
452
|
-
when HardsploitAPI::USB_STATE::UNKNOWN_CONNECTED
|
453
|
-
@console.print('The device may be BUSY or a another device with the same IdVendor and IdProduct was found')
|
454
|
-
when HardsploitAPI::USB_STATE::CONNECTED
|
455
|
-
$usbConnected = true
|
456
|
-
api.startFPGA
|
457
|
-
@console.print("Hardsploit board detected GUI V#{VERSION} API V#{HardsploitAPI::VERSION::API} BOARD : #{api.getVersionNumber}")
|
458
|
-
@console.print('Hardsploit ready to suck chip souls !')
|
459
|
-
else
|
460
|
-
@console.print('You are in the else part of a case that should normally never be triggered. Good luck.')
|
461
|
-
end
|
462
|
-
end
|
463
|
-
end
|