mirror of
https://github.com/getredash/redash.git
synced 2026-05-09 12:01:08 -04:00
* Create React version for the EmailSettingsWarning * Migrate the Create User Page * Migrate UserProfile to React * Add /users/me to the routes (Percy ftw) * Fix UserShow test spec * Remove Error Messages component * Show invitation link if email server not setup (#3519) * return invite link to client if e-mail server is not set up * add a couple of tests to make sure invite links are only returned when neccessary * show invite link when e-mail is not configured * remove "an e-mail has been sent" when there's no e-mail configured * return invite_url in re-invites as well. Also refactor to reuse the code. * Use CreateUserDialog instead of Page * Render invite link on Resend Invitation click * Add email validation to DynamicForm * Fix EmailWarning position + update user list with user creation success * Fix console error on UserProfile * Redirect from /users/new + rename createUser -> showCreateUserDialog * Use alert instead of toastr for user creation errors * Remove logic from CreateUserDialog * CR * Use Promise.reject instead of throw to avoid console error
171 lines
4.8 KiB
JavaScript
171 lines
4.8 KiB
JavaScript
import { isString } from 'lodash';
|
|
import { $http, $sanitize, toastr } from '@/services/ng';
|
|
import { clientConfig } from '@/services/auth';
|
|
|
|
export let User = null; // eslint-disable-line import/no-mutable-exports
|
|
|
|
function disableResource(user) {
|
|
return `api/users/${user.id}/disable`;
|
|
}
|
|
|
|
function enableUser(user) {
|
|
const userName = $sanitize(user.name);
|
|
|
|
return $http
|
|
.delete(disableResource(user))
|
|
.then((data) => {
|
|
toastr.success(`User <b>${userName}</b> is now enabled.`, { allowHtml: true });
|
|
user.is_disabled = false;
|
|
user.profile_image_url = data.data.profile_image_url;
|
|
return data;
|
|
})
|
|
.catch((response) => {
|
|
let message = response instanceof Error ? response.message : response.statusText;
|
|
if (!isString(message)) {
|
|
message = 'Unknown error';
|
|
}
|
|
toastr.error(`Cannot enable user <b>${userName}</b><br>${message}`, { allowHtml: true });
|
|
});
|
|
}
|
|
|
|
function disableUser(user) {
|
|
const userName = $sanitize(user.name);
|
|
return $http
|
|
.post(disableResource(user))
|
|
.then((data) => {
|
|
toastr.warning(`User <b>${userName}</b> is now disabled.`, { allowHtml: true });
|
|
user.is_disabled = true;
|
|
user.profile_image_url = data.data.profile_image_url;
|
|
return data;
|
|
})
|
|
.catch((response = {}) => {
|
|
const message =
|
|
response.data && response.data.message
|
|
? response.data.message
|
|
: `Cannot disable user <b>${userName}</b><br>${response.statusText}`;
|
|
|
|
toastr.error(message, { allowHtml: true });
|
|
});
|
|
}
|
|
|
|
function deleteUser(user) {
|
|
const userName = $sanitize(user.name);
|
|
return $http
|
|
.delete(`api/users/${user.id}`)
|
|
.then((data) => {
|
|
toastr.warning(`User <b>${userName}</b> has been deleted.`, { allowHtml: true });
|
|
return data;
|
|
})
|
|
.catch((response = {}) => {
|
|
const message =
|
|
response.data && response.data.message
|
|
? response.data.message
|
|
: `Cannot delete user <b>${userName}</b><br>${response.statusText}`;
|
|
|
|
toastr.error(message, { allowHtml: true });
|
|
});
|
|
}
|
|
|
|
function convertUserInfo(user) {
|
|
return {
|
|
id: user.id,
|
|
name: user.name,
|
|
email: user.email,
|
|
profileImageUrl: user.profile_image_url,
|
|
apiKey: user.api_key,
|
|
isDisabled: user.is_disabled,
|
|
isInvitationPending: user.is_invitation_pending,
|
|
};
|
|
}
|
|
|
|
function regenerateApiKey(user) {
|
|
return $http
|
|
.post(`api/users/${user.id}/regenerate_api_key`)
|
|
.then(({ data }) => {
|
|
toastr.success('The API Key has been updated.');
|
|
return data.api_key;
|
|
})
|
|
.catch((response = {}) => {
|
|
const message =
|
|
response.data && response.data.message
|
|
? response.data.message
|
|
: `Failed regenerating API Key: ${response.statusText}`;
|
|
|
|
toastr.error(message);
|
|
});
|
|
}
|
|
|
|
function sendPasswordReset(user) {
|
|
return $http
|
|
.post(`api/users/${user.id}/reset_password`)
|
|
.then(({ data }) => {
|
|
if (clientConfig.mailSettingsMissing) {
|
|
toastr.warning('The mail server is not configured.');
|
|
return data.reset_link;
|
|
}
|
|
toastr.success('Password reset email sent.');
|
|
})
|
|
.catch((response = {}) => {
|
|
const message =
|
|
response.message
|
|
? response.message
|
|
: `Failed to send password reset email: ${response.statusText}`;
|
|
|
|
toastr.error(message);
|
|
});
|
|
}
|
|
|
|
function resendInvitation(user) {
|
|
return $http
|
|
.post(`api/users/${user.id}/invite`)
|
|
.then(({ data }) => {
|
|
if (clientConfig.mailSettingsMissing) {
|
|
toastr.warning('The mail server is not configured.');
|
|
return data.invite_link;
|
|
}
|
|
toastr.success('Invitation sent.');
|
|
})
|
|
.catch((response = {}) => {
|
|
const message =
|
|
response.message
|
|
? response.message
|
|
: `Failed to resend invitation: ${response.statusText}`;
|
|
|
|
toastr.error(message);
|
|
});
|
|
}
|
|
|
|
function UserService($resource) {
|
|
const actions = {
|
|
get: { method: 'GET' },
|
|
create: { method: 'POST' },
|
|
save: { method: 'POST' },
|
|
query: { method: 'GET', isArray: false },
|
|
delete: { method: 'DELETE' },
|
|
disable: { method: 'POST', url: 'api/users/:id/disable' },
|
|
enable: { method: 'DELETE', url: 'api/users/:id/disable' },
|
|
};
|
|
|
|
const UserResource = $resource('api/users/:id', { id: '@id' }, actions);
|
|
|
|
UserResource.enableUser = enableUser;
|
|
UserResource.disableUser = disableUser;
|
|
UserResource.deleteUser = deleteUser;
|
|
UserResource.convertUserInfo = convertUserInfo;
|
|
UserResource.regenerateApiKey = regenerateApiKey;
|
|
UserResource.sendPasswordReset = sendPasswordReset;
|
|
UserResource.resendInvitation = resendInvitation;
|
|
|
|
return UserResource;
|
|
}
|
|
|
|
export default function init(ngModule) {
|
|
ngModule.factory('User', UserService);
|
|
|
|
ngModule.run(($injector) => {
|
|
User = $injector.get('User');
|
|
});
|
|
}
|
|
|
|
init.init = true;
|