clixon/apps/restconf
Olof Hagsand e48f8dd00e clixon_netconf -S is obsolete. Use clixon_netconf -l s instead.
* Unified log handling for all clicon applications using -l e|o|s|f.
  * The options stand for e:stderr, o:stdout, s: syslog, f:file
2018-07-29 19:41:10 +02:00
..
clixon_restconf.h mv api_return_err to restconf_lib.c 2018-04-08 16:07:24 +00:00
Makefile.in Added clicon_log_init(.., CLICON_LOG_FILE) option and clicon_log_file() for c\ 2018-07-26 20:13:02 +02:00
README.md readme start nginx 2018-07-22 20:49:16 +02:00
restconf_lib.c * Experimental NACM RFC8341 Network Configuration Access Control Model. 2018-04-19 22:44:15 +02:00
restconf_lib.h mv api_return_err to restconf_lib.c 2018-04-08 16:07:24 +00:00
restconf_main.c clixon_netconf -S is obsolete. Use clixon_netconf -l s instead. 2018-07-29 19:41:10 +02:00
restconf_methods.c * Much better support for XPATH 1.0 according to https://www.w3.org/TR/xpath-10 using yacc/lex 2018-07-17 16:59:32 +02:00
restconf_methods.h * Restructure and more generic plugin API (cli,backend,restconf,netconf) 2018-04-02 10:38:53 +02:00

Clixon Restconf

Installation using Nginx

Ensure www-data is member of the CLICON_SOCK_GROUP (default clicon). If not, add it:

  sudo usermod -a -G clicon www-data

Define nginx config file: /etc/nginx/sites-available/default

server {
  ...
  location /restconf {
    root /usr/share/nginx/html/restconf;
    fastcgi_pass unix:/www-data/fastcgi_restconf.sock;
    include fastcgi_params;
  }
}

Start nginx daemon

sudo /etc/init.d nginx start

Alternatively, start it via systemd:

sudo /etc/init.d/nginx start
sudo systemctl start start.service

Start clixon restconf daemon

olof@vandal> sudo su -c "/www-data/clixon_restconf -f /usr/local/etc/example.xml " -s /bin/sh www-data

Make restconf calls with curl

olof@vandal> curl -G http://127.0.0.1/restconf/data/interfaces
[
  {
    "interfaces": {
      "interface":[
        {
          "name": "eth0",
          "type": "eth",
          "enabled": "true",
          "name": "eth9",
          "type": "eth",
          "enabled": "true"
         }
      ]
    }
  }
]
olof@vandal> curl -G http://127.0.0.1/restconf/data/interfaces/interface/name=eth9/type
[
  {
    "type": "eth" 
  }
]

curl -sX POST -d '{"interfaces":{"interface":{"name":"eth1","type":"eth","enabled":"true"}}}' http://localhost/restconf/data

Debugging

Start the restconf fastcgi program with debug flag:

sudo su -c "/www-data/clixon_restconf -Df /usr/local/etc/example.xml" -s /bin/sh www-data

Look at syslog:

tail -f /var/log/syslog | grep clixon_restconf

Send command:

curl -G http://127.0.0.1/restconf/data/*