simplici_auth_flutter 1.3.7 copy "simplici_auth_flutter: ^1.3.7" to clipboard
simplici_auth_flutter: ^1.3.7 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.handleHooks for 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.handleHooks with authentication data

Data Flow #

  1. Instance Details: Webcomponent sends Google OAuth configuration
  2. Authorization: User authenticates via Google OAuth
  3. Code Exchange: Authorization code is exchanged for access token
  4. Hook Call: window.handleHooks is called with authentication data
  5. 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.

1
likes
0
points
41
downloads

Publisher

unverified uploader

Weekly Downloads

A Flutter package for integrating SimpliciAuth with Google OAuth in Flutter applications. Provides webview-based authentication with customizable configuration and comprehensive OAuth handling.

Repository (GitHub)
View/report issues

Topics

#authentication #oauth #google #webview #simplici

License

unknown (license)

Dependencies

flutter, flutter_inappwebview, http, webview_flutter

More

Packages that depend on simplici_auth_flutter