Перья JS Local Auth не аутентифицируются с дополнительными полями пользователя - PullRequest
0 голосов
/ 30 января 2020

Я создал базовое приложение c Feathers JS и использовал перья / cli для создания локальной аутентификации с помощью службы пользователей.

Поля, необходимые для аутентификации, - это электронная почта и пароль.

В дополнение к этим полям я храню другую информацию о пользователе.

Вот пример записи из MongoDB

{"_id":"5e320297f41de5354c299a55",
"email":"bob@think-engineer.com",
"password":"$2a$10$J832IZpb58Yf2tIPC2Wr5u7RGTAATkwobMZop1n6j/fOT72qe6izq",
"displayName":"Bob"
,"imageUrl":"",
"active":"yes",
"createdAt":"2020-01-29T22:09:27.340Z",
"updatedAt":"2020-01-29T22:09:27.340Z",
"__v":0,
"currentOrgId":"5e3202a2f41de5354c299a56",
"currentProjId":"5e3202cff41de5354c299a57"}

Когда этот пользователь создается впервые, а затем мой приложение входит в систему, оно успешно аутентифицируется. Если я затем выйду из системы и попытаюсь снова пройти аутентификацию, я получу 401

NotAuthenticated {type: "FeathersError", name: "NotAuthenticated", message: "Invalid login", code: 401

. Я полагаю, что проблема связана с наличием дополнительных данных в пользовательской записи, кроме электронной почты и пароля, за некоторыми исключениями.

Я вручную создал следующего пользователя из Почтальона, я опубликовал это в службе пользователей.

{"email": "wtf@think-engineer.com", "password": "123"}

Это успешно создало следующую запись

{
    "_id": "5e3208d4f41de5354c299a5b",
    "email": "wtf@think-engineer.com",
    "createdAt": "2020-01-29T22:36:04.606Z",
    "updatedAt": "2020-01-29T22:36:04.606Z",
    "__v": 0
}

Затем я опубликовал это в службу аутентификации:

{"strategy": "local", "email": "wtf@think-engineer.com", "password": "123"}

Это сработало несколько раз подряд, возвращая сообщения, подобные этому:

{
    "accessToken": "eyJhbGciOiJIUzI1NiIsInR5cCI6ImFjY2VzcyJ9.eyJpYXQiOjE1ODAzMzc0NTgsImV4cCI6MTU4MDQyMzg1OCwiYXVkIjoiaHR0cHM6Ly95b3VyZG9tYWluLmNvbSIsImlzcyI6ImZlYXRoZXJzIiwic3ViIjoiNWUzMjA4ZDRmNDFkZTUzNTRjMjk5YTViIiwianRpIjoiZGYyZDc5MmMtOTIyYS00YzEyLTgyYTUtMzc4YTU2OGRmYWFjIn0.KxUJBH_MnHRYQR9lq39ztb_yMleAu7GRykc2nm2FIU8",
    "authentication": {
        "strategy": "local"
    },
    "user": {
        "_id": "5e3208d4f41de5354c299a5b",
        "email": "wtf@think-engineer.com",
        "createdAt": "2020-01-29T22:36:04.606Z",
        "updatedAt": "2020-01-29T22:36:04.606Z",
        "__v": 0
    }
}

Затем я внес исправления в отображаемое имя, imageURL и статус avtive для пользователь 5e3208d4f41de5354c299a5b, который работал и возвратил новую запись:

{
    "_id": "5e3208d4f41de5354c299a5b",
    "email": "wtf@think-engineer.com",
    "createdAt": "2020-01-29T22:36:04.606Z",
    "updatedAt": "2020-01-29T22:41:54.463Z",
    "__v": 0,
    "displayName": "Bob",
    "active": "yes",
    "imageUrl": "..."
}

Я все еще могу аутентифицировать пользователя, используя только стратегию, адрес электронной почты и пароль, и получить маркер обратно

{
    "accessToken": "eyJhbGciOiJIUzI1NiIsInR5cCI6ImFjY2VzcyJ9.eyJpYXQiOjE1ODAzMzc3MjcsImV4cCI6MTU4MDQyNDEyNywiYXVkIjoiaHR0cHM6Ly95b3VyZG9tYWluLmNvbSIsImlzcyI6ImZlYXRoZXJzIiwic3ViIjoiNWUzMjA4ZDRmNDFkZTUzNTRjMjk5YTViIiwianRpIjoiNzEzN2EwZDAtZjM0MC00MDRlLTlhYzItMjM3MmQ2N2NlYWJkIn0.wjj8KZRrcTbpk3b-ZzJh3riEGvMClGoqkH5vBflHSPg",
    "authentication": {
        "strategy": "local"
    },
    "user": {
        "_id": "5e3208d4f41de5354c299a5b",
        "email": "wtf@think-engineer.com",
        "createdAt": "2020-01-29T22:36:04.606Z",
        "updatedAt": "2020-01-29T22:41:54.463Z",
        "__v": 0,
        "displayName": "Bob",
        "active": "yes",
        "imageUrl": "..."
    }
}

Однако в другой раз, когда я попробовал это сделать, после установки только отображаемого имени, я не смог пройти аутентификацию.

Как только пользователь больше не может проходить аутентификацию, Я не могу исправить запись. Я зашел прямо в базу данных и удалил все поля, кроме минимальных полей, которые существуют при создании простого пользователя, и он все еще не аутентифицируется.

Если все данные, которые я хочу в записи пользователя существует, я не могу заставить его когда-либо аутентифицироваться, но подмножество данных, которое останавливает работу входа в систему, кажется, отличается каждый раз, когда я проверяю это. Иногда добавления отображаемого имени достаточно, чтобы остановить аутентификацию, но иногда с отображаемым именем все в порядке.

Это то, что по умолчанию у меня. json выглядит как перья.

{
  "host": "localhost",
  "port": 3030,
  "public": "../public/",
  "paginate": {
    "default": 10,
    "max": 50
  },
  "authentication": {
    "entity": "user",
    "service": "users",
    "secret": "ZxSXb/PP5TamjYSc5FUNmBupSA0=",
    "authStrategies": [
      "jwt",
      "local"
    ],
    "jwtOptions": {
      "header": {
        "typ": "access"
      },
      "audience": "https://yourdomain.com",
      "issuer": "feathers",
      "algorithm": "HS256",
      "expiresIn": "1d"
    },
    "local": {
      "usernameField": "email",
      "passwordField": "password"
    }
  },
  "mongodb": "mongodb://localhost:27017/server_3"
}

I можно было бы ожидать, что только стратегия, электронная почта и пароль должны быть переданы, и что пользователи должны аутентифицироваться, но они этого не делают.

Любые идеи о том, почему это происходит, и как остановить это, будут с благодарностью.

...