<?php
/**********************************************************************
Copyright (C) FrontAccounting, LLC.
- Released under the terms of the GNU Affero General Public License,
- AGPL, as published by the Free Software Foundation, either version
- 3 of the License, or (at your option) any later version.
+ Released under the terms of the GNU General Public License, GPL,
+ as published by the Free Software Foundation, either version 3
+ of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
- See the License here <http://www.gnu.org/licenses/agpl-3.0.html>.
+ See the License here <http://www.gnu.org/licenses/gpl-3.0.html>.
***********************************************************************/
- include_once($path_to_root . "/includes/db/connect_db.inc");
+include_once($path_to_root . "/includes/db/connect_db.inc");
- include_once($path_to_root . "/includes/reserved.inc");
- include_once($path_to_root . "/includes/errors.inc");
- include_once($path_to_root . "/includes/types.inc");
- include_once($path_to_root . "/includes/systypes.inc");
- include_once($path_to_root . "/includes/references.inc");
- include_once($path_to_root . "/includes/prefs/sysprefs.inc");
- include_once($path_to_root . "/includes/db/comments_db.inc");
- include_once($path_to_root . "/includes/db/sql_functions.inc");
+include_once($path_to_root . "/includes/errors.inc");
+include_once($path_to_root . "/includes/types.inc");
+include_once($path_to_root . "/includes/systypes.inc");
+include_once($path_to_root . "/includes/references.inc");
+include_once($path_to_root . "/includes/db/comments_db.inc");
+include_once($path_to_root . "/includes/db/sql_functions.inc");
+include_once($path_to_root . "/includes/db/audit_trail_db.inc");
+//include_once($path_to_root . "/includes/validation.inc");
- include_once($path_to_root . "/admin/db/users_db.inc");
- include_once($path_to_root . "/includes/ui/ui_view.inc");
- include_once($path_to_root . "/includes/ui/ui_controls.inc");
- include_once($path_to_root . "/installed_extensions.php");
+include_once($path_to_root . "/admin/db/users_db.inc");
+include_once($path_to_root . "/includes/ui/ui_view.inc");
+include_once($path_to_root . "/includes/ui/ui_controls.inc");
- function page($title, $no_menu=false, $is_index=false, $onload="", $js="", $script_only=false)
- {
+function page($title, $no_menu=false, $is_index=false, $onload="", $js="", $script_only=false)
+{
- global $path_to_root, $installed_extensions;
+ global $path_to_root, $page_security;
- $hide_menu = $no_menu;
- if ($no_menu==false && count($installed_extensions))
- {
- global $applications;
- foreach ($installed_extensions as $ext)
- {
- $s = $applications['system'];
- array_pop($applications);
- $applications[$ext['name']] = $ext['title'];;
- $applications['system'] = $s;
- }
- }
+ $hide_menu = $no_menu;
- include($path_to_root . "/includes/page/header.inc");
-
- page_header($title, $no_menu, $is_index, $onload, $js);
- error_box();
- if($script_only) {
- echo '<noscript>';
- echo display_heading(_('This page is usable only with javascript enabled browsers.'));
- echo '</noscript>';
- div_start('_page_body', null, true);
- } else {
- div_start('_page_body'); // whole page content for ajax reloading
- }
- }
+ include($path_to_root . "/includes/page/header.inc");
- function end_page($no_menu=false, $is_index=false)
- {
- global $path_to_root, $Ajax;
+ page_header($title, $no_menu, $is_index, $onload, $js);
+ check_page_security($page_security);
+// error_box();
+ if($script_only) {
+ echo '<noscript>';
+ echo display_heading(_('This page is usable only with javascript enabled browsers.'));
+ echo '</noscript>';
+ div_start('_page_body', null, true);
+ } else {
+ div_start('_page_body'); // whole page content for ajax reloading
+ }
+}
- $hide_menu = $no_menu;
+function end_page($no_menu=false, $is_index=false, $hide_back_link=false, $type_no=0, $trans_no=0)
+{
+ global $path_to_root;
- div_end(); // _page_body section
- include($path_to_root . "/includes/page/footer.inc");
+ if (!$is_index && !$hide_back_link && function_exists('hyperlink_back'))
+ hyperlink_back(true, $no_menu, $type_no, $trans_no);
+ div_end(); // end of _page_body section
- page_footer($no_menu, $is_index);
- }
+ include($path_to_root . "/includes/page/footer.inc");
+ page_footer($no_menu, $is_index, $hide_back_link);
+}
- function flush_dir($path) {
+function flush_dir($path, $wipe = false)
+{
$dir = opendir($path);
while(false !== ($fname = readdir($dir))) {
- if($fname=='.' || $fname=='..' || $fname=='index.php') continue;
+ if($fname=='.' || $fname=='..' || $fname=='CVS' || (!$wipe && $fname=='index.php')) continue;
if(is_dir($path.'/'.$fname)) {
- flush_dir($path.'/'.$fname);
- @rmdir($path.'/'.$fname);
+ flush_dir($path.'/'.$fname, $wipe);
+ if ($wipe) @rmdir($path.'/'.$fname);
} else
@unlink($path.'/'.$fname);
- }
- }
+ }
+}
- function cache_js_file($fpath, $text)
- {
+function cache_js_file($fpath, $text)
+{
global $go_debug;
if(!$go_debug) $text = js_compress($text);
if (!fwrite($file, $text)) return false;
return fclose($file);
- }
+}
- function add_js_file($filename)
- {
+function add_js_file($filename)
+{
global $js_static;
$search = array_search($filename, $js_static);
if ($search === false || $search === null) // php>4.2.0 returns null
$js_static[] = $filename;
- }
+}
- function add_js_ufile($filename)
- {
+function add_js_ufile($filename)
+{
global $js_userlib;
$search = array_search($filename, $js_userlib);
if ($search === false || $search === null) // php>4.2.0 returns null
$js_userlib[] = $filename;
- }
+}
- function add_js_source($text)
- {
+function add_js_source($text)
+{
global $js_lib;
$search = array_search($text, $js_lib);
if ($search === false || $search === null) // php>4.2.0 returns null
$js_lib[] = $text;
- }
+}
/**
* Compresses the Javascript code for more efficient delivery.
$inNormalComment = false;
//loop through line's characters and take out any literal strings, replace them with ___i___ where i is the index of this string
- for($j=0;$j<strlen($line);$j++)
+ $len = strlen($line);
+ for($j=0;$j<$len;$j++)
{
- $c = substr($line,$j,1);
- $d = substr($line,$j,2);
+ $c = $line[$j]; // this is _really_ faster than subst
+ $d = $c.$line[$j+1];
//look for start of quote
if(!$inQuote && !$inComment)
}
return $sJS;
}
-//-----------------------------------------------------------------------------
-// Inserts $elements into $array at position $index.
-// $elements is list of any objects
-//
-function array_insert(&$array, $index, $elements)
-{
- if (!is_array($elements)) $elements = array($elements);
- $head = array_splice($array, 0, $index);
- $array = array_merge($head, $elements, $array);
+/*
+ Check if file can be updated, restoring subdirectories
+ if needed. Returns 1 when no confilcts, -1 when file exists and is writable
+*/
+function check_write($path)
+{
+ if ($path == ''//|| $path == '.' || $path == '..'
+ ) return 0;
+
+ return is_writable($path) ? (is_dir($path) ? 1 : -1)
+ : ($path =='.' ? 0 : check_write(dirname($path)));
}
-function array_remove(&$array, $index, $len=1)
+/*
+ Copies set of files. When $strict is set
+ also removes files from the $to which
+ does not exists in $from directory but arelisted in $flist.
+*/
+function copy_files($flist, $from, $to, $strict=false)
{
- array_splice($array, $index, $len);
+ foreach ($flist as $file) {
+ if (file_exists($from.'/'.$file))
+ if (!copy_file($file, $from, $to))
+ return false;
+ if ($strict && !is_file($from.'/'.$file)) // if
+ unlink($to.'/'.$file);
+ }
+ return true;
}
-function array_replace(&$array, $index, $len, $elements)
+/*
+ Copies file from base to target directory, restoring subdirectories
+ if needed.
+*/
+function copy_file($file, $from, $to)
{
- array_splice($array, $index, $len);
- array_insert($array, $index, $elements);
+
+ if (!is_dir(dirname($file=='.' ? $to : ($to.'/'.$file)))) {
+ if (!copy_file(dirname($file), null, $to))
+ return false;
+ }
+ if (!$from) {
+ // error_log( 'dodanie katalogu '.$to.'/'.$file);
+ return @mkdir($file=='.' ? $to : ($to.'/'.$file));
+ }
+ else {
+ // error_log( 'skopiowanie '.$to.'/'.$file);
+ return @copy($from.'/'.$file, $to.'/'.$file);
+ }
}
+/*
+ Returns current path to company private folder.
+ (Current path can change after chdir).
+*/
+function company_path($comp=null)
+{
+ global $path_to_root, $comp_path;
+
+ if (!isset($comp))
+ $comp = user_company();
-function array_append(&$array, $elements)
+ // if path is relative, set current path_to_root
+ return ($comp_path[0]=='.' ? $path_to_root.'/'.basename($comp_path) : $comp_path)
+ . '/'.$comp;
+}
+/*
+ Search for file, looking first for company specific version, then for
+ version provided by any extension module, finally in main FA directory.
+ Also adds include path for any related files.
+
+ Returns found file path or null.
+*/
+function find_custom_file($rep)
{
- foreach($elements as $key => $el) {
- if(is_int($key))
- $array[] = $el;
- else
- $array[$key] = $el;
+ global $installed_extensions, $comp_path, $path_to_root;
+
+ // customized per company version
+ $path = company_path();
+ $file = $path.'/'.$rep;
+ if (file_exists($file)) {
+ // add local include path
+ set_include_path($path.PATH_SEPARATOR.get_include_path());
+ return $file;
}
+ // file added by active extension modules
+ if (count($installed_extensions) > 0)
+ {
+ $extensions = $installed_extensions;
+ foreach ($extensions as $ext)
+ if (($ext['active'] && $ext['type'] == 'extension')) {
+ $path = $path_to_root.'/'.$ext['path'];
+ $file = $path.$rep;
+ if (file_exists($file)) {
+ set_include_path($path.PATH_SEPARATOR.get_include_path());
+ return $file;
+ }
+ }
+ }
+ // standard location
+ $file = $path_to_root.$rep;
+ if (file_exists($file))
+ return $file;
+
+ return null;
}
+
?>
\ No newline at end of file