mirror of
https://github.com/Athou/commafeed.git
synced 2026-03-21 21:37:29 +00:00
allow users to permanently delete their account
This commit is contained in:
@@ -6,10 +6,16 @@ import java.util.Collection;
|
|||||||
import javax.ejb.Stateless;
|
import javax.ejb.Stateless;
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
|
|
||||||
|
import com.commafeed.backend.dao.FeedCategoryDAO;
|
||||||
|
import com.commafeed.backend.dao.FeedEntryStatusDAO;
|
||||||
|
import com.commafeed.backend.dao.FeedSubscriptionDAO;
|
||||||
import com.commafeed.backend.dao.UserDAO;
|
import com.commafeed.backend.dao.UserDAO;
|
||||||
|
import com.commafeed.backend.dao.UserRoleDAO;
|
||||||
|
import com.commafeed.backend.dao.UserSettingsDAO;
|
||||||
import com.commafeed.backend.model.User;
|
import com.commafeed.backend.model.User;
|
||||||
import com.commafeed.backend.model.UserRole;
|
import com.commafeed.backend.model.UserRole;
|
||||||
import com.commafeed.backend.model.UserRole.Role;
|
import com.commafeed.backend.model.UserRole.Role;
|
||||||
|
import com.commafeed.backend.model.UserSettings.ReadingOrder;
|
||||||
import com.google.common.base.Preconditions;
|
import com.google.common.base.Preconditions;
|
||||||
|
|
||||||
@Stateless
|
@Stateless
|
||||||
@@ -18,6 +24,21 @@ public class UserService {
|
|||||||
@Inject
|
@Inject
|
||||||
UserDAO userDAO;
|
UserDAO userDAO;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
FeedEntryStatusDAO feedEntryStatusDAO;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
FeedSubscriptionDAO feedSubscriptionDAO;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
FeedCategoryDAO feedCategoryDAO;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
UserSettingsDAO userSettingsDAO;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
UserRoleDAO userRoleDAO;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
PasswordEncryptionService encryptionService;
|
PasswordEncryptionService encryptionService;
|
||||||
|
|
||||||
@@ -63,4 +84,14 @@ public class UserService {
|
|||||||
userDAO.save(user);
|
userDAO.save(user);
|
||||||
return user;
|
return user;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void unregister(User user) {
|
||||||
|
feedEntryStatusDAO.delete(feedEntryStatusDAO.findAll(user, false,
|
||||||
|
ReadingOrder.desc, false));
|
||||||
|
feedSubscriptionDAO.delete(feedSubscriptionDAO.findAll(user));
|
||||||
|
feedCategoryDAO.delete(feedCategoryDAO.findAll(user));
|
||||||
|
userSettingsDAO.delete(userSettingsDAO.findByUser(user));
|
||||||
|
userRoleDAO.delete(userRoleDAO.findAll(user));
|
||||||
|
userDAO.delete(user);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -18,7 +18,6 @@ import com.commafeed.backend.model.ApplicationSettings;
|
|||||||
import com.commafeed.backend.model.User;
|
import com.commafeed.backend.model.User;
|
||||||
import com.commafeed.backend.model.UserRole;
|
import com.commafeed.backend.model.UserRole;
|
||||||
import com.commafeed.backend.model.UserRole.Role;
|
import com.commafeed.backend.model.UserRole.Role;
|
||||||
import com.commafeed.backend.model.UserSettings.ReadingOrder;
|
|
||||||
import com.commafeed.frontend.SecurityCheck;
|
import com.commafeed.frontend.SecurityCheck;
|
||||||
import com.commafeed.frontend.model.UserModel;
|
import com.commafeed.frontend.model.UserModel;
|
||||||
import com.commafeed.frontend.model.request.IDRequest;
|
import com.commafeed.frontend.model.request.IDRequest;
|
||||||
@@ -150,14 +149,7 @@ public class AdminREST extends AbstractResourceREST {
|
|||||||
return Response.status(Status.FORBIDDEN)
|
return Response.status(Status.FORBIDDEN)
|
||||||
.entity("You cannot delete the admin user.").build();
|
.entity("You cannot delete the admin user.").build();
|
||||||
}
|
}
|
||||||
feedEntryStatusDAO.delete(feedEntryStatusDAO.findAll(user, false,
|
userService.unregister(user);
|
||||||
ReadingOrder.desc, false));
|
|
||||||
feedSubscriptionDAO.delete(feedSubscriptionDAO.findAll(user));
|
|
||||||
feedCategoryDAO.delete(feedCategoryDAO.findAll(user));
|
|
||||||
userSettingsDAO.delete(userSettingsDAO.findByUser(user));
|
|
||||||
userRoleDAO.delete(userRoleDAO.findAll(user));
|
|
||||||
userDAO.delete(user);
|
|
||||||
|
|
||||||
return Response.ok().build();
|
return Response.ok().build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -122,6 +122,18 @@ public class UserREST extends AbstractResourceREST {
|
|||||||
return Response.ok().build();
|
return Response.ok().build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Path("/profile/deleteAccount")
|
||||||
|
@POST
|
||||||
|
@ApiOperation(value = "Delete the user account")
|
||||||
|
public Response delete() {
|
||||||
|
if (StartupBean.USERNAME_ADMIN.equals(getUser().getName())
|
||||||
|
|| StartupBean.USERNAME_DEMO.equals(getUser().getName())) {
|
||||||
|
return Response.status(Status.UNAUTHORIZED).build();
|
||||||
|
}
|
||||||
|
userService.unregister(getUser());
|
||||||
|
return Response.ok().build();
|
||||||
|
}
|
||||||
|
|
||||||
private String generateKey(User user) {
|
private String generateKey(User user) {
|
||||||
byte[] key = encryptionService.getEncryptedPassword(UUID.randomUUID()
|
byte[] key = encryptionService.getEncryptedPassword(UUID.randomUUID()
|
||||||
.toString(), user.getSalt());
|
.toString(), user.getSalt());
|
||||||
|
|||||||
@@ -809,8 +809,8 @@ function($scope, $location, SettingsService, AnalyticsService) {
|
|||||||
};
|
};
|
||||||
}]);
|
}]);
|
||||||
|
|
||||||
module.controller('ProfileCtrl', ['$scope', '$location', 'ProfileService', 'AnalyticsService',
|
module.controller('ProfileCtrl', ['$scope', '$location', '$dialog', 'ProfileService', 'AnalyticsService',
|
||||||
function($scope, $location, ProfileService, AnalyticsService) {
|
function($scope, $location, $dialog, ProfileService, AnalyticsService) {
|
||||||
|
|
||||||
AnalyticsService.track();
|
AnalyticsService.track();
|
||||||
|
|
||||||
@@ -832,7 +832,25 @@ function($scope, $location, ProfileService, AnalyticsService) {
|
|||||||
ProfileService.save(o, function() {
|
ProfileService.save(o, function() {
|
||||||
$location.path('/');
|
$location.path('/');
|
||||||
});
|
});
|
||||||
|
};
|
||||||
|
$scope.deleteAccount = function() {
|
||||||
|
var title = 'Delete account';
|
||||||
|
var msg = 'Delete your acount? There\'s no turning back!';
|
||||||
|
var btns = [ {
|
||||||
|
result : 'cancel',
|
||||||
|
label : 'Cancel'
|
||||||
|
}, {
|
||||||
|
result : 'ok',
|
||||||
|
label : 'OK',
|
||||||
|
cssClass : 'btn-primary'
|
||||||
|
} ];
|
||||||
|
|
||||||
|
$dialog.messageBox(title, msg, btns).open().then(function(result) {
|
||||||
|
if (result == 'ok') {
|
||||||
|
ProfileService.deleteAccount();
|
||||||
|
window.location.href = 'logout';
|
||||||
|
}
|
||||||
|
});
|
||||||
};
|
};
|
||||||
}]);
|
}]);
|
||||||
|
|
||||||
|
|||||||
@@ -14,7 +14,9 @@ module.service('AnalyticsService', [ '$state', function($state) {
|
|||||||
|
|
||||||
|
|
||||||
module.factory('ProfileService', ['$resource', function($resource) {
|
module.factory('ProfileService', ['$resource', function($resource) {
|
||||||
return $resource('rest/user/profile/');
|
var res = $resource('rest/user/profile/');
|
||||||
|
res.deleteAccount = $resource('rest/user/profile/deleteAccount').save;
|
||||||
|
return res;
|
||||||
}]);
|
}]);
|
||||||
|
|
||||||
module.factory('SettingsService', ['$resource', function($resource) {
|
module.factory('SettingsService', ['$resource', function($resource) {
|
||||||
|
|||||||
@@ -50,6 +50,7 @@
|
|||||||
<div class="form-actions">
|
<div class="form-actions">
|
||||||
<button type="submit" class="btn btn-primary">Save</button>
|
<button type="submit" class="btn btn-primary">Save</button>
|
||||||
<button type="button" class="btn" ng-click="cancel()">Cancel</button>
|
<button type="button" class="btn" ng-click="cancel()">Cancel</button>
|
||||||
|
<button type="button" class="btn btn-danger" ng-click="deleteAccount()">Delete account</button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
Reference in New Issue
Block a user