2dd057b1db32649fe1d9ff9995cfc590272043db
[mir.git] / source / mir / util / InternetFunctions.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.util.List;
35
36 public class InternetFunctions {
37   private InternetFunctions() {
38   }
39
40   public static boolean isIpAddressInNetwork(String anIpAddress, String aNetwork) throws Exception {
41     long ipAddress = parseIPAddress(anIpAddress);
42     long network = 0;
43     long netMask = (1L<<32)-1;
44     List networkParts = StringRoutines.separateString(aNetwork, "/");
45
46     network = parseIPAddress((String) networkParts.get(0));
47     if (networkParts.size()>=2) {
48       netMask=parseNetmask((String) networkParts.get(1));
49     }
50
51     return (ipAddress & netMask ) == (network & netMask);
52   }
53
54   public static long parseIPAddress(String anIpAddress) throws Exception {
55     int[] parts = {0,0,0,0};
56     int i;
57     List stringParts = StringRoutines.splitString(anIpAddress, ".");
58
59     if (stringParts.size()!=4)
60       throw new Exception("Not a valid IP Address: " + anIpAddress);
61
62     try {
63       for (i=0; i<4; i++) {
64         parts[i] = Integer.parseInt((String) stringParts.get(i));
65       }
66     }
67     catch (Throwable t) {
68       throw new Exception("Not a valid IP Address: " + anIpAddress);
69     }
70     for (i=0; i<4; i++) {
71       if (parts[i]<0 || parts[i]>255)
72         throw new Exception("Not a valid IP Address: " + anIpAddress);
73     }
74
75     return parts[0]<<24 | parts[1]<<16 | parts[2]<<8 | parts[3];
76   }
77
78   public static long parseNetmask(String anIpAddress) throws Exception {
79     try {
80       return parseIPAddress(anIpAddress);
81     }
82     catch (Throwable t) {
83     }
84
85     try {
86       int size = Integer.parseInt(anIpAddress);
87
88       if (size<=32)
89         return ((1L<<size)-1)<<(32-size);
90     }
91     catch (Throwable t) {
92     }
93
94     return (1L<<32)-1;
95   }
96 }