com.hcl.domino.jna.internal.structs.VerifyLDAPConnectionStruct Maven / Gradle / Ivy
/*
* ==========================================================================
* Copyright (C) 2019-2022 HCL America, Inc. ( http://www.hcl.com/ )
* All rights reserved.
* ==========================================================================
* Licensed under the Apache License, Version 2.0 (the "License"). You may
* not use this file except in compliance with the License. You may obtain a
* copy of the License at .
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
* ==========================================================================
*/
package com.hcl.domino.jna.internal.structs;
import java.io.Serializable;
import java.security.AccessController;
import java.security.PrivilegedAction;
import java.util.Arrays;
import java.util.List;
import com.hcl.domino.commons.structs.WrongArraySizeException;
import com.hcl.domino.commons.util.DominoUtils;
import com.hcl.domino.data.IAdaptable;
import com.hcl.domino.misc.NotesConstants;
import com.sun.jna.Pointer;
import com.sun.jna.Structure;
/**
* JNA class for the VerifyLDAPConnectionStruct type
*
* @author Raghu M R
*/
public class VerifyLDAPConnectionStruct extends BaseStructure implements Serializable, IAdaptable {
private static final long serialVersionUID = 1L;
public byte[] szHostName = new byte[NotesConstants.MAXUSERNAME];
public byte[] szUserName = new byte[NotesConstants.MAXUSERNAME];
public byte[] szPassword = new byte[NotesConstants.MAXUSERPASSWORD];
public byte[] szDNSearch = new byte[NotesConstants.MAXLDAPBASE];
public boolean bUseSSL;
public short wPort;
public boolean bAcceptExpiredCertificates;
public boolean bVerifyRemoteSrvCert;
public VerifyLDAPConnectionStruct(byte hostName[],byte userName[], byte password[], byte dnSearch[], boolean useSSL, short port, boolean acceptExpiredCertificates, boolean verifyRemoteSrvCert) {
super();
if ((hostName.length > this.szHostName.length)) {
throw new WrongArraySizeException("hostName"); //$NON-NLS-1$
}
DominoUtils.overwriteArray(hostName, this.szHostName);
if ((userName.length > this.szUserName.length)) {
throw new WrongArraySizeException("userName"); //$NON-NLS-1$
}
DominoUtils.overwriteArray(userName, this.szUserName);
if ((password.length > this.szPassword.length)) {
throw new WrongArraySizeException("Password"); //$NON-NLS-1$
}
DominoUtils.overwriteArray(password, this.szPassword);
if ((dnSearch.length > this.szDNSearch.length)) {
throw new WrongArraySizeException("DNSearch"); //$NON-NLS-1$
}
DominoUtils.overwriteArray(dnSearch, this.szDNSearch);
this.wPort = port;
this.bUseSSL =useSSL;
this.bAcceptExpiredCertificates = acceptExpiredCertificates;
this.bVerifyRemoteSrvCert = verifyRemoteSrvCert;
}
public VerifyLDAPConnectionStruct() {
super();
}
public static VerifyLDAPConnectionStruct newInstance() {
return AccessController.doPrivileged((PrivilegedAction) () -> new VerifyLDAPConnectionStruct());
}
public static VerifyLDAPConnectionStruct.ByValue newInstanceByVal() {
return AccessController.doPrivileged((PrivilegedAction) () -> new VerifyLDAPConnectionStruct.ByValue());
}
@SuppressWarnings("nls")
@Override
protected List getFieldOrder() {
return Arrays.asList("szHostName", "szUserName", "szPassword", "szDNSearch", "bUseSSL", "wPort", "bAcceptExpiredCertificates", "bVerifyRemoteSrvCert");
}
@Override
@SuppressWarnings("unchecked")
public T getAdapter(Class clazz) {
if (clazz == VerifyLDAPConnectionStruct.class) {
return (T) this;
}
else if (clazz == Pointer.class) {
return (T) getPointer();
}
return null;
}
public static class ByReference extends VerifyLDAPConnectionStruct implements Structure.ByReference {
private static final long serialVersionUID = -2958581285484373942L;
};
public static class ByValue extends VerifyLDAPConnectionStruct implements Structure.ByValue {
private static final long serialVersionUID = -6538673668884547829L;
};
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy