along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- $Id: graph.c,v 1.1.2.13 2002/06/21 10:11:12 guus Exp $
+ $Id: graph.c,v 1.1.2.14 2002/07/10 11:27:06 guus Exp $
*/
/* We need to generate two trees from the graph:
#include "edge.h"
#include "connection.h"
#include "process.h"
+#include "device.h"
#include "system.h"
avl_tree_t *todo_tree;
int indirect;
char *name;
+ char *address, *port;
+ char *envp[7];
+ int i;
todo_tree = avl_alloc_tree(NULL, NULL);
next = node->next;
n = (node_t *)node->data;
- if(n->status.visited)
+ if(n->status.visited ^ n->status.reachable)
{
- if(!n->status.reachable)
- {
- if(debug_lvl >= DEBUG_TRAFFIC)
+ n->status.reachable = !n->status.reachable;
+ if(debug_lvl >= DEBUG_TRAFFIC)
+ if(n->status.reachable)
syslog(LOG_DEBUG, _("Node %s (%s) became reachable"), n->name, n->hostname);
- n->status.reachable = 1;
- asprintf(&name, "hosts/%s-up", n->name);
- execute_script(name);
- free(name);
- }
- }
- else
- {
- if(n->status.reachable)
- {
- if(debug_lvl >= DEBUG_TRAFFIC)
- syslog(LOG_DEBUG, _("Node %s (%s) became unreachable"), n->name, n->hostname);
- n->status.reachable = 0;
- n->status.validkey = 0;
- n->status.waitingforkey = 0;
- n->sent_seqno = 0;
- asprintf(&name, "hosts/%s-down", n->name);
- execute_script(name);
- free(name);
- }
+ else
+ syslog(LOG_DEBUG, _("Node %s (%s) became unreachable"), n->name, n->hostname);
+
+ if(!n->status.reachable)
+ {
+ n->status.reachable = 0;
+ n->status.validkey = 0;
+ n->status.waitingforkey = 0;
+ n->sent_seqno = 0;
+ }
+
+ asprintf(&envp[0], "NETNAME=%s", netname?netname:"");
+ asprintf(&envp[1], "DEVICE=%s", device?device:"");
+ asprintf(&envp[2], "INTERFACE=%s", interface?interface:"");
+ asprintf(&envp[3], "NODE=%s", n->name);
+ sockaddr2str(&n->address, &address, &port);
+ asprintf(&envp[4], "REMOTEADDRESS=%s", address);
+ asprintf(&envp[5], "REMOTEPORT=%s", port);
+ envp[6] = NULL;
+
+ asprintf(&name, n->status.reachable?"hosts/%s-up":"hosts/%s-down", n->name);
+ execute_script(name, envp);
+ free(name);
+ free(address);
+ free(port);
+
+ for(i = 0; i < 7; i++)
+ free(envp[i]);
}
}
}
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- $Id: net_setup.c,v 1.1.2.20 2002/06/21 10:11:12 guus Exp $
+ $Id: net_setup.c,v 1.1.2.21 2002/07/10 11:27:06 guus Exp $
*/
#include "config.h"
*/
int setup_network_connections(void)
{
+ char *envp[4];
+ int i;
cp
now = time(NULL);
return -1;
/* Run tinc-up script to further initialize the tap interface */
- execute_script("tinc-up");
+ asprintf(&envp[0], "NETNAME=%s", netname?netname:"");
+ asprintf(&envp[1], "DEVICE=%s", device?device:"");
+ asprintf(&envp[2], "INTERFACE=%s", interface?interface:"");
+ envp[3] = NULL;
+
+ execute_script("tinc-up", envp);
+
+ for(i = 0; i < 4; i++)
+ free(envp[i]);
if(setup_myself() < 0)
return -1;
{
avl_node_t *node, *next;
connection_t *c;
+ char *envp[4];
int i;
cp
for(node = connection_tree->head; node; node = next)
exit_nodes();
exit_connections();
- execute_script("tinc-down");
+ asprintf(&envp[0], "NETNAME=%s", netname?netname:"");
+ asprintf(&envp[1], "DEVICE=%s", device?device:"");
+ asprintf(&envp[2], "INTERFACE=%s", interface?interface:"");
+ envp[3] = NULL;
+
+ execute_script("tinc-down", envp);
+
+ for(i = 0; i < 4; i++)
+ free(envp[i]);
close_device();
cp
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- $Id: process.c,v 1.1.2.41 2002/06/21 10:11:13 guus Exp $
+ $Id: process.c,v 1.1.2.42 2002/07/10 11:27:06 guus Exp $
*/
#include "config.h"
Execute the program name, with sane environment. All output will be
redirected to syslog.
*/
-void _execute_script(const char *scriptname) __attribute__ ((noreturn));
-void _execute_script(const char *scriptname)
+void _execute_script(const char *scriptname, char **envp) __attribute__ ((noreturn));
+void _execute_script(const char *scriptname, char **envp)
{
char *s;
cp
-#ifdef HAVE_UNSETENV
- unsetenv("NETNAME");
- unsetenv("DEVICE");
- unsetenv("INTERFACE");
-#endif
-
- if(netname)
- {
- asprintf(&s, "NETNAME=%s", netname);
- putenv(s); /* Don't free s! see man 3 putenv */
- }
-
- if(device)
- {
- asprintf(&s, "DEVICE=%s", device);
- putenv(s); /* Don't free s! see man 3 putenv */
- }
-
- if(interface)
- {
- asprintf(&s, "INTERFACE=%s", interface);
- putenv(s); /* Don't free s! see man 3 putenv */
- }
-
+ while(*envp)
+ putenv(*envp++);
+
chdir("/");
/* Close all file descriptors */
/*
Fork and execute the program pointed to by name.
*/
-int execute_script(const char *name)
+int execute_script(const char *name, char **envp)
{
pid_t pid;
int status;
cp
/* Child here */
- _execute_script(scriptname);
+ _execute_script(scriptname, envp);
}
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- $Id: process.h,v 1.1.2.11 2002/06/21 10:11:13 guus Exp $
+ $Id: process.h,v 1.1.2.12 2002/07/10 11:27:06 guus Exp $
*/
#ifndef __TINC_PROCESS_H__
extern int do_detach;
extern void setup_signals(void);
-extern int execute_script(const char *);
+extern int execute_script(const char *, char **);
extern int detach(void);
extern int kill_other(int);
extern void cleanup_and_exit(int);