freerasp 3.0.2
freerasp: ^3.0.2 copied to clipboard
Flutter library for improving app security and threat monitoring on Android and iOS mobile devices. Learn more about provided features on the freeRASP's homepage first.
import 'dart:async';
import 'dart:io';
import 'package:flutter/material.dart';
import 'package:freerasp/talsec_app.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatefulWidget {
const MyApp({final Key? key}) : super(key: key);
@override
_MyAppState createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
/// ThreatTypes to hold current state (Android)
final ThreatType _root = ThreatType("Root");
final ThreatType _emulator = ThreatType("Emulator");
final ThreatType _tamper = ThreatType("Tamper");
final ThreatType _hook = ThreatType("Hook");
final ThreatType _deviceBinding = ThreatType("Device binding");
final ThreatType _untrustedSource =
ThreatType("Untrusted source of installation");
/// ThreatTypes to hold current state (iOS)
final ThreatType _signature = ThreatType("Signature");
final ThreatType _jailbreak = ThreatType("Jailbreak");
final ThreatType _runtimeManipulation = ThreatType("Runtime Manipulation");
final ThreatType _simulator = ThreatType("Simulator");
final ThreatType _deviceChange = ThreatType("Device change");
final ThreatType _deviceId = ThreatType("Device ID");
final ThreatType _unofficialStore = ThreatType("Unofficial Store");
final ThreatType _passcode = ThreatType("Passcode");
final ThreatType _missingSecureEnclave = ThreatType("Missing secure enclave");
/// ThreatTypes to hold current state (common)
final ThreatType _debugger = ThreatType("Debugger");
/// Getter to determine which states we care about
List<Widget> get overview {
if (Platform.isAndroid) {
return [
Text(_root.state),
Text(_debugger.state),
Text(_emulator.state),
Text(_tamper.state),
Text(_hook.state),
Text(_deviceBinding.state),
Text(_untrustedSource.state),
];
}
return [
Text(_signature.state),
Text(_jailbreak.state),
Text(_debugger.state),
Text(_runtimeManipulation.state),
Text(_passcode.state),
Text(_simulator.state),
Text(_missingSecureEnclave.state),
Text(_deviceChange.state),
Text(_deviceId.state),
Text(_unofficialStore.state)
];
}
/// Override initState of the "highest" widget in order to start freeRASP
/// as soon as possible.
@override
void initState() {
super.initState();
initSecurityState();
}
Future<void> initSecurityState() async {
/// Provide TalsecConfig your expected data and then use them in TalsecApp
final TalsecConfig config = TalsecConfig(
/// For Android
androidConfig: AndroidConfig(
expectedPackageName: 'com.aheaditec.freeraspExample',
expectedSigningCertificateHash: 'ek124Mj...',
supportedAlternativeStores: ["com.sec.android.app.samsungapps"],
),
/// For iOS
iosConfig: const IOSconfig(
appBundleId: 'com.aheaditec.freeraspExample',
appTeamId: 'M8AK35...',
),
watcherMail: 'your_mail@example.com',
);
/// Callbacks thrown by library
final TalsecCallback callback = TalsecCallback(
/// For Android
androidCallback: AndroidCallback(
onRootDetected: () => _updateState(_root),
onEmulatorDetected: () => _updateState(_emulator),
onHookDetected: () => _updateState(_hook),
onTamperDetected: () => _updateState(_tamper),
onDeviceBindingDetected: () => _updateState(_deviceBinding),
onUntrustedInstallationDetected: () => _updateState(_untrustedSource),
),
/// For iOS
iosCallback: IOSCallback(
onSignatureDetected: () => _updateState(_signature),
onRuntimeManipulationDetected: () => _updateState(_runtimeManipulation),
onJailbreakDetected: () => _updateState(_jailbreak),
onPasscodeDetected: () => _updateState(_passcode),
onSimulatorDetected: () => _updateState(_simulator),
onMissingSecureEnclaveDetected: () =>
_updateState(_missingSecureEnclave),
onDeviceChangeDetected: () => _updateState(_deviceChange),
onDeviceIdDetected: () => _updateState(_deviceId),
onUnofficialStoreDetected: () => _updateState(_unofficialStore),
),
/// Debugger is common for both platforms
onDebuggerDetected: () => _updateState(_debugger),
);
final TalsecApp app = TalsecApp(
config: config,
callback: callback,
);
/// Turn on freeRASP
app.start();
if (!mounted) return;
}
void _updateState(final ThreatType type) {
setState(() {
// ignore: parameter_assignments
type.threatFound();
});
}
@override
Widget build(final BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(
title: const Text('Plugin example app'),
),
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: overview,
),
),
),
);
}
}
class ThreatType {
final String _text;
bool _isSecure = true;
ThreatType(this._text);
void threatFound() => _isSecure = false;
String get state => '$_text: ${_isSecure ? "Secured" : "Detected"}\n';
}