Signed-off-by: Evan Broder <broder@mit.edu>
cdef class PTS:
cdef ubik_client * client
cdef class PTS:
cdef ubik_client * client
def __cinit__(self, cell=None, sec=1):
cdef afs_int32 code
cdef afsconf_dir *cdir
def __cinit__(self, cell=None, sec=1):
cdef afs_int32 code
cdef afsconf_dir *cdir
cdef rx_securityClass *sc
cdef rx_connection *serverconns[MAXSERVERS]
cdef int i
cdef rx_securityClass *sc
cdef rx_connection *serverconns[MAXSERVERS]
cdef int i
if cell is None:
c_cell = NULL
else:
c_cell = cell
if cell is None:
c_cell = NULL
else:
c_cell = cell
code = rx_Init(0)
if code != 0:
raise Exception(code, "Error initializing Rx")
code = rx_Init(0)
if code != 0:
raise Exception(code, "Error initializing Rx")
cdir = afsconf_Open(AFSDIR_CLIENT_ETC_DIRPATH)
if cdir is NULL:
raise OSError(errno,
cdir = afsconf_Open(AFSDIR_CLIENT_ETC_DIRPATH)
if cdir is NULL:
raise OSError(errno,
code = afsconf_GetCellInfo(cdir, c_cell, "afsprot", &info)
if code != 0:
raise Exception(code, "GetCellInfo: %s" % afs_error_message(code))
code = afsconf_GetCellInfo(cdir, c_cell, "afsprot", &info)
if code != 0:
raise Exception(code, "GetCellInfo: %s" % afs_error_message(code))
if sec > 0:
strncpy(prin.cell, info.name, sizeof(prin.cell))
prin.instance[0] = 0
strncpy(prin.name, "afs", sizeof(prin.name))
if sec > 0:
strncpy(prin.cell, info.name, sizeof(prin.cell))
prin.instance[0] = 0
strncpy(prin.name, "afs", sizeof(prin.name))
code = ktc_GetToken(&prin, &token, sizeof(token), NULL);
if code != 0:
if sec >= 2:
code = ktc_GetToken(&prin, &token, sizeof(token), NULL);
if code != 0:
if sec >= 2:
sc = rxkad_NewClientSecurityObject(level, &token.sessionKey,
token.kvno, token.ticketLen,
token.ticket)
sc = rxkad_NewClientSecurityObject(level, &token.sessionKey,
token.kvno, token.ticketLen,
token.ticket)
if sec == 0:
sc = rxnull_NewClientSecurityObject()
else:
sec = 2
if sec == 0:
sc = rxnull_NewClientSecurityObject()
else:
sec = 2
memset(serverconns, 0, sizeof(serverconns))
for 0 <= i < info.numServers:
serverconns[i] = rx_NewConnection(info.hostAddr[i].sin_addr.s_addr,
memset(serverconns, 0, sizeof(serverconns))
for 0 <= i < info.numServers:
serverconns[i] = rx_NewConnection(info.hostAddr[i].sin_addr.s_addr,
code = ubik_ClientInit(serverconns, &self.client)
if code != 0:
raise Exception("Failed to initialize ubik connection to Protection server: %s" % afs_error_message(code))
code = ubik_ClientInit(serverconns, &self.client)
if code != 0:
raise Exception("Failed to initialize ubik connection to Protection server: %s" % afs_error_message(code))
def __dealloc__(self):
ubik_ClientDestroy(self.client)
rx_Finalize()
def __dealloc__(self):
ubik_ClientDestroy(self.client)
rx_Finalize()
MAXCELLCHARS
MAXHOSTSPERCELL
MAXHOSTCHARS
MAXCELLCHARS
MAXHOSTSPERCELL
MAXHOSTCHARS
# We just pass afsconf_dir structs around to other AFS functions,
# so this can be treated as opaque
struct afsconf_dir:
pass
# We just pass afsconf_dir structs around to other AFS functions,
# so this can be treated as opaque
struct afsconf_dir:
pass
# For afsconf_cell, on the other hand, we care about everything
struct afsconf_cell:
char name[MAXCELLCHARS]
# For afsconf_cell, on the other hand, we care about everything
struct afsconf_cell:
char name[MAXCELLCHARS]
char hostName[MAXHOSTSPERCELL][MAXHOSTCHARS]
char *linkedCell
int timeout
char hostName[MAXHOSTSPERCELL][MAXHOSTCHARS]
char *linkedCell
int timeout
afsconf_dir *afsconf_Open(char *adir)
int afsconf_GetCellInfo(afsconf_dir *adir,
char *acellName,
afsconf_dir *afsconf_Open(char *adir)
int afsconf_GetCellInfo(afsconf_dir *adir,
char *acellName,
cdef extern from "rx/rxkad.h":
ctypedef char rxkad_level
cdef extern from "rx/rxkad.h":
ctypedef char rxkad_level
enum:
MAXKTCNAMELEN
MAXKTCREALMLEN
enum:
MAXKTCNAMELEN
MAXKTCREALMLEN
enum:
rxkad_clear
rxkad_crypt
enum:
rxkad_clear
rxkad_crypt
struct ktc_encryptionKey:
pass
struct ktc_encryptionKey:
pass
char name[MAXKTCNAMELEN]
char instance[MAXKTCNAMELEN]
char cell[MAXKTCREALMLEN]
char name[MAXKTCNAMELEN]
char instance[MAXKTCNAMELEN]
char cell[MAXKTCREALMLEN]
struct rx_securityClass:
pass
struct rx_securityClass:
pass
rx_securityClass *rxkad_NewClientSecurityObject(rxkad_level level,
ktc_encryptionKey *sessionKey,
afs_int32 kvno,
int ticketLen,
char *ticket)
rx_securityClass *rxnull_NewClientSecurityObject()
rx_securityClass *rxkad_NewClientSecurityObject(rxkad_level level,
ktc_encryptionKey *sessionKey,
afs_int32 kvno,
int ticketLen,
char *ticket)
rx_securityClass *rxnull_NewClientSecurityObject()
int rxs_Release(rx_securityClass *aobj)
cdef extern from "rx/rx.h":
int rx_Init(int port)
void rx_Finalize()
int rxs_Release(rx_securityClass *aobj)
cdef extern from "rx/rx.h":
int rx_Init(int port)
void rx_Finalize()
struct rx_connection:
pass
struct rx_connection:
pass
rx_connection *rx_NewConnection(afs_uint32 shost,
unsigned short sport,
unsigned short sservice,
rx_connection *rx_NewConnection(afs_uint32 shost,
unsigned short sport,
unsigned short sservice,
cdef extern from "afs/auth.h":
enum:
MAXKTCTICKETLEN
cdef extern from "afs/auth.h":
enum:
MAXKTCTICKETLEN
struct ktc_token:
ktc_encryptionKey sessionKey
short kvno
int ticketLen
char ticket[MAXKTCTICKETLEN]
struct ktc_token:
ktc_encryptionKey sessionKey
short kvno
int ticketLen
char ticket[MAXKTCTICKETLEN]
int ktc_GetToken(ktc_principal *server,
ktc_token *token,
int tokenLen,
int ktc_GetToken(ktc_principal *server,
ktc_token *token,
int tokenLen,
cdef extern from "ubik.h":
enum:
MAXSERVERS
cdef extern from "ubik.h":
enum:
MAXSERVERS
# ubik_client is an opaque struct, so we don't care about its members
struct ubik_client:
pass
# ubik_client is an opaque struct, so we don't care about its members
struct ubik_client:
pass
int ubik_ClientInit(rx_connection **serverconns,
ubik_client **aclient)
afs_int32 ubik_ClientDestroy(ubik_client *aclient)
int ubik_ClientInit(rx_connection **serverconns,
ubik_client **aclient)
afs_int32 ubik_ClientDestroy(ubik_client *aclient)