Merge branch 'permisstionIos15+' of https://github.com/phamconganh/flutter_inappwebview into phamconganh-permisstionIos15+

This commit is contained in:
Lorenzo Pichilli 2022-04-21 12:44:30 +02:00
commit 09edc2890b
1 changed files with 56 additions and 0 deletions

View File

@ -1485,6 +1485,43 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
return result; return result;
} }
@available(iOS 15.0, *)
@available(macOS 12.0, *)
@available(macCatalyst 15.0, *)
public func webView(_ webView: WKWebView,
requestMediaCapturePermissionFor origin: WKSecurityOrigin,
initiatedByFrame frame: WKFrameInfo,
type: WKMediaCaptureType,
decisionHandler: @escaping (WKPermissionDecision) -> Void) {
onPermissionRequest(origin: origin, type: type, result: {(result) -> Void in
if result is FlutterError {
print((result as! FlutterError).message ?? "")
decisionHandler(.deny)
}
else if (result as? NSObject) == FlutterMethodNotImplemented {
decisionHandler(.deny)
}
else {
var response: [String: Any]
if let r = result {
response = r as! [String: Any]
var action = response["action"] as? Int
action = action != nil ? action : 0;
// var resources = response["resources"] as? [String]
switch action {
case 1:
decisionHandler(.grant)
break
default:
decisionHandler(.deny)
}
return;
}
decisionHandler(.deny)
}
})
}
@available(iOS 13.0, *) @available(iOS 13.0, *)
public func webView(_ webView: WKWebView, public func webView(_ webView: WKWebView,
decidePolicyFor navigationAction: WKNavigationAction, decidePolicyFor navigationAction: WKNavigationAction,
@ -2426,6 +2463,25 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
channel?.invokeMethod("onNavigationResponse", arguments: navigationResponse.toMap(), result: result) channel?.invokeMethod("onNavigationResponse", arguments: navigationResponse.toMap(), result: result)
} }
@available(iOS 15.0, *)
@available(macOS 12.0, *)
@available(macCatalyst 15.0, *)
public func onPermissionRequest(origin: WKSecurityOrigin, type: WKMediaCaptureType, result: FlutterResult?) {
let resources: [String];
switch type {
case .camera:
resources = ["camera"]
break;
case .microphone:
resources = ["microphone"]
break;
default:
resources = ["cameraAndMicrophone"]
}
let arguments: [String: Any] = ["origin": origin.protocol + "://" + origin.host, "resources": resources]
channel?.invokeMethod("onPermissionRequest", arguments: arguments, result: result)
}
public func onReceivedHttpAuthRequest(challenge: URLAuthenticationChallenge, result: FlutterResult?) { public func onReceivedHttpAuthRequest(challenge: URLAuthenticationChallenge, result: FlutterResult?) {
channel?.invokeMethod("onReceivedHttpAuthRequest", channel?.invokeMethod("onReceivedHttpAuthRequest",
arguments: HttpAuthenticationChallenge(fromChallenge: challenge).toMap(), result: result) arguments: HttpAuthenticationChallenge(fromChallenge: challenge).toMap(), result: result)