summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'sys-apps/gradm/files/gradm2-cvs-20Jun2004.diff')
-rw-r--r--sys-apps/gradm/files/gradm2-cvs-20Jun2004.diff230
1 files changed, 230 insertions, 0 deletions
diff --git a/sys-apps/gradm/files/gradm2-cvs-20Jun2004.diff b/sys-apps/gradm/files/gradm2-cvs-20Jun2004.diff
new file mode 100644
index 000000000000..0ba07710003e
--- /dev/null
+++ b/sys-apps/gradm/files/gradm2-cvs-20Jun2004.diff
@@ -0,0 +1,230 @@
+diff -Naupr gradm2-release/Makefile gradm2-cvs-20Jun2004/Makefile
+--- gradm2-release/Makefile 2004-04-03 23:19:40.000000000 -0600
++++ gradm2-cvs-20Jun2004/Makefile 2004-06-17 20:51:29.000000000 -0500
+@@ -23,9 +23,8 @@ STRIP=/usr/bin/strip
+ #LIBS=
+ LIBS=-lfl
+ KERNVER=`uname -r | cut -d"." -f 2`
+-#for sparc64
+-#OPT_FLAGS=-O2 -m64 -mcpu=ultrasparc -mcmodel=medlow -ffixed-g4 \
+-# -fcall-used-g5 -fcall-used-g5 -fcall-used-g7 -Wno-sign-compare
++#for 64-bit archs
++#OPT_FLAGS=-O2 -m64
+ OPT_FLAGS=-O2
+ CFLAGS=$(OPT_FLAGS) -DGRSEC_DIR=\"$(GRSEC_DIR)\" -DKERNVER=$(KERNVER)
+ LDFLAGS=
+diff -Naupr gradm2-release/gradm_analyze.c gradm2-cvs-20Jun2004/gradm_analyze.c
+--- gradm2-release/gradm_analyze.c 2004-03-02 14:42:31.000000000 -0600
++++ gradm2-cvs-20Jun2004/gradm_analyze.c 2004-05-31 10:03:56.000000000 -0500
+@@ -319,9 +319,22 @@ analyze_acls(void)
+ struct chk_perm chk;
+ unsigned int errs_found = 0;
+ struct role_acl *role;
++ int def_role_found = 0;
+
+ check_role_transitions();
+
++ for_each_role(role, current_role)
++ if (role->roletype & GR_ROLE_DEFAULT)
++ def_role_found = 1;
++
++ if (!def_role_found) {
++ fprintf(stderr, "There is no default role present in your "
++ "configuration.\nPlease read the RBAC "
++ "documentation and create a default role before "
++ "attempting to enable the RBAC system.\n\n");
++ exit(EXIT_FAILURE);
++ }
++
+ for_each_role(role, current_role) {
+ if (role->roletype & GR_ROLE_SPECIAL)
+ continue;
+diff -Naupr gradm2-release/gradm_arg.c gradm2-cvs-20Jun2004/gradm_arg.c
+--- gradm2-release/gradm_arg.c 2004-04-03 10:22:56.000000000 -0600
++++ gradm2-cvs-20Jun2004/gradm_arg.c 2004-06-12 04:04:36.000000000 -0500
+@@ -140,9 +140,8 @@ parse_args(int argc, char *argv[])
+ show_help();
+ entry.mode = GRADM_UNSPROLE;
+ check_acl_status(entry.mode);
+- get_user_passwd(&entry, GR_PWONLY);
+ grarg = conv_user_to_kernel(&entry);
+- transmit_to_kernel(grarg, sizeof (struct gr_arg));
++ transmit_to_kernel(grarg);
+ memset(grarg, 0, sizeof (struct gr_arg));
+ break;
+ case 'R':
+@@ -157,7 +156,7 @@ parse_args(int argc, char *argv[])
+ grarg = conv_user_to_kernel(&entry);
+ read_saltandpass(entry.rolename, grarg->salt,
+ grarg->sum);
+- transmit_to_kernel(grarg, sizeof (struct gr_arg));
++ transmit_to_kernel(grarg);
+ memset(grarg, 0, sizeof (struct gr_arg));
+ break;
+ case 'M':
+@@ -174,7 +173,7 @@ parse_args(int argc, char *argv[])
+ conv_name_to_num(optarg, &entry.segv_dev,
+ &entry.segv_inode);
+ grarg = conv_user_to_kernel(&entry);
+- transmit_to_kernel(grarg, sizeof (struct gr_arg));
++ transmit_to_kernel(grarg);
+ memset(grarg, 0, sizeof (struct gr_arg));
+ exit(EXIT_SUCCESS);
+ break;
+@@ -185,7 +184,7 @@ parse_args(int argc, char *argv[])
+ check_acl_status(entry.mode);
+ get_user_passwd(&entry, GR_PWONLY);
+ grarg = conv_user_to_kernel(&entry);
+- if (transmit_to_kernel(grarg, sizeof (struct gr_arg)))
++ if (transmit_to_kernel(grarg))
+ memset(grarg, 0, sizeof (struct gr_arg));
+ else {
+ memset(grarg, 0, sizeof (struct gr_arg));
+@@ -246,7 +245,7 @@ parse_args(int argc, char *argv[])
+ check_acl_status(entry.mode);
+ get_user_passwd(&entry, GR_PWONLY);
+ grarg = conv_user_to_kernel(&entry);
+- transmit_to_kernel(grarg, sizeof (struct gr_arg));
++ transmit_to_kernel(grarg);
+ memset(grarg, 0, sizeof (struct gr_arg));
+ exit(EXIT_SUCCESS);
+ break;
+@@ -258,7 +257,7 @@ parse_args(int argc, char *argv[])
+ entry.mode = GRADM_SPROLE;
+ check_acl_status(entry.mode);
+ grarg = conv_user_to_kernel(&entry);
+- transmit_to_kernel(grarg, sizeof (struct gr_arg));
++ transmit_to_kernel(grarg);
+ memset(grarg, 0, sizeof (struct gr_arg));
+ exit(EXIT_SUCCESS);
+ break;
+@@ -298,7 +297,7 @@ parse_args(int argc, char *argv[])
+ grarg = conv_user_to_kernel(&entry);
+ read_saltandpass(entry.rolename, grarg->salt,
+ grarg->sum);
+- transmit_to_kernel(grarg, sizeof (struct gr_arg));
++ transmit_to_kernel(grarg);
+ memset(grarg, 0, sizeof (struct gr_arg));
+ } else if (gr_learn && gr_output) {
+ FILE *stream;
+diff -Naupr gradm2-release/gradm_func.h gradm2-cvs-20Jun2004/gradm_func.h
+--- gradm2-release/gradm_func.h 2004-03-30 19:20:18.000000000 -0600
++++ gradm2-cvs-20Jun2004/gradm_func.h 2004-06-17 20:50:57.000000000 -0500
+@@ -1,7 +1,7 @@
+ void yyerror(const char *s);
+ FILE *open_acl_file(const char *filename);
+ void get_user_passwd(struct gr_pw_entry *entry, int mode);
+-int transmit_to_kernel(void *buf, unsigned long len);
++int transmit_to_kernel(struct gr_arg *buf);
+ void generate_salt(struct gr_pw_entry *entry);
+ void write_user_passwd(struct gr_pw_entry *entry);
+ void parse_acls(void);
+@@ -126,3 +126,4 @@ void gr_dyn_free(void *addr);
+ void insert_acl_object(struct proc_acl *subject, struct file_acl *object);
+ void insert_acl_subject(struct role_acl *role, struct proc_acl *subject);
+
++void insert_nested_acl_subject(struct proc_acl *subject);
+diff -Naupr gradm2-release/gradm_lib.c gradm2-cvs-20Jun2004/gradm_lib.c
+--- gradm2-release/gradm_lib.c 2004-03-07 18:22:09.000000000 -0600
++++ gradm2-cvs-20Jun2004/gradm_lib.c 2004-06-17 20:50:57.000000000 -0500
+@@ -554,3 +554,8 @@ void insert_acl_subject(struct role_acl
+ return;
+ }
+
++void insert_nested_acl_subject(struct proc_acl *subject)
++{
++ subject->hash = create_hash_table(GR_HASH_OBJECT);
++ return;
++}
+diff -Naupr gradm2-release/gradm_misc.c gradm2-cvs-20Jun2004/gradm_misc.c
+--- gradm2-release/gradm_misc.c 2004-03-09 19:45:17.000000000 -0600
++++ gradm2-cvs-20Jun2004/gradm_misc.c 2004-06-12 23:12:04.000000000 -0500
+@@ -14,17 +14,18 @@ open_acl_file(const char *filename)
+ }
+
+ int
+-transmit_to_kernel(void *buf, unsigned long len)
++transmit_to_kernel(struct gr_arg *buf)
+ {
+ int fd;
+ int err = 0;
++ void *pbuf = buf;
+
+ if ((fd = open(GRDEV_PATH, O_WRONLY)) < 0) {
+ fprintf(stderr, "Could not open %s.\n", GRDEV_PATH);
+ failure("open");
+ }
+
+- if (write(fd, buf, len) != len) {
++ if (write(fd, &pbuf, sizeof(struct gr_arg *)) != sizeof(struct gr_arg *)) {
+ err = 1;
+ switch (errno) {
+ case EFAULT:
+@@ -65,6 +66,7 @@ void check_acl_status(__u16 reqmode)
+ int fd;
+ int retval;
+ struct gr_arg arg;
++ struct gr_arg *parg = &arg;
+
+ arg.mode = GRADM_STATUS;
+
+@@ -73,7 +75,7 @@ void check_acl_status(__u16 reqmode)
+ failure("open");
+ }
+
+- retval = write(fd, &arg, sizeof(arg));
++ retval = write(fd, &parg, sizeof(struct gr_arg *));
+ close(fd);
+
+ switch (reqmode) {
+diff -Naupr gradm2-release/gradm_newlearn.c gradm2-cvs-20Jun2004/gradm_newlearn.c
+--- gradm2-release/gradm_newlearn.c 2004-04-06 14:09:33.000000000 -0500
++++ gradm2-cvs-20Jun2004/gradm_newlearn.c 2004-06-17 21:50:20.000000000 -0500
+@@ -1652,7 +1652,10 @@ insert_learn_role(struct gr_learn_role_e
+ (*((*role_list) + num)) = (struct gr_learn_role_entry *)gr_stat_alloc(sizeof(struct gr_learn_role_entry));
+ (*((*role_list) + num))->rolename = rolename;
+ (*((*role_list) + num))->rolemode = rolemode;
+-
++
++ /* give every learned role a / subject */
++ insert_learn_role_subject(*((*role_list) + num), conv_filename_to_struct("/", GR_FIND));
++
+ return (*((*role_list) + num));
+ }
+
+diff -Naupr gradm2-release/gradm_opt.c gradm2-cvs-20Jun2004/gradm_opt.c
+--- gradm2-release/gradm_opt.c 2004-03-30 19:20:18.000000000 -0600
++++ gradm2-cvs-20Jun2004/gradm_opt.c 2004-05-08 14:26:47.000000000 -0500
+@@ -10,11 +10,10 @@ expand_acl(struct proc_acl *proc, struct
+ strcpy(tmpproc, proc->filename);
+
+ while (parent_dir(proc->filename, &tmpproc)) {
+- for_each_subject(tmpp, role) {
+- if (!strcmp(tmpproc, tmpp->filename)) {
+- proc->parent_subject = tmpp;
+- return;
+- }
++ tmpp = lookup_acl_subject_by_name(role, tmpproc);
++ if (tmpp) {
++ proc->parent_subject = tmpp;
++ return;
+ }
+ }
+
+diff -Naupr gradm2-release/gradm_parse.c gradm2-cvs-20Jun2004/gradm_parse.c
+--- gradm2-release/gradm_parse.c 2004-04-03 11:18:11.000000000 -0600
++++ gradm2-cvs-20Jun2004/gradm_parse.c 2004-06-17 20:50:57.000000000 -0500
+@@ -565,7 +565,12 @@ add_proc_subject_acl(struct role_acl *ro
+ return 0;
+ }
+
+- insert_acl_subject(role, p);
++ /* don't insert nested subjects into main hash */
++ if (!(flag & GR_FFAKE))
++ insert_acl_subject(role, p);
++ else
++ insert_nested_acl_subject(p);
++
+ current_subject = p;
+
+ return 1;