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

com.izforge.izpack.util.PortValidator Maven / Gradle / Ivy

/*
 * IzPack - Copyright 2001-2008 Julien Ponge, All Rights Reserved.
 * 
 * http://izpack.org/
 * http://izpack.codehaus.org/
 * 
 * Copyright 2004 Thorsten Kamann
 * 
 * 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
 * 
 *     http://www.apache.org/licenses/LICENSE-2.0
 *     
 * 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.izforge.izpack.util;

import com.izforge.izpack.panels.ProcessingClient;
import com.izforge.izpack.panels.Validator;

import java.net.InetAddress;
import java.net.ServerSocket;

/**
 * A validator to check whether a port is available (free) on the localhost.
 * 

* This validator can be used for rule input fields in the UserInputPanel to make sure that the port * the user entered is not in use. * * @author thorque */ public class PortValidator implements Validator { public boolean validate(ProcessingClient client) { InetAddress inet = null; String host = "localhost"; boolean retValue = false; int numfields = client.getNumFields(); for (int i = 0; i < numfields; i++) { String value = client.getFieldContents(i); if ((value == null) || (value.length() == 0)) { return false; } try { inet = InetAddress.getByName(host); ServerSocket socket = new ServerSocket(Integer.parseInt(value), 0, inet); retValue = socket.getLocalPort() > 0; if (!retValue) { break; } socket.close(); } catch (Exception ex) { retValue = false; } } return retValue; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy