| 
									
										
										
										
											2025-03-25 09:06:23 +00:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Type definitions for SNMP module | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-19 13:14:18 +00:00
										 |  |  | import { Buffer } from 'node:buffer'; | 
					
						
							| 
									
										
										
										
											2025-10-18 16:17:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-25 09:06:23 +00:00
										 |  |  | /** | 
					
						
							|  |  |  |  * UPS status interface | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2025-03-25 10:21:21 +00:00
										 |  |  | export interface IUpsStatus { | 
					
						
							| 
									
										
										
										
											2025-03-25 09:06:23 +00:00
										 |  |  |   /** Current power status */ | 
					
						
							|  |  |  |   powerStatus: 'online' | 'onBattery' | 'unknown'; | 
					
						
							|  |  |  |   /** Battery capacity percentage */ | 
					
						
							|  |  |  |   batteryCapacity: number; | 
					
						
							|  |  |  |   /** Remaining runtime in minutes */ | 
					
						
							|  |  |  |   batteryRuntime: number; | 
					
						
							|  |  |  |   /** Raw values from SNMP responses */ | 
					
						
							|  |  |  |   raw: Record<string, any>; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * SNMP OID Sets for different UPS brands | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2025-03-25 10:21:21 +00:00
										 |  |  | export interface IOidSet { | 
					
						
							| 
									
										
										
										
											2025-03-25 09:06:23 +00:00
										 |  |  |   /** OID for power status */ | 
					
						
							|  |  |  |   POWER_STATUS: string; | 
					
						
							|  |  |  |   /** OID for battery capacity */ | 
					
						
							|  |  |  |   BATTERY_CAPACITY: string; | 
					
						
							|  |  |  |   /** OID for battery runtime */ | 
					
						
							|  |  |  |   BATTERY_RUNTIME: string; | 
					
						
							| 
									
										
										
										
											2025-10-19 23:48:13 +00:00
										 |  |  |   /** Power status value mappings */ | 
					
						
							|  |  |  |   POWER_STATUS_VALUES?: { | 
					
						
							|  |  |  |     /** SNMP value that indicates UPS is online (on AC power) */ | 
					
						
							|  |  |  |     online: number; | 
					
						
							|  |  |  |     /** SNMP value that indicates UPS is on battery */ | 
					
						
							|  |  |  |     onBattery: number; | 
					
						
							|  |  |  |   }; | 
					
						
							| 
									
										
										
										
											2025-03-25 09:06:23 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Supported UPS model types | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2025-03-25 10:21:21 +00:00
										 |  |  | export type TUpsModel = 'cyberpower' | 'apc' | 'eaton' | 'tripplite' | 'liebert' | 'custom'; | 
					
						
							| 
									
										
										
										
											2025-03-25 09:06:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * SNMP Configuration interface | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2025-03-25 10:21:21 +00:00
										 |  |  | export interface ISnmpConfig { | 
					
						
							| 
									
										
										
										
											2025-03-25 09:06:23 +00:00
										 |  |  |   /** SNMP server host */ | 
					
						
							|  |  |  |   host: string; | 
					
						
							|  |  |  |   /** SNMP server port (default 161) */ | 
					
						
							|  |  |  |   port: number; | 
					
						
							|  |  |  |   /** SNMP version (1, 2, or 3) */ | 
					
						
							|  |  |  |   version: number; | 
					
						
							|  |  |  |   /** Timeout in milliseconds */ | 
					
						
							|  |  |  |   timeout: number; | 
					
						
							| 
									
										
										
										
											2025-03-26 13:13:01 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   context?: string; | 
					
						
							| 
									
										
										
										
											2025-10-19 13:14:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-25 09:06:23 +00:00
										 |  |  |   // SNMPv1/v2c
 | 
					
						
							|  |  |  |   /** Community string for SNMPv1/v2c */ | 
					
						
							|  |  |  |   community?: string; | 
					
						
							| 
									
										
										
										
											2025-10-19 13:14:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-25 09:06:23 +00:00
										 |  |  |   // SNMPv3
 | 
					
						
							|  |  |  |   /** Security level for SNMPv3 */ | 
					
						
							|  |  |  |   securityLevel?: 'noAuthNoPriv' | 'authNoPriv' | 'authPriv'; | 
					
						
							|  |  |  |   /** Username for SNMPv3 authentication */ | 
					
						
							|  |  |  |   username?: string; | 
					
						
							|  |  |  |   /** Authentication protocol for SNMPv3 */ | 
					
						
							|  |  |  |   authProtocol?: 'MD5' | 'SHA'; | 
					
						
							|  |  |  |   /** Authentication key for SNMPv3 */ | 
					
						
							|  |  |  |   authKey?: string; | 
					
						
							|  |  |  |   /** Privacy protocol for SNMPv3 */ | 
					
						
							|  |  |  |   privProtocol?: 'DES' | 'AES'; | 
					
						
							|  |  |  |   /** Privacy key for SNMPv3 */ | 
					
						
							|  |  |  |   privKey?: string; | 
					
						
							| 
									
										
										
										
											2025-10-19 13:14:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-25 09:06:23 +00:00
										 |  |  |   // UPS model and custom OIDs
 | 
					
						
							|  |  |  |   /** UPS model for OID selection */ | 
					
						
							| 
									
										
										
										
											2025-03-25 10:21:21 +00:00
										 |  |  |   upsModel?: TUpsModel; | 
					
						
							| 
									
										
										
										
											2025-03-25 09:06:23 +00:00
										 |  |  |   /** Custom OIDs when using custom UPS model */ | 
					
						
							| 
									
										
										
										
											2025-03-25 10:21:21 +00:00
										 |  |  |   customOIDs?: IOidSet; | 
					
						
							| 
									
										
										
										
											2025-03-25 09:06:23 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * SNMPv3 security parameters | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2025-03-25 10:21:21 +00:00
										 |  |  | export interface ISnmpV3SecurityParams { | 
					
						
							| 
									
										
										
										
											2025-03-25 09:06:23 +00:00
										 |  |  |   /** Engine ID for the SNMP server */ | 
					
						
							|  |  |  |   msgAuthoritativeEngineID: Buffer; | 
					
						
							|  |  |  |   /** Engine boots counter */ | 
					
						
							|  |  |  |   msgAuthoritativeEngineBoots: number; | 
					
						
							|  |  |  |   /** Engine time counter */ | 
					
						
							|  |  |  |   msgAuthoritativeEngineTime: number; | 
					
						
							|  |  |  |   /** Username for authentication */ | 
					
						
							|  |  |  |   msgUserName: string; | 
					
						
							|  |  |  |   /** Authentication parameters */ | 
					
						
							|  |  |  |   msgAuthenticationParameters: Buffer; | 
					
						
							|  |  |  |   /** Privacy parameters */ | 
					
						
							|  |  |  |   msgPrivacyParameters: Buffer; | 
					
						
							| 
									
										
										
										
											2025-10-19 13:14:18 +00:00
										 |  |  | } |