mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2025-01-02 02:05:05 +03:00
1f4020240b
Fix critical issue with keeloq manufacturer name random change. Now you can emulate any manufacturer system with proper key handling. Came Atomo parcel counter increasing and emulation. Beta test (need rework signal header and make button counter cycle array for encoder).
115 lines
4.3 KiB
C
115 lines
4.3 KiB
C
#include "../subghz_i.h"
|
|
#include "../views/transmitter.h"
|
|
#include <dolphin/dolphin.h>
|
|
#include <lib/subghz/protocols/keeloq.h>
|
|
|
|
void subghz_scene_transmitter_callback(SubGhzCustomEvent event, void* context) {
|
|
furi_assert(context);
|
|
SubGhz* subghz = context;
|
|
view_dispatcher_send_custom_event(subghz->view_dispatcher, event);
|
|
}
|
|
|
|
bool subghz_scene_transmitter_update_data_show(void* context) {
|
|
//ToDo Fix
|
|
SubGhz* subghz = context;
|
|
|
|
if(subghz->txrx->decoder_result) {
|
|
string_t key_str;
|
|
string_t frequency_str;
|
|
string_t modulation_str;
|
|
|
|
string_init(key_str);
|
|
string_init(frequency_str);
|
|
string_init(modulation_str);
|
|
uint8_t show_button = 0;
|
|
|
|
subghz_protocol_decoder_base_deserialize(
|
|
subghz->txrx->decoder_result, subghz->txrx->fff_data);
|
|
subghz_protocol_decoder_base_get_string(subghz->txrx->decoder_result, key_str);
|
|
|
|
if((subghz->txrx->decoder_result->protocol->flag & SubGhzProtocolFlag_Send) ==
|
|
SubGhzProtocolFlag_Send) {
|
|
show_button = 1;
|
|
}
|
|
|
|
subghz_get_frequency_modulation(subghz, frequency_str, modulation_str);
|
|
subghz_view_transmitter_add_data_to_show(
|
|
subghz->subghz_transmitter,
|
|
string_get_cstr(key_str),
|
|
string_get_cstr(frequency_str),
|
|
string_get_cstr(modulation_str),
|
|
show_button);
|
|
|
|
string_clear(frequency_str);
|
|
string_clear(modulation_str);
|
|
string_clear(key_str);
|
|
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
void subghz_scene_transmitter_on_enter(void* context) {
|
|
SubGhz* subghz = context;
|
|
DOLPHIN_DEED(DolphinDeedSubGhzSend);
|
|
if(!subghz_scene_transmitter_update_data_show(subghz)) {
|
|
view_dispatcher_send_custom_event(
|
|
subghz->view_dispatcher, SubGhzCustomEventViewTransmitterError);
|
|
}
|
|
|
|
subghz_view_transmitter_set_callback(
|
|
subghz->subghz_transmitter, subghz_scene_transmitter_callback, subghz);
|
|
|
|
subghz->state_notifications = SubGhzNotificationStateIDLE;
|
|
view_dispatcher_switch_to_view(subghz->view_dispatcher, SubGhzViewIdTransmitter);
|
|
}
|
|
|
|
bool subghz_scene_transmitter_on_event(void* context, SceneManagerEvent event) {
|
|
SubGhz* subghz = context;
|
|
if(event.type == SceneManagerEventTypeCustom) {
|
|
if(event.event == SubGhzCustomEventViewTransmitterSendStart) {
|
|
subghz->state_notifications = SubGhzNotificationStateIDLE;
|
|
if(subghz->txrx->txrx_state == SubGhzTxRxStateRx) {
|
|
subghz_rx_end(subghz);
|
|
}
|
|
if((subghz->txrx->txrx_state == SubGhzTxRxStateIDLE) ||
|
|
(subghz->txrx->txrx_state == SubGhzTxRxStateSleep)) {
|
|
if(!subghz_tx_start(subghz, subghz->txrx->fff_data)) {
|
|
scene_manager_next_scene(subghz->scene_manager, SubGhzSceneShowOnlyRx);
|
|
} else {
|
|
subghz->state_notifications = SubGhzNotificationStateTx;
|
|
subghz_scene_transmitter_update_data_show(subghz);
|
|
}
|
|
}
|
|
return true;
|
|
} else if(event.event == SubGhzCustomEventViewTransmitterSendStop) {
|
|
subghz->state_notifications = SubGhzNotificationStateIDLE;
|
|
if(subghz->txrx->txrx_state == SubGhzTxRxStateTx) {
|
|
subghz_tx_stop(subghz);
|
|
subghz_sleep(subghz);
|
|
}
|
|
return true;
|
|
} else if(event.event == SubGhzCustomEventViewTransmitterBack) {
|
|
subghz->state_notifications = SubGhzNotificationStateIDLE;
|
|
scene_manager_search_and_switch_to_previous_scene(
|
|
subghz->scene_manager, SubGhzSceneStart);
|
|
return true;
|
|
} else if(event.event == SubGhzCustomEventViewTransmitterError) {
|
|
string_set_str(subghz->error_str, "Protocol not found");
|
|
scene_manager_next_scene(subghz->scene_manager, SubGhzSceneShowErrorSub);
|
|
}
|
|
} else if(event.type == SceneManagerEventTypeTick) {
|
|
if(subghz->state_notifications == SubGhzNotificationStateTx) {
|
|
notification_message(subghz->notifications, &sequence_blink_magenta_10);
|
|
}
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
void subghz_scene_transmitter_on_exit(void* context) {
|
|
SubGhz* subghz = context;
|
|
subghz->state_notifications = SubGhzNotificationStateIDLE;
|
|
keeloq_reset_mfname();
|
|
}
|