<?php
-// $Id: SpamPickupTest.php,v 1.7 2008/12/31 15:44:14 henoheno Exp $
+// $Id: SpamPickupTest.php,v 1.8 2009/01/02 09:30:50 henoheno Exp $
// Copyright (C) 2007 heno
//
// Design test case for spam.php (called from runner.php)
$this->assertEquals('sss', $results[0]['host']);
$this->assertEquals('foo.html', $results[0]['file']);
- // uri_pickup_normalize_pathtofile()
+ // uri_pickup_normalize_pathfile()
$test_string = ' http://example.com/path/to/directory-accidentally-not-ended-with-slash ';
- $results = uri_pickup_normalize_pathtofile(uri_pickup($test_string));
- $this->assertEquals('/path/to/directory-accidentally-not-ended-with-slash',
- $results[0]['pathtofile']);
- $this->assertEquals(FALSE, isset($results[0]['path']));
+ $results = uri_pickup_normalize_pathfile(uri_pickup($test_string));
+ $this->assertEquals('/path/to/directory-accidentally-not-ended-with-slash', $results[0]['path']);
+ $this->assertEquals(TRUE, isset($results[0]['path']));
$this->assertEquals(FALSE, isset($results[0]['file']));
+ $this->assertEquals('http://example.com/path/to/directory-accidentally-not-ended-with-slash',
+ uri_pickup_implode($results[0]));
}
function testFunc_spam_uri_pickup()
<?php
-// $Id: checker.php,v 1.4 2008/12/30 11:15:10 henoheno Exp $
+// $Id: checker.php,v 1.5 2009/01/02 09:30:50 henoheno Exp $
// Concept-work of spam-uri metrics
// Copyright (C) 2006-2007 PukiWiki Developers Team
// License: GPL v2 or (at your option) any later version
echo '<pre>';
$results = spam_uri_pickup($msg);
$results = uri_pickup_normalize($results);
+ $results = uri_pickup_normalize_pathfile($results);
echo '$results:' . "\n";
echo htmlspecialchars(var_export($results, TRUE));
echo '</pre>';
<?php
-// $Id: spam_pickup.php,v 1.65 2008/12/31 15:44:14 henoheno Exp $
+// $Id: spam_pickup.php,v 1.66 2009/01/02 09:30:50 henoheno Exp $
// Copyright (C) 2006-2007 PukiWiki Developers Team
// License: GPL v2 or (at your option) any later version
//
'[a-z0-9_-][a-z0-9_.-]+[a-z0-9_-]' . // hostname(FQDN) : foo.example.org
')' .
'(?::([0-9]*))?' . // 4: Port
- '((?:/+[^\s<>"\'\[\]/\#]+)*/+)?' . // 5: Directory path or path-info
+ '((?:/+[^\s<>"\'\[\]/\#]+)*/+)?' . // 5: Directory path
'([^\s<>"\'\[\]\#?]+)?' . // 6: File?
'(?:\?([^\s<>"\'\[\]\#]+))?' . // 7: Query string
'(?:\#([a-z0-9._~%!$&\'()*+,;=:@-]*))?' . // 8: Fragment
$tmp[] = ':';
$tmp[] = & $uri['port'];
}
- if (isset($uri['pathtofile']) && $uri['pathtofile'] !== '') {
- $tmp[] = & $uri['pathtofile'];
- } else {
- if (isset($uri['path']) && $uri['path'] !== '') {
- $tmp[] = & $uri['path'];
- }
- if (isset($uri['file']) && $uri['file'] !== '') {
- $tmp[] = & $uri['file'];
- }
+ if (isset($uri['path']) && $uri['path'] !== '') {
+ $tmp[] = & $uri['path'];
+ }
+ if (isset($uri['file']) && $uri['file'] !== '') {
+ $tmp[] = & $uri['file'];
}
if (isset($uri['query']) && $uri['query'] !== '') {
$tmp[] = '?';
// Normalize an array of URI arrays
// NOTE: Give me the uri_pickup() results
-function uri_pickup_normalize(& $pickups, $destructive = TRUE, $pathtofile = FALSE)
+function uri_pickup_normalize(& $pickups, $destructive = TRUE, $pathfile = FALSE)
{
if (! is_array($pickups)) return $pickups;
}
}
- if ($pathtofile) {
- return uri_pickup_normalize_pathtofile($pickups, TRUE);
+ if ($pathfile) {
+ return uri_pickup_normalize_pathfile($pickups);
} else {
return $pickups;
}
}
-// Normalize: 'path' + 'file' = 'pathtofile'
-// In some case, 'file' DOES NOT mean _filename_.
+// Normalize: 'path' + 'file' = 'path' (Similar structure using PHP's "parse_url()" function)
+// NOTE: In some case, 'file' DOES NOT mean _filename_.
// [EXAMPLE] http://example.com/path/to/directory-accidentally-not-ended-with-slash
-function uri_pickup_normalize_pathtofile(& $pickups, $removeoriginal = TRUE)
+function uri_pickup_normalize_pathfile(& $pickups)
{
if (! is_array($pickups)) return $pickups;
foreach (array_keys($pickups) as $key) {
$_key = & $pickups[$key];
- if (! isset($_key['pathtofile']) && isset($_key['path'], $_key['file'])) {
- $_key['pathtofile'] = $_key['path'] . $_key['file'];
- if ($removeoriginal) unset($_key['path'], $_key['file']);
+ if (isset($_key['path'], $_key['file'])) {
+ $_key['path'] = $_key['path'] . $_key['file'];
+ unset($_key['file']);
}
}