#ifndef __XRDOFSEVR_H__
#define __XRDOFSEVR_H__
/******************************************************************************/
/* */
/* X r d O f s E v r . h h */
/* */
/* (c) 2006 by the Board of Trustees of the Leland Stanford, Jr., University */
/* All Rights Reserved */
/* Produced by Andrew Hanushevsky for Stanford University under contract */
/* DE-AC02-76-SFO0515 with the Department of Energy */
/* */
/* This file is part of the XRootD software suite. */
/* */
/* XRootD is free software: you can redistribute it and/or modify it under */
/* the terms of the GNU Lesser General Public License as published by the */
/* Free Software Foundation, either version 3 of the License, or (at your */
/* option) any later version. */
/* */
/* XRootD is distributed in the hope that it will be useful, but WITHOUT */
/* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or */
/* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public */
/* License for more details. */
/* */
/* You should have received a copy of the GNU Lesser General Public License */
/* along with XRootD in a file called COPYING.LESSER (LGPL license) and file */
/* COPYING (GPL license). If not, see . */
/* */
/* The copyright holder's institutional names and contributor's names may not */
/* be used to endorse or promote products derived from this software without */
/* specific prior written permission of the institution or contributor. */
/******************************************************************************/
#include
#include "XrdOuc/XrdOucHash.hh"
#include "XrdOuc/XrdOucErrInfo.hh"
#include "XrdSys/XrdSysPthread.hh"
#include "XrdOuc/XrdOucStream.hh"
class XrdSysError;
class XrdCmsClient;
class XrdOfsEvr
{
public:
class theClient;
void flushEvents();
int Init(XrdSysError *eObj);
int Init(XrdCmsClient *trg=0);
void recvEvents();
void Wait4Event(const char *path, XrdOucErrInfo *einfo);
void Work4Event(theClient *Client);
XrdOfsEvr() : mySem(0), eDest(0), Balancer(0) {runQ = 0; deferQ = 0;}
~XrdOfsEvr();
class theClient : XrdOucEICB
{
public:
void Done(int &Result, XrdOucErrInfo *eInfo, const char *path=0)
{ (void)Result; (void)eInfo; (void)path; EvrP->Work4Event(this);}
int Same(unsigned long long arg1, unsigned long long arg2)
{ (void)arg1; (void)arg2; return 0;}
theClient *Next;
const char *User;
char *Path;
XrdOfsEvr *EvrP;
XrdOucEICB *evtCB;
unsigned long long evtCBarg;
theClient(XrdOfsEvr *evr, XrdOucErrInfo *einfo, const char *path=0)
{evtCB = einfo->getErrCB(evtCBarg);
User = einfo->getErrUser();
Path = (path ? strdup(path) : 0);
EvrP = evr;
Next = 0;
}
~theClient() {if (Path) free(Path);}
};
struct theEvent {theClient *aClient;
char *finalMsg;
int finalRC;
char Happened;
theEvent(int rc, const char *emsg, theClient *cp=0)
{aClient = cp; finalRC = rc; Happened = 0;
finalMsg = (emsg ? strdup(emsg) : 0);
}
~theEvent()
{if (finalMsg) free(finalMsg);
if (aClient) delete aClient;
}
};
private:
void eventStage();
void sendEvent(theEvent *ep);
static const int maxLife = (8*60*60); // Eight hours
XrdSysMutex myMutex;
XrdSysSemaphore mySem;
XrdOucStream eventFIFO;
XrdSysError *eDest;
XrdCmsClient *Balancer;
theClient *deferQ;
int runQ;
int msgFD;
XrdOucHash Events;
};
#endif