Compare commits

..

2 Commits
v9.4.0 ... main

Author SHA1 Message Date
86615efa94 v9.5.0
Some checks failed
Default (tags) / security (push) Failing after 0s
Default (tags) / test (push) Failing after 0s
Default (tags) / release (push) Has been skipped
Default (tags) / metadata (push) Has been skipped
2026-04-05 11:27:27 +00:00
efb56ef58e feat(smartacme): add forceRenew option to bypass cached certificate reuse during issuance 2026-04-05 11:27:27 +00:00
4 changed files with 11 additions and 2 deletions

View File

@@ -1,5 +1,11 @@
# Changelog
## 2026-04-05 - 9.5.0 - feat(smartacme)
add forceRenew option to bypass cached certificate reuse during issuance
- adds a forceRenew flag to certificate issuance input handling
- skips the cached valid-certificate check when forceRenew is enabled
## 2026-04-03 - 9.4.0 - feat(smartacme)
add forceRenew option for certificate issuance requests

View File

@@ -1,6 +1,6 @@
{
"name": "@push.rocks/smartacme",
"version": "9.4.0",
"version": "9.5.0",
"private": false,
"description": "A TypeScript-based ACME client and server for certificate management with built-in CA, supporting LetsEncrypt and custom ACME authorities.",
"main": "dist_ts/index.js",

View File

@@ -3,6 +3,6 @@
*/
export const commitinfo = {
name: '@push.rocks/smartacme',
version: '9.4.0',
version: '9.5.0',
description: 'A TypeScript-based ACME client and server for certificate management with built-in CA, supporting LetsEncrypt and custom ACME authorities.'
}

View File

@@ -11,6 +11,7 @@ interface ICertIssuanceInput {
domainArg: string;
isWildcardRequest: boolean;
includeWildcard: boolean;
forceRenew: boolean;
}
const CERT_ISSUANCE_STEPS = [
@@ -159,6 +160,7 @@ export class SmartAcme {
},
shouldExecute: async (_task, input?: ICertIssuanceInput) => {
if (!input?.certDomainName || !this.certmanager) return true;
if (input.forceRenew) return true;
// Safety net: if a valid cert is already cached, skip re-issuance
const existing = await this.certmanager.retrieveCertificate(input.certDomainName);
if (existing && !existing.shouldBeRenewed()) {
@@ -397,6 +399,7 @@ export class SmartAcme {
domainArg,
isWildcardRequest,
includeWildcard: options?.includeWildcard ?? false,
forceRenew,
};
const result = await this.taskManager.triggerTaskConstrained(