General solution :
Client Side:
if (Meteor.isClient) {
Template.herokuDashboard.helpers({
appInfo: function() {
return Session.get("herokuDashboard_appInfo");
}
});
Template.herokuDashboard.created = function(){
Meteor.call('getData', function (error, result) {
Session.set("herokuDashboard_appInfo",result);
} );
}
}
There is no way to directly return results from Meteor.call.
However there are at least 2 solutions (@akshat and @Hubert OG):
How to use Meteor methods inside of a template helper
Server Side (Meteor._wrapAsync):
Using Meteor._wrapAsync :
if (Meteor.isServer) {
var asyncFunc = function(callback){
setTimeout(function(){
// callback(error, result);
// success :
callback(null,"result");
// failure:
// callback(new Error("error"));
},2000)
}
var syncFunc = Meteor._wrapAsync(asyncFunc);
Meteor.methods({
'getData': function(){
var result;
try{
result = syncFunc();
}catch(e){
console.log("getData method returned error : " + e);
}finally{
return result;
}
}
});
}
Proper usage of Future library:
if (Meteor.isServer) {
Future = Npm.require('fibers/future');
Meteor.methods({
'getData': function() {
var fut = new Future();
setTimeout(
Meteor.bindEnvironment(
function() {
fut.return("test");
},
function(exception) {
console.log("Exception : ", exception);
fut.throw(new Error("Async function throw exception"));
}
),
1000
)
return fut.wait();
}
});
}
Using Future library WITHOUT Meteor.bindEnvironment is NOT RECOMMENDED, see:
There is also 3rd approach using Async utilities
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…