переворачивает вызов хранимой процедуры. - PullRequest
0 голосов
/ 25 мая 2018

У меня проблема с созданием перехватчика, вызывающего хранимую процедуру.

Мои перехватчики пользовательских сервисов (customservice.hooks.js):

const callstored = require('../../hooks/callstored')
module.exports = {
  before: {
    all: [],
    find: [callstored()],
    get: [],
    create: [],
    update: [],
    patch: [],
    remove: []
  },
 ...

Мой класс сервиса (customservice.class.js):

const mysql = require('mysql')

class Service {
  constructor (options) {
    this.options = options || {};
  }

  find (params) {
    return Promise.resolve( [] );
  }

  get (id, params) {
    return Promise.resolve({

      id, text: `A new message with ID: ${id}!`
    });
  }

  create (data, params) {
    if (Array.isArray(data)) {
      return Promise.all(data.map(current => this.create(current)));
    }

    return Promise.resolve(data);
  }

  update (id, data, params) {
    return Promise.resolve(data);
  }

  patch (id, data, params) {
    return Promise.resolve(data);
  }

  remove (id, params) {
    return Promise.resolve({ id });
  }
}

module.exports = function (options) {
  return new Service(options);
};

module.exports.Service = Service;

И мой сервис (customservice.service.js):

const createService = require('./rankingvotes.class.js');
const hooks = require('./rankingvotes.hooks');

module.exports = function (app) {

  const paginate = app.get('paginate');

  const options = {
    name: 'rankingvotes',
    paginate
  };

  // Initialize our service with any options it requires
  app.use('/rankingvotes', createService(options));

  // Get our initialized service so that we can register hooks and filters
  const service = app.service('rankingvotes');

  service.hooks(hooks);

  app.publish(() => {

  });
};

И, наконец, мой хук это (звонки.js)

const Sequelize = require('sequelize');
module.exports = function () {
  return function (hook) {
    sequelize = hook.app.get('sequelizeClient');
    let result=[];
    return sequelize.query('CALL RANKING();',{
      nest: true,
      raw: true }).then(function(response){
        console.log(response[0]) //data are correct
        hook.data=response[0]; 
        return hook;
      }).error(function(err){
        console.log(err);
        return hook;
      });
  }
}

Если я проверю консоль, я получу данные правильно, но ничего не получаю от REST-клиента, такого как Postman.

Есть идеи?Спасибо.

1 Ответ

0 голосов
/ 25 мая 2018

Если вы хотите изменить ответ, вы должны установить hook.result .

const Sequelize = require('sequelize');
module.exports = function () {
  return async hook => {
    try {
      const sequelize = hook.app.get('sequelizeClient');
      const response = await sequelize.query('CALL RANKING();',{
        nest: true,
        raw: true
      });

      console.log(response[0]) //data are correct
      context.result = response[0]; 
    } catch(error) {
      console.error(error);
    }

    return hook;
  }
}

hook.data - это данные запроса и доступны толькодля create, update и patch.

Имейте в виду, что настройка hook.result будет пропускать ваш пользовательский сервис find, если он установлен в beforeкрюк.

...