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

com.aoindustries.aoserv.client.signup.Request Maven / Gradle / Ivy

There is a newer version: 1.92.0
Show newest version
/*
 * aoserv-client - Java client for the AOServ Platform.
 * Copyright (C) 2007-2013, 2016, 2017, 2018, 2019, 2020  AO Industries, Inc.
 *     [email protected]
 *     7262 Bull Pen Cir
 *     Mobile, AL 36695
 *
 * This file is part of aoserv-client.
 *
 * aoserv-client is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * aoserv-client is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with aoserv-client.  If not, see .
 */
package com.aoindustries.aoserv.client.signup;

import com.aoindustries.aoserv.client.CachedObjectIntegerKey;
import com.aoindustries.aoserv.client.account.Account;
import com.aoindustries.aoserv.client.account.Administrator;
import com.aoindustries.aoserv.client.account.User;
import com.aoindustries.aoserv.client.billing.PackageDefinition;
import com.aoindustries.aoserv.client.pki.EncryptionKey;
import com.aoindustries.aoserv.client.reseller.Brand;
import com.aoindustries.aoserv.client.schema.AoservProtocol;
import com.aoindustries.aoserv.client.schema.Table;
import com.aoindustries.io.stream.StreamableInput;
import com.aoindustries.io.stream.StreamableOutput;
import com.aoindustries.lang.Strings;
import com.aoindustries.net.Email;
import com.aoindustries.net.InetAddress;
import com.aoindustries.sql.UnmodifiableTimestamp;
import com.aoindustries.util.InternUtils;
import com.aoindustries.validation.ValidationException;
import java.io.IOException;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;
import java.util.Objects;

/**
 * Stores a single sign-up request.
 *
 * @author  AO Industries, Inc.
 */
final public class Request extends CachedObjectIntegerKey {

	static final int
		COLUMN_PKEY=0,
		COLUMN_BRAND=1
	;
	static final String COLUMN_BRAND_name = "brand";
	static final String COLUMN_TIME_name = "time";

	private Account.Name brand;
	private UnmodifiableTimestamp time;
	private InetAddress ip_address;
	private int package_definition;
	private String business_name;
	private String business_phone;
	private String business_fax;
	private String business_address1;
	private String business_address2;
	private String business_city;
	private String business_state;
	private String business_country;
	private String business_zip;
	private String ba_name;
	private String ba_title;
	private String ba_work_phone;
	private String ba_cell_phone;
	private String ba_home_phone;
	private String ba_fax;
	private Email ba_email;
	private String ba_address1;
	private String ba_address2;
	private String ba_city;
	private String ba_state;
	private String ba_country;
	private String ba_zip;
	private User.Name ba_username;
	private String billing_contact;
	private Email billing_email;
	private boolean billing_use_monthly;
	private boolean billing_pay_one_year;
	private String encrypted_data;
	private int encryption_from;
	private int encryption_recipient;
	private User.Name completed_by;
	private UnmodifiableTimestamp completed_time;

	// These are not pulled from the database, but are decrypted from encrypted_data by GPG
	transient private String decryptPassphrase;
	transient private String ba_password;
	transient private String billing_cardholder_name;
	transient private String billing_card_number;
	transient private String billing_expiration_month;
	transient private String billing_expiration_year;
	transient private String billing_street_address;
	transient private String billing_city;
	transient private String billing_state;
	transient private String billing_zip;

	@Override
	protected Object getColumnImpl(int i) {
		switch(i) {
			case COLUMN_PKEY: return pkey;
			case COLUMN_BRAND: return brand;
			case 2: return time;
			case 3: return ip_address;
			case 4: return package_definition;
			case 5: return business_name;
			case 6: return business_phone;
			case 7: return business_fax;
			case 8: return business_address1;
			case 9: return business_address2;
			case 10: return business_city;
			case 11: return business_state;
			case 12: return business_country;
			case 13: return business_zip;
			case 14: return ba_name;
			case 15: return ba_title;
			case 16: return ba_work_phone;
			case 17: return ba_cell_phone;
			case 18: return ba_home_phone;
			case 19: return ba_fax;
			case 20: return ba_email;
			case 21: return ba_address1;
			case 22: return ba_address2;
			case 23: return ba_city;
			case 24: return ba_state;
			case 25: return ba_country;
			case 26: return ba_zip;
			case 27: return ba_username;
			case 28: return billing_contact;
			case 29: return billing_email;
			case 30: return billing_use_monthly;
			case 31: return billing_pay_one_year;
			case 32: return encrypted_data;
			case 33: return encryption_from;
			case 34: return encryption_recipient;
			case 35: return completed_by;
			case 36: return completed_time;
			default: throw new IllegalArgumentException("Invalid index: " + i);
		}
	}

	@Override
	public Table.TableID getTableID() {
		return Table.TableID.SIGNUP_REQUESTS;
	}

	@Override
	public void init(ResultSet result) throws SQLException {
		try {
			int pos = 1;
			pkey = result.getInt(pos++);
			brand = Account.Name.valueOf(result.getString(pos++));
			time = UnmodifiableTimestamp.valueOf(result.getTimestamp(pos++));
			ip_address=InetAddress.valueOf(result.getString(pos++));
			package_definition=result.getInt(pos++);
			business_name=result.getString(pos++);
			business_phone=result.getString(pos++);
			business_fax=result.getString(pos++);
			business_address1=result.getString(pos++);
			business_address2=result.getString(pos++);
			business_city=result.getString(pos++);
			business_state=result.getString(pos++);
			business_country=result.getString(pos++);
			business_zip=result.getString(pos++);
			ba_name=result.getString(pos++);
			ba_title=result.getString(pos++);
			ba_work_phone=result.getString(pos++);
			ba_cell_phone=result.getString(pos++);
			ba_home_phone=result.getString(pos++);
			ba_fax=result.getString(pos++);
			ba_email=Email.valueOf(result.getString(pos++));
			ba_address1=result.getString(pos++);
			ba_address2=result.getString(pos++);
			ba_city=result.getString(pos++);
			ba_state=result.getString(pos++);
			ba_country=result.getString(pos++);
			ba_zip=result.getString(pos++);
			ba_username = User.Name.valueOf(result.getString(pos++));
			billing_contact=result.getString(pos++);
			billing_email=Email.valueOf(result.getString(pos++));
			billing_use_monthly=result.getBoolean(pos++);
			billing_pay_one_year=result.getBoolean(pos++);
			encrypted_data=result.getString(pos++);
			encryption_from=result.getInt(pos++);
			encryption_recipient=result.getInt(pos++);
			completed_by = User.Name.valueOf(result.getString(pos++));
			completed_time = UnmodifiableTimestamp.valueOf(result.getTimestamp(pos++));
		} catch(ValidationException e) {
			throw new SQLException(e);
		}
	}

	@Override
	public void read(StreamableInput in, AoservProtocol.Version protocolVersion) throws IOException {
		try {
			pkey=in.readCompressedInt();
			brand=Account.Name.valueOf(in.readUTF()).intern();
			time = in.readUnmodifiableTimestamp();
			ip_address=InetAddress.valueOf(in.readUTF());
			package_definition=in.readCompressedInt();
			business_name=in.readUTF();
			business_phone=in.readUTF();
			business_fax=in.readNullUTF();
			business_address1=in.readUTF();
			business_address2=in.readNullUTF();
			business_city=in.readUTF();
			business_state=InternUtils.intern(in.readNullUTF());
			business_country=in.readUTF().intern();
			business_zip=in.readNullUTF();
			ba_name=in.readUTF();
			ba_title=in.readNullUTF();
			ba_work_phone=in.readUTF();
			ba_cell_phone=in.readNullUTF();
			ba_home_phone=in.readNullUTF();
			ba_fax=in.readNullUTF();
			ba_email=Email.valueOf(in.readUTF());
			ba_address1=in.readNullUTF();
			ba_address2=in.readNullUTF();
			ba_city=in.readNullUTF();
			ba_state=InternUtils.intern(in.readNullUTF());
			ba_country=InternUtils.intern(in.readNullUTF());
			ba_zip=in.readNullUTF();
			ba_username = User.Name.valueOf(in.readUTF()).intern();
			billing_contact=in.readUTF();
			billing_email=Email.valueOf(in.readUTF());
			billing_use_monthly=in.readBoolean();
			billing_pay_one_year=in.readBoolean();
			encrypted_data=in.readUTF();
			encryption_from=in.readCompressedInt();
			encryption_recipient=in.readCompressedInt();
			completed_by = InternUtils.intern(User.Name.valueOf(in.readNullUTF()));
			completed_time = in.readNullUnmodifiableTimestamp();
		} catch(ValidationException e) {
			throw new IOException(e);
		}
	}

	@Override
	public void write(StreamableOutput out, AoservProtocol.Version protocolVersion) throws IOException {
		out.writeCompressedInt(pkey);
		out.writeUTF(brand.toString());
		if(protocolVersion.compareTo(AoservProtocol.Version.VERSION_1_83_0) < 0) {
			out.writeLong(time.getTime());
		} else {
			out.writeTimestamp(time);
		}
		out.writeUTF(ip_address.toString());
		out.writeCompressedInt(package_definition);
		out.writeUTF(business_name);
		out.writeUTF(business_phone);
		out.writeNullUTF(business_fax);
		out.writeUTF(business_address1);
		out.writeNullUTF(business_address2);
		out.writeUTF(business_city);
		out.writeNullUTF(business_state);
		out.writeUTF(business_country);
		out.writeNullUTF(business_zip);
		out.writeUTF(ba_name);
		out.writeNullUTF(ba_title);
		out.writeUTF(ba_work_phone);
		out.writeNullUTF(ba_cell_phone);
		out.writeNullUTF(ba_home_phone);
		out.writeNullUTF(ba_fax);
		out.writeUTF(ba_email.toString());
		out.writeNullUTF(ba_address1);
		out.writeNullUTF(ba_address2);
		out.writeNullUTF(ba_city);
		out.writeNullUTF(ba_state);
		out.writeNullUTF(ba_country);
		out.writeNullUTF(ba_zip);
		out.writeUTF(ba_username.toString());
		out.writeUTF(billing_contact);
		out.writeUTF(billing_email.toString());
		out.writeBoolean(billing_use_monthly);
		out.writeBoolean(billing_pay_one_year);
		out.writeUTF(encrypted_data);
		if(protocolVersion.compareTo(AoservProtocol.Version.VERSION_1_31)>=0) out.writeCompressedInt(encryption_from);
		out.writeCompressedInt(encryption_recipient); // Used to be called encryption_key
		out.writeNullUTF(Objects.toString(completed_by, null));
		if(protocolVersion.compareTo(AoservProtocol.Version.VERSION_1_83_0) < 0) {
			out.writeLong(completed_time == null ? -1 : completed_time.getTime());
		} else {
			out.writeNullTimestamp(completed_time);
		}
	}

	public Brand getBrand() throws SQLException, IOException {
		Brand br = table.getConnector().getReseller().getBrand().get(brand);
		if(br == null) throw new SQLException("Unable to find Brand: " + brand);
		return br;
	}

	public UnmodifiableTimestamp getTime() {
		return time;
	}

	public InetAddress getIpAddress() {
		return ip_address;
	}

	public PackageDefinition getPackageDefinition() throws SQLException, IOException {
		PackageDefinition pd = table.getConnector().getBilling().getPackageDefinition().get(package_definition);
		if(pd == null) throw new SQLException("Unable to find PackageDefinition: "+package_definition);
		return pd;
	}

	public String getBusinessName() {
		return business_name;
	}

	public String getBusinessPhone() {
		return business_phone;
	}

	public String getBusinessFax() {
		return business_fax;
	}

	public String getBusinessAddress1() {
		return business_address1;
	}

	public String getBusinessAddress2() {
		return business_address2;
	}

	public String getBusinessCity() {
		return business_city;
	}

	public String getBusinessState() {
		return business_state;
	}

	public String getBusinessCountry() {
		return business_country;
	}

	public String getBusinessZip() {
		return business_zip;
	}

	public String getBaName() {
		return ba_name;
	}

	public String getBaTitle() {
		return ba_title;
	}

	public String getBaWorkPhone() {
		return ba_work_phone;
	}

	public String getBaCellPhone() {
		return ba_cell_phone;
	}

	public String getBaHomePhone() {
		return ba_home_phone;
	}

	public String getBaFax() {
		return ba_fax;
	}

	public Email getBaEmail() {
		return ba_email;
	}

	public String getBaAddress1() {
		return ba_address1;
	}

	public String getBaAddress2() {
		return ba_address2;
	}

	public String getBaCity() {
		return ba_city;
	}

	public String getBaState() {
		return ba_state;
	}

	public String getBaCountry() {
		return ba_country;
	}

	public String getBaZip() {
		return ba_zip;
	}

	public User.Name getBaUsername() {
		return ba_username;
	}

	public String getBillingContact() {
		return billing_contact;
	}

	public Email getBillingEmail() {
		return billing_email;
	}

	public boolean getBillingUseMonthly() {
		return billing_use_monthly;
	}

	public boolean getBillingPayOneYear() {
		return billing_pay_one_year;
	}

	public EncryptionKey getEncryptionFrom() throws SQLException, IOException {
		EncryptionKey ek = table.getConnector().getPki().getEncryptionKey().get(encryption_from);
		if(ek == null) throw new SQLException("Unable to find EncryptionKey: "+encryption_from);
		return ek;
	}

	public EncryptionKey getEncryptionRecipient() throws SQLException, IOException {
		EncryptionKey er = table.getConnector().getPki().getEncryptionKey().get(encryption_recipient);
		if(er == null) throw new SQLException("Unable to find EncryptionKey: "+encryption_recipient);
		return er;
	}

	public Administrator getCompletedBy() throws IOException, SQLException {
		if(completed_by == null) return null;
		// May be filtered, null is OK
		return table.getConnector().getAccount().getAdministrator().get(completed_by);
	}

	public UnmodifiableTimestamp getCompletedTime() {
		return completed_time;
	}

	synchronized public String getBaPassword(String passphrase) throws IOException, SQLException {
		decrypt(passphrase);
		return ba_password;
	}

	synchronized public String getBillingCardholderName(String passphrase) throws IOException, SQLException {
		decrypt(passphrase);
		return billing_cardholder_name;
	}

	synchronized public String getBillingCardNumber(String passphrase) throws IOException, SQLException {
		decrypt(passphrase);
		return billing_card_number;
	}

	synchronized public String getBillingExpirationMonth(String passphrase) throws IOException, SQLException {
		decrypt(passphrase);
		return billing_expiration_month;
	}

	synchronized public String getBillingExpirationYear(String passphrase) throws IOException, SQLException {
		decrypt(passphrase);
		return billing_expiration_year;
	}

	synchronized public String getBillingStreetAddress(String passphrase) throws IOException, SQLException {
		decrypt(passphrase);
		return billing_street_address;
	}

	synchronized public String getBillingCity(String passphrase) throws IOException, SQLException {
		decrypt(passphrase);
		return billing_city;
	}

	synchronized public String getBillingState(String passphrase) throws IOException, SQLException {
		decrypt(passphrase);
		return billing_state;
	}

	synchronized public String getBillingZip(String passphrase) throws IOException, SQLException {
		decrypt(passphrase);
		return billing_zip;
	}

	synchronized private void decrypt(String passphrase) throws IOException, SQLException {
		// If a different passphrase is provided, don't use the cached values, clear, and re-decrypt
		if(decryptPassphrase==null || !passphrase.equals(decryptPassphrase)) {
			// Clear first just in case there is a problem in part of the decryption
			decryptPassphrase=null;
			ba_password=null;
			billing_cardholder_name=null;
			billing_card_number=null;
			billing_expiration_month=null;
			billing_expiration_year=null;
			billing_street_address=null;
			billing_city=null;
			billing_state=null;
			billing_zip=null;

			// Perform the decryption
			String decrypted = getEncryptionRecipient().decrypt(encrypted_data, passphrase);

			// Parse
			List lines = Strings.splitLines(decrypted);

			// Store the values
			if(lines.size()==9) {
				// 9-line format
				ba_password=lines.get(0);
				billing_cardholder_name=lines.get(1);
				billing_card_number=lines.get(2);
				billing_expiration_month=lines.get(3);
				billing_expiration_year=lines.get(4);
				billing_street_address=lines.get(5);
				billing_city=lines.get(6);
				billing_state=lines.get(7);
				billing_zip=lines.get(8);
			} else {
				throw new IOException("Unexpected number of lines after decryption: "+lines.size());
			}
			decryptPassphrase=passphrase;
		}
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy