[FL-2226] BadUSB, U2F: missing assets error (#979)
* badusb, u2f: showing error screen if assets are missing * BadUsb: remove dead code * U2F: remove dead code Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
This commit is contained in:
		| @@ -1,6 +1,7 @@ | ||||
| #include "bad_usb_app_i.h" | ||||
| #include <furi.h> | ||||
| #include <furi_hal.h> | ||||
| #include <storage/storage.h> | ||||
|  | ||||
| static bool bad_usb_app_custom_event_callback(void* context, uint32_t event) { | ||||
|     furi_assert(context); | ||||
| @@ -20,6 +21,24 @@ static void bad_usb_app_tick_event_callback(void* context) { | ||||
|     scene_manager_handle_tick_event(app->scene_manager); | ||||
| } | ||||
|  | ||||
| static bool bad_usb_check_assets() { | ||||
|     Storage* fs_api = furi_record_open("storage"); | ||||
|  | ||||
|     File* dir = storage_file_alloc(fs_api); | ||||
|     bool ret = false; | ||||
|  | ||||
|     if(storage_dir_open(dir, BAD_USB_APP_PATH_FOLDER)) { | ||||
|         ret = true; | ||||
|     } | ||||
|  | ||||
|     storage_dir_close(dir); | ||||
|     storage_file_free(dir); | ||||
|  | ||||
|     furi_record_close("storage"); | ||||
|  | ||||
|     return ret; | ||||
| } | ||||
|  | ||||
| BadUsbApp* bad_usb_app_alloc() { | ||||
|     BadUsbApp* app = furi_alloc(sizeof(BadUsbApp)); | ||||
|  | ||||
| @@ -41,11 +60,20 @@ BadUsbApp* bad_usb_app_alloc() { | ||||
|  | ||||
|     view_dispatcher_attach_to_gui(app->view_dispatcher, app->gui, ViewDispatcherTypeFullscreen); | ||||
|  | ||||
|     // Custom Widget | ||||
|     app->widget = widget_alloc(); | ||||
|     view_dispatcher_add_view( | ||||
|         app->view_dispatcher, BadUsbAppViewError, widget_get_view(app->widget)); | ||||
|  | ||||
|     app->bad_usb_view = bad_usb_alloc(); | ||||
|     view_dispatcher_add_view( | ||||
|         app->view_dispatcher, BadUsbAppViewWork, bad_usb_get_view(app->bad_usb_view)); | ||||
|  | ||||
|     scene_manager_next_scene(app->scene_manager, BadUsbAppViewFileSelect); | ||||
|     if(bad_usb_check_assets()) { | ||||
|         scene_manager_next_scene(app->scene_manager, BadUsbSceneFileSelect); | ||||
|     } else { | ||||
|         scene_manager_next_scene(app->scene_manager, BadUsbSceneError); | ||||
|     } | ||||
|  | ||||
|     return app; | ||||
| } | ||||
| @@ -58,6 +86,10 @@ void bad_usb_app_free(BadUsbApp* app) { | ||||
|     view_dispatcher_remove_view(app->view_dispatcher, BadUsbAppViewWork); | ||||
|     bad_usb_free(app->bad_usb_view); | ||||
|  | ||||
|     // Custom Widget | ||||
|     view_dispatcher_remove_view(app->view_dispatcher, BadUsbAppViewError); | ||||
|     widget_free(app->widget); | ||||
|  | ||||
|     // View dispatcher | ||||
|     view_dispatcher_free(app->view_dispatcher); | ||||
|     scene_manager_free(app->scene_manager); | ||||
|   | ||||
| @@ -11,6 +11,7 @@ | ||||
| #include <dialogs/dialogs.h> | ||||
| #include <notification/notification_messages.h> | ||||
| #include <gui/modules/variable_item_list.h> | ||||
| #include <gui/modules/widget.h> | ||||
| #include "views/bad_usb_view.h" | ||||
|  | ||||
| #define BAD_USB_APP_PATH_FOLDER "/any/badusb" | ||||
| @@ -23,6 +24,7 @@ struct BadUsbApp { | ||||
|     SceneManager* scene_manager; | ||||
|     NotificationApp* notifications; | ||||
|     DialogsApp* dialogs; | ||||
|     Widget* widget; | ||||
|  | ||||
|     char file_name[BAD_USB_FILE_NAME_LEN + 1]; | ||||
|     BadUsb* bad_usb_view; | ||||
| @@ -30,6 +32,7 @@ struct BadUsbApp { | ||||
| }; | ||||
|  | ||||
| typedef enum { | ||||
|     BadUsbAppViewError, | ||||
|     BadUsbAppViewFileSelect, | ||||
|     BadUsbAppViewWork, | ||||
| } BadUsbAppView; | ||||
|   | ||||
| @@ -159,8 +159,6 @@ static bool ducky_altchar(const char* charcode) { | ||||
|     uint8_t i = 0; | ||||
|     bool state = false; | ||||
|  | ||||
|     //TODO: numlock | ||||
|  | ||||
|     FURI_LOG_I(WORKER_TAG, "char %s", charcode); | ||||
|  | ||||
|     furi_hal_hid_kb_press(KEY_MOD_LEFT_ALT); | ||||
|   | ||||
| @@ -1,2 +1,3 @@ | ||||
| ADD_SCENE(bad_usb, file_select, FileSelect) | ||||
| ADD_SCENE(bad_usb, work, Work) | ||||
| ADD_SCENE(bad_usb, error, Error) | ||||
|   | ||||
							
								
								
									
										53
									
								
								applications/bad_usb/scenes/bad_usb_scene_error.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								applications/bad_usb/scenes/bad_usb_scene_error.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,53 @@ | ||||
| #include "../bad_usb_app_i.h" | ||||
|  | ||||
| typedef enum { | ||||
|     SubghzCustomEventErrorBack, | ||||
| } BadUsbCustomEvent; | ||||
|  | ||||
| static void | ||||
|     bad_usb_scene_error_event_callback(GuiButtonType result, InputType type, void* context) { | ||||
|     furi_assert(context); | ||||
|     BadUsbApp* app = context; | ||||
|  | ||||
|     if((result == GuiButtonTypeLeft) && (type == InputTypeShort)) { | ||||
|         view_dispatcher_send_custom_event(app->view_dispatcher, SubghzCustomEventErrorBack); | ||||
|     } | ||||
| } | ||||
|  | ||||
| void bad_usb_scene_error_on_enter(void* context) { | ||||
|     BadUsbApp* app = context; | ||||
|  | ||||
|     widget_add_icon_element(app->widget, 0, 0, &I_SDQuestion_35x43); | ||||
|  | ||||
|     widget_add_string_multiline_element( | ||||
|         app->widget, | ||||
|         81, | ||||
|         4, | ||||
|         AlignCenter, | ||||
|         AlignTop, | ||||
|         FontSecondary, | ||||
|         "No SD card or\napp data found.\nThis app will not\nwork without\nrequired files."); | ||||
|  | ||||
|     widget_add_button_element( | ||||
|         app->widget, GuiButtonTypeLeft, "Back", bad_usb_scene_error_event_callback, app); | ||||
|  | ||||
|     view_dispatcher_switch_to_view(app->view_dispatcher, BadUsbAppViewError); | ||||
| } | ||||
|  | ||||
| bool bad_usb_scene_error_on_event(void* context, SceneManagerEvent event) { | ||||
|     BadUsbApp* app = context; | ||||
|     bool consumed = false; | ||||
|  | ||||
|     if(event.type == SceneManagerEventTypeCustom) { | ||||
|         if(event.event == SubghzCustomEventErrorBack) { | ||||
|             view_dispatcher_stop(app->view_dispatcher); | ||||
|             consumed = true; | ||||
|         } | ||||
|     } | ||||
|     return consumed; | ||||
| } | ||||
|  | ||||
| void bad_usb_scene_error_on_exit(void* context) { | ||||
|     BadUsbApp* app = context; | ||||
|     widget_clear(app->widget); | ||||
| } | ||||
| @@ -1 +1,2 @@ | ||||
| ADD_SCENE(u2f, main, Main) | ||||
| ADD_SCENE(u2f, error, Error) | ||||
|   | ||||
							
								
								
									
										49
									
								
								applications/u2f/scenes/u2f_scene_error.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								applications/u2f/scenes/u2f_scene_error.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,49 @@ | ||||
| #include "../u2f_app_i.h" | ||||
|  | ||||
| static void u2f_scene_error_event_callback(GuiButtonType result, InputType type, void* context) { | ||||
|     furi_assert(context); | ||||
|     U2fApp* app = context; | ||||
|  | ||||
|     if((result == GuiButtonTypeLeft) && (type == InputTypeShort)) { | ||||
|         view_dispatcher_send_custom_event(app->view_dispatcher, U2fCustomEventErrorBack); | ||||
|     } | ||||
| } | ||||
|  | ||||
| void u2f_scene_error_on_enter(void* context) { | ||||
|     U2fApp* app = context; | ||||
|  | ||||
|     widget_add_icon_element(app->widget, 0, 0, &I_SDQuestion_35x43); | ||||
|  | ||||
|     widget_add_string_multiline_element( | ||||
|         app->widget, | ||||
|         81, | ||||
|         4, | ||||
|         AlignCenter, | ||||
|         AlignTop, | ||||
|         FontSecondary, | ||||
|         "No SD card or\napp data found.\nThis app will not\nwork without\nrequired files."); | ||||
|  | ||||
|     widget_add_button_element( | ||||
|         app->widget, GuiButtonTypeLeft, "Back", u2f_scene_error_event_callback, app); | ||||
|  | ||||
|     view_dispatcher_switch_to_view(app->view_dispatcher, U2fAppViewError); | ||||
| } | ||||
|  | ||||
| bool u2f_scene_error_on_event(void* context, SceneManagerEvent event) { | ||||
|     U2fApp* app = context; | ||||
|     bool consumed = false; | ||||
|  | ||||
|     if(event.type == SceneManagerEventTypeCustom) { | ||||
|         if(event.event == U2fCustomEventErrorBack) { | ||||
|             view_dispatcher_stop(app->view_dispatcher); | ||||
|             consumed = true; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     return consumed; | ||||
| } | ||||
|  | ||||
| void u2f_scene_error_on_exit(void* context) { | ||||
|     U2fApp* app = context; | ||||
|     widget_clear(app->widget); | ||||
| } | ||||
| @@ -1,4 +1,5 @@ | ||||
| #include "u2f_app_i.h" | ||||
| #include "u2f_data.h" | ||||
| #include <furi.h> | ||||
| #include <furi_hal.h> | ||||
|  | ||||
| @@ -39,11 +40,19 @@ U2fApp* u2f_app_alloc() { | ||||
|  | ||||
|     view_dispatcher_attach_to_gui(app->view_dispatcher, app->gui, ViewDispatcherTypeFullscreen); | ||||
|  | ||||
|     // Custom Widget | ||||
|     app->widget = widget_alloc(); | ||||
|     view_dispatcher_add_view(app->view_dispatcher, U2fAppViewError, widget_get_view(app->widget)); | ||||
|  | ||||
|     app->u2f_view = u2f_view_alloc(); | ||||
|     view_dispatcher_add_view( | ||||
|         app->view_dispatcher, U2fAppViewMain, u2f_view_get_view(app->u2f_view)); | ||||
|  | ||||
|     scene_manager_next_scene(app->scene_manager, U2fAppViewMain); | ||||
|     if(u2f_data_check()) { | ||||
|         scene_manager_next_scene(app->scene_manager, U2fSceneMain); | ||||
|     } else { | ||||
|         scene_manager_next_scene(app->scene_manager, U2fSceneError); | ||||
|     } | ||||
|  | ||||
|     return app; | ||||
| } | ||||
| @@ -55,6 +64,10 @@ void u2f_app_free(U2fApp* app) { | ||||
|     view_dispatcher_remove_view(app->view_dispatcher, U2fAppViewMain); | ||||
|     u2f_view_free(app->u2f_view); | ||||
|  | ||||
|     // Custom Widget | ||||
|     view_dispatcher_remove_view(app->view_dispatcher, U2fAppViewError); | ||||
|     widget_free(app->widget); | ||||
|  | ||||
|     // View dispatcher | ||||
|     view_dispatcher_free(app->view_dispatcher); | ||||
|     scene_manager_free(app->scene_manager); | ||||
|   | ||||
| @@ -10,6 +10,7 @@ | ||||
| #include <dialogs/dialogs.h> | ||||
| #include <notification/notification_messages.h> | ||||
| #include <gui/modules/variable_item_list.h> | ||||
| #include <gui/modules/widget.h> | ||||
| #include "views/u2f_view.h" | ||||
| #include "u2f_hid.h" | ||||
| #include "u2f.h" | ||||
| @@ -29,9 +30,12 @@ typedef enum { | ||||
|  | ||||
|     U2fCustomEventConfirm, | ||||
|  | ||||
|     U2fCustomEventErrorBack, | ||||
|  | ||||
| } GpioCustomEvent; | ||||
|  | ||||
| typedef enum { | ||||
|     U2fAppViewError, | ||||
|     U2fAppViewMain, | ||||
| } U2fAppView; | ||||
|  | ||||
| @@ -40,6 +44,7 @@ struct U2fApp { | ||||
|     ViewDispatcher* view_dispatcher; | ||||
|     SceneManager* scene_manager; | ||||
|     NotificationApp* notifications; | ||||
|     Widget* widget; | ||||
|     osTimerId_t timer; | ||||
|     U2fHid* u2f_hid; | ||||
|     U2fView* u2f_view; | ||||
|   | ||||
| @@ -38,6 +38,26 @@ typedef struct { | ||||
|     uint32_t control; | ||||
| } __attribute__((packed)) U2fCounterData; | ||||
|  | ||||
| bool u2f_data_check() { | ||||
|     bool state = false; | ||||
|     Storage* fs_api = furi_record_open("storage"); | ||||
|     File* file = storage_file_alloc(fs_api); | ||||
|  | ||||
|     if(storage_file_open(file, U2F_CERT_FILE, FSAM_READ, FSOM_OPEN_EXISTING)) { | ||||
|         storage_file_close(file); | ||||
|         if(storage_file_open(file, U2F_CERT_KEY_FILE, FSAM_READ, FSOM_OPEN_EXISTING)) { | ||||
|             state = true; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     storage_file_close(file); | ||||
|     storage_file_free(file); | ||||
|  | ||||
|     furi_record_close("storage"); | ||||
|  | ||||
|     return state; | ||||
| } | ||||
|  | ||||
| bool u2f_data_cert_check() { | ||||
|     bool state = false; | ||||
|     Storage* fs_api = furi_record_open("storage"); | ||||
|   | ||||
| @@ -6,6 +6,8 @@ extern "C" { | ||||
|  | ||||
| #include <furi.h> | ||||
|  | ||||
| bool u2f_data_check(); | ||||
|  | ||||
| bool u2f_data_cert_check(); | ||||
|  | ||||
| uint32_t u2f_data_cert_load(uint8_t* cert); | ||||
|   | ||||
| @@ -39,7 +39,7 @@ static void u2f_view_draw_callback(Canvas* canvas, void* _model) { | ||||
|             canvas, 128 / 2, 3, AlignCenter, AlignTop, "Authentication successfull!"); | ||||
|     } else if(model->display_msg == U2fMsgError) { | ||||
|         canvas_draw_icon(canvas, 22, 15, &I_Error_62x31); | ||||
|         canvas_draw_str_aligned(canvas, 128 / 2, 3, AlignCenter, AlignTop, "Ceritficate missing"); | ||||
|         canvas_draw_str_aligned(canvas, 128 / 2, 3, AlignCenter, AlignTop, "Ceritficate error"); | ||||
|     } | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user