Skip to content

Commit

Permalink
Implemented #177 (#179)
Browse files Browse the repository at this point in the history
  • Loading branch information
akopachov authored Aug 1, 2023
1 parent d6b3066 commit 6a4cbc4
Show file tree
Hide file tree
Showing 12 changed files with 67 additions and 120 deletions.
67 changes: 4 additions & 63 deletions build.ps1
Original file line number Diff line number Diff line change
@@ -1,6 +1,4 @@
param (
[switch]$doNotBuildBaseFap = $false,
[switch]$buildCustomFontFap = $false,
[switch]$doNotClearBuildFolder = $false
)

Expand Down Expand Up @@ -79,68 +77,11 @@ function Build-Run {
}
}

if ($doNotBuildBaseFap -eq $false) {
Write-Information 'Building with all the features enables'
Build-Run -FeaturesSuffix ''
Write-Information 'Building with all the features enables'
Build-Run -FeaturesSuffix ''

Write-Information 'Building with BadBT but without BadBT icon'
Build-Run -FeaturesSuffix '_badbt-wo-icon' -CppDefine TOTP_NO_AUTOMATION_ICONS

Write-Information 'Building without BadBT'
Build-Run -FeaturesSuffix '_no-badbt' -CppDefine TOTP_NO_BADBT_TYPE,TOTP_NO_AUTOMATION_ICONS
}

if ($buildCustomFontFap -eq $true) {
$custom_fonts = @(
[PSCustomObject]@{
CDEF = "TOTP_FONT_REDHATMONO";
Subfolder = 'Redhat_Mono'
},
[PSCustomObject]@{
CDEF = "TOTP_FONT_BEDSTEAD";
Subfolder = 'Bedstead'
},
[PSCustomObject]@{
CDEF = "TOTP_FONT_ZECTOR";
Subfolder = 'Zector'
},
[PSCustomObject]@{
CDEF = "TOTP_FONT_712SERIF";
Subfolder = '7-12_Serif'
},
[PSCustomObject]@{
CDEF = "TOTP_FONT_GRAPH35PIX";
Subfolder = 'Graph35_pix'
},
[PSCustomObject]@{
CDEF = "TOTP_FONT_KARMAFUTURE";
Subfolder = 'Karma_future'
},
[PSCustomObject]@{
CDEF = "TOTP_FONT_FUNCLIMBING";
Subfolder = 'Funclimbing'
},
[PSCustomObject]@{
CDEF = "TOTP_FONT_DPCOMIC";
Subfolder = 'DPComic'
},
[PSCustomObject]@{
CDEF = "TOTP_FONT_PIXELFLAG";
Subfolder = 'Pixel_flag'
}
)

foreach ($custom_font in $custom_fonts) {
Write-Information "Custom font ($($custom_font.Subfolder)): Building with all the features enables"
Build-Run -FeaturesSuffix '' -CppDefine TOTP_FONT=$($custom_font.CDEF) -Subfolder $($custom_font.Subfolder)

Write-Information "Custom font ($($custom_font.Subfolder)): Building with BadBT but without BadBT icon"
Build-Run -FeaturesSuffix '_badbt-wo-icon' -CppDefine TOTP_NO_AUTOMATION_ICONS,TOTP_FONT=$($custom_font.CDEF) -Subfolder $($custom_font.Subfolder)

Write-Information "Custom font ($($custom_font.Subfolder)): Building without BadBT"
Build-Run -FeaturesSuffix '_no-badbt' -CppDefine TOTP_NO_BADBT_TYPE,TOTP_NO_AUTOMATION_ICONS,TOTP_FONT=$($custom_font.CDEF) -Subfolder $($custom_font.Subfolder)
}
}
Write-Information 'Building without BadBT'
Build-Run -FeaturesSuffix '_no-badbt' -CppDefine TOTP_NO_BADBT_AUTOMATION

$checksum_file = 'build/checksums.sha256'
New-Item $checksum_file -ItemType File -Force
Expand Down
2 changes: 1 addition & 1 deletion totp/application.fam
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ App(
],
stack_size=2 * 1024,
order=20,
fap_version="3.10",
fap_version="3.20",
fap_author="Alexander Kopachov (@akopachov)",
fap_description="Software-based TOTP authenticator for Flipper Zero device",
fap_weburl="https://github.com/akopachov/flipper-zero_authenticator",
Expand Down
14 changes: 7 additions & 7 deletions totp/cli/commands/automation/automation.c
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
#define TOTP_CLI_COMMAND_AUTOMATION_ARG_METHOD "automation"
#define TOTP_CLI_COMMAND_AUTOMATION_METHOD_NONE "none"
#define TOTP_CLI_COMMAND_AUTOMATION_METHOD_USB "usb"
#ifdef TOTP_BADBT_TYPE_ENABLED
#ifdef TOTP_BADBT_AUTOMATION_ENABLED
#define TOTP_CLI_COMMAND_AUTOMATION_METHOD_BT "bt"
#endif
#define TOTP_CLI_COMMAND_AUTOMATION_LAYOUT_QWERTY "QWERTY"
Expand All @@ -31,7 +31,7 @@ void totp_cli_command_automation_docopt_arguments() {
" " TOTP_CLI_COMMAND_AUTOMATION_ARG_METHOD
" Automation method to be set. Must be one of: " TOTP_CLI_COMMAND_AUTOMATION_METHOD_NONE
", " TOTP_CLI_COMMAND_AUTOMATION_METHOD_USB
#ifdef TOTP_BADBT_TYPE_ENABLED
#ifdef TOTP_BADBT_AUTOMATION_ENABLED
", " TOTP_CLI_COMMAND_AUTOMATION_METHOD_BT
#endif
"\r\n");
Expand All @@ -47,17 +47,17 @@ void totp_cli_command_automation_docopt_options() {
}

static void print_method(AutomationMethod method, const char* color) {
#ifdef TOTP_BADBT_TYPE_ENABLED
#ifdef TOTP_BADBT_AUTOMATION_ENABLED
bool has_previous_method = false;
#endif
if(method & AutomationMethodBadUsb) {
TOTP_CLI_PRINTF_COLORFUL(color, "\"" TOTP_CLI_COMMAND_AUTOMATION_METHOD_USB "\"");
#ifdef TOTP_BADBT_TYPE_ENABLED
#ifdef TOTP_BADBT_AUTOMATION_ENABLED
has_previous_method = true;
#endif
}

#ifdef TOTP_BADBT_TYPE_ENABLED
#ifdef TOTP_BADBT_AUTOMATION_ENABLED
if(method & AutomationMethodBadBt) {
if(has_previous_method) {
TOTP_CLI_PRINTF_COLORFUL(color, " and ");
Expand Down Expand Up @@ -121,7 +121,7 @@ void totp_cli_command_automation_handle(PluginState* plugin_state, FuriString* a
new_method_provided = true;
new_method |= AutomationMethodBadUsb;
}
#ifdef TOTP_BADBT_TYPE_ENABLED
#ifdef TOTP_BADBT_AUTOMATION_ENABLED
else if(furi_string_cmpi_str(temp_str, TOTP_CLI_COMMAND_AUTOMATION_METHOD_BT) == 0) {
new_method_provided = true;
new_method |= AutomationMethodBadBt;
Expand Down Expand Up @@ -161,7 +161,7 @@ void totp_cli_command_automation_handle(PluginState* plugin_state, FuriString* a
totp_cli_print_error_updating_config_file();
}

#ifdef TOTP_BADBT_TYPE_ENABLED
#ifdef TOTP_BADBT_AUTOMATION_ENABLED
if(!(new_method & AutomationMethodBadBt) &&
plugin_state->bt_type_code_worker_context != NULL) {
totp_bt_type_code_worker_free(plugin_state->bt_type_code_worker_context);
Expand Down
9 changes: 2 additions & 7 deletions totp/features_config.h
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,8 @@
#endif

// Include Bluetooth token input automation
#ifndef TOTP_NO_BADBT_TYPE
#define TOTP_BADBT_TYPE_ENABLED
#endif

// Include token input automation icons on the main screen
#ifndef TOTP_NO_AUTOMATION_ICONS
#define TOTP_AUTOMATION_ICONS_ENABLED
#ifndef TOTP_NO_BADBT_AUTOMATION
#define TOTP_BADBT_AUTOMATION_ENABLED
#endif

// List of compatible firmwares
Expand Down
21 changes: 10 additions & 11 deletions totp/services/config/config.c
Original file line number Diff line number Diff line change
Expand Up @@ -111,7 +111,16 @@ static char* totp_config_file_backup_i(Storage* storage) {
static bool totp_open_config_file(Storage* storage, FlipperFormat** file) {
FlipperFormat* fff_data_file = flipper_format_file_alloc(storage);

if(storage_common_stat(storage, CONFIG_FILE_PATH, NULL) == FSE_OK) {
bool conf_file_exists = storage_common_stat(storage, CONFIG_FILE_PATH, NULL) == FSE_OK;
if(!conf_file_exists) {
FURI_LOG_I(LOGGING_TAG, "Application catalog needs to be migrated");
FS_Error migration_result =
storage_common_migrate(storage, EXT_PATH("authenticator"), CONFIG_FILE_DIRECTORY_PATH);
FURI_LOG_I(LOGGING_TAG, "Migrated catalog. Result code: %d", (int)migration_result);
conf_file_exists = storage_common_stat(storage, CONFIG_FILE_PATH, NULL) == FSE_OK;
}

if(conf_file_exists) {
FURI_LOG_D(LOGGING_TAG, "Config file %s found", CONFIG_FILE_PATH);
if(!flipper_format_file_open_existing(fff_data_file, CONFIG_FILE_PATH)) {
FURI_LOG_E(LOGGING_TAG, "Error opening existing file %s", CONFIG_FILE_PATH);
Expand All @@ -120,16 +129,6 @@ static bool totp_open_config_file(Storage* storage, FlipperFormat** file) {
}
} else {
FURI_LOG_D(LOGGING_TAG, "Config file %s is not found. Will create new.", CONFIG_FILE_PATH);
if(storage_common_stat(storage, CONFIG_FILE_DIRECTORY_PATH, NULL) == FSE_NOT_EXIST) {
FURI_LOG_D(
LOGGING_TAG,
"Directory %s doesn't exist. Will create new.",
CONFIG_FILE_DIRECTORY_PATH);
if(!storage_simply_mkdir(storage, CONFIG_FILE_DIRECTORY_PATH)) {
FURI_LOG_E(LOGGING_TAG, "Error creating directory %s", CONFIG_FILE_DIRECTORY_PATH);
return false;
}
}

if(!flipper_format_file_open_new(fff_data_file, CONFIG_FILE_PATH)) {
totp_close_config_file(fff_data_file);
Expand Down
2 changes: 1 addition & 1 deletion totp/services/config/constants.h
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

#include <storage/storage.h>

#define CONFIG_FILE_DIRECTORY_PATH EXT_PATH("authenticator")
#define CONFIG_FILE_DIRECTORY_PATH STORAGE_APP_DATA_PATH_PREFIX
#define CONFIG_FILE_HEADER "Flipper TOTP plugin config file"
#define CONFIG_FILE_ACTUAL_VERSION (8)

Expand Down
9 changes: 6 additions & 3 deletions totp/totp_app.c
Original file line number Diff line number Diff line change
Expand Up @@ -134,7 +134,7 @@ static bool totp_plugin_state_init(PluginState* const plugin_state) {

plugin_state->event_queue = furi_message_queue_alloc(8, sizeof(PluginEvent));

#ifdef TOTP_BADBT_TYPE_ENABLED
#ifdef TOTP_BADBT_AUTOMATION_ENABLED
if(plugin_state->automation_method & AutomationMethodBadBt) {
plugin_state->bt_type_code_worker_context = totp_bt_type_code_worker_init();
} else {
Expand Down Expand Up @@ -168,14 +168,17 @@ static void totp_plugin_state_free(PluginState* plugin_state) {
free(plugin_state->crypto_verify_data);
}

#ifdef TOTP_BADBT_TYPE_ENABLED
#ifdef TOTP_BADBT_AUTOMATION_ENABLED
if(plugin_state->bt_type_code_worker_context != NULL) {
totp_bt_type_code_worker_free(plugin_state->bt_type_code_worker_context);
plugin_state->bt_type_code_worker_context = NULL;
}
#endif

furi_message_queue_free(plugin_state->event_queue);
if(plugin_state->event_queue != NULL) {
furi_message_queue_free(plugin_state->event_queue);
}

free(plugin_state);
}

Expand Down
2 changes: 1 addition & 1 deletion totp/types/automation_method.h
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ typedef uint8_t AutomationMethod;
enum AutomationMethods {
AutomationMethodNone = 0b00,
AutomationMethodBadUsb = 0b01,
#ifdef TOTP_BADBT_TYPE_ENABLED
#ifdef TOTP_BADBT_AUTOMATION_ENABLED
AutomationMethodBadBt = 0b10,
#endif
};
4 changes: 2 additions & 2 deletions totp/types/plugin_state.h
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
#include "notification_method.h"
#include "automation_method.h"
#include "automation_kb_layout.h"
#ifdef TOTP_BADBT_TYPE_ENABLED
#ifdef TOTP_BADBT_AUTOMATION_ENABLED
#include "../workers/bt_type_code/bt_type_code.h"
#endif
#include "../services/crypto/constants.h"
Expand Down Expand Up @@ -89,7 +89,7 @@ typedef struct {
*/
AutomationKeyboardLayout automation_kb_layout;

#ifdef TOTP_BADBT_TYPE_ENABLED
#ifdef TOTP_BADBT_AUTOMATION_ENABLED
/**
* @brief Bad-Bluetooth worker context
*/
Expand Down
40 changes: 25 additions & 15 deletions totp/ui/scenes/app_settings/totp_app_settings.c
Original file line number Diff line number Diff line change
Expand Up @@ -12,30 +12,30 @@
#include "../../../services/convert/convert.h"
#include <roll_value.h>
#include "../../../features_config.h"
#ifdef TOTP_BADBT_TYPE_ENABLED
#ifdef TOTP_BADBT_AUTOMATION_ENABLED
#include "../../../workers/bt_type_code/bt_type_code.h"
#endif

#ifdef TOTP_BADBT_AUTOMATION_ENABLED
#define AUTOMATION_LIST_MAX_INDEX (3)
#else
#define AUTOMATION_LIST_MAX_INDEX (1)
#endif
#define BAD_KB_LAYOUT_LIST_MAX_INDEX (1)
#define FONT_TEST_STR_LENGTH (7)

static const char* YES_NO_LIST[] = {"NO", "YES"};
static const char* AUTOMATION_LIST[] = {
"None",
"USB"
#ifdef TOTP_BADBT_TYPE_ENABLED
#ifdef TOTP_BADBT_AUTOMATION_ENABLED
,
"Bluetooth",
"BT and USB"
#endif
};

#ifdef TOTP_BADBT_TYPE_ENABLED
#define AUTOMATION_LIST_MAX_INDEX (3)
#else
#define AUTOMATION_LIST_MAX_INDEX (1)
#endif

static const char* BAD_KB_LAYOUT_LIST[] = {"QWERTY", "AZERTY"};
static const char* FONT_TEST_STR = "0123BCD";
static const uint8_t FONT_TEST_STR_LENGTH = 7;

typedef enum {
HoursInput,
Expand Down Expand Up @@ -71,8 +71,10 @@ void totp_scene_app_settings_activate(PluginState* plugin_state) {
scene_state->tz_offset_minutes = 60.0f * off_dec;
scene_state->notification_sound = plugin_state->notification_method & NotificationMethodSound;
scene_state->notification_vibro = plugin_state->notification_method & NotificationMethodVibro;
scene_state->automation_method = plugin_state->automation_method;
scene_state->automation_kb_layout = plugin_state->automation_kb_layout;
scene_state->automation_method =
MIN(plugin_state->automation_method, AUTOMATION_LIST_MAX_INDEX);
scene_state->automation_kb_layout =
MIN(plugin_state->automation_kb_layout, BAD_KB_LAYOUT_LIST_MAX_INDEX);

scene_state->active_font = plugin_state->active_font_index;
}
Expand Down Expand Up @@ -281,7 +283,11 @@ bool totp_scene_app_settings_handle_event(
RollOverflowBehaviorRoll);
} else if(scene_state->selected_control == BadKeyboardLayoutSelect) {
totp_roll_value_uint8_t(
&scene_state->automation_kb_layout, 1, 0, 1, RollOverflowBehaviorRoll);
&scene_state->automation_kb_layout,
1,
0,
BAD_KB_LAYOUT_LIST_MAX_INDEX,
RollOverflowBehaviorRoll);
}
break;
case InputKeyLeft:
Expand Down Expand Up @@ -311,7 +317,11 @@ bool totp_scene_app_settings_handle_event(
RollOverflowBehaviorRoll);
} else if(scene_state->selected_control == BadKeyboardLayoutSelect) {
totp_roll_value_uint8_t(
&scene_state->automation_kb_layout, -1, 0, 1, RollOverflowBehaviorRoll);
&scene_state->automation_kb_layout,
-1,
0,
BAD_KB_LAYOUT_LIST_MAX_INDEX,
RollOverflowBehaviorRoll);
}
break;
case InputKeyOk:
Expand Down Expand Up @@ -342,7 +352,7 @@ bool totp_scene_app_settings_handle_event(
return false;
}

#ifdef TOTP_BADBT_TYPE_ENABLED
#ifdef TOTP_BADBT_AUTOMATION_ENABLED
if((scene_state->automation_method & AutomationMethodBadBt) == 0 &&
plugin_state->bt_type_code_worker_context != NULL) {
totp_bt_type_code_worker_free(plugin_state->bt_type_code_worker_context);
Expand Down
Loading

0 comments on commit 6a4cbc4

Please sign in to comment.