Проблемы с интеграцией cosmos auth и Identity Manager

Я хочу интегрировать cosmos-auth с Idm GE. Конфигурация приложения node.js:

{
"host": "192.168.4.180",
"port": 13000,
"private_key_file": "key.pem",
"certificate_file": "cert.pem",
"idm": {
  "host": "192.168.4.33",
  "port": "443",
  "path": "/oauth2/token"
},
"cosmos_app": {
  "client_id": "0434fdf60897479588c3c31cfc957b6d",
  "client_secret": "a7c3540aa5de4de3a0b1c52a606b82df"
},
"log": {
  "file_name": "/var/log/cosmos/cosmos-auth/cosmos-auth.log",
  "date_pattern": ".dd-MM-yyyy"
 }
}

Когда я отправляю HTTP-запрос POST напрямую в IDM GE на url

https://192.168.4.33:443/oauth2/token

с необходимыми параметрами я получаю нормальные результаты:

{
 access_token: "LyZT5DRGSn0F8IKqYU8EmRFTLo1iPJ"
 token_type: "Bearer"
 expires_in: 3600
 refresh_token: "XiyfKCHrIVyludabjaCyGqVsTkx8Sf"
}

Но когда я скручиваю приложение cosmos-auth node.js

curl -X POST "https://192.168.4.180:13000/cosmos-auth/v1/token" -H 
"Content-Type: application/x-www-form-urlencoded" -d   
"grant_type=password&username=idm&password=idm" -k

Получаю следующий результат:

{"statusCode":500,"error":"Internal Server Error","message":"An internal server error occurred"}

Кто-нибудь сталкивался с чем-то подобным? В чем может быть проблема?


person Milos Miletic    schedule 18.08.2015    source источник
comment
Ошибка, которую вы получаете, - это просто пересылка ошибки, отправленной IdM, в cosmos-auth. Пожалуйста, не могли бы вы проверить логи IdM, чтобы найти более подробное объяснение того, что происходит?   -  person frb    schedule 19.08.2015


Ответы (1)


Ошибка, которую я сделал, заключалась в использовании неподписанного сертификата. Какая неуклюжая с моей стороны. Поэтому либо подпишите сертификат, либо вставьте дополнительный элемент в объект параметров (rejectUnauthorized: false)

var options = {
    host : host,
    port : port,
    path : path,
    method : method,
    headers: headers,
    rejectUnauthorized: false
};

или в начале файла вставьте:

process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0';

Конечно, это временное решение, пока мы не используем полностью подписанный сертификат. В любом случае обработка ошибок и логи в приложении cosmos-auth node.js должны показать немного больше.

person Milos Miletic    schedule 19.08.2015