added:
[mir.git] / source / mir / util / InternetRoutines.java
1 /*
2  * Copyright (C) 2001, 2002  The Mir-coders group
3  *
4  * This file is part of Mir.
5  *
6  * Mir is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * Mir is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with Mir; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19  *
20  * In addition, as a special exception, The Mir-coders gives permission to link
21  * the code of this program with the com.oreilly.servlet library, any library
22  * licensed under the Apache Software License, The Sun (tm) Java Advanced
23  * Imaging library (JAI), The Sun JIMI library (or with modified versions of
24  * the above that use the same license as the above), and distribute linked
25  * combinations including the two.  You must obey the GNU General Public
26  * License in all respects for all of the code used other than the above
27  * mentioned libraries.  If you modify this file, you may extend this exception
28  * to your version of the file, but you are not obligated to do so.  If you do
29  * not wish to do so, delete this exception statement from your version.
30  */
31
32 package mir.util;
33
34 import java.net.InetAddress;
35 import java.net.UnknownHostException;
36 import java.util.List;
37
38 public class InternetRoutines {
39   protected InternetRoutines() {
40   }
41
42   public static boolean isIpAddressInNetwork(String anIpAddress, String aNetwork) throws Exception {
43     long ipAddress = parseHostNameOrIPAddress(anIpAddress);
44     long network = 0;
45     long netMask = (1L<<32)-1;
46     List networkParts = StringRoutines.separateString(aNetwork, "/");
47
48     network = parseHostNameOrIPAddress((String) networkParts.get(0));
49     if (networkParts.size()>=2) {
50       netMask=parseNetmask((String) networkParts.get(1));
51     }
52
53     return (ipAddress & netMask ) == (network & netMask);
54   }
55
56   public static long parseHostNameOrIPAddress(String aHostName) throws Exception {
57     InetAddress addr = InetAddress.getByName(aHostName.trim());
58     return
59         ((((long) addr.getAddress()[0])&255) << 24) +
60         ((((long) addr.getAddress()[1])&255) << 16) +
61         ((((long) addr.getAddress()[2])&255) << 8) +
62         ((((long) addr.getAddress()[3])&255));
63   }
64
65   public static long parseIPAddress(String anIpAddress) throws Exception {
66     int[] parts = {0,0,0,0};
67     int i;
68     List stringParts = StringRoutines.splitString(anIpAddress, ".");
69
70     if (stringParts.size()!=4)
71       throw new Exception("Not a valid IP Address: " + anIpAddress);
72
73     try {
74       for (i=0; i<4; i++) {
75         parts[i] = Integer.parseInt(((String) stringParts.get(i)).trim());
76       }
77     }
78     catch (Throwable t) {
79       throw new Exception("Not a valid IP Address: " + anIpAddress);
80     }
81     for (i=0; i<4; i++) {
82       if (parts[i]<0 || parts[i]>255)
83         throw new Exception("Not a valid IP Address: " + anIpAddress);
84     }
85
86     return parts[0]<<24 | parts[1]<<16 | parts[2]<<8 | parts[3];
87   }
88
89   public static long parseNetmask(String anIpAddress) throws Exception {
90     try {
91       return parseIPAddress(anIpAddress);
92     }
93     catch (Throwable t) {
94     }
95
96     try {
97       int size = Integer.parseInt(anIpAddress);
98
99       if (size<=32)
100         return ((1L<<size)-1)<<(32-size);
101     }
102     catch (Throwable t) {
103     }
104
105     return (1L<<32)-1;
106   }
107 }