call method
Executes this Callable HTTPS trigger asynchronously.
The data passed into the trigger can be any of the following types:
null
String
num
List, where the contained objects are also one of these types.
Map, where the values are also one of these types.
The request to the Cloud Functions backend made by this method automatically includes a Firebase Instance ID token to identify the app instance. If a user is logged in with Firebase Auth, an auth ID token for the user is also automatically included.
Implementation
@override
Future<dynamic> call([Object? parameters]) async {
if (origin != null) {
final uri = Uri.parse(origin!);
_webFunctions.useFunctionsEmulator(uri.host, uri.port);
}
functions_interop.HttpsCallableOptions callableOptions =
functions_interop.HttpsCallableOptions(
timeout: options.timeout.inMilliseconds.toJS,
limitedUseAppCheckTokens: options.limitedUseAppCheckToken.toJS,
);
late functions_interop.HttpsCallable callable;
if (name != null) {
callable = _webFunctions.httpsCallable(name!, callableOptions);
} else if (uri != null) {
callable = _webFunctions.httpsCallableUri(uri!, callableOptions);
} else {
throw ArgumentError('Either name or uri must be provided');
}
functions_interop.HttpsCallableResult response;
final JSAny? parametersJS = parameters?.jsify();
try {
response = await callable.call(parametersJS);
} catch (e, s) {
throw convertFirebaseFunctionsException(e as JSObject, s);
}
return response.data;
}