X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/python-afs.git/blobdiff_plain/b5df6079cc89dd5cdb2bb5e9c4ad1a62eefa78b0..7566acb783c3ad657b643456f993d9c7b3cbcde3:/afs/_pts.pyx diff --git a/afs/_pts.pyx b/afs/_pts.pyx index d050a4c..640fcc2 100644 --- a/afs/_pts.pyx +++ b/afs/_pts.pyx @@ -26,6 +26,7 @@ cdef import from "afs/ptuser.h": afs_int32 owner afs_int32 creator afs_int32 ngroups + afs_int32 nusers afs_int32 count int ubik_PR_NameToID(ubik_client *, afs_int32, namelist *, idlist *) @@ -40,6 +41,8 @@ cdef import from "afs/ptuser.h": int ubik_PR_ListEntry(ubik_client *, afs_int32, afs_int32, prcheckentry *) int ubik_PR_ChangeEntry(ubik_client *, afs_int32, afs_int32, char *, afs_int32, afs_int32) int ubik_PR_IsAMemberOf(ubik_client *, afs_int32, afs_int32, afs_int32, afs_int32 *) + int ubik_PR_ListMax(ubik_client *, afs_int32, afs_int32 *, afs_int32 *) + int ubik_PR_SetMax(ubik_client *, afs_int32, afs_int32, afs_int32) cdef import from "afs/pterror.h": enum: @@ -54,6 +57,7 @@ cdef class PTEntry: cdef public afs_int32 owner cdef public afs_int32 creator cdef public afs_int32 ngroups + cdef public afs_int32 nusers cdef public afs_int32 count cdef int _ptentry_from_c(PTEntry p_entry, prcheckentry c_entry) except -1: @@ -66,6 +70,7 @@ cdef int _ptentry_from_c(PTEntry p_entry, prcheckentry c_entry) except -1: p_entry.owner = c_entry.owner p_entry.creator = c_entry.creator p_entry.ngroups = c_entry.ngroups + p_entry.nusers = c_entry.nusers p_entry.count = c_entry.count return 0 @@ -79,6 +84,7 @@ cdef int _ptentry_to_c(prcheckentry * c_entry, PTEntry p_entry) except -1: c_entry.owner = p_entry.owner c_entry.creator = p_entry.creator c_entry.ngroups = p_entry.ngroups + c_entry.nusers = p_entry.nusers c_entry.count = p_entry.count return 0 @@ -407,3 +413,38 @@ cdef class PTS: raise Exception("Error testing membership: %s" % afs_error_message(code)) return bool(flag) + + def ListMax(self): + """ + Return a tuple of the maximum user ID and the maximum group + ID currently assigned. + """ + cdef afs_int32 code, uid, gid + + code = ubik_PR_ListMax(self.client, 0, &uid, &gid) + if code != 0: + raise Exception("Error looking up max uid/gid: %s" % afs_error_message(code)) + + return (uid, gid) + + def SetMaxUserId(self, id): + """ + Set the maximum currently assigned user ID (the next + automatically assigned UID will be id + 1) + """ + cdef afs_int32 code + + code = ubik_PR_SetMax(self.client, 0, id, 0) + if code != 0: + raise Exception("Error setting max uid: %s" % afs_error_message(code)) + + def SetMaxGroupId(self, id): + """ + Set the maximum currently assigned user ID (the next + automatically assigned UID will be id + 1) + """ + cdef afs_int32 code + + code = ubik_PR_SetMax(self.client, 0, id, PRGRP) + if code != 0: + raise Exception("Error setting max gid: %s" % afs_error_message(code))