IPTables-IPv4
view release on metacpan or search on metacpan
modules/ipt_pl_owner.c view on Meta::CPAN
free(base);
return(FALSE);
}
free(base);
}
else {
SET_ERRSTR("%s: Must have an integer or string value", field);
return(FALSE);
}
info->match |= IPT_OWNER_SID;
}
#ifdef IPT_OWNER_COMM
else if(!strcmp(field, "cmd-owner")) {
if(!SvPOK(value)) {
SET_ERRSTR("%s: Must have a string value", field);
return(FALSE);
}
temp = SvPV(value, len);
base = str = malloc(len + 1);
strncpy(str, temp, len);
str[len] = '\0';
if (str[0] == INVCHAR) {
info->invert |= IPT_OWNER_COMM;
str++;
}
if (strlen(str) > sizeof(info->comm)) {
SET_ERRSTR("%s: Command name is too long", field);
return(FALSE);
}
strncpy(info->comm, str, sizeof(info->comm));
free(base);
info->match |= IPT_OWNER_COMM;
}
#endif /* IPT_OWNER_COMM */
else
return(FALSE);
if(*flags) {
#ifdef IPT_OWNER_COMM
SET_ERRSTR("%s: Only one of 'uid-owner', 'gid-owner', 'pid-owner', "
"'sid-owner', 'cmd-owner' allowed with owner match",
field);
#else /* !IPT_OWNER_COMM */
SET_ERRSTR("%s: Only one of 'uid-owner', 'gid-owner', 'pid-owner', "
"'sid-owner' allowed with owner match", field);
#endif /* IPT_OWNER_COMM */
return(FALSE);
}
*flags = 1;
return(TRUE);
}
static void get_fields(HV *ent_hash, void *myinfo, struct ipt_entry *entry) {
MODULE_DATATYPE *info = (void *)((MODULE_ENTRYTYPE *)myinfo)->data;
char *name, *temp;
SV *sv;
if(info->match & IPT_OWNER_UID) {
struct passwd *pwd;
pwd = getpwuid(info->uid);
if(pwd) {
name = strdup(pwd->pw_name);
if(info->invert & IPT_OWNER_UID) {
asprintf(&temp, "%c%s", INVCHAR, name);
free(name);
name = temp;
}
sv = newSVpv(name, 0);
free(name);
}
else if(info->invert & IPT_OWNER_UID) {
asprintf(&name, "%c%u", INVCHAR, info->uid);
sv = newSVpv(name, 0);
free(name);
}
else
sv = newSViv(info->uid);
hv_store(ent_hash, "uid-owner", 9, sv, 0);
}
else if(info->match & IPT_OWNER_GID) {
struct group *grp;
grp = getgrgid(info->gid);
if(grp) {
name = strdup(grp->gr_name);
if(info->invert & IPT_OWNER_GID) {
asprintf(&temp, "%c%s", INVCHAR, name);
free(name);
name = temp;
}
sv = newSVpv(name, 0);
free(name);
}
else if(info->invert & IPT_OWNER_GID) {
asprintf(&name, "%c%u", INVCHAR, info->gid);
sv = newSVpv(name, 0);
free(name);
}
else
sv = newSViv(info->gid);
hv_store(ent_hash, "gid-owner", 9, sv, 0);
}
else if(info->match & IPT_OWNER_PID) {
if(info->invert & IPT_OWNER_PID) {
asprintf(&name, "%c%u", INVCHAR, info->pid);
sv = newSVpv(name, 0);
free(name);
}
else
sv = newSViv(info->pid);
hv_store(ent_hash, "pid-owner", 9, sv, 0);
}
else if(info->match & IPT_OWNER_SID) {
if(info->invert & IPT_OWNER_SID) {
asprintf(&name, "%c%u", INVCHAR, info->sid);
sv = newSVpv(name, 0);
free(name);
}
else
sv = newSViv(info->sid);
hv_store(ent_hash, "sid-owner", 9, sv, 0);
( run in 2.711 seconds using v1.01-cache-2.11-cpan-5837b0d9d2c )