Los ejemplos de esta sección demuestran cómo llamar a un Función de reino nombrada sum que toma dos argumentos, los suma y devuelve el resultado:
// sum: adds two numbers exports = function(a, b) { return a + b; };
Nota
Autenticar primero
Usted llama a funciones en un objeto Usuario, por lo tanto, antes de llamar a cualquier función, debe autenticar a un usuario.
Llamar a una función por su nombre
Importante
Asegúrese de desinfectar los datos del cliente para protegerlos contra la inyección de código al usar funciones.
Para ejecutar una función desde el SDK .NET, utilice el método Functions.CallAsync() en el User objeto, pasando el nombre de la función como primer parámetro y los argumentos como los parámetros restantes:
var bsonValue = await user.Functions.CallAsync("sum", 2, 40); // The result must now be cast to Int32: var sum = bsonValue.ToInt32(); // Or use the generic overloads to avoid casting the BsonValue: sum = await user.Functions.CallAsync<int>("sum", 2, 40);
Nota
El método CallAsync() devuelve un único objeto BsonValue, que se puede deserializar después de llamar a la función o mediante la sobrecarga genérica. Ambos métodos de deserialización se muestran en el código anterior.
Un objeto BsonValue puede contener un único valor primitivo (como se muestra en el ejemplo anterior) o un documento BSON completo. Si tiene una clase que asigna el objeto devuelto, puede deserializarlo a esa clase mediante la sobrecarga genérica. Por ejemplo, el siguiente código llama a una función que devuelve un objeto de una colección de "RealmTasks". Como conocemos la forma del objeto devuelto, podemos deserializar BsonValue a una clase que hayamos creado y, de esta manera, acceder a las propiedades y métodos de ese objeto:
var item = await user.Functions.CallAsync<MyClass> ("getItem", "5f7f7638024a99f41a3c8de4"); var name = item.Name;