com.mindoo.domino.jna.internal.structs.NotesSSOTokenStruct32 Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of domino-jna Show documentation
Show all versions of domino-jna Show documentation
Java project to access the HCL Domino C API using Java Native Access (JNA)
package com.mindoo.domino.jna.internal.structs;
import java.security.AccessController;
import java.security.PrivilegedAction;
import java.util.Arrays;
import java.util.List;
import com.sun.jna.Pointer;
import com.sun.jna.Structure;
/**
* Internal class to decode the SSO_TOKEN structure values
*
* @author Karsten Lehmann
*/
public class NotesSSOTokenStruct32 extends BaseStructure {
public int mhName;
public int mhDomainList;
public short wNumDomains;
public int bSecureOnly;
public int mhData;
/**
* @deprecated only public to be used by JNA; use static newInstance method instead to run in AccessController.doPrivileged block
*/
public NotesSSOTokenStruct32() {
super();
}
public static NotesSSOTokenStruct32 newInstance() {
return AccessController.doPrivileged(new PrivilegedAction() {
@Override
public NotesSSOTokenStruct32 run() {
return new NotesSSOTokenStruct32();
}
});
}
@Override
protected List getFieldOrder() {
return Arrays.asList("mhName", "mhDomainList", "wNumDomains", "bSecureOnly", "mhData");
}
/**
* Creates a new instance
*
* @param mhName name for the token when set as a cookie
* @param mhDomainList list of DNS domains for the token when set as a cookie
* @param wNumDomains Total number of domains contained in the mhDomainList member
* @param bSecureOnly BOOL recommending that the token only be set on a secure connection.
* @param mhData MEMHANDLE to a the null-terminated token data.
* @deprecated only public to be used by JNA; use static newInstance method instead to run in AccessController.doPrivileged block
*/
public NotesSSOTokenStruct32(int mhName, int mhDomainList, short wNumDomains, int bSecureOnly, int mhData) {
super();
this.mhName = mhName;
this.mhDomainList = mhDomainList;
this.wNumDomains = wNumDomains;
this.bSecureOnly = bSecureOnly;
this.mhData = mhData;
}
public static NotesSSOTokenStruct32 newInstance(final int mhName, final int mhDomainList, final short wNumDomains, final int bSecureOnly, final int mhData) {
return AccessController.doPrivileged(new PrivilegedAction() {
@Override
public NotesSSOTokenStruct32 run() {
return new NotesSSOTokenStruct32(mhName, mhDomainList, wNumDomains, bSecureOnly, mhData);
}
});
}
/**
* @deprecated only public to be used by JNA; use static newInstance method instead to run in AccessController.doPrivileged block
*
* @param peer pointer
*/
public NotesSSOTokenStruct32(Pointer peer) {
super(peer);
}
public static NotesSSOTokenStruct32 newInstance(final Pointer p) {
return AccessController.doPrivileged(new PrivilegedAction() {
@Override
public NotesSSOTokenStruct32 run() {
return new NotesSSOTokenStruct32(p);
}
});
}
public boolean isSecureOnly() {
return bSecureOnly!=0;
}
public static class ByReference extends NotesSSOTokenStruct32 implements Structure.ByReference {
};
public static class ByValue extends NotesSSOTokenStruct32 implements Structure.ByValue {
};
}