1 /*
   2  * CDDL HEADER START
   3  *
   4  * The contents of this file are subject to the terms of the
   5  * Common Development and Distribution License (the "License").
   6  * You may not use this file except in compliance with the License.
   7  *
   8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
   9  * or http://www.opensolaris.org/os/licensing.
  10  * See the License for the specific language governing permissions
  11  * and limitations under the License.
  12  *
  13  * When distributing Covered Code, include this CDDL HEADER in each
  14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
  15  * If applicable, add the following below this CDDL HEADER, with the
  16  * fields enclosed by brackets "[]" replaced with your own identifying
  17  * information: Portions Copyright [yyyy] [name of copyright owner]
  18  *
  19  * CDDL HEADER END
  20  */
  21 /*
  22  * Copyright 2014 Garrett D'Amore <garrett@damore.org>
  23  * Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
  24  */
  25 
  26 #ifndef _PROF_ATTR_H
  27 #define _PROF_ATTR_H
  28 
  29 #ifdef  __cplusplus
  30 extern "C" {
  31 #endif
  32 
  33 
  34 #include <sys/types.h>
  35 #include <secdb.h>
  36 
  37 
  38 #define PROFATTR_FILENAME               "/etc/security/prof_attr"
  39 #define PROFATTR_DB_NAME                "prof_attr.org_dir"
  40 #define PROFATTR_DB_NCOL                5       /* total columns */
  41 #define PROFATTR_DB_NKEYCOL             1       /* total searchable columns */
  42 #define PROFATTR_DB_TBLT                "prof_attr_tbl"
  43 #define PROFATTR_NAME_DEFAULT_KW        "nobody"
  44 
  45 #define PROFATTR_COL0_KW                "name"
  46 #define PROFATTR_COL1_KW                "res1"
  47 #define PROFATTR_COL2_KW                "res2"
  48 #define PROFATTR_COL3_KW                "desc"
  49 #define PROFATTR_COL4_KW                "attr"
  50 
  51 #define PROFILE_STOP                    "Stop"
  52 
  53 #define DEF_PROF                        "PROFS_GRANTED="
  54 #define DEF_CONSUSER                    "CONSOLE_USER="
  55 
  56 #define MAXPROFS                        4096
  57 
  58 /*
  59  * indices of searchable columns
  60  */
  61 #define PROFATTR_KEYCOL0                0       /* name */
  62 
  63 
  64 /*
  65  * Key words used in the prof_attr database
  66  */
  67 #define PROFATTR_AUTHS_KW               "auths"
  68 #define PROFATTR_PROFS_KW               "profiles"
  69 #define PROFATTR_PRIVS_KW               "privs"
  70 
  71 
  72 /*
  73  * Nsswitch representation of profile attributes.
  74  */
  75 
  76 typedef struct profstr_s {
  77         char   *name;   /* proforization name */
  78         char   *res1;   /* RESERVED */
  79         char   *res2;   /* RESERVED */
  80         char   *desc;   /* description */
  81         char   *attr;   /* string of key-value pair attributes */
  82 } profstr_t;
  83 
  84 typedef struct profattr_s {
  85         char   *name;   /* proforization name */
  86         char   *res1;   /* RESERVED */
  87         char   *res2;   /* RESERVED */
  88         char   *desc;   /* description */
  89         kva_t  *attr;   /* array of key-value pair attributes */
  90 } profattr_t;
  91 
  92 extern profattr_t *getprofnam(const char *);
  93 extern profattr_t *getprofattr(void);
  94 extern void getproflist(const char *, char **, int *);
  95 extern void setprofattr(void);
  96 extern void endprofattr(void);
  97 extern void free_profattr(profattr_t *);
  98 extern void free_proflist(char **, int);
  99 
 100 #ifdef __cplusplus
 101 }
 102 #endif
 103 
 104 #endif  /* _PROF_ATTR_H */