summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--debian/control3
-rw-r--r--debian/vyatta-cfg.postinst.in4
-rwxr-xr-xetc/bash_completion.d/20vyatta-cfg2
-rw-r--r--etc/default/vyatta-cfg1
-rwxr-xr-xscripts/VyattaMisc.pm27
-rw-r--r--scripts/vyatta-interfaces.pl51
-rwxr-xr-xscripts/vyatta-load-config.pl2
-rw-r--r--src/cli_new.c148
-rw-r--r--src/cli_path_utils.c1
-rw-r--r--src/cli_val.h41
-rw-r--r--src/commit.c126
-rw-r--r--src/delete.c79
-rw-r--r--src/set.c28
-rw-r--r--templates/interfaces/ethernet/node.def8
-rw-r--r--templates/interfaces/ethernet/node.tag/address/node.def1
-rw-r--r--templates/interfaces/ethernet/node.tag/vif/node.def13
-rw-r--r--templates/interfaces/ethernet/node.tag/vif/node.tag/address/node.def1
-rw-r--r--templates/interfaces/loopback/node.tag/address/node.def1
18 files changed, 273 insertions, 264 deletions
diff --git a/debian/control b/debian/control
index c469fb8..064474b 100644
--- a/debian/control
+++ b/debian/control
@@ -21,7 +21,8 @@ Depends: sed (>= 4.1.5),
bsdutils (>=1:2.13),
libc6 (>= 2.7-6),
libsort-versions-perl,
- vlan
+ vlan,
+ curl
Replaces: vyatta-cfg-firewall
Suggests: util-linux (>= 2.13-5),
net-tools,
diff --git a/debian/vyatta-cfg.postinst.in b/debian/vyatta-cfg.postinst.in
index 074d57c..d934b84 100644
--- a/debian/vyatta-cfg.postinst.in
+++ b/debian/vyatta-cfg.postinst.in
@@ -4,7 +4,7 @@ prefix=@prefix@
sysconfdir=@sysconfdir@
mkdir -m 0775 -p $sysconfdir/config $prefix/config
-chgrp vyattacfg $sysconfdir/config $prefix/config
+chgrp vyattacfg $sysconfdir/config $prefix/config 2>/dev/null
update-rc.d vyatta-ofr defaults 90 >/dev/null
# do we want to start vyatta-ofr here in postinst?
@@ -19,5 +19,5 @@ if [ "$sysconfdir" != "/etc" ]; then
fi
# add group for configuration, if not already present:
-grep '^vyattacfg:' /etc/group >/dev/null ||
+grep '^vyattacfg:' /etc/group >&/dev/null ||
addgroup --system vyattacfg
diff --git a/etc/bash_completion.d/20vyatta-cfg b/etc/bash_completion.d/20vyatta-cfg
index 3b523bd..d829693 100755
--- a/etc/bash_completion.d/20vyatta-cfg
+++ b/etc/bash_completion.d/20vyatta-cfg
@@ -1,4 +1,4 @@
-#!/bin/sh
+#!/bin/bash
# **** License ****
# This program is free software; you can redistribute it and/or modify
diff --git a/etc/default/vyatta-cfg b/etc/default/vyatta-cfg
index b07440f..8dbf00e 100644
--- a/etc/default/vyatta-cfg
+++ b/etc/default/vyatta-cfg
@@ -10,6 +10,7 @@ declare -x -r VYATTA_CONFIG_TEMPLATE=$vyatta_cfg_templates
declare -x -r VYATTA_TAG_NAME=node.tag
declare -x -r VYATTA_MOD_NAME=.modified
declare -x -r VYATTA_CFG_GROUP_NAME=vyattacfg
+declare -x -r HISTIGNORE="*password*:*-secret*"
} 2>/dev/null || :
declare -x VYATTA_EDIT_LEVEL=/
diff --git a/scripts/VyattaMisc.pm b/scripts/VyattaMisc.pm
index e6bd9ff..d74b55a 100755
--- a/scripts/VyattaMisc.pm
+++ b/scripts/VyattaMisc.pm
@@ -24,8 +24,8 @@
package VyattaMisc;
require Exporter;
@ISA = qw(Exporter);
-@EXPORT = qw(getNetAddIP isIpAddress);
-@EXPORT_OK = qw(getNetAddIP isIpAddress);
+@EXPORT = qw(getNetAddIP isIpAddress is_ip_v4_or_v6);
+@EXPORT_OK = qw(getNetAddIP isIpAddress is_ip_v4_or_v6);
use strict;
@@ -61,6 +61,29 @@ sub getNetAddrIP {
return $naip;
}
+sub is_ip_v4_or_v6 {
+ my $addr = shift;
+
+ my $ip = NetAddr::IP->new($addr);
+ if (defined $ip && $ip->version() == 4) {
+ #
+ # the call to IP->new() will accept 1.1 and consider
+ # it to be 1.1.0.0, so add a check to force all
+ # 4 octets to be defined
+ #
+ if ($addr !~ /\d+\.\d+\.\d+\.\d+/) {
+ return undef;
+ }
+ return 4;
+ }
+ $ip = NetAddr::IP->new6($addr);
+ if (defined $ip && $ip->version() == 6) {
+ return 6;
+ }
+
+ return undef;
+}
+
sub isIpAddress {
my $ip = shift;
diff --git a/scripts/vyatta-interfaces.pl b/scripts/vyatta-interfaces.pl
index 3794769..0c219c1 100644
--- a/scripts/vyatta-interfaces.pl
+++ b/scripts/vyatta-interfaces.pl
@@ -184,6 +184,14 @@ sub is_domain_name_set {
return $domainname;
}
+sub is_ethernet_mtu_set {
+ my $intf = shift;
+ my $config = new VyattaConfig;
+ $config->setLevel("interfaces ethernet $intf");
+ my $interface_mtu = undef;
+ $interface_mtu = $config->returnValue("mtu");
+ return $interface_mtu;
+}
sub dhcp_update_config {
my ($conf_file, $intf) = @_;
@@ -198,39 +206,20 @@ sub dhcp_update_config {
$output .= "\trequest subnet-mask, broadcast-address, routers, domain-name-servers";
my $domainname = is_domain_name_set();
if (!defined($domainname)) {
- $output .= ", domain-name;\n";
- } else {
- $output .= ";\n";
+ $output .= ", domain-name";
+ }
+ if ($intf =~ m/^eth[0-9]+$/) {
+ my $interface_mtu = is_ethernet_mtu_set($intf);
+ if (!defined($interface_mtu)) {
+ $output .= ", interface-mtu";
+ }
}
-
+ $output .= ";\n";
$output .= "}\n\n";
dhcp_write_file($conf_file, $output);
}
-sub is_ip_v4_or_v6 {
- my $addr = shift;
-
- my $ip = NetAddr::IP->new($addr);
- if (defined $ip && $ip->version() == 4) {
- #
- # the call to IP->new() will accept 1.1 and consider
- # it to be 1.1.0.0, so add a check to force all
- # 4 octets to be defined
- #
- if ($addr !~ /\d+\.\d+\.\d+\.\d+/) {
- return undef;
- }
- return 4;
- }
- $ip = NetAddr::IP->new6($addr);
- if (defined $ip && $ip->version() == 6) {
- return 6;
- }
-
- return undef;
-}
-
sub generate_dhclient_intf_files {
my $intf = shift;
@@ -456,7 +445,7 @@ sub op_dhcp_command {
print "$intf is not using DHCP to get an IP address\n";
exit 1;
}
-
+
my $tmp_dhclient_dir = '/var/run/vyatta/dhclient/';
my $release_file = $tmp_dhclient_dir . 'dhclient_release_' . $intf;
if ($op_command eq "dhcp-release") {
@@ -473,13 +462,13 @@ sub op_dhcp_command {
exit 0;
}
} elsif ($op_command eq "dhcp-renew") {
- print "Renewing DHCP lease on $intf ...\n";
+ print "Renewing DHCP lease on $intf ...\n";
run_dhclient($intf);
system ("rm -f $release_file\;");
exit 0;
}
-
- exit 0;
+
+ exit 0;
}
diff --git a/scripts/vyatta-load-config.pl b/scripts/vyatta-load-config.pl
index ee4a9c4..dfbf575 100755
--- a/scripts/vyatta-load-config.pl
+++ b/scripts/vyatta-load-config.pl
@@ -28,6 +28,8 @@ use IO::Prompt;
use Sys::Syslog qw(:standard :macros);
use VyattaConfigLoad;
+$SIG{'INT'} = 'IGNORE';
+
my $etcdir = $ENV{vyatta_sysconfdir};
my $sbindir = $ENV{vyatta_sbindir};
my $bootpath = $etcdir . "/config";
diff --git a/src/cli_new.c b/src/cli_new.c
index 0b50ccb..83cc150 100644
--- a/src/cli_new.c
+++ b/src/cli_new.c
@@ -16,6 +16,7 @@
#include <regex.h>
#include <errno.h>
#include <time.h>
+#include <utime.h>
#include "cli_objects.h"
#include "cli_val_engine.h"
@@ -35,7 +36,7 @@
/* Global vars: */
vtw_path m_path, t_path;
-/* Loval vars: */
+/* Local vars: */
static vtw_node *vtw_free_nodes; /* linked via left */
static char val_name[] = VAL_NAME;
static int cond1[TOP_COND] ={5, 0,-1,-1, 0, 1, 0, 0};
@@ -43,23 +44,23 @@ static int cond2[TOP_COND] ={5, 0, 1,-1,-1, 1, 1, 0};
static char const *cond_formats[DOMAIN_TYPE] =
{
0,
- "%u", /* INT_TYPE */
- "%u.%u.%u.%u", /*IPV4_TYPE*/
- "%u.%u.%u.%u/%u", /*IPV4NET_TYPE*/
- 0,
- 0,
- "%x:%x:%x:%x:%x:%x" /* MACADDR_TYPE */
+ "%u", /* INT_TYPE */
+ "%u.%u.%u.%u", /* IPV4_TYPE */
+ "%u.%u.%u.%u/%u", /* IPV4NET_TYPE */
+ "%x:%x:%x:%x:%x:%x:%x:%x", /* IPV6NET */
+ "%x:%x:%x:%x:%x:%x:%x:%x/%u", /* IPV6NET_TYPE */
+ "%x:%x:%x:%x:%x:%x" /* MACADDR_TYPE */
};
static int cond_format_lens[DOMAIN_TYPE] =
{
- 0,
- 1, /* INT_TYPE */
- 4, /*IPV4_TYPE*/
- 5, /*IPV4NET_TYPE*/
- 0,
- 0,
- 6 /* MACADDR_TYPE */
+ 0,
+ 1, /* INT_TYPE */
+ 4, /* IPV4_TYPE */
+ 5, /* IPV4NET_TYPE */
+ 16, /* IPV6_TYPE */
+ 17, /* IPV6NET_TYPE */
+ 6 /* MACADDR_TYPE */
};
static int cli_val_len;
@@ -110,7 +111,7 @@ char *cli_operation_name = NULL;
printf("echo \"bla-bla-bla%s\";", sptr)
note very important ';' as the end of the format
*/
-void bye(char *msg, ...)
+void bye(const char *msg, ...)
{
va_list ap;
@@ -135,7 +136,7 @@ void bye(char *msg, ...)
which are executed as eval `command` in order to
modify BASH env
*/
-void print_msg(char *msg, ...)
+void print_msg(const char *msg, ...)
{
va_list ap;
@@ -149,21 +150,49 @@ void print_msg(char *msg, ...)
va_end(ap);
}
+int mkdir_p(const char *path)
+{
+ if (mkdir(path, 0777) == 0)
+ return 0;
+
+ if (errno != ENOENT)
+ return -1;
+
+ char *tmp = strdup(path);
+ if (tmp == NULL) {
+ errno = ENOMEM;
+ return -1;
+ }
+
+ char *slash = strrchr(tmp, '/');
+ if (slash == NULL)
+ return -1;
+ *slash = '\0';
+
+ /* recurse to make missing piece of path */
+ int ret = mkdir_p(tmp);
+ if (ret == 0)
+ ret = mkdir(path, 0777);
+
+ free(tmp);
+ return ret;
+}
+
void touch_dir(const char *dp)
{
struct stat statbuf;
+
if (lstat(dp, &statbuf) < 0) {
- char *command;
- command = my_malloc(strlen(dp) + 10, "set");
- sprintf(command, "mkdir -p %s", dp);
- system(command);
- free(command);
- return;
- }
- if ((statbuf.st_mode & S_IFMT) != S_IFDIR) {
- bye("directory %s expected, found regular file", dp);
+ if (errno != ENOENT)
+ bye("can't access directory: %s (%s)", dp, strerror(errno));
+
+ if (mkdir_p(dp) < 0)
+ bye("can't make directory: %s (%s)", dp, strerror(errno));
+ } else {
+ if(!S_ISDIR(statbuf.st_mode))
+ bye("directory %s expected, found file", dp);
+ utime(dp, NULL);
}
- return;
}
/*****************************************************
@@ -367,7 +396,7 @@ get_config_lock()
return ret;
}
-void internal_error(int line, char *file)
+void internal_error(int line, const char *file)
{
printf("\n\nInternal Error at line %d in %s\n", line, file);
exit (-1);
@@ -802,7 +831,7 @@ int char2val(vtw_def *def, char *value, valstruct *valp)
compare two values per cond
returns result of comparison
****************************************************/
-boolean val_cmp(valstruct *left, valstruct *right, vtw_cond_e cond)
+boolean val_cmp(const valstruct *left, const valstruct *right, vtw_cond_e cond)
{
unsigned int left_parts[9], right_parts[9];
vtw_type_e val_type;
@@ -2045,35 +2074,7 @@ int cli_val_read(char *buf, int max_size)
}
return len;
}
-/*==========================================================*/
-/* MEMORY */
-/*==========================================================*/
-
-void *my_malloc(size_t size, const char *name)
-{
- return malloc(size);
-}
-void *my_realloc(void *ptr, size_t size, const char *name)
-{
- return realloc(ptr, size);
-}
-
-void my_free(void *ptr)
-{
- free(ptr);
-}
-
-/*************************************************
- my_strdup:
- do a strdup,
- exit on no memory
-**************************************************/
-char *my_strdup(const char *s, const char *name)
-{
- return strdup(s);
-}
-
-void done()
+void done(void)
{
free_reuse_list();
free_path(&t_path);
@@ -2094,16 +2095,28 @@ void restore_paths(vtw_mark *markp)
pop_path(&t_path);
}
-void touch()
+void touch_file(const char *filename)
{
- char *command;
- command = my_malloc(strlen(get_mdirp()) + 20, "delete");
- sprintf(command, "touch %s/%s", get_mdirp(), MOD_NAME);
- system(command);
- free(command);
+ int fd = creat(filename, 0666);
+ if (fd < 0)
+ {
+ if (errno == EEXIST)
+ utime(filename, NULL);
+ else
+ bye("can't touch %s (%s)", filename, strerror(errno));
+ }
+ else
+ close(fd);
+}
+
+void touch(void)
+{
+ char filename[strlen(get_mdirp()) + 20];
+ sprintf(filename, "%s/%s", get_mdirp(), MOD_NAME);
+ touch_file(filename);
}
-char *type_to_name(vtw_type_e type) {
+const char *type_to_name(vtw_type_e type) {
switch(type) {
case INT_TYPE: return("u32");
case IPV4_TYPE: return("ipv4");
@@ -2118,12 +2131,7 @@ char *type_to_name(vtw_type_e type) {
}
}
-#if 1
-void
-dump_log(int argc, char **argv)
-{
-}
-#else
+#ifdef CLI_DEBUG
void dump_log(int argc, char **argv)
{
int i;
diff --git a/src/cli_path_utils.c b/src/cli_path_utils.c
index 642b5ae..4111568 100644
--- a/src/cli_path_utils.c
+++ b/src/cli_path_utils.c
@@ -55,6 +55,7 @@
#include <string.h>
#include "cli_path_utils.h"
+#include "cli_val.h"
/*********************
* Data definitions
diff --git a/src/cli_val.h b/src/cli_val.h
index c9d59a6..5abaaee 100644
--- a/src/cli_val.h
+++ b/src/cli_val.h
@@ -156,8 +156,6 @@ extern void push_path(vtw_path *path, char *segm);
extern void push_path_no_escape(vtw_path *path, char *segm);
extern void free_def(vtw_def *defp);
extern void free_sorted(vtw_sorted *sortp);
-extern void *my_malloc(size_t size, const char *name);
-extern void *my_realloc(void *ptr, size_t size, const char *name);
extern vtw_path m_path, t_path;
@@ -167,29 +165,33 @@ extern vtw_path m_path, t_path;
extern void add_val(valstruct *first, valstruct *second);
extern int cli_val_read(char *buf, int max_size);
extern vtw_node *make_val_node(valstruct *val);
-extern char *my_strdup(const char *s, const char *name);
extern valstruct str2val(char *cp);
extern void dump_tree(vtw_node *node, int lev);
extern void dump_def(vtw_def *defp);
-extern boolean val_cmp(valstruct *left, valstruct *right, vtw_cond_e cond);
-extern void out_of_memory(void);
+extern boolean val_cmp(const valstruct *left, const valstruct *right,
+ vtw_cond_e cond);
+extern void out_of_memory(void) __attribute__((noreturn));
extern void subtract_values(char **lhs, const char *rhs);
extern boolean validate_value(vtw_def *def,
char *value);
-extern void internal_error(int line, char *file);
+extern void internal_error(int line, const char *file)
+ __attribute__((noreturn));
extern void done(void);
extern void del_value(vtw_def *defp, char *cp);
-extern void bye(char *msg, ...);
-extern void print_msg(char *msg, ...);
+extern void bye(const char *msg, ...)
+ __attribute__((format(printf, 1, 2), noreturn));
+extern void print_msg(const char *msg, ...)
+ __attribute__((format(printf, 1, 2)));
extern void switch_path(first_seg *seg);
extern void vtw_sort(valstruct *valp, vtw_sorted *sortp);
extern void free_val(valstruct *val);
-extern void my_free(void *ptr);
extern void touch(void);
-extern void dump_log(int argc, char **argv);
-extern char *type_to_name(vtw_type_e type);
+extern int mkdir_p(const char *path);
+
+extern const char *type_to_name(vtw_type_e type);
extern boolean execute_list(vtw_node *cur, vtw_def *def);
extern void touch_dir(const char *dp);
+extern void touch_file(const char *name);
extern void copy_path(vtw_path *to, vtw_path *from);
extern void free_path(vtw_path *path);
@@ -197,7 +199,7 @@ extern void free_path(vtw_path *path);
void mark_paths(vtw_mark *markp);
void restore_paths(vtw_mark *markp);
-extern int get_config_lock();
+extern int get_config_lock(void);
#define VTWERR_BADPATH -2
#define VTWERR_OK 0
@@ -217,14 +219,21 @@ extern int out_fd;
extern FILE *out_stream;
extern FILE *err_stream;
-extern int initialize_output();
+extern int initialize_output(void);
+
+/* debug hooks? */
+#define my_malloc(size, name) malloc(size)
+#define my_realloc(ptr, size, name) realloc(ptr, size)
+#define my_strdup(str, name) strdup(str)
+#define my_free(ptr) free(ptr)
/*** debug ***/
#undef CLI_DEBUG
#ifdef CLI_DEBUG
-#define DPRINT(...) printf(__VA_ARGS__)
+#define DPRINT(fmt, arg...) printf(fmt, #arg)
+extern void dump_log(int argc, char **argv);
#else
-#define DPRINT(...)
+#define DPRINT(fmt, arg...) while (0) { printf(fmt, ##arg); }
+#define dump_log(argc, argv)
#endif
-
#endif
diff --git a/src/commit.c b/src/commit.c
index 3b4d9d3..ee159b7 100644
--- a/src/commit.c
+++ b/src/commit.c
@@ -22,14 +22,14 @@ struct DirIndex {
};
struct DirSort {
- char name[255];
unsigned long priority;
+ char name[255];
};
-static char def_name[] = DEF_NAME;
-static char tag_name[] = TAG_NAME;
-static char opaque_name[] = OPQ_NAME;
+static const char def_name[] = DEF_NAME;
+static const char tag_name[] = TAG_NAME;
+static const char opaque_name[] = OPQ_NAME;
static int fin_commit(boolean ok);
static boolean commit_value(vtw_def *defp, char *cp,
@@ -51,17 +51,12 @@ static void make_dir()
{
struct stat statbuf;
if (lstat(m_path.path, &statbuf) < 0) {
- char *command;
- command = my_malloc(strlen(m_path.path) + 10, "set");
- sprintf(command, "mkdir -p %s", m_path.path);
- system(command);
- free(command);
+ mkdir_p(m_path.path);
return;
}
- if ((statbuf.st_mode & S_IFMT) != S_IFDIR) {
- bye("directory %s expected, found regular file", m_path.path);
+ if (!S_ISDIR(statbuf.st_mode)) {
+ bye("directory %s expected, found file", m_path.path);
}
- return;
}
#endif
@@ -111,18 +106,18 @@ init_next_filtered_dirname(DIR *dp, int sort_order, int exclude_wh)
strcpy(d->name,dirp->d_name);
d->priority = (unsigned long)0;
vtw_def def;
- char *path;
- path = malloc(strlen(t_path.path)+strlen(dirp->d_name)+2+8+1);
- sprintf(path,"%s/%s/node.def",t_path.path,dirp->d_name);
+
+ char path[strlen(t_path.path)+strlen(dirp->d_name)+2+8+1];
+ sprintf(path,"%s/%s/node.def", t_path.path, dirp->d_name);
+
struct stat s;
- if ((lstat(path,&s) >= 0) &&
- ((s.st_mode & S_IFMT) == S_IFREG)) {
+ if ((lstat(path,&s) == 0) && S_ISREG(s.st_mode)) {
memset(&def, 0, sizeof(def));
if (parse_def(&def,path,FALSE) == 0) {
d->priority = def.def_priority;
}
}
- free(path);
+
di->dirname[di->dirname_ct++] = d;
if (di->dirname_ct % 1024 == 0) {
di->dirname = realloc(di->dirname, (di->dirname_ct+1024)*sizeof(char*));
@@ -380,9 +375,7 @@ int main(int argc, char **argv)
{
boolean status;
- char *mod;
struct stat statbuf;
- int st;
boolean update_pending = FALSE;
cli_operation_name = "Commit";
@@ -394,11 +387,10 @@ int main(int argc, char **argv)
set_in_commit(TRUE);
dump_log( argc, argv);
init_paths(TRUE);
- mod = my_malloc(strlen(get_mdirp()) + strlen(MOD_NAME)+2, "COMMIT");
+
+ char mod[strlen(get_mdirp()) + sizeof(MOD_NAME)+2];
sprintf(mod, "%s/%s", get_mdirp(), MOD_NAME);
- st = lstat(mod, &statbuf);
- my_free(mod);
- if (st < 0 ) {
+ if (lstat(mod, &statbuf) < 0) {
fprintf(out_stream, "No configuration changes to commit\n");
return 0;
}
@@ -430,17 +422,14 @@ int main(int argc, char **argv)
static void perform_create_node()
{
#if BITWISE
- static char format[]="rm -f -r %s;mkdir %s";
- char *command;
+ static const char format[]="rm -f -r %s;mkdir %s";
+ char command[2 * strlen(m_path.path) + sizeof(format)];
+
switch_path(APATH);
- command = my_malloc(2 * strlen(m_path.path) + sizeof(format),
- "commit_create");
sprintf(command, format, m_path.path, m_path.path);
system(command);
- my_free(command);
switch_path(CPATH);
#endif
- return;
}
@@ -451,32 +440,27 @@ static void perform_create_node()
static void perform_delete_node()
{
#if BITWISE
- static char format[]="rm -f -r %s";
- char *command;
- command = my_malloc(strlen(m_path.path) + sizeof(format),
- "commit_delete");
+ static const char format[]="rm -f -r %s";
+ char command[strlen(m_path.path) + sizeof(format)];
sprintf(command, format, m_path.path);
system(command);
- my_free(command);
#endif
- return;
}
+
static void perform_move()
{
#if BITWISE
- static char format[] = "rm -r -f %s;mkdir %s;mv %s/" VAL_NAME " %s";
+ static const char format[] = "rm -r -f %s;mkdir %s;mv %s/" VAL_NAME " %s";
char *a_path;
- char *command;
+ char command[sizeof(format)+3*strlen(a_path)+strlen(m_path.path)];
+
switch_path(APATH);
a_path = my_strdup(m_path.path, "");
switch_path(CPATH);
- command = my_malloc(sizeof(format)+3*strlen(a_path)+strlen(m_path.path),"");
sprintf(command, format, a_path, a_path, m_path.path, a_path);
system(command);
- my_free(command);
my_free(a_path);
#endif
- return;
}
/*************************************************
@@ -753,26 +737,26 @@ boolean commit_update_child(vtw_def *pdefp, char *child,
switch_path(MPATH);
len = sizeof(format1) + 2 * strlen(get_tmpp()) +
strlen(m_path.path) + strlen(child);
- command = my_malloc(len, "");
+ command = malloc(len);
sprintf(command, format1, get_tmpp(), m_path.path, child,
get_tmpp());
system(command);
- my_free(command);
+
switch_path(APATH);
len = sizeof(format2) + 2 *strlen(m_path.path) +
2 * strlen( child) + strlen(get_tmpp());
- command = my_malloc(len, "");
+ command = realloc(command, len);
sprintf(command, format2, m_path.path, child, get_tmpp(),
child, m_path.path);
system(command);
- my_free(command);
+
switch_path(CPATH);
len = sizeof(format3) + strlen(m_path.path) +
strlen( child);
- command = my_malloc(len, "");
+ command = realloc(command, len);
sprintf(command, format3, m_path.path, child);
system(command);
- my_free(command);
+ free(command);
}
#endif
restore_paths(&mark);
@@ -1530,14 +1514,14 @@ static boolean commit_value(vtw_def *defp, char *cp,
static int fin_commit(boolean ok)
{
char *command;
- static char format1[]="cp -r -f %s/* %s"; /*mdirp, tmpp*/
- static char format2[]="sudo umount %s"; /*mdirp*/
- static char format3[]="rm -f %s/" MOD_NAME " >&/dev/null ; /bin/true";
+ static const char format1[]="cp -r -f %s/* %s"; /*mdirp, tmpp*/
+ static const char format2[]="sudo umount %s"; /*mdirp*/
+ static const char format3[]="rm -f %s/" MOD_NAME " >&/dev/null ; /bin/true";
/*tmpp*/
- static char format4[]="rm -rf %s/{.*,*} >&/dev/null ; /bin/true"; /*cdirp*/
- static char format5[]="rm -rf %s/{.*,*} >&/dev/null ; /bin/true"; /*adirp*/
- static char format6[]="mv -f %s/* -t %s";/*tmpp, adirp*/
- static char format7[]="sudo mount -t $UNIONFS -o dirs=%s=rw:%s=ro"
+ static const char format4[]="rm -rf %s/{.*,*} >&/dev/null ; /bin/true"; /*cdirp*/
+ static const char format5[]="rm -rf %s/{.*,*} >&/dev/null ; /bin/true"; /*adirp*/
+ static const char format6[]="mv -f %s/* -t %s";/*tmpp, adirp*/
+ static const char format7[]="sudo mount -t $UNIONFS -o dirs=%s=rw:%s=ro"
" $UNIONFS %s"; /*cdirp, adirp, mdirp*/
int m_len = strlen(get_mdirp());
int t_len = strlen(get_tmpp());
@@ -1548,40 +1532,34 @@ static int fin_commit(boolean ok)
fprintf(out_stream, "Commit failed\n");
return -1;
}
- command = my_malloc(strlen(format1) + m_len + t_len, "");
+ command = malloc(strlen(format1) + m_len + t_len);
sprintf(command, format1, get_mdirp(), get_tmpp());
system(command);
- my_free(command);
- command = my_malloc(strlen(format2) + m_len, "");
- sprintf(command, format2, get_mdirp());
+ command = realloc(command, strlen(format2) + m_len);
+ sprintf(command, format2, get_mdirp());
system(command);
- my_free(command);
- command = my_malloc(strlen(format3) + t_len, "");
- sprintf(command, format3, get_tmpp());
+ command = realloc(command, strlen(format3) + t_len);
+ sprintf(command, format3, get_tmpp());
system(command);
- my_free(command);
- command = my_malloc(strlen(format4) + c_len, "");
- sprintf(command, format4, get_cdirp());
+ command = realloc(command, strlen(format4) + c_len);
+ sprintf(command, format4, get_cdirp());
system(command);
- my_free(command);
- command = my_malloc(strlen(format5) + a_len, "");
- sprintf(command, format5, get_adirp());
+ command = realloc(command, strlen(format5) + a_len);
+ sprintf(command, format5, get_adirp());
system(command);
- my_free(command);
- command = my_malloc(strlen(format6) + t_len + a_len, "");
- sprintf(command, format6, get_tmpp(), get_adirp());
+ command = realloc(command, strlen(format6) + t_len + a_len);
+ sprintf(command, format6, get_tmpp(), get_adirp());
system(command);
- my_free(command);
- command = my_malloc(strlen(format7) + c_len + a_len + m_len, "");
- sprintf(command, format7, get_cdirp(), get_adirp(), get_mdirp());
+ command = realloc(command, strlen(format7) + c_len + a_len + m_len);
+ sprintf(command, format7, get_cdirp(), get_adirp(), get_mdirp());
system(command);
- my_free(command);
+ free(command);
/* notify other users in config mode */
system("/opt/vyatta/sbin/vyatta-cfg-notify");
diff --git a/src/delete.c b/src/delete.c
index bb2c987..004986d 100644
--- a/src/delete.c
+++ b/src/delete.c
@@ -12,35 +12,35 @@ extern char *cli_operation_name;
static void remove_rf(boolean do_umount)
{
- char *command;
- touch();
- if (do_umount) {
- command = my_malloc(strlen(get_mdirp()) + 20, "delete");
- sprintf(command, "sudo umount %s", get_mdirp());
- system(command);
- free(command);
- }
- command = my_malloc(strlen(m_path.path) + 10, "delete");
- sprintf(command, "rm -rf %s", m_path.path);
+ char *command = NULL;
+ touch();
+ if (do_umount) {
+ command = malloc(strlen(get_mdirp()) + 20);
+ sprintf(command, "sudo umount %s", get_mdirp());
system(command);
- free(command);
- if (do_umount) {
- command = my_malloc(strlen(get_mdirp()) + strlen(get_cdirp()) +
- strlen(get_mdirp()) + 100,
- "delete");
- sprintf(command, "sudo mount -t $UNIONFS -o dirs=%s=rw:%s=ro"
- " $UNIONFS %s", get_cdirp(), get_adirp(), get_mdirp());
- system(command);
- free(command);
- }
+ }
+
+ command = realloc(command, strlen(m_path.path) + 10);
+ sprintf(command, "rm -rf %s", m_path.path);
+ system(command);
+
+ if (do_umount) {
+ command = realloc(command, strlen(get_mdirp()) + strlen(get_cdirp()) +
+ strlen(get_mdirp()) + 100);
+ sprintf(command, "sudo mount -t $UNIONFS -o dirs=%s=rw:%s=ro"
+ " $UNIONFS %s", get_cdirp(), get_adirp(), get_mdirp());
+ system(command);
+ }
+ free(command);
}
+
static boolean has_default(char **def, int size)
{
- char *buf;
- buf = malloc(1025);
char *buf_ptr;
FILE *fp = fopen(t_path.path, "r");
+
if (fp) {
+ char buf[1025];
while (fgets(buf, 1024, fp)) {
if (strncmp(buf, "default:", 8) == 0) {
buf_ptr = index(buf,':');
@@ -53,33 +53,32 @@ static boolean has_default(char **def, int size)
}
memcpy(*def, buf_ptr, strlen(buf_ptr)-1);
fclose(fp);
- free(buf);
return 0;
}
}
fclose(fp);
}
- free(buf);
+
return 1;
}
-static void reset_default(char *def_val)
+
+static void reset_default(const char *def_val)
{
- char *command,*def_cmd;
- boolean has_default = 1;
- if (def_val == NULL) {
+ if (def_val == NULL)
return;
- }
- if (has_default) {
- touch();
- command = my_malloc(strlen(m_path.path) + 100, "set");
- sprintf(command, "echo %s > %s/node.val", def_val, m_path.path);
- system(command);
- def_cmd = malloc(strlen(m_path.path) + 12);
- sprintf(def_cmd, "touch %s/def",m_path.path);
- system(def_cmd);
- free(command);
- free(def_cmd);
- }
+
+ char filename[strlen(m_path.path) + 10];
+ touch();
+ sprintf(filename, "%s/node.val", m_path.path);
+
+ FILE *fp = fopen(filename, "w");
+ if (fp == NULL)
+ bye("can not open: %s", filename);
+ fputs(def_val, fp);
+ fclose(fp);
+
+ sprintf(filename, "%s/def", m_path.path);
+ touch_file(filename);
}
/***************************************************
set_validate:
diff --git a/src/set.c b/src/set.c
index ed43267..195beeb 100644
--- a/src/set.c
+++ b/src/set.c
@@ -12,12 +12,11 @@
extern char *cli_operation_name;
-static void make_dir(void);
static void handle_defaults(void);
static void make_dir()
{
- touch_dir(m_path.path);
+ mkdir_p(m_path.path);
}
/***************************************************
set_validate:
@@ -107,7 +106,6 @@ int main(int argc, char **argv)
FILE *fp;
boolean res;
char *cp;
- char *command;
boolean need_mod = FALSE, not_new = FALSE;
boolean empty_val = FALSE;
@@ -248,11 +246,9 @@ int main(int argc, char **argv)
if (!def.multi) {
- char *path;
- path= malloc(strlen(m_path.path)+5);
+ char path[strlen(m_path.path)+5];
sprintf(path, "%s/def",m_path.path);
unlink(path);
- free(path);
}
push_path(&m_path, VAL_NAME);
@@ -276,9 +272,9 @@ int main(int argc, char **argv)
bye("Error writing file %s", m_path.path);
if (need_mod) {
pop_path(&m_path); /* get rid of "value" */
- command = my_malloc(strlen(m_path.path) + 30, "set");
- sprintf(command, "touch %s/" MOD_NAME, m_path.path);
- system(command);
+ char filename[strlen(m_path.path) + sizeof(MOD_NAME)+1];
+ sprintf(filename, "%s/" MOD_NAME, m_path.path);
+ touch_file(filename);
}
return 0;
}
@@ -359,13 +355,13 @@ handle_default(vtw_path *mpath, vtw_path *tpath, char *exclude)
touch_dir(mpath->path); /* make sure directory exist */
//create def marker
- char *def_file;
- def_file = malloc(strlen(mpath->path)+22);
- sprintf(def_file,"touch %s/def",mpath->path);
- system(def_file);
- sprintf(def_file,"echo 'empty' > %s/def",mpath->path);
- system(def_file);
- free(def_file);
+ char def_file[strlen(mpath->path)+8];
+ sprintf(def_file,"%s/def",mpath->path);
+ fp = fopen(def_file, "w");
+ if (fp == NULL)
+ bye("Can not open def file %s", def_file);
+ fputs("empty\n", fp);
+ fclose(fp);
push_path(mpath, VAL_NAME);
fp = fopen(mpath->path, "w");
diff --git a/templates/interfaces/ethernet/node.def b/templates/interfaces/ethernet/node.def
index 1049f3e..ba15828 100644
--- a/templates/interfaces/ethernet/node.def
+++ b/templates/interfaces/ethernet/node.def
@@ -6,10 +6,10 @@ syntax:expression: exec " \
echo Invalid ethernet interface [$VAR(@)]; \
exit 1 ; \
fi ; "
-update:expression: "sudo ip link set $VAR(@) up" ; "Error enabling dev $VAR(@)"
-update:expression: "${vyatta_sbindir}/vyatta-vtysh.pl -c \"configure terminal\" -c \"interface $VAR(@)\" \
- -c \"link-detect\"; "
-delete:expression: "sudo ip link set $VAR(@) down" ; "Error disabling dev $VAR(@)"
+update: sudo ip link set "$VAR(@)" up
+ vyatta-vtysh -c "configure terminal" \
+ -c "interface $VAR(@)" -c "link-detect"
+delete: sudo ip link set "$VAR(@)" down
allowed: for dev in /sys/class/net/*;
do if [[ -d $dev && -L $dev/device ]]
then if [[ $(cat $dev/type) -eq 1 ]]
diff --git a/templates/interfaces/ethernet/node.tag/address/node.def b/templates/interfaces/ethernet/node.tag/address/node.def
index 0ff02c8..d523793 100644
--- a/templates/interfaces/ethernet/node.tag/address/node.def
+++ b/templates/interfaces/ethernet/node.tag/address/node.def
@@ -7,5 +7,6 @@ delete:expression: "sudo /opt/vyatta/sbin/vyatta-interfaces.pl --eth-addr-delete
allowed: echo "dhcp <>"
comp_help:Possible completions:
<x.x.x.x/x> Set the IP address and prefix length
+ <h:h:h:h:h:h:h:h/x> Set the IPv6 address and prefix length
dhcp Set the IP address and prefix length via DHCP
diff --git a/templates/interfaces/ethernet/node.tag/vif/node.def b/templates/interfaces/ethernet/node.tag/vif/node.def
index 7ee3b50..d37b045 100644
--- a/templates/interfaces/ethernet/node.tag/vif/node.def
+++ b/templates/interfaces/ethernet/node.tag/vif/node.def
@@ -2,12 +2,11 @@ tag:
type: u32
help: Set Virtual Local Area Network (VLAN) ID
syntax:expression: $VAR(@) >= 0 && $VAR(@) <= 4094; "VLAN ID must be between 0 and 4094"
-create:expression: "sudo modprobe 8021q"; "Error loading 802.1q driver"
-create:expression: "sudo vconfig add $VAR(../@) $VAR(@)"; "Error adding VLAN id $VAR(@) to dev $VAR(../@)"
-create:expression: "sudo ip link set $VAR(../@).$VAR(@) up"; "Error enabling VLAN id $VAR(@) on dev $VAR(../@)"
-create:expression: "${vyatta_sbindir}/vyatta-vtysh.pl -c \"configure terminal\"\
- -c \"interface $VAR(../@).$VAR(@)\" \
- -c \"link-detect\"; "
-delete:expression: "sudo vconfig rem $VAR(../@).$VAR(@)"; "Error removing VLAN id $VAR(@) from dev $VAR(../@)"
+create: sudo modprobe 8021q
+ sudo vconfig add "$VAR(../@)" "$VAR(@)"
+ sudo ip link set "$VAR(../@).$VAR(@)" up
+ vyatta-vtysh -c "configure terminal" \
+ -c "interface $VAR(../@).$VAR(@)" -c "link-detect"
+delete: sudo vconfig rem "$VAR(../@).$VAR(@)"
comp_help: possible completions:
<0-4094> Set VLAN ID
diff --git a/templates/interfaces/ethernet/node.tag/vif/node.tag/address/node.def b/templates/interfaces/ethernet/node.tag/vif/node.tag/address/node.def
index cb9cedc..625130a 100644
--- a/templates/interfaces/ethernet/node.tag/vif/node.tag/address/node.def
+++ b/templates/interfaces/ethernet/node.tag/vif/node.tag/address/node.def
@@ -7,4 +7,5 @@ delete:expression: "sudo /opt/vyatta/sbin/vyatta-interfaces.pl --eth-addr-delete
allowed: echo "dhcp <>"
comp_help:Possible completions:
<x.x.x.x/x> Set the IP address and prefix length
+ <h:h:h:h:h:h:h:h/x> Set the IPv6 address and prefix length
dhcp Set the IP address and prefix length via DHCP
diff --git a/templates/interfaces/loopback/node.tag/address/node.def b/templates/interfaces/loopback/node.tag/address/node.def
index 03ead09..9faf664 100644
--- a/templates/interfaces/loopback/node.tag/address/node.def
+++ b/templates/interfaces/loopback/node.tag/address/node.def
@@ -12,3 +12,4 @@ delete:expression: "sudo /opt/vyatta/sbin/vyatta-interfaces.pl --eth-addr-delete
comp_help:Possible completions:
<x.x.x.x/x> Set the IP address and prefix length
+ <h:h:h:h:h:h:h:h/x> Set the IPv6 address and prefix length