Как получить информацию о пользователе от Okta, кроме имени, фамилии и электронной почты? - PullRequest
0 голосов
/ 14 января 2019

Я хотел бы получить другую информацию от Okta, потому что с this.props.auth.getUser() я буду получать только электронную почту, имя и фамилию о пользователе. Но есть много данных об Okta, например, штат, город, адрес, почтовый индекс и т. Д.

Я создаю веб-приложение с ReactJS и Node express, и вход в систему управляется Okta (https://developer.okta.com/),, затем я хотел бы сохранить информацию о пользователях Okta в базе данных.

async checkAuthentication() {
  const authenticated = await this.props.auth.isAuthenticated();

  if (authenticated !== this.state.authenticated) {
    const user = await this.props.auth.getUser();

    console.log(this.props.auth);
    this.setState({
      authenticated,
      user
    });
    this.getUsers();
  }
}

async getUsers() {
  let params = "";
  let url = "";

  if (this.state.user != null) {
    params += "EMAIL=" + this.state.user.email;
  }

  url = params == null ? "/user" : "/user?";
  url += params;
  this.state.users = await this.fetch('get', url);

  if (this.state.users && Object.keys(this.state.users).length == 0) {
    this.saveUser();
  }
}

async saveUser() {
  var user = {
    EMAIL: this.state.user.email,
    NAME: this.state.user.given_name,
    SURNAME: this.state.user.family_name,
    //ORGANIZATION: "this.state.user.organization",
    //PHONE = "this.state.user.primaryPhone",
    //STATE = "this.state.user.state",
    //STREET_ADDRESS = "this.state.user.streetAddress",
    //ZIP_CODE = "this.state.user.zipCode",
  };

  await this.fetch('post', '/user', user);
}

Здесь я хотел бы сохранить другие данные из Okta.

//ORGANIZATION: "this.state.user.organization",
//PHONE = "this.state.user.primaryPhone",
//STATE = "this.state.user.state",
//STREET_ADDRESS = "this.state.user.streetAddress",
//ZIP_CODE = "this.state.user.zipCode",

Ответы [ 2 ]

0 голосов
/ 21 января 2019

auth.getUser () возвращает сведения, доступные в конечной точке / userinfo на сервере авторизации, через который пользователь прошел аутентификацию и авторизацию, как описано здесь.

Если вы также хотите опубликовать другие сведения об этой / конечной точке, выполните следующие действия:

  • перейдите от своего клиента Okta к Admin >> API >> Сервер авторизации >> ваш сервер авторизации
  • на вкладке Претензии добавьте новые претензии со значениями профиля пользователя и в разделе «Включить в тип токена» выберите «Идентификатор токена» и «Запрос Userinfo / id_token»
0 голосов
/ 18 января 2019

Вам нужно указать, что вы хотите в качестве области. Okta имеет области действия по умолчанию, которые следующие: offline_access, phone, address, email, profile, openid. В конфигурации вы можете использовать эти документы https://developer.okta.com/authentication-guide/implementing-authentication/

...