summaryrefslogtreecommitdiff
path: root/usr.sbin/hoststated/pfe.c
diff options
context:
space:
mode:
authorPierre-Yves Ritschard <pyr@cvs.openbsd.org>2007-02-06 08:45:47 +0000
committerPierre-Yves Ritschard <pyr@cvs.openbsd.org>2007-02-06 08:45:47 +0000
commit39659b52b3422ff9282ee8e076893e3c3f7f957c (patch)
treea51ff16f67f60c144c5959999003c382e783f755 /usr.sbin/hoststated/pfe.c
parent7179ffad04c7ecffda3812591d161dc659346c3a (diff)
inform hoststatectl monitor of ruleset changes and table syncs.
ok reyk@
Diffstat (limited to 'usr.sbin/hoststated/pfe.c')
-rw-r--r--usr.sbin/hoststated/pfe.c24
1 files changed, 22 insertions, 2 deletions
diff --git a/usr.sbin/hoststated/pfe.c b/usr.sbin/hoststated/pfe.c
index b77b411d82b..5584b5df928 100644
--- a/usr.sbin/hoststated/pfe.c
+++ b/usr.sbin/hoststated/pfe.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pfe.c,v 1.10 2007/02/01 20:03:39 pyr Exp $ */
+/* $OpenBSD: pfe.c,v 1.11 2007/02/06 08:45:46 pyr Exp $ */
/*
* Copyright (c) 2006 Pierre-Yves Ritschard <pyr@spootnik.org>
@@ -497,7 +497,11 @@ pfe_sync(void)
struct service *service;
struct table *active;
int backup;
+ struct ctl_id id;
+ struct imsg imsg;
+ bzero(&id, sizeof(id));
+ bzero(&imsg, sizeof(imsg));
TAILQ_FOREACH(service, &env->services, entry) {
backup = (service->flags & F_BACKUP);
service->flags &= ~(F_BACKUP);
@@ -515,8 +519,14 @@ pfe_sync(void)
} else
active = service->table;
- if (active != NULL && active->flags & F_CHANGED)
+ if (active != NULL && active->flags & F_CHANGED) {
+ id.id = active->id;
+ imsg.hdr.type = IMSG_CTL_TABLE_CHANGED;
+ imsg.hdr.len = sizeof(id) + IMSG_HEADER_SIZE;
+ imsg.data = &id;
sync_table(env, service, active);
+ control_imsg_forward(&imsg);
+ }
service->table->flags &= ~(F_CHANGED);
service->backup->flags &= ~(F_CHANGED);
@@ -526,12 +536,22 @@ pfe_sync(void)
flush_table(env, service);
log_debug("pfe_sync: disabling ruleset");
service->flags &= ~(F_ACTIVE_RULESET);
+ id.id = service->id;
+ imsg.hdr.type = IMSG_CTL_PULL_RULESET;
+ imsg.hdr.len = sizeof(id) + IMSG_HEADER_SIZE;
+ imsg.data = &id;
sync_ruleset(env, service, 0);
+ control_imsg_forward(&imsg);
}
} else if (!(service->flags & F_ACTIVE_RULESET)) {
log_debug("pfe_sync: enabling ruleset");
service->flags |= F_ACTIVE_RULESET;
+ id.id = service->id;
+ imsg.hdr.type = IMSG_CTL_PUSH_RULESET;
+ imsg.hdr.len = sizeof(id) + IMSG_HEADER_SIZE;
+ imsg.data = &id;
sync_ruleset(env, service, 1);
+ control_imsg_forward(&imsg);
}
}
}