mirror of
https://github.com/fleetdm/fleet
synced 2026-04-21 13:37:30 +00:00
**Related issue:** Resolves #14401 this updates the mechanism of storing the auth token for a user that is used for making requests and validating a user session. We change the storage from local storage to a cookie. This allow a bit more security and prepares for a future change where we will allow the browser to handle setting and passing the auth token in the request. - [x] Changes file added for user-visible changes in `changes/`, `orbit/changes/` or `ee/fleetd-chrome/changes`. - [x] QA'd all new/changed functionality manually
124 lines
2.7 KiB
TypeScript
124 lines
2.7 KiB
TypeScript
import PropTypes from "prop-types";
|
|
import teamInterface, { ITeam } from "./team";
|
|
import { IUserSettings } from "./config";
|
|
|
|
export default PropTypes.shape({
|
|
created_at: PropTypes.string,
|
|
updated_at: PropTypes.string,
|
|
id: PropTypes.number,
|
|
name: PropTypes.string,
|
|
email: PropTypes.string,
|
|
role: PropTypes.string,
|
|
force_password_reset: PropTypes.bool,
|
|
gravatar_url: PropTypes.string,
|
|
sso_enabled: PropTypes.bool,
|
|
mfa_enabled: PropTypes.bool,
|
|
global_role: PropTypes.string,
|
|
api_only: PropTypes.bool,
|
|
teams: PropTypes.arrayOf(teamInterface),
|
|
});
|
|
|
|
export const USERS_ROLES = [
|
|
"admin",
|
|
"maintainer",
|
|
"observer",
|
|
"observer_plus",
|
|
] as const;
|
|
export type IUserRole = typeof USERS_ROLES[number];
|
|
export type UserRole =
|
|
| "admin"
|
|
| "maintainer"
|
|
| "observer"
|
|
| "observer_plus"
|
|
| "gitops"
|
|
| "Admin"
|
|
| "Maintainer"
|
|
| "Observer"
|
|
| "Observer+"
|
|
| "GitOps"
|
|
| "Unassigned"
|
|
| ""
|
|
| "Various";
|
|
|
|
export interface IUser {
|
|
created_at?: string;
|
|
updated_at?: string;
|
|
id: number;
|
|
name: string;
|
|
email: string;
|
|
role?: UserRole;
|
|
force_password_reset: boolean;
|
|
gravatar_url?: string;
|
|
gravatar_url_dark?: string;
|
|
sso_enabled: boolean;
|
|
mfa_enabled?: boolean;
|
|
global_role: UserRole | null;
|
|
api_only: boolean;
|
|
teams: ITeam[];
|
|
fleets: ITeam[]; // This will eventually replace `teams`, but for now we need both to avoid breaking changes.
|
|
}
|
|
|
|
/**
|
|
* The shape of the request body when updating a user.
|
|
*/
|
|
export interface IUserUpdateBody {
|
|
global_role?: UserRole | null;
|
|
teams?: ITeam[];
|
|
name: string;
|
|
email?: string;
|
|
sso_enabled?: boolean;
|
|
mfa_enabled?: boolean;
|
|
role?: UserRole;
|
|
id: number;
|
|
}
|
|
|
|
export interface IUserFormErrors {
|
|
email?: string | null;
|
|
name?: string | null;
|
|
password?: string | null;
|
|
sso_enabled?: boolean | null;
|
|
}
|
|
export interface IResetPasswordFormErrors {
|
|
new_password?: string | null;
|
|
new_password_confirmation?: string | null;
|
|
}
|
|
|
|
export interface IResetPasswordForm {
|
|
new_password: string;
|
|
new_password_confirmation: string;
|
|
}
|
|
|
|
export interface ILoginUserData {
|
|
email: string;
|
|
password: string;
|
|
}
|
|
|
|
export interface ICreateUserFormData {
|
|
email: string;
|
|
global_role: UserRole | null;
|
|
name: string;
|
|
password?: string | null;
|
|
sso_enabled?: boolean;
|
|
mfa_enabled?: boolean;
|
|
teams: ITeam[];
|
|
}
|
|
|
|
export interface IUpdateUserFormData {
|
|
currentUserId?: number;
|
|
email?: string;
|
|
global_role?: UserRole | null;
|
|
name?: string;
|
|
password?: string | null;
|
|
sso_enabled?: boolean;
|
|
mfa_enabled?: boolean;
|
|
teams?: ITeam[];
|
|
settings?: IUserSettings;
|
|
}
|
|
|
|
export interface ICreateUserWithInvitationFormData {
|
|
email: string;
|
|
invite_token: string;
|
|
name: string;
|
|
password: string;
|
|
password_confirmation: string;
|
|
}
|