diff options
-rw-r--r-- | debian/control | 3 | ||||
-rw-r--r-- | debian/vyatta-cfg.postinst.in | 4 | ||||
-rwxr-xr-x | etc/bash_completion.d/20vyatta-cfg | 2 | ||||
-rw-r--r-- | etc/default/vyatta-cfg | 1 | ||||
-rwxr-xr-x | scripts/VyattaMisc.pm | 27 | ||||
-rw-r--r-- | scripts/vyatta-interfaces.pl | 51 | ||||
-rwxr-xr-x | scripts/vyatta-load-config.pl | 2 | ||||
-rw-r--r-- | src/cli_new.c | 148 | ||||
-rw-r--r-- | src/cli_path_utils.c | 1 | ||||
-rw-r--r-- | src/cli_val.h | 41 | ||||
-rw-r--r-- | src/commit.c | 126 | ||||
-rw-r--r-- | src/delete.c | 79 | ||||
-rw-r--r-- | src/set.c | 28 | ||||
-rw-r--r-- | templates/interfaces/ethernet/node.def | 8 | ||||
-rw-r--r-- | templates/interfaces/ethernet/node.tag/address/node.def | 1 | ||||
-rw-r--r-- | templates/interfaces/ethernet/node.tag/vif/node.def | 13 | ||||
-rw-r--r-- | templates/interfaces/ethernet/node.tag/vif/node.tag/address/node.def | 1 | ||||
-rw-r--r-- | templates/interfaces/loopback/node.tag/address/node.def | 1 |
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: @@ -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 |