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

com.aoindustries.aoserv.client.distribution.SoftwareVersionTable Maven / Gradle / Ivy

There is a newer version: 1.92.0
Show newest version
/*
 * aoserv-client - Java client for the AOServ Platform.
 * Copyright (C) 2001-2009, 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.distribution;

import com.aoindustries.aoserv.client.AOServConnector;
import com.aoindustries.aoserv.client.GlobalTableIntegerKey;
import com.aoindustries.aoserv.client.schema.Table;
import com.aoindustries.lang.Strings;
import com.aoindustries.sql.UnmodifiableTimestamp;
import java.io.IOException;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

/**
 * @see  SoftwareVersion
 *
 * @author  AO Industries, Inc.
 */
final public class SoftwareVersionTable extends GlobalTableIntegerKey {

	/**
	 * Fields used in an order by search.
	 */
	public static final int NONE = 0, NAME = 1, VERSION = 2, UPDATED = 3;

	/**
	 * Labels for the different sort orders.
	 */
	static final String[] orderLabels = { "None", "Name", "Version", "Updated" };

	public static final int NUM_ORDER_LABELS=4;

	private static UnmodifiableTimestamp maximumUpdatedTime = null;

	SoftwareVersionTable(AOServConnector connector) {
		super(connector, SoftwareVersion.class);
	}

	private static final OrderBy[] defaultOrderBy = {
		new OrderBy(SoftwareVersion.COLUMN_NAME_name, ASCENDING),
		new OrderBy(SoftwareVersion.COLUMN_VERSION_name, ASCENDING)
	};
	@Override
	protected OrderBy[] getDefaultOrderBy() {
		return defaultOrderBy;
	}

	@Override
	public void clearCache() {
		super.clearCache();
		synchronized(SoftwareVersionTable.class) {
			maximumUpdatedTime = null;
		}
	}

	@Override
	public SoftwareVersion get(int pkey) throws IOException, SQLException {
		return getUniqueRow(SoftwareVersion.COLUMN_PKEY, pkey);
	}

	public UnmodifiableTimestamp getMaximumUpdatedTime() throws IOException, SQLException {
		synchronized(SoftwareVersionTable.class) {
			if(maximumUpdatedTime == null) {
				List versions=getRows();
				int size=versions.size();
				UnmodifiableTimestamp max = null;
				for(int c=0;c 0) max = mod;
				}
				maximumUpdatedTime = max;
			}
			return maximumUpdatedTime;
		}
	}

	public static String getOrderLabel(int index) {
		return orderLabels[index];
	}

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

	SoftwareVersion getTechnologyVersion(Software techName, String version, OperatingSystemVersion osv) throws IOException, SQLException {
		String name=techName.getName();
		int osvPKey=osv.getPkey();
		List table=getRows();
		int size=table.size();
		for(int c=0;cArrayList of TechnologyClasses.
	 *                  Only the technologies that have any class are selected.
	 *                  If empty, all are selected.
	 * @param  version  if not {@code null} only the technologies that have every word in their version are selected
	 * @param  orderBy  the column that the results will be ordered by
	 *
	 * @return  a TechnologyVersion[] of all the matches
	 */
	public List getTechnologyVersions(OperatingSystemVersion osv, String name, List classes, String version, int orderBy) throws IOException, SQLException {
		// Prepare names
		String[] nameWords = null;
		if (name != null) {
			nameWords=Strings.split(name);
			int len = nameWords.length;
			for (int c = 0; c < len; c++) nameWords[c]=nameWords[c].toLowerCase();
		}

		// Version
		String[] versionWords = null;
		if (version != null) {
			versionWords = Strings.split(version);
			int len = versionWords.length;
			for (int c = 0; c < len; c++) versionWords[c]=versionWords[c].toLowerCase();
		}

		List table=getRows();
		List matches=new ArrayList<>();
		int tableSize=table.size();
		for(int c=0;c0) {
							List rowClasses=TV.getTechnologyName(connector).getTechnologies(connector);
							found=false;
						Loop:
							for (SoftwareCategory matchClass : classes) {
								for (SoftwareCategorization rowClass : rowClasses) {
									if (rowClass.getTechnologyClass(connector).equals(matchClass)) {
										found=true;
										break Loop;
									}
								}
							}
						}

						// Insert sorted to the correct place
						// This is a simple sort algorithm, not the fastest
						if(found) {
							int len=matches.size();
							int addAt=-1;
							for(int d=0;d 0) addAt=d;
								} else throw new IllegalArgumentException("Invalid value for orderBy: " + orderBy);
							}
							matches.add(addAt==-1?len:addAt, TV);
						}
					}
				}
			}
		}
		// Convert and return the matches
		return matches;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy