flutter_config2 0.0.1
flutter_config2: ^0.0.1 copied to clipboard
Plugin that exposes environment variables to your Dart code in Flutter as well as to your native code in iOS and Android. Inspired from flutter_config
Config Variables for your Flutter apps. #
Plugin that exposes environment variables to your Dart code in Flutter as well as to your native code in iOS and Android. Upgraded from flutter_config
Basic Usage #
Create a new file .env in the root of your Flutter app:
API_URL=https://myapi.com
FABRIC_ID=myFabric
load all environment varibles in main.dart
import 'package:flutter_config2/flutter_config2.dart';
void main() async {
WidgetsFlutterBinding.ensureInitialized(); // Required by FlutterConfig2
await FlutterConfig2.loadEnvVariables();
runApp(MyApp());
}
Now you can access your environment varibles anywhere in your app.
import 'package:flutter_config2/flutter_config2.dart';
FlutterConfig2.get('FABRIC_ID') // returns 'myFabric'
Keep in mind this module doesn't obfuscate or encrypt secrets for packaging, so do not store sensitive keys in .env. It's basically impossible to prevent users from reverse engineering mobile app secrets, so design your app (and APIs) with that in mind.
Load Environment Varibles in Swift #
First import the plugin
import flutter_config2
Then you can use the .env Variable, replace ENV_API_KEY with yours.
flutter_config2.FlutterConfig2Plugin.env(for: "ENV_API_KEY")
Getting Started #
Install the latest version of the plugin
Refer to Android Setup Guide for initial setup and advanced options
No additional setup is required for iOS, however, for advanced usage refer to the iOS Setup Guide
Testing #
Whenever you need to use FlutterConfig2 in your tests, simply use the method loadValueForTesting
import 'package:flutter_config2/flutter_config2.dart';
void main() {
FlutterConfig2.loadValueForTesting({'BASE_URL': 'https://www.mockurl.com'});
test('mock http client test', () {
final client = HttpClient(
baseUrl: FlutterConfig2.get('BASE_URL')
);
});
}