Получение значений из хранилища параметров в AWS - PullRequest
0 голосов
/ 30 декабря 2018

Вот мой код:

const AWS = require('aws-sdk');
const { Client } = require('pg');

function main() {
    AWS.config.update({region:'eu-west-2'});

    let db_user = {
        Name: "postgres_db_user",
        WithDecryption: false
    };

    let db_host = {
        Name: "postgres_db_host",
        WithDecryption: false
    };

    let db_database = {
        Name: "postgres_db_name",
        WithDecryption: false
    };

    let db_password = {
        Name: "postgres_db_password",
        WithDecryption: true
    };

    let db_port = {
        Name: "postgres_db_port",
        WithDecryption: false
    };

    let database_user_name;
    let database_host;
    let database_name;
    let database_port;
    let database_password;

    let ssm = new AWS.SSM();
    ssm.getParameter(db_user, function (err, data) {
        if (err) {
            console.log(err, err.stack);
        } else {
            database_user_name = data;
        }
    });

    ssm.getParameter(db_host, function (err, data) {
        if (err) {
            console.log(err, err.stack);
        } else {
            database_host = data;
        }
    });

    ssm.getParameter(db_database, function (err, data) {
        if (err) {
            console.log(err, err.stack);
        } else {
            database_name = data;
        }
    });

    ssm.getParameter(db_password, function (err, data) {
        if (err) {
            console.log(err, err.stack);
        } else {
            database_password = data;
        }
    });

    ssm.getParameter(db_port, function (err, data) {
        if (err) {
            console.log(err, err.stack);
        } else {
           database_port = data;
        }
    });

    console.log(database_user_name);
    console.log(database_host);
    console.log(database_name);
    console.log(database_password);
    console.log(database_port);

    let client = new Client({
        user: database_user_name,
        host: database_host,
        database: database_name,
        password: database_password,
        port: database_port,
    });
}

main();

Проблема в том, что когда я печатаю переменные, они не определены, и я понятия не имею, почему.Функция SSM getParameter работает, потому что, если я использую отладчик, я вижу значения, но кажется, что по какой-то странной причине переменная данных не сохраняется в переменных.

Если кто-то может мне помочьпочему этот код печатает неопределенные переменные, я был бы признателен.

1 Ответ

0 голосов
/ 30 декабря 2018

Я составлял свой ответ, когда Джон прокомментировал:).

getParameter - асинхронная функция, и она выполняется, пока вы инициализируете клиент со свойствами.

Вот несколько примеровинициализации кодирования (не идеально, но вы можете понять).

var AWS = require('aws-sdk');
AWS.config.update({ region: 'us-east-1' });
var ssm = new AWS.SSM();

function getParameter(param) {
  return new Promise(function (success, reject) {
    ssm.getParameter(param, function (err, data) {
      if (err) {
        reject(err);
      } else {
        success(data);
      }
    });
  });
};

function main() {
  let db_user = {
    Name: "postgres_db_user",
    WithDecryption: false
  };
  let database_user_name;
  var promises = [];
  promises.push(getParameter(db_user));

  Promise.all(promises)
    .then(function (result) {
      database_user_name = result[0].Parameter.Value;
      console.log(database_user_name);
      let client = new Client({
        user: database_user_name
        //rest of the properties
      });
      //rest of the main() function code
    })
    .catch(function (err) {
      console.log(err);
    });
}
main();

Ссылка - https://stackoverflow.com/a/44868681/5030709

...