| Required role: | super-admin |
| GET | /login-history |
|---|
export class UserLoginHistory
{
public id: number;
public userId: number;
// @StringLength(150)
public userName: string;
// @StringLength(45)
public ipAddress: string;
// @StringLength(500)
public deviceInfo: string;
// @StringLength(50)
public loginStatus: string;
// @StringLength(500)
public failReason: string;
// @Required()
public createdAt: string;
public provider: string;
public constructor(init?: Partial<UserLoginHistory>) { (Object as any).assign(this, init); }
}
export class UserLoginHistoryDto extends UserLoginHistory
{
public failedLoginCount?: number;
public constructor(init?: Partial<UserLoginHistoryDto>) { super(init); (Object as any).assign(this, init); }
}
export class LoginHistoryRespnse implements IResponseRequest
{
public data?: UserLoginHistoryDto[];
public totalRecords: number;
public code: number;
public message: string;
public constructor(init?: Partial<LoginHistoryRespnse>) { (Object as any).assign(this, init); }
}
/** @description Lấy lịch sử đăng nhập */
export class LoginHistoryRequest
{
public userId?: number;
public userName: string;
public startDate?: string;
public endDate?: string;
public page: number;
public limit: number;
public constructor(init?: Partial<LoginHistoryRequest>) { (Object as any).assign(this, init); }
}
TypeScript LoginHistoryRequest DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
GET /login-history HTTP/1.1 Host: etc-api.vsmlab.vn Accept: text/jsv
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length
{
data:
[
{
failedLoginCount: 0,
id: 0,
userId: 0,
userName: String,
ipAddress: String,
deviceInfo: String,
loginStatus: String,
failReason: String,
provider: String
}
],
totalRecords: 0,
code: 0,
message: String
}