Blame nis/nis_defaults.c

Packit 6c4009
/* Copyright (c) 1997-2018 Free Software Foundation, Inc.
Packit 6c4009
   This file is part of the GNU C Library.
Packit 6c4009
   Contributed by Thorsten Kukuk <kukuk@vt.uni-paderborn.de>, 1997.
Packit 6c4009
Packit 6c4009
   The GNU C Library is free software; you can redistribute it and/or
Packit 6c4009
   modify it under the terms of the GNU Lesser General Public
Packit 6c4009
   License as published by the Free Software Foundation; either
Packit 6c4009
   version 2.1 of the License, or (at your option) any later version.
Packit 6c4009
Packit 6c4009
   The GNU C Library is distributed in the hope that it will be useful,
Packit 6c4009
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 6c4009
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 6c4009
   Lesser General Public License for more details.
Packit 6c4009
Packit 6c4009
   You should have received a copy of the GNU Lesser General Public
Packit 6c4009
   License along with the GNU C Library; if not, see
Packit 6c4009
   <http://www.gnu.org/licenses/>.  */
Packit 6c4009
Packit 6c4009
#include <assert.h>
Packit 6c4009
#include <stdio.h>
Packit 6c4009
#include <stdlib.h>
Packit 6c4009
#include <string.h>
Packit 6c4009
#include <stdint.h>
Packit 6c4009
#include <sys/types.h>
Packit 6c4009
#include <rpc/rpc.h>
Packit 6c4009
#include <rpcsvc/nis.h>
Packit 6c4009
#include <shlib-compat.h>
Packit 6c4009
Packit 6c4009
#define DEFAULT_TTL 43200
Packit 6c4009
Packit 6c4009
/*
Packit 6c4009
** Some functions for parsing the -D param and NIS_DEFAULTS Environ
Packit 6c4009
*/
Packit 6c4009
static nis_name
Packit 6c4009
searchXYX (char *str, const char *what)
Packit 6c4009
{
Packit 6c4009
  assert (strlen (what) == 6);
Packit 6c4009
  assert (strncmp (str, what, 6) == 0);
Packit 6c4009
  str += 6;			/* Points to the begin of the parameters.  */
Packit 6c4009
Packit 6c4009
  int i = 0;
Packit 6c4009
  while (str[i] != '\0' && str[i] != ':')
Packit 6c4009
    ++i;
Packit 6c4009
  if (i == 0)			/* only "<WHAT>=" ? */
Packit 6c4009
    return strdup ("");
Packit 6c4009
Packit 6c4009
  return strndup (str, i);
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
Packit 6c4009
static nis_name
Packit 6c4009
searchgroup (char *str)
Packit 6c4009
{
Packit 6c4009
  return searchXYX (str, "group=");
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
Packit 6c4009
static nis_name
Packit 6c4009
searchowner (char *str)
Packit 6c4009
{
Packit 6c4009
  return searchXYX (str, "owner=");
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
Packit 6c4009
static uint32_t
Packit 6c4009
searchttl (char *str)
Packit 6c4009
{
Packit 6c4009
  char buf[strlen (str) + 1];
Packit 6c4009
  char *cptr, *dptr;
Packit 6c4009
  uint32_t time;
Packit 6c4009
  int i;
Packit 6c4009
Packit 6c4009
  dptr = strstr (str, "ttl=");
Packit 6c4009
  if (dptr == NULL)		/* should (could) not happen */
Packit 6c4009
    return DEFAULT_TTL;;
Packit 6c4009
Packit 6c4009
  dptr += 4;			/* points to the begin of the new ttl */
Packit 6c4009
  i = 0;
Packit 6c4009
  while (dptr[i] != '\0' && dptr[i] != ':')
Packit 6c4009
    i++;
Packit 6c4009
  if (i == 0)			/* only "ttl=" ? */
Packit 6c4009
    return DEFAULT_TTL;
Packit 6c4009
Packit 6c4009
  strncpy (buf, dptr, i);
Packit 6c4009
  buf[i] = '\0';
Packit 6c4009
  time = 0;
Packit 6c4009
Packit 6c4009
  dptr = buf;
Packit 6c4009
  cptr = strchr (dptr, 'd');
Packit 6c4009
  if (cptr != NULL)
Packit 6c4009
    {
Packit 6c4009
      *cptr = '\0';
Packit 6c4009
      cptr++;
Packit 6c4009
      time += atoi (dptr) * 60 * 60 * 24;
Packit 6c4009
      dptr = cptr;
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  cptr = strchr (dptr, 'h');
Packit 6c4009
  if (cptr != NULL)
Packit 6c4009
    {
Packit 6c4009
      *cptr = '\0';
Packit 6c4009
      cptr++;
Packit 6c4009
      time += atoi (dptr) * 60 * 60;
Packit 6c4009
      dptr = cptr;
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  cptr = strchr (dptr, 'm');
Packit 6c4009
  if (cptr != NULL)
Packit 6c4009
    {
Packit 6c4009
      *cptr = '\0';
Packit 6c4009
      cptr++;
Packit 6c4009
      time += atoi (dptr) * 60;
Packit 6c4009
      dptr = cptr;
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  cptr = strchr (dptr, 's');
Packit 6c4009
  if (cptr != NULL)
Packit 6c4009
    *cptr = '\0';
Packit 6c4009
Packit 6c4009
  time += atoi (dptr);
Packit 6c4009
Packit 6c4009
  return time;
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
static unsigned int
Packit 6c4009
searchaccess (char *str, unsigned int access)
Packit 6c4009
{
Packit 6c4009
  char buf[strlen (str) + 1];
Packit 6c4009
  char *cptr;
Packit 6c4009
  unsigned int result = access;
Packit 6c4009
  int i;
Packit 6c4009
  int n, o, g, w;
Packit 6c4009
Packit 6c4009
  cptr = strstr (str, "access=");
Packit 6c4009
  if (cptr == NULL)
Packit 6c4009
    return 0;
Packit 6c4009
Packit 6c4009
  cptr += 7;			/* points to the begin of the access string */
Packit 6c4009
  i = 0;
Packit 6c4009
  while (cptr[i] != '\0' && cptr[i] != ':')
Packit 6c4009
    i++;
Packit 6c4009
  if (i == 0)			/* only "access=" ? */
Packit 6c4009
    return 0;
Packit 6c4009
Packit 6c4009
  strncpy (buf, cptr, i);
Packit 6c4009
  buf[i] = '\0';
Packit 6c4009
Packit 6c4009
  n = o = g = w = 0;
Packit 6c4009
  cptr = buf;
Packit 6c4009
  if (*cptr == ',') /* Fix for stupid Solaris scripts */
Packit 6c4009
    ++cptr;
Packit 6c4009
  while (*cptr != '\0')
Packit 6c4009
    {
Packit 6c4009
      switch (*cptr)
Packit 6c4009
	{
Packit 6c4009
	case 'n':
Packit 6c4009
	  n = 1;
Packit 6c4009
	  break;
Packit 6c4009
	case 'o':
Packit 6c4009
	  o = 1;
Packit 6c4009
	  break;
Packit 6c4009
	case 'g':
Packit 6c4009
	  g = 1;
Packit 6c4009
	  break;
Packit 6c4009
	case 'w':
Packit 6c4009
	  w = 1;
Packit 6c4009
	  break;
Packit 6c4009
	case 'a':
Packit 6c4009
	  o = g = w = 1;
Packit 6c4009
	  break;
Packit 6c4009
	case '-':
Packit 6c4009
	  cptr++;		/* Remove "-" from beginning */
Packit 6c4009
	  while (*cptr != '\0' && *cptr != ',')
Packit 6c4009
	    {
Packit 6c4009
	      switch (*cptr)
Packit 6c4009
		{
Packit 6c4009
		case 'r':
Packit 6c4009
		  if (n)
Packit 6c4009
		    result = result & ~(NIS_READ_ACC << 24);
Packit 6c4009
		  if (o)
Packit 6c4009
		    result = result & ~(NIS_READ_ACC << 16);
Packit 6c4009
		  if (g)
Packit 6c4009
		    result = result & ~(NIS_READ_ACC << 8);
Packit 6c4009
		  if (w)
Packit 6c4009
		    result = result & ~(NIS_READ_ACC);
Packit 6c4009
		  break;
Packit 6c4009
		case 'm':
Packit 6c4009
		  if (n)
Packit 6c4009
		    result = result & ~(NIS_MODIFY_ACC << 24);
Packit 6c4009
		  if (o)
Packit 6c4009
		    result = result & ~(NIS_MODIFY_ACC << 16);
Packit 6c4009
		  if (g)
Packit 6c4009
		    result = result & ~(NIS_MODIFY_ACC << 8);
Packit 6c4009
		  if (w)
Packit 6c4009
		    result = result & ~(NIS_MODIFY_ACC);
Packit 6c4009
		  break;
Packit 6c4009
		case 'c':
Packit 6c4009
		  if (n)
Packit 6c4009
		    result = result & ~(NIS_CREATE_ACC << 24);
Packit 6c4009
		  if (o)
Packit 6c4009
		    result = result & ~(NIS_CREATE_ACC << 16);
Packit 6c4009
		  if (g)
Packit 6c4009
		    result = result & ~(NIS_CREATE_ACC << 8);
Packit 6c4009
		  if (w)
Packit 6c4009
		    result = result & ~(NIS_CREATE_ACC);
Packit 6c4009
		  break;
Packit 6c4009
		case 'd':
Packit 6c4009
		  if (n)
Packit 6c4009
		    result = result & ~(NIS_DESTROY_ACC << 24);
Packit 6c4009
		  if (o)
Packit 6c4009
		    result = result & ~(NIS_DESTROY_ACC << 16);
Packit 6c4009
		  if (g)
Packit 6c4009
		    result = result & ~(NIS_DESTROY_ACC << 8);
Packit 6c4009
		  if (w)
Packit 6c4009
		    result = result & ~(NIS_DESTROY_ACC);
Packit 6c4009
		  break;
Packit 6c4009
		default:
Packit 6c4009
		  return (~0U);
Packit 6c4009
		}
Packit 6c4009
	      cptr++;
Packit 6c4009
	    }
Packit 6c4009
	  n = o = g = w = 0;
Packit 6c4009
	  break;
Packit 6c4009
	case '+':
Packit 6c4009
	  cptr++;		/* Remove "+" from beginning */
Packit 6c4009
	  while (*cptr != '\0' && *cptr != ',')
Packit 6c4009
	    {
Packit 6c4009
	      switch (*cptr)
Packit 6c4009
		{
Packit 6c4009
		case 'r':
Packit 6c4009
		  if (n)
Packit 6c4009
		    result = result | (NIS_READ_ACC << 24);
Packit 6c4009
		  if (o)
Packit 6c4009
		    result = result | (NIS_READ_ACC << 16);
Packit 6c4009
		  if (g)
Packit 6c4009
		    result = result | (NIS_READ_ACC << 8);
Packit 6c4009
		  if (w)
Packit 6c4009
		    result = result | (NIS_READ_ACC);
Packit 6c4009
		  break;
Packit 6c4009
		case 'm':
Packit 6c4009
		  if (n)
Packit 6c4009
		    result = result | (NIS_MODIFY_ACC << 24);
Packit 6c4009
		  if (o)
Packit 6c4009
		    result = result | (NIS_MODIFY_ACC << 16);
Packit 6c4009
		  if (g)
Packit 6c4009
		    result = result | (NIS_MODIFY_ACC << 8);
Packit 6c4009
		  if (w)
Packit 6c4009
		    result = result | (NIS_MODIFY_ACC);
Packit 6c4009
		  break;
Packit 6c4009
		case 'c':
Packit 6c4009
		  if (n)
Packit 6c4009
		    result = result | (NIS_CREATE_ACC << 24);
Packit 6c4009
		  if (o)
Packit 6c4009
		    result = result | (NIS_CREATE_ACC << 16);
Packit 6c4009
		  if (g)
Packit 6c4009
		    result = result | (NIS_CREATE_ACC << 8);
Packit 6c4009
		  if (w)
Packit 6c4009
		    result = result | (NIS_CREATE_ACC);
Packit 6c4009
		  break;
Packit 6c4009
		case 'd':
Packit 6c4009
		  if (n)
Packit 6c4009
		    result = result | (NIS_DESTROY_ACC << 24);
Packit 6c4009
		  if (o)
Packit 6c4009
		    result = result | (NIS_DESTROY_ACC << 16);
Packit 6c4009
		  if (g)
Packit 6c4009
		    result = result | (NIS_DESTROY_ACC << 8);
Packit 6c4009
		  if (w)
Packit 6c4009
		    result = result | (NIS_DESTROY_ACC);
Packit 6c4009
		  break;
Packit 6c4009
		default:
Packit 6c4009
		  return (~0U);
Packit 6c4009
		}
Packit 6c4009
	      cptr++;
Packit 6c4009
	    }
Packit 6c4009
	  n = o = g = w = 0;
Packit 6c4009
	  break;
Packit 6c4009
	case '=':
Packit 6c4009
	  cptr++;		/* Remove "=" from beginning */
Packit 6c4009
	  /* Clear */
Packit 6c4009
	  if (n)
Packit 6c4009
	    result = result & ~((NIS_READ_ACC + NIS_MODIFY_ACC +
Packit 6c4009
				 NIS_CREATE_ACC + NIS_DESTROY_ACC) << 24);
Packit 6c4009
Packit 6c4009
	  if (o)
Packit 6c4009
	    result = result & ~((NIS_READ_ACC + NIS_MODIFY_ACC +
Packit 6c4009
				 NIS_CREATE_ACC + NIS_DESTROY_ACC) << 16);
Packit 6c4009
	  if (g)
Packit 6c4009
	    result = result & ~((NIS_READ_ACC + NIS_MODIFY_ACC +
Packit 6c4009
				 NIS_CREATE_ACC + NIS_DESTROY_ACC) << 8);
Packit 6c4009
	  if (w)
Packit 6c4009
	    result = result & ~(NIS_READ_ACC + NIS_MODIFY_ACC +
Packit 6c4009
				NIS_CREATE_ACC + NIS_DESTROY_ACC);
Packit 6c4009
	  while (*cptr != '\0' && *cptr != ',')
Packit 6c4009
	    {
Packit 6c4009
	      switch (*cptr)
Packit 6c4009
		{
Packit 6c4009
		case 'r':
Packit 6c4009
		  if (n)
Packit 6c4009
		    result = result | (NIS_READ_ACC << 24);
Packit 6c4009
		  if (o)
Packit 6c4009
		    result = result | (NIS_READ_ACC << 16);
Packit 6c4009
		  if (g)
Packit 6c4009
		    result = result | (NIS_READ_ACC << 8);
Packit 6c4009
		  if (w)
Packit 6c4009
		    result = result | (NIS_READ_ACC);
Packit 6c4009
		  break;
Packit 6c4009
		case 'm':
Packit 6c4009
		  if (n)
Packit 6c4009
		    result = result | (NIS_MODIFY_ACC << 24);
Packit 6c4009
		  if (o)
Packit 6c4009
		    result = result | (NIS_MODIFY_ACC << 16);
Packit 6c4009
		  if (g)
Packit 6c4009
		    result = result | (NIS_MODIFY_ACC << 8);
Packit 6c4009
		  if (w)
Packit 6c4009
		    result = result | (NIS_MODIFY_ACC);
Packit 6c4009
		  break;
Packit 6c4009
		case 'c':
Packit 6c4009
		  if (n)
Packit 6c4009
		    result = result | (NIS_CREATE_ACC << 24);
Packit 6c4009
		  if (o)
Packit 6c4009
		    result = result | (NIS_CREATE_ACC << 16);
Packit 6c4009
		  if (g)
Packit 6c4009
		    result = result | (NIS_CREATE_ACC << 8);
Packit 6c4009
		  if (w)
Packit 6c4009
		    result = result | (NIS_CREATE_ACC);
Packit 6c4009
		  break;
Packit 6c4009
		case 'd':
Packit 6c4009
		  if (n)
Packit 6c4009
		    result = result | (NIS_DESTROY_ACC << 24);
Packit 6c4009
		  if (o)
Packit 6c4009
		    result = result | (NIS_DESTROY_ACC << 16);
Packit 6c4009
		  if (g)
Packit 6c4009
		    result = result | (NIS_DESTROY_ACC << 8);
Packit 6c4009
		  if (w)
Packit 6c4009
		    result = result | (NIS_DESTROY_ACC);
Packit 6c4009
		  break;
Packit 6c4009
		default:
Packit 6c4009
		  return result = (~0U);
Packit 6c4009
		}
Packit 6c4009
	      cptr++;
Packit 6c4009
	    }
Packit 6c4009
	  n = o = g = w = 0;
Packit 6c4009
	  break;
Packit 6c4009
	default:
Packit 6c4009
	  return result = (~0U);
Packit 6c4009
	}
Packit 6c4009
      if (*cptr != '\0')
Packit 6c4009
	cptr++;
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  return result;
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
Packit 6c4009
nis_name
Packit 6c4009
__nis_default_owner (char *defaults)
Packit 6c4009
{
Packit 6c4009
  char *default_owner = NULL;
Packit 6c4009
Packit 6c4009
  char *cptr = defaults;
Packit 6c4009
  if (cptr == NULL)
Packit 6c4009
    cptr = getenv ("NIS_DEFAULTS");
Packit 6c4009
Packit 6c4009
  if (cptr != NULL)
Packit 6c4009
    {
Packit 6c4009
      char *dptr = strstr (cptr, "owner=");
Packit 6c4009
      if (dptr != NULL)
Packit 6c4009
	{
Packit 6c4009
	  char *p = searchowner (dptr);
Packit 6c4009
	  if (p == NULL)
Packit 6c4009
	    return NULL;
Packit 6c4009
	  default_owner = strdupa (p);
Packit 6c4009
	  free (p);
Packit 6c4009
	}
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  return strdup (default_owner ?: nis_local_principal ());
Packit 6c4009
}
Packit 6c4009
libnsl_hidden_nolink_def (__nis_default_owner, GLIBC_2_1)
Packit 6c4009
Packit 6c4009
Packit 6c4009
nis_name
Packit 6c4009
__nis_default_group (char *defaults)
Packit 6c4009
{
Packit 6c4009
  char *default_group = NULL;
Packit 6c4009
Packit 6c4009
  char *cptr = defaults;
Packit 6c4009
  if (cptr == NULL)
Packit 6c4009
    cptr = getenv ("NIS_DEFAULTS");
Packit 6c4009
Packit 6c4009
  if (cptr != NULL)
Packit 6c4009
    {
Packit 6c4009
      char *dptr = strstr (cptr, "group=");
Packit 6c4009
      if (dptr != NULL)
Packit 6c4009
	{
Packit 6c4009
	  char *p = searchgroup (dptr);
Packit 6c4009
	  if (p == NULL)
Packit 6c4009
	    return NULL;
Packit 6c4009
	  default_group = strdupa (p);
Packit 6c4009
	  free (p);
Packit 6c4009
	}
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  return strdup (default_group ?: nis_local_group ());
Packit 6c4009
}
Packit 6c4009
libnsl_hidden_nolink_def (__nis_default_group, GLIBC_2_1)
Packit 6c4009
Packit 6c4009
Packit 6c4009
uint32_t
Packit 6c4009
__nis_default_ttl (char *defaults)
Packit 6c4009
{
Packit 6c4009
  char *cptr, *dptr;
Packit 6c4009
Packit 6c4009
  if (defaults != NULL)
Packit 6c4009
    {
Packit 6c4009
      dptr = strstr (defaults, "ttl=");
Packit 6c4009
      if (dptr != NULL)
Packit 6c4009
	return searchttl (defaults);
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  cptr = getenv ("NIS_DEFAULTS");
Packit 6c4009
  if (cptr == NULL)
Packit 6c4009
    return DEFAULT_TTL;
Packit 6c4009
Packit 6c4009
  dptr = strstr (cptr, "ttl=");
Packit 6c4009
  if (dptr == NULL)
Packit 6c4009
    return DEFAULT_TTL;
Packit 6c4009
Packit 6c4009
  return searchttl (cptr);
Packit 6c4009
}
Packit 6c4009
libnsl_hidden_nolink_def (__nis_default_ttl, GLIBC_2_1)
Packit 6c4009
Packit 6c4009
/* Default access rights are ----rmcdr---r---, but we could change
Packit 6c4009
   this with the NIS_DEFAULTS variable. */
Packit 6c4009
unsigned int
Packit 6c4009
__nis_default_access (char *param, unsigned int defaults)
Packit 6c4009
{
Packit 6c4009
  unsigned int result;
Packit 6c4009
  char *cptr;
Packit 6c4009
Packit 6c4009
  if (defaults == 0)
Packit 6c4009
    result = 0 | OWNER_DEFAULT | GROUP_DEFAULT | WORLD_DEFAULT;
Packit 6c4009
  else
Packit 6c4009
    result = defaults;
Packit 6c4009
Packit 6c4009
  if (param != NULL && strstr (param, "access=") != NULL)
Packit 6c4009
    result = searchaccess (param, result);
Packit 6c4009
  else
Packit 6c4009
    {
Packit 6c4009
      cptr = getenv ("NIS_DEFAULTS");
Packit 6c4009
      if (cptr != NULL && strstr (cptr, "access=") != NULL)
Packit 6c4009
	result = searchaccess (cptr, result);
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  return result;
Packit 6c4009
}
Packit 6c4009
libnsl_hidden_nolink_def (__nis_default_access, GLIBC_2_1)