/* -*-c-*-
*
- * $Id: rule.c,v 1.5 1998/01/12 16:46:25 mdw Exp $
+ * $Id: rule.c,v 1.7 2003/10/12 00:14:55 mdw Exp $
*
* Managing rule sets
*
/*----- Revision history --------------------------------------------------*
*
* $Log: rule.c,v $
+ * Revision 1.7 2003/10/12 00:14:55 mdw
+ * Major overhaul. Now uses DSA signatures rather than the bogus symmetric
+ * encrypt-and-hope thing. Integrated with mLib and Catacomb.
+ *
+ * Revision 1.6 1998/04/23 13:27:31 mdw
+ * Export structure of the rule list, for `bcquery's benefit.
+ *
* Revision 1.5 1998/01/12 16:46:25 mdw
* Fix copyright date.
*
#include <netdb.h>
#include <unistd.h>
+/* --- mLib headers --- */
+
+#include <mLib/alloc.h>
+#include <mLib/report.h>
+#include <mLib/trace.h>
+
/* --- Local headers --- */
#include "become.h"
#include "class.h"
#include "rule.h"
#include "userdb.h"
-#include "utils.h"
-
-/*----- Type definitions --------------------------------------------------*/
-
-/* --- Rule block --- */
-
-typedef struct rule {
- struct rule *next; /* Next rule in the list */
- class_node *host; /* Hosts this rule applies to */
- class_node *from; /* From users in this class */
- class_node *to; /* To users in this class */
- class_node *cmd; /* To run commands in this class */
-} rule;
/*----- Static variables --------------------------------------------------*/
}
}
+/* --- @rule_list@ --- *
+ *
+ * Arguments: ---
+ *
+ * Returns: The list of rules.
+ *
+ * Use: Returns the address of the first node in the rule list.
+ */
+
+rule *rule_list(void)
+{
+ return (rule__list);
+}
+
/* --- @rule_add@ --- *
*
* Arguments: @class_node *host@ = class of hosts this rule applies to
* Use: Registers another rule.
*/
-void rule_add(class_node *host, class_node *from, class_node *to, class_node *cmd)
+void rule_add(class_node *host, class_node *from,
+ class_node *to, class_node *cmd)
{
rule *r = xmalloc(sizeof(*r));