Mit dem ctlmgr_ctl
können interne Variablen von AVM angezeigt und bearbeitet werden die unter /var/flash/
zumeist in Textdateien gespeichert sind.
Manche dieser Variablen sind nicht, nicht mehr oder nur mit einem anderen Branding im Webinterface zu sehen.
Dies ist keine öffentliche und dokumentierte Schnittstelle und verhält sich teilweise sehr eigenwillig.
Manche Werte sind nicht änderbar oder andere akzeptieren nur gewisse Wertebereiche.
Andere lösen ein Ereignis aus und kehren zu ihrem Wert zurück.
Es kann auch Werte geben die man besser nicht ändern sollte.
Vor dem Experimentieren sollte man unbedingt eine Konfigurationsicherung erstellen.
Die Module sind Kategorien wie zum Beispiel wlan
, env
oder tr069
die oft einzlene Konfigurationsdateien repräsentieren.
Um alle Module des Gerätes anzuzeigen:
$ ctlmgr_ctl u | sed '1,2d'
rights
uimodlogic
boxusers
...
avmcounter
rrd
move
Die Keys sind die Variablen eines Modules. Diese beginnen mit settings/
und manche alternativ mit status/
.
Um alle Keys eines Modules anzuzeigen:
$ ctlmgr_ctl u tr064
tr064:settings/
enabled=0
username=dslf-config
password=***
only_https=0
check_sid=error
doupdate_require_auth=1
Listet alle Module mit allen Keys und den gesetzten Werten auf.
Dieser Befehlt braucht gut 1 Minute und speichert die Ausgabe zusätzlich in uimods.txt
.
for x in $(ctlmgr_ctl u | sed '1,2d'); do echo; ctlmgr_ctl u $x; done | tee uimods.txt
$ ctlmgr_ctl r tr064 settings/username
dslf-config
oder
$ ctlmgr_ctl r -v tr064 settings/username
tr064:settings/username = dslf-config
$ ctlmgr_ctl w tr064 settings/username dslf-config
dslf-config
oder
$ ctlmgr_ctl w -v tr064 settings/username dslf-config
tr064:settings/username = dslf-config
Lesen:
$ ctlmgr_ctl r tr064 settings/enabled tr064 settings/username
0
dslf-config
oder
$ ctlmgr_ctl r -v tr064 settings/enabled tr064 settings/username
tr064:settings/enabled = 0
tr064:settings/username = dslf-config
Schreiben:
$ctlmgr_ctl w tr064 settings/enabled 0 tr064 settings/username dslf-config
0
dslf-config
oder
$ ctlmgr_ctl w -v tr064 settings/enabled 0 tr064 settings/username dslf-config
tr064:settings/enabled = 0
tr064:settings/username = dslf-config
Anzahl Elemente einer Liste ausgeben:
$ ctlmgr_ctl r boxusers settings/user/count
2
Alle Elemente einer Liste anzeigen:
$ ctlmgr_ctl l boxusers settings/user/list
user0
user1
Ausgewählte Variablen aller Elemente lesen:
$ ctlmgr_ctl l boxusers "settings/user/list(UID,name,box_admin_rights)"
user0 boxuser11 fritz 3
user1 boxuser10 horst 0
Eine Variable eines Elementes lesen:
$ ctlmgr_ctl r boxusers settings/user0/UID
boxuser11
Nächstes freies Element anzeigen:
$ ctlmgr_ctl r boxusers settings/user/newid
user2
Ein neues Element anlegen:
$ ctlmgr_ctl w boxusers settings/user2/enabled 0 boxusers settings/user2/name horst boxusers settings/user2/box_admin_rights 3 boxusers settings/user2/password aciouasvdtn
0
horst
3
****
Ein Element löschen:
$ ctlmgr_ctl del boxusers boxusers:command/user2