summaryrefslogtreecommitdiff
path: root/Postman/Postman-Connectivity-Test/registered-domain-libs-master/PHP/regDomain.class.php
blob: ffe492e694ef9d1be5d08123c2db0344148fa8ef (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
<?php

/*
 * Calculate the effective registered domain of a fully qualified domain name.
 *
 * <@LICENSE>
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to you 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.
 * </@LICENSE>
 *
 * Florian Sager, 25.07.2008, sager@agitos.de, http://www.agitos.de
 */

/*
 * Remove subdomains from a signing domain to get the registered domain.
 *
 * dkim-reputation.org blocks signing domains on the level of registered domains
 * to rate senders who use e.g. a.spamdomain.tld, b.spamdomain.tld, ... under
 * the most common identifier - the registered domain - finally.
 *
 * This function returns NULL if $signingDomain is TLD itself
 * 
 * $signingDomain has to be provided lowercase (!)
 */

class regDomain {
	/* tld tree */
	protected $tldTree = array();

	/* main function */
	public function getRegisteredDomain($signingDomain, $fallback = TRUE) {
		$signingDomainParts = explode('.', $signingDomain);

		$result = $this->findRegisteredDomain($signingDomainParts, $this->tldTree);

		if ($result===NULL || $result=="") {
			// this is an invalid domain name
			return NULL;
		}

		// assure there is at least 1 TLD in the stripped signing domain
		if (!strpos($result, '.')) {
			if ($fallback===FALSE) {
				return NULL;
			}
			$cnt = count($signingDomainParts);
			if ($cnt==1 || $signingDomainParts[$cnt-2]=="") return NULL;
			if (!$this->validDomainPart($signingDomainParts[$cnt-2]) || !$this->validDomainPart($signingDomainParts[$cnt-1])) return NULL;
			return $signingDomainParts[$cnt-2].'.'.$signingDomainParts[$cnt-1];
		}
		return $result;
	}

	/* validate parts */
	public function validDomainPart($domPart) {
		// see http://www.register.com/domain-extension-rules.rcmx
		$len = strlen($domPart);

		// not more than 63 characters
		if ($len>63) return FALSE;

		// not less than 1 characters --> there are TLD-specific rules that could be considered additionally
		if ($len<1) return FALSE;

		// Use only letters, numbers, or hyphen ("-")
		// not beginning or ending with a hypen (this is TLD specific, be aware!)
		if (!preg_match("/^([a-z0-9])(([a-z0-9-])*([a-z0-9]))*$/", $domPart)) return FALSE;

		return TRUE;
	}

	/* recursive helper method */
	public function findRegisteredDomain($remainingSigningDomainParts, &$treeNode) {
		$sub = array_pop($remainingSigningDomainParts);

		$result = NULL;
		if (isset($treeNode['!'])) {
			return '#';
		}

		if (!$this->validDomainPart($sub)) {
			return NULL;
		}

		if (is_array($treeNode) && array_key_exists($sub, $treeNode)) {
			$result = $this->findRegisteredDomain($remainingSigningDomainParts, $treeNode[$sub]);
		} else if (is_array($treeNode) && array_key_exists('*', $treeNode)) {
			$result = $this->findRegisteredDomain($remainingSigningDomainParts, $treeNode['*']);
		} else {
			return $sub;
		}

		// this is a hack 'cause PHP interpretes '' as NULL
		if ($result == '#') {
			return $sub;
		} else if (strlen($result)>0) {
			return $result.'.'.$sub;
		}
		return NULL;
	}

	/* load tld tree into object */
	function __construct() {
		/* include tld tree data */
		include(dirname(__FILE__) . '/effectiveTLDs.inc.php');
	}

}