fix(core): Refactor import paths and update dependency references
This commit is contained in:
		| @@ -1,5 +1,13 @@ | ||||
| # Changelog | ||||
|  | ||||
| ## 2025-05-05 - 7.3.1 - fix(core) | ||||
| Refactor import paths and update dependency references | ||||
|  | ||||
| - Replaced deprecated 'smartacme.plugins.js' with the new 'plugins.js' across cert managers, handlers, and core classes | ||||
| - Added missing dependencies (@push.rocks/smartfile and @push.rocks/smartnetwork) in package.json | ||||
| - Updated HTTP challenge handlers to include domain support checks via checkWetherDomainIsSupported | ||||
| - Adjusted import paths in MongoCertManager, MemoryCertManager, and DNS-01 handler for consistency | ||||
|  | ||||
| ## 2025-05-05 - 7.3.0 - feat(index) | ||||
| Bump @tsclass/tsclass to 9.2.0 and update module exports to include handlers | ||||
|  | ||||
|   | ||||
| @@ -45,7 +45,9 @@ | ||||
|     "@push.rocks/smartdata": "^5.15.1", | ||||
|     "@push.rocks/smartdelay": "^3.0.5", | ||||
|     "@push.rocks/smartdns": "^6.2.2", | ||||
|     "@push.rocks/smartfile": "^11.2.0", | ||||
|     "@push.rocks/smartlog": "^3.0.7", | ||||
|     "@push.rocks/smartnetwork": "^4.0.1", | ||||
|     "@push.rocks/smartpromise": "^4.2.3", | ||||
|     "@push.rocks/smartrequest": "^2.1.0", | ||||
|     "@push.rocks/smartstring": "^4.0.15", | ||||
|   | ||||
							
								
								
									
										113
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										113
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							| @@ -26,9 +26,15 @@ importers: | ||||
|       '@push.rocks/smartdns': | ||||
|         specifier: ^6.2.2 | ||||
|         version: 6.2.2 | ||||
|       '@push.rocks/smartfile': | ||||
|         specifier: ^11.2.0 | ||||
|         version: 11.2.0 | ||||
|       '@push.rocks/smartlog': | ||||
|         specifier: ^3.0.7 | ||||
|         version: 3.0.7 | ||||
|       '@push.rocks/smartnetwork': | ||||
|         specifier: ^4.0.1 | ||||
|         version: 4.0.1 | ||||
|       '@push.rocks/smartpromise': | ||||
|         specifier: ^4.2.3 | ||||
|         version: 4.2.3 | ||||
| @@ -878,6 +884,9 @@ packages: | ||||
|   '@push.rocks/smartnetwork@3.0.2': | ||||
|     resolution: {integrity: sha512-s6CNGzQ1n/d/6cOKXbxeW6/tO//dr1woLqI01g7XhqTriw0nsm2G2kWaZh2J0VOguGNWBgQVCIpR0LjdRNWb3g==} | ||||
|  | ||||
|   '@push.rocks/smartnetwork@4.0.1': | ||||
|     resolution: {integrity: sha512-zLH88bKY6/cK6vVnCW4Fsugu4T+l6OerWWappit+BecdnQ6vrgShXSAa13JIkkWkWcs4dxEirlEfycQEEQw8BQ==} | ||||
|  | ||||
|   '@push.rocks/smartnpm@2.0.4': | ||||
|     resolution: {integrity: sha512-ljRPqnUsXzL5qnuAEt5POy0NnfKs7eYPuuJPJjYiK9VUdP/CyF4h14qTB4H816vNEuF7VU/ASRtz0qDlXmrztg==} | ||||
|  | ||||
| @@ -896,6 +905,9 @@ packages: | ||||
|   '@push.rocks/smartpdf@3.2.2': | ||||
|     resolution: {integrity: sha512-SKGNHz7HsgU6uVSVrRCL13kIeAFMvd4oQBLI3VmPcMkxXfWNPJkb6jKknqP8bhobWA/ryJS+3Dj///UELUvVKQ==} | ||||
|  | ||||
|   '@push.rocks/smartping@1.0.8': | ||||
|     resolution: {integrity: sha512-Fvx1Db6hSsDOI6pdiCuS9GjtOX8ugx865YQrPg5vK2iw6Qj/srwyXcWLFYt+19WVKtvtWDJIAKbW+q3bXFsCeA==} | ||||
|  | ||||
|   '@push.rocks/smartpromise@4.2.3': | ||||
|     resolution: {integrity: sha512-Ycg/TJR+tMt+S3wSFurOpEoW6nXv12QBtKXgBcjMZ4RsdO28geN46U09osPn9N9WuwQy1PkmTV5J/V4F9U8qEw==} | ||||
|  | ||||
| @@ -1402,6 +1414,9 @@ packages: | ||||
|   '@types/default-gateway@3.0.1': | ||||
|     resolution: {integrity: sha512-tpu0hp+AOIzwdAHyZPzLE5pCf9uT0pb+xZ76T4S7MrY2YTVq918Q7Q2VQ3KCVQqYxM7nxuCK/SL3X97jBEIeKQ==} | ||||
|  | ||||
|   '@types/default-gateway@7.2.2': | ||||
|     resolution: {integrity: sha512-35C93fYQlnLKLASkMPoxRvok4fENwB3By9clRLd2I/08n/XRl0pCdf7EB17K5oMMwZu8NBYA8i66jH5r/LYBKA==} | ||||
|  | ||||
|   '@types/dns-packet@5.6.5': | ||||
|     resolution: {integrity: sha512-qXOC7XLOEe43ehtWJCMnQXvgcIpv6rPmQ1jXT98Ad8A3TB1Ue50jsCbSSSyuazScEuZ/Q026vHbrOTVkmwA+7Q==} | ||||
|  | ||||
| @@ -1932,6 +1947,10 @@ packages: | ||||
|     resolution: {integrity: sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==} | ||||
|     engines: {node: '>=12'} | ||||
|  | ||||
|   clone-regexp@3.0.0: | ||||
|     resolution: {integrity: sha512-ujdnoq2Kxb8s3ItNBtnYeXdm07FcU0u8ARAT1lQ2YdMwQC+cdiXX8KoqMVuglztILivceTtp4ivqGSmEmhBUJw==} | ||||
|     engines: {node: '>=12'} | ||||
|  | ||||
|   clone@2.1.2: | ||||
|     resolution: {integrity: sha1-G39Ln1kfHo+DZwQBYANFoCiHQ18=} | ||||
|     engines: {node: '>=0.8'} | ||||
| @@ -2000,6 +2019,10 @@ packages: | ||||
|     resolution: {integrity: sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==} | ||||
|     engines: {node: '>= 0.6'} | ||||
|  | ||||
|   convert-hrtime@5.0.0: | ||||
|     resolution: {integrity: sha512-lOETlkIeYSJWcbbcvjRKGxVMXJR+8+OQb/mTPbA4ObPMytYIsUbuOE0Jzy60hjARYszq1id0j8KgVhC+WGZVTg==} | ||||
|     engines: {node: '>=12'} | ||||
|  | ||||
|   convert-source-map@2.0.0: | ||||
|     resolution: {integrity: sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==} | ||||
|  | ||||
| @@ -2518,6 +2541,10 @@ packages: | ||||
|   function-bind@1.1.2: | ||||
|     resolution: {integrity: sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==} | ||||
|  | ||||
|   function-timeout@0.1.1: | ||||
|     resolution: {integrity: sha512-0NVVC0TaP7dSTvn1yMiy6d6Q8gifzbvQafO46RtLG/kHJUBNd+pVRGOBoK44wNBvtSPUJRfdVvkFdD3p0xvyZg==} | ||||
|     engines: {node: '>=14.16'} | ||||
|  | ||||
|   get-caller-file@2.0.5: | ||||
|     resolution: {integrity: sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==} | ||||
|     engines: {node: 6.* || 8.* || >= 10.*} | ||||
| @@ -2583,6 +2610,10 @@ packages: | ||||
|     resolution: {integrity: sha512-mThBblvlAF1d4O5oqyvN+ZxLAYwIJK7bpMxgYqPD9okW0C3qm5FFn7k811QrcuEBwaogR3ngOFoCfs6mRv7teQ==} | ||||
|     engines: {node: '>=14.16'} | ||||
|  | ||||
|   got@13.0.0: | ||||
|     resolution: {integrity: sha512-XfBk1CxOOScDcMr9O1yKkNaQyy865NbYs+F7dr4H0LZMVgCj2Le59k6PqbNHoL5ToeaEQUYh6c6yMfVcc6SJxA==} | ||||
|     engines: {node: '>=16'} | ||||
|  | ||||
|   graceful-fs@4.2.10: | ||||
|     resolution: {integrity: sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==} | ||||
|  | ||||
| @@ -2803,6 +2834,10 @@ packages: | ||||
|     resolution: {integrity: sha512-4B4XA2HEIm/PY+OSpeMBXr8pGWBYbXuHgjMAqrwbLO3CPTCAd9ArEJzBUKGZtk9viY6+aSfadGnWyjY3ydYZkw==} | ||||
|     engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} | ||||
|  | ||||
|   is-ip@5.0.1: | ||||
|     resolution: {integrity: sha512-FCsGHdlrOnZQcp0+XT5a+pYowf33itBalCl+7ovNXC/7o5BhIpG14M3OrpPPdBSIQJCm+0M5+9mO7S9VVTTCFw==} | ||||
|     engines: {node: '>=14.16'} | ||||
|  | ||||
|   is-nan@1.3.2: | ||||
|     resolution: {integrity: sha512-E+zBKpQ2t6MEo1VsonYmluk9NxGrbzpeeLC2xIViuO2EjU2xsXsBPwTr3Ykv9l08UYEVEdWeRZNouaZqF6RN0w==} | ||||
|     engines: {node: '>= 0.4'} | ||||
| @@ -2827,6 +2862,10 @@ packages: | ||||
|     resolution: {integrity: sha512-MjYsKHO5O7mCsmRGxWcLWheFqN9DJ/2TmngvjKXihe6efViPqc274+Fx/4fYj/r03+ESvBdTXK0V6tA3rgez1g==} | ||||
|     engines: {node: '>= 0.4'} | ||||
|  | ||||
|   is-regexp@3.1.0: | ||||
|     resolution: {integrity: sha512-rbku49cWloU5bSMI+zaRaXdQHXnthP6DZ/vLnfdSKyL4zUzuWnomtOEiZZOd+ioQ+avFo/qau3KPTc7Fjy1uPA==} | ||||
|     engines: {node: '>=12'} | ||||
|  | ||||
|   is-stream@2.0.1: | ||||
|     resolution: {integrity: sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==} | ||||
|     engines: {node: '>=8'} | ||||
| @@ -3688,6 +3727,10 @@ packages: | ||||
|     resolution: {integrity: sha512-+6bkjnf0yQ4+tZV0zJv1017DiIF7y6R4yg17Mrhhkc25L7dtQtXWHgSCrz9BbLL4OeTFbPK4EALXqJUrwCIWXw==} | ||||
|     engines: {node: '>=14.16'} | ||||
|  | ||||
|   public-ip@7.0.1: | ||||
|     resolution: {integrity: sha512-DdNcqcIbI0wEeCBcqX+bmZpUCvrDMJHXE553zgyG1MZ8S1a/iCCxmK9iTjjql+SpHSv4cZkmRv5/zGYW93AlCw==} | ||||
|     engines: {node: '>=18'} | ||||
|  | ||||
|   pump@2.0.1: | ||||
|     resolution: {integrity: sha512-ruPMNRkN3MHP1cWJc9OWr+T/xDP0jhXYCLfJcBuX54hhfIBnaQmAUMfDcG4DM5UMWByBbJY69QSphm3jtDKIkA==} | ||||
|  | ||||
| @@ -4073,6 +4116,10 @@ packages: | ||||
|   stubborn-fs@1.2.5: | ||||
|     resolution: {integrity: sha512-H2N9c26eXjzL/S/K+i/RHHcFanE74dptvvjM8iwzwbVcWY/zjBbgRqF3K0DY4+OD+uTTASTBvDoxPDaPN02D7g==} | ||||
|  | ||||
|   super-regex@0.2.0: | ||||
|     resolution: {integrity: sha512-WZzIx3rC1CvbMDloLsVw0lkZVKJWbrkJ0k1ghKFmcnPrW1+jWbgTkTEWVtD9lMdmI4jZEz40+naBxl1dCUhXXw==} | ||||
|     engines: {node: '>=14.16'} | ||||
|  | ||||
|   supports-color@5.5.0: | ||||
|     resolution: {integrity: sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==} | ||||
|     engines: {node: '>=4'} | ||||
| @@ -4118,6 +4165,10 @@ packages: | ||||
|   through2@4.0.2: | ||||
|     resolution: {integrity: sha512-iOqSav00cVxEEICeD7TjLB1sueEL+81Wpzp2bY17uZjZN0pWZPuo4suZ/61VujxmqSGFfgOcNuTZ85QJwNZQpw==} | ||||
|  | ||||
|   time-span@5.1.0: | ||||
|     resolution: {integrity: sha512-75voc/9G4rDIJleOo4jPvN4/YC4GRZrY8yy1uU4lwrB3XEQbWve8zXoO5No4eFrGcTAMYyoY67p8jRQdtA1HbA==} | ||||
|     engines: {node: '>=12'} | ||||
|  | ||||
|   tiny-worker@2.3.0: | ||||
|     resolution: {integrity: sha512-pJ70wq5EAqTAEl9IkGzA+fN0836rycEuz2Cn6yeZ6FRzlVS5IDOkFHpIoEsksPRQV34GDqXm65+OlnZqUSyK2g==} | ||||
|  | ||||
| @@ -5981,6 +6032,16 @@ snapshots: | ||||
|       public-ip: 6.0.2 | ||||
|       systeminformation: 5.25.11 | ||||
|  | ||||
|   '@push.rocks/smartnetwork@4.0.1': | ||||
|     dependencies: | ||||
|       '@push.rocks/smartping': 1.0.8 | ||||
|       '@push.rocks/smartpromise': 4.2.3 | ||||
|       '@push.rocks/smartstring': 4.0.15 | ||||
|       '@types/default-gateway': 7.2.2 | ||||
|       isopen: 1.3.0 | ||||
|       public-ip: 7.0.1 | ||||
|       systeminformation: 5.25.11 | ||||
|  | ||||
|   '@push.rocks/smartnpm@2.0.4': | ||||
|     dependencies: | ||||
|       '@push.rocks/consolecolor': 2.0.2 | ||||
| @@ -6041,6 +6102,11 @@ snapshots: | ||||
|       - typescript | ||||
|       - utf-8-validate | ||||
|  | ||||
|   '@push.rocks/smartping@1.0.8': | ||||
|     dependencies: | ||||
|       '@types/ping': 0.4.4 | ||||
|       ping: 0.4.4 | ||||
|  | ||||
|   '@push.rocks/smartpromise@4.2.3': {} | ||||
|  | ||||
|   '@push.rocks/smartpuppeteer@2.0.5(typescript@5.7.3)': | ||||
| @@ -6918,6 +6984,8 @@ snapshots: | ||||
|  | ||||
|   '@types/default-gateway@3.0.1': {} | ||||
|  | ||||
|   '@types/default-gateway@7.2.2': {} | ||||
|  | ||||
|   '@types/dns-packet@5.6.5': | ||||
|     dependencies: | ||||
|       '@types/node': 22.15.3 | ||||
| @@ -7538,6 +7606,10 @@ snapshots: | ||||
|       strip-ansi: 6.0.1 | ||||
|       wrap-ansi: 7.0.0 | ||||
|  | ||||
|   clone-regexp@3.0.0: | ||||
|     dependencies: | ||||
|       is-regexp: 3.1.0 | ||||
|  | ||||
|   clone@2.1.2: {} | ||||
|  | ||||
|   cloudflare@4.2.0: | ||||
| @@ -7614,6 +7686,8 @@ snapshots: | ||||
|  | ||||
|   content-type@1.0.5: {} | ||||
|  | ||||
|   convert-hrtime@5.0.0: {} | ||||
|  | ||||
|   convert-source-map@2.0.0: {} | ||||
|  | ||||
|   cookie-signature@1.0.6: {} | ||||
| @@ -8185,6 +8259,8 @@ snapshots: | ||||
|  | ||||
|   function-bind@1.1.2: {} | ||||
|  | ||||
|   function-timeout@0.1.1: {} | ||||
|  | ||||
|   get-caller-file@2.0.5: {} | ||||
|  | ||||
|   get-intrinsic@1.2.2: | ||||
| @@ -8295,6 +8371,20 @@ snapshots: | ||||
|       p-cancelable: 3.0.0 | ||||
|       responselike: 3.0.0 | ||||
|  | ||||
|   got@13.0.0: | ||||
|     dependencies: | ||||
|       '@sindresorhus/is': 5.6.0 | ||||
|       '@szmarczak/http-timer': 5.0.1 | ||||
|       cacheable-lookup: 7.0.0 | ||||
|       cacheable-request: 10.2.14 | ||||
|       decompress-response: 6.0.0 | ||||
|       form-data-encoder: 2.1.4 | ||||
|       get-stream: 6.0.1 | ||||
|       http2-wrapper: 2.2.1 | ||||
|       lowercase-keys: 3.0.0 | ||||
|       p-cancelable: 3.0.0 | ||||
|       responselike: 3.0.0 | ||||
|  | ||||
|   graceful-fs@4.2.10: {} | ||||
|  | ||||
|   graceful-fs@4.2.11: {} | ||||
| @@ -8531,6 +8621,11 @@ snapshots: | ||||
|     dependencies: | ||||
|       ip-regex: 5.0.0 | ||||
|  | ||||
|   is-ip@5.0.1: | ||||
|     dependencies: | ||||
|       ip-regex: 5.0.0 | ||||
|       super-regex: 0.2.0 | ||||
|  | ||||
|   is-nan@1.3.2: | ||||
|     dependencies: | ||||
|       call-bind: 1.0.8 | ||||
| @@ -8551,6 +8646,8 @@ snapshots: | ||||
|       has-tostringtag: 1.0.2 | ||||
|       hasown: 2.0.2 | ||||
|  | ||||
|   is-regexp@3.1.0: {} | ||||
|  | ||||
|   is-stream@2.0.1: {} | ||||
|  | ||||
|   is-stream@4.0.1: {} | ||||
| @@ -9590,6 +9687,12 @@ snapshots: | ||||
|       got: 12.6.1 | ||||
|       is-ip: 4.0.0 | ||||
|  | ||||
|   public-ip@7.0.1: | ||||
|     dependencies: | ||||
|       dns-socket: 4.2.2 | ||||
|       got: 13.0.0 | ||||
|       is-ip: 5.0.1 | ||||
|  | ||||
|   pump@2.0.1: | ||||
|     dependencies: | ||||
|       end-of-stream: 1.4.4 | ||||
| @@ -10093,6 +10196,12 @@ snapshots: | ||||
|  | ||||
|   stubborn-fs@1.2.5: {} | ||||
|  | ||||
|   super-regex@0.2.0: | ||||
|     dependencies: | ||||
|       clone-regexp: 3.0.0 | ||||
|       function-timeout: 0.1.1 | ||||
|       time-span: 5.1.0 | ||||
|  | ||||
|   supports-color@5.5.0: | ||||
|     dependencies: | ||||
|       has-flag: 3.0.0 | ||||
| @@ -10158,6 +10267,10 @@ snapshots: | ||||
|     dependencies: | ||||
|       readable-stream: 3.6.2 | ||||
|  | ||||
|   time-span@5.1.0: | ||||
|     dependencies: | ||||
|       convert-hrtime: 5.0.0 | ||||
|  | ||||
|   tiny-worker@2.3.0: | ||||
|     dependencies: | ||||
|       esm: 3.2.25 | ||||
|   | ||||
| @@ -3,6 +3,6 @@ | ||||
|  */ | ||||
| export const commitinfo = { | ||||
|   name: '@push.rocks/smartacme', | ||||
|   version: '7.3.0', | ||||
|   version: '7.3.1', | ||||
|   description: 'A TypeScript-based ACME client for LetsEncrypt certificate management with a focus on simplicity and power.' | ||||
| } | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import * as plugins from '../smartacme.plugins.js'; | ||||
| import * as plugins from '../plugins.js'; | ||||
| import type { ICertManager } from '../interfaces/certmanager.js'; | ||||
| import { SmartacmeCert } from '../smartacme.classes.cert.js'; | ||||
|  | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import * as plugins from '../smartacme.plugins.js'; | ||||
| import * as plugins from '../plugins.js'; | ||||
| import type { ICertManager } from '../interfaces/certmanager.js'; | ||||
| import { SmartacmeCert } from '../smartacme.classes.cert.js'; | ||||
|  | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import * as plugins from '../smartacme.plugins.js'; | ||||
| import * as plugins from '../plugins.js'; | ||||
| import type { IChallengeHandler } from './IChallengeHandler.js'; | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -1,5 +1,4 @@ | ||||
| import { promises as fs } from 'fs'; | ||||
| import * as path from 'path'; | ||||
| import * as plugins from '../plugins.js'; | ||||
| import type { IChallengeHandler } from './IChallengeHandler.js'; | ||||
|  | ||||
| /** | ||||
| @@ -19,6 +18,9 @@ export class Http01Webroot implements IChallengeHandler<{ | ||||
|   keyAuthorization: string; | ||||
|   webPath: string; | ||||
| }> { | ||||
|   private smartnetworkInstance = new plugins.smartnetwork.SmartNetwork(); | ||||
|   private smartdnsClient = new plugins.smartdnsClient.Smartdns({}); | ||||
|    | ||||
|   private webroot: string; | ||||
|  | ||||
|   constructor(options: Http01WebrootOptions) { | ||||
| @@ -31,10 +33,10 @@ export class Http01Webroot implements IChallengeHandler<{ | ||||
|  | ||||
|   public async prepare(ch: { token: string; keyAuthorization: string; webPath: string }): Promise<void> { | ||||
|     const relWebPath = ch.webPath.replace(/^\/+/, ''); | ||||
|     const filePath = path.join(this.webroot, relWebPath); | ||||
|     const dir = path.dirname(filePath); | ||||
|     await fs.mkdir(dir, { recursive: true }); | ||||
|     await fs.writeFile(filePath, ch.keyAuthorization, 'utf8'); | ||||
|     const filePath = plugins.path.join(this.webroot, relWebPath); | ||||
|     const dir = plugins.path.dirname(filePath); | ||||
|     await plugins.fs.promises.mkdir(dir, { recursive: true }); | ||||
|     await plugins.fs.promises.writeFile(filePath, ch.keyAuthorization, 'utf8'); | ||||
|   } | ||||
|  | ||||
|   public async verify(ch: { webPath: string; keyAuthorization: string }): Promise<void> { | ||||
| @@ -44,11 +46,24 @@ export class Http01Webroot implements IChallengeHandler<{ | ||||
|  | ||||
|   public async cleanup(ch: { token: string; webPath: string }): Promise<void> { | ||||
|     const relWebPath = ch.webPath.replace(/^\/+/, ''); | ||||
|     const filePath = path.join(this.webroot, relWebPath); | ||||
|     const filePath = plugins.path.join(this.webroot, relWebPath); | ||||
|     try { | ||||
|       await fs.unlink(filePath); | ||||
|       await plugins.fs.promises.unlink(filePath); | ||||
|     } catch { | ||||
|       // ignore missing file | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   public async checkWetherDomainIsSupported(domainArg: string): Promise<boolean> { | ||||
|     const publicIps = await this.smartnetworkInstance.getPublicIps(); | ||||
|     const aRecords = await this.smartdnsClient.getRecordsA(domainArg); | ||||
|     const aaaaRecords = await this.smartdnsClient.getRecordsAAAA(domainArg); | ||||
|     if (aRecords.length && aRecords.some(record => record.value !== publicIps.v4)) { | ||||
|       return false; | ||||
|     } | ||||
|     if (aaaaRecords.length && aaaaRecords.some(record => record.value !== publicIps.v6)) { | ||||
|       return false; | ||||
|     } | ||||
|     return true; | ||||
|   } | ||||
| } | ||||
| @@ -1,3 +1,4 @@ | ||||
| import * as plugins from '../plugins.js'; | ||||
| import type { IChallengeHandler } from './IChallengeHandler.js'; | ||||
|  | ||||
| /** | ||||
| @@ -13,6 +14,8 @@ export interface Http01MemoryHandlerChallenge { | ||||
| } | ||||
|  | ||||
| export class Http01MemoryHandler implements IChallengeHandler<Http01MemoryHandlerChallenge> { | ||||
|   private smartnetworkInstance = new plugins.smartnetwork.SmartNetwork(); | ||||
|   private smartdnsClient = new plugins.smartdnsClient.Smartdns({}); | ||||
|   private store: Map<string, string> = new Map(); | ||||
|  | ||||
|   public getSupportedTypes(): string[] { | ||||
| @@ -64,4 +67,17 @@ export class Http01MemoryHandler implements IChallengeHandler<Http01MemoryHandle | ||||
|     res.statusCode = 404; | ||||
|     return res.end(); | ||||
|   } | ||||
| } | ||||
|  | ||||
|   public async checkWetherDomainIsSupported(domainArg: string): Promise<boolean> { | ||||
|     const publicIps = await this.smartnetworkInstance.getPublicIps(); | ||||
|     const aRecords = await this.smartdnsClient.getRecordsA(domainArg); | ||||
|     const aaaaRecords = await this.smartdnsClient.getRecordsAAAA(domainArg); | ||||
|     if (aRecords.length && aRecords.some((record) => record.value !== publicIps.v4)) { | ||||
|       return false; | ||||
|     } | ||||
|     if (aaaaRecords.length && aaaaRecords.some((record) => record.value !== publicIps.v6)) { | ||||
|       return false; | ||||
|     } | ||||
|     return true; | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -19,4 +19,6 @@ export interface IChallengeHandler<T> { | ||||
|    * Clean up resources: remove DNS record, stop server. | ||||
|    */ | ||||
|   cleanup(ch: T): Promise<void>; | ||||
|  | ||||
|   checkWetherDomainIsSupported(domainArg: string): Promise<boolean>; | ||||
| } | ||||
| @@ -1,3 +1,9 @@ | ||||
| // node native
 | ||||
| import * as fs from 'fs'; | ||||
| import * as path from 'path'; | ||||
| 
 | ||||
| export { fs, path }; | ||||
| 
 | ||||
| // @apiclient.xyz scope
 | ||||
| import * as cloudflare from '@apiclient.xyz/cloudflare'; | ||||
| 
 | ||||
| @@ -13,7 +19,9 @@ import * as lik from '@push.rocks/lik'; | ||||
| import * as smartdata from '@push.rocks/smartdata'; | ||||
| import * as smartdelay from '@push.rocks/smartdelay'; | ||||
| import * as smartdnsClient from '@push.rocks/smartdns/client'; | ||||
| import * as smartfile from '@push.rocks/smartfile'; | ||||
| import * as smartlog from '@push.rocks/smartlog'; | ||||
| import * as smartnetwork from '@push.rocks/smartnetwork'; | ||||
| import * as smartpromise from '@push.rocks/smartpromise'; | ||||
| import * as smartrequest from '@push.rocks/smartrequest'; | ||||
| import * as smartunique from '@push.rocks/smartunique'; | ||||
| @@ -25,7 +33,9 @@ export { | ||||
|   smartdata, | ||||
|   smartdelay, | ||||
|   smartdnsClient, | ||||
|   smartfile, | ||||
|   smartlog, | ||||
|   smartnetwork, | ||||
|   smartpromise, | ||||
|   smartrequest, | ||||
|   smartunique, | ||||
| @@ -1,4 +1,4 @@ | ||||
| import * as plugins from './smartacme.plugins.js'; | ||||
| import * as plugins from './plugins.js'; | ||||
|  | ||||
| /** | ||||
|  * Plain certificate record. | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import * as plugins from './smartacme.plugins.js'; | ||||
| import * as plugins from './plugins.js'; | ||||
| import * as interfaces from './interfaces/index.js'; | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import * as plugins from './smartacme.plugins.js'; | ||||
| import * as plugins from './plugins.js'; | ||||
| import type { ICertManager } from './interfaces/certmanager.js'; | ||||
| import { SmartacmeCertMatcher } from './smartacme.classes.certmatcher.js'; | ||||
| import { commitinfo } from './00_commitinfo_data.js'; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user