simplici_auth 1.7.4  simplici_auth: ^1.7.4 copied to clipboard
simplici_auth: ^1.7.4 copied to clipboard
A Flutter package for integrating SimpliciAuth with Google OAuth in Flutter applications. Provides webview-based authentication with customizable configuration and comprehensive OAuth handling.
Simplici Auth Flutter #
A Flutter package for integrating SimpliciAuth with Google OAuth in Flutter applications. This package provides webview-based authentication with customizable configuration and comprehensive OAuth handling.
Features #
- π Google OAuth Integration: Complete Google OAuth 2.0 flow with authorization code exchange
- π WebView Authentication: Secure webview-based authentication
- π± Cross-Platform: Works on iOS, Android, and Web
- π¨ Customizable UI: Fullscreen webview with custom styling
- π Token Management: Automatic token exchange and refresh handling
- π User Data: Complete user profile information retrieval
- β‘ Hook System: Integration with window.handleHooksfor custom flows
- π‘οΈ Error Handling: Comprehensive error handling and logging
Installation #
Add this to your package's pubspec.yaml file:
dependencies:
  simplici_auth: ^1.0.0
Then run:
flutter pub get
Usage #
Basic Usage #
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:simplici_auth/simplici_auth.dart';
void main() {
  WidgetsFlutterBinding.ensureInitialized();
  
  // Hide system UI for fullscreen experience
  SystemChrome.setEnabledSystemUIMode(SystemUiMode.immersiveSticky);
  
  runApp(const MyApp());
}
class MyApp extends StatelessWidget {
  const MyApp({super.key});
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      debugShowCheckedModeBanner: false,
      theme: ThemeData(
        scaffoldBackgroundColor: Colors.transparent,
      ),
      home: SimpliciAuthWebView(
        config: SimpliciAuthConfig(
          instanceId: "your-instance-id",
          environment: "beta", // or "production"
          isCombinedInput: true,
          autoNavigate: true,
          platform: "ios",
          onAuthSuccess: (data) {
            print("Authentication successful: $data");
          },
          onAuthError: (error) {
            print("Authentication error: $error");
          },
        ),
      ),
    );
  }
}
Advanced Usage with Custom Configuration #
class CustomAuthScreen extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: Text('Authentication')),
      body: SimpliciAuthWebView(
        config: SimpliciAuthConfig(
          instanceId: "your-instance-id",
          environment: "production",
          isCombinedInput: false,
          autoNavigate: false,
          platform: "android",
          baseUrl: "https://auth.yourdomain.com",
          userAgent: "Custom UserAgent",
          debugMode: true,
          showLoadingOverlay: true,
          onAuthSuccess: (data) {
            // Handle successful authentication
            print("User authenticated: ${data['email']}");
          },
          onAuthError: (error) {
            // Handle authentication errors
            showDialog(
              context: context,
              builder: (context) => AlertDialog(
                title: Text("Authentication Error"),
                content: Text(error),
                actions: [
                  TextButton(
                    onPressed: () => Navigator.of(context).pop(),
                    child: Text("OK"),
                  ),
                ],
              ),
            );
          },
          onStepChanged: (data) {
            // Handle authentication step changes
            print("Auth step changed: $data");
          },
          onAuthComplete: (data) {
            // Handle authentication completion
            Navigator.of(context).pushReplacement(
              MaterialPageRoute(builder: (context) => HomePage()),
            );
          },
        ),
      ),
    );
  }
}
Configuration Options #
The SimpliciAuthConfig class provides comprehensive configuration options that map directly to the SimpliciAuth webcomponent properties:
Required Parameters #
- instanceId(String) - Your SimpliciAuth instance ID
Core Configuration #
- environment(String) - Environment ("beta" or "production", default: "beta")
- platform(String) - Target platform ("ios", "android", "web", default: "ios")
- page(String?) - Specific page to display
- lang(String?) - Language code (e.g., 'en', 'es', 'fr')
UI Configuration #
- isCombinedInput(bool) - Use combined input UI (default: true)
- autoNavigate(bool) - Enable auto navigation (default: true)
- hideNavigation(bool) - Hide navigation elements (default: false)
- showLoadingOverlay(bool) - Show loading overlay (default: false)
OAuth Redirect URLs #
- microsoftRedirectUrl(String?) - Microsoft OAuth redirect URL
- facebookRedirectUrl(String?) - Facebook OAuth redirect URL
- appleRedirectUrl(String?) - Apple OAuth redirect URL
- googleRedirectUrl(String?) - Google OAuth redirect URL
Advanced Configuration #
- baseUrl(String) - Custom base URL (default: "https://auth.beta.satschel.com")
- jsPath(String) - Path to JavaScript file (default: "/static/js/main.js")
- userAgent(String?) - Custom user agent string
- debugMode(bool) - Enable debug logging (default: false)
- customCSS(String?) - Custom CSS styles
- additionalAttributes(Map<String, String>?) - Additional webcomponent attributes
Callback Functions #
- onAuthSuccess(Function(Map<String, dynamic>)?) - Called when authentication succeeds
- onAuthError(Function(String)?) - Called when authentication fails
- onStepChanged(Function(Map<String, dynamic>)?) - Called when authentication step changes
- onAuthComplete(Function(Map<String, dynamic>)?) - Called when authentication flow completes
- onLoaded(Function()?) - Called when the webcomponent is loaded
Example with All Properties #
SimpliciAuthConfig config = SimpliciAuthConfig(
  instanceId: "your-instance-id",
  environment: "beta",
  platform: "ios",
  page: "login",
  lang: "en",
  isCombinedInput: true,
  autoNavigate: true,
  hideNavigation: false,
  debugMode: true,
  microsoftRedirectUrl: "com.yourapp://oauth/microsoft",
  facebookRedirectUrl: "com.yourapp://oauth/facebook",
  appleRedirectUrl: "com.yourapp://oauth/apple",
  googleRedirectUrl: "com.yourapp://oauth/google",
  onLoaded: () {
    print("SimpliciAuth component loaded");
  },
  onAuthSuccess: (data) {
    print("Authentication successful: ${data['email']}");
  },
  onAuthError: (error) {
    print("Authentication error: $error");
  },
  onStepChanged: (data) {
    print("Authentication step changed: $data");
  },
  onAuthComplete: (data) {
    print("Authentication complete: $data");
  },
);
Configuration #
The package automatically handles:
- Google OAuth Configuration: Receives instance details from the webcomponent
- Token Exchange: Exchanges authorization codes for access tokens
- User Information: Retrieves user profile data from Google
- Hook Integration: Calls window.handleHookswith authentication data
Data Flow #
- Instance Details: Webcomponent sends Google OAuth configuration
- Authorization: User authenticates via Google OAuth
- Code Exchange: Authorization code is exchanged for access token
- Hook Call: window.handleHooksis called with authentication data
- User Data: Complete user information is retrieved and set as sso_user_data
Response Format #
The package sets sso_user_data with the following structure:
{
  "provider": "google",
  "access_token": "ya29.a0...",
  "code": "4/0AfJohX...",
  "redirect_url": "com.googleusercontent.apps...",
  "instanceId": "686792efe1934dbaa5b8c988",
  "type": "embeded",
  "responseType": "json",
  "refresh_token": "1//04...",
  "expires_in": 3599,
  "email": "user@example.com",
  "userId": "686d0c009e6a67af37701b79",
  "firstName": "John",
  "lastName": "Doe",
  "hook_result": {
    "statusCode": 200,
    "message": "ok",
    "data": { ... }
  }
}
Requirements #
- Flutter SDK: >=1.17.0
- Dart SDK: ^3.8.1
Dependencies #
- webview_flutter: ^4.2.2
- flutter_inappwebview: ^6.0.0
- http: ^1.1.0
Platform Support #
| Platform | Support | 
|---|---|
| Android | β | 
| iOS | β | 
| Web | β | 
| macOS | β | 
| Linux | β | 
| Windows | β | 
Example #
Check out the example directory for a complete implementation.
Contributing #
Contributions are welcome! Please feel free to submit a Pull Request.
License #
This project is licensed under the MIT License - see the LICENSE file for details.
Support #
If you have any questions or need help, please open an issue on GitHub.