import 'dart:async'; import 'types/main.dart'; import 'package:flutter/services.dart'; ///Class that implements a singleton object (shared instance) which manages the shared HTTP auth credentials cache. ///On iOS, this class uses the [URLCredentialStorage](https://developer.apple.com/documentation/foundation/urlcredentialstorage) class. ///On Android, this class has a custom implementation using `android.database.sqlite.SQLiteDatabase` because ///[WebViewDatabase](https://developer.android.com/reference/android/webkit/WebViewDatabase) ///doesn't offer the same functionalities as iOS `URLCredentialStorage`. /// ///**Supported Platforms/Implementations**: ///- Android native WebView ///- iOS class HttpAuthCredentialDatabase { static HttpAuthCredentialDatabase? _instance; static const MethodChannel _channel = const MethodChannel( 'com.pichillilorenzo/flutter_inappwebview_credential_database'); ///Gets the database shared instance. static HttpAuthCredentialDatabase instance() { return (_instance != null) ? _instance! : _init(); } static HttpAuthCredentialDatabase _init() { _channel.setMethodCallHandler((call) async { try { return await _handleMethod(call); } on Error catch (e) { print(e); print(e.stackTrace); } }); _instance = HttpAuthCredentialDatabase(); return _instance!; } static Future _handleMethod(MethodCall call) async {} ///Gets a map list of all HTTP auth credentials saved. ///Each map contains the key `protectionSpace` of type [URLProtectionSpace] ///and the key `credentials` of type List<[URLCredential]> that contains all the HTTP auth credentials saved for that `protectionSpace`. /// ///**Supported Platforms/Implementations**: ///- Android native WebView ///- iOS ([Official API - URLCredentialStorage.allCredentials](https://developer.apple.com/documentation/foundation/urlcredentialstorage/1413859-allcredentials)) Future> getAllAuthCredentials() async { Map args = {}; List allCredentials = await _channel.invokeMethod('getAllAuthCredentials', args); List result = []; for (Map map in allCredentials) { var element = URLProtectionSpaceHttpAuthCredentials.fromMap( map.cast()); if (element != null) { result.add(element); } } return result; } ///Gets all the HTTP auth credentials saved for that [protectionSpace]. /// ///**Supported Platforms/Implementations**: ///- Android native WebView ///- iOS Future> getHttpAuthCredentials( {required URLProtectionSpace protectionSpace}) async { Map args = {}; args.putIfAbsent("host", () => protectionSpace.host); args.putIfAbsent("protocol", () => protectionSpace.protocol); args.putIfAbsent("realm", () => protectionSpace.realm); args.putIfAbsent("port", () => protectionSpace.port); List credentialList = await _channel.invokeMethod('getHttpAuthCredentials', args); List credentials = []; for (Map map in credentialList) { var credential = URLCredential.fromMap(map.cast()); if (credential != null) { credentials.add(credential); } } return credentials; } ///Saves an HTTP auth [credential] for that [protectionSpace]. /// ///**Supported Platforms/Implementations**: ///- Android native WebView ///- iOS ([Official API - URLCredentialStorage.set](https://developer.apple.com/documentation/foundation/urlcredentialstorage/1407227-set)) Future setHttpAuthCredential( {required URLProtectionSpace protectionSpace, required URLCredential credential}) async { Map args = {}; args.putIfAbsent("host", () => protectionSpace.host); args.putIfAbsent("protocol", () => protectionSpace.protocol); args.putIfAbsent("realm", () => protectionSpace.realm); args.putIfAbsent("port", () => protectionSpace.port); args.putIfAbsent("username", () => credential.username); args.putIfAbsent("password", () => credential.password); await _channel.invokeMethod('setHttpAuthCredential', args); } ///Removes an HTTP auth [credential] for that [protectionSpace]. /// ///**Supported Platforms/Implementations**: ///- Android native WebView ///- iOS ([Official API - URLCredentialStorage.remove](https://developer.apple.com/documentation/foundation/urlcredentialstorage/1408664-remove)) Future removeHttpAuthCredential( {required URLProtectionSpace protectionSpace, required URLCredential credential}) async { Map args = {}; args.putIfAbsent("host", () => protectionSpace.host); args.putIfAbsent("protocol", () => protectionSpace.protocol); args.putIfAbsent("realm", () => protectionSpace.realm); args.putIfAbsent("port", () => protectionSpace.port); args.putIfAbsent("username", () => credential.username); args.putIfAbsent("password", () => credential.password); await _channel.invokeMethod('removeHttpAuthCredential', args); } ///Removes all the HTTP auth credentials saved for that [protectionSpace]. /// ///**Supported Platforms/Implementations**: ///- Android native WebView ///- iOS Future removeHttpAuthCredentials( {required URLProtectionSpace protectionSpace}) async { Map args = {}; args.putIfAbsent("host", () => protectionSpace.host); args.putIfAbsent("protocol", () => protectionSpace.protocol); args.putIfAbsent("realm", () => protectionSpace.realm); args.putIfAbsent("port", () => protectionSpace.port); await _channel.invokeMethod('removeHttpAuthCredentials', args); } ///Removes all the HTTP auth credentials saved in the database. /// ///**Supported Platforms/Implementations**: ///- Android native WebView ///- iOS Future clearAllAuthCredentials() async { Map args = {}; await _channel.invokeMethod('clearAllAuthCredentials', args); } }