aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--mod/profile/icondirect.php63
-rw-r--r--mod/profile/start.php23
2 files changed, 76 insertions, 10 deletions
diff --git a/mod/profile/icondirect.php b/mod/profile/icondirect.php
new file mode 100644
index 000000000..4d20de149
--- /dev/null
+++ b/mod/profile/icondirect.php
@@ -0,0 +1,63 @@
+<?php
+
+ /**
+ * Elgg profile icon
+ *
+ * @package ElggProfile
+ * @license http://www.gnu.org/licenses/old-licenses/gpl-2.0.html GNU Public License version 2
+ * @author Curverider Ltd <info@elgg.com>
+ * @copyright Curverider Ltd 2008-2009
+ * @link http://elgg.com/
+ */
+
+ // Get DB settings, connect
+ require_once(dirname(dirname(dirname(__FILE__))). '/engine/settings.php');
+
+ global $CONFIG;
+
+ $contents = '';
+
+ if ($dblink = @mysql_connect($CONFIG->dbhost,$CONFIG->dbuser,$CONFIG->dbpass)) {
+
+
+ $username = $_GET['username'];
+ $username = preg_replace('/[^A-Za-z0-9\_\-]/i','',$username);
+ $userarray = str_split($username);
+
+ $matrix = '';
+ $length = 5;
+ if (sizeof($userarray) < $length) $length = sizeof($userarray);
+ for ($n = 0; $n < $length; $n++) {
+ $matrix .= $userarray[$n] . "/";
+ }
+
+ // Get the size
+ $size = strtolower($_GET['size']);
+ if (!in_array($size,array('large','medium','small','tiny','master','topbar')))
+ $size = "medium";
+
+ // Try and get the icon
+ if (@mysql_select_db($CONFIG->dbname,$dblink)) {
+ if ($result = mysql_query("select value from {$CONFIG->dbprefix}datalists where name = 'dataroot'",$dblink)) {
+ $row = mysql_fetch_object($result);
+ $dataroot = $row->value;
+ }
+ $filename = $dataroot . $matrix . "{$username}/profile/" . $username . $size . ".jpg";
+ $contents = @file_get_contents($filename);
+ }
+ }
+ if (empty($contents)) {
+
+ global $CONFIG;
+ $contents = @file_get_contents(dirname(__FILE__) . "/graphics/default{$size}.jpg");
+
+ }
+
+ header("Content-type: image/jpeg");
+ header('Expires: ' . date('r',time() + 864000));
+ header("Pragma: public");
+ header("Cache-Control: public");
+ header("Content-Length: " . strlen($contents));
+ echo $contents;
+
+?> \ No newline at end of file
diff --git a/mod/profile/start.php b/mod/profile/start.php
index f8899226b..671000f80 100644
--- a/mod/profile/start.php
+++ b/mod/profile/start.php
@@ -233,20 +233,23 @@
global $CONFIG;
if ((!$returnvalue) && ($hook == 'entity:icon:url') && ($params['entity'] instanceof ElggUser))
- {
+ {
+
$entity = $params['entity'];
$type = $entity->type;
$subtype = get_subtype_from_id($entity->subtype);
$viewtype = $params['viewtype'];
$size = $params['size'];
- $username = $entity->username;
-
- if ($icontime = $entity->icontime) {
- $icontime = "{$icontime}";
- } else {
- $icontime = "default";
- }
-
+ $username = $entity->username;
+
+ if ($icontime = $entity->icontime) {
+ $icontime = "{$icontime}";
+ } else {
+ $icontime = "default";
+ }
+
+ return $CONFIG->wwwroot . 'mod/profile/icondirect.php/'.$icontime.'/?username='.$entity->username.'&size='.$size;
+ /*
$filehandler = new ElggFile();
$filehandler->owner_guid = $entity->getGUID();
@@ -257,7 +260,7 @@
return $url;
- }
+ } */
}
}