Hi akcoder,
Thank you for the reply, this is the debug log I get:
GNU nano 6.2 genieacs-cwmp-access.log
2025-03-24T10:31:07.272Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: Inform; cpeRequestId="4" informEvent="2 PERIODIC" informRetryCount=0
2025-03-24T10:31:07.466Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: ACS request; acsRequestId="195c7b4c1f80000" acsRequestName="GetParameterNames"
2025-03-24T10:31:07.671Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: ACS request; acsRequestId="195c7b4c1f80001" acsRequestName="GetParameterNames"
2025-03-24T10:31:07.865Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: ACS request; acsRequestId="195c7b4c1f80002" acsRequestName="GetParameterNames"
2025-03-24T10:31:08.059Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: ACS request; acsRequestId="195c7b4c1f80003" acsRequestName="GetParameterNames"
2025-03-24T10:31:08.254Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: ACS request; acsRequestId="195c7b4c1f80004" acsRequestName="GetParameterNames"
2025-03-24T10:31:08.448Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: ACS request; acsRequestId="195c7b4c1f80005" acsRequestName="GetParameterNames"
2025-03-24T10:31:08.641Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: ACS request; acsRequestId="195c7b4c1f80006" acsRequestName="GetParameterNames"
2025-03-24T10:31:08.840Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: ACS request; acsRequestId="195c7b4c1f80007" acsRequestName="GetParameterNames"
2025-03-24T10:31:09.035Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: ACS request; acsRequestId="195c7b4c1f80008" acsRequestName="GetParameterNames"
2025-03-24T10:31:09.230Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: ACS request; acsRequestId="195c7b4c1f80009" acsRequestName="GetParameterNames"
2025-03-24T10:31:09.644Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: ACS request; acsRequestId="195c7b4c1f8000a" acsRequestName="GetParameterNames"
2025-03-24T10:31:09.872Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: ACS request; acsRequestId="195c7b4c1f8000b" acsRequestName="GetParameterNames"
2025-03-24T10:31:10.102Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: ACS request; acsRequestId="195c7b4c1f8000c" acsRequestName="GetParameterNames"
2025-03-24T10:31:10.332Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: ACS request; acsRequestId="195c7b4c1f8000d" acsRequestName="GetParameterNames"
2025-03-24T10:31:10.525Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: ACS request; acsRequestId="195c7b4c1f8000e" acsRequestName="GetParameterValues"
2025-03-24T10:31:10.722Z [WARN] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: Missing parameter in response; parameter="InternetGatewayDevice.LANDevice.1.WLANConfiguration>
2025-03-24T10:31:10.722Z [WARN] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: Missing parameter in response; parameter="InternetGatewayDevice.LANDevice.1.WLANConfiguration>
2025-03-24T10:31:10.722Z [WARN] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: Missing parameter in response; parameter="InternetGatewayDevice.LANDevice.1.WLANConfiguration>
2025-03-24T10:31:10.722Z [WARN] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: Missing parameter in response; parameter="InternetGatewayDevice.LANDevice.1.WLANConfiguration>
2025-03-24T10:31:10.722Z [WARN] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: Missing parameter in response; parameter="InternetGatewayDevice.LANDevice.1.WLANConfiguration>
2025-03-24T10:31:10.722Z [WARN] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: Missing parameter in response; parameter="InternetGatewayDevice.LANDevice.1.WLANConfiguration>
2025-03-24T10:31:10.726Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: ACS request; acsRequestId="195c7b4c1f8000f" acsRequestName="GetParameterNames"
2025-03-24T10:31:11.329Z [WARN] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: CPE fault; acsRequestId="195c7b4c1f8000f" cpeFaultCode="9003" cpeFaultString="Invalid argumen>
2025-03-24T10:31:11.329Z [WARN] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: Channel has faulted; channel="default" retries=0 faultCode="cwmp.9003" faultMessage="Invalid >
2025-03-24T10:31:11.329Z [WARN] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: Channel has faulted; channel="inform" retries=0 faultCode="cwmp.9003" faultMessage="Invalid a>
2025-03-24T10:31:11.342Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: ACS request; acsRequestId="195c7b4c1f80200" acsRequestName="GetParameterNames"
2025-03-24T10:31:11.535Z [WARN] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: CPE fault; acsRequestId="195c7b4c1f80200" cpeFaultCode="9003" cpeFaultString="Invalid argumen>
2025-03-24T10:31:11.535Z [WARN] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: Channel has faulted; channel="inform" retries=1 faultCode="cwmp.9003" faultMessage="Invalid a>
2025-03-24T10:31:11.561Z [INFO] ::ffff:103.173.170.61 8CC7C3-XPON%2B1GE%2B1FE%2B1POTS%2BWIFI-F32428CC7C3017243: New device registered
All of my provision scripts are reverted to default with addition of this virtual parameter declaration.
Inform:
// Device ID as user name
const username = declare("DeviceID.ID", {value: 1}).value[0]
//// Password will be fixed for a given device because Math.random() is seeded with device ID by default.
const password = Math.trunc(Math.random() * Number.MAX_SAFE_INTEGER).toString(36);
const informInterval = 300;
// Refresh values daily
const daily = Date.now(86400000);
// Unique inform offset per device for better load distribution
const informTime = daily % 86400000;
declare("InternetGatewayDevice.ManagementServer.ConnectionRequestUsername", {value: daily}, {value: username});
declare("InternetGatewayDevice.ManagementServer.ConnectionRequestPassword", {value: daily}, {value: password});
declare("InternetGatewayDevice.ManagementServer.PeriodicInformEnable", {value: daily}, {value: true});
declare("InternetGatewayDevice.ManagementServer.PeriodicInformInterval", {value: daily}, {value: informInterval});
declare("InternetGatewayDevice.ManagementServer.PeriodicInformTime", {value: daily}, {value: informTime});
declare("Device.ManagementServer.ConnectionRequestUsername", {value: daily}, {value: username});
declare("Device.ManagementServer.ConnectionRequestPassword", {value: daily}, {value: password});
declare("Device.ManagementServer.PeriodicInformEnable", {value: daily}, {value: true});
declare("Device.ManagementServer.PeriodicInformInterval", {value: daily}, {value: informInterval});
declare("Device.ManagementServer.PeriodicInformTime", {value: daily}, {value: informTime});
declare("VirtualParameters.User", {path: Date.now(), value: Date.now()});
default
const hourly = Date.now(3600000);
// Refresh basic parameters hourly
declare("InternetGatewayDevice.DeviceInfo.HardwareVersion", {path: hourly, value: hourly});
declare("InternetGatewayDevice.DeviceInfo.SoftwareVersion", {path: hourly, value: hourly});
declare("InternetGatewayDevice.WANDevice.*.WANConnectionDevice.*.WANIPConnection.*.MACAddress", {path: hourly, value: hourly});
declare("InternetGatewayDevice.WANDevice.*.WANConnectionDevice.*.WANIPConnection.*.ExternalIPAddress", {path: hourly, value: hourly});
declare("InternetGatewayDevice.LANDevice.*.WLANConfiguration.*.SSID", {path: hourly, value: hourly});
// Don't refresh password field periodically because CPEs always report blank passowrds for security reasons
declare("InternetGatewayDevice.LANDevice.*.WLANConfiguration.*.KeyPassphrase", {path: hourly, value: 1});
declare("InternetGatewayDevice.LANDevice.*.Hosts.Host.*.HostName", {path: hourly, value: hourly});
declare("InternetGatewayDevice.LANDevice.*.Hosts.Host.*.IPAddress", {path: hourly, value: hourly});
declare("InternetGatewayDevice.LANDevice.*.Hosts.Host.*.MACAddress", {path: hourly, value: hourly});
bootstrap
const now = Date.now();
// Clear cached data model to force a refresh
clear("Device", now);
clear("InternetGatewayDevice", now);
Any advice is much appreciated.
Thanks again.