/* ***** BEGIN LICENSE BLOCK ***** * Version: MPL 1.1/GPL 2.0/LGPL 2.1 * * The contents of this file are subject to the Mozilla Public License Version * 1.1 (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License * for the specific language governing rights and limitations under the * License. * * The Original Code is part of dcm4che, an implementation of DICOM(TM) in * Java(TM), hosted at https://github.com/gunterze/dcm4che. * * The Initial Developer of the Original Code is * Agfa Healthcare. * Portions created by the Initial Developer are Copyright (C) 2011 * the Initial Developer. All Rights Reserved. * * Contributor(s): * See @authors listed below * * Alternatively, the contents of this file may be used under the terms of * either the GNU General Public License Version 2 or later (the "GPL"), or * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), * in which case the provisions of the GPL or the LGPL are applicable instead * of those above. If you wish to allow use of your version of this file only * under the terms of either the GPL or the LGPL, and not to allow others to * use your version of this file under the terms of the MPL, indicate your * decision by deleting the provisions above and replace them with the notice * and other provisions required by the GPL or the LGPL. If you do not delete * the provisions above, a recipient may use your version of this file under * the terms of any one of the MPL, the GPL or the LGPL. * * ***** END LICENSE BLOCK ***** */ package org.dcm4che3.net.pdu; import java.io.UnsupportedEncodingException; import org.dcm4che3.util.StringUtils; /** * @author Gunter Zeilinger <gunterze@gmail.com> * */ public class UserIdentityRQ { public static final int USERNAME = 1; public static final int USERNAME_PASSCODE = 2; public static final int KERBEROS = 3; public static final int SAML = 4; private static final String[] TYPES = { "0", "1 - Username", "2 - Username and passcode", "3 - Kerberos Service ticket", "4 - SAML Assertion" }; private final int type; private final boolean rspReq; private final byte[] primaryField; private final byte[] secondaryField; public UserIdentityRQ(int type, boolean rspReq, byte[] primaryField, byte[] secondaryField) { this.type = type; this.rspReq = rspReq; this.primaryField = primaryField.clone(); this.secondaryField = secondaryField != null ? secondaryField.clone() : new byte[0]; } public UserIdentityRQ(int type, boolean rspReq, byte[] primaryField) { this(type, rspReq, primaryField, null); } public UserIdentityRQ(String username, char[] passcode) { this(USERNAME_PASSCODE, true, toBytes(username), toBytes(new String(passcode))); } public UserIdentityRQ(String username, boolean rspReq) { this(USERNAME, rspReq, toBytes(username)); } private static String typeAsString(int type) { try { return TYPES[type]; } catch (IndexOutOfBoundsException e) { return Integer.toString(type); } } public final int getType() { return type; } public final boolean isPositiveResponseRequested() { return rspReq; } public final byte[] getPrimaryField() { return primaryField.clone(); } public final byte[] getSecondaryField() { return secondaryField.clone(); } public final String getUsername() { return toString(primaryField); } public final char[] getPasscode() { return toString(secondaryField).toCharArray(); } private static byte[] toBytes(String s) { try { return s.getBytes("UTF-8"); } catch (UnsupportedEncodingException e) { throw new Error(e); } } private static String toString(byte[] b) { try { return new String(b, "UTF-8"); } catch (UnsupportedEncodingException e) { throw new Error(e); } } public int length() { return 6 + primaryField.length + secondaryField.length; } @Override public String toString() { return promptTo(new StringBuilder()).toString(); } StringBuilder promptTo(StringBuilder sb) { sb.append(" UserIdentity[") .append(StringUtils.LINE_SEPARATOR) .append(" type: ") .append(typeAsString(type)) .append(StringUtils.LINE_SEPARATOR); if (type == USERNAME || type == USERNAME_PASSCODE) sb.append(" username: ") .append(getUsername()); else sb.append(" primaryField: byte[") .append(primaryField.length) .append(']'); if (type == USERNAME_PASSCODE) { sb.append(StringUtils.LINE_SEPARATOR) .append(" passcode: "); for (int i = secondaryField.length; --i >= 0;) sb.append('*'); } else if (secondaryField.length > 0) { sb.append(StringUtils.LINE_SEPARATOR) .append(" secondaryField: byte[") .append(secondaryField.length) .append(']'); } return sb.append(StringUtils.LINE_SEPARATOR) .append(" ]"); } }