Loopback Geopoint Hook不会持续改变

时间:2017-01-03 05:50:04

标签: javascript node.js google-maps geocoding loopbackjs

我在loopback api应用程序中创建了一个之前的保存挂钩。我的位置模型有一个地址和一个latlng geopoint

  "properties": {
    "name": {
      "type": "string"
    },
    "address": {
      "type": "string"
    },
    "latlng": {
      "type": "geopoint"
    }
  },

在我的common\models\location.js中,我有以下代码:

var https = require('https');
var loopback = require('loopback');
module.exports = function(Location) {
  Location.observe('before save', function(ctx, next) {
    let path = `/maps/api/geocode/json?address=${ctx.instance['address']}&key=AIzaSyCWk3ePB8idTw74LyhR8tLSCmVgbZDKiIQ`
    console.log(path);
    https.get({
      hostname: 'maps.googleapis.com',
      path: encodeURI(path)
    }, (res) => {
      var body = [];
      res.on('data', (d) => {
        body.push(d)
      })
      res.on('end', () =>{
        body = JSON.parse(Buffer.concat(body).toString());
        let latlng = new loopback.GeoPoint({
          lat: body['results'][0]['geometry']['location']['lat'],
          lng: body['results'][0]['geometry']['location']['lng']
        })
        console.log(latlng)
        if (ctx.instance) {
          ctx.instance.latlng = latlng;
        } else {
          ctx.data.latlng = latlng;
        }
      })
    })
     next();
  })
};

我期望此代码要做的是向谷歌地图发出http(s)请求,返回地址的纬度和经度,天真地预测第一个条目正确并将该数据保存到我的模型中属性。我目前正在向控制台输出预期的纬度和经度作为GeoPoint对象:

GeoPoint { lat: 42.3675294, lng: -71.18696609999999 }

如何使用此信息更新我的模型?我试图删除条件if (ctx.instance)没有区别。我尝试使用不同的对象表示法:

ctx.instance['latlng']=latlng

未记录任何错误。我坚持使用MongoDB,但使用内存数据库的问题是一样的。附加代码位于Github.com/andygauge/api.socialconnect

1 个答案:

答案 0 :(得分:1)

此处的问题是next()的展示位置。由于nodejs的异步性质,在http请求完成和处理之前调用了next()。在工作流程进行验证后,将对模型进行更改。

解决方案如下所示:

module.exports = function(Location) {
  Location.observe('before save', function(ctx, next) {
    let path = `/maps/api/geocode/json?address=${ctx.instance['address']}&key=AIzaSyCWk3ePB8idTw74LyhR8tLSCmVgbZDKiIQ`
    console.log(path);
    https.get({
      hostname: 'maps.googleapis.com',
      path: encodeURI(path)
    }, (res) => {
      var body = [];
      res.on('data', (d) => {
        body.push(d)
      })
      res.on('end', () =>{
        body = JSON.parse(Buffer.concat(body).toString());
        let latlng = new loopback.GeoPoint({
          lat: body['results'][0]['geometry']['location']['lat'],
          lng: body['results'][0]['geometry']['location']['lng']
        })
        console.log(latlng)
        if (ctx.instance) {
          ctx.instance.latlng = latlng;
        } else {
          ctx.data.latlng = latlng;
        }
        next();
      })
    })
  })
};

感谢您的观点。