XRootD
Loading...
Searching...
No Matches
XrdPosixAdmin Class Reference

#include <XrdPosixAdmin.hh>

Collaboration diagram for XrdPosixAdmin:

Public Member Functions

 XrdPosixAdmin (const char *path, XrdOucECMsg &ecm)
 ~XrdPosixAdmin ()
XrdCl::URLFanOut (int &num)
bool isOK ()
int Query (XrdCl::QueryCode::Code reqCode, std::string &resp)
int Query (XrdCl::QueryCode::Code reqCode, void *buff, int bsz)
bool Stat (mode_t *flags=0, time_t *mtime=0)
bool Stat (struct stat &Stat)

Public Attributes

XrdOucECMsgecMsg
XrdCl::URL Url
XrdCl::FileSystem Xrd

Detailed Description

Definition at line 49 of file XrdPosixAdmin.hh.

Constructor & Destructor Documentation

◆ XrdPosixAdmin()

XrdPosixAdmin::XrdPosixAdmin ( const char * path,
XrdOucECMsg & ecm )
inline

Definition at line 74 of file XrdPosixAdmin.hh.

75 : Url((std::string)path), Xrd(Url), ecMsg(ecm) {}
XrdCl::FileSystem Xrd
XrdOucECMsg & ecMsg
XrdCl::URL Url

References ecMsg, and Url.

◆ ~XrdPosixAdmin()

XrdPosixAdmin::~XrdPosixAdmin ( )
inline

Definition at line 76 of file XrdPosixAdmin.hh.

76{}

Member Function Documentation

◆ FanOut()

XrdCl::URL * XrdPosixAdmin::FanOut ( int & num)

Definition at line 46 of file XrdPosixAdmin.cc.

47{
48 XrdCl::XRootDStatus xStatus;
49 XrdCl::LocationInfo *info = 0;
51 XrdCl::URL *uVec;
52 XrdNetAddr netLoc;
53 const char *hName;
54 unsigned long i;
55
56// Make sure admin is ok
57//
58 if (!isOK()) return 0;
59
60// Issue the deep locate and verify that all went well
61//
62 xStatus = Xrd.DeepLocate(Url.GetPathWithParams(),XrdCl::OpenFlags::PrefName,info);
63 if (!xStatus.IsOK())
64 {num = XrdPosixMap::Result(xStatus, ecMsg, false);
65 return 0;
66 }
67
68// Allocate an array large enough to hold this information
69//
70 if (!(i = info->GetSize())) {delete info; return 0;}
71 if (i > std::numeric_limits<ptrdiff_t>::max() / sizeof(XrdCl::URL))
72 {delete info; return 0;}
73 uVec = new XrdCl::URL[i];
74
75// Now start filling out the array
76//
77 num = 0;
78 for( it = info->Begin(); it != info->End(); ++it )
79 {if (!netLoc.Set(it->GetAddress().c_str()) && (hName = netLoc.Name()))
80 {std::string hString(hName);
81 uVec[num] = Url;
82 uVec[num].SetHostName(hString);
83 uVec[num].SetPort(netLoc.Port());
84 num++;
85 }
86 }
87
88// Make sure we can return something;
89//
90 delete info;
91 if (!num) {delete [] uVec; return 0;}
92 return uVec;
93}
uint32_t GetSize() const
Get number of locations.
Iterator Begin()
Get the location begin iterator.
LocationList::iterator Iterator
Iterator over locations.
Iterator End()
Get the location end iterator.
void SetPort(int port)
Definition XrdClURL.hh:196
void SetHostName(const std::string &hostName)
Set the host name.
Definition XrdClURL.hh:178
const char * Name(const char *eName=0, const char **eText=0)
int Port(int pNum=-1)
const char * Set(const char *hSpec, int pNum=PortInSpec)
static int Result(const XrdCl::XRootDStatus &Status, XrdOucECMsg &ecMsg, bool retneg1=false)
bool IsOK() const
We're fine.

References XrdCl::LocationInfo::Begin(), ecMsg, XrdCl::LocationInfo::End(), XrdCl::LocationInfo::GetSize(), XrdCl::Status::IsOK(), isOK(), XrdNetAddrInfo::Name(), XrdNetAddr::Port(), XrdCl::OpenFlags::PrefName, XrdPosixMap::Result(), XrdNetAddr::Set(), XrdCl::URL::SetHostName(), XrdCl::URL::SetPort(), and Url.

Referenced by XrdFfsMisc_get_all_urls_real().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ isOK()

bool XrdPosixAdmin::isOK ( )
inline

Definition at line 57 of file XrdPosixAdmin.hh.

57 {if (Url.IsValid()) return true;
58 ecMsg.Set(EINVAL, 0);
59 ecMsg.Msgf("PosixAdmin", "url '%s' is invalid",
60 Url.GetObfuscatedURL().c_str());
61 errno = EINVAL; return false;
62 }

References ecMsg, and Url.

Referenced by FanOut(), XrdPosixXrootd::Mkdir(), Query(), Query(), XrdPosixXrootd::Rename(), XrdPosixXrootd::Rmdir(), Stat(), Stat(), XrdPosixXrootd::Stat(), XrdPosixXrootd::Statvfs(), XrdPosixXrootd::Truncate(), XrdPosixXrootd::Unlink(), XrdFfsMisc_get_all_urls_real(), and XrdFfsMisc_get_current_url().

Here is the caller graph for this function:

◆ Query() [1/2]

int XrdPosixAdmin::Query ( XrdCl::QueryCode::Code reqCode,
std::string & resp )

Definition at line 136 of file XrdPosixAdmin.cc.

137{
138 XrdCl::Buffer reqBuff, *rspBuff = 0;
139
140// Make sure we are OK
141//
142 if (!isOK()) return -1;
143
144// Get argument
145//
146 reqBuff.FromString(Url.GetPathWithParams());
147
148// Issue the query
149//
150 if (!XrdPosixMap::Result(Xrd.Query(reqCode, reqBuff, rspBuff),ecMsg))
151 {uint32_t rspSz = rspBuff->GetSize();
152 char *rspData = rspBuff->GetBuffer();
153 if (rspData && rspSz)
154 {std::string tmp(rspData, (size_t)rspSz);
155 delete rspBuff;
156 resp = std::move(tmp);
157 return static_cast<int>(rspSz + 1);
158 } else ecMsg.SetErrno(EFAULT,0,"Invalid return results");
159 }
160
161// Return error
162//
163 delete rspBuff;
164 return -1;
165}
void FromString(const std::string str)
Fill the buffer from a string.
const char * GetBuffer(uint32_t offset=0) const
Get the message buffer.
uint32_t GetSize() const
Get the size of the message.

References ecMsg, XrdCl::Buffer::FromString(), XrdCl::Buffer::GetBuffer(), XrdCl::Buffer::GetSize(), isOK(), XrdPosixMap::Result(), and Url.

Here is the call graph for this function:

◆ Query() [2/2]

int XrdPosixAdmin::Query ( XrdCl::QueryCode::Code reqCode,
void * buff,
int bsz )

Definition at line 99 of file XrdPosixAdmin.cc.

100{
101 XrdCl::Buffer reqBuff, *rspBuff = 0;
102
103// Make sure we are OK
104//
105 if (!isOK()) return -1;
106
107// Get argument
108//
109 reqBuff.FromString(Url.GetPathWithParams());
110
111// Issue the query
112//
113 if (!XrdPosixMap::Result(Xrd.Query(reqCode, reqBuff, rspBuff),ecMsg))
114 {uint32_t rspSz = rspBuff->GetSize();
115 char *rspbuff = rspBuff->GetBuffer();
116 if (rspbuff && rspSz)
117 {// if the string is null-terminated decrement the size
118 if ( !(rspbuff[rspSz - 1]) ) --rspSz;
119 if (bsz >= (int)rspSz + 1)
120 {strncpy((char *)buff, rspbuff, rspSz);
121 ((char*)buff)[rspSz] = 0; // make sure it is null-terminated
122 delete rspBuff;
123 return static_cast<int>(rspSz + 1);
124 } else ecMsg.SetErrno(ERANGE,0,"buffer to small to hold result");
125 } else ecMsg.SetErrno(EFAULT,0,"Invalid return results");
126 }
127
128// Return error
129//
130 delete rspBuff;
131 return -1;
132}

References ecMsg, XrdCl::Buffer::FromString(), XrdCl::Buffer::GetBuffer(), XrdCl::Buffer::GetSize(), isOK(), XrdPosixMap::Result(), and Url.

Referenced by XrdPosixExtra::FSctl(), XrdPosixXrootd::Getxattr(), XrdPosixXrootd::QueryChksum(), and XrdPosixXrootd::QueryOpaque().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ Stat() [1/2]

bool XrdPosixAdmin::Stat ( mode_t * flags = 0,
time_t * mtime = 0 )

Definition at line 170 of file XrdPosixAdmin.cc.

171{
172 XrdCl::XRootDStatus xStatus;
173 XrdCl::StatInfo *sInfo = 0;
174
175// Make sure admin is ok
176//
177 if (!isOK()) return false;
178
179// Issue the stat and verify that all went well
180//
181 xStatus = Xrd.Stat(Url.GetPathWithParams(), sInfo);
182 if (!xStatus.IsOK())
183 {XrdPosixMap::Result(xStatus,ecMsg);
184 delete sInfo;
185 return false;
186 }
187
188// Return wanted data
189//
190 if (flags) *flags = XrdPosixMap::Flags2Mode(0, sInfo->GetFlags());
191 if (mtime) *mtime = static_cast<time_t>(sInfo->GetModTime());
192
193// Delete our status information and return final result
194//
195 delete sInfo;
196 return true;
197}
uint32_t GetFlags() const
Get flags.
uint64_t GetModTime() const
Get modification time (in seconds since epoch).
static mode_t Flags2Mode(dev_t *rdv, uint32_t flags)

References ecMsg, XrdPosixMap::Flags2Mode(), XrdCl::StatInfo::GetFlags(), XrdCl::StatInfo::GetModTime(), XrdCl::Status::IsOK(), isOK(), XrdPosixMap::Result(), and Url.

Referenced by XrdPosixXrootd::Access(), XrdPosixExtra::FSctl(), XrdPosixXrootd::Getxattr(), XrdPosixXrootd::QueryChksum(), XrdPosixXrootd::QueryOpaque(), Stat(), XrdPosixXrootd::Stat(), and XrdFfsMisc_get_current_url().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ Stat() [2/2]

bool XrdPosixAdmin::Stat ( struct stat & Stat)

Definition at line 201 of file XrdPosixAdmin.cc.

202{
203 XrdCl::XRootDStatus xStatus;
204 XrdCl::StatInfo *sInfo = 0;
205
206// Make sure admin is ok
207//
208 if (!isOK()) return false;
209
210// Issue the stat and verify that all went well
211//
212 xStatus = Xrd.Stat(Url.GetPathWithParams(), sInfo);
213 if (!xStatus.IsOK())
214 {XrdPosixMap::Result(xStatus,ecMsg);
215 delete sInfo;
216 return false;
217 }
218
219// Return the data
220//
221 Stat.st_size = static_cast<size_t>(sInfo->GetSize());
222 Stat.st_blocks = Stat.st_size/512 + Stat.st_size%512;
223 Stat.st_ino = static_cast<ino_t>(strtoll(sInfo->GetId().c_str(), 0, 10));
224#if defined(__mips__) && _MIPS_SIM == _ABIO32
225 // Work around inconsistent type definitions on MIPS
226 // The st_rdev field in struct stat (which is 32 bits) is not type
227 // dev_t (which is 64 bits)
228 dev_t tmp_rdev = Stat.st_rdev;
229 Stat.st_mode = XrdPosixMap::Flags2Mode(&tmp_rdev, sInfo->GetFlags());
230 Stat.st_rdev = tmp_rdev;
231#else
232 Stat.st_mode = XrdPosixMap::Flags2Mode(&Stat.st_rdev, sInfo->GetFlags());
233#endif
234 Stat.st_mtime = static_cast<time_t>(sInfo->GetModTime());
235
236 if (sInfo->ExtendedFormat())
237 {
238 // Flags2Mode only maps the simplified protocol flags to owner permission
239 // bits (S_IRUSR, S_IWUSR, S_IXUSR). The extended stat response carries
240 // the full POSIX permission mode as an octal string (e.g. "0644").
241 // Replace the permission bits while preserving the file type (S_IFMT).
242 mode_t realPerms = strtol(sInfo->GetModeAsString().c_str(), nullptr, 8);
243 Stat.st_mode = (Stat.st_mode & S_IFMT) | (realPerms & 07777);
244 Stat.st_ctime = static_cast<time_t>(sInfo->GetChangeTime());
245 Stat.st_atime = static_cast<time_t>(sInfo->GetAccessTime());
246 } else {
247 Stat.st_ctime = Stat.st_mtime;
248 Stat.st_atime = time(0);
249 }
250
251// Delete our status information and return final result
252//
253 delete sInfo;
254 return true;
255}
uint64_t GetChangeTime() const
Get change time (in seconds since epoch).
uint64_t GetSize() const
Get size (in bytes).
bool ExtendedFormat() const
Has extended stat information.
const std::string & GetModeAsString() const
Get mode.
const std::string & GetId() const
Get id.
uint64_t GetAccessTime() const
Get change time (in seconds since epoch).
bool Stat(mode_t *flags=0, time_t *mtime=0)

References ecMsg, XrdCl::StatInfo::ExtendedFormat(), XrdPosixMap::Flags2Mode(), XrdCl::StatInfo::GetAccessTime(), XrdCl::StatInfo::GetChangeTime(), XrdCl::StatInfo::GetFlags(), XrdCl::StatInfo::GetId(), XrdCl::StatInfo::GetModeAsString(), XrdCl::StatInfo::GetModTime(), XrdCl::StatInfo::GetSize(), XrdCl::Status::IsOK(), isOK(), XrdPosixMap::Result(), Stat(), stat, and Url.

Here is the call graph for this function:

Member Data Documentation

◆ ecMsg

XrdOucECMsg& XrdPosixAdmin::ecMsg

Definition at line 55 of file XrdPosixAdmin.hh.

Referenced by XrdPosixAdmin(), FanOut(), isOK(), Query(), Query(), Stat(), and Stat().

◆ Url

◆ Xrd


The documentation for this class was generated from the following files: