All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.ibm.as400.access.JDPrivilegeFieldMap Maven / Gradle / Ivy

The newest version!
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// 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