mirror of
https://github.com/Stirling-Tools/Stirling-PDF.git
synced 2025-06-13 02:55:03 +00:00

# Description of Changes Please provide a summary of the changes, including: - What was changed - Why the change was made - Any challenges encountered Closes #(issue_number) --- ## Checklist ### General - [ ] I have read the [Contribution Guidelines](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/CONTRIBUTING.md) - [ ] I have read the [Stirling-PDF Developer Guide](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/DeveloperGuide.md) (if applicable) - [ ] I have read the [How to add new languages to Stirling-PDF](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/HowToAddNewLanguage.md) (if applicable) - [ ] I have performed a self-review of my own code - [ ] My changes generate no new warnings ### Documentation - [ ] I have updated relevant docs on [Stirling-PDF's doc repo](https://github.com/Stirling-Tools/Stirling-Tools.github.io/blob/main/docs/) (if functionality has heavily changed) - [ ] 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) ### UI Changes (if applicable) - [ ] Screenshots or videos demonstrating the UI changes are attached (e.g., as comments or direct attachments in the PR) ### Testing (if applicable) - [ ] I have tested my changes locally. Refer to the [Testing Guide](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/DeveloperGuide.md#6-testing) for more details. --------- Co-authored-by: a <a>
101 lines
3.4 KiB
Java
101 lines
3.4 KiB
Java
package stirling.software.SPDF.EE;
|
|
|
|
import java.io.IOException;
|
|
import java.nio.file.Files;
|
|
import java.nio.file.Path;
|
|
import java.nio.file.Paths;
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.scheduling.annotation.Scheduled;
|
|
import org.springframework.stereotype.Component;
|
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
|
|
import stirling.software.SPDF.EE.KeygenLicenseVerifier.License;
|
|
import stirling.software.SPDF.model.ApplicationProperties;
|
|
import stirling.software.SPDF.utils.GeneralUtils;
|
|
|
|
@Component
|
|
@Slf4j
|
|
public class LicenseKeyChecker {
|
|
|
|
private static final String FILE_PREFIX = "file:";
|
|
|
|
private final KeygenLicenseVerifier licenseService;
|
|
|
|
private final ApplicationProperties applicationProperties;
|
|
|
|
private License premiumEnabledResult = License.NORMAL;
|
|
|
|
@Autowired
|
|
public LicenseKeyChecker(
|
|
KeygenLicenseVerifier licenseService, ApplicationProperties applicationProperties) {
|
|
this.licenseService = licenseService;
|
|
this.applicationProperties = applicationProperties;
|
|
this.checkLicense();
|
|
}
|
|
|
|
@Scheduled(initialDelay = 604800000, fixedRate = 604800000) // 7 days in milliseconds
|
|
public void checkLicensePeriodically() {
|
|
checkLicense();
|
|
}
|
|
|
|
private void checkLicense() {
|
|
if (!applicationProperties.getPremium().isEnabled()) {
|
|
premiumEnabledResult = License.NORMAL;
|
|
} else {
|
|
String licenseKey = getLicenseKeyContent(applicationProperties.getPremium().getKey());
|
|
if (licenseKey != null) {
|
|
premiumEnabledResult = licenseService.verifyLicense(licenseKey);
|
|
if (License.ENTERPRISE == premiumEnabledResult) {
|
|
log.info("License key is Enterprise.");
|
|
} else if (License.PRO == premiumEnabledResult) {
|
|
log.info("License key is Pro.");
|
|
} else {
|
|
log.info("License key is invalid, defaulting to non pro license.");
|
|
}
|
|
} else {
|
|
log.error("Failed to obtain license key content.");
|
|
premiumEnabledResult = License.NORMAL;
|
|
}
|
|
}
|
|
}
|
|
|
|
private String getLicenseKeyContent(String keyOrFilePath) {
|
|
if (keyOrFilePath == null || keyOrFilePath.trim().isEmpty()) {
|
|
log.error("License key is not specified");
|
|
return null;
|
|
}
|
|
|
|
// Check if it's a file reference
|
|
if (keyOrFilePath.startsWith(FILE_PREFIX)) {
|
|
String filePath = keyOrFilePath.substring(FILE_PREFIX.length());
|
|
try {
|
|
Path path = Paths.get(filePath);
|
|
if (!Files.exists(path)) {
|
|
log.error("License file does not exist: {}", filePath);
|
|
return null;
|
|
}
|
|
log.info("Reading license from file: {}", filePath);
|
|
return Files.readString(path);
|
|
} catch (IOException e) {
|
|
log.error("Failed to read license file: {}", e.getMessage());
|
|
return null;
|
|
}
|
|
}
|
|
|
|
// It's a direct license key
|
|
return keyOrFilePath;
|
|
}
|
|
|
|
public void updateLicenseKey(String newKey) throws IOException {
|
|
applicationProperties.getPremium().setKey(newKey);
|
|
GeneralUtils.saveKeyToSettings("EnterpriseEdition.key", newKey);
|
|
checkLicense();
|
|
}
|
|
|
|
public License getPremiumLicenseEnabledResult() {
|
|
return premiumEnabledResult;
|
|
}
|
|
}
|