00001 #ifndef __ACC_ENTITY_H__ 00002 #define __ACC_ENTITY_H__ 00003 /******************************************************************************/ 00004 /* */ 00005 /* X r d A c c E n t i t y . h h */ 00006 /* */ 00007 /* (c) 2019 by the Board of Trustees of the Leland Stanford, Jr., University */ 00008 /* Produced by Andrew Hanushevsky for Stanford University under contract */ 00009 /* DE-AC02-76-SFO0515 with the Department of Energy */ 00010 /* */ 00011 /* This file is part of the XRootD software suite. */ 00012 /* */ 00013 /* XRootD is free software: you can redistribute it and/or modify it under */ 00014 /* the terms of the GNU Lesser General Public License as published by the */ 00015 /* Free Software Foundation, either version 3 of the License, or (at your */ 00016 /* option) any later version. */ 00017 /* */ 00018 /* XRootD is distributed in the hope that it will be useful, but WITHOUT */ 00019 /* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or */ 00020 /* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public */ 00021 /* License for more details. */ 00022 /* */ 00023 /* You should have received a copy of the GNU Lesser General Public License */ 00024 /* along with XRootD in a file called COPYING.LESSER (LGPL license) and file */ 00025 /* COPYING (GPL license). If not, see <http://www.gnu.org/licenses/>. */ 00026 /* */ 00027 /* The copyright holder's institutional names and contributor's names may not */ 00028 /* be used to endorse or promote products derived from this software without */ 00029 /* specific prior written permission of the institution or contributor. */ 00030 /******************************************************************************/ 00031 00032 #include <stdlib.h> 00033 #include <vector> 00034 00035 /******************************************************************************/ 00036 /* X r d A c c E n t i t y I n f o */ 00037 /******************************************************************************/ 00038 00039 struct XrdAccEntityInfo 00040 {const char *name; // Filled in by caller 00041 const char *host; // Filled in by caller 00042 const char *vorg; 00043 const char *role; 00044 const char *grup; 00045 XrdAccEntityInfo() {} 00046 ~XrdAccEntityInfo() {} 00047 }; 00048 00049 /******************************************************************************/ 00050 /* X r d A c c E n t i t y */ 00051 /******************************************************************************/ 00052 00053 class XrdOucTokenizer; 00054 class XrdSecEntity; 00055 class XrdSysError; 00056 00057 class XrdAccEntity 00058 { 00059 public: 00060 00061 static 00062 XrdAccEntity *GetEntity(const XrdSecEntity *secP); 00063 00064 bool Next(int &seq, XrdAccEntityInfo &info) 00065 {if (int(attrVec.size()) <= seq) return false; 00066 EntityAttr *aP = &attrVec[seq++]; 00067 info.vorg = aP->vorg; 00068 info.role = aP->role; 00069 info.grup = aP->grup; 00070 return true; 00071 } 00072 00073 void PutEntity(); 00074 00075 static 00076 void setError(XrdSysError *errP); 00077 00078 private: 00079 00080 XrdAccEntity(const XrdSecEntity *secP, bool &aOK); 00081 00082 ~XrdAccEntity() {if (vorgInfo) free(vorgInfo); 00083 if (roleInfo) free(roleInfo); 00084 if (grpsInfo) free(grpsInfo); 00085 } 00086 00087 bool OneOrZero(char *src, const char *&dest); 00088 bool setAttr(XrdOucTokenizer &tkl, const char *&dest); 00089 00090 struct EntityAttr 00091 {const char *vorg; 00092 const char *role; 00093 const char *grup; 00094 EntityAttr() {} 00095 ~EntityAttr() {} 00096 }; 00097 00098 00099 std::vector<EntityAttr> attrVec; 00100 00101 char *vorgInfo; 00102 char *roleInfo; 00103 char *grpsInfo; 00104 int ueid; 00105 }; 00106 00107 /******************************************************************************/ 00108 /* X r d A c c E n t i t y I n i t */ 00109 /******************************************************************************/ 00110 00111 class XrdAccEntityInit 00112 { 00113 public: 00114 00115 XrdAccEntityInit(const XrdSecEntity *secP, XrdAccEntity *&aeR) 00116 {aeR = aeP = XrdAccEntity::GetEntity(secP);} 00117 00118 ~XrdAccEntityInit() {if (aeP) aeP->PutEntity();} 00119 00120 private: 00121 00122 XrdAccEntity *aeP; 00123 }; 00124 #endif