
io.github.weresandstorm.springsecurity.persist.MgoUserIdentityRepo Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of spring-security-mongo Show documentation
Show all versions of spring-security-mongo Show documentation
A spring-security-oauth2 extension supporting storing oauth data into MongoDB
/*
* Copyright (C) 2018 The Sandstorm Org
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.github.weresandstorm.springsecurity.persist;
import static com.mongodb.client.model.Updates.set;
import io.github.weresandstorm.springsecurity.domain.UserIdentity;
import io.github.weresandstorm.springsecurity.domain.UserIdentityRepo;
import java.util.Optional;
import org.springframework.stereotype.Component;
@Component
public class MgoUserIdentityRepo extends MgoRepoBase
implements UserIdentityRepo {
@Override
public String collectionName() {
return "user_identities";
}
@Override
public Optional findByUsername(String username) {
return getOptional(username);
}
@Override
public boolean changePassword(String oldPassword, String newPassword, String username) {
UserIdentity account = get(username);
// TODO This is business logic and should be moved into domain service.
if (!account.getPassword().equals(oldPassword)) {
throw new RuntimeException("Old password is incorrect");
}
return update(username, set("password", newPassword));
}
@Override
public void deleteByUsername(String username) {
delete(username);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy