我一直在为一个项目创建一个 Autodesk 3D 查看器系统。
我正在尝试将 3D 模型文件(*.rvt 扩展名)上传到我的流星服务器,然后使用 Autodesk View and Data API 进行翻译。
我正在使用流星上传将文件上传到系统。上传完成后,回调函数会触发 Meteor 方法调用,以将此文件上传到 Autodesk API 并对其进行翻译。
流星上传的客户端代码:
Template.uploader.helpers({
afterUpload: function(){
return {
finished:function(index,fileinfo,content){
console.log(fileinfo);
Meteor.call('translateFile', fileinfo.name, function(err,result){
console.log(result);
});
}
}
}
});
即使在开始上传之前,控制台日志也会打印 undefined。以下是服务器代码
translateFile:function(name){
var filename =process.env.PWD + '/.data/' + name ;
var bucket =
'model'
+ new Date ().toISOString ().replace (/T/, '-').replace (/:+/g, '-').replace (/\..+/, '')
+ '-' + lmv.Lmv.getToken ().toLowerCase ().replace (/\W+/g, '') ;
var policy ='persistent' ;
console.log(bucket);
async.waterfall ([
function (callbacks1) {
console.log ('createBucketIfNotExist') ;
new lmv.Lmv(bucket).createBucketIfNotExist (policy)
.on ('success', function (data) {
console.log ('Bucket already or now exist!') ;
callbacks1 (null, data) ;
})
.on ('fail', function (err) {
console.log ('Failed to create bucket!') ;
callbacks1 (err) ;
})
;
},
function (arg1, callbacks2) {
console.log ('async upload') ;
new lmv.Lmv(bucket).uploadFile (filename)
.on ('success', function (data) {
console.log (filename + ' uploaded.') ;
callbacks2 (null, data) ;
})
.on ('fail', function (err) {
console.log ('Failed to upload ' + filename + '!') ;
callbacks2 (err) ;
})
;
},
function (arg1, callbacks3) {
console.log ('Launching translation') ;
var urn =JSON.parse (arg1).objects [0].id ;
new lmv.Lmv (bucket).register (urn)
.on ('success', function (data) {
console.log ('Translation requested.') ;
callbacks3 (null, data) ;
})
.on ('fail', function (err) {
console.log ('Failed to request translation!') ;
callbacks3 (err) ;
})
;
}
], function (err, results) {
console.log(results.urn);
console.log(results);
console.log(err);
if (err){
console.log(err);
return err;
}
if(results){
Document.insert({urn:results.urn,name:name});
console.log('inserting');
}
}) ;
console.log('---------------------HERE AT THE END---------------------')
},
客户端代码是:
Meteor.call('translateFile', name, function(err,result){
console.log(result);
})
问题是该方法立即返回 undefined 值,并且 async.waterfall 中的所有控制台日志都以正确的顺序打印,除了最后一个回调“插入”中的那个。这是因为 Document.insert 函数没有被调用/触发,我什至没有收到错误。
我试过 Futures 库没用。我什至尝试将插入函数放在不同的方法中,仍然没有用。
任何想法都会非常有帮助。如有必要,我很乐意提供更多信息。