mirror of
				https://github.com/NodeBB/NodeBB.git
				synced 2025-10-26 16:46:12 +01:00 
			
		
		
		
	feat: manual password expiry. closes #7471
This commit is contained in:
		| @@ -6,6 +6,7 @@ | ||||
| 	"validate-email": "Validate Email", | ||||
| 	"send-validation-email": "Send Validation Email", | ||||
| 	"password-reset-email": "Send Password Reset Email", | ||||
| 	"force-password-reset": "Force Password Reset & Log User Out", | ||||
| 	"ban": "Ban User(s)", | ||||
| 	"temp-ban": "Ban User(s) Temporarily", | ||||
| 	"unban": "Unban User(s)", | ||||
| @@ -81,7 +82,9 @@ | ||||
| 	"alerts.confirm-remove-moderator": "Do you really want to remove this moderator?", | ||||
| 	"alerts.remove-moderator-success": "User is no longer moderator.", | ||||
| 	"alerts.confirm-validate-email": "Do you want to validate email(s) of these user(s)?", | ||||
| 	"alerts.confirm-force-password-reset": "Are you sure you want to force the password reset and log out these user(s)?", | ||||
| 	"alerts.validate-email-success": "Emails validated", | ||||
| 	"alerts.validate-force-password-reset-success": "User(s) passwords have been reset and their existing sessions have been revoked.", | ||||
| 	"alerts.password-reset-confirm": "Do you want to send password reset email(s) to these user(s)?", | ||||
| 	"alerts.confirm-delete": "<b>Warning!</b><br/>Do you really want to delete user(s)?<br/> This action is not reversable! Only the user account will be deleted, their posts and topics will remain.", | ||||
| 	"alerts.delete-success": "User(s) Deleted!", | ||||
|   | ||||
| @@ -175,6 +175,19 @@ define('admin/manage/users', ['translator', 'benchpress'], function (translator, | ||||
| 			}); | ||||
| 		}); | ||||
|  | ||||
| 		$('.force-password-reset').on('click', function () { | ||||
| 			var uids = getSelectedUids(); | ||||
| 			if (!uids.length) { | ||||
| 				return; | ||||
| 			} | ||||
|  | ||||
| 			bootbox.confirm('[[admin/manage/users:alerts.confirm-force-password-reset]]', function (confirm) { | ||||
| 				if (confirm) { | ||||
| 					socket.emit('admin.user.forcePasswordReset', uids, done('[[admin/manage/users:alerts.validate-force-password-reset-success]]')); | ||||
| 				} | ||||
| 			}); | ||||
| 		}); | ||||
|  | ||||
| 		$('.delete-user').on('click', function () { | ||||
| 			var uids = getSelectedUids(); | ||||
| 			if (!uids.length) { | ||||
|   | ||||
| @@ -126,6 +126,25 @@ User.sendPasswordResetEmail = function (socket, uids, callback) { | ||||
| 	}, callback); | ||||
| }; | ||||
|  | ||||
| User.forcePasswordReset = function (socket, uids, callback) { | ||||
| 	if (!Array.isArray(uids)) { | ||||
| 		return callback(new Error('[[error:invalid-data]]')); | ||||
| 	} | ||||
|  | ||||
| 	uids = uids.filter(uid => parseInt(uid, 10)); | ||||
|  | ||||
| 	async.each(uids, function (uid, next) { | ||||
| 		async.waterfall([ | ||||
| 			function (next) { | ||||
| 				user.setUserField(uid, 'passwordExpiry', Date.now(), next); | ||||
| 			}, | ||||
| 			function (next) { | ||||
| 				user.auth.revokeAllSessions(uid, next); | ||||
| 			}, | ||||
| 		], next); | ||||
| 	}, callback); | ||||
| }; | ||||
|  | ||||
| User.deleteUsers = function (socket, uids, callback) { | ||||
| 	deleteUsers(socket, uids, function (uid, next) { | ||||
| 		user.deleteAccount(uid, next); | ||||
|   | ||||
| @@ -11,6 +11,7 @@ | ||||
| 							<li><a href="#" class="validate-email"><i class="fa fa-fw fa-check"></i> [[admin/manage/users:validate-email]]</a></li> | ||||
| 							<li><a href="#" class="send-validation-email"><i class="fa fa-fw fa-mail-forward"></i> [[admin/manage/users:send-validation-email]]</a></li> | ||||
| 							<li><a href="#" class="password-reset-email"><i class="fa fa-fw fa-key"></i> [[admin/manage/users:password-reset-email]]</a></li> | ||||
| 							<li><a href="#" class="force-password-reset"><i class="fa fa-fw fa-unlock-alt"></i> [[admin/manage/users:force-password-reset]]</a></li> | ||||
| 							<li class="divider"></li> | ||||
| 							<li><a href="#" class="ban-user"><i class="fa fa-fw fa-gavel"></i> [[admin/manage/users:ban]]</a></li> | ||||
| 							<li><a href="#" class="ban-user-temporary"><i class="fa fa-fw fa-clock-o"></i>[[admin/manage/users:temp-ban]]</a></li> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user