Fixed chmod and friends.
diff --git a/chmod_chown_chgrp.c b/chmod_chown_chgrp.c
index e760500..faebbbe 100644
--- a/chmod_chown_chgrp.c
+++ b/chmod_chown_chgrp.c
@@ -25,8 +25,8 @@
#include "internal.h"
-static int uid=-1;
-static int gid=0;
+static uid_t uid=-1;
+static gid_t gid=-1;
static int whichApp;
static char* invocationName=NULL;
static mode_t mode=0644;
@@ -48,18 +48,70 @@
"\t-R\tchange files and directories recursively.\n";
+uid_t my_getid(const char *filename, const char *name)
+{
+ FILE *stream;
+ char *rname, *start, *end, buf[128];
+ uid_t rid;
+
+ stream=fopen(filename,"r");
+
+ while (fgets (buf, 128, stream) != NULL) {
+ if (buf[0] == '#')
+ continue;
+
+ start = buf;
+ end = strchr (start, ':');
+ if (end == NULL)
+ continue;
+ *end = '\0';
+ rname = start;
+
+ start = end + 1;
+ end = strchr (start, ':');
+ if (end == NULL)
+ continue;
+
+ start = end + 1;
+ rid = (uid_t) strtol (start, &end, 10);
+ if (end == start)
+ continue;
+
+ if (name) {
+ if (0 == strcmp(rname, name))
+ return( rid);
+ }
+ }
+ fclose(stream);
+ return (-1);
+}
+
+uid_t
+my_getpwnam(char *name)
+{
+ return my_getid("/etc/passwd", name);
+}
+
+gid_t
+my_getgrnam(char *name)
+{
+ return my_getid("/etc/group", name);
+}
static int fileAction(const char *fileName, struct stat* statbuf)
{
switch (whichApp) {
case CHGRP_APP:
case CHOWN_APP:
- if (chown(fileName, ((whichApp==CHOWN_APP)? uid: statbuf->st_uid), gid) < 0)
+ if (chown(fileName, (whichApp==CHOWN_APP)? uid : statbuf->st_uid,
+ (gid==-1)? statbuf->st_gid : gid) == 0) {
return( TRUE);
+ }
+ break;
case CHMOD_APP:
- fprintf(stderr, "%s, %d\n", fileName, mode);
- if (chmod(fileName, mode))
+ if (chmod(fileName, mode) == 0)
return( TRUE);
+ break;
}
perror(fileName);
return( FALSE);
@@ -67,8 +119,6 @@
int chmod_chown_chgrp_main(int argc, char **argv)
{
- struct group *grp;
- struct passwd *pwd;
int recursiveFlag=FALSE;
char *groupName;
@@ -104,31 +154,33 @@
fprintf(stderr, "%s: Unknown mode: %s\n", invocationName, *argv);
exit( FALSE);
}
- //mode &= andWithMode;
- fprintf(stderr, "mode %d\n", mode);
} else {
/* Find the selected group */
- groupName = strchr(*argv, '.');
- if ( whichApp==TRUE && groupName )
- *groupName++ = '\0';
- else
+ if ( whichApp==CHGRP_APP && groupName ) {
groupName = *argv;
- grp = getgrnam(groupName);
- if (grp == NULL) {
- fprintf(stderr, "%s: Unknown group name: %s\n", invocationName, groupName);
- exit( FALSE);
+ gid = my_getgrnam(groupName);
+ if (gid == -1)
+ goto bad_group;
+ } else {
+ groupName = strchr(*argv, '.');
+ if (groupName) {
+ *groupName++ = '\0';
+ gid = my_getgrnam(groupName);
+ if (gid == -1)
+ goto bad_group;
+ } else
+ gid = -1;
}
- gid = grp->gr_gid;
+
/* Find the selected user (if appropriate) */
- if (whichApp==TRUE) {
- pwd = getpwnam(*argv);
- if (pwd == NULL) {
+ if (whichApp==CHOWN_APP) {
+ uid = my_getpwnam(*argv);
+ if (uid == -1) {
fprintf(stderr, "%s: Unknown user name: %s\n", invocationName, *argv);
exit( FALSE);
}
- uid = pwd->pw_uid;
}
}
@@ -142,173 +194,10 @@
exit( FALSE);
}
exit(TRUE);
+
+bad_group:
+ fprintf(stderr, "%s: Unknown group name: %s\n", invocationName, groupName);
+ exit( FALSE);
}
-
-
-
-
-
-
-
-
-
-
-#ifdef fooo
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-#include "internal.h"
-#include <pwd.h>
-#include <grp.h>
-#include <string.h>
-#include <stdio.h>
-
-int my_getid(const char *filename, const char *name, uid_t *id)
-{
- FILE *stream;
- uid_t rid;
- char *rname, *start, *end, buf[128];
-
- stream=fopen(filename,"r");
-
- while (fgets (buf, 128, stream) != NULL) {
- if (buf[0] == '#')
- continue;
-
- start = buf;
- end = strchr (start, ':');
- if (end == NULL)
- continue;
- *end = '\0';
- rname = start;
-
- start = end + 1;
- end = strchr (start, ':');
- if (end == NULL)
- continue;
-
- start = end + 1;
- rid = (uid_t) strtol (start, &end, 10);
- if (end == start)
- continue;
-
- if (name) {
- if (0 == strcmp(rname, name)) {
- *id=rid;
- return 0;
- }
- } else {
- if ( *id == rid )
- return 0;
- }
- }
- fclose(stream);
- return -1;
-}
-
-int
-my_getpwuid(uid_t *uid)
-{
- return my_getid("/etc/passwd", NULL, uid);
-}
-
-int
-my_getpwnam(char *name, uid_t *uid)
-{
- return my_getid("/etc/passwd", name, uid);
-}
-
-int
-my_getgrgid(gid_t *gid)
-{
- return my_getid("/etc/group", NULL, gid);
-}
-
-int
-my_getgrnam(char *name, gid_t *gid)
-{
- return my_getid("/etc/group", name, gid);
-}
-
-const char chown_usage[] = "chown [-R] user-name file [file ...]\n"
-"\n\tThe group list is kept in the file /etc/groups.\n\n"
-"\t-R:\tRecursively change the mode of all files and directories\n"
-"\t\tunder the argument directory.";
-
-int
-parse_user_name(const char * s, struct FileInfo * i)
-{
- char * dot = strchr(s, '.');
- char * end = NULL;
- uid_t id = 0;
-
- if (! dot )
- dot = strchr(s, ':');
-
- if ( dot )
- *dot = '\0';
-
- if ( my_getpwnam(s,&id) == -1 ) {
- id = strtol(s,&end,10);
- if ((*end != '\0') || ( my_getpwuid(&id) == -1 )) {
- fprintf(stderr, "%s: no such user.\n", s);
- return 1;
- }
- }
- i->userID = id;
-
- if ( dot ) {
- if ( my_getgrnam(++dot,&id) == -1 ) {
- id = strtol(dot,&end,10);
- if ((*end != '\0') || ( my_getgrgid(&id) == -1 )) {
- fprintf(stderr, "%s: no such group.\n", dot);
- return 1;
- }
- }
- i->groupID = id;
- i->changeGroupID = 1;
- }
- return 0;
-}
-
-extern int
-chown_main(struct FileInfo * i, int argc, char * * argv)
-{
- int status;
-
- while ( argc >= 3 && strcmp("-R", argv[1]) == 0 ) {
- i->recursive = 1;
- argc--;
- argv++;
- }
-
- if ( (status = parse_user_name(argv[1], i)) != 0 )
- return status;
-
- argv++;
- argc--;
-
- i->changeUserID = 1;
- i->complainInPostProcess = 1;
-
- return monadic_main(i, argc, argv);
-}
-
-
-
-
-#endif