summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorslioch <slioch@eng-140.vyatta.com>2009-06-26 15:05:48 -0700
committerslioch <slioch@eng-140.vyatta.com>2009-06-26 15:05:48 -0700
commitd034ac00df12e6c33e8fe0d42a057d1dad16967d (patch)
tree8767d601f68c42793c5694091cf772dc0bfcd8eb
parentaa0909474d754d7a4295c02151ea92d3b31f22e9 (diff)
downloadvyatta-cfg-d034ac00df12e6c33e8fe0d42a057d1dad16967d.tar.gz
vyatta-cfg-d034ac00df12e6c33e8fe0d42a057d1dad16967d.zip
The SYNTAX and COMMIT tags will be executed before an actions (UPDATE,
CREATE, DELETE, END, BEGIN) within a priority tree. That means that all work (include the commit-check pass) will be performed on a priority tree before proceeding to the next priority tree. If a priority tree generates a failure in the commit-check pass processing will halt on the priority tree and no further processing will be performed on the priority tree. The failed priority tree will NOT be copied to the active working directory. All nodes in the priority tree will execute SYNTAX and COMMIT actions except for nodes that have been deleted. Note this iteration is performed on the working tree, so all commit-check nodes will either be directly modified or have a node down the hierarchy that had been modified. The working directory and active directory will not be modified until after all priority trees have been processed.
-rw-r--r--src/commit2.c79
-rw-r--r--src/common/defs.h1
2 files changed, 67 insertions, 13 deletions
diff --git a/src/commit2.c b/src/commit2.c
index 7f08e0b..63ccc33 100644
--- a/src/commit2.c
+++ b/src/commit2.c
@@ -172,16 +172,6 @@ main(int argc, char** argv)
return 0;
}
-
- if (g_dump_trans == FALSE) { //DISABLE VALIDATION ON TREE DUMP
- set_in_commit(TRUE);
- // Perform syntax and commit check on tree
- if (validate_configuration(config_data, full_commit_check) == FALSE) {
- fprintf(out_stream, "Commit failed\n");
- return 0;
- }
- }
-
GNode *orig_node_tree = g_node_copy(config_data);
// Get collection of transactions, i.e. trans nodes that have been activated.
@@ -208,17 +198,28 @@ main(int argc, char** argv)
}
}
+ set_in_commit(TRUE);
+
GNode *trans_child_node = (GNode*)g_node_first_child(trans_coll);
if (trans_child_node == NULL) {
printf("commit2: No child nodes to process, exiting\n");
exit(0);
}
+ //open the changes file and clear
+ FILE *fp_changes = fopen("/tmp/.changes","w");
+ if (fp_changes == NULL) {
+ printf("commit2: Cannot access changes file, exiting\n");
+ syslog(LOG_ERR,"commit2: Cannot access changes file, exiting");
+ exit(0);
+ }
+
GSList *completed_root_node_coll = NULL;
+ GSList *nodes_visited_coll = NULL;
boolean no_errors = TRUE;
int i = 0;
do {
- boolean success = TRUE;
+ boolean success = FALSE;
if (g_debug == TRUE) {
if (trans_child_node != NULL && trans_child_node->data != NULL && ((struct VyattaNode*)(trans_child_node->data))->_data._name != NULL) {
printf("commit2: Starting new transaction processing pass on root: %s\n", ((struct VyattaNode*)(trans_child_node->data))->_data._name);
@@ -238,7 +239,9 @@ main(int argc, char** argv)
}
//on each priority node now execute actions
- if ((success = process_priority_node(trans_child_node)) == TRUE) {
+
+ nodes_visited_coll = NULL;
+ if ((validate_configuration(trans_child_node, full_commit_check, &nodes_visited_coll) == TRUE) && (success = process_priority_node(trans_child_node)) == TRUE) {
//this below copies the node directory from the local to active location
//if this is true root skip
if (trans_child_node != NULL && trans_child_node->data != NULL && strcmp(((struct VyattaNode*)(trans_child_node->data))->_data._path,"/") == 0) {
@@ -263,6 +266,10 @@ main(int argc, char** argv)
syslog(LOG_DEBUG,"commit2: Failed in processing node\n");
}
}
+
+ //now update the changes file
+ update_change_file(fp_changes,nodes_visited_coll);
+
++i;
} while ((trans_child_node = (GNode*)g_node_nth_child((GNode*)trans_coll,(guint)i)) != NULL);
@@ -297,6 +304,9 @@ main(int argc, char** argv)
syslog(LOG_DEBUG,"DONE");
}
+ if (fp_changes != NULL) {
+ fclose(fp_changes);
+ }
exit (no_errors == FALSE);
}
@@ -907,7 +917,7 @@ enclosing_process_func(GNode *node, gpointer data)
*
**/
boolean
-validate_configuration(GNode *root_node, boolean mode)
+validate_configuration(GNode *root_node, boolean mode, GSList **nodes_visited_coll)
{
if (root_node == NULL) {
return FALSE;
@@ -916,6 +926,7 @@ validate_configuration(GNode *root_node, boolean mode)
struct Result result;
result._err_code = 0;
result._mode = (int)mode;
+ result._data = (void*)nodes_visited_coll;
//handles both syntax and commit
result._action = syntax_act;
@@ -933,6 +944,9 @@ validate_configuration(GNode *root_node, boolean mode)
}
return FALSE;
}
+
+ GList **c_tmp = (GList**)result._data;
+ *nodes_visited_coll = (GSList*)*c_tmp;
return TRUE;
}
@@ -952,6 +966,23 @@ validate_func(GNode *node, gpointer data)
struct Config *c = &((struct VyattaNode*)gp)->_config;
struct Data *d = &((struct VyattaNode*)gp)->_data;
struct Result *result = (struct Result*)data;
+
+ //since this visits all working nodes, let's maintain a set of nodes to commit
+ GList **c_tmp = (GList**)result->_data;
+ GList *coll = *c_tmp;
+ if (d->_path != NULL) {
+ char *buf = malloc(MAX_LENGTH_DIR_PATH*sizeof(char));
+ if (IS_DELETE(d->_operation)) {
+ sprintf(buf,"- %s",d->_path);
+ coll = g_slist_append(coll,buf);
+ result->_data = (void*)&coll;
+ }
+ else if (IS_SET_OR_CREATE(d->_operation)) {
+ sprintf(buf,"+ %s",d->_path);
+ coll = g_slist_append(coll,buf);
+ result->_data = (void*)&coll;
+ }
+ }
if (IS_DELETE(d->_operation)) {
return FALSE; //will not perform validation checks on deleted nodes
@@ -1034,3 +1065,25 @@ validate_func(GNode *node, gpointer data)
}
return FALSE;
}
+
+/**
+ *
+ *
+ **/
+void
+update_change_file(FILE *fp, GSList *coll)
+{
+ if (coll == NULL || fp == NULL) {
+ return;
+ }
+ GSList *l;
+ for (l = coll; l; l = g_slist_next (l)) {
+ if (l->data) {
+ char buf[MAX_LENGTH_DIR_PATH*sizeof(char)];
+ sprintf(buf,"%s\n",(char*)l->data);
+ fwrite(buf,1,strlen((char*)buf),fp);
+ free(l->data);
+ }
+ }
+ g_slist_free(coll);
+}
diff --git a/src/common/defs.h b/src/common/defs.h
index f2cf3a1..5d6b0a8 100644
--- a/src/common/defs.h
+++ b/src/common/defs.h
@@ -22,6 +22,7 @@ struct Result
char *_err_str;
int _action;
int _mode;
+ void* _data;
};
typedef enum {