@loopback/docs
Version:
Documentation files rendered at [https://loopback.io](https://loopback.io)
35 lines (22 loc) • 1.57 kB
Markdown
---
lang: en
title: 'API docs: authentication.authenticationstrategy.authenticate'
keywords: LoopBack 4.0, LoopBack 4, Node.js, TypeScript, OpenAPI
sidebar: lb4_sidebar
editurl: https://github.com/loopbackio/loopback-next/tree/master/packages/authentication
permalink: /doc/en/lb4/apidocs.authentication.authenticationstrategy.authenticate.html
---
<!-- Do not edit this file. It is automatically generated by API Documenter. -->
[Home](./index.md) > [@loopback/authentication](./authentication.md) > [AuthenticationStrategy](./authentication.authenticationstrategy.md) > [authenticate](./authentication.authenticationstrategy.authenticate.md)
## AuthenticationStrategy.authenticate() method
The 'authenticate' method takes in a given request and returns a user profile which is an instance of 'UserProfile'. (A user profile is a minimal subset of a user object) If the user credentials are valid, this method should return a 'UserProfile' instance. If the user credentials are invalid, this method should throw an error If the user credentials are missing, this method should throw an error, or return 'undefined' and let the authentication action deal with it.
<b>Signature:</b>
```typescript
authenticate(request: Request): Promise<UserProfile | RedirectRoute | undefined>;
```
## Parameters
| Parameter | Type | Description |
| --- | --- | --- |
| request | Request | Express request object |
<b>Returns:</b>
Promise<[UserProfile](./security.userprofile.md) \| [RedirectRoute](./rest.redirectroute.md) \| undefined>