]> git.mxchange.org Git - friendica.git/blobdiff - boot.php
improve performance of photo upload page
[friendica.git] / boot.php
index 17fd628fca70e6e03f88a7256e16225628830883..1809df966c130946a9c9a4ca2cf05993583e291b 100644 (file)
--- a/boot.php
+++ b/boot.php
@@ -9,11 +9,12 @@ require_once('include/pgettext.php');
 require_once('include/nav.php');
 require_once('include/cache.php');
 require_once('library/Mobile_Detect/Mobile_Detect.php');
+require_once('include/features.php');
 
 define ( 'FRIENDICA_PLATFORM',     'Friendica');
-define ( 'FRIENDICA_VERSION',      '3.0.1521' );
+define ( 'FRIENDICA_VERSION',      '3.0.1538' );
 define ( 'DFRN_PROTOCOL_VERSION',  '2.23'    );
-define ( 'DB_UPDATE_VERSION',      1156      );
+define ( 'DB_UPDATE_VERSION',      1157      );
 
 define ( 'EOL',                    "<br />\r\n"     );
 define ( 'ATOM_TIME',              'Y-m-d\TH:i:s\Z' );
@@ -359,6 +360,7 @@ if(! class_exists('App')) {
 
                public $category;
 
+
                // Allow themes to control internal parameters
                // by changing App values in theme.php
 
@@ -437,8 +439,9 @@ if(! class_exists('App')) {
                                if(isset($path) && strlen($path) && ($path != $this->path))
                                        $this->path = $path;
                        }
-                       if (is_array($argv) && $argc>1 && !x($_SERVER,'SERVER_NAME') && substr(end($argv), 0, 4)=="http" ) {
+                       if (is_array($argv) && $argc>1 && substr(end($argv), 0, 4)=="http" ) {
                                $this->set_baseurl(array_pop($argv) );
+                               $argc --;
                        }
 
                        set_include_path(
@@ -1009,6 +1012,13 @@ if(! function_exists('remote_user')) {
 // a page is loaded. Usually used for errors or alerts.
 
 if(! function_exists('notice')) {
+       /**
+        * Show an error message to user.
+        * 
+        * This function save text in session, to be shown to the user at next page load
+        * 
+        * @param string $s - Text of notice
+        */
        function notice($s) {
                $a = get_app();
                if(! x($_SESSION,'sysmsg'))     $_SESSION['sysmsg'] = array();
@@ -1017,6 +1027,13 @@ if(! function_exists('notice')) {
        }
 }
 if(! function_exists('info')) {
+       /**
+        * Show an info message to user.
+        * 
+        * This function save text in session, to be shown to the user at next page load
+        * 
+        * @param string $s - Text of notice
+        */
        function info($s) {
                $a = get_app();
                if(! x($_SESSION,'sysmsg_info')) $_SESSION['sysmsg_info'] = array();
@@ -1217,7 +1234,7 @@ if(! function_exists('profile_sidebar')) {
 
 
                // show edit profile to yourself
-               if ($profile['uid'] == local_user()) {
+               if ($profile['uid'] == local_user() && feature_enabled(local_user(),'multi_profiles')) {
                        $profile['edit'] = array($a->get_baseurl(). '/profiles', t('Profiles'),"", t('Manage/edit profiles'));
                
                        $r = q("SELECT * FROM `profile` WHERE `uid` = %d",
@@ -1833,3 +1850,54 @@ function random_digits($digits) {
        }
        return $rn;
 }
+
+function get_cachefile($file, $writemode = true) {
+       $cache = get_config("system","itemcache");
+
+       if ($cache == "")
+               return("");
+
+       if (!is_dir($cache))
+               return("");
+
+       $subfolder = $cache."/".substr($file, 0, 2);
+
+       $cachepath = $subfolder."/".$file;
+
+       if ($writemode) {
+               if (!is_dir($subfolder)) {
+                       mkdir($subfolder);
+                       chmod($subfolder, 0777);
+               }
+       }
+
+       return($cachepath);
+}
+
+function clear_cache($basepath = "", $path = "") {
+       if ($path == "") {
+               $basepath = get_config('system','itemcache');
+               $path = $basepath;
+       }
+
+       if (($path == "") OR (!is_dir($path)))
+               return;
+
+       if (substr(realpath($path), 0, strlen($basepath)) != $basepath)
+               return;
+
+       $cachetime = (int)get_config('system','itemcache_duration');
+       if ($cachetime == 0)
+               $cachetime = 86400;
+
+       if ($dh = opendir($path)) {
+               while (($file = readdir($dh)) !== false) {
+                       $fullpath = $path."/".$file;
+                       if ((filetype($fullpath) == "dir") and ($file != ".") and ($file != ".."))
+                               clear_cache($basepath, $fullpath);
+                       if ((filetype($fullpath) == "file") and filectime($fullpath) < (time() - $cachetime))
+                               unlink($fullpath);
+               }
+               closedir($dh);
+       }
+}