Я использую фреймворк loopback для генерации своих API. Теперь я пытаюсь написать пользовательский «RemoteMethod», для которого потребуется длинное число (временная метка в формате unix, например 1466598625506), и вернуть массив объектов синхронизации (я использую доработку для общения с конечными точками). В моем приложении для Android, когда я вызываю конечную точку «getRecodsAfterTimestamp», он должен возвращать записи с равным или большим значением времениStamp, чем указанное в запросе. То, что возвращается, - это все записи (3 в это время).Loopback удаленный метод не возвращает правильные значения
Это как моя модель (sync.json) называется синхронизация выглядит следующим образом:
{
"name": "Sync",
"base": "PersistedModel",
"idInjection": true,
"options": {
"validateUpsert": true
},
"properties": {
"uuid": {
"type": "string"
},
"table": {
"type": "string"
},
"action": {
"type": "string"
},
"timeChanged": {
"type": "number"
}
},
"validations": [],
"relations": {},
"acls": [],
"methods": {}
}
И это мой sync.js с удаленного метода выглядит следующим образом:
module.exports = function(Sync) {
Sync.getRecodsAfterTimestamp = function(timestamp, cb){
// var response;
Sync.find({where:{ or: [
{timeChanged:timestamp},
{timeChanged: {gt:timestamp } }
] }}, function(err, sync) {
cb(null,sync);
// response.push(sync);
});
// cb(null, response);
}
Sync.remoteMethod (
'getRecodsAfterTimestamp',
{
http: {path: '/getRecodsAfterTimestamp', verb: 'get'},
accepts: {arg: 'timeChanged', type: 'number', http: { source: 'query' } },
returns: {
arg: 'data',
type: 'array',
root: true
}
}
);
};
я не знаю, если это имеет значение, но это мой метод модифицированной декларации:
@GET("Syncs")
Call<List<Sync>> getAllSyncsAfterThisTimeStamp(@Query(("getRecodsAfterTimestamp?timeChanged=")) long timeChanged);
И вот я звоню это так:
Long timeStamp = 1466598625506L;
Log.e(TAG, "Job Service task is running...");
getAllSyncsCall = espcService.getAllSyncsAfterThisTimeStamp(timeStamp);
getAllSyncsCall.enqueue(EspcJobSheculerService.this);
Это не результат я хочу. Он должен был вернуть все записи после 1466598625506
, который состоит только из двух записей.