com.ibm.as400.access.JDPrivilegeFieldMap Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jt400 Show documentation
Show all versions of jt400 Show documentation
The Open Source version of the IBM Toolbox for Java
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename: JDPrivilegeFieldMap.java
//
// The source code contained herein is licensed under the IBM Public License
// Version 1.0, which has been approved by the Open Source Initiative.
// Copyright (C) 1997-2001 International Business Machines Corporation and
// others. All rights reserved.
//
///////////////////////////////////////////////////////////////////////////////
package com.ibm.as400.access;
import java.sql.SQLException;
/**
The JDPrivilegeFieldMap converts the authority
information returned from the system to the string
value required by JDBC.
The system returns a char(2) which
contains the following information:
- AUTHORITY CHAR(2)
- BIT 0 - OBJECT EXISTENCE
- BIT 1 - OBJECT MANAGEMENT
- BIT 2 - POINTER AUTHORITY
- BIT 3 - SPACE AUTHORITY
- BIT 4 - READ
- BIT 5 - ADD
- BIT 6 - DELETE
- BIT 7 - UPDATE
- BIT 8 - OWNERSHIP
- BIT 9 - EXCLUDE
- BIT 10 - AUTHORIZATION LIST MGT
- BIT 11 - EXECUTE
- BIT 12 - OBJECT ALTER
- BIT 13 - OBJECT REFERENCE
- BIT 14-15- RESERVED
The only values returned are: "READ", "ADD",
"DELETE", or "UPDATE". More than one value may be
returned.
**/
class JDPrivilegeFieldMap
extends JDSimpleFieldMap
implements JDFieldMap
{
static final String copyright = "Copyright (C) 1997-2001 International Business Machines Corporation and others.";
JDPrivilegeFieldMap (int fromIndex)
{
super (fromIndex);
}
/**
Returns the privileges in JDBC format.
**/
public Object getValue (JDRow row)
throws SQLException
{
Object serverData = super.getValue (row); // gets it from correct column
// using fromIndex
StringBuffer privileges = new StringBuffer ("");
byte[] privilegeBytes = (byte[]) serverData;
// Send back the appropriate String for authority
// we now have 2 bytes
// I only care about bytes 4-7 of byte 1
if((privilegeBytes[0] & 0x08) != 0) // Read authority
privileges.append ("READ ");
if((privilegeBytes[0] & 0x04) != 0) // Add authority
privileges.append ("ADD ");
if((privilegeBytes[0] & 0x02) != 0) // Delete authority
privileges.append ("DELETE ");
if((privilegeBytes[0] & 0x01) != 0) // Update authority
privileges.append ("UPDATE ");
return privileges.toString();
}
/**
Indicates if the value was a data mapping error.
**/
public boolean isDataMappingError(JDRow row)
throws SQLException
{
return false;
}
/**
Indicates if value is null.
**/
public boolean isNull (JDRow row)
throws SQLException
{
return false;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy