mirror of
https://github.com/Stirling-Tools/Stirling-PDF.git
synced 2025-06-23 16:05:09 +00:00

# Description This pull request includes several changes aimed at improving the code structure and removing redundant code. The most significant changes involve reordering methods, removing unnecessary annotations, and refactoring constructors to use dependency injection. Autowired now comes via constructor (which also doesn't need autowired annotation as its done by default for configuration) ## Checklist - [ ] I have read the [Contribution Guidelines](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/CONTRIBUTING.md) - [ ] I have performed a self-review of my own code - [ ] I have attached images of the change if it is UI based - [ ] I have commented my code, particularly in hard-to-understand areas - [ ] If my code has heavily changed functionality I have updated relevant docs on [Stirling-PDFs doc repo](https://github.com/Stirling-Tools/Stirling-Tools.github.io/blob/main/docs/) - [ ] My changes generate no new warnings - [ ] I have read the section [Add New Translation Tags](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/HowToAddNewLanguage.md#add-new-translation-tags) (for new translation tags only)
89 lines
3.4 KiB
Java
89 lines
3.4 KiB
Java
package stirling.software.SPDF.config.security;
|
|
|
|
import java.io.IOException;
|
|
import java.util.UUID;
|
|
|
|
import org.springframework.stereotype.Component;
|
|
|
|
import jakarta.annotation.PostConstruct;
|
|
import lombok.extern.slf4j.Slf4j;
|
|
import stirling.software.SPDF.config.interfaces.DatabaseBackupInterface;
|
|
import stirling.software.SPDF.model.ApplicationProperties;
|
|
import stirling.software.SPDF.model.Role;
|
|
|
|
@Component
|
|
@Slf4j
|
|
public class InitialSecuritySetup {
|
|
|
|
private final UserService userService;
|
|
|
|
private final ApplicationProperties applicationProperties;
|
|
|
|
private final DatabaseBackupInterface databaseBackupHelper;
|
|
|
|
public InitialSecuritySetup(
|
|
UserService userService,
|
|
ApplicationProperties applicationProperties,
|
|
DatabaseBackupInterface databaseBackupHelper) {
|
|
this.userService = userService;
|
|
this.applicationProperties = applicationProperties;
|
|
this.databaseBackupHelper = databaseBackupHelper;
|
|
}
|
|
|
|
@PostConstruct
|
|
public void init() throws IllegalArgumentException, IOException {
|
|
if (databaseBackupHelper.hasBackup() && !userService.hasUsers()) {
|
|
databaseBackupHelper.importDatabase();
|
|
} else if (!userService.hasUsers()) {
|
|
initializeAdminUser();
|
|
} else {
|
|
databaseBackupHelper.exportDatabase();
|
|
userService.migrateOauth2ToSSO();
|
|
}
|
|
initializeInternalApiUser();
|
|
}
|
|
|
|
private void initializeAdminUser() throws IOException {
|
|
String initialUsername =
|
|
applicationProperties.getSecurity().getInitialLogin().getUsername();
|
|
String initialPassword =
|
|
applicationProperties.getSecurity().getInitialLogin().getPassword();
|
|
if (initialUsername != null
|
|
&& !initialUsername.isEmpty()
|
|
&& initialPassword != null
|
|
&& !initialPassword.isEmpty()
|
|
&& !userService.findByUsernameIgnoreCase(initialUsername).isPresent()) {
|
|
try {
|
|
userService.saveUser(initialUsername, initialPassword, Role.ADMIN.getRoleId());
|
|
log.info("Admin user created: " + initialUsername);
|
|
} catch (IllegalArgumentException e) {
|
|
log.error("Failed to initialize security setup", e);
|
|
System.exit(1);
|
|
}
|
|
} else {
|
|
createDefaultAdminUser();
|
|
}
|
|
}
|
|
|
|
private void createDefaultAdminUser() throws IllegalArgumentException, IOException {
|
|
String defaultUsername = "admin";
|
|
String defaultPassword = "stirling";
|
|
if (!userService.findByUsernameIgnoreCase(defaultUsername).isPresent()) {
|
|
userService.saveUser(defaultUsername, defaultPassword, Role.ADMIN.getRoleId(), true);
|
|
log.info("Default admin user created: " + defaultUsername);
|
|
}
|
|
}
|
|
|
|
private void initializeInternalApiUser() throws IllegalArgumentException, IOException {
|
|
if (!userService.usernameExistsIgnoreCase(Role.INTERNAL_API_USER.getRoleId())) {
|
|
userService.saveUser(
|
|
Role.INTERNAL_API_USER.getRoleId(),
|
|
UUID.randomUUID().toString(),
|
|
Role.INTERNAL_API_USER.getRoleId());
|
|
userService.addApiKeyToUser(Role.INTERNAL_API_USER.getRoleId());
|
|
log.info("Internal API user created: " + Role.INTERNAL_API_USER.getRoleId());
|
|
}
|
|
userService.syncCustomApiUser(applicationProperties.getSecurity().getCustomGlobalAPIKey());
|
|
}
|
|
}
|