Compare commits
100 Commits
v1.2.2
...
484444b97a
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
484444b97a | ||
| 6dc6a58765 | |||
| ca8da46a58 | |||
| a28e5244ab | |||
|
|
31acfd1ee4 | ||
|
|
f1155ad824 | ||
|
|
eef3a81be7 | ||
|
|
bf60e9fcbf | ||
| 7d42256a30 | |||
|
|
5226fbcfc3 | ||
|
|
87b9af9786 | ||
|
|
7981e3ab51 | ||
|
|
21b9b99197 | ||
|
|
d9df0d64b8 | ||
|
|
73cdbe27c0 | ||
| 759b5527f8 | |||
| 8417e60c9d | |||
| aec8a5ee70 | |||
| f34d4214f4 | |||
| a2b6f29886 | |||
| a95d28a09f | |||
|
|
57b1aae9b4 | ||
| 42b4112a5e | |||
| 63a2495183 | |||
|
|
717962edc5 | ||
|
|
dc692f14e4 | ||
| b1a30b6dde | |||
| 967af4dc37 | |||
|
|
7a8fdcdf07 | ||
|
|
a06320c42b | ||
|
|
f0ba8c3c50 | ||
|
|
2e85bf5ee8 | ||
|
|
ff94efee8d | ||
|
|
93f2cf9b73 | ||
|
|
c39e48a709 | ||
|
|
1cc010818d | ||
|
|
1e164f3b93 | ||
|
|
9f7ab65a15 | ||
|
|
c69607323a | ||
|
|
13a7900bd6 | ||
|
|
dc94fa1cd5 | ||
|
|
fd191877cd | ||
|
|
65a5785ce5 | ||
|
|
adcfaf5fa0 | ||
|
|
f7685463b4 | ||
|
|
dd92fa6031 | ||
|
|
6606f30ceb | ||
|
|
e1255e0872 | ||
|
|
5c53621f96 | ||
|
|
581518963b | ||
|
|
23735eba92 | ||
|
|
9eb78f40fd | ||
|
|
f599033a38 | ||
|
|
61f1b92bad | ||
|
|
1dfe246e0f | ||
|
|
d64e40ca2c | ||
|
|
6810c030e8 | ||
|
|
d7a6abd5b9 | ||
|
|
2a2221af31 | ||
|
|
03be3a317f | ||
|
|
bdcd83c579 | ||
|
|
f4f84bdd67 | ||
|
|
86535c23f1 | ||
|
|
5d146c1dfd | ||
|
|
82ca78d8b3 | ||
|
|
55f35868bd | ||
|
|
e0805c9dc6 | ||
|
|
a2129f91c5 | ||
|
|
adf46f620b | ||
|
|
31bef7a531 | ||
|
|
20b134231e | ||
|
|
236a415fb4 | ||
|
|
1551df058d | ||
|
|
f980b1e76a | ||
|
|
8de868fe4a | ||
|
|
a20df16c2c | ||
|
|
939ff2e4a5 | ||
|
|
1c3cc95fdb | ||
|
|
115e9ad700 | ||
|
|
3aaa9b3f0d | ||
|
|
799cff4e00 | ||
|
|
72ef4a24c5 | ||
|
|
0f44aaf3e4 | ||
|
|
795f69050a | ||
|
|
1c5bb8aebe | ||
|
|
36f19e64d0 | ||
|
|
19a1081197 | ||
|
|
45974a9e30 | ||
|
|
f1247efd34 | ||
|
|
c38346b97c | ||
|
|
3c26adb493 | ||
|
|
4458f366f9 | ||
|
|
805330638a | ||
|
|
86cd04f862 | ||
|
|
a182834985 | ||
|
|
0ce1432513 | ||
|
|
a447fc2ef6 | ||
|
|
8160d05d25 | ||
|
|
647dd52c92 | ||
|
|
b2fdbc0571 |
@@ -1,6 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# $Id: create_default_trigger.sh 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
# creates the default on update trigger for the inherited generic tables (date/name)
|
# creates the default on update trigger for the inherited generic tables (date/name)
|
||||||
|
|
||||||
orig_file="../tmpl/trigger.tmpl"
|
orig_file="../tmpl/trigger.tmpl"
|
||||||
|
|||||||
@@ -1,14 +1,13 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# $Id: drop_data.sh 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
# quick hack for import
|
# quick hack for import
|
||||||
|
|
||||||
#echo "EXIT";
|
#echo "EXIT";
|
||||||
#exit;
|
#exit;
|
||||||
|
|
||||||
db='cibavision_jp_cms';
|
db='<db name>';
|
||||||
host='db.tokyo.tequila.jp';
|
host='<db host>';
|
||||||
user='ciba_vision';
|
user='<db user>';
|
||||||
schemas="public dev";
|
schemas="public dev";
|
||||||
|
|
||||||
file_prefix="trg";
|
file_prefix="trg";
|
||||||
|
|||||||
@@ -1,7 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# $Id: drop_reload.sh 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
|
|
||||||
rm error;
|
rm error;
|
||||||
rm output;
|
rm output;
|
||||||
bin/drop_data.sh;
|
bin/drop_data.sh;
|
||||||
|
|||||||
@@ -1,14 +1,13 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# $Id: import_data.sh 4382 2013-02-18 07:27:24Z gullevek $
|
|
||||||
# quick hack for import
|
# quick hack for import
|
||||||
|
|
||||||
#echo "EXIT";
|
#echo "EXIT";
|
||||||
#exit;
|
#exit;
|
||||||
|
|
||||||
db='gullevek';
|
db='<db name>';
|
||||||
host='db.tokyo.tequila.jp';
|
host='<db host>';
|
||||||
user='gullevek';
|
user='<db user>';
|
||||||
#schema="publicv";
|
#schema="publicv";
|
||||||
|
|
||||||
for file in `cat ORDER`;
|
for file in `cat ORDER`;
|
||||||
|
|||||||
28
4dev/database/function/edit_set_access_uid.sql
Normal file
28
4dev/database/function/edit_set_access_uid.sql
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
-- add uid add for edit_access table
|
||||||
|
|
||||||
|
CREATE OR REPLACE FUNCTION set_edit_access_uid() RETURNS TRIGGER AS
|
||||||
|
$$
|
||||||
|
DECLARE
|
||||||
|
myrec RECORD;
|
||||||
|
v_uid VARCHAR;
|
||||||
|
BEGIN
|
||||||
|
-- skip if NEW.name is not set
|
||||||
|
IF NEW.name IS NOT NULL AND NEW.name <> '' THEN
|
||||||
|
-- use NEW.name as base, remove all spaces
|
||||||
|
-- name data is already unique, so we do not need to worry about this here
|
||||||
|
v_uid := REPLACE(NEW.name, ' ', '');
|
||||||
|
IF TG_OP = 'INSERT' THEN
|
||||||
|
-- always set
|
||||||
|
NEW.uid := v_uid;
|
||||||
|
ELSIF TG_OP = 'UPDATE' THEN
|
||||||
|
-- check if not set, then set
|
||||||
|
SELECT INTO myrec t.* FROM edit_access t WHERE edit_access_id = NEW.edit_access_id;
|
||||||
|
IF FOUND THEN
|
||||||
|
NEW.uid := v_uid;
|
||||||
|
END IF;
|
||||||
|
END IF;
|
||||||
|
END IF;
|
||||||
|
RETURN NEW;
|
||||||
|
END;
|
||||||
|
$$
|
||||||
|
LANGUAGE 'plpgsql';
|
||||||
12
4dev/database/function/set_generic.sql
Normal file
12
4dev/database/function/set_generic.sql
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
-- adds the created or updated date tags
|
||||||
|
|
||||||
|
CREATE OR REPLACE FUNCTION set_generic() RETURNS TRIGGER AS '
|
||||||
|
BEGIN
|
||||||
|
IF TG_OP = ''INSERT'' THEN
|
||||||
|
NEW.date_created := ''now'';
|
||||||
|
ELSIF TG_OP = ''UPDATE'' THEN
|
||||||
|
NEW.date_updated := ''now'';
|
||||||
|
END IF;
|
||||||
|
RETURN NEW;
|
||||||
|
END;
|
||||||
|
' LANGUAGE 'plpgsql';
|
||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: update_function.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
-- adds the created or updated date tags
|
-- adds the created or updated date tags
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION set_generic() RETURNS TRIGGER AS '
|
CREATE OR REPLACE FUNCTION set_generic() RETURNS TRIGGER AS '
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: edit_access.sql 4382 2013-02-18 07:27:24Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/05
|
-- DATE: 2005/07/05
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
|
|||||||
16
4dev/database/table/edit_access_data.sql
Normal file
16
4dev/database/table/edit_access_data.sql
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
|
-- DATE: 2016/7/15
|
||||||
|
-- DESCRIPTION:
|
||||||
|
-- sub table to edit access, holds additional data for access group
|
||||||
|
-- TABLE: edit_access_data
|
||||||
|
-- HISTORY:
|
||||||
|
|
||||||
|
-- DROP TABLE edit_access_data;
|
||||||
|
CREATE TABLE edit_access_data (
|
||||||
|
edit_access_data_id SERIAL PRIMARY KEY,
|
||||||
|
edit_access_id INT NOT NULL,
|
||||||
|
name VARCHAR,
|
||||||
|
value VARCHAR,
|
||||||
|
enabled SMALLINT NOT NULL DEFAULT 0,
|
||||||
|
FOREIGN KEY (edit_access_id) REFERENCES edit_access (edit_access_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE
|
||||||
|
) INHERITS (edit_generic) WITHOUT OIDS;
|
||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: edit_access_right.sql 4382 2013-02-18 07:27:24Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/05
|
-- DATE: 2005/07/05
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: edit_access_user.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/05
|
-- DATE: 2005/07/05
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: edit_generic.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/05
|
-- DATE: 2005/07/05
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
@@ -10,7 +9,5 @@
|
|||||||
CREATE TABLE edit_generic (
|
CREATE TABLE edit_generic (
|
||||||
eg_status INT,
|
eg_status INT,
|
||||||
date_created TIMESTAMP WITHOUT TIME ZONE DEFAULT clock_timestamp(),
|
date_created TIMESTAMP WITHOUT TIME ZONE DEFAULT clock_timestamp(),
|
||||||
date_updated TIMESTAMP WITHOUT TIME ZONE,
|
date_updated TIMESTAMP WITHOUT TIME ZONE
|
||||||
user_created VARCHAR(25) DEFAULT CURRENT_USER,
|
|
||||||
user_updated VARCHAR(25)
|
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: edit_group.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/05
|
-- DATE: 2005/07/05
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: edit_language.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/05
|
-- DATE: 2005/07/05
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: edit_log.sql 4382 2013-02-18 07:27:24Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/05
|
-- DATE: 2005/07/05
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
@@ -11,7 +10,7 @@ CREATE TABLE edit_log (
|
|||||||
edit_log_id SERIAL PRIMARY KEY,
|
edit_log_id SERIAL PRIMARY KEY,
|
||||||
username VARCHAR,
|
username VARCHAR,
|
||||||
password VARCHAR,
|
password VARCHAR,
|
||||||
event_date TIMESTAMP(0) WITHOUT TIME ZONE DEFAULT CURRENT_TIMESTAMP,
|
event_date TIMESTAMP WITHOUT TIME ZONE DEFAULT CURRENT_TIMESTAMP,
|
||||||
ip VARCHAR,
|
ip VARCHAR,
|
||||||
error TEXT,
|
error TEXT,
|
||||||
event TEXT,
|
event TEXT,
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: edit_menu_group.sql 4382 2013-02-18 07:27:24Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/05
|
-- DATE: 2005/07/05
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: edit_page.sql 4382 2013-02-18 07:27:24Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/05
|
-- DATE: 2005/07/05
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: edit_page_access.sql 4382 2013-02-18 07:27:24Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/05
|
-- DATE: 2005/07/05
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: edit_page_menu_group.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/05
|
-- DATE: 2005/07/05
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: edit_page_visible_group.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/05
|
-- DATE: 2005/07/05
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: edit_query_string.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/05
|
-- DATE: 2005/07/05
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: edit_scheme.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/05
|
-- DATE: 2005/07/05
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: edit_temp_files.sql 4382 2013-02-18 07:27:24Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/08
|
-- DATE: 2005/07/08
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: edit_user.sql 4226 2012-11-02 07:19:57Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/06
|
-- DATE: 2005/07/06
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: edit_visible_group.sql 4382 2013-02-18 07:27:24Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/05
|
-- DATE: 2005/07/05
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
-- $Id: generic.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
-- AUTHOR: Clemens Schwaighofer
|
-- AUTHOR: Clemens Schwaighofer
|
||||||
-- DATE: 2005/07/05
|
-- DATE: 2005/07/05
|
||||||
-- DESCRIPTION:
|
-- DESCRIPTION:
|
||||||
@@ -8,9 +7,6 @@
|
|||||||
|
|
||||||
-- DROP TABLE edit_generic;
|
-- DROP TABLE edit_generic;
|
||||||
CREATE TABLE generic (
|
CREATE TABLE generic (
|
||||||
row_status INT,
|
|
||||||
date_created TIMESTAMP WITHOUT TIME ZONE DEFAULT clock_timestamp(),
|
date_created TIMESTAMP WITHOUT TIME ZONE DEFAULT clock_timestamp(),
|
||||||
date_updated TIMESTAMP WITHOUT TIME ZONE,
|
date_updated TIMESTAMP WITHOUT TIME ZONE
|
||||||
user_created VARCHAR(25) DEFAULT CURRENT_USER,
|
|
||||||
user_updated VARCHAR(25)
|
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
-- $Id: trg_edit_access.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
|
|
||||||
-- DROP TRIGGER trg_edit_access ON edit_access;
|
-- DROP TRIGGER trg_edit_access ON edit_access;
|
||||||
CREATE TRIGGER trg_edit_access
|
CREATE TRIGGER trg_edit_access
|
||||||
BEFORE INSERT OR UPDATE ON edit_access
|
BEFORE INSERT OR UPDATE ON edit_access
|
||||||
|
|||||||
4
4dev/database/trigger/trg_edit_access_data.sql
Normal file
4
4dev/database/trigger/trg_edit_access_data.sql
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
-- DROP TRIGGER trg_edit_access_data ON edit_access_data;
|
||||||
|
CREATE TRIGGER trg_edit_access_data
|
||||||
|
BEFORE INSERT OR UPDATE ON edit_access_data
|
||||||
|
FOR EACH ROW EXECUTE PROCEDURE set_generic();
|
||||||
@@ -1,5 +1,3 @@
|
|||||||
-- $Id: trg_edit_access_right.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
|
|
||||||
-- DROP TRIGGER trg_edit_access_right ON edit_access_right;
|
-- DROP TRIGGER trg_edit_access_right ON edit_access_right;
|
||||||
CREATE TRIGGER trg_edit_access_right
|
CREATE TRIGGER trg_edit_access_right
|
||||||
BEFORE INSERT OR UPDATE ON edit_access_right
|
BEFORE INSERT OR UPDATE ON edit_access_right
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
-- $Id: trg_edit_access_user.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
|
|
||||||
-- DROP TRIGGER trg_edit_access_user ON edit_access_user;
|
-- DROP TRIGGER trg_edit_access_user ON edit_access_user;
|
||||||
CREATE TRIGGER trg_edit_access_user
|
CREATE TRIGGER trg_edit_access_user
|
||||||
BEFORE INSERT OR UPDATE ON edit_access_user
|
BEFORE INSERT OR UPDATE ON edit_access_user
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
-- $Id: trg_edit_group.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
|
|
||||||
-- DROP TRIGGER trg_edit_group ON edit_group;
|
-- DROP TRIGGER trg_edit_group ON edit_group;
|
||||||
CREATE TRIGGER trg_edit_group
|
CREATE TRIGGER trg_edit_group
|
||||||
BEFORE INSERT OR UPDATE ON edit_group
|
BEFORE INSERT OR UPDATE ON edit_group
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
-- $Id: trg_edit_language.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
|
|
||||||
-- DROP TRIGGER trg_edit_language ON edit_language;
|
-- DROP TRIGGER trg_edit_language ON edit_language;
|
||||||
CREATE TRIGGER trg_edit_language
|
CREATE TRIGGER trg_edit_language
|
||||||
BEFORE INSERT OR UPDATE ON edit_language
|
BEFORE INSERT OR UPDATE ON edit_language
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
-- $Id: trg_edit_log.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
|
|
||||||
-- DROP TRIGGER trg_edit_log ON edit_log;
|
-- DROP TRIGGER trg_edit_log ON edit_log;
|
||||||
CREATE TRIGGER trg_edit_log
|
CREATE TRIGGER trg_edit_log
|
||||||
BEFORE INSERT OR UPDATE ON edit_log
|
BEFORE INSERT OR UPDATE ON edit_log
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
-- $Id: trg_edit_menu_group.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
|
|
||||||
-- DROP TRIGGER trg_edit_visible_group ON edit_visible_group;
|
-- DROP TRIGGER trg_edit_visible_group ON edit_visible_group;
|
||||||
CREATE TRIGGER trg_edit_menu_group
|
CREATE TRIGGER trg_edit_menu_group
|
||||||
BEFORE INSERT OR UPDATE ON edit_menu_group
|
BEFORE INSERT OR UPDATE ON edit_menu_group
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
-- $Id: trg_edit_page.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
|
|
||||||
-- DROP TRIGGER trg_edit_page ON edit_page;
|
-- DROP TRIGGER trg_edit_page ON edit_page;
|
||||||
CREATE TRIGGER trg_edit_page
|
CREATE TRIGGER trg_edit_page
|
||||||
BEFORE INSERT OR UPDATE ON edit_page
|
BEFORE INSERT OR UPDATE ON edit_page
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
-- $Id: trg_edit_page_access.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
|
|
||||||
-- DROP TRIGGER trg_edit_page_access ON edit_page_access;
|
-- DROP TRIGGER trg_edit_page_access ON edit_page_access;
|
||||||
CREATE TRIGGER trg_edit_page_access
|
CREATE TRIGGER trg_edit_page_access
|
||||||
BEFORE INSERT OR UPDATE ON edit_page_access
|
BEFORE INSERT OR UPDATE ON edit_page_access
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
-- $Id: trg_edit_query_string.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
|
|
||||||
-- DROP TRIGGER trg_edit_query_string ON edit_query_string;
|
-- DROP TRIGGER trg_edit_query_string ON edit_query_string;
|
||||||
CREATE TRIGGER trg_edit_query_string
|
CREATE TRIGGER trg_edit_query_string
|
||||||
BEFORE INSERT OR UPDATE ON edit_query_string
|
BEFORE INSERT OR UPDATE ON edit_query_string
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
-- $Id: trg_edit_scheme.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
|
|
||||||
-- DROP TRIGGER trg_edit_scheme ON edit_scheme;
|
-- DROP TRIGGER trg_edit_scheme ON edit_scheme;
|
||||||
CREATE TRIGGER trg_edit_scheme
|
CREATE TRIGGER trg_edit_scheme
|
||||||
BEFORE INSERT OR UPDATE ON edit_scheme
|
BEFORE INSERT OR UPDATE ON edit_scheme
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
-- $Id: trg_edit_user.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
|
|
||||||
-- DROP TRIGGER trg_edit_user ON edit_user;
|
-- DROP TRIGGER trg_edit_user ON edit_user;
|
||||||
CREATE TRIGGER trg_edit_user
|
CREATE TRIGGER trg_edit_user
|
||||||
BEFORE INSERT OR UPDATE ON edit_user
|
BEFORE INSERT OR UPDATE ON edit_user
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
-- $Id: trg_edit_visible_group.sql 3158 2010-09-02 02:49:00Z gullevek $
|
|
||||||
|
|
||||||
-- DROP TRIGGER trg_edit_visible_group ON edit_visible_group;
|
-- DROP TRIGGER trg_edit_visible_group ON edit_visible_group;
|
||||||
CREATE TRIGGER trg_edit_visible_group
|
CREATE TRIGGER trg_edit_visible_group
|
||||||
BEFORE INSERT OR UPDATE ON edit_visible_group
|
BEFORE INSERT OR UPDATE ON edit_visible_group
|
||||||
|
|||||||
4
4dev/database/trigger/trg_set_edit_access_uid.sql
Normal file
4
4dev/database/trigger/trg_set_edit_access_uid.sql
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
-- DROP TRIGGER trg_set_edit_access_uid ON edit_access;
|
||||||
|
CREATE TRIGGER trg_set_edit_access_uid
|
||||||
|
BEFORE INSERT OR UPDATE ON edit_access
|
||||||
|
FOR EACH ROW EXECUTE PROCEDURE set_edit_access_uid();
|
||||||
@@ -3,10 +3,10 @@
|
|||||||
# create path
|
# create path
|
||||||
path=`pwd`"/"$0;
|
path=`pwd`"/"$0;
|
||||||
|
|
||||||
LOCAL_BASE_DIR="";
|
LOCAL_BASE_DIR="<local folder>";
|
||||||
LOCAL_DIR=$LOCAL_BASE_DIR"";
|
LOCAL_DIR=$LOCAL_BASE_DIR"";
|
||||||
REMOTE_WEB="";
|
REMOTE_WEB="<remote folder>";
|
||||||
TARGET_HOST_WEB="developer@10.76.32.25";
|
TARGET_HOST_WEB="<user>@<host>
|
||||||
TMP_DIR=$LOCAL_BASE_DIR"/4dev/";
|
TMP_DIR=$LOCAL_BASE_DIR"/4dev/";
|
||||||
tmpf_web=$TMP_DIR"tmp.web";
|
tmpf_web=$TMP_DIR"tmp.web";
|
||||||
|
|
||||||
|
|||||||
2
4dev/tmp/.gitignore
vendored
Normal file
2
4dev/tmp/.gitignore
vendored
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
*
|
||||||
|
!.gitignore
|
||||||
674
LICENSE
Normal file
674
LICENSE
Normal file
@@ -0,0 +1,674 @@
|
|||||||
|
GNU GENERAL PUBLIC LICENSE
|
||||||
|
Version 3, 29 June 2007
|
||||||
|
|
||||||
|
Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
|
||||||
|
Everyone is permitted to copy and distribute verbatim copies
|
||||||
|
of this license document, but changing it is not allowed.
|
||||||
|
|
||||||
|
Preamble
|
||||||
|
|
||||||
|
The GNU General Public License is a free, copyleft license for
|
||||||
|
software and other kinds of works.
|
||||||
|
|
||||||
|
The licenses for most software and other practical works are designed
|
||||||
|
to take away your freedom to share and change the works. By contrast,
|
||||||
|
the GNU General Public License is intended to guarantee your freedom to
|
||||||
|
share and change all versions of a program--to make sure it remains free
|
||||||
|
software for all its users. We, the Free Software Foundation, use the
|
||||||
|
GNU General Public License for most of our software; it applies also to
|
||||||
|
any other work released this way by its authors. You can apply it to
|
||||||
|
your programs, too.
|
||||||
|
|
||||||
|
When we speak of free software, we are referring to freedom, not
|
||||||
|
price. Our General Public Licenses are designed to make sure that you
|
||||||
|
have the freedom to distribute copies of free software (and charge for
|
||||||
|
them if you wish), that you receive source code or can get it if you
|
||||||
|
want it, that you can change the software or use pieces of it in new
|
||||||
|
free programs, and that you know you can do these things.
|
||||||
|
|
||||||
|
To protect your rights, we need to prevent others from denying you
|
||||||
|
these rights or asking you to surrender the rights. Therefore, you have
|
||||||
|
certain responsibilities if you distribute copies of the software, or if
|
||||||
|
you modify it: responsibilities to respect the freedom of others.
|
||||||
|
|
||||||
|
For example, if you distribute copies of such a program, whether
|
||||||
|
gratis or for a fee, you must pass on to the recipients the same
|
||||||
|
freedoms that you received. You must make sure that they, too, receive
|
||||||
|
or can get the source code. And you must show them these terms so they
|
||||||
|
know their rights.
|
||||||
|
|
||||||
|
Developers that use the GNU GPL protect your rights with two steps:
|
||||||
|
(1) assert copyright on the software, and (2) offer you this License
|
||||||
|
giving you legal permission to copy, distribute and/or modify it.
|
||||||
|
|
||||||
|
For the developers' and authors' protection, the GPL clearly explains
|
||||||
|
that there is no warranty for this free software. For both users' and
|
||||||
|
authors' sake, the GPL requires that modified versions be marked as
|
||||||
|
changed, so that their problems will not be attributed erroneously to
|
||||||
|
authors of previous versions.
|
||||||
|
|
||||||
|
Some devices are designed to deny users access to install or run
|
||||||
|
modified versions of the software inside them, although the manufacturer
|
||||||
|
can do so. This is fundamentally incompatible with the aim of
|
||||||
|
protecting users' freedom to change the software. The systematic
|
||||||
|
pattern of such abuse occurs in the area of products for individuals to
|
||||||
|
use, which is precisely where it is most unacceptable. Therefore, we
|
||||||
|
have designed this version of the GPL to prohibit the practice for those
|
||||||
|
products. If such problems arise substantially in other domains, we
|
||||||
|
stand ready to extend this provision to those domains in future versions
|
||||||
|
of the GPL, as needed to protect the freedom of users.
|
||||||
|
|
||||||
|
Finally, every program is threatened constantly by software patents.
|
||||||
|
States should not allow patents to restrict development and use of
|
||||||
|
software on general-purpose computers, but in those that do, we wish to
|
||||||
|
avoid the special danger that patents applied to a free program could
|
||||||
|
make it effectively proprietary. To prevent this, the GPL assures that
|
||||||
|
patents cannot be used to render the program non-free.
|
||||||
|
|
||||||
|
The precise terms and conditions for copying, distribution and
|
||||||
|
modification follow.
|
||||||
|
|
||||||
|
TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
0. Definitions.
|
||||||
|
|
||||||
|
"This License" refers to version 3 of the GNU General Public License.
|
||||||
|
|
||||||
|
"Copyright" also means copyright-like laws that apply to other kinds of
|
||||||
|
works, such as semiconductor masks.
|
||||||
|
|
||||||
|
"The Program" refers to any copyrightable work licensed under this
|
||||||
|
License. Each licensee is addressed as "you". "Licensees" and
|
||||||
|
"recipients" may be individuals or organizations.
|
||||||
|
|
||||||
|
To "modify" a work means to copy from or adapt all or part of the work
|
||||||
|
in a fashion requiring copyright permission, other than the making of an
|
||||||
|
exact copy. The resulting work is called a "modified version" of the
|
||||||
|
earlier work or a work "based on" the earlier work.
|
||||||
|
|
||||||
|
A "covered work" means either the unmodified Program or a work based
|
||||||
|
on the Program.
|
||||||
|
|
||||||
|
To "propagate" a work means to do anything with it that, without
|
||||||
|
permission, would make you directly or secondarily liable for
|
||||||
|
infringement under applicable copyright law, except executing it on a
|
||||||
|
computer or modifying a private copy. Propagation includes copying,
|
||||||
|
distribution (with or without modification), making available to the
|
||||||
|
public, and in some countries other activities as well.
|
||||||
|
|
||||||
|
To "convey" a work means any kind of propagation that enables other
|
||||||
|
parties to make or receive copies. Mere interaction with a user through
|
||||||
|
a computer network, with no transfer of a copy, is not conveying.
|
||||||
|
|
||||||
|
An interactive user interface displays "Appropriate Legal Notices"
|
||||||
|
to the extent that it includes a convenient and prominently visible
|
||||||
|
feature that (1) displays an appropriate copyright notice, and (2)
|
||||||
|
tells the user that there is no warranty for the work (except to the
|
||||||
|
extent that warranties are provided), that licensees may convey the
|
||||||
|
work under this License, and how to view a copy of this License. If
|
||||||
|
the interface presents a list of user commands or options, such as a
|
||||||
|
menu, a prominent item in the list meets this criterion.
|
||||||
|
|
||||||
|
1. Source Code.
|
||||||
|
|
||||||
|
The "source code" for a work means the preferred form of the work
|
||||||
|
for making modifications to it. "Object code" means any non-source
|
||||||
|
form of a work.
|
||||||
|
|
||||||
|
A "Standard Interface" means an interface that either is an official
|
||||||
|
standard defined by a recognized standards body, or, in the case of
|
||||||
|
interfaces specified for a particular programming language, one that
|
||||||
|
is widely used among developers working in that language.
|
||||||
|
|
||||||
|
The "System Libraries" of an executable work include anything, other
|
||||||
|
than the work as a whole, that (a) is included in the normal form of
|
||||||
|
packaging a Major Component, but which is not part of that Major
|
||||||
|
Component, and (b) serves only to enable use of the work with that
|
||||||
|
Major Component, or to implement a Standard Interface for which an
|
||||||
|
implementation is available to the public in source code form. A
|
||||||
|
"Major Component", in this context, means a major essential component
|
||||||
|
(kernel, window system, and so on) of the specific operating system
|
||||||
|
(if any) on which the executable work runs, or a compiler used to
|
||||||
|
produce the work, or an object code interpreter used to run it.
|
||||||
|
|
||||||
|
The "Corresponding Source" for a work in object code form means all
|
||||||
|
the source code needed to generate, install, and (for an executable
|
||||||
|
work) run the object code and to modify the work, including scripts to
|
||||||
|
control those activities. However, it does not include the work's
|
||||||
|
System Libraries, or general-purpose tools or generally available free
|
||||||
|
programs which are used unmodified in performing those activities but
|
||||||
|
which are not part of the work. For example, Corresponding Source
|
||||||
|
includes interface definition files associated with source files for
|
||||||
|
the work, and the source code for shared libraries and dynamically
|
||||||
|
linked subprograms that the work is specifically designed to require,
|
||||||
|
such as by intimate data communication or control flow between those
|
||||||
|
subprograms and other parts of the work.
|
||||||
|
|
||||||
|
The Corresponding Source need not include anything that users
|
||||||
|
can regenerate automatically from other parts of the Corresponding
|
||||||
|
Source.
|
||||||
|
|
||||||
|
The Corresponding Source for a work in source code form is that
|
||||||
|
same work.
|
||||||
|
|
||||||
|
2. Basic Permissions.
|
||||||
|
|
||||||
|
All rights granted under this License are granted for the term of
|
||||||
|
copyright on the Program, and are irrevocable provided the stated
|
||||||
|
conditions are met. This License explicitly affirms your unlimited
|
||||||
|
permission to run the unmodified Program. The output from running a
|
||||||
|
covered work is covered by this License only if the output, given its
|
||||||
|
content, constitutes a covered work. This License acknowledges your
|
||||||
|
rights of fair use or other equivalent, as provided by copyright law.
|
||||||
|
|
||||||
|
You may make, run and propagate covered works that you do not
|
||||||
|
convey, without conditions so long as your license otherwise remains
|
||||||
|
in force. You may convey covered works to others for the sole purpose
|
||||||
|
of having them make modifications exclusively for you, or provide you
|
||||||
|
with facilities for running those works, provided that you comply with
|
||||||
|
the terms of this License in conveying all material for which you do
|
||||||
|
not control copyright. Those thus making or running the covered works
|
||||||
|
for you must do so exclusively on your behalf, under your direction
|
||||||
|
and control, on terms that prohibit them from making any copies of
|
||||||
|
your copyrighted material outside their relationship with you.
|
||||||
|
|
||||||
|
Conveying under any other circumstances is permitted solely under
|
||||||
|
the conditions stated below. Sublicensing is not allowed; section 10
|
||||||
|
makes it unnecessary.
|
||||||
|
|
||||||
|
3. Protecting Users' Legal Rights From Anti-Circumvention Law.
|
||||||
|
|
||||||
|
No covered work shall be deemed part of an effective technological
|
||||||
|
measure under any applicable law fulfilling obligations under article
|
||||||
|
11 of the WIPO copyright treaty adopted on 20 December 1996, or
|
||||||
|
similar laws prohibiting or restricting circumvention of such
|
||||||
|
measures.
|
||||||
|
|
||||||
|
When you convey a covered work, you waive any legal power to forbid
|
||||||
|
circumvention of technological measures to the extent such circumvention
|
||||||
|
is effected by exercising rights under this License with respect to
|
||||||
|
the covered work, and you disclaim any intention to limit operation or
|
||||||
|
modification of the work as a means of enforcing, against the work's
|
||||||
|
users, your or third parties' legal rights to forbid circumvention of
|
||||||
|
technological measures.
|
||||||
|
|
||||||
|
4. Conveying Verbatim Copies.
|
||||||
|
|
||||||
|
You may convey verbatim copies of the Program's source code as you
|
||||||
|
receive it, in any medium, provided that you conspicuously and
|
||||||
|
appropriately publish on each copy an appropriate copyright notice;
|
||||||
|
keep intact all notices stating that this License and any
|
||||||
|
non-permissive terms added in accord with section 7 apply to the code;
|
||||||
|
keep intact all notices of the absence of any warranty; and give all
|
||||||
|
recipients a copy of this License along with the Program.
|
||||||
|
|
||||||
|
You may charge any price or no price for each copy that you convey,
|
||||||
|
and you may offer support or warranty protection for a fee.
|
||||||
|
|
||||||
|
5. Conveying Modified Source Versions.
|
||||||
|
|
||||||
|
You may convey a work based on the Program, or the modifications to
|
||||||
|
produce it from the Program, in the form of source code under the
|
||||||
|
terms of section 4, provided that you also meet all of these conditions:
|
||||||
|
|
||||||
|
a) The work must carry prominent notices stating that you modified
|
||||||
|
it, and giving a relevant date.
|
||||||
|
|
||||||
|
b) The work must carry prominent notices stating that it is
|
||||||
|
released under this License and any conditions added under section
|
||||||
|
7. This requirement modifies the requirement in section 4 to
|
||||||
|
"keep intact all notices".
|
||||||
|
|
||||||
|
c) You must license the entire work, as a whole, under this
|
||||||
|
License to anyone who comes into possession of a copy. This
|
||||||
|
License will therefore apply, along with any applicable section 7
|
||||||
|
additional terms, to the whole of the work, and all its parts,
|
||||||
|
regardless of how they are packaged. This License gives no
|
||||||
|
permission to license the work in any other way, but it does not
|
||||||
|
invalidate such permission if you have separately received it.
|
||||||
|
|
||||||
|
d) If the work has interactive user interfaces, each must display
|
||||||
|
Appropriate Legal Notices; however, if the Program has interactive
|
||||||
|
interfaces that do not display Appropriate Legal Notices, your
|
||||||
|
work need not make them do so.
|
||||||
|
|
||||||
|
A compilation of a covered work with other separate and independent
|
||||||
|
works, which are not by their nature extensions of the covered work,
|
||||||
|
and which are not combined with it such as to form a larger program,
|
||||||
|
in or on a volume of a storage or distribution medium, is called an
|
||||||
|
"aggregate" if the compilation and its resulting copyright are not
|
||||||
|
used to limit the access or legal rights of the compilation's users
|
||||||
|
beyond what the individual works permit. Inclusion of a covered work
|
||||||
|
in an aggregate does not cause this License to apply to the other
|
||||||
|
parts of the aggregate.
|
||||||
|
|
||||||
|
6. Conveying Non-Source Forms.
|
||||||
|
|
||||||
|
You may convey a covered work in object code form under the terms
|
||||||
|
of sections 4 and 5, provided that you also convey the
|
||||||
|
machine-readable Corresponding Source under the terms of this License,
|
||||||
|
in one of these ways:
|
||||||
|
|
||||||
|
a) Convey the object code in, or embodied in, a physical product
|
||||||
|
(including a physical distribution medium), accompanied by the
|
||||||
|
Corresponding Source fixed on a durable physical medium
|
||||||
|
customarily used for software interchange.
|
||||||
|
|
||||||
|
b) Convey the object code in, or embodied in, a physical product
|
||||||
|
(including a physical distribution medium), accompanied by a
|
||||||
|
written offer, valid for at least three years and valid for as
|
||||||
|
long as you offer spare parts or customer support for that product
|
||||||
|
model, to give anyone who possesses the object code either (1) a
|
||||||
|
copy of the Corresponding Source for all the software in the
|
||||||
|
product that is covered by this License, on a durable physical
|
||||||
|
medium customarily used for software interchange, for a price no
|
||||||
|
more than your reasonable cost of physically performing this
|
||||||
|
conveying of source, or (2) access to copy the
|
||||||
|
Corresponding Source from a network server at no charge.
|
||||||
|
|
||||||
|
c) Convey individual copies of the object code with a copy of the
|
||||||
|
written offer to provide the Corresponding Source. This
|
||||||
|
alternative is allowed only occasionally and noncommercially, and
|
||||||
|
only if you received the object code with such an offer, in accord
|
||||||
|
with subsection 6b.
|
||||||
|
|
||||||
|
d) Convey the object code by offering access from a designated
|
||||||
|
place (gratis or for a charge), and offer equivalent access to the
|
||||||
|
Corresponding Source in the same way through the same place at no
|
||||||
|
further charge. You need not require recipients to copy the
|
||||||
|
Corresponding Source along with the object code. If the place to
|
||||||
|
copy the object code is a network server, the Corresponding Source
|
||||||
|
may be on a different server (operated by you or a third party)
|
||||||
|
that supports equivalent copying facilities, provided you maintain
|
||||||
|
clear directions next to the object code saying where to find the
|
||||||
|
Corresponding Source. Regardless of what server hosts the
|
||||||
|
Corresponding Source, you remain obligated to ensure that it is
|
||||||
|
available for as long as needed to satisfy these requirements.
|
||||||
|
|
||||||
|
e) Convey the object code using peer-to-peer transmission, provided
|
||||||
|
you inform other peers where the object code and Corresponding
|
||||||
|
Source of the work are being offered to the general public at no
|
||||||
|
charge under subsection 6d.
|
||||||
|
|
||||||
|
A separable portion of the object code, whose source code is excluded
|
||||||
|
from the Corresponding Source as a System Library, need not be
|
||||||
|
included in conveying the object code work.
|
||||||
|
|
||||||
|
A "User Product" is either (1) a "consumer product", which means any
|
||||||
|
tangible personal property which is normally used for personal, family,
|
||||||
|
or household purposes, or (2) anything designed or sold for incorporation
|
||||||
|
into a dwelling. In determining whether a product is a consumer product,
|
||||||
|
doubtful cases shall be resolved in favor of coverage. For a particular
|
||||||
|
product received by a particular user, "normally used" refers to a
|
||||||
|
typical or common use of that class of product, regardless of the status
|
||||||
|
of the particular user or of the way in which the particular user
|
||||||
|
actually uses, or expects or is expected to use, the product. A product
|
||||||
|
is a consumer product regardless of whether the product has substantial
|
||||||
|
commercial, industrial or non-consumer uses, unless such uses represent
|
||||||
|
the only significant mode of use of the product.
|
||||||
|
|
||||||
|
"Installation Information" for a User Product means any methods,
|
||||||
|
procedures, authorization keys, or other information required to install
|
||||||
|
and execute modified versions of a covered work in that User Product from
|
||||||
|
a modified version of its Corresponding Source. The information must
|
||||||
|
suffice to ensure that the continued functioning of the modified object
|
||||||
|
code is in no case prevented or interfered with solely because
|
||||||
|
modification has been made.
|
||||||
|
|
||||||
|
If you convey an object code work under this section in, or with, or
|
||||||
|
specifically for use in, a User Product, and the conveying occurs as
|
||||||
|
part of a transaction in which the right of possession and use of the
|
||||||
|
User Product is transferred to the recipient in perpetuity or for a
|
||||||
|
fixed term (regardless of how the transaction is characterized), the
|
||||||
|
Corresponding Source conveyed under this section must be accompanied
|
||||||
|
by the Installation Information. But this requirement does not apply
|
||||||
|
if neither you nor any third party retains the ability to install
|
||||||
|
modified object code on the User Product (for example, the work has
|
||||||
|
been installed in ROM).
|
||||||
|
|
||||||
|
The requirement to provide Installation Information does not include a
|
||||||
|
requirement to continue to provide support service, warranty, or updates
|
||||||
|
for a work that has been modified or installed by the recipient, or for
|
||||||
|
the User Product in which it has been modified or installed. Access to a
|
||||||
|
network may be denied when the modification itself materially and
|
||||||
|
adversely affects the operation of the network or violates the rules and
|
||||||
|
protocols for communication across the network.
|
||||||
|
|
||||||
|
Corresponding Source conveyed, and Installation Information provided,
|
||||||
|
in accord with this section must be in a format that is publicly
|
||||||
|
documented (and with an implementation available to the public in
|
||||||
|
source code form), and must require no special password or key for
|
||||||
|
unpacking, reading or copying.
|
||||||
|
|
||||||
|
7. Additional Terms.
|
||||||
|
|
||||||
|
"Additional permissions" are terms that supplement the terms of this
|
||||||
|
License by making exceptions from one or more of its conditions.
|
||||||
|
Additional permissions that are applicable to the entire Program shall
|
||||||
|
be treated as though they were included in this License, to the extent
|
||||||
|
that they are valid under applicable law. If additional permissions
|
||||||
|
apply only to part of the Program, that part may be used separately
|
||||||
|
under those permissions, but the entire Program remains governed by
|
||||||
|
this License without regard to the additional permissions.
|
||||||
|
|
||||||
|
When you convey a copy of a covered work, you may at your option
|
||||||
|
remove any additional permissions from that copy, or from any part of
|
||||||
|
it. (Additional permissions may be written to require their own
|
||||||
|
removal in certain cases when you modify the work.) You may place
|
||||||
|
additional permissions on material, added by you to a covered work,
|
||||||
|
for which you have or can give appropriate copyright permission.
|
||||||
|
|
||||||
|
Notwithstanding any other provision of this License, for material you
|
||||||
|
add to a covered work, you may (if authorized by the copyright holders of
|
||||||
|
that material) supplement the terms of this License with terms:
|
||||||
|
|
||||||
|
a) Disclaiming warranty or limiting liability differently from the
|
||||||
|
terms of sections 15 and 16 of this License; or
|
||||||
|
|
||||||
|
b) Requiring preservation of specified reasonable legal notices or
|
||||||
|
author attributions in that material or in the Appropriate Legal
|
||||||
|
Notices displayed by works containing it; or
|
||||||
|
|
||||||
|
c) Prohibiting misrepresentation of the origin of that material, or
|
||||||
|
requiring that modified versions of such material be marked in
|
||||||
|
reasonable ways as different from the original version; or
|
||||||
|
|
||||||
|
d) Limiting the use for publicity purposes of names of licensors or
|
||||||
|
authors of the material; or
|
||||||
|
|
||||||
|
e) Declining to grant rights under trademark law for use of some
|
||||||
|
trade names, trademarks, or service marks; or
|
||||||
|
|
||||||
|
f) Requiring indemnification of licensors and authors of that
|
||||||
|
material by anyone who conveys the material (or modified versions of
|
||||||
|
it) with contractual assumptions of liability to the recipient, for
|
||||||
|
any liability that these contractual assumptions directly impose on
|
||||||
|
those licensors and authors.
|
||||||
|
|
||||||
|
All other non-permissive additional terms are considered "further
|
||||||
|
restrictions" within the meaning of section 10. If the Program as you
|
||||||
|
received it, or any part of it, contains a notice stating that it is
|
||||||
|
governed by this License along with a term that is a further
|
||||||
|
restriction, you may remove that term. If a license document contains
|
||||||
|
a further restriction but permits relicensing or conveying under this
|
||||||
|
License, you may add to a covered work material governed by the terms
|
||||||
|
of that license document, provided that the further restriction does
|
||||||
|
not survive such relicensing or conveying.
|
||||||
|
|
||||||
|
If you add terms to a covered work in accord with this section, you
|
||||||
|
must place, in the relevant source files, a statement of the
|
||||||
|
additional terms that apply to those files, or a notice indicating
|
||||||
|
where to find the applicable terms.
|
||||||
|
|
||||||
|
Additional terms, permissive or non-permissive, may be stated in the
|
||||||
|
form of a separately written license, or stated as exceptions;
|
||||||
|
the above requirements apply either way.
|
||||||
|
|
||||||
|
8. Termination.
|
||||||
|
|
||||||
|
You may not propagate or modify a covered work except as expressly
|
||||||
|
provided under this License. Any attempt otherwise to propagate or
|
||||||
|
modify it is void, and will automatically terminate your rights under
|
||||||
|
this License (including any patent licenses granted under the third
|
||||||
|
paragraph of section 11).
|
||||||
|
|
||||||
|
However, if you cease all violation of this License, then your
|
||||||
|
license from a particular copyright holder is reinstated (a)
|
||||||
|
provisionally, unless and until the copyright holder explicitly and
|
||||||
|
finally terminates your license, and (b) permanently, if the copyright
|
||||||
|
holder fails to notify you of the violation by some reasonable means
|
||||||
|
prior to 60 days after the cessation.
|
||||||
|
|
||||||
|
Moreover, your license from a particular copyright holder is
|
||||||
|
reinstated permanently if the copyright holder notifies you of the
|
||||||
|
violation by some reasonable means, this is the first time you have
|
||||||
|
received notice of violation of this License (for any work) from that
|
||||||
|
copyright holder, and you cure the violation prior to 30 days after
|
||||||
|
your receipt of the notice.
|
||||||
|
|
||||||
|
Termination of your rights under this section does not terminate the
|
||||||
|
licenses of parties who have received copies or rights from you under
|
||||||
|
this License. If your rights have been terminated and not permanently
|
||||||
|
reinstated, you do not qualify to receive new licenses for the same
|
||||||
|
material under section 10.
|
||||||
|
|
||||||
|
9. Acceptance Not Required for Having Copies.
|
||||||
|
|
||||||
|
You are not required to accept this License in order to receive or
|
||||||
|
run a copy of the Program. Ancillary propagation of a covered work
|
||||||
|
occurring solely as a consequence of using peer-to-peer transmission
|
||||||
|
to receive a copy likewise does not require acceptance. However,
|
||||||
|
nothing other than this License grants you permission to propagate or
|
||||||
|
modify any covered work. These actions infringe copyright if you do
|
||||||
|
not accept this License. Therefore, by modifying or propagating a
|
||||||
|
covered work, you indicate your acceptance of this License to do so.
|
||||||
|
|
||||||
|
10. Automatic Licensing of Downstream Recipients.
|
||||||
|
|
||||||
|
Each time you convey a covered work, the recipient automatically
|
||||||
|
receives a license from the original licensors, to run, modify and
|
||||||
|
propagate that work, subject to this License. You are not responsible
|
||||||
|
for enforcing compliance by third parties with this License.
|
||||||
|
|
||||||
|
An "entity transaction" is a transaction transferring control of an
|
||||||
|
organization, or substantially all assets of one, or subdividing an
|
||||||
|
organization, or merging organizations. If propagation of a covered
|
||||||
|
work results from an entity transaction, each party to that
|
||||||
|
transaction who receives a copy of the work also receives whatever
|
||||||
|
licenses to the work the party's predecessor in interest had or could
|
||||||
|
give under the previous paragraph, plus a right to possession of the
|
||||||
|
Corresponding Source of the work from the predecessor in interest, if
|
||||||
|
the predecessor has it or can get it with reasonable efforts.
|
||||||
|
|
||||||
|
You may not impose any further restrictions on the exercise of the
|
||||||
|
rights granted or affirmed under this License. For example, you may
|
||||||
|
not impose a license fee, royalty, or other charge for exercise of
|
||||||
|
rights granted under this License, and you may not initiate litigation
|
||||||
|
(including a cross-claim or counterclaim in a lawsuit) alleging that
|
||||||
|
any patent claim is infringed by making, using, selling, offering for
|
||||||
|
sale, or importing the Program or any portion of it.
|
||||||
|
|
||||||
|
11. Patents.
|
||||||
|
|
||||||
|
A "contributor" is a copyright holder who authorizes use under this
|
||||||
|
License of the Program or a work on which the Program is based. The
|
||||||
|
work thus licensed is called the contributor's "contributor version".
|
||||||
|
|
||||||
|
A contributor's "essential patent claims" are all patent claims
|
||||||
|
owned or controlled by the contributor, whether already acquired or
|
||||||
|
hereafter acquired, that would be infringed by some manner, permitted
|
||||||
|
by this License, of making, using, or selling its contributor version,
|
||||||
|
but do not include claims that would be infringed only as a
|
||||||
|
consequence of further modification of the contributor version. For
|
||||||
|
purposes of this definition, "control" includes the right to grant
|
||||||
|
patent sublicenses in a manner consistent with the requirements of
|
||||||
|
this License.
|
||||||
|
|
||||||
|
Each contributor grants you a non-exclusive, worldwide, royalty-free
|
||||||
|
patent license under the contributor's essential patent claims, to
|
||||||
|
make, use, sell, offer for sale, import and otherwise run, modify and
|
||||||
|
propagate the contents of its contributor version.
|
||||||
|
|
||||||
|
In the following three paragraphs, a "patent license" is any express
|
||||||
|
agreement or commitment, however denominated, not to enforce a patent
|
||||||
|
(such as an express permission to practice a patent or covenant not to
|
||||||
|
sue for patent infringement). To "grant" such a patent license to a
|
||||||
|
party means to make such an agreement or commitment not to enforce a
|
||||||
|
patent against the party.
|
||||||
|
|
||||||
|
If you convey a covered work, knowingly relying on a patent license,
|
||||||
|
and the Corresponding Source of the work is not available for anyone
|
||||||
|
to copy, free of charge and under the terms of this License, through a
|
||||||
|
publicly available network server or other readily accessible means,
|
||||||
|
then you must either (1) cause the Corresponding Source to be so
|
||||||
|
available, or (2) arrange to deprive yourself of the benefit of the
|
||||||
|
patent license for this particular work, or (3) arrange, in a manner
|
||||||
|
consistent with the requirements of this License, to extend the patent
|
||||||
|
license to downstream recipients. "Knowingly relying" means you have
|
||||||
|
actual knowledge that, but for the patent license, your conveying the
|
||||||
|
covered work in a country, or your recipient's use of the covered work
|
||||||
|
in a country, would infringe one or more identifiable patents in that
|
||||||
|
country that you have reason to believe are valid.
|
||||||
|
|
||||||
|
If, pursuant to or in connection with a single transaction or
|
||||||
|
arrangement, you convey, or propagate by procuring conveyance of, a
|
||||||
|
covered work, and grant a patent license to some of the parties
|
||||||
|
receiving the covered work authorizing them to use, propagate, modify
|
||||||
|
or convey a specific copy of the covered work, then the patent license
|
||||||
|
you grant is automatically extended to all recipients of the covered
|
||||||
|
work and works based on it.
|
||||||
|
|
||||||
|
A patent license is "discriminatory" if it does not include within
|
||||||
|
the scope of its coverage, prohibits the exercise of, or is
|
||||||
|
conditioned on the non-exercise of one or more of the rights that are
|
||||||
|
specifically granted under this License. You may not convey a covered
|
||||||
|
work if you are a party to an arrangement with a third party that is
|
||||||
|
in the business of distributing software, under which you make payment
|
||||||
|
to the third party based on the extent of your activity of conveying
|
||||||
|
the work, and under which the third party grants, to any of the
|
||||||
|
parties who would receive the covered work from you, a discriminatory
|
||||||
|
patent license (a) in connection with copies of the covered work
|
||||||
|
conveyed by you (or copies made from those copies), or (b) primarily
|
||||||
|
for and in connection with specific products or compilations that
|
||||||
|
contain the covered work, unless you entered into that arrangement,
|
||||||
|
or that patent license was granted, prior to 28 March 2007.
|
||||||
|
|
||||||
|
Nothing in this License shall be construed as excluding or limiting
|
||||||
|
any implied license or other defenses to infringement that may
|
||||||
|
otherwise be available to you under applicable patent law.
|
||||||
|
|
||||||
|
12. No Surrender of Others' Freedom.
|
||||||
|
|
||||||
|
If conditions are imposed on you (whether by court order, agreement or
|
||||||
|
otherwise) that contradict the conditions of this License, they do not
|
||||||
|
excuse you from the conditions of this License. If you cannot convey a
|
||||||
|
covered work so as to satisfy simultaneously your obligations under this
|
||||||
|
License and any other pertinent obligations, then as a consequence you may
|
||||||
|
not convey it at all. For example, if you agree to terms that obligate you
|
||||||
|
to collect a royalty for further conveying from those to whom you convey
|
||||||
|
the Program, the only way you could satisfy both those terms and this
|
||||||
|
License would be to refrain entirely from conveying the Program.
|
||||||
|
|
||||||
|
13. Use with the GNU Affero General Public License.
|
||||||
|
|
||||||
|
Notwithstanding any other provision of this License, you have
|
||||||
|
permission to link or combine any covered work with a work licensed
|
||||||
|
under version 3 of the GNU Affero General Public License into a single
|
||||||
|
combined work, and to convey the resulting work. The terms of this
|
||||||
|
License will continue to apply to the part which is the covered work,
|
||||||
|
but the special requirements of the GNU Affero General Public License,
|
||||||
|
section 13, concerning interaction through a network will apply to the
|
||||||
|
combination as such.
|
||||||
|
|
||||||
|
14. Revised Versions of this License.
|
||||||
|
|
||||||
|
The Free Software Foundation may publish revised and/or new versions of
|
||||||
|
the GNU General Public License from time to time. Such new versions will
|
||||||
|
be similar in spirit to the present version, but may differ in detail to
|
||||||
|
address new problems or concerns.
|
||||||
|
|
||||||
|
Each version is given a distinguishing version number. If the
|
||||||
|
Program specifies that a certain numbered version of the GNU General
|
||||||
|
Public License "or any later version" applies to it, you have the
|
||||||
|
option of following the terms and conditions either of that numbered
|
||||||
|
version or of any later version published by the Free Software
|
||||||
|
Foundation. If the Program does not specify a version number of the
|
||||||
|
GNU General Public License, you may choose any version ever published
|
||||||
|
by the Free Software Foundation.
|
||||||
|
|
||||||
|
If the Program specifies that a proxy can decide which future
|
||||||
|
versions of the GNU General Public License can be used, that proxy's
|
||||||
|
public statement of acceptance of a version permanently authorizes you
|
||||||
|
to choose that version for the Program.
|
||||||
|
|
||||||
|
Later license versions may give you additional or different
|
||||||
|
permissions. However, no additional obligations are imposed on any
|
||||||
|
author or copyright holder as a result of your choosing to follow a
|
||||||
|
later version.
|
||||||
|
|
||||||
|
15. Disclaimer of Warranty.
|
||||||
|
|
||||||
|
THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
|
||||||
|
APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
|
||||||
|
HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
|
||||||
|
OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||||||
|
PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
|
||||||
|
IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
|
||||||
|
ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
|
||||||
|
|
||||||
|
16. Limitation of Liability.
|
||||||
|
|
||||||
|
IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||||
|
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
|
||||||
|
THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
|
||||||
|
GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
|
||||||
|
USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
|
||||||
|
DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
|
||||||
|
PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
|
||||||
|
EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
|
||||||
|
SUCH DAMAGES.
|
||||||
|
|
||||||
|
17. Interpretation of Sections 15 and 16.
|
||||||
|
|
||||||
|
If the disclaimer of warranty and limitation of liability provided
|
||||||
|
above cannot be given local legal effect according to their terms,
|
||||||
|
reviewing courts shall apply local law that most closely approximates
|
||||||
|
an absolute waiver of all civil liability in connection with the
|
||||||
|
Program, unless a warranty or assumption of liability accompanies a
|
||||||
|
copy of the Program in return for a fee.
|
||||||
|
|
||||||
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
How to Apply These Terms to Your New Programs
|
||||||
|
|
||||||
|
If you develop a new program, and you want it to be of the greatest
|
||||||
|
possible use to the public, the best way to achieve this is to make it
|
||||||
|
free software which everyone can redistribute and change under these terms.
|
||||||
|
|
||||||
|
To do so, attach the following notices to the program. It is safest
|
||||||
|
to attach them to the start of each source file to most effectively
|
||||||
|
state the exclusion of warranty; and each file should have at least
|
||||||
|
the "copyright" line and a pointer to where the full notice is found.
|
||||||
|
|
||||||
|
<one line to give the program's name and a brief idea of what it does.>
|
||||||
|
Copyright (C) <year> <name of author>
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License 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
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
Also add information on how to contact you by electronic and paper mail.
|
||||||
|
|
||||||
|
If the program does terminal interaction, make it output a short
|
||||||
|
notice like this when it starts in an interactive mode:
|
||||||
|
|
||||||
|
<program> Copyright (C) <year> <name of author>
|
||||||
|
This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
||||||
|
This is free software, and you are welcome to redistribute it
|
||||||
|
under certain conditions; type `show c' for details.
|
||||||
|
|
||||||
|
The hypothetical commands `show w' and `show c' should show the appropriate
|
||||||
|
parts of the General Public License. Of course, your program's commands
|
||||||
|
might be different; for a GUI interface, you would use an "about box".
|
||||||
|
|
||||||
|
You should also get your employer (if you work as a programmer) or school,
|
||||||
|
if any, to sign a "copyright disclaimer" for the program, if necessary.
|
||||||
|
For more information on this, and how to apply and follow the GNU GPL, see
|
||||||
|
<http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
The GNU General Public License does not permit incorporating your program
|
||||||
|
into proprietary programs. If your program is a subroutine library, you
|
||||||
|
may consider it more useful to permit linking proprietary applications with
|
||||||
|
the library. If this is what you want to do, use the GNU Lesser General
|
||||||
|
Public License instead of this License. But first, please read
|
||||||
|
<http://www.gnu.org/philosophy/why-not-lgpl.html>.
|
||||||
10
README
10
README
@@ -1,10 +0,0 @@
|
|||||||
PHP Core Library
|
|
||||||
================
|
|
||||||
|
|
||||||
Base PHP class files to setup any project
|
|
||||||
* login
|
|
||||||
* database wrapper
|
|
||||||
* basic helper class for debugging and other features
|
|
||||||
* admin/frontend split
|
|
||||||
* domain controlled database/settings split
|
|
||||||
* dynamic layout groups
|
|
||||||
25
README.md
Normal file
25
README.md
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
# PHP Core Library
|
||||||
|
|
||||||
|
Base PHP class files to setup any project
|
||||||
|
* login
|
||||||
|
* database wrapper
|
||||||
|
* basic helper class for debugging and other features
|
||||||
|
* admin/frontend split
|
||||||
|
* domain controlled database/settings split
|
||||||
|
* dynamic layout groups
|
||||||
|
|
||||||
|
## NOTE
|
||||||
|
|
||||||
|
There are three branches:
|
||||||
|
|
||||||
|
### master
|
||||||
|
|
||||||
|
This is currently the legacy branch set live. This will change to the namespace branch once development is finished
|
||||||
|
|
||||||
|
### legacy
|
||||||
|
|
||||||
|
The old non namepsace format layout. This will only get bug fixes and no new development
|
||||||
|
|
||||||
|
### namespace
|
||||||
|
|
||||||
|
The new namespace branch. Once development is finished this branch will be removed or renamed to development only branch
|
||||||
@@ -1 +1 @@
|
|||||||
smarty-3.1.27/
|
smarty-3.1.30
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -1,78 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty plugin
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage PluginsFunction
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty {counter} function plugin
|
|
||||||
* Type: function<br>
|
|
||||||
* Name: counter<br>
|
|
||||||
* Purpose: print out a counter value
|
|
||||||
*
|
|
||||||
* @author Monte Ohrt <monte at ohrt dot com>
|
|
||||||
* @link http://www.smarty.net/manual/en/language.function.counter.php {counter}
|
|
||||||
* (Smarty online manual)
|
|
||||||
*
|
|
||||||
* @param array $params parameters
|
|
||||||
* @param Smarty_Internal_Template $template template object
|
|
||||||
*
|
|
||||||
* @return string|null
|
|
||||||
*/
|
|
||||||
function smarty_function_counter($params, $template)
|
|
||||||
{
|
|
||||||
static $counters = array();
|
|
||||||
|
|
||||||
$name = (isset($params['name'])) ? $params['name'] : 'default';
|
|
||||||
if (!isset($counters[$name])) {
|
|
||||||
$counters[$name] = array(
|
|
||||||
'start' => 1,
|
|
||||||
'skip' => 1,
|
|
||||||
'direction' => 'up',
|
|
||||||
'count' => 1
|
|
||||||
);
|
|
||||||
}
|
|
||||||
$counter =& $counters[$name];
|
|
||||||
|
|
||||||
if (isset($params['start'])) {
|
|
||||||
$counter['start'] = $counter['count'] = (int) $params['start'];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!empty($params['assign'])) {
|
|
||||||
$counter['assign'] = $params['assign'];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isset($counter['assign'])) {
|
|
||||||
$template->assign($counter['assign'], $counter['count']);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isset($params['print'])) {
|
|
||||||
$print = (bool) $params['print'];
|
|
||||||
} else {
|
|
||||||
$print = empty($counter['assign']);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($print) {
|
|
||||||
$retval = $counter['count'];
|
|
||||||
} else {
|
|
||||||
$retval = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isset($params['skip'])) {
|
|
||||||
$counter['skip'] = $params['skip'];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isset($params['direction'])) {
|
|
||||||
$counter['direction'] = $params['direction'];
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($counter['direction'] == "down") {
|
|
||||||
$counter['count'] -= $counter['skip'];
|
|
||||||
} else {
|
|
||||||
$counter['count'] += $counter['skip'];
|
|
||||||
}
|
|
||||||
|
|
||||||
return $retval;
|
|
||||||
}
|
|
||||||
@@ -1,50 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty plugin
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage PluginsModifierCompiler
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty unescape modifier plugin
|
|
||||||
* Type: modifier<br>
|
|
||||||
* Name: unescape<br>
|
|
||||||
* Purpose: unescape html entities
|
|
||||||
*
|
|
||||||
* @author Rodney Rehm
|
|
||||||
*
|
|
||||||
* @param array $params parameters
|
|
||||||
*
|
|
||||||
* @return string with compiled code
|
|
||||||
*/
|
|
||||||
function smarty_modifiercompiler_unescape($params)
|
|
||||||
{
|
|
||||||
if (!isset($params[1])) {
|
|
||||||
$params[1] = 'html';
|
|
||||||
}
|
|
||||||
if (!isset($params[2])) {
|
|
||||||
$params[2] = '\'' . addslashes(Smarty::$_CHARSET) . '\'';
|
|
||||||
} else {
|
|
||||||
$params[2] = "'" . $params[2] . "'";
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (trim($params[1], '"\'')) {
|
|
||||||
case 'entity':
|
|
||||||
case 'htmlall':
|
|
||||||
if (Smarty::$_MBSTRING) {
|
|
||||||
return 'mb_convert_encoding(' . $params[0] . ', ' . $params[2] . ', \'HTML-ENTITIES\')';
|
|
||||||
}
|
|
||||||
|
|
||||||
return 'html_entity_decode(' . $params[0] . ', ENT_NOQUOTES, ' . $params[2] . ')';
|
|
||||||
|
|
||||||
case 'html':
|
|
||||||
return 'htmlspecialchars_decode(' . $params[0] . ', ENT_QUOTES)';
|
|
||||||
|
|
||||||
case 'url':
|
|
||||||
return 'rawurldecode(' . $params[0] . ')';
|
|
||||||
|
|
||||||
default:
|
|
||||||
return $params[0];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,47 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty plugin
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage PluginsModifierCompiler
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty wordwrap modifier plugin
|
|
||||||
* Type: modifier<br>
|
|
||||||
* Name: wordwrap<br>
|
|
||||||
* Purpose: wrap a string of text at a given length
|
|
||||||
*
|
|
||||||
* @link http://smarty.php.net/manual/en/language.modifier.wordwrap.php wordwrap (Smarty online manual)
|
|
||||||
* @author Uwe Tews
|
|
||||||
*
|
|
||||||
* @param array $params parameters
|
|
||||||
* @param $compiler
|
|
||||||
*
|
|
||||||
* @return string with compiled code
|
|
||||||
*/
|
|
||||||
function smarty_modifiercompiler_wordwrap($params, $compiler)
|
|
||||||
{
|
|
||||||
if (!isset($params[1])) {
|
|
||||||
$params[1] = 80;
|
|
||||||
}
|
|
||||||
if (!isset($params[2])) {
|
|
||||||
$params[2] = '"\n"';
|
|
||||||
}
|
|
||||||
if (!isset($params[3])) {
|
|
||||||
$params[3] = 'false';
|
|
||||||
}
|
|
||||||
$function = 'wordwrap';
|
|
||||||
if (Smarty::$_MBSTRING) {
|
|
||||||
if ($compiler->template->caching && ($compiler->tag_nocache | $compiler->nocache)) {
|
|
||||||
$compiler->template->required_plugins['nocache']['wordwrap']['modifier']['file'] = SMARTY_PLUGINS_DIR . 'shared.mb_wordwrap.php';
|
|
||||||
$compiler->template->required_plugins['nocache']['wordwrap']['modifier']['function'] = 'smarty_mb_wordwrap';
|
|
||||||
} else {
|
|
||||||
$compiler->template->required_plugins['compiled']['wordwrap']['modifier']['file'] = SMARTY_PLUGINS_DIR . 'shared.mb_wordwrap.php';
|
|
||||||
$compiler->template->required_plugins['compiled']['wordwrap']['modifier']['function'] = 'smarty_mb_wordwrap';
|
|
||||||
}
|
|
||||||
$function = 'smarty_mb_wordwrap';
|
|
||||||
}
|
|
||||||
|
|
||||||
return $function . '(' . $params[0] . ',' . $params[1] . ',' . $params[2] . ',' . $params[3] . ')';
|
|
||||||
}
|
|
||||||
@@ -1,53 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty shared plugin
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage PluginsShared
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (version_compare(PHP_VERSION, '5.2.3', '>=')) {
|
|
||||||
/**
|
|
||||||
* escape_special_chars common function
|
|
||||||
* Function: smarty_function_escape_special_chars<br>
|
|
||||||
* Purpose: used by other smarty functions to escape
|
|
||||||
* special chars except for already escaped ones
|
|
||||||
*
|
|
||||||
* @author Monte Ohrt <monte at ohrt dot com>
|
|
||||||
*
|
|
||||||
* @param string $string text that should by escaped
|
|
||||||
*
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
function smarty_function_escape_special_chars($string)
|
|
||||||
{
|
|
||||||
if (!is_array($string)) {
|
|
||||||
$string = htmlspecialchars($string, ENT_COMPAT, Smarty::$_CHARSET, false);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $string;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
/**
|
|
||||||
* escape_special_chars common function
|
|
||||||
* Function: smarty_function_escape_special_chars<br>
|
|
||||||
* Purpose: used by other smarty functions to escape
|
|
||||||
* special chars except for already escaped ones
|
|
||||||
*
|
|
||||||
* @author Monte Ohrt <monte at ohrt dot com>
|
|
||||||
*
|
|
||||||
* @param string $string text that should by escaped
|
|
||||||
*
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
function smarty_function_escape_special_chars($string)
|
|
||||||
{
|
|
||||||
if (!is_array($string)) {
|
|
||||||
$string = preg_replace('!&(#?\w+);!', '%%%SMARTY_START%%%\\1%%%SMARTY_END%%%', $string);
|
|
||||||
$string = htmlspecialchars($string);
|
|
||||||
$string = str_replace(array('%%%SMARTY_START%%%', '%%%SMARTY_END%%%'), array('&', ';'), $string);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $string;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
smarty-3.1.27/
|
|
||||||
@@ -1,442 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Cacher
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Cache Handler API
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Cacher
|
|
||||||
* @author Rodney Rehm
|
|
||||||
*/
|
|
||||||
abstract class Smarty_CacheResource
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* cache for Smarty_CacheResource instances
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public static $resources = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* resource types provided by the core
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
protected static $sysplugins = array(
|
|
||||||
'file' => true,
|
|
||||||
);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* populate Cached Object with meta data from Resource
|
|
||||||
*
|
|
||||||
* @param Smarty_Template_Cached $cached cached object
|
|
||||||
* @param Smarty_Internal_Template $_template template object
|
|
||||||
*
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
abstract public function populate(Smarty_Template_Cached $cached, Smarty_Internal_Template $_template);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* populate Cached Object with timestamp and exists from Resource
|
|
||||||
*
|
|
||||||
* @param Smarty_Template_Cached $cached
|
|
||||||
*
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
abstract public function populateTimestamp(Smarty_Template_Cached $cached);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Read the cached template and process header
|
|
||||||
*
|
|
||||||
* @param Smarty_Internal_Template $_template template object
|
|
||||||
* @param Smarty_Template_Cached $cached cached object
|
|
||||||
*
|
|
||||||
* @return boolean true or false if the cached content does not exist
|
|
||||||
*/
|
|
||||||
abstract public function process(Smarty_Internal_Template $_template, Smarty_Template_Cached $cached = null);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Write the rendered template output to cache
|
|
||||||
*
|
|
||||||
* @param Smarty_Internal_Template $_template template object
|
|
||||||
* @param string $content content to cache
|
|
||||||
*
|
|
||||||
* @return boolean success
|
|
||||||
*/
|
|
||||||
abstract public function writeCachedContent(Smarty_Internal_Template $_template, $content);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return cached content
|
|
||||||
*
|
|
||||||
* @param Smarty_Internal_Template $_template template object
|
|
||||||
*
|
|
||||||
* @return null|string
|
|
||||||
*/
|
|
||||||
public function getCachedContent(Smarty_Internal_Template $_template)
|
|
||||||
{
|
|
||||||
if ($_template->cached->handler->process($_template)) {
|
|
||||||
ob_start();
|
|
||||||
$_template->properties['unifunc']($_template);
|
|
||||||
|
|
||||||
return ob_get_clean();
|
|
||||||
}
|
|
||||||
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Empty cache
|
|
||||||
*
|
|
||||||
* @param Smarty $smarty Smarty object
|
|
||||||
* @param integer $exp_time expiration time (number of seconds, not timestamp)
|
|
||||||
*
|
|
||||||
* @return integer number of cache files deleted
|
|
||||||
*/
|
|
||||||
abstract public function clearAll(Smarty $smarty, $exp_time = null);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Empty cache for a specific template
|
|
||||||
*
|
|
||||||
* @param Smarty $smarty Smarty object
|
|
||||||
* @param string $resource_name template name
|
|
||||||
* @param string $cache_id cache id
|
|
||||||
* @param string $compile_id compile id
|
|
||||||
* @param integer $exp_time expiration time (number of seconds, not timestamp)
|
|
||||||
*
|
|
||||||
* @return integer number of cache files deleted
|
|
||||||
*/
|
|
||||||
abstract public function clear(Smarty $smarty, $resource_name, $cache_id, $compile_id, $exp_time);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Smarty $smarty
|
|
||||||
* @param Smarty_Template_Cached $cached
|
|
||||||
*
|
|
||||||
* @return bool|null
|
|
||||||
*/
|
|
||||||
public function locked(Smarty $smarty, Smarty_Template_Cached $cached)
|
|
||||||
{
|
|
||||||
// theoretically locking_timeout should be checked against time_limit (max_execution_time)
|
|
||||||
$start = microtime(true);
|
|
||||||
$hadLock = null;
|
|
||||||
while ($this->hasLock($smarty, $cached)) {
|
|
||||||
$hadLock = true;
|
|
||||||
if (microtime(true) - $start > $smarty->locking_timeout) {
|
|
||||||
// abort waiting for lock release
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
sleep(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $hadLock;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check is cache is locked for this template
|
|
||||||
*
|
|
||||||
* @param Smarty $smarty
|
|
||||||
* @param Smarty_Template_Cached $cached
|
|
||||||
*
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
public function hasLock(Smarty $smarty, Smarty_Template_Cached $cached)
|
|
||||||
{
|
|
||||||
// check if lock exists
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Lock cache for this template
|
|
||||||
*
|
|
||||||
* @param Smarty $smarty
|
|
||||||
* @param Smarty_Template_Cached $cached
|
|
||||||
*
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
public function acquireLock(Smarty $smarty, Smarty_Template_Cached $cached)
|
|
||||||
{
|
|
||||||
// create lock
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Unlock cache for this template
|
|
||||||
*
|
|
||||||
* @param Smarty $smarty
|
|
||||||
* @param Smarty_Template_Cached $cached
|
|
||||||
*
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
public function releaseLock(Smarty $smarty, Smarty_Template_Cached $cached)
|
|
||||||
{
|
|
||||||
// release lock
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Load Cache Resource Handler
|
|
||||||
*
|
|
||||||
* @param Smarty $smarty Smarty object
|
|
||||||
* @param string $type name of the cache resource
|
|
||||||
*
|
|
||||||
* @throws SmartyException
|
|
||||||
* @return Smarty_CacheResource Cache Resource Handler
|
|
||||||
*/
|
|
||||||
public static function load(Smarty $smarty, $type = null)
|
|
||||||
{
|
|
||||||
if (!isset($type)) {
|
|
||||||
$type = $smarty->caching_type;
|
|
||||||
}
|
|
||||||
|
|
||||||
// try smarty's cache
|
|
||||||
if (isset($smarty->_cacheresource_handlers[$type])) {
|
|
||||||
return $smarty->_cacheresource_handlers[$type];
|
|
||||||
}
|
|
||||||
|
|
||||||
// try registered resource
|
|
||||||
if (isset($smarty->registered_cache_resources[$type])) {
|
|
||||||
// do not cache these instances as they may vary from instance to instance
|
|
||||||
return $smarty->_cacheresource_handlers[$type] = $smarty->registered_cache_resources[$type];
|
|
||||||
}
|
|
||||||
// try sysplugins dir
|
|
||||||
if (isset(self::$sysplugins[$type])) {
|
|
||||||
if (!isset(self::$resources[$type])) {
|
|
||||||
$cache_resource_class = 'Smarty_Internal_CacheResource_' . ucfirst($type);
|
|
||||||
self::$resources[$type] = new $cache_resource_class();
|
|
||||||
}
|
|
||||||
|
|
||||||
return $smarty->_cacheresource_handlers[$type] = self::$resources[$type];
|
|
||||||
}
|
|
||||||
// try plugins dir
|
|
||||||
$cache_resource_class = 'Smarty_CacheResource_' . ucfirst($type);
|
|
||||||
if ($smarty->loadPlugin($cache_resource_class)) {
|
|
||||||
if (!isset(self::$resources[$type])) {
|
|
||||||
self::$resources[$type] = new $cache_resource_class();
|
|
||||||
}
|
|
||||||
|
|
||||||
return $smarty->_cacheresource_handlers[$type] = self::$resources[$type];
|
|
||||||
}
|
|
||||||
// give up
|
|
||||||
throw new SmartyException("Unable to load cache resource '{$type}'");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Invalid Loaded Cache Files
|
|
||||||
*
|
|
||||||
* @param Smarty $smarty Smarty object
|
|
||||||
*/
|
|
||||||
public static function invalidLoadedCache(Smarty $smarty)
|
|
||||||
{
|
|
||||||
foreach ($smarty->template_objects as $tpl) {
|
|
||||||
if (isset($tpl->cached)) {
|
|
||||||
$tpl->cached->valid = false;
|
|
||||||
$tpl->cached->processed = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Resource Data Object
|
|
||||||
* Cache Data Container for Template Files
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage TemplateResources
|
|
||||||
* @author Rodney Rehm
|
|
||||||
*/
|
|
||||||
class Smarty_Template_Cached
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Source Filepath
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $filepath = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Source Content
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $content = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Source Timestamp
|
|
||||||
*
|
|
||||||
* @var integer
|
|
||||||
*/
|
|
||||||
public $timestamp = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Source Existence
|
|
||||||
*
|
|
||||||
* @var boolean
|
|
||||||
*/
|
|
||||||
public $exists = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Cache Is Valid
|
|
||||||
*
|
|
||||||
* @var boolean
|
|
||||||
*/
|
|
||||||
public $valid = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Cache was processed
|
|
||||||
*
|
|
||||||
* @var boolean
|
|
||||||
*/
|
|
||||||
public $processed = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* CacheResource Handler
|
|
||||||
*
|
|
||||||
* @var Smarty_CacheResource
|
|
||||||
*/
|
|
||||||
public $handler = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Template Compile Id (Smarty_Internal_Template::$compile_id)
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $compile_id = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Template Cache Id (Smarty_Internal_Template::$cache_id)
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $cache_id = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Id for cache locking
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $lock_id = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* flag that cache is locked by this instance
|
|
||||||
*
|
|
||||||
* @var bool
|
|
||||||
*/
|
|
||||||
public $is_locked = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Source Object
|
|
||||||
*
|
|
||||||
* @var Smarty_Template_Source
|
|
||||||
*/
|
|
||||||
public $source = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* create Cached Object container
|
|
||||||
*
|
|
||||||
* @param Smarty_Internal_Template $_template template object
|
|
||||||
*/
|
|
||||||
public function __construct(Smarty_Internal_Template $_template)
|
|
||||||
{
|
|
||||||
$this->compile_id = $_template->compile_id;
|
|
||||||
$this->cache_id = $_template->cache_id;
|
|
||||||
$this->source = $_template->source;
|
|
||||||
$_template->cached = $this;
|
|
||||||
$smarty = $_template->smarty;
|
|
||||||
|
|
||||||
//
|
|
||||||
// load resource handler
|
|
||||||
//
|
|
||||||
$this->handler = $handler = Smarty_CacheResource::load($smarty); // Note: prone to circular references
|
|
||||||
|
|
||||||
//
|
|
||||||
// check if cache is valid
|
|
||||||
//
|
|
||||||
if (!($_template->caching == Smarty::CACHING_LIFETIME_CURRENT || $_template->caching == Smarty::CACHING_LIFETIME_SAVED) || $_template->source->recompiled) {
|
|
||||||
$handler->populate($this, $_template);
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
while (true) {
|
|
||||||
while (true) {
|
|
||||||
$handler->populate($this, $_template);
|
|
||||||
if ($this->timestamp === false || $smarty->force_compile || $smarty->force_cache) {
|
|
||||||
$this->valid = false;
|
|
||||||
} else {
|
|
||||||
$this->valid = true;
|
|
||||||
}
|
|
||||||
if ($this->valid && $_template->caching == Smarty::CACHING_LIFETIME_CURRENT && $_template->cache_lifetime >= 0 && time() > ($this->timestamp + $_template->cache_lifetime)) {
|
|
||||||
// lifetime expired
|
|
||||||
$this->valid = false;
|
|
||||||
}
|
|
||||||
if ($this->valid || !$_template->smarty->cache_locking) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if (!$this->handler->locked($_template->smarty, $this)) {
|
|
||||||
$this->handler->acquireLock($_template->smarty, $this);
|
|
||||||
break 2;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($this->valid) {
|
|
||||||
if (!$_template->smarty->cache_locking || $this->handler->locked($_template->smarty, $this) === null) {
|
|
||||||
// load cache file for the following checks
|
|
||||||
if ($smarty->debugging) {
|
|
||||||
Smarty_Internal_Debug::start_cache($_template);
|
|
||||||
}
|
|
||||||
if ($handler->process($_template, $this) === false) {
|
|
||||||
$this->valid = false;
|
|
||||||
} else {
|
|
||||||
$this->processed = true;
|
|
||||||
}
|
|
||||||
if ($smarty->debugging) {
|
|
||||||
Smarty_Internal_Debug::end_cache($_template);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if ($this->valid && $_template->caching === Smarty::CACHING_LIFETIME_SAVED && $_template->properties['cache_lifetime'] >= 0 && (time() > ($_template->cached->timestamp + $_template->properties['cache_lifetime']))) {
|
|
||||||
$this->valid = false;
|
|
||||||
}
|
|
||||||
if (!$this->valid && $_template->smarty->cache_locking) {
|
|
||||||
$this->handler->acquireLock($_template->smarty, $this);
|
|
||||||
|
|
||||||
return;
|
|
||||||
} else {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Write this cache object to handler
|
|
||||||
*
|
|
||||||
* @param Smarty_Internal_Template $_template template object
|
|
||||||
* @param string $content content to cache
|
|
||||||
*
|
|
||||||
* @return boolean success
|
|
||||||
*/
|
|
||||||
public function write(Smarty_Internal_Template $_template, $content)
|
|
||||||
{
|
|
||||||
if (!$_template->source->recompiled) {
|
|
||||||
if ($this->handler->writeCachedContent($_template, $content)) {
|
|
||||||
$this->content = null;
|
|
||||||
$this->timestamp = time();
|
|
||||||
$this->exists = true;
|
|
||||||
$this->valid = true;
|
|
||||||
if ($_template->smarty->cache_locking) {
|
|
||||||
$this->handler->releaseLock($_template->smarty, $this);
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,94 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage TemplateResources
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Resource Data Object
|
|
||||||
* Meta Data Container for Config Files
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage TemplateResources
|
|
||||||
* @author Rodney Rehm
|
|
||||||
* @property string $content
|
|
||||||
* @property int $timestamp
|
|
||||||
* @property bool $exists
|
|
||||||
*/
|
|
||||||
class Smarty_Config_Source extends Smarty_Template_Source
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* create Config Object container
|
|
||||||
*
|
|
||||||
* @param Smarty_Resource $handler Resource Handler this source object communicates with
|
|
||||||
* @param Smarty $smarty Smarty instance this source object belongs to
|
|
||||||
* @param string $resource full config_resource
|
|
||||||
* @param string $type type of resource
|
|
||||||
* @param string $name resource name
|
|
||||||
* @param string $unique_resource unqiue resource name
|
|
||||||
*/
|
|
||||||
public function __construct(Smarty_Resource $handler, Smarty $smarty, $resource, $type, $name, $unique_resource)
|
|
||||||
{
|
|
||||||
$this->handler = $handler; // Note: prone to circular references
|
|
||||||
|
|
||||||
// Note: these may be ->config_compiler_class etc in the future
|
|
||||||
//$this->config_compiler_class = $handler->config_compiler_class;
|
|
||||||
//$this->config_lexer_class = $handler->config_lexer_class;
|
|
||||||
//$this->config_parser_class = $handler->config_parser_class;
|
|
||||||
|
|
||||||
$this->smarty = $smarty;
|
|
||||||
$this->resource = $resource;
|
|
||||||
$this->type = $type;
|
|
||||||
$this->name = $name;
|
|
||||||
$this->unique_resource = $unique_resource;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <<magic>> Generic setter.
|
|
||||||
*
|
|
||||||
* @param string $property_name valid: content, timestamp, exists
|
|
||||||
* @param mixed $value newly assigned value (not check for correct type)
|
|
||||||
*
|
|
||||||
* @throws SmartyException when the given property name is not valid
|
|
||||||
*/
|
|
||||||
public function __set($property_name, $value)
|
|
||||||
{
|
|
||||||
switch ($property_name) {
|
|
||||||
case 'content':
|
|
||||||
case 'timestamp':
|
|
||||||
case 'exists':
|
|
||||||
$this->$property_name = $value;
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new SmartyException("invalid config property '$property_name'.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <<magic>> Generic getter.
|
|
||||||
*
|
|
||||||
* @param string $property_name valid: content, timestamp, exists
|
|
||||||
*
|
|
||||||
* @return mixed|void
|
|
||||||
* @throws SmartyException when the given property name is not valid
|
|
||||||
*/
|
|
||||||
public function __get($property_name)
|
|
||||||
{
|
|
||||||
switch ($property_name) {
|
|
||||||
case 'timestamp':
|
|
||||||
case 'exists':
|
|
||||||
$this->handler->populateTimestamp($this);
|
|
||||||
|
|
||||||
return $this->$property_name;
|
|
||||||
|
|
||||||
case 'content':
|
|
||||||
return $this->content = $this->handler->getContent($this);
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new SmartyException("config property '$property_name' does not exist.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,297 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin CacheResource File
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Cacher
|
|
||||||
* @author Uwe Tews
|
|
||||||
* @author Rodney Rehm
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This class does contain all necessary methods for the HTML cache on file system
|
|
||||||
* Implements the file system as resource for the HTML cache Version ussing nocache inserts.
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Cacher
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_CacheResource_File extends Smarty_CacheResource
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* populate Cached Object with meta data from Resource
|
|
||||||
*
|
|
||||||
* @param Smarty_Template_Cached $cached cached object
|
|
||||||
* @param Smarty_Internal_Template $_template template object
|
|
||||||
*
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
public function populate(Smarty_Template_Cached $cached, Smarty_Internal_Template $_template)
|
|
||||||
{
|
|
||||||
$_source_file_path = str_replace(':', '.', $_template->source->filepath);
|
|
||||||
$_cache_id = isset($_template->cache_id) ? preg_replace('![^\w\|]+!', '_', $_template->cache_id) : null;
|
|
||||||
$_compile_id = isset($_template->compile_id) ? preg_replace('![^\w\|]+!', '_', $_template->compile_id) : null;
|
|
||||||
$_filepath = $_template->source->uid;
|
|
||||||
// if use_sub_dirs, break file into directories
|
|
||||||
if ($_template->smarty->use_sub_dirs) {
|
|
||||||
$_filepath = substr($_filepath, 0, 2) . DS
|
|
||||||
. substr($_filepath, 2, 2) . DS
|
|
||||||
. substr($_filepath, 4, 2) . DS
|
|
||||||
. $_filepath;
|
|
||||||
}
|
|
||||||
$_compile_dir_sep = $_template->smarty->use_sub_dirs ? DS : '^';
|
|
||||||
if (isset($_cache_id)) {
|
|
||||||
$_cache_id = str_replace('|', $_compile_dir_sep, $_cache_id) . $_compile_dir_sep;
|
|
||||||
} else {
|
|
||||||
$_cache_id = '';
|
|
||||||
}
|
|
||||||
if (isset($_compile_id)) {
|
|
||||||
$_compile_id = $_compile_id . $_compile_dir_sep;
|
|
||||||
} else {
|
|
||||||
$_compile_id = '';
|
|
||||||
}
|
|
||||||
$_cache_dir = $_template->smarty->getCacheDir();
|
|
||||||
if ($_template->smarty->cache_locking) {
|
|
||||||
// create locking file name
|
|
||||||
// relative file name?
|
|
||||||
if (!preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $_cache_dir)) {
|
|
||||||
$_lock_dir = rtrim(getcwd(), '/\\') . DS . $_cache_dir;
|
|
||||||
} else {
|
|
||||||
$_lock_dir = $_cache_dir;
|
|
||||||
}
|
|
||||||
$cached->lock_id = $_lock_dir . sha1($_cache_id . $_compile_id . $_template->source->uid) . '.lock';
|
|
||||||
}
|
|
||||||
$cached->filepath = $_cache_dir . $_cache_id . $_compile_id . $_filepath . '.' . basename($_source_file_path) . '.php';
|
|
||||||
$cached->timestamp = @filemtime($cached->filepath);
|
|
||||||
$cached->exists = !!$cached->timestamp;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* populate Cached Object with timestamp and exists from Resource
|
|
||||||
*
|
|
||||||
* @param Smarty_Template_Cached $cached cached object
|
|
||||||
*
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
public function populateTimestamp(Smarty_Template_Cached $cached)
|
|
||||||
{
|
|
||||||
$cached->timestamp = @filemtime($cached->filepath);
|
|
||||||
$cached->exists = !!$cached->timestamp;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Read the cached template and process its header
|
|
||||||
*
|
|
||||||
* @param Smarty_Internal_Template $_template template object
|
|
||||||
* @param Smarty_Template_Cached $cached cached object
|
|
||||||
*
|
|
||||||
* @return booleantrue or false if the cached content does not exist
|
|
||||||
*/
|
|
||||||
public function process(Smarty_Internal_Template $_template, Smarty_Template_Cached $cached = null)
|
|
||||||
{
|
|
||||||
/** @var Smarty_Internal_Template $_smarty_tpl
|
|
||||||
* used in included file
|
|
||||||
*/
|
|
||||||
$_smarty_tpl = $_template;
|
|
||||||
|
|
||||||
return @include $_template->cached->filepath;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Write the rendered template output to cache
|
|
||||||
*
|
|
||||||
* @param Smarty_Internal_Template $_template template object
|
|
||||||
* @param string $content content to cache
|
|
||||||
*
|
|
||||||
* @return boolean success
|
|
||||||
*/
|
|
||||||
public function writeCachedContent(Smarty_Internal_Template $_template, $content)
|
|
||||||
{
|
|
||||||
if (Smarty_Internal_Write_File::writeFile($_template->cached->filepath, $content, $_template->smarty) === true) {
|
|
||||||
$_template->cached->timestamp = @filemtime($_template->cached->filepath);
|
|
||||||
$_template->cached->exists = !!$_template->cached->timestamp;
|
|
||||||
if ($_template->cached->exists) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Empty cache
|
|
||||||
*
|
|
||||||
* @param Smarty $smarty
|
|
||||||
* @param integer $exp_time expiration time (number of seconds, not timestamp)
|
|
||||||
*
|
|
||||||
* @return integer number of cache files deleted
|
|
||||||
*/
|
|
||||||
public function clearAll(Smarty $smarty, $exp_time = null)
|
|
||||||
{
|
|
||||||
return $this->clear($smarty, null, null, null, $exp_time);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Empty cache for a specific template
|
|
||||||
*
|
|
||||||
* @param Smarty $smarty
|
|
||||||
* @param string $resource_name template name
|
|
||||||
* @param string $cache_id cache id
|
|
||||||
* @param string $compile_id compile id
|
|
||||||
* @param integer $exp_time expiration time (number of seconds, not timestamp)
|
|
||||||
*
|
|
||||||
* @return integer number of cache files deleted
|
|
||||||
*/
|
|
||||||
public function clear(Smarty $smarty, $resource_name, $cache_id, $compile_id, $exp_time)
|
|
||||||
{
|
|
||||||
$_cache_id = isset($cache_id) ? preg_replace('![^\w\|]+!', '_', $cache_id) : null;
|
|
||||||
$_compile_id = isset($compile_id) ? preg_replace('![^\w\|]+!', '_', $compile_id) : null;
|
|
||||||
$_dir_sep = $smarty->use_sub_dirs ? '/' : '^';
|
|
||||||
$_compile_id_offset = $smarty->use_sub_dirs ? 3 : 0;
|
|
||||||
if (($_dir = realpath($smarty->getCacheDir())) === false) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
$_dir .= '/';
|
|
||||||
$_dir_length = strlen($_dir);
|
|
||||||
if (isset($_cache_id)) {
|
|
||||||
$_cache_id_parts = explode('|', $_cache_id);
|
|
||||||
$_cache_id_parts_count = count($_cache_id_parts);
|
|
||||||
if ($smarty->use_sub_dirs) {
|
|
||||||
foreach ($_cache_id_parts as $id_part) {
|
|
||||||
$_dir .= $id_part . DS;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (isset($resource_name)) {
|
|
||||||
$_save_stat = $smarty->caching;
|
|
||||||
$smarty->caching = true;
|
|
||||||
$tpl = new $smarty->template_class($resource_name, $smarty);
|
|
||||||
$smarty->caching = $_save_stat;
|
|
||||||
|
|
||||||
// remove from template cache
|
|
||||||
$tpl->source; // have the template registered before unset()
|
|
||||||
if ($smarty->allow_ambiguous_resources) {
|
|
||||||
$_templateId = $tpl->source->unique_resource . $tpl->cache_id . $tpl->compile_id;
|
|
||||||
} else {
|
|
||||||
$_templateId = $smarty->joined_template_dir . '#' . $resource_name . $tpl->cache_id . $tpl->compile_id;
|
|
||||||
}
|
|
||||||
if (isset($_templateId[150])) {
|
|
||||||
$_templateId = sha1($_templateId);
|
|
||||||
}
|
|
||||||
unset($smarty->template_objects[$_templateId]);
|
|
||||||
|
|
||||||
if ($tpl->source->exists) {
|
|
||||||
$_resourcename_parts = basename(str_replace('^', '/', $tpl->cached->filepath));
|
|
||||||
} else {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$_count = 0;
|
|
||||||
$_time = time();
|
|
||||||
if (file_exists($_dir)) {
|
|
||||||
$_cacheDirs = new RecursiveDirectoryIterator($_dir);
|
|
||||||
$_cache = new RecursiveIteratorIterator($_cacheDirs, RecursiveIteratorIterator::CHILD_FIRST);
|
|
||||||
foreach ($_cache as $_file) {
|
|
||||||
if (substr(basename($_file->getPathname()), 0, 1) == '.' || strpos($_file, '.svn') !== false) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
// directory ?
|
|
||||||
if ($_file->isDir()) {
|
|
||||||
if (!$_cache->isDot()) {
|
|
||||||
// delete folder if empty
|
|
||||||
@rmdir($_file->getPathname());
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$_parts = explode($_dir_sep, str_replace('\\', '/', substr((string) $_file, $_dir_length)));
|
|
||||||
$_parts_count = count($_parts);
|
|
||||||
// check name
|
|
||||||
if (isset($resource_name)) {
|
|
||||||
if ($_parts[$_parts_count - 1] != $_resourcename_parts) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// check compile id
|
|
||||||
if (isset($_compile_id) && (!isset($_parts[$_parts_count - 2 - $_compile_id_offset]) || $_parts[$_parts_count - 2 - $_compile_id_offset] != $_compile_id)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
// check cache id
|
|
||||||
if (isset($_cache_id)) {
|
|
||||||
// count of cache id parts
|
|
||||||
$_parts_count = (isset($_compile_id)) ? $_parts_count - 2 - $_compile_id_offset : $_parts_count - 1 - $_compile_id_offset;
|
|
||||||
if ($_parts_count < $_cache_id_parts_count) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
for ($i = 0; $i < $_cache_id_parts_count; $i ++) {
|
|
||||||
if ($_parts[$i] != $_cache_id_parts[$i]) {
|
|
||||||
continue 2;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// expired ?
|
|
||||||
if (isset($exp_time)) {
|
|
||||||
if ($exp_time < 0) {
|
|
||||||
preg_match('#\'cache_lifetime\' =>\s*(\d*)#', file_get_contents($_file), $match);
|
|
||||||
if ($_time < (@filemtime($_file) + $match[1])) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if ($_time - @filemtime($_file) < $exp_time) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$_count += @unlink((string) $_file) ? 1 : 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $_count;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check is cache is locked for this template
|
|
||||||
*
|
|
||||||
* @param Smarty $smarty Smarty object
|
|
||||||
* @param Smarty_Template_Cached $cached cached object
|
|
||||||
*
|
|
||||||
* @return boolean true or false if cache is locked
|
|
||||||
*/
|
|
||||||
public function hasLock(Smarty $smarty, Smarty_Template_Cached $cached)
|
|
||||||
{
|
|
||||||
if (version_compare(PHP_VERSION, '5.3.0', '>=')) {
|
|
||||||
clearstatcache(true, $cached->lock_id);
|
|
||||||
} else {
|
|
||||||
clearstatcache();
|
|
||||||
}
|
|
||||||
$t = @filemtime($cached->lock_id);
|
|
||||||
|
|
||||||
return $t && (time() - $t < $smarty->locking_timeout);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Lock cache for this template
|
|
||||||
*
|
|
||||||
* @param Smarty $smarty Smarty object
|
|
||||||
* @param Smarty_Template_Cached $cached cached object
|
|
||||||
*
|
|
||||||
* @return bool|void
|
|
||||||
*/
|
|
||||||
public function acquireLock(Smarty $smarty, Smarty_Template_Cached $cached)
|
|
||||||
{
|
|
||||||
$cached->is_locked = true;
|
|
||||||
touch($cached->lock_id);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Unlock cache for this template
|
|
||||||
*
|
|
||||||
* @param Smarty $smarty Smarty object
|
|
||||||
* @param Smarty_Template_Cached $cached cached object
|
|
||||||
*
|
|
||||||
* @return bool|void
|
|
||||||
*/
|
|
||||||
public function releaseLock(Smarty $smarty, Smarty_Template_Cached $cached)
|
|
||||||
{
|
|
||||||
$cached->is_locked = false;
|
|
||||||
@unlink($cached->lock_id);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,86 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Assign
|
|
||||||
* Compiles the {assign} tag
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Assign Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Assign extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Compiles code for the {assign} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter)
|
|
||||||
{
|
|
||||||
// the following must be assigned at runtime because it will be overwritten in Smarty_Internal_Compile_Append
|
|
||||||
$this->required_attributes = array('var', 'value');
|
|
||||||
$this->shorttag_order = array('var', 'value');
|
|
||||||
$this->optional_attributes = array('scope');
|
|
||||||
$_nocache = 'null';
|
|
||||||
$_scope = Smarty::SCOPE_LOCAL;
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
// nocache ?
|
|
||||||
if ($compiler->tag_nocache || $compiler->nocache) {
|
|
||||||
$_nocache = 'true';
|
|
||||||
// create nocache var to make it know for further compiling
|
|
||||||
if (isset($compiler->template->tpl_vars[trim($_attr['var'], "'")])) {
|
|
||||||
$compiler->template->tpl_vars[trim($_attr['var'], "'")]->nocache = true;
|
|
||||||
} else {
|
|
||||||
$compiler->template->tpl_vars[trim($_attr['var'], "'")] = new Smarty_variable(null, true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// scope setup
|
|
||||||
if (isset($_attr['scope'])) {
|
|
||||||
$_attr['scope'] = trim($_attr['scope'], "'\"");
|
|
||||||
if ($_attr['scope'] == 'parent') {
|
|
||||||
$_scope = Smarty::SCOPE_PARENT;
|
|
||||||
} elseif ($_attr['scope'] == 'root') {
|
|
||||||
$_scope = Smarty::SCOPE_ROOT;
|
|
||||||
} elseif ($_attr['scope'] == 'global') {
|
|
||||||
$_scope = Smarty::SCOPE_GLOBAL;
|
|
||||||
} else {
|
|
||||||
$compiler->trigger_template_error('illegal value for "scope" attribute', $compiler->lex->taglineno);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// compiled output
|
|
||||||
if (isset($parameter['smarty_internal_index'])) {
|
|
||||||
$output = "<?php \$_smarty_tpl->createLocalArrayVariable($_attr[var], $_nocache, $_scope);\n\$_smarty_tpl->tpl_vars[$_attr[var]]->value$parameter[smarty_internal_index] = $_attr[value];";
|
|
||||||
} else {
|
|
||||||
// implement Smarty2's behaviour of variables assigned by reference
|
|
||||||
if ($compiler->template->smarty instanceof SmartyBC) {
|
|
||||||
$output = "<?php if (isset(\$_smarty_tpl->tpl_vars[$_attr[var]])) {\$_smarty_tpl->tpl_vars[$_attr[var]] = clone \$_smarty_tpl->tpl_vars[$_attr[var]];";
|
|
||||||
$output .= "\n\$_smarty_tpl->tpl_vars[$_attr[var]]->value = $_attr[value]; \$_smarty_tpl->tpl_vars[$_attr[var]]->nocache = $_nocache; \$_smarty_tpl->tpl_vars[$_attr[var]]->scope = $_scope;";
|
|
||||||
$output .= "\n} else \$_smarty_tpl->tpl_vars[$_attr[var]] = new Smarty_variable($_attr[value], $_nocache, $_scope);";
|
|
||||||
} else {
|
|
||||||
$output = "<?php \$_smarty_tpl->tpl_vars[$_attr[var]] = new Smarty_variable($_attr[value], $_nocache, $_scope);";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($_scope == Smarty::SCOPE_PARENT) {
|
|
||||||
$output .= "\nif (\$_smarty_tpl->parent != null) \$_smarty_tpl->parent->tpl_vars[$_attr[var]] = clone \$_smarty_tpl->tpl_vars[$_attr[var]];";
|
|
||||||
} elseif ($_scope == Smarty::SCOPE_ROOT || $_scope == Smarty::SCOPE_GLOBAL) {
|
|
||||||
$output .= "\n\$_ptr = \$_smarty_tpl->parent; while (\$_ptr != null) {\$_ptr->tpl_vars[$_attr[var]] = clone \$_smarty_tpl->tpl_vars[$_attr[var]]; \$_ptr = \$_ptr->parent; }";
|
|
||||||
}
|
|
||||||
if ($_scope == Smarty::SCOPE_GLOBAL) {
|
|
||||||
$output .= "\nSmarty::\$global_tpl_vars[$_attr[var]] = clone \$_smarty_tpl->tpl_vars[$_attr[var]];";
|
|
||||||
}
|
|
||||||
$output .= '?>';
|
|
||||||
|
|
||||||
return $output;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,444 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Block
|
|
||||||
* Compiles the {block}{/block} tags
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Block Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Block extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
|
|
||||||
const parent = '____SMARTY_BLOCK_PARENT____';
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $required_attributes = array('name');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $shorttag_order = array('name');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $option_flags = array('hide', 'append', 'prepend', 'nocache');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $optional_attributes = array('internal_file', 'internal_uid', 'internal_line');
|
|
||||||
/**
|
|
||||||
* nested child block names
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public static $nested_block_names = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* child block source buffer
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public static $block_data = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles code for the {block} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
*
|
|
||||||
* @return boolean true
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
$_name = trim($_attr['name'], "\"'");
|
|
||||||
|
|
||||||
// existing child must override parent settings
|
|
||||||
if (isset($compiler->template->block_data[$_name]) && $compiler->template->block_data[$_name]['mode'] == 'replace') {
|
|
||||||
$_attr['append'] = false;
|
|
||||||
$_attr['prepend'] = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// check if we process an inheritance child template
|
|
||||||
if ($compiler->inheritance_child) {
|
|
||||||
array_unshift(self::$nested_block_names, $_name);
|
|
||||||
// build {block} for child block
|
|
||||||
self::$block_data[$_name]['source'] =
|
|
||||||
"{$compiler->smarty->left_delimiter}private_child_block name={$_attr['name']} file='{$compiler->template->source->filepath}' type='{$compiler->template->source->type}' resource='{$compiler->template->template_resource}'" .
|
|
||||||
" uid='{$compiler->template->source->uid}' line={$compiler->lex->line}";
|
|
||||||
if ($_attr['nocache']) {
|
|
||||||
self::$block_data[$_name]['source'] .= ' nocache';
|
|
||||||
}
|
|
||||||
self::$block_data[$_name]['source'] .= $compiler->smarty->right_delimiter;
|
|
||||||
|
|
||||||
$save = array($_attr, $compiler->inheritance);
|
|
||||||
$this->openTag($compiler, 'block', $save);
|
|
||||||
// set flag for {block} tag
|
|
||||||
$compiler->inheritance = true;
|
|
||||||
$compiler->lex->yypushstate(Smarty_Internal_Templatelexer::CHILDBLOCK);
|
|
||||||
$compiler->has_code = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// must merge includes
|
|
||||||
if ($_attr['nocache'] == true) {
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
}
|
|
||||||
$save = array($_attr, $compiler->inheritance, $compiler->parser->current_buffer, $compiler->nocache);
|
|
||||||
$this->openTag($compiler, 'block', $save);
|
|
||||||
$compiler->inheritance = true;
|
|
||||||
$compiler->nocache = $compiler->nocache | $compiler->tag_nocache;
|
|
||||||
|
|
||||||
$compiler->parser->current_buffer = new _smarty_template_buffer($compiler->parser);
|
|
||||||
$compiler->has_code = false;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compile saved child block source
|
|
||||||
*
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param string $_name optional name of child block
|
|
||||||
*
|
|
||||||
* @return string compiled code of child block
|
|
||||||
*/
|
|
||||||
static function compileChildBlock($compiler, $_name = null)
|
|
||||||
{
|
|
||||||
if ($compiler->inheritance_child) {
|
|
||||||
$name1 = Smarty_Internal_Compile_Block::$nested_block_names[0];
|
|
||||||
if (isset($compiler->template->block_data[$name1])) {
|
|
||||||
// replace inner block name with generic
|
|
||||||
Smarty_Internal_Compile_Block::$block_data[$name1]['source'] .= $compiler->template->block_data[$name1]['source'];
|
|
||||||
Smarty_Internal_Compile_Block::$block_data[$name1]['child'] = true;
|
|
||||||
}
|
|
||||||
$compiler->lex->yypushstate(Smarty_Internal_Templatelexer::CHILDBLOCK);
|
|
||||||
$compiler->has_code = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// if called by {$smarty.block.child} we must search the name of enclosing {block}
|
|
||||||
if ($_name == null) {
|
|
||||||
$stack_count = count($compiler->_tag_stack);
|
|
||||||
while (--$stack_count >= 0) {
|
|
||||||
if ($compiler->_tag_stack[$stack_count][0] == 'block') {
|
|
||||||
$_name = trim($compiler->_tag_stack[$stack_count][1][0]['name'], "\"'");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($_name == null) {
|
|
||||||
$compiler->trigger_template_error(' tag {$smarty.block.child} used outside {block} tags ', $compiler->lex->taglineno);
|
|
||||||
}
|
|
||||||
// undefined child?
|
|
||||||
if (!isset($compiler->template->block_data[$_name]['source'])) {
|
|
||||||
$compiler->popTrace();
|
|
||||||
return '';
|
|
||||||
}
|
|
||||||
// flag that child is already compile by {$smarty.block.child} inclusion
|
|
||||||
$compiler->template->block_data[$_name]['compiled'] = true;
|
|
||||||
$_tpl = new Smarty_Internal_template('string:' . $compiler->template->block_data[$_name]['source'], $compiler->smarty, $compiler->template, $compiler->template->cache_id,
|
|
||||||
$compiler->template->compile_id, $compiler->template->caching, $compiler->template->cache_lifetime);
|
|
||||||
if ($compiler->smarty->debugging) {
|
|
||||||
Smarty_Internal_Debug::ignore($_tpl);
|
|
||||||
}
|
|
||||||
$_tpl->tpl_vars = $compiler->template->tpl_vars;
|
|
||||||
$_tpl->variable_filters = $compiler->template->variable_filters;
|
|
||||||
$_tpl->properties['nocache_hash'] = $compiler->template->properties['nocache_hash'];
|
|
||||||
$_tpl->allow_relative_path = true;
|
|
||||||
$_tpl->compiler->inheritance = true;
|
|
||||||
$_tpl->compiler->suppressHeader = true;
|
|
||||||
$_tpl->compiler->suppressFilter = true;
|
|
||||||
$_tpl->compiler->suppressTemplatePropertyHeader = true;
|
|
||||||
$_tpl->compiler->suppressMergedTemplates = true;
|
|
||||||
$nocache = $compiler->nocache || $compiler->tag_nocache;
|
|
||||||
if (strpos($compiler->template->block_data[$_name]['source'], self::parent) !== false) {
|
|
||||||
$_output = str_replace(self::parent, $compiler->parser->current_buffer->to_smarty_php(), $_tpl->compiler->compileTemplate($_tpl, $nocache));
|
|
||||||
} elseif ($compiler->template->block_data[$_name]['mode'] == 'prepend') {
|
|
||||||
$_output = $_tpl->compiler->compileTemplate($_tpl, $nocache) . $compiler->parser->current_buffer->to_smarty_php();
|
|
||||||
} elseif ($compiler->template->block_data[$_name]['mode'] == 'append') {
|
|
||||||
$_output = $compiler->parser->current_buffer->to_smarty_php() . $_tpl->compiler->compileTemplate($_tpl, $nocache);
|
|
||||||
} elseif (!empty($compiler->template->block_data[$_name])) {
|
|
||||||
$_output = $_tpl->compiler->compileTemplate($_tpl, $nocache);
|
|
||||||
}
|
|
||||||
$compiler->template->properties['file_dependency'] = array_merge($compiler->template->properties['file_dependency'], $_tpl->properties['file_dependency']);
|
|
||||||
$compiler->template->properties['function'] = array_merge($compiler->template->properties['function'], $_tpl->properties['function']);
|
|
||||||
$compiler->merged_templates = array_merge($compiler->merged_templates, $_tpl->compiler->merged_templates);
|
|
||||||
$compiler->template->variable_filters = $_tpl->variable_filters;
|
|
||||||
if ($_tpl->has_nocache_code) {
|
|
||||||
$compiler->template->has_nocache_code = true;
|
|
||||||
}
|
|
||||||
foreach ($_tpl->required_plugins as $key => $tmp1) {
|
|
||||||
if ($compiler->nocache && $compiler->template->caching) {
|
|
||||||
$code = 'nocache';
|
|
||||||
} else {
|
|
||||||
$code = $key;
|
|
||||||
}
|
|
||||||
foreach ($tmp1 as $name => $tmp) {
|
|
||||||
foreach ($tmp as $type => $data) {
|
|
||||||
$compiler->template->required_plugins[$code][$name][$type] = $data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
unset($_tpl);
|
|
||||||
$compiler->has_code = true;
|
|
||||||
return $_output;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compile $smarty.block.parent
|
|
||||||
*
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param string $_name optional name of child block
|
|
||||||
*
|
|
||||||
* @return string compiled code of child block
|
|
||||||
*/
|
|
||||||
static function compileParentBlock($compiler, $_name = null)
|
|
||||||
{
|
|
||||||
// if called by {$smarty.block.parent} we must search the name of enclosing {block}
|
|
||||||
if ($_name == null) {
|
|
||||||
$stack_count = count($compiler->_tag_stack);
|
|
||||||
while (--$stack_count >= 0) {
|
|
||||||
if ($compiler->_tag_stack[$stack_count][0] == 'block') {
|
|
||||||
$_name = trim($compiler->_tag_stack[$stack_count][1][0]['name'], "\"'");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($_name == null) {
|
|
||||||
$compiler->trigger_template_error(' tag {$smarty.block.parent} used outside {block} tags ', $compiler->lex->taglineno);
|
|
||||||
}
|
|
||||||
if (empty(Smarty_Internal_Compile_Block::$nested_block_names)) {
|
|
||||||
$compiler->trigger_template_error(' illegal {$smarty.block.parent} in parent template ', $compiler->lex->taglineno);
|
|
||||||
}
|
|
||||||
Smarty_Internal_Compile_Block::$block_data[Smarty_Internal_Compile_Block::$nested_block_names[0]]['source'] .= Smarty_Internal_Compile_Block::parent;
|
|
||||||
$compiler->lex->yypushstate(Smarty_Internal_Templatelexer::CHILDBLOCK);
|
|
||||||
$compiler->has_code = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Process block source
|
|
||||||
*
|
|
||||||
* @param $compiler
|
|
||||||
* @param string $source source text
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
static function blockSource($compiler, $source)
|
|
||||||
{
|
|
||||||
Smarty_Internal_Compile_Block::$block_data[Smarty_Internal_Compile_Block::$nested_block_names[0]]['source'] .= $source;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile BlockClose Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Blockclose extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Compiles code for the {/block} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler)
|
|
||||||
{
|
|
||||||
$compiler->has_code = true;
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
$saved_data = $this->closeTag($compiler, array('block'));
|
|
||||||
$_name = trim($saved_data[0]['name'], "\"'");
|
|
||||||
// reset flag for {block} tag
|
|
||||||
$compiler->inheritance = $saved_data[1];
|
|
||||||
// check if we process an inheritance child template
|
|
||||||
if ($compiler->inheritance_child) {
|
|
||||||
$name1 = Smarty_Internal_Compile_Block::$nested_block_names[0];
|
|
||||||
Smarty_Internal_Compile_Block::$block_data[$name1]['source'] .= "{$compiler->smarty->left_delimiter}/private_child_block{$compiler->smarty->right_delimiter}";
|
|
||||||
array_shift(Smarty_Internal_Compile_Block::$nested_block_names);
|
|
||||||
if (!empty(Smarty_Internal_Compile_Block::$nested_block_names)) {
|
|
||||||
$name2 = Smarty_Internal_Compile_Block::$nested_block_names[0];
|
|
||||||
if (isset($compiler->template->block_data[$name1]) || !$saved_data[0]['hide']) {
|
|
||||||
if (isset(Smarty_Internal_Compile_Block::$block_data[$name1]['child']) || !isset($compiler->template->block_data[$name1])) {
|
|
||||||
Smarty_Internal_Compile_Block::$block_data[$name2]['source'] .= Smarty_Internal_Compile_Block::$block_data[$name1]['source'];
|
|
||||||
} else {
|
|
||||||
if ($compiler->template->block_data[$name1]['mode'] == 'append') {
|
|
||||||
Smarty_Internal_Compile_Block::$block_data[$name2]['source'] .= Smarty_Internal_Compile_Block::$block_data[$name1]['source'] . $compiler->template->block_data[$name1]['source'];
|
|
||||||
} elseif ($compiler->template->block_data[$name1]['mode'] == 'prepend') {
|
|
||||||
Smarty_Internal_Compile_Block::$block_data[$name2]['source'] .= $compiler->template->block_data[$name1]['source'] . Smarty_Internal_Compile_Block::$block_data[$name1]['source'];
|
|
||||||
} else {
|
|
||||||
Smarty_Internal_Compile_Block::$block_data[$name2]['source'] .= $compiler->template->block_data[$name1]['source'];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
unset(Smarty_Internal_Compile_Block::$block_data[$name1]);
|
|
||||||
$compiler->lex->yypushstate(Smarty_Internal_Templatelexer::CHILDBLOCK);
|
|
||||||
} else {
|
|
||||||
if (isset($compiler->template->block_data[$name1]) || !$saved_data[0]['hide']) {
|
|
||||||
if (isset($compiler->template->block_data[$name1]) && !isset(Smarty_Internal_Compile_Block::$block_data[$name1]['child'])) {
|
|
||||||
if (strpos($compiler->template->block_data[$name1]['source'], Smarty_Internal_Compile_Block::parent) !== false) {
|
|
||||||
$compiler->template->block_data[$name1]['source'] =
|
|
||||||
str_replace(Smarty_Internal_Compile_Block::parent, Smarty_Internal_Compile_Block::$block_data[$name1]['source'], $compiler->template->block_data[$name1]['source']);
|
|
||||||
} elseif ($compiler->template->block_data[$name1]['mode'] == 'prepend') {
|
|
||||||
$compiler->template->block_data[$name1]['source'] .= Smarty_Internal_Compile_Block::$block_data[$name1]['source'];
|
|
||||||
} elseif ($compiler->template->block_data[$name1]['mode'] == 'append') {
|
|
||||||
$compiler->template->block_data[$name1]['source'] = Smarty_Internal_Compile_Block::$block_data[$name1]['source'] . $compiler->template->block_data[$name1]['source'];
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$compiler->template->block_data[$name1]['source'] = Smarty_Internal_Compile_Block::$block_data[$name1]['source'];
|
|
||||||
}
|
|
||||||
$compiler->template->block_data[$name1]['mode'] = 'replace';
|
|
||||||
if ($saved_data[0]['append']) {
|
|
||||||
$compiler->template->block_data[$name1]['mode'] = 'append';
|
|
||||||
}
|
|
||||||
if ($saved_data[0]['prepend']) {
|
|
||||||
$compiler->template->block_data[$name1]['mode'] = 'prepend';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
unset(Smarty_Internal_Compile_Block::$block_data[$name1]);
|
|
||||||
$compiler->lex->yypushstate(Smarty_Internal_Templatelexer::CHILDBODY);
|
|
||||||
}
|
|
||||||
$compiler->has_code = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (isset($compiler->template->block_data[$_name]) && !isset($compiler->template->block_data[$_name]['compiled'])) {
|
|
||||||
$_output = Smarty_Internal_Compile_Block::compileChildBlock($compiler, $_name);
|
|
||||||
} else {
|
|
||||||
if ($saved_data[0]['hide'] && !isset($compiler->template->block_data[$_name]['source'])) {
|
|
||||||
$_output = '';
|
|
||||||
} else {
|
|
||||||
$_output = $compiler->parser->current_buffer->to_smarty_php();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
unset($compiler->template->block_data[$_name]['compiled']);
|
|
||||||
// reset flags
|
|
||||||
$compiler->parser->current_buffer = $saved_data[2];
|
|
||||||
if ($compiler->nocache) {
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
}
|
|
||||||
$compiler->nocache = $saved_data[3];
|
|
||||||
// $_output content has already nocache code processed
|
|
||||||
$compiler->suppressNocacheProcessing = true;
|
|
||||||
|
|
||||||
return $_output;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Child Block Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Private_Child_Block extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $required_attributes = array('name', 'file', 'uid', 'line', 'type', 'resource');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles code for the {private_child_block} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
*
|
|
||||||
* @return boolean true
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
|
|
||||||
// update template with original template resource of {block}
|
|
||||||
if (trim($_attr['type'], "'") == 'file') {
|
|
||||||
$compiler->template->template_resource = 'file:' . realpath(trim($_attr['file'], "'"));
|
|
||||||
} else {
|
|
||||||
$compiler->template->template_resource = trim($_attr['resource'], "'");
|
|
||||||
}
|
|
||||||
// source object
|
|
||||||
unset ($compiler->template->source);
|
|
||||||
$exists = $compiler->template->source->exists;
|
|
||||||
|
|
||||||
// must merge includes
|
|
||||||
if ($_attr['nocache'] == true) {
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
}
|
|
||||||
$save = array($_attr, $compiler->nocache);
|
|
||||||
|
|
||||||
// set trace back to child block
|
|
||||||
$compiler->pushTrace(trim($_attr['file'], "\"'"), trim($_attr['uid'], "\"'"), $_attr['line'] - $compiler->lex->line);
|
|
||||||
|
|
||||||
$this->openTag($compiler, 'private_child_block', $save);
|
|
||||||
|
|
||||||
$compiler->nocache = $compiler->nocache | $compiler->tag_nocache;
|
|
||||||
$compiler->has_code = false;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Child Block Close Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Private_Child_Blockclose extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles code for the {/private_child_block} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
*
|
|
||||||
* @return boolean true
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
|
|
||||||
$saved_data = $this->closeTag($compiler, array('private_child_block'));
|
|
||||||
|
|
||||||
// end of child block
|
|
||||||
$compiler->popTrace();
|
|
||||||
|
|
||||||
$compiler->nocache = $saved_data[1];
|
|
||||||
$compiler->has_code = false;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,127 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Function_Call
|
|
||||||
* Compiles the calls of user defined tags defined by {function}
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Function_Call Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Call extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $required_attributes = array('name');
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $shorttag_order = array('name');
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $optional_attributes = array('_any');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles the calls of user defined tags defined by {function}
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
// save possible attributes
|
|
||||||
if (isset($_attr['assign'])) {
|
|
||||||
// output will be stored in a smarty variable instead of being displayed
|
|
||||||
$_assign = $_attr['assign'];
|
|
||||||
}
|
|
||||||
$_name = $_attr['name'];
|
|
||||||
if ($compiler->compiles_template_function) {
|
|
||||||
$compiler->called_functions[] = trim($_name, "'\"");
|
|
||||||
}
|
|
||||||
unset($_attr['name'], $_attr['assign'], $_attr['nocache']);
|
|
||||||
// set flag (compiled code of {function} must be included in cache file
|
|
||||||
if ($compiler->nocache || $compiler->tag_nocache) {
|
|
||||||
$_nocache = 'true';
|
|
||||||
} else {
|
|
||||||
$_nocache = 'false';
|
|
||||||
}
|
|
||||||
$_paramsArray = array();
|
|
||||||
foreach ($_attr as $_key => $_value) {
|
|
||||||
if (is_int($_key)) {
|
|
||||||
$_paramsArray[] = "$_key=>$_value";
|
|
||||||
} else {
|
|
||||||
$_paramsArray[] = "'$_key'=>$_value";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (isset($compiler->template->properties['function'][$_name]['parameter'])) {
|
|
||||||
foreach ($compiler->template->properties['function'][$_name]['parameter'] as $_key => $_value) {
|
|
||||||
if (!isset($_attr[$_key])) {
|
|
||||||
if (is_int($_key)) {
|
|
||||||
$_paramsArray[] = "$_key=>$_value";
|
|
||||||
} else {
|
|
||||||
$_paramsArray[] = "'$_key'=>$_value";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} elseif (isset($compiler->smarty->template_functions[$_name]['parameter'])) {
|
|
||||||
foreach ($compiler->smarty->template_functions[$_name]['parameter'] as $_key => $_value) {
|
|
||||||
if (!isset($_attr[$_key])) {
|
|
||||||
if (is_int($_key)) {
|
|
||||||
$_paramsArray[] = "$_key=>$_value";
|
|
||||||
} else {
|
|
||||||
$_paramsArray[] = "'$_key'=>$_value";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
//variable name?
|
|
||||||
if (!(strpos($_name, '$') === false)) {
|
|
||||||
$call_cache = $_name;
|
|
||||||
$call_function = '$tmp = "smarty_template_function_".' . $_name . '; $tmp';
|
|
||||||
} else {
|
|
||||||
$_name = trim($_name, "'\"");
|
|
||||||
$call_cache = "'{$_name}'";
|
|
||||||
$call_function = 'smarty_template_function_' . $_name;
|
|
||||||
}
|
|
||||||
|
|
||||||
$_params = 'array(' . implode(",", $_paramsArray) . ')';
|
|
||||||
$_hash = str_replace('-', '_', $compiler->template->properties['nocache_hash']);
|
|
||||||
// was there an assign attribute
|
|
||||||
if (isset($_assign)) {
|
|
||||||
if ($compiler->template->caching) {
|
|
||||||
$_output = "<?php ob_start(); Smarty_Internal_Function_Call_Handler::call ({$call_cache},\$_smarty_tpl,{$_params},'{$_hash}',{$_nocache}); \$_smarty_tpl->assign({$_assign}, ob_get_clean());?>\n";
|
|
||||||
} else {
|
|
||||||
$_output = "<?php ob_start(); {$call_function}(\$_smarty_tpl,{$_params}); \$_smarty_tpl->assign({$_assign}, ob_get_clean());?>\n";
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if ($compiler->template->caching) {
|
|
||||||
$_output = "<?php Smarty_Internal_Function_Call_Handler::call ({$call_cache},\$_smarty_tpl,{$_params},'{$_hash}',{$_nocache});?>\n";
|
|
||||||
} else {
|
|
||||||
$_output = "<?php {$call_function}(\$_smarty_tpl,{$_params});?>\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $_output;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,96 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Capture
|
|
||||||
* Compiles the {capture} tag
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Capture Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Capture extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $shorttag_order = array('name');
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $optional_attributes = array('name', 'assign', 'append');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles code for the {capture} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
|
|
||||||
$buffer = isset($_attr['name']) ? $_attr['name'] : "'default'";
|
|
||||||
$assign = isset($_attr['assign']) ? $_attr['assign'] : 'null';
|
|
||||||
$append = isset($_attr['append']) ? $_attr['append'] : 'null';
|
|
||||||
|
|
||||||
$compiler->_capture_stack[0][] = array($buffer, $assign, $append, $compiler->nocache);
|
|
||||||
// maybe nocache because of nocache variables
|
|
||||||
$compiler->nocache = $compiler->nocache | $compiler->tag_nocache;
|
|
||||||
$_output = "<?php \$_smarty_tpl->_capture_stack[0][] = array($buffer, $assign, $append); ob_start(); ?>";
|
|
||||||
|
|
||||||
return $_output;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Captureclose Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_CaptureClose extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Compiles code for the {/capture} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
// must endblock be nocache?
|
|
||||||
if ($compiler->nocache) {
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
list($buffer, $assign, $append, $compiler->nocache) = array_pop($compiler->_capture_stack[0]);
|
|
||||||
|
|
||||||
$_output = "<?php list(\$_capture_buffer, \$_capture_assign, \$_capture_append) = array_pop(\$_smarty_tpl->_capture_stack[0]);\n";
|
|
||||||
$_output .= "if (!empty(\$_capture_buffer)) {\n";
|
|
||||||
$_output .= " if (isset(\$_capture_assign)) \$_smarty_tpl->assign(\$_capture_assign, ob_get_contents());\n";
|
|
||||||
$_output .= " if (isset( \$_capture_append)) \$_smarty_tpl->append( \$_capture_append, ob_get_contents());\n";
|
|
||||||
$_output .= " Smarty::\$_smarty_vars['capture'][\$_capture_buffer]=ob_get_clean();\n";
|
|
||||||
$_output .= "} else \$_smarty_tpl->capture_error();?>";
|
|
||||||
|
|
||||||
return $_output;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,85 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile extend
|
|
||||||
* Compiles the {extends} tag
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile extend Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Extends extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $required_attributes = array('file');
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $shorttag_order = array('file');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles code for the {extends} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
if ($_attr['nocache'] === true) {
|
|
||||||
$compiler->trigger_template_error('nocache option not allowed', $compiler->lex->taglineno);
|
|
||||||
}
|
|
||||||
if (strpos($_attr['file'], '$_tmp') !== false) {
|
|
||||||
$compiler->trigger_template_error('illegal value for file attribute', $compiler->lex->taglineno);
|
|
||||||
}
|
|
||||||
|
|
||||||
$name = $_attr['file'];
|
|
||||||
/** @var Smarty_Internal_Template $_smarty_tpl
|
|
||||||
* used in evaluated code
|
|
||||||
*/
|
|
||||||
$_smarty_tpl = $compiler->template;
|
|
||||||
eval("\$tpl_name = $name;");
|
|
||||||
// create template object
|
|
||||||
$_template = new $compiler->smarty->template_class($tpl_name, $compiler->smarty, $compiler->template);
|
|
||||||
// check for recursion
|
|
||||||
$uid = $_template->source->uid;
|
|
||||||
if (isset($compiler->extends_uid[$uid])) {
|
|
||||||
$compiler->trigger_template_error("illegal recursive call of \"$include_file\"", $compiler->lex->line - 1);
|
|
||||||
}
|
|
||||||
$compiler->extends_uid[$uid] = true;
|
|
||||||
if (empty($_template->source->components)) {
|
|
||||||
array_unshift($compiler->sources, $_template->source);
|
|
||||||
} else {
|
|
||||||
foreach ($_template->source->components as $source) {
|
|
||||||
array_unshift($compiler->sources, $source);
|
|
||||||
$uid = $source->uid;
|
|
||||||
if (isset($compiler->extends_uid[$uid])) {
|
|
||||||
$compiler->trigger_template_error("illegal recursive call of \"{$source->filepath}\"", $compiler->lex->line - 1);
|
|
||||||
}
|
|
||||||
$compiler->extends_uid[$uid] = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
unset ($_template);
|
|
||||||
$compiler->inheritance_child = true;
|
|
||||||
$compiler->lex->yypushstate(Smarty_Internal_Templatelexer::CHILDBODY);
|
|
||||||
return '';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,229 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Foreach
|
|
||||||
* Compiles the {foreach} {foreachelse} {/foreach} tags
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Foreach Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Foreach extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $required_attributes = array('from', 'item');
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $optional_attributes = array('name', 'key');
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $shorttag_order = array('from', 'item', 'key', 'name');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles code for the {foreach} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
|
|
||||||
$from = $_attr['from'];
|
|
||||||
$item = $_attr['item'];
|
|
||||||
if (!strncmp("\$_smarty_tpl->tpl_vars[$item]", $from, strlen($item) + 24)) {
|
|
||||||
$compiler->trigger_template_error("item variable {$item} may not be the same variable as at 'from'", $compiler->lex->taglineno);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isset($_attr['key'])) {
|
|
||||||
$key = $_attr['key'];
|
|
||||||
} else {
|
|
||||||
$key = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->openTag($compiler, 'foreach', array('foreach', $compiler->nocache, $item, $key));
|
|
||||||
// maybe nocache because of nocache variables
|
|
||||||
$compiler->nocache = $compiler->nocache | $compiler->tag_nocache;
|
|
||||||
|
|
||||||
if (isset($_attr['name'])) {
|
|
||||||
$name = $_attr['name'];
|
|
||||||
$has_name = true;
|
|
||||||
$SmartyVarName = '$smarty.foreach.' . trim($name, '\'"') . '.';
|
|
||||||
} else {
|
|
||||||
$name = null;
|
|
||||||
$has_name = false;
|
|
||||||
}
|
|
||||||
$ItemVarName = '$' . trim($item, '\'"') . '@';
|
|
||||||
// evaluates which Smarty variables and properties have to be computed
|
|
||||||
if ($has_name) {
|
|
||||||
$usesSmartyFirst = strpos($compiler->lex->data, $SmartyVarName . 'first') !== false;
|
|
||||||
$usesSmartyLast = strpos($compiler->lex->data, $SmartyVarName . 'last') !== false;
|
|
||||||
$usesSmartyIndex = strpos($compiler->lex->data, $SmartyVarName . 'index') !== false;
|
|
||||||
$usesSmartyIteration = strpos($compiler->lex->data, $SmartyVarName . 'iteration') !== false;
|
|
||||||
$usesSmartyShow = strpos($compiler->lex->data, $SmartyVarName . 'show') !== false;
|
|
||||||
$usesSmartyTotal = strpos($compiler->lex->data, $SmartyVarName . 'total') !== false;
|
|
||||||
} else {
|
|
||||||
$usesSmartyFirst = false;
|
|
||||||
$usesSmartyLast = false;
|
|
||||||
$usesSmartyTotal = false;
|
|
||||||
$usesSmartyShow = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$usesPropFirst = $usesSmartyFirst || strpos($compiler->lex->data, $ItemVarName . 'first') !== false;
|
|
||||||
$usesPropLast = $usesSmartyLast || strpos($compiler->lex->data, $ItemVarName . 'last') !== false;
|
|
||||||
$usesPropIndex = $usesPropFirst || strpos($compiler->lex->data, $ItemVarName . 'index') !== false;
|
|
||||||
$usesPropIteration = $usesPropLast || strpos($compiler->lex->data, $ItemVarName . 'iteration') !== false;
|
|
||||||
$usesPropShow = strpos($compiler->lex->data, $ItemVarName . 'show') !== false;
|
|
||||||
$usesPropTotal = $usesSmartyTotal || $usesSmartyShow || $usesPropShow || $usesPropLast || strpos($compiler->lex->data, $ItemVarName . 'total') !== false;
|
|
||||||
// generate output code
|
|
||||||
$output = "<?php ";
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars[$item] = new Smarty_Variable; \$_smarty_tpl->tpl_vars[$item]->_loop = false;\n";
|
|
||||||
if ($key != null) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars[$key] = new Smarty_Variable;\n";
|
|
||||||
}
|
|
||||||
$output .= " \$_from = $from; if (!is_array(\$_from) && !is_object(\$_from)) { settype(\$_from, 'array');}\n";
|
|
||||||
if ($usesPropTotal) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars[$item]->total= \$_smarty_tpl->_count(\$_from);\n";
|
|
||||||
}
|
|
||||||
if ($usesPropIteration) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars[$item]->iteration=0;\n";
|
|
||||||
}
|
|
||||||
if ($usesPropIndex) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars[$item]->index=-1;\n";
|
|
||||||
}
|
|
||||||
if ($usesPropShow) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars[$item]->show = (\$_smarty_tpl->tpl_vars[$item]->total > 0);\n";
|
|
||||||
}
|
|
||||||
if ($has_name) {
|
|
||||||
if ($usesSmartyTotal) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['total'] = \$_smarty_tpl->tpl_vars[$item]->total;\n";
|
|
||||||
}
|
|
||||||
if ($usesSmartyIteration) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['iteration']=0;\n";
|
|
||||||
}
|
|
||||||
if ($usesSmartyIndex) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['index']=-1;\n";
|
|
||||||
}
|
|
||||||
if ($usesSmartyShow) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['show']=(\$_smarty_tpl->tpl_vars[$item]->total > 0);\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$output .= "foreach (\$_from as \$_smarty_tpl->tpl_vars[$item]->key => \$_smarty_tpl->tpl_vars[$item]->value) {\n\$_smarty_tpl->tpl_vars[$item]->_loop = true;\n";
|
|
||||||
if ($key != null) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars[$key]->value = \$_smarty_tpl->tpl_vars[$item]->key;\n";
|
|
||||||
}
|
|
||||||
if ($usesPropIteration) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars[$item]->iteration++;\n";
|
|
||||||
}
|
|
||||||
if ($usesPropIndex) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars[$item]->index++;\n";
|
|
||||||
}
|
|
||||||
if ($usesPropFirst) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars[$item]->first = \$_smarty_tpl->tpl_vars[$item]->index === 0;\n";
|
|
||||||
}
|
|
||||||
if ($usesPropLast) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars[$item]->last = \$_smarty_tpl->tpl_vars[$item]->iteration === \$_smarty_tpl->tpl_vars[$item]->total;\n";
|
|
||||||
}
|
|
||||||
if ($has_name) {
|
|
||||||
if ($usesSmartyFirst) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['first'] = \$_smarty_tpl->tpl_vars[$item]->first;\n";
|
|
||||||
}
|
|
||||||
if ($usesSmartyIteration) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['iteration']++;\n";
|
|
||||||
}
|
|
||||||
if ($usesSmartyIndex) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['index']++;\n";
|
|
||||||
}
|
|
||||||
if ($usesSmartyLast) {
|
|
||||||
$output .= " \$_smarty_tpl->tpl_vars['smarty']->value['foreach'][$name]['last'] = \$_smarty_tpl->tpl_vars[$item]->last;\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$output .= "?>";
|
|
||||||
|
|
||||||
return $output;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Foreachelse Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Foreachelse extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Compiles code for the {foreachelse} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
|
|
||||||
list($openTag, $nocache, $item, $key) = $this->closeTag($compiler, array('foreach'));
|
|
||||||
$this->openTag($compiler, 'foreachelse', array('foreachelse', $nocache, $item, $key));
|
|
||||||
|
|
||||||
return "<?php }\nif (!\$_smarty_tpl->tpl_vars[$item]->_loop) {\n?>";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Foreachclose Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Foreachclose extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Compiles code for the {/foreach} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
// must endblock be nocache?
|
|
||||||
if ($compiler->nocache) {
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
list($openTag, $compiler->nocache, $item, $key) = $this->closeTag($compiler, array('foreach', 'foreachelse'));
|
|
||||||
|
|
||||||
return "<?php } ?>";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,162 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Function
|
|
||||||
* Compiles the {function} {/function} tags
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Function Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Function extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $required_attributes = array('name');
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $shorttag_order = array('name');
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $optional_attributes = array('_any');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles code for the {function} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
*
|
|
||||||
* @return boolean true
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
|
|
||||||
if ($_attr['nocache'] === true) {
|
|
||||||
$compiler->trigger_template_error('nocache option not allowed', $compiler->lex->taglineno);
|
|
||||||
}
|
|
||||||
unset($_attr['nocache']);
|
|
||||||
$save = array($_attr, $compiler->parser->current_buffer,
|
|
||||||
$compiler->template->has_nocache_code, $compiler->template->required_plugins);
|
|
||||||
$this->openTag($compiler, 'function', $save);
|
|
||||||
$_name = trim($_attr['name'], "'\"");
|
|
||||||
unset($_attr['name']);
|
|
||||||
// set flag that we are compiling a template function
|
|
||||||
$compiler->compiles_template_function = true;
|
|
||||||
$compiler->template->properties['function'][$_name]['parameter'] = array();
|
|
||||||
/** @var Smarty_Internal_Template $_smarty_tpl
|
|
||||||
* used in evaluated code
|
|
||||||
*/
|
|
||||||
$_smarty_tpl = $compiler->template;
|
|
||||||
foreach ($_attr as $_key => $_data) {
|
|
||||||
eval ('$tmp=' . $_data . ';');
|
|
||||||
$compiler->template->properties['function'][$_name]['parameter'][$_key] = $tmp;
|
|
||||||
}
|
|
||||||
$compiler->smarty->template_functions[$_name]['parameter'] = $compiler->template->properties['function'][$_name]['parameter'];
|
|
||||||
if ($compiler->template->caching) {
|
|
||||||
$output = '';
|
|
||||||
} else {
|
|
||||||
$output = "<?php if (!function_exists('smarty_template_function_{$_name}')) {
|
|
||||||
function smarty_template_function_{$_name}(\$_smarty_tpl,\$params) {
|
|
||||||
\$saved_tpl_vars = \$_smarty_tpl->tpl_vars;
|
|
||||||
foreach (\$_smarty_tpl->smarty->template_functions['{$_name}']['parameter'] as \$key => \$value) {\$_smarty_tpl->tpl_vars[\$key] = new Smarty_variable(\$value);};
|
|
||||||
foreach (\$params as \$key => \$value) {\$_smarty_tpl->tpl_vars[\$key] = new Smarty_variable(\$value);}?>";
|
|
||||||
}
|
|
||||||
// Init temporary context
|
|
||||||
$compiler->template->required_plugins = array('compiled' => array(), 'nocache' => array());
|
|
||||||
$compiler->parser->current_buffer = new _smarty_template_buffer($compiler->parser);
|
|
||||||
$compiler->parser->current_buffer->append_subtree(new _smarty_tag($compiler->parser, $output));
|
|
||||||
$compiler->template->has_nocache_code = false;
|
|
||||||
$compiler->has_code = false;
|
|
||||||
$compiler->template->properties['function'][$_name]['compiled'] = '';
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Functionclose Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Functionclose extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Compiles code for the {/function} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
*
|
|
||||||
* @return boolean true
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter)
|
|
||||||
{
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
$saved_data = $this->closeTag($compiler, array('function'));
|
|
||||||
$_name = trim($saved_data[0]['name'], "'\"");
|
|
||||||
// build plugin include code
|
|
||||||
$plugins_string = '';
|
|
||||||
if (!empty($compiler->template->required_plugins['compiled'])) {
|
|
||||||
$plugins_string = '<?php ';
|
|
||||||
foreach ($compiler->template->required_plugins['compiled'] as $tmp) {
|
|
||||||
foreach ($tmp as $data) {
|
|
||||||
$plugins_string .= "if (!is_callable('{$data['function']}')) include '{$data['file']}';\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$plugins_string .= '?>';
|
|
||||||
}
|
|
||||||
if (!empty($compiler->template->required_plugins['nocache'])) {
|
|
||||||
$plugins_string .= "<?php echo '/*%%SmartyNocache:{$compiler->template->properties['nocache_hash']}%%*/<?php ";
|
|
||||||
foreach ($compiler->template->required_plugins['nocache'] as $tmp) {
|
|
||||||
foreach ($tmp as $data) {
|
|
||||||
$plugins_string .= "if (!is_callable(\'{$data['function']}\')) include \'{$data['file']}\';\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$plugins_string .= "?>/*/%%SmartyNocache:{$compiler->template->properties['nocache_hash']}%%*/';?>\n";
|
|
||||||
}
|
|
||||||
// if caching save template function for possible nocache call
|
|
||||||
if ($compiler->template->caching) {
|
|
||||||
$compiler->template->properties['function'][$_name]['compiled'] .= $plugins_string
|
|
||||||
. $compiler->parser->current_buffer->to_smarty_php();
|
|
||||||
$compiler->template->properties['function'][$_name]['nocache_hash'] = $compiler->template->properties['nocache_hash'];
|
|
||||||
$compiler->template->properties['function'][$_name]['has_nocache_code'] = $compiler->template->has_nocache_code;
|
|
||||||
$compiler->template->properties['function'][$_name]['called_functions'] = $compiler->called_functions;
|
|
||||||
$compiler->called_functions = array();
|
|
||||||
$compiler->smarty->template_functions[$_name] = $compiler->template->properties['function'][$_name];
|
|
||||||
$compiler->has_code = false;
|
|
||||||
$output = true;
|
|
||||||
} else {
|
|
||||||
$output = $plugins_string . $compiler->parser->current_buffer->to_smarty_php() . "<?php \$_smarty_tpl->tpl_vars = \$saved_tpl_vars;
|
|
||||||
foreach (Smarty::\$global_tpl_vars as \$key => \$value) if(!isset(\$_smarty_tpl->tpl_vars[\$key])) \$_smarty_tpl->tpl_vars[\$key] = \$value;}}?>\n";
|
|
||||||
}
|
|
||||||
// reset flag that we are compiling a template function
|
|
||||||
$compiler->compiles_template_function = false;
|
|
||||||
// restore old compiler status
|
|
||||||
$compiler->parser->current_buffer = $saved_data[1];
|
|
||||||
$compiler->template->has_nocache_code = $compiler->template->has_nocache_code | $saved_data[2];
|
|
||||||
$compiler->template->required_plugins = $saved_data[3];
|
|
||||||
|
|
||||||
return $output;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,210 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile If
|
|
||||||
* Compiles the {if} {else} {elseif} {/if} tags
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile If Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_If extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Compiles code for the {if} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
$this->openTag($compiler, 'if', array(1, $compiler->nocache));
|
|
||||||
// must whole block be nocache ?
|
|
||||||
$compiler->nocache = $compiler->nocache | $compiler->tag_nocache;
|
|
||||||
|
|
||||||
if (!array_key_exists("if condition", $parameter)) {
|
|
||||||
$compiler->trigger_template_error("missing if condition", $compiler->lex->taglineno);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (is_array($parameter['if condition'])) {
|
|
||||||
if ($compiler->nocache) {
|
|
||||||
$_nocache = ',true';
|
|
||||||
// create nocache var to make it know for further compiling
|
|
||||||
if (is_array($parameter['if condition']['var'])) {
|
|
||||||
$compiler->template->tpl_vars[trim($parameter['if condition']['var']['var'], "'")] = new Smarty_variable(null, true);
|
|
||||||
} else {
|
|
||||||
$compiler->template->tpl_vars[trim($parameter['if condition']['var'], "'")] = new Smarty_variable(null, true);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$_nocache = '';
|
|
||||||
}
|
|
||||||
if (is_array($parameter['if condition']['var'])) {
|
|
||||||
$_output = "<?php if (!isset(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]) || !is_array(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]->value)) \$_smarty_tpl->createLocalArrayVariable(" . $parameter['if condition']['var']['var'] . "$_nocache);\n";
|
|
||||||
$_output .= "if (\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]->value" . $parameter['if condition']['var']['smarty_internal_index'] . " = " . $parameter['if condition']['value'] . ") {?>";
|
|
||||||
} else {
|
|
||||||
$_output = "<?php if (!isset(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "])) \$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "] = new Smarty_Variable(null{$_nocache});";
|
|
||||||
$_output .= "if (\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "]->value = " . $parameter['if condition']['value'] . ") {?>";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $_output;
|
|
||||||
} else {
|
|
||||||
return "<?php if ({$parameter['if condition']}) {?>";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Else Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Else extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Compiles code for the {else} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter)
|
|
||||||
{
|
|
||||||
list($nesting, $compiler->tag_nocache) = $this->closeTag($compiler, array('if', 'elseif'));
|
|
||||||
$this->openTag($compiler, 'else', array($nesting, $compiler->tag_nocache));
|
|
||||||
|
|
||||||
return "<?php } else { ?>";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile ElseIf Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Elseif extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Compiles code for the {elseif} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
|
|
||||||
list($nesting, $compiler->tag_nocache) = $this->closeTag($compiler, array('if', 'elseif'));
|
|
||||||
|
|
||||||
if (!array_key_exists("if condition", $parameter)) {
|
|
||||||
$compiler->trigger_template_error("missing elseif condition", $compiler->lex->taglineno);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (is_array($parameter['if condition'])) {
|
|
||||||
$condition_by_assign = true;
|
|
||||||
if ($compiler->nocache) {
|
|
||||||
$_nocache = ',true';
|
|
||||||
// create nocache var to make it know for further compiling
|
|
||||||
if (is_array($parameter['if condition']['var'])) {
|
|
||||||
$compiler->template->tpl_vars[trim($parameter['if condition']['var']['var'], "'")] = new Smarty_variable(null, true);
|
|
||||||
} else {
|
|
||||||
$compiler->template->tpl_vars[trim($parameter['if condition']['var'], "'")] = new Smarty_variable(null, true);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$_nocache = '';
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$condition_by_assign = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (empty($compiler->prefix_code)) {
|
|
||||||
if ($condition_by_assign) {
|
|
||||||
$this->openTag($compiler, 'elseif', array($nesting + 1, $compiler->tag_nocache));
|
|
||||||
if (is_array($parameter['if condition']['var'])) {
|
|
||||||
$_output = "<?php } else { if (!isset(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]) || !is_array(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]->value)) \$_smarty_tpl->createLocalArrayVariable(" . $parameter['if condition']['var']['var'] . "$_nocache);\n";
|
|
||||||
$_output .= "if (\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]->value" . $parameter['if condition']['var']['smarty_internal_index'] . " = " . $parameter['if condition']['value'] . ") {?>";
|
|
||||||
} else {
|
|
||||||
$_output = "<?php } else { if (!isset(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "])) \$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "] = new Smarty_Variable(null{$_nocache});";
|
|
||||||
$_output .= "if (\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "]->value = " . $parameter['if condition']['value'] . ") {?>";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $_output;
|
|
||||||
} else {
|
|
||||||
$this->openTag($compiler, 'elseif', array($nesting, $compiler->tag_nocache));
|
|
||||||
|
|
||||||
return "<?php } elseif ({$parameter['if condition']}) {?>";
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$tmp = '';
|
|
||||||
foreach ($compiler->prefix_code as $code) {
|
|
||||||
$tmp .= $code;
|
|
||||||
}
|
|
||||||
$compiler->prefix_code = array();
|
|
||||||
$this->openTag($compiler, 'elseif', array($nesting + 1, $compiler->tag_nocache));
|
|
||||||
if ($condition_by_assign) {
|
|
||||||
if (is_array($parameter['if condition']['var'])) {
|
|
||||||
$_output = "<?php } else {?>{$tmp}<?php if (!isset(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]) || !is_array(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]->value)) \$_smarty_tpl->createLocalArrayVariable(" . $parameter['if condition']['var']['var'] . "$_nocache);\n";
|
|
||||||
$_output .= "if (\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]->value" . $parameter['if condition']['var']['smarty_internal_index'] . " = " . $parameter['if condition']['value'] . ") {?>";
|
|
||||||
} else {
|
|
||||||
$_output = "<?php } else {?>{$tmp}<?php if (!isset(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "])) \$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "] = new Smarty_Variable(null{$_nocache});";
|
|
||||||
$_output .= "if (\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "]->value = " . $parameter['if condition']['value'] . ") {?>";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $_output;
|
|
||||||
} else {
|
|
||||||
return "<?php } else {?>{$tmp}<?php if ({$parameter['if condition']}) {?>";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Ifclose Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Ifclose extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Compiles code for the {/if} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter)
|
|
||||||
{
|
|
||||||
// must endblock be nocache?
|
|
||||||
if ($compiler->nocache) {
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
}
|
|
||||||
list($nesting, $compiler->nocache) = $this->closeTag($compiler, array('if', 'else', 'elseif'));
|
|
||||||
$tmp = '';
|
|
||||||
for ($i = 0; $i < $nesting; $i ++) {
|
|
||||||
$tmp .= '}';
|
|
||||||
}
|
|
||||||
|
|
||||||
return "<?php {$tmp}?>";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,265 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Include
|
|
||||||
* Compiles the {include} tag
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Include Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Include extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* caching mode to create nocache code but no cache file
|
|
||||||
*/
|
|
||||||
const CACHING_NOCACHE_CODE = 9999;
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $required_attributes = array('file');
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $shorttag_order = array('file');
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $option_flags = array('nocache', 'inline', 'caching');
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $optional_attributes = array('_any');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles code for the {include} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
// save possible attributes
|
|
||||||
$include_file = $_attr['file'];
|
|
||||||
|
|
||||||
if (isset($_attr['assign'])) {
|
|
||||||
// output will be stored in a smarty variable instead of being displayed
|
|
||||||
$_assign = $_attr['assign'];
|
|
||||||
}
|
|
||||||
|
|
||||||
$_parent_scope = Smarty::SCOPE_LOCAL;
|
|
||||||
if (isset($_attr['scope'])) {
|
|
||||||
$_attr['scope'] = trim($_attr['scope'], "'\"");
|
|
||||||
if ($_attr['scope'] == 'parent') {
|
|
||||||
$_parent_scope = Smarty::SCOPE_PARENT;
|
|
||||||
} elseif ($_attr['scope'] == 'root') {
|
|
||||||
$_parent_scope = Smarty::SCOPE_ROOT;
|
|
||||||
} elseif ($_attr['scope'] == 'global') {
|
|
||||||
$_parent_scope = Smarty::SCOPE_GLOBAL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$_caching = Smarty::CACHING_OFF;
|
|
||||||
|
|
||||||
// flag if included template code should be merged into caller
|
|
||||||
$merge_compiled_includes = ($compiler->smarty->merge_compiled_includes || ($compiler->inheritance && $compiler->smarty->inheritance_merge_compiled_includes) || $_attr['inline'] === true) && !$compiler->template->source->recompiled;
|
|
||||||
|
|
||||||
// set default when in nocache mode
|
|
||||||
// if ($compiler->template->caching && ($compiler->nocache || $compiler->tag_nocache || $compiler->forceNocache == 2)) {
|
|
||||||
if ($compiler->template->caching && ((!$compiler->inheritance && !$compiler->nocache && !$compiler->tag_nocache) || ($compiler->inheritance && ($compiler->nocache || $compiler->tag_nocache)))) {
|
|
||||||
$_caching = self::CACHING_NOCACHE_CODE;
|
|
||||||
}
|
|
||||||
/*
|
|
||||||
* if the {include} tag provides individual parameter for caching
|
|
||||||
* it will not be included into the common cache file and treated like
|
|
||||||
* a nocache section
|
|
||||||
*/
|
|
||||||
if (isset($_attr['cache_lifetime'])) {
|
|
||||||
$_cache_lifetime = $_attr['cache_lifetime'];
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
$_caching = Smarty::CACHING_LIFETIME_CURRENT;
|
|
||||||
} else {
|
|
||||||
$_cache_lifetime = 'null';
|
|
||||||
}
|
|
||||||
if (isset($_attr['cache_id'])) {
|
|
||||||
$_cache_id = $_attr['cache_id'];
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
$_caching = Smarty::CACHING_LIFETIME_CURRENT;
|
|
||||||
} else {
|
|
||||||
$_cache_id = '$_smarty_tpl->cache_id';
|
|
||||||
}
|
|
||||||
if (isset($_attr['compile_id'])) {
|
|
||||||
$_compile_id = $_attr['compile_id'];
|
|
||||||
} else {
|
|
||||||
$_compile_id = '$_smarty_tpl->compile_id';
|
|
||||||
}
|
|
||||||
if ($_attr['caching'] === true) {
|
|
||||||
$_caching = Smarty::CACHING_LIFETIME_CURRENT;
|
|
||||||
}
|
|
||||||
if ($_attr['nocache'] === true) {
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
if ($merge_compiled_includes) {
|
|
||||||
$_caching = self::CACHING_NOCACHE_CODE;
|
|
||||||
} else {
|
|
||||||
$_caching = Smarty::CACHING_OFF;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$has_compiled_template = false;
|
|
||||||
if ($merge_compiled_includes && $_attr['inline'] !== true) {
|
|
||||||
// variable template name ?
|
|
||||||
if ($compiler->has_variable_string || !((substr_count($include_file, '"') == 2 || substr_count($include_file, "'") == 2))
|
|
||||||
|| substr_count($include_file, '(') != 0 || substr_count($include_file, '$_smarty_tpl->') != 0
|
|
||||||
) {
|
|
||||||
$merge_compiled_includes = false;
|
|
||||||
if ($compiler->inheritance && $compiler->smarty->inheritance_merge_compiled_includes) {
|
|
||||||
$compiler->trigger_template_error(' variable template file names not allow within {block} tags');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// variable compile_id?
|
|
||||||
if (isset($_attr['compile_id'])) {
|
|
||||||
if (!((substr_count($_attr['compile_id'], '"') == 2 || substr_count($_attr['compile_id'], "'") == 2))
|
|
||||||
|| substr_count($_attr['compile_id'], '(') != 0 || substr_count($_attr['compile_id'], '$_smarty_tpl->') != 0
|
|
||||||
) {
|
|
||||||
$merge_compiled_includes = false;
|
|
||||||
if ($compiler->inheritance && $compiler->smarty->inheritance_merge_compiled_includes) {
|
|
||||||
$compiler->trigger_template_error(' variable compile_id not allow within {block} tags');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($merge_compiled_includes) {
|
|
||||||
if ($compiler->template->caching && ($compiler->tag_nocache || $compiler->nocache) && $_caching != self::CACHING_NOCACHE_CODE) {
|
|
||||||
$merge_compiled_includes = false;
|
|
||||||
if ($compiler->inheritance && $compiler->smarty->inheritance_merge_compiled_includes) {
|
|
||||||
$compiler->trigger_template_error(' invalid caching mode of subtemplate within {block} tags');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($merge_compiled_includes) {
|
|
||||||
// we must observe different compile_id
|
|
||||||
$uid = sha1($_compile_id);
|
|
||||||
$tpl_name = null;
|
|
||||||
$nocache = false;
|
|
||||||
/** @var Smarty_Internal_Template $_smarty_tpl
|
|
||||||
* used in evaluated code
|
|
||||||
*/
|
|
||||||
$_smarty_tpl = $compiler->template;
|
|
||||||
eval("\$tpl_name = $include_file;");
|
|
||||||
if (!isset($compiler->smarty->merged_templates_func[$tpl_name][$uid])) {
|
|
||||||
$tpl = new $compiler->smarty->template_class ($tpl_name, $compiler->smarty, $compiler->template, $compiler->template->cache_id, $compiler->template->compile_id);
|
|
||||||
// save unique function name
|
|
||||||
$compiler->smarty->merged_templates_func[$tpl_name][$uid]['func'] = $tpl->properties['unifunc'] = 'content_' . str_replace(array('.', ','), '_', uniqid('', true));
|
|
||||||
// use current nocache hash for inlined code
|
|
||||||
$compiler->smarty->merged_templates_func[$tpl_name][$uid]['nocache_hash'] = $tpl->properties['nocache_hash'] = $compiler->template->properties['nocache_hash'];
|
|
||||||
if ($compiler->template->caching && $_caching == self::CACHING_NOCACHE_CODE) {
|
|
||||||
// all code must be nocache
|
|
||||||
$nocache = true;
|
|
||||||
}
|
|
||||||
if ($compiler->inheritance) {
|
|
||||||
$tpl->compiler->inheritance = true;
|
|
||||||
}
|
|
||||||
// make sure whole chain gets compiled
|
|
||||||
$tpl->mustCompile = true;
|
|
||||||
if (!($tpl->source->uncompiled) && $tpl->source->exists) {
|
|
||||||
|
|
||||||
// get compiled code
|
|
||||||
$compiled_code = $tpl->compiler->compileTemplate($tpl, $nocache);
|
|
||||||
// release compiler object to free memory
|
|
||||||
unset($tpl->compiler);
|
|
||||||
// merge compiled code for {function} tags
|
|
||||||
$compiler->template->properties['function'] = array_merge($compiler->template->properties['function'], $tpl->properties['function']);
|
|
||||||
// merge filedependency
|
|
||||||
$tpl->properties['file_dependency'][$tpl->source->uid] = array($tpl->source->filepath, $tpl->source->timestamp, $tpl->source->type);
|
|
||||||
$compiler->template->properties['file_dependency'] = array_merge($compiler->template->properties['file_dependency'], $tpl->properties['file_dependency']);
|
|
||||||
// remove header code
|
|
||||||
$compiled_code = preg_replace("/(<\?php \/\*%%SmartyHeaderCode:{$tpl->properties['nocache_hash']}%%\*\/(.+?)\/\*\/%%SmartyHeaderCode%%\*\/\?>\n)/s", '', $compiled_code);
|
|
||||||
if ($tpl->has_nocache_code) {
|
|
||||||
// replace nocache_hash
|
|
||||||
$compiled_code = str_replace("{$tpl->properties['nocache_hash']}", $compiler->template->properties['nocache_hash'], $compiled_code);
|
|
||||||
$compiler->template->has_nocache_code = true;
|
|
||||||
}
|
|
||||||
$compiler->merged_templates[$tpl->properties['unifunc']] = $compiled_code;
|
|
||||||
$has_compiled_template = true;
|
|
||||||
unset ($tpl);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$has_compiled_template = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// delete {include} standard attributes
|
|
||||||
unset($_attr['file'], $_attr['assign'], $_attr['cache_id'], $_attr['compile_id'], $_attr['cache_lifetime'], $_attr['nocache'], $_attr['caching'], $_attr['scope'], $_attr['inline']);
|
|
||||||
// remaining attributes must be assigned as smarty variable
|
|
||||||
if (!empty($_attr)) {
|
|
||||||
if ($_parent_scope == Smarty::SCOPE_LOCAL) {
|
|
||||||
// create variables
|
|
||||||
$nccode = '';
|
|
||||||
foreach ($_attr as $key => $value) {
|
|
||||||
$_pairs[] = "'$key'=>$value";
|
|
||||||
$nccode .= "\$_smarty_tpl->tpl_vars['$key'] = new Smarty_variable($value);\n";
|
|
||||||
}
|
|
||||||
$_vars = 'array(' . join(',', $_pairs) . ')';
|
|
||||||
} else {
|
|
||||||
$compiler->trigger_template_error('variable passing not allowed in parent/global scope', $compiler->lex->taglineno);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$_vars = 'array()';
|
|
||||||
}
|
|
||||||
if ($has_compiled_template) {
|
|
||||||
// never call inline templates in nocache mode
|
|
||||||
$compiler->suppressNocacheProcessing = true;
|
|
||||||
$_hash = $compiler->smarty->merged_templates_func[$tpl_name][$uid]['nocache_hash'];
|
|
||||||
$_output = "<?php /* Call merged included template \"" . $tpl_name . "\" */\n";
|
|
||||||
$_output .= "\$_tpl_stack[] = \$_smarty_tpl;\n";
|
|
||||||
if (!empty($nccode) && $_caching == 9999 && $_smarty_tpl->caching) {
|
|
||||||
$compiler->suppressNocacheProcessing = false;
|
|
||||||
$_output .= substr($compiler->processNocacheCode('<?php ' .$nccode . "?>\n", true), 6, -3);
|
|
||||||
$compiler->suppressNocacheProcessing = true;
|
|
||||||
}
|
|
||||||
$_output .= " \$_smarty_tpl = \$_smarty_tpl->setupInlineSubTemplate($include_file, $_cache_id, $_compile_id, $_caching, $_cache_lifetime, $_vars, $_parent_scope, '$_hash');\n";
|
|
||||||
if (isset($_assign)) {
|
|
||||||
$_output .= 'ob_start(); ';
|
|
||||||
}
|
|
||||||
$_output .= $compiler->smarty->merged_templates_func[$tpl_name][$uid]['func'] . "(\$_smarty_tpl);\n";
|
|
||||||
$_output .= "\$_smarty_tpl = array_pop(\$_tpl_stack); ";
|
|
||||||
if (isset($_assign)) {
|
|
||||||
$_output .= " \$_smarty_tpl->tpl_vars[$_assign] = new Smarty_variable(ob_get_clean());";
|
|
||||||
}
|
|
||||||
$_output .= "\n/* End of included template \"" . $tpl_name . "\" */?>";
|
|
||||||
|
|
||||||
return $_output;
|
|
||||||
}
|
|
||||||
|
|
||||||
// was there an assign attribute
|
|
||||||
if (isset($_assign)) {
|
|
||||||
$_output = "<?php \$_smarty_tpl->tpl_vars[$_assign] = new Smarty_variable(\$_smarty_tpl->getSubTemplate ($include_file, $_cache_id, $_compile_id, $_caching, $_cache_lifetime, $_vars, $_parent_scope));?>\n";;
|
|
||||||
} else {
|
|
||||||
$_output = "<?php echo \$_smarty_tpl->getSubTemplate ($include_file, $_cache_id, $_compile_id, $_caching, $_cache_lifetime, $_vars, $_parent_scope);?>\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $_output;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,85 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Block Plugin
|
|
||||||
* Compiles code for the execution of block plugin
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Block Plugin Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Private_Block_Plugin extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $optional_attributes = array('_any');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles code for the execution of block plugin
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
* @param string $tag name of block plugin
|
|
||||||
* @param string $function PHP function name
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter, $tag, $function)
|
|
||||||
{
|
|
||||||
if (!isset($tag[5]) || substr($tag, - 5) != 'close') {
|
|
||||||
// opening tag of block plugin
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
if ($_attr['nocache'] === true) {
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
}
|
|
||||||
unset($_attr['nocache']);
|
|
||||||
// convert attributes into parameter array string
|
|
||||||
$_paramsArray = array();
|
|
||||||
foreach ($_attr as $_key => $_value) {
|
|
||||||
if (is_int($_key)) {
|
|
||||||
$_paramsArray[] = "$_key=>$_value";
|
|
||||||
} else {
|
|
||||||
$_paramsArray[] = "'$_key'=>$_value";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$_params = 'array(' . implode(",", $_paramsArray) . ')';
|
|
||||||
|
|
||||||
$this->openTag($compiler, $tag, array($_params, $compiler->nocache));
|
|
||||||
// maybe nocache because of nocache variables or nocache plugin
|
|
||||||
$compiler->nocache = $compiler->nocache | $compiler->tag_nocache;
|
|
||||||
// compile code
|
|
||||||
$output = "<?php \$_smarty_tpl->smarty->_tag_stack[] = array('{$tag}', {$_params}); \$_block_repeat=true; echo {$function}({$_params}, null, \$_smarty_tpl, \$_block_repeat);while (\$_block_repeat) { ob_start();?>";
|
|
||||||
} else {
|
|
||||||
// must endblock be nocache?
|
|
||||||
if ($compiler->nocache) {
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
}
|
|
||||||
// closing tag of block plugin, restore nocache
|
|
||||||
list($_params, $compiler->nocache) = $this->closeTag($compiler, substr($tag, 0, - 5));
|
|
||||||
// This tag does create output
|
|
||||||
$compiler->has_output = true;
|
|
||||||
// compile code
|
|
||||||
if (!isset($parameter['modifier_list'])) {
|
|
||||||
$mod_pre = $mod_post = '';
|
|
||||||
} else {
|
|
||||||
$mod_pre = ' ob_start(); ';
|
|
||||||
$mod_post = 'echo ' . $compiler->compileTag('private_modifier', array(), array('modifierlist' => $parameter['modifier_list'], 'value' => 'ob_get_clean()')) . ';';
|
|
||||||
}
|
|
||||||
$output = "<?php \$_block_content = ob_get_clean(); \$_block_repeat=false;" . $mod_pre . " echo {$function}({$_params}, \$_block_content, \$_smarty_tpl, \$_block_repeat); " . $mod_post . " } array_pop(\$_smarty_tpl->smarty->_tag_stack);?>";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $output . "\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,86 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Object Block Function
|
|
||||||
* Compiles code for registered objects as block function
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Object Block Function Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Private_Object_Block_Function extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $optional_attributes = array('_any');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles code for the execution of block plugin
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
* @param string $tag name of block object
|
|
||||||
* @param string $method name of method to call
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter, $tag, $method)
|
|
||||||
{
|
|
||||||
if (!isset($tag[5]) || substr($tag, - 5) != 'close') {
|
|
||||||
// opening tag of block plugin
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
if ($_attr['nocache'] === true) {
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
}
|
|
||||||
unset($_attr['nocache']);
|
|
||||||
// convert attributes into parameter array string
|
|
||||||
$_paramsArray = array();
|
|
||||||
foreach ($_attr as $_key => $_value) {
|
|
||||||
if (is_int($_key)) {
|
|
||||||
$_paramsArray[] = "$_key=>$_value";
|
|
||||||
} else {
|
|
||||||
$_paramsArray[] = "'$_key'=>$_value";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$_params = 'array(' . implode(",", $_paramsArray) . ')';
|
|
||||||
|
|
||||||
$this->openTag($compiler, $tag . '->' . $method, array($_params, $compiler->nocache));
|
|
||||||
// maybe nocache because of nocache variables or nocache plugin
|
|
||||||
$compiler->nocache = $compiler->nocache | $compiler->tag_nocache;
|
|
||||||
// compile code
|
|
||||||
$output = "<?php \$_smarty_tpl->smarty->_tag_stack[] = array('{$tag}->{$method}', {$_params}); \$_block_repeat=true; echo \$_smarty_tpl->smarty->registered_objects['{$tag}'][0]->{$method}({$_params}, null, \$_smarty_tpl, \$_block_repeat);while (\$_block_repeat) { ob_start();?>";
|
|
||||||
} else {
|
|
||||||
$base_tag = substr($tag, 0, - 5);
|
|
||||||
// must endblock be nocache?
|
|
||||||
if ($compiler->nocache) {
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
}
|
|
||||||
// closing tag of block plugin, restore nocache
|
|
||||||
list($_params, $compiler->nocache) = $this->closeTag($compiler, $base_tag . '->' . $method);
|
|
||||||
// This tag does create output
|
|
||||||
$compiler->has_output = true;
|
|
||||||
// compile code
|
|
||||||
if (!isset($parameter['modifier_list'])) {
|
|
||||||
$mod_pre = $mod_post = '';
|
|
||||||
} else {
|
|
||||||
$mod_pre = ' ob_start(); ';
|
|
||||||
$mod_post = 'echo ' . $compiler->compileTag('private_modifier', array(), array('modifierlist' => $parameter['modifier_list'], 'value' => 'ob_get_clean()')) . ';';
|
|
||||||
}
|
|
||||||
$output = "<?php \$_block_content = ob_get_contents(); ob_end_clean(); \$_block_repeat=false;" . $mod_pre . " echo \$_smarty_tpl->smarty->registered_objects['{$base_tag}'][0]->{$method}({$_params}, \$_block_content, \$_smarty_tpl, \$_block_repeat); " . $mod_post . " } array_pop(\$_smarty_tpl->smarty->_tag_stack);?>";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $output . "\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,151 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Print Expression
|
|
||||||
* Compiles any tag which will output an expression or variable
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Print Expression Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Private_Print_Expression extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $optional_attributes = array('assign');
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $option_flags = array('nocache', 'nofilter');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles code for generating output from any expression
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
*
|
|
||||||
* @throws SmartyException
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
// nocache option
|
|
||||||
if ($_attr['nocache'] === true) {
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
}
|
|
||||||
if (isset($_attr['assign'])) {
|
|
||||||
// assign output to variable
|
|
||||||
$output = "<?php \$_smarty_tpl->assign({$_attr['assign']},{$parameter['value']});?>";
|
|
||||||
} else {
|
|
||||||
// display value
|
|
||||||
$output = $parameter['value'];
|
|
||||||
// tag modifier
|
|
||||||
if (!empty($parameter['modifierlist'])) {
|
|
||||||
$output = $compiler->compileTag('private_modifier', array(), array('modifierlist' => $parameter['modifierlist'], 'value' => $output));
|
|
||||||
}
|
|
||||||
if (!$_attr['nofilter']) {
|
|
||||||
// default modifier
|
|
||||||
if (!empty($compiler->smarty->default_modifiers)) {
|
|
||||||
if (empty($compiler->default_modifier_list)) {
|
|
||||||
$modifierlist = array();
|
|
||||||
foreach ($compiler->smarty->default_modifiers as $key => $single_default_modifier) {
|
|
||||||
preg_match_all('/(\'[^\'\\\\]*(?:\\\\.[^\'\\\\]*)*\'|"[^"\\\\]*(?:\\\\.[^"\\\\]*)*"|:|[^:]+)/', $single_default_modifier, $mod_array);
|
|
||||||
for ($i = 0, $count = count($mod_array[0]); $i < $count; $i ++) {
|
|
||||||
if ($mod_array[0][$i] != ':') {
|
|
||||||
$modifierlist[$key][] = $mod_array[0][$i];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$compiler->default_modifier_list = $modifierlist;
|
|
||||||
}
|
|
||||||
$output = $compiler->compileTag('private_modifier', array(), array('modifierlist' => $compiler->default_modifier_list, 'value' => $output));
|
|
||||||
}
|
|
||||||
// autoescape html
|
|
||||||
if ($compiler->template->smarty->escape_html) {
|
|
||||||
$output = "htmlspecialchars({$output}, ENT_QUOTES, '" . addslashes(Smarty::$_CHARSET) . "')";
|
|
||||||
}
|
|
||||||
// loop over registered filters
|
|
||||||
if (!empty($compiler->template->smarty->registered_filters[Smarty::FILTER_VARIABLE])) {
|
|
||||||
foreach ($compiler->template->smarty->registered_filters[Smarty::FILTER_VARIABLE] as $key => $function) {
|
|
||||||
if (!is_array($function)) {
|
|
||||||
$output = "{$function}({$output},\$_smarty_tpl)";
|
|
||||||
} elseif (is_object($function[0])) {
|
|
||||||
$output = "\$_smarty_tpl->smarty->registered_filters[Smarty::FILTER_VARIABLE]['{$key}'][0]->{$function[1]}({$output},\$_smarty_tpl)";
|
|
||||||
} else {
|
|
||||||
$output = "{$function[0]}::{$function[1]}({$output},\$_smarty_tpl)";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// auto loaded filters
|
|
||||||
if (isset($compiler->smarty->autoload_filters[Smarty::FILTER_VARIABLE])) {
|
|
||||||
foreach ((array) $compiler->template->smarty->autoload_filters[Smarty::FILTER_VARIABLE] as $name) {
|
|
||||||
$result = $this->compile_output_filter($compiler, $name, $output);
|
|
||||||
if ($result !== false) {
|
|
||||||
$output = $result;
|
|
||||||
} else {
|
|
||||||
// not found, throw exception
|
|
||||||
throw new SmartyException("Unable to load filter '{$name}'");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (isset($compiler->template->variable_filters)) {
|
|
||||||
foreach ($compiler->template->variable_filters as $filter) {
|
|
||||||
if (count($filter) == 1 && ($result = $this->compile_output_filter($compiler, $filter[0], $output)) !== false) {
|
|
||||||
$output = $result;
|
|
||||||
} else {
|
|
||||||
$output = $compiler->compileTag('private_modifier', array(), array('modifierlist' => array($filter), 'value' => $output));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$compiler->has_output = true;
|
|
||||||
$output = "<?php echo {$output};?>";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $output;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param string $name name of variable filter
|
|
||||||
* @param string $output embedded output
|
|
||||||
*
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
private function compile_output_filter($compiler, $name, $output)
|
|
||||||
{
|
|
||||||
$plugin_name = "smarty_variablefilter_{$name}";
|
|
||||||
$path = $compiler->smarty->loadPlugin($plugin_name, false);
|
|
||||||
if ($path) {
|
|
||||||
if ($compiler->template->caching) {
|
|
||||||
$compiler->template->required_plugins['nocache'][$name][Smarty::FILTER_VARIABLE]['file'] = $path;
|
|
||||||
$compiler->template->required_plugins['nocache'][$name][Smarty::FILTER_VARIABLE]['function'] = $plugin_name;
|
|
||||||
} else {
|
|
||||||
$compiler->template->required_plugins['compiled'][$name][Smarty::FILTER_VARIABLE]['file'] = $path;
|
|
||||||
$compiler->template->required_plugins['compiled'][$name][Smarty::FILTER_VARIABLE]['function'] = $plugin_name;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// not found
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return "{$plugin_name}({$output},\$_smarty_tpl)";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,111 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Registered Block
|
|
||||||
* Compiles code for the execution of a registered block function
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Registered Block Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Private_Registered_Block extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $optional_attributes = array('_any');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles code for the execution of a block function
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
* @param string $tag name of block function
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter, $tag)
|
|
||||||
{
|
|
||||||
if (!isset($tag[5]) || substr($tag, - 5) != 'close') {
|
|
||||||
// opening tag of block plugin
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
if ($_attr['nocache']) {
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
}
|
|
||||||
unset($_attr['nocache']);
|
|
||||||
if (isset($compiler->smarty->registered_plugins[Smarty::PLUGIN_BLOCK][$tag])) {
|
|
||||||
$tag_info = $compiler->smarty->registered_plugins[Smarty::PLUGIN_BLOCK][$tag];
|
|
||||||
} else {
|
|
||||||
$tag_info = $compiler->default_handler_plugins[Smarty::PLUGIN_BLOCK][$tag];
|
|
||||||
}
|
|
||||||
// convert attributes into parameter array string
|
|
||||||
$_paramsArray = array();
|
|
||||||
foreach ($_attr as $_key => $_value) {
|
|
||||||
if (is_int($_key)) {
|
|
||||||
$_paramsArray[] = "$_key=>$_value";
|
|
||||||
} elseif ($compiler->template->caching && in_array($_key, $tag_info[2])) {
|
|
||||||
$_value = str_replace("'", "^#^", $_value);
|
|
||||||
$_paramsArray[] = "'$_key'=>^#^.var_export($_value,true).^#^";
|
|
||||||
} else {
|
|
||||||
$_paramsArray[] = "'$_key'=>$_value";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$_params = 'array(' . implode(",", $_paramsArray) . ')';
|
|
||||||
|
|
||||||
$this->openTag($compiler, $tag, array($_params, $compiler->nocache));
|
|
||||||
// maybe nocache because of nocache variables or nocache plugin
|
|
||||||
$compiler->nocache = !$tag_info[1] | $compiler->nocache | $compiler->tag_nocache;
|
|
||||||
$function = $tag_info[0];
|
|
||||||
// compile code
|
|
||||||
if (!is_array($function)) {
|
|
||||||
$output = "<?php \$_smarty_tpl->smarty->_tag_stack[] = array('{$tag}', {$_params}); \$_block_repeat=true; echo {$function}({$_params}, null, \$_smarty_tpl, \$_block_repeat);while (\$_block_repeat) { ob_start();?>";
|
|
||||||
} elseif (is_object($function[0])) {
|
|
||||||
$output = "<?php \$_smarty_tpl->smarty->_tag_stack[] = array('{$tag}', {$_params}); \$_block_repeat=true; echo \$_smarty_tpl->smarty->registered_plugins['block']['{$tag}'][0][0]->{$function[1]}({$_params}, null, \$_smarty_tpl, \$_block_repeat);while (\$_block_repeat) { ob_start();?>";
|
|
||||||
} else {
|
|
||||||
$output = "<?php \$_smarty_tpl->smarty->_tag_stack[] = array('{$tag}', {$_params}); \$_block_repeat=true; echo {$function[0]}::{$function[1]}({$_params}, null, \$_smarty_tpl, \$_block_repeat);while (\$_block_repeat) { ob_start();?>";
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// must endblock be nocache?
|
|
||||||
if ($compiler->nocache) {
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
}
|
|
||||||
$base_tag = substr($tag, 0, - 5);
|
|
||||||
// closing tag of block plugin, restore nocache
|
|
||||||
list($_params, $compiler->nocache) = $this->closeTag($compiler, $base_tag);
|
|
||||||
// This tag does create output
|
|
||||||
$compiler->has_output = true;
|
|
||||||
if (isset($compiler->smarty->registered_plugins[Smarty::PLUGIN_BLOCK][$base_tag])) {
|
|
||||||
$function = $compiler->smarty->registered_plugins[Smarty::PLUGIN_BLOCK][$base_tag][0];
|
|
||||||
} else {
|
|
||||||
$function = $compiler->default_handler_plugins[Smarty::PLUGIN_BLOCK][$base_tag][0];
|
|
||||||
}
|
|
||||||
// compile code
|
|
||||||
if (!isset($parameter['modifier_list'])) {
|
|
||||||
$mod_pre = $mod_post = '';
|
|
||||||
} else {
|
|
||||||
$mod_pre = ' ob_start(); ';
|
|
||||||
$mod_post = 'echo ' . $compiler->compileTag('private_modifier', array(), array('modifierlist' => $parameter['modifier_list'], 'value' => 'ob_get_clean()')) . ';';
|
|
||||||
}
|
|
||||||
if (!is_array($function)) {
|
|
||||||
$output = "<?php \$_block_content = ob_get_clean(); \$_block_repeat=false;" . $mod_pre . " echo {$function}({$_params}, \$_block_content, \$_smarty_tpl, \$_block_repeat);" . $mod_post . " } array_pop(\$_smarty_tpl->smarty->_tag_stack);?>";
|
|
||||||
} elseif (is_object($function[0])) {
|
|
||||||
$output = "<?php \$_block_content = ob_get_clean(); \$_block_repeat=false;" . $mod_pre . " echo \$_smarty_tpl->smarty->registered_plugins['block']['{$base_tag}'][0][0]->{$function[1]}({$_params}, \$_block_content, \$_smarty_tpl, \$_block_repeat); " . $mod_post . "} array_pop(\$_smarty_tpl->smarty->_tag_stack);?>";
|
|
||||||
} else {
|
|
||||||
$output = "<?php \$_block_content = ob_get_clean(); \$_block_repeat=false;" . $mod_pre . " echo {$function[0]}::{$function[1]}({$_params}, \$_block_content, \$_smarty_tpl, \$_block_repeat); " . $mod_post . "} array_pop(\$_smarty_tpl->smarty->_tag_stack);?>";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $output . "\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,79 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Registered Function
|
|
||||||
* Compiles code for the execution of a registered function
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Registered Function Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Private_Registered_Function extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $optional_attributes = array('_any');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles code for the execution of a registered function
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
* @param string $tag name of function
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter, $tag)
|
|
||||||
{
|
|
||||||
// This tag does create output
|
|
||||||
$compiler->has_output = true;
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
if ($_attr['nocache']) {
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
}
|
|
||||||
unset($_attr['nocache']);
|
|
||||||
if (isset($compiler->smarty->registered_plugins[Smarty::PLUGIN_FUNCTION][$tag])) {
|
|
||||||
$tag_info = $compiler->smarty->registered_plugins[Smarty::PLUGIN_FUNCTION][$tag];
|
|
||||||
} else {
|
|
||||||
$tag_info = $compiler->default_handler_plugins[Smarty::PLUGIN_FUNCTION][$tag];
|
|
||||||
}
|
|
||||||
// not cachable?
|
|
||||||
$compiler->tag_nocache = $compiler->tag_nocache || !$tag_info[1];
|
|
||||||
// convert attributes into parameter array string
|
|
||||||
$_paramsArray = array();
|
|
||||||
foreach ($_attr as $_key => $_value) {
|
|
||||||
if (is_int($_key)) {
|
|
||||||
$_paramsArray[] = "$_key=>$_value";
|
|
||||||
} elseif ($compiler->template->caching && in_array($_key, $tag_info[2])) {
|
|
||||||
$_value = str_replace("'", "^#^", $_value);
|
|
||||||
$_paramsArray[] = "'$_key'=>^#^.var_export($_value,true).^#^";
|
|
||||||
} else {
|
|
||||||
$_paramsArray[] = "'$_key'=>$_value";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$_params = 'array(' . implode(",", $_paramsArray) . ')';
|
|
||||||
$function = $tag_info[0];
|
|
||||||
// compile code
|
|
||||||
if (!is_array($function)) {
|
|
||||||
$output = "<?php echo {$function}({$_params},\$_smarty_tpl);?>\n";
|
|
||||||
} elseif (is_object($function[0])) {
|
|
||||||
$output = "<?php echo \$_smarty_tpl->smarty->registered_plugins[Smarty::PLUGIN_FUNCTION]['{$tag}'][0][0]->{$function[1]}({$_params},\$_smarty_tpl);?>\n";
|
|
||||||
} else {
|
|
||||||
$output = "<?php echo {$function[0]}::{$function[1]}({$_params},\$_smarty_tpl);?>\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $output;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,114 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Special Smarty Variable
|
|
||||||
* Compiles the special $smarty variables
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile special Smarty Variable Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Private_Special_Variable extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Compiles code for the special $smarty variables
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param $parameter
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter)
|
|
||||||
{
|
|
||||||
$_index = preg_split("/\]\[/", substr($parameter, 1, strlen($parameter) - 2));
|
|
||||||
$compiled_ref = ' ';
|
|
||||||
$variable = trim($_index[0], "'");
|
|
||||||
switch ($variable) {
|
|
||||||
case 'foreach':
|
|
||||||
return "\$_smarty_tpl->getVariable('smarty')->value$parameter";
|
|
||||||
case 'section':
|
|
||||||
return "\$_smarty_tpl->getVariable('smarty')->value$parameter";
|
|
||||||
case 'capture':
|
|
||||||
return "Smarty::\$_smarty_vars$parameter";
|
|
||||||
case 'now':
|
|
||||||
return 'time()';
|
|
||||||
case 'cookies':
|
|
||||||
if (isset($compiler->smarty->security_policy) && !$compiler->smarty->security_policy->allow_super_globals) {
|
|
||||||
$compiler->trigger_template_error("(secure mode) super globals not permitted");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
$compiled_ref = '$_COOKIE';
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'get':
|
|
||||||
case 'post':
|
|
||||||
case 'env':
|
|
||||||
case 'server':
|
|
||||||
case 'session':
|
|
||||||
case 'request':
|
|
||||||
if (isset($compiler->smarty->security_policy) && !$compiler->smarty->security_policy->allow_super_globals) {
|
|
||||||
$compiler->trigger_template_error("(secure mode) super globals not permitted");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
$compiled_ref = '$_' . strtoupper($variable);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'template':
|
|
||||||
return 'basename($_smarty_tpl->source->filepath)';
|
|
||||||
|
|
||||||
case 'template_object':
|
|
||||||
return '$_smarty_tpl';
|
|
||||||
|
|
||||||
case 'current_dir':
|
|
||||||
return 'dirname($_smarty_tpl->source->filepath)';
|
|
||||||
|
|
||||||
case 'version':
|
|
||||||
$_version = Smarty::SMARTY_VERSION;
|
|
||||||
|
|
||||||
return "'$_version'";
|
|
||||||
|
|
||||||
case 'const':
|
|
||||||
if (isset($compiler->smarty->security_policy) && !$compiler->smarty->security_policy->allow_constants) {
|
|
||||||
$compiler->trigger_template_error("(secure mode) constants not permitted");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return "@constant({$_index[1]})";
|
|
||||||
|
|
||||||
case 'config':
|
|
||||||
if (isset($_index[2])) {
|
|
||||||
return "(is_array(\$tmp = \$_smarty_tpl->getConfigVariable($_index[1])) ? \$tmp[$_index[2]] : null)";
|
|
||||||
} else {
|
|
||||||
return "\$_smarty_tpl->getConfigVariable($_index[1])";
|
|
||||||
}
|
|
||||||
case 'ldelim':
|
|
||||||
$_ldelim = $compiler->smarty->left_delimiter;
|
|
||||||
|
|
||||||
return "'$_ldelim'";
|
|
||||||
|
|
||||||
case 'rdelim':
|
|
||||||
$_rdelim = $compiler->smarty->right_delimiter;
|
|
||||||
|
|
||||||
return "'$_rdelim'";
|
|
||||||
|
|
||||||
default:
|
|
||||||
$compiler->trigger_template_error('$smarty.' . trim($_index[0], "'") . ' is invalid');
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if (isset($_index[1])) {
|
|
||||||
array_shift($_index);
|
|
||||||
foreach ($_index as $_ind) {
|
|
||||||
$compiled_ref = $compiled_ref . "[$_ind]";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $compiled_ref;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,206 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Section
|
|
||||||
* Compiles the {section} {sectionelse} {/section} tags
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Section Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Section extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $required_attributes = array('name', 'loop');
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $shorttag_order = array('name', 'loop');
|
|
||||||
/**
|
|
||||||
* Attribute definition: Overwrites base class.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
* @see Smarty_Internal_CompileBase
|
|
||||||
*/
|
|
||||||
public $optional_attributes = array('start', 'step', 'max', 'show');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles code for the {section} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
|
|
||||||
$this->openTag($compiler, 'section', array('section', $compiler->nocache));
|
|
||||||
// maybe nocache because of nocache variables
|
|
||||||
$compiler->nocache = $compiler->nocache | $compiler->tag_nocache;
|
|
||||||
|
|
||||||
$output = "<?php ";
|
|
||||||
|
|
||||||
$section_name = $_attr['name'];
|
|
||||||
|
|
||||||
$output .= "if (isset(\$_smarty_tpl->tpl_vars['smarty']->value['section'][$section_name])) unset(\$_smarty_tpl->tpl_vars['smarty']->value['section'][$section_name]);\n";
|
|
||||||
$section_props = "\$_smarty_tpl->tpl_vars['smarty']->value['section'][$section_name]";
|
|
||||||
|
|
||||||
foreach ($_attr as $attr_name => $attr_value) {
|
|
||||||
switch ($attr_name) {
|
|
||||||
case 'loop':
|
|
||||||
$output .= "{$section_props}['loop'] = is_array(\$_loop=$attr_value) ? count(\$_loop) : max(0, (int) \$_loop); unset(\$_loop);\n";
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'show':
|
|
||||||
if (is_bool($attr_value)) {
|
|
||||||
$show_attr_value = $attr_value ? 'true' : 'false';
|
|
||||||
} else {
|
|
||||||
$show_attr_value = "(bool) $attr_value";
|
|
||||||
}
|
|
||||||
$output .= "{$section_props}['show'] = $show_attr_value;\n";
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'name':
|
|
||||||
$output .= "{$section_props}['$attr_name'] = $attr_value;\n";
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'max':
|
|
||||||
case 'start':
|
|
||||||
$output .= "{$section_props}['$attr_name'] = (int) $attr_value;\n";
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'step':
|
|
||||||
$output .= "{$section_props}['$attr_name'] = ((int) $attr_value) == 0 ? 1 : (int) $attr_value;\n";
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!isset($_attr['show'])) {
|
|
||||||
$output .= "{$section_props}['show'] = true;\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!isset($_attr['loop'])) {
|
|
||||||
$output .= "{$section_props}['loop'] = 1;\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!isset($_attr['max'])) {
|
|
||||||
$output .= "{$section_props}['max'] = {$section_props}['loop'];\n";
|
|
||||||
} else {
|
|
||||||
$output .= "if ({$section_props}['max'] < 0)\n" . " {$section_props}['max'] = {$section_props}['loop'];\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!isset($_attr['step'])) {
|
|
||||||
$output .= "{$section_props}['step'] = 1;\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!isset($_attr['start'])) {
|
|
||||||
$output .= "{$section_props}['start'] = {$section_props}['step'] > 0 ? 0 : {$section_props}['loop']-1;\n";
|
|
||||||
} else {
|
|
||||||
$output .= "if ({$section_props}['start'] < 0)\n" . " {$section_props}['start'] = max({$section_props}['step'] > 0 ? 0 : -1, {$section_props}['loop'] + {$section_props}['start']);\n" . "else\n" . " {$section_props}['start'] = min({$section_props}['start'], {$section_props}['step'] > 0 ? {$section_props}['loop'] : {$section_props}['loop']-1);\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
$output .= "if ({$section_props}['show']) {\n";
|
|
||||||
if (!isset($_attr['start']) && !isset($_attr['step']) && !isset($_attr['max'])) {
|
|
||||||
$output .= " {$section_props}['total'] = {$section_props}['loop'];\n";
|
|
||||||
} else {
|
|
||||||
$output .= " {$section_props}['total'] = min(ceil(({$section_props}['step'] > 0 ? {$section_props}['loop'] - {$section_props}['start'] : {$section_props}['start']+1)/abs({$section_props}['step'])), {$section_props}['max']);\n";
|
|
||||||
}
|
|
||||||
$output .= " if ({$section_props}['total'] == 0)\n" . " {$section_props}['show'] = false;\n" . "} else\n" . " {$section_props}['total'] = 0;\n";
|
|
||||||
|
|
||||||
$output .= "if ({$section_props}['show']):\n";
|
|
||||||
$output .= "
|
|
||||||
for ({$section_props}['index'] = {$section_props}['start'], {$section_props}['iteration'] = 1;
|
|
||||||
{$section_props}['iteration'] <= {$section_props}['total'];
|
|
||||||
{$section_props}['index'] += {$section_props}['step'], {$section_props}['iteration']++):\n";
|
|
||||||
$output .= "{$section_props}['rownum'] = {$section_props}['iteration'];\n";
|
|
||||||
$output .= "{$section_props}['index_prev'] = {$section_props}['index'] - {$section_props}['step'];\n";
|
|
||||||
$output .= "{$section_props}['index_next'] = {$section_props}['index'] + {$section_props}['step'];\n";
|
|
||||||
$output .= "{$section_props}['first'] = ({$section_props}['iteration'] == 1);\n";
|
|
||||||
$output .= "{$section_props}['last'] = ({$section_props}['iteration'] == {$section_props}['total']);\n";
|
|
||||||
|
|
||||||
$output .= "?>";
|
|
||||||
|
|
||||||
return $output;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Sectionelse Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Sectionelse extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Compiles code for the {sectionelse} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
|
|
||||||
list($openTag, $nocache) = $this->closeTag($compiler, array('section'));
|
|
||||||
$this->openTag($compiler, 'sectionelse', array('sectionelse', $nocache));
|
|
||||||
|
|
||||||
return "<?php endfor; else: ?>";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Sectionclose Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Sectionclose extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Compiles code for the {/section} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
|
|
||||||
// must endblock be nocache?
|
|
||||||
if ($compiler->nocache) {
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
list($openTag, $compiler->nocache) = $this->closeTag($compiler, array('section', 'sectionelse'));
|
|
||||||
|
|
||||||
if ($openTag == 'sectionelse') {
|
|
||||||
return "<?php endif; ?>";
|
|
||||||
} else {
|
|
||||||
return "<?php endfor; endif; ?>";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,93 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile While
|
|
||||||
* Compiles the {while} tag
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile While Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_While extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Compiles code for the {while} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler, $parameter)
|
|
||||||
{
|
|
||||||
// check and get attributes
|
|
||||||
$_attr = $this->getAttributes($compiler, $args);
|
|
||||||
$this->openTag($compiler, 'while', $compiler->nocache);
|
|
||||||
|
|
||||||
if (!array_key_exists("if condition", $parameter)) {
|
|
||||||
$compiler->trigger_template_error("missing while condition", $compiler->lex->taglineno);
|
|
||||||
}
|
|
||||||
|
|
||||||
// maybe nocache because of nocache variables
|
|
||||||
$compiler->nocache = $compiler->nocache | $compiler->tag_nocache;
|
|
||||||
if (is_array($parameter['if condition'])) {
|
|
||||||
if ($compiler->nocache) {
|
|
||||||
$_nocache = ',true';
|
|
||||||
// create nocache var to make it know for further compiling
|
|
||||||
if (is_array($parameter['if condition']['var'])) {
|
|
||||||
$compiler->template->tpl_vars[trim($parameter['if condition']['var']['var'], "'")] = new Smarty_variable(null, true);
|
|
||||||
} else {
|
|
||||||
$compiler->template->tpl_vars[trim($parameter['if condition']['var'], "'")] = new Smarty_variable(null, true);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$_nocache = '';
|
|
||||||
}
|
|
||||||
if (is_array($parameter['if condition']['var'])) {
|
|
||||||
$_output = "<?php if (!isset(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]) || !is_array(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]->value)) \$_smarty_tpl->createLocalArrayVariable(" . $parameter['if condition']['var']['var'] . "$_nocache);\n";
|
|
||||||
$_output .= "while (\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var']['var'] . "]->value" . $parameter['if condition']['var']['smarty_internal_index'] . " = " . $parameter['if condition']['value'] . ") {?>";
|
|
||||||
} else {
|
|
||||||
$_output = "<?php if (!isset(\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "])) \$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "] = new Smarty_Variable(null{$_nocache});";
|
|
||||||
$_output .= "while (\$_smarty_tpl->tpl_vars[" . $parameter['if condition']['var'] . "]->value = " . $parameter['if condition']['value'] . ") {?>";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $_output;
|
|
||||||
} else {
|
|
||||||
return "<?php while ({$parameter['if condition']}) {?>";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Compile Whileclose Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Compile_Whileclose extends Smarty_Internal_CompileBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Compiles code for the {/while} tag
|
|
||||||
*
|
|
||||||
* @param array $args array with attributes from parser
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compile($args, $compiler)
|
|
||||||
{
|
|
||||||
// must endblock be nocache?
|
|
||||||
if ($compiler->nocache) {
|
|
||||||
$compiler->tag_nocache = true;
|
|
||||||
}
|
|
||||||
$compiler->nocache = $this->closeTag($compiler, array('while'));
|
|
||||||
|
|
||||||
return "<?php }?>";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,306 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Config
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Config
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Config
|
|
||||||
* Main class for config variables
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Config
|
|
||||||
* @ignore
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Config
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Smarty instance
|
|
||||||
*
|
|
||||||
* @var Smarty object
|
|
||||||
*/
|
|
||||||
public $smarty = null;
|
|
||||||
/**
|
|
||||||
* Object of config var storage
|
|
||||||
*
|
|
||||||
* @var object
|
|
||||||
*/
|
|
||||||
public $data = null;
|
|
||||||
/**
|
|
||||||
* Config resource
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $config_resource = null;
|
|
||||||
/**
|
|
||||||
* Compiled config file
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $compiled_config = null;
|
|
||||||
/**
|
|
||||||
* filepath of compiled config file
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $compiled_filepath = null;
|
|
||||||
/**
|
|
||||||
* Filemtime of compiled config Filemtime
|
|
||||||
*
|
|
||||||
* @var int
|
|
||||||
*/
|
|
||||||
public $compiled_timestamp = null;
|
|
||||||
/**
|
|
||||||
* flag if compiled config file is invalid and must be (re)compiled
|
|
||||||
*
|
|
||||||
* @var bool
|
|
||||||
*/
|
|
||||||
public $mustCompile = null;
|
|
||||||
/**
|
|
||||||
* Config file compiler object
|
|
||||||
*
|
|
||||||
* @var Smarty_Internal_Config_File_Compiler object
|
|
||||||
*/
|
|
||||||
public $compiler_object = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor of config file object
|
|
||||||
*
|
|
||||||
* @param string $config_resource config file resource name
|
|
||||||
* @param Smarty $smarty Smarty instance
|
|
||||||
* @param object $data object for config vars storage
|
|
||||||
*/
|
|
||||||
public function __construct($config_resource, $smarty, $data = null)
|
|
||||||
{
|
|
||||||
$this->data = $data;
|
|
||||||
$this->smarty = $smarty;
|
|
||||||
$this->config_resource = $config_resource;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the compiled filepath
|
|
||||||
*
|
|
||||||
* @return string the compiled filepath
|
|
||||||
*/
|
|
||||||
public function getCompiledFilepath()
|
|
||||||
{
|
|
||||||
return $this->compiled_filepath === null ?
|
|
||||||
($this->compiled_filepath = $this->buildCompiledFilepath()) :
|
|
||||||
$this->compiled_filepath;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get file path.
|
|
||||||
*
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
public function buildCompiledFilepath()
|
|
||||||
{
|
|
||||||
$_compile_id = isset($this->smarty->compile_id) ? preg_replace('![^\w\|]+!', '_', $this->smarty->compile_id) : null;
|
|
||||||
$_flag = (int) $this->smarty->config_read_hidden + (int) $this->smarty->config_booleanize * 2
|
|
||||||
+ (int) $this->smarty->config_overwrite * 4;
|
|
||||||
$_filepath = sha1(realpath($this->source->filepath) . $_flag);
|
|
||||||
// if use_sub_dirs, break file into directories
|
|
||||||
if ($this->smarty->use_sub_dirs) {
|
|
||||||
$_filepath = substr($_filepath, 0, 2) . DS
|
|
||||||
. substr($_filepath, 2, 2) . DS
|
|
||||||
. substr($_filepath, 4, 2) . DS
|
|
||||||
. $_filepath;
|
|
||||||
}
|
|
||||||
$_compile_dir_sep = $this->smarty->use_sub_dirs ? DS : '^';
|
|
||||||
if (isset($_compile_id)) {
|
|
||||||
$_filepath = $_compile_id . $_compile_dir_sep . $_filepath;
|
|
||||||
}
|
|
||||||
$_compile_dir = $this->smarty->getCompileDir();
|
|
||||||
|
|
||||||
return $_compile_dir . $_filepath . '.' . basename($this->source->name) . '.config' . '.php';
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the timestamp of the compiled file
|
|
||||||
*
|
|
||||||
* @return integer the file timestamp
|
|
||||||
*/
|
|
||||||
public function getCompiledTimestamp()
|
|
||||||
{
|
|
||||||
return $this->compiled_timestamp === null
|
|
||||||
? ($this->compiled_timestamp = (file_exists($this->getCompiledFilepath())) ? filemtime($this->getCompiledFilepath()) : false)
|
|
||||||
: $this->compiled_timestamp;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns if the current config file must be compiled
|
|
||||||
* It does compare the timestamps of config source and the compiled config and checks the force compile configuration
|
|
||||||
*
|
|
||||||
* @return boolean true if the file must be compiled
|
|
||||||
*/
|
|
||||||
public function mustCompile()
|
|
||||||
{
|
|
||||||
return $this->mustCompile === null ?
|
|
||||||
$this->mustCompile = ($this->smarty->force_compile || $this->getCompiledTimestamp() === false || $this->smarty->compile_check && $this->getCompiledTimestamp() < $this->source->timestamp) :
|
|
||||||
$this->mustCompile;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the compiled config file
|
|
||||||
* It checks if the config file must be compiled or just read the compiled version
|
|
||||||
*
|
|
||||||
* @return string the compiled config file
|
|
||||||
*/
|
|
||||||
public function getCompiledConfig()
|
|
||||||
{
|
|
||||||
if ($this->compiled_config === null) {
|
|
||||||
// see if template needs compiling.
|
|
||||||
if ($this->mustCompile()) {
|
|
||||||
$this->compileConfigSource();
|
|
||||||
} else {
|
|
||||||
$this->compiled_config = file_get_contents($this->getCompiledFilepath());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->compiled_config;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles the config files
|
|
||||||
*
|
|
||||||
* @throws Exception
|
|
||||||
*/
|
|
||||||
public function compileConfigSource()
|
|
||||||
{
|
|
||||||
// compile template
|
|
||||||
if (!is_object($this->compiler_object)) {
|
|
||||||
// load compiler
|
|
||||||
$this->compiler_object = new Smarty_Internal_Config_File_Compiler($this->smarty);
|
|
||||||
}
|
|
||||||
// compile locking
|
|
||||||
if ($this->smarty->compile_locking) {
|
|
||||||
if ($saved_timestamp = $this->getCompiledTimestamp()) {
|
|
||||||
touch($this->getCompiledFilepath());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// call compiler
|
|
||||||
try {
|
|
||||||
$this->compiler_object->compileSource($this);
|
|
||||||
}
|
|
||||||
catch (Exception $e) {
|
|
||||||
// restore old timestamp in case of error
|
|
||||||
if ($this->smarty->compile_locking && $saved_timestamp) {
|
|
||||||
touch($this->getCompiledFilepath(), $saved_timestamp);
|
|
||||||
}
|
|
||||||
throw $e;
|
|
||||||
}
|
|
||||||
// compiling succeeded
|
|
||||||
// write compiled template
|
|
||||||
Smarty_Internal_Write_File::writeFile($this->getCompiledFilepath(), $this->getCompiledConfig(), $this->smarty);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* load config variables
|
|
||||||
*
|
|
||||||
* @param mixed $sections array of section names, single section or null
|
|
||||||
* @param string $scope global,parent or local
|
|
||||||
*
|
|
||||||
* @throws Exception
|
|
||||||
*/
|
|
||||||
public function loadConfigVars($sections = null, $scope = 'local')
|
|
||||||
{
|
|
||||||
if ($this->data instanceof Smarty_Internal_Template) {
|
|
||||||
$this->data->properties['file_dependency'][sha1($this->source->filepath)] = array($this->source->filepath, $this->source->timestamp, 'file');
|
|
||||||
}
|
|
||||||
if ($this->mustCompile()) {
|
|
||||||
$this->compileConfigSource();
|
|
||||||
}
|
|
||||||
// pointer to scope
|
|
||||||
if ($scope == 'local') {
|
|
||||||
$scope_ptr = $this->data;
|
|
||||||
} elseif ($scope == 'parent') {
|
|
||||||
if (isset($this->data->parent)) {
|
|
||||||
$scope_ptr = $this->data->parent;
|
|
||||||
} else {
|
|
||||||
$scope_ptr = $this->data;
|
|
||||||
}
|
|
||||||
} elseif ($scope == 'root' || $scope == 'global') {
|
|
||||||
$scope_ptr = $this->data;
|
|
||||||
while (isset($scope_ptr->parent)) {
|
|
||||||
$scope_ptr = $scope_ptr->parent;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$_config_vars = array();
|
|
||||||
include($this->getCompiledFilepath());
|
|
||||||
// copy global config vars
|
|
||||||
foreach ($_config_vars['vars'] as $variable => $value) {
|
|
||||||
if ($this->smarty->config_overwrite || !isset($scope_ptr->config_vars[$variable])) {
|
|
||||||
$scope_ptr->config_vars[$variable] = $value;
|
|
||||||
} else {
|
|
||||||
$scope_ptr->config_vars[$variable] = array_merge((array) $scope_ptr->config_vars[$variable], (array) $value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// scan sections
|
|
||||||
if (!empty($sections)) {
|
|
||||||
foreach ((array) $sections as $this_section) {
|
|
||||||
if (isset($_config_vars['sections'][$this_section])) {
|
|
||||||
foreach ($_config_vars['sections'][$this_section]['vars'] as $variable => $value) {
|
|
||||||
if ($this->smarty->config_overwrite || !isset($scope_ptr->config_vars[$variable])) {
|
|
||||||
$scope_ptr->config_vars[$variable] = $value;
|
|
||||||
} else {
|
|
||||||
$scope_ptr->config_vars[$variable] = array_merge((array) $scope_ptr->config_vars[$variable], (array) $value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* set Smarty property in template context
|
|
||||||
*
|
|
||||||
* @param string $property_name property name
|
|
||||||
* @param mixed $value value
|
|
||||||
*
|
|
||||||
* @throws SmartyException if $property_name is not valid
|
|
||||||
*/
|
|
||||||
public function __set($property_name, $value)
|
|
||||||
{
|
|
||||||
switch ($property_name) {
|
|
||||||
case 'source':
|
|
||||||
case 'compiled':
|
|
||||||
$this->$property_name = $value;
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
throw new SmartyException("invalid config property '$property_name'.");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* get Smarty property in template context
|
|
||||||
*
|
|
||||||
* @param string $property_name property name
|
|
||||||
*
|
|
||||||
* @return \Smarty_Config_Source|\Smarty_Template_Compiled
|
|
||||||
* @throws SmartyException if $property_name is not valid
|
|
||||||
*/
|
|
||||||
public function __get($property_name)
|
|
||||||
{
|
|
||||||
switch ($property_name) {
|
|
||||||
case 'source':
|
|
||||||
if (empty($this->config_resource)) {
|
|
||||||
throw new SmartyException("Unable to parse resource name \"{$this->config_resource}\"");
|
|
||||||
}
|
|
||||||
$this->source = Smarty_Resource::config($this);
|
|
||||||
|
|
||||||
return $this->source;
|
|
||||||
|
|
||||||
case 'compiled':
|
|
||||||
$this->compiled = $this->source->getCompiled($this);
|
|
||||||
|
|
||||||
return $this->compiled;
|
|
||||||
}
|
|
||||||
|
|
||||||
throw new SmartyException("config attribute '$property_name' does not exist.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,576 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Data
|
|
||||||
* This file contains the basic classes and methods for template and variable creation
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Template
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Base class with template and variable methods
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Template
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Data
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* name of class used for templates
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $template_class = 'Smarty_Internal_Template';
|
|
||||||
/**
|
|
||||||
* template variables
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $tpl_vars = array();
|
|
||||||
/**
|
|
||||||
* parent template (if any)
|
|
||||||
*
|
|
||||||
* @var Smarty_Internal_Template
|
|
||||||
*/
|
|
||||||
public $parent = null;
|
|
||||||
/**
|
|
||||||
* configuration settings
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $config_vars = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* assigns a Smarty variable
|
|
||||||
*
|
|
||||||
* @param array|string $tpl_var the template variable name(s)
|
|
||||||
* @param mixed $value the value to assign
|
|
||||||
* @param boolean $nocache if true any output of this variable will be not cached
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function assign($tpl_var, $value = null, $nocache = false)
|
|
||||||
{
|
|
||||||
if (is_array($tpl_var)) {
|
|
||||||
foreach ($tpl_var as $_key => $_val) {
|
|
||||||
if ($_key != '') {
|
|
||||||
$this->tpl_vars[$_key] = new Smarty_variable($_val, $nocache);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if ($tpl_var != '') {
|
|
||||||
$this->tpl_vars[$tpl_var] = new Smarty_variable($value, $nocache);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* assigns a global Smarty variable
|
|
||||||
*
|
|
||||||
* @param string $varname the global variable name
|
|
||||||
* @param mixed $value the value to assign
|
|
||||||
* @param boolean $nocache if true any output of this variable will be not cached
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function assignGlobal($varname, $value = null, $nocache = false)
|
|
||||||
{
|
|
||||||
if ($varname != '') {
|
|
||||||
Smarty::$global_tpl_vars[$varname] = new Smarty_variable($value, $nocache);
|
|
||||||
$ptr = $this;
|
|
||||||
while ($ptr instanceof Smarty_Internal_Template) {
|
|
||||||
$ptr->tpl_vars[$varname] = clone Smarty::$global_tpl_vars[$varname];
|
|
||||||
$ptr = $ptr->parent;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* assigns values to template variables by reference
|
|
||||||
*
|
|
||||||
* @param string $tpl_var the template variable name
|
|
||||||
* @param $value
|
|
||||||
* @param boolean $nocache if true any output of this variable will be not cached
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function assignByRef($tpl_var, &$value, $nocache = false)
|
|
||||||
{
|
|
||||||
if ($tpl_var != '') {
|
|
||||||
$this->tpl_vars[$tpl_var] = new Smarty_variable(null, $nocache);
|
|
||||||
$this->tpl_vars[$tpl_var]->value = & $value;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* appends values to template variables
|
|
||||||
*
|
|
||||||
* @param array|string $tpl_var the template variable name(s)
|
|
||||||
* @param mixed $value the value to append
|
|
||||||
* @param boolean $merge flag if array elements shall be merged
|
|
||||||
* @param boolean $nocache if true any output of this variable will be not cached
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function append($tpl_var, $value = null, $merge = false, $nocache = false)
|
|
||||||
{
|
|
||||||
if (is_array($tpl_var)) {
|
|
||||||
// $tpl_var is an array, ignore $value
|
|
||||||
foreach ($tpl_var as $_key => $_val) {
|
|
||||||
if ($_key != '') {
|
|
||||||
if (!isset($this->tpl_vars[$_key])) {
|
|
||||||
$tpl_var_inst = $this->getVariable($_key, null, true, false);
|
|
||||||
if ($tpl_var_inst instanceof Undefined_Smarty_Variable) {
|
|
||||||
$this->tpl_vars[$_key] = new Smarty_variable(null, $nocache);
|
|
||||||
} else {
|
|
||||||
$this->tpl_vars[$_key] = clone $tpl_var_inst;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!(is_array($this->tpl_vars[$_key]->value) || $this->tpl_vars[$_key]->value instanceof ArrayAccess)) {
|
|
||||||
settype($this->tpl_vars[$_key]->value, 'array');
|
|
||||||
}
|
|
||||||
if ($merge && is_array($_val)) {
|
|
||||||
foreach ($_val as $_mkey => $_mval) {
|
|
||||||
$this->tpl_vars[$_key]->value[$_mkey] = $_mval;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$this->tpl_vars[$_key]->value[] = $_val;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if ($tpl_var != '' && isset($value)) {
|
|
||||||
if (!isset($this->tpl_vars[$tpl_var])) {
|
|
||||||
$tpl_var_inst = $this->getVariable($tpl_var, null, true, false);
|
|
||||||
if ($tpl_var_inst instanceof Undefined_Smarty_Variable) {
|
|
||||||
$this->tpl_vars[$tpl_var] = new Smarty_variable(null, $nocache);
|
|
||||||
} else {
|
|
||||||
$this->tpl_vars[$tpl_var] = clone $tpl_var_inst;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!(is_array($this->tpl_vars[$tpl_var]->value) || $this->tpl_vars[$tpl_var]->value instanceof ArrayAccess)) {
|
|
||||||
settype($this->tpl_vars[$tpl_var]->value, 'array');
|
|
||||||
}
|
|
||||||
if ($merge && is_array($value)) {
|
|
||||||
foreach ($value as $_mkey => $_mval) {
|
|
||||||
$this->tpl_vars[$tpl_var]->value[$_mkey] = $_mval;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$this->tpl_vars[$tpl_var]->value[] = $value;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* appends values to template variables by reference
|
|
||||||
*
|
|
||||||
* @param string $tpl_var the template variable name
|
|
||||||
* @param mixed &$value the referenced value to append
|
|
||||||
* @param boolean $merge flag if array elements shall be merged
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function appendByRef($tpl_var, &$value, $merge = false)
|
|
||||||
{
|
|
||||||
if ($tpl_var != '' && isset($value)) {
|
|
||||||
if (!isset($this->tpl_vars[$tpl_var])) {
|
|
||||||
$this->tpl_vars[$tpl_var] = new Smarty_variable();
|
|
||||||
}
|
|
||||||
if (!is_array($this->tpl_vars[$tpl_var]->value)) {
|
|
||||||
settype($this->tpl_vars[$tpl_var]->value, 'array');
|
|
||||||
}
|
|
||||||
if ($merge && is_array($value)) {
|
|
||||||
foreach ($value as $_key => $_val) {
|
|
||||||
$this->tpl_vars[$tpl_var]->value[$_key] = & $value[$_key];
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$this->tpl_vars[$tpl_var]->value[] = & $value;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns a single or all template variables
|
|
||||||
*
|
|
||||||
* @param string $varname variable name or null
|
|
||||||
* @param object $_ptr optional pointer to data object
|
|
||||||
* @param boolean $search_parents include parent templates?
|
|
||||||
*
|
|
||||||
* @return string variable value or or array of variables
|
|
||||||
*/
|
|
||||||
public function getTemplateVars($varname = null, $_ptr = null, $search_parents = true)
|
|
||||||
{
|
|
||||||
if (isset($varname)) {
|
|
||||||
$_var = $this->getVariable($varname, $_ptr, $search_parents, false);
|
|
||||||
if (is_object($_var)) {
|
|
||||||
return $_var->value;
|
|
||||||
} else {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$_result = array();
|
|
||||||
if ($_ptr === null) {
|
|
||||||
$_ptr = $this;
|
|
||||||
}
|
|
||||||
while ($_ptr !== null) {
|
|
||||||
foreach ($_ptr->tpl_vars AS $key => $var) {
|
|
||||||
if (!array_key_exists($key, $_result)) {
|
|
||||||
$_result[$key] = $var->value;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// not found, try at parent
|
|
||||||
if ($search_parents) {
|
|
||||||
$_ptr = $_ptr->parent;
|
|
||||||
} else {
|
|
||||||
$_ptr = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($search_parents && isset(Smarty::$global_tpl_vars)) {
|
|
||||||
foreach (Smarty::$global_tpl_vars AS $key => $var) {
|
|
||||||
if (!array_key_exists($key, $_result)) {
|
|
||||||
$_result[$key] = $var->value;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $_result;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* clear the given assigned template variable.
|
|
||||||
*
|
|
||||||
* @param string|array $tpl_var the template variable(s) to clear
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function clearAssign($tpl_var)
|
|
||||||
{
|
|
||||||
if (is_array($tpl_var)) {
|
|
||||||
foreach ($tpl_var as $curr_var) {
|
|
||||||
unset($this->tpl_vars[$curr_var]);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
unset($this->tpl_vars[$tpl_var]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* clear all the assigned template variables.
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function clearAllAssign()
|
|
||||||
{
|
|
||||||
$this->tpl_vars = array();
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* load a config file, optionally load just selected sections
|
|
||||||
*
|
|
||||||
* @param string $config_file filename
|
|
||||||
* @param mixed $sections array of section names, single section or null
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function configLoad($config_file, $sections = null)
|
|
||||||
{
|
|
||||||
// load Config class
|
|
||||||
$config = new Smarty_Internal_Config($config_file, $this->smarty, $this);
|
|
||||||
$config->loadConfigVars($sections);
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* gets the object of a Smarty variable
|
|
||||||
*
|
|
||||||
* @param string $variable the name of the Smarty variable
|
|
||||||
* @param object $_ptr optional pointer to data object
|
|
||||||
* @param boolean $search_parents search also in parent data
|
|
||||||
* @param bool $error_enable
|
|
||||||
*
|
|
||||||
* @return object the object of the variable
|
|
||||||
*/
|
|
||||||
public function getVariable($variable, $_ptr = null, $search_parents = true, $error_enable = true)
|
|
||||||
{
|
|
||||||
if ($_ptr === null) {
|
|
||||||
$_ptr = $this;
|
|
||||||
}
|
|
||||||
while ($_ptr !== null) {
|
|
||||||
if (isset($_ptr->tpl_vars[$variable])) {
|
|
||||||
// found it, return it
|
|
||||||
return $_ptr->tpl_vars[$variable];
|
|
||||||
}
|
|
||||||
// not found, try at parent
|
|
||||||
if ($search_parents) {
|
|
||||||
$_ptr = $_ptr->parent;
|
|
||||||
} else {
|
|
||||||
$_ptr = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (isset(Smarty::$global_tpl_vars[$variable])) {
|
|
||||||
// found it, return it
|
|
||||||
return Smarty::$global_tpl_vars[$variable];
|
|
||||||
}
|
|
||||||
if ($this->smarty->error_unassigned && $error_enable) {
|
|
||||||
// force a notice
|
|
||||||
$x = $$variable;
|
|
||||||
}
|
|
||||||
|
|
||||||
return new Undefined_Smarty_Variable;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* gets a config variable
|
|
||||||
*
|
|
||||||
* @param string $variable the name of the config variable
|
|
||||||
* @param bool $error_enable
|
|
||||||
*
|
|
||||||
* @return mixed the value of the config variable
|
|
||||||
*/
|
|
||||||
public function getConfigVariable($variable, $error_enable = true)
|
|
||||||
{
|
|
||||||
$_ptr = $this;
|
|
||||||
while ($_ptr !== null) {
|
|
||||||
if (isset($_ptr->config_vars[$variable])) {
|
|
||||||
// found it, return it
|
|
||||||
return $_ptr->config_vars[$variable];
|
|
||||||
}
|
|
||||||
// not found, try at parent
|
|
||||||
$_ptr = $_ptr->parent;
|
|
||||||
}
|
|
||||||
if ($this->smarty->error_unassigned && $error_enable) {
|
|
||||||
// force a notice
|
|
||||||
$x = $$variable;
|
|
||||||
}
|
|
||||||
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* gets a stream variable
|
|
||||||
*
|
|
||||||
* @param string $variable the stream of the variable
|
|
||||||
*
|
|
||||||
* @throws SmartyException
|
|
||||||
* @return mixed the value of the stream variable
|
|
||||||
*/
|
|
||||||
public function getStreamVariable($variable)
|
|
||||||
{
|
|
||||||
$_result = '';
|
|
||||||
$fp = fopen($variable, 'r+');
|
|
||||||
if ($fp) {
|
|
||||||
while (!feof($fp) && ($current_line = fgets($fp)) !== false) {
|
|
||||||
$_result .= $current_line;
|
|
||||||
}
|
|
||||||
fclose($fp);
|
|
||||||
|
|
||||||
return $_result;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($this->smarty->error_unassigned) {
|
|
||||||
throw new SmartyException('Undefined stream variable "' . $variable . '"');
|
|
||||||
} else {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns a single or all config variables
|
|
||||||
*
|
|
||||||
* @param string $varname variable name or null
|
|
||||||
* @param bool $search_parents
|
|
||||||
*
|
|
||||||
* @return string variable value or or array of variables
|
|
||||||
*/
|
|
||||||
public function getConfigVars($varname = null, $search_parents = true)
|
|
||||||
{
|
|
||||||
$_ptr = $this;
|
|
||||||
$var_array = array();
|
|
||||||
while ($_ptr !== null) {
|
|
||||||
if (isset($varname)) {
|
|
||||||
if (isset($_ptr->config_vars[$varname])) {
|
|
||||||
return $_ptr->config_vars[$varname];
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$var_array = array_merge($_ptr->config_vars, $var_array);
|
|
||||||
}
|
|
||||||
// not found, try at parent
|
|
||||||
if ($search_parents) {
|
|
||||||
$_ptr = $_ptr->parent;
|
|
||||||
} else {
|
|
||||||
$_ptr = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (isset($varname)) {
|
|
||||||
return '';
|
|
||||||
} else {
|
|
||||||
return $var_array;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Deassigns a single or all config variables
|
|
||||||
*
|
|
||||||
* @param string $varname variable name or null
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Data current Smarty_Internal_Data (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function clearConfig($varname = null)
|
|
||||||
{
|
|
||||||
if (isset($varname)) {
|
|
||||||
unset($this->config_vars[$varname]);
|
|
||||||
} else {
|
|
||||||
$this->config_vars = array();
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* class for the Smarty data object
|
|
||||||
* The Smarty data object will hold Smarty variables in the current scope
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Template
|
|
||||||
*/
|
|
||||||
class Smarty_Data extends Smarty_Internal_Data
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Smarty object
|
|
||||||
*
|
|
||||||
* @var Smarty
|
|
||||||
*/
|
|
||||||
public $smarty = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* create Smarty data object
|
|
||||||
*
|
|
||||||
* @param Smarty|array $_parent parent template
|
|
||||||
* @param Smarty|Smarty_Internal_Template $smarty global smarty instance
|
|
||||||
*
|
|
||||||
* @throws SmartyException
|
|
||||||
*/
|
|
||||||
public function __construct($_parent = null, $smarty = null)
|
|
||||||
{
|
|
||||||
$this->smarty = $smarty;
|
|
||||||
if (is_object($_parent)) {
|
|
||||||
// when object set up back pointer
|
|
||||||
$this->parent = $_parent;
|
|
||||||
} elseif (is_array($_parent)) {
|
|
||||||
// set up variable values
|
|
||||||
foreach ($_parent as $_key => $_val) {
|
|
||||||
$this->tpl_vars[$_key] = new Smarty_variable($_val);
|
|
||||||
}
|
|
||||||
} elseif ($_parent != null) {
|
|
||||||
throw new SmartyException("Wrong type for template variables");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* class for the Smarty variable object
|
|
||||||
* This class defines the Smarty variable object
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Template
|
|
||||||
*/
|
|
||||||
class Smarty_Variable
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* template variable
|
|
||||||
*
|
|
||||||
* @var mixed
|
|
||||||
*/
|
|
||||||
public $value = null;
|
|
||||||
/**
|
|
||||||
* if true any output of this variable will be not cached
|
|
||||||
*
|
|
||||||
* @var boolean
|
|
||||||
*/
|
|
||||||
public $nocache = false;
|
|
||||||
/**
|
|
||||||
* the scope the variable will have (local,parent or root)
|
|
||||||
*
|
|
||||||
* @var int
|
|
||||||
*/
|
|
||||||
public $scope = Smarty::SCOPE_LOCAL;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* create Smarty variable object
|
|
||||||
*
|
|
||||||
* @param mixed $value the value to assign
|
|
||||||
* @param boolean $nocache if true any output of this variable will be not cached
|
|
||||||
* @param int $scope the scope the variable will have (local,parent or root)
|
|
||||||
*/
|
|
||||||
public function __construct($value = null, $nocache = false, $scope = Smarty::SCOPE_LOCAL)
|
|
||||||
{
|
|
||||||
$this->value = $value;
|
|
||||||
$this->nocache = $nocache;
|
|
||||||
$this->scope = $scope;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <<magic>> String conversion
|
|
||||||
*
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
public function __toString()
|
|
||||||
{
|
|
||||||
return (string) $this->value;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* class for undefined variable object
|
|
||||||
* This class defines an object for undefined variable handling
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Template
|
|
||||||
*/
|
|
||||||
class Undefined_Smarty_Variable
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Returns FALSE for 'nocache' and NULL otherwise.
|
|
||||||
*
|
|
||||||
* @param string $name
|
|
||||||
*
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
public function __get($name)
|
|
||||||
{
|
|
||||||
if ($name == 'nocache') {
|
|
||||||
return false;
|
|
||||||
} else {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Always returns an empty string.
|
|
||||||
*
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
public function __toString()
|
|
||||||
{
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,254 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Debug
|
|
||||||
* Class to collect data for the Smarty Debugging Consol
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Debug
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Debug Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Debug
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Debug extends Smarty_Internal_Data
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* template data
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public static $template_data = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* List of uid's which shall be ignored
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public static $ignore_uid = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Ignore template
|
|
||||||
*
|
|
||||||
* @param object $template
|
|
||||||
*/
|
|
||||||
public static function ignore($template)
|
|
||||||
{
|
|
||||||
// calculate Uid if not already done
|
|
||||||
if ($template->source->uid == '') {
|
|
||||||
$template->source->filepath;
|
|
||||||
}
|
|
||||||
self::$ignore_uid[$template->source->uid] = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Start logging of compile time
|
|
||||||
*
|
|
||||||
* @param object $template
|
|
||||||
*/
|
|
||||||
public static function start_compile($template)
|
|
||||||
{
|
|
||||||
static $_is_stringy = array('string' => true, 'eval' => true);
|
|
||||||
if (!empty($template->compiler->trace_uid)) {
|
|
||||||
$key = $template->compiler->trace_uid;
|
|
||||||
if (!isset(self::$template_data[$key])) {
|
|
||||||
if (isset($_is_stringy[$template->source->type])) {
|
|
||||||
self::$template_data[$key]['name'] = '\'' . substr($template->source->name, 0, 25) . '...\'';
|
|
||||||
} else {
|
|
||||||
self::$template_data[$key]['name'] = $template->source->filepath;
|
|
||||||
}
|
|
||||||
self::$template_data[$key]['compile_time'] = 0;
|
|
||||||
self::$template_data[$key]['render_time'] = 0;
|
|
||||||
self::$template_data[$key]['cache_time'] = 0;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (isset(self::$ignore_uid[$template->source->uid])) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
$key = self::get_key($template);
|
|
||||||
}
|
|
||||||
self::$template_data[$key]['start_time'] = microtime(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* End logging of compile time
|
|
||||||
*
|
|
||||||
* @param object $template
|
|
||||||
*/
|
|
||||||
public static function end_compile($template)
|
|
||||||
{
|
|
||||||
if (!empty($template->compiler->trace_uid)) {
|
|
||||||
$key = $template->compiler->trace_uid;
|
|
||||||
} else {
|
|
||||||
if (isset(self::$ignore_uid[$template->source->uid])) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$key = self::get_key($template);
|
|
||||||
}
|
|
||||||
self::$template_data[$key]['compile_time'] += microtime(true) - self::$template_data[$key]['start_time'];
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Start logging of render time
|
|
||||||
*
|
|
||||||
* @param object $template
|
|
||||||
*/
|
|
||||||
public static function start_render($template)
|
|
||||||
{
|
|
||||||
$key = self::get_key($template);
|
|
||||||
self::$template_data[$key]['start_time'] = microtime(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* End logging of compile time
|
|
||||||
*
|
|
||||||
* @param object $template
|
|
||||||
*/
|
|
||||||
public static function end_render($template)
|
|
||||||
{
|
|
||||||
$key = self::get_key($template);
|
|
||||||
self::$template_data[$key]['render_time'] += microtime(true) - self::$template_data[$key]['start_time'];
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Start logging of cache time
|
|
||||||
*
|
|
||||||
* @param object $template cached template
|
|
||||||
*/
|
|
||||||
public static function start_cache($template)
|
|
||||||
{
|
|
||||||
$key = self::get_key($template);
|
|
||||||
self::$template_data[$key]['start_time'] = microtime(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* End logging of cache time
|
|
||||||
*
|
|
||||||
* @param object $template cached template
|
|
||||||
*/
|
|
||||||
public static function end_cache($template)
|
|
||||||
{
|
|
||||||
$key = self::get_key($template);
|
|
||||||
self::$template_data[$key]['cache_time'] += microtime(true) - self::$template_data[$key]['start_time'];
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Opens a window for the Smarty Debugging Consol and display the data
|
|
||||||
*
|
|
||||||
* @param Smarty_Internal_Template|Smarty $obj object to debug
|
|
||||||
*/
|
|
||||||
public static function display_debug($obj)
|
|
||||||
{
|
|
||||||
// prepare information of assigned variables
|
|
||||||
$ptr = self::get_debug_vars($obj);
|
|
||||||
if ($obj instanceof Smarty) {
|
|
||||||
$smarty = clone $obj;
|
|
||||||
} else {
|
|
||||||
$smarty = clone $obj->smarty;
|
|
||||||
}
|
|
||||||
$_assigned_vars = $ptr->tpl_vars;
|
|
||||||
ksort($_assigned_vars);
|
|
||||||
$_config_vars = $ptr->config_vars;
|
|
||||||
ksort($_config_vars);
|
|
||||||
$smarty->registered_filters = array();
|
|
||||||
$smarty->autoload_filters = array();
|
|
||||||
$smarty->default_modifiers = array();
|
|
||||||
$smarty->force_compile = false;
|
|
||||||
$smarty->left_delimiter = '{';
|
|
||||||
$smarty->right_delimiter = '}';
|
|
||||||
$smarty->debugging = false;
|
|
||||||
$smarty->debugging_ctrl = 'NONE';
|
|
||||||
$smarty->force_compile = false;
|
|
||||||
$_template = new Smarty_Internal_Template($smarty->debug_tpl, $smarty);
|
|
||||||
$_template->caching = false;
|
|
||||||
$_template->disableSecurity();
|
|
||||||
$_template->cache_id = null;
|
|
||||||
$_template->compile_id = null;
|
|
||||||
if ($obj instanceof Smarty_Internal_Template) {
|
|
||||||
$_template->assign('template_name', $obj->source->type . ':' . $obj->source->name);
|
|
||||||
}
|
|
||||||
if ($obj instanceof Smarty) {
|
|
||||||
$_template->assign('template_data', self::$template_data);
|
|
||||||
} else {
|
|
||||||
$_template->assign('template_data', null);
|
|
||||||
}
|
|
||||||
$_template->assign('assigned_vars', $_assigned_vars);
|
|
||||||
$_template->assign('config_vars', $_config_vars);
|
|
||||||
$_template->assign('execution_time', microtime(true) - $smarty->start_time);
|
|
||||||
echo $_template->fetch();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Recursively gets variables from all template/data scopes
|
|
||||||
*
|
|
||||||
* @param Smarty_Internal_Template|Smarty_Data $obj object to debug
|
|
||||||
*
|
|
||||||
* @return StdClass
|
|
||||||
*/
|
|
||||||
public static function get_debug_vars($obj)
|
|
||||||
{
|
|
||||||
$config_vars = $obj->config_vars;
|
|
||||||
$tpl_vars = array();
|
|
||||||
foreach ($obj->tpl_vars as $key => $var) {
|
|
||||||
$tpl_vars[$key] = clone $var;
|
|
||||||
if ($obj instanceof Smarty_Internal_Template) {
|
|
||||||
$tpl_vars[$key]->scope = $obj->source->type . ':' . $obj->source->name;
|
|
||||||
} elseif ($obj instanceof Smarty_Data) {
|
|
||||||
$tpl_vars[$key]->scope = 'Data object';
|
|
||||||
} else {
|
|
||||||
$tpl_vars[$key]->scope = 'Smarty root';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isset($obj->parent)) {
|
|
||||||
$parent = self::get_debug_vars($obj->parent);
|
|
||||||
$tpl_vars = array_merge($parent->tpl_vars, $tpl_vars);
|
|
||||||
$config_vars = array_merge($parent->config_vars, $config_vars);
|
|
||||||
} else {
|
|
||||||
foreach (Smarty::$global_tpl_vars as $name => $var) {
|
|
||||||
if (!array_key_exists($name, $tpl_vars)) {
|
|
||||||
$clone = clone $var;
|
|
||||||
$clone->scope = 'Global';
|
|
||||||
$tpl_vars[$name] = $clone;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return (object) array('tpl_vars' => $tpl_vars, 'config_vars' => $config_vars);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return key into $template_data for template
|
|
||||||
*
|
|
||||||
* @param object $template template object
|
|
||||||
*
|
|
||||||
* @return string key into $template_data
|
|
||||||
*/
|
|
||||||
private static function get_key($template)
|
|
||||||
{
|
|
||||||
static $_is_stringy = array('string' => true, 'eval' => true);
|
|
||||||
// calculate Uid if not already done
|
|
||||||
if ($template->source->uid == '') {
|
|
||||||
$template->source->filepath;
|
|
||||||
}
|
|
||||||
$key = $template->source->uid;
|
|
||||||
if (isset(self::$template_data[$key])) {
|
|
||||||
return $key;
|
|
||||||
} else {
|
|
||||||
if (isset($_is_stringy[$template->source->type])) {
|
|
||||||
self::$template_data[$key]['name'] = '\'' . substr($template->source->name, 0, 25) . '...\'';
|
|
||||||
} else {
|
|
||||||
self::$template_data[$key]['name'] = $template->source->filepath;
|
|
||||||
}
|
|
||||||
self::$template_data[$key]['compile_time'] = 0;
|
|
||||||
self::$template_data[$key]['render_time'] = 0;
|
|
||||||
self::$template_data[$key]['cache_time'] = 0;
|
|
||||||
|
|
||||||
return $key;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,67 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Filter Handler
|
|
||||||
* Smarty filter handler class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage PluginsInternal
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for filter processing
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage PluginsInternal
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Filter_Handler
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Run filters over content
|
|
||||||
* The filters will be lazy loaded if required
|
|
||||||
* class name format: Smarty_FilterType_FilterName
|
|
||||||
* plugin filename format: filtertype.filtername.php
|
|
||||||
* Smarty2 filter plugins could be used
|
|
||||||
*
|
|
||||||
* @param string $type the type of filter ('pre','post','output') which shall run
|
|
||||||
* @param string $content the content which shall be processed by the filters
|
|
||||||
* @param Smarty_Internal_Template $template template object
|
|
||||||
*
|
|
||||||
* @throws SmartyException
|
|
||||||
* @return string the filtered content
|
|
||||||
*/
|
|
||||||
public static function runFilter($type, $content, Smarty_Internal_Template $template)
|
|
||||||
{
|
|
||||||
$output = $content;
|
|
||||||
// loop over autoload filters of specified type
|
|
||||||
if (!empty($template->smarty->autoload_filters[$type])) {
|
|
||||||
foreach ((array) $template->smarty->autoload_filters[$type] as $name) {
|
|
||||||
$plugin_name = "Smarty_{$type}filter_{$name}";
|
|
||||||
if ($template->smarty->loadPlugin($plugin_name)) {
|
|
||||||
if (function_exists($plugin_name)) {
|
|
||||||
// use loaded Smarty2 style plugin
|
|
||||||
$output = $plugin_name($output, $template);
|
|
||||||
} elseif (class_exists($plugin_name, false)) {
|
|
||||||
// loaded class of filter plugin
|
|
||||||
$output = call_user_func(array($plugin_name, 'execute'), $output, $template);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// nothing found, throw exception
|
|
||||||
throw new SmartyException("Unable to load filter {$plugin_name}");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// loop over registerd filters of specified type
|
|
||||||
if (!empty($template->smarty->registered_filters[$type])) {
|
|
||||||
foreach ($template->smarty->registered_filters[$type] as $key => $name) {
|
|
||||||
if (is_array($template->smarty->registered_filters[$type][$key])) {
|
|
||||||
$output = call_user_func($template->smarty->registered_filters[$type][$key], $output, $template);
|
|
||||||
} else {
|
|
||||||
$output = $template->smarty->registered_filters[$type][$key]($output, $template);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// return filtered output
|
|
||||||
return $output;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,52 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Function Call Handler
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage PluginsInternal
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This class does call function defined with the {function} tag
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage PluginsInternal
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Function_Call_Handler
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* This function handles calls to template functions defined by {function}
|
|
||||||
* It does create a PHP function at the first call
|
|
||||||
*
|
|
||||||
* @param string $_name template function name
|
|
||||||
* @param Smarty_Internal_Template $_template template object
|
|
||||||
* @param array $_params Smarty variables passed as call parameter
|
|
||||||
* @param string $_hash nocache hash value
|
|
||||||
* @param bool $_nocache nocache flag
|
|
||||||
*/
|
|
||||||
public static function call($_name, Smarty_Internal_Template $_template, $_params, $_hash, $_nocache)
|
|
||||||
{
|
|
||||||
if ($_nocache) {
|
|
||||||
$_function = "smarty_template_function_{$_name}_nocache";
|
|
||||||
} else {
|
|
||||||
$_function = "smarty_template_function_{$_hash}_{$_name}";
|
|
||||||
}
|
|
||||||
if (!is_callable($_function)) {
|
|
||||||
$_code = "function {$_function}(\$_smarty_tpl,\$params) {
|
|
||||||
\$saved_tpl_vars = \$_smarty_tpl->tpl_vars;
|
|
||||||
foreach (\$_smarty_tpl->smarty->template_functions['{$_name}']['parameter'] as \$key => \$value) {\$_smarty_tpl->tpl_vars[\$key] = new Smarty_variable(\$value);};
|
|
||||||
foreach (\$params as \$key => \$value) {\$_smarty_tpl->tpl_vars[\$key] = new Smarty_variable(\$value);}?>";
|
|
||||||
if ($_nocache) {
|
|
||||||
$_code .= preg_replace(array("!<\?php echo \\'/\*%%SmartyNocache:{$_template->smarty->template_functions[$_name]['nocache_hash']}%%\*/|/\*/%%SmartyNocache:{$_template->smarty->template_functions[$_name]['nocache_hash']}%%\*/\\';\?>!",
|
|
||||||
"!\\\'!"), array('', "'"), $_template->smarty->template_functions[$_name]['compiled']);
|
|
||||||
$_template->smarty->template_functions[$_name]['called_nocache'] = true;
|
|
||||||
} else {
|
|
||||||
$_code .= preg_replace("/{$_template->smarty->template_functions[$_name]['nocache_hash']}/", $_template->properties['nocache_hash'], $_template->smarty->template_functions[$_name]['compiled']);
|
|
||||||
}
|
|
||||||
$_code .= "<?php \$_smarty_tpl->tpl_vars = \$saved_tpl_vars;}";
|
|
||||||
eval($_code);
|
|
||||||
}
|
|
||||||
$_function($_template, $_params);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,46 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty read include path plugin
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage PluginsInternal
|
|
||||||
* @author Monte Ohrt
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Read Include Path Class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage PluginsInternal
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Get_Include_Path
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Return full file path from PHP include_path
|
|
||||||
*
|
|
||||||
* @param string $filepath filepath
|
|
||||||
*
|
|
||||||
* @return string|boolean full filepath or false
|
|
||||||
*/
|
|
||||||
public static function getIncludePath($filepath)
|
|
||||||
{
|
|
||||||
static $_include_path = null;
|
|
||||||
|
|
||||||
if (function_exists('stream_resolve_include_path')) {
|
|
||||||
// available since PHP 5.3.2
|
|
||||||
return stream_resolve_include_path($filepath);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($_include_path === null) {
|
|
||||||
$_include_path = explode(PATH_SEPARATOR, get_include_path());
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach ($_include_path as $_path) {
|
|
||||||
if (file_exists($_path . DS . $filepath)) {
|
|
||||||
return $_path . DS . $filepath;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,361 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Templateparser Parsetrees
|
|
||||||
* These are classes to build parsetrees in the template parser
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Thue Kristensen
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @ignore
|
|
||||||
*/
|
|
||||||
abstract class _smarty_parsetree
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Parser object
|
|
||||||
*
|
|
||||||
* @var object
|
|
||||||
*/
|
|
||||||
public $parser;
|
|
||||||
/**
|
|
||||||
* Buffer content
|
|
||||||
*
|
|
||||||
* @var mixed
|
|
||||||
*/
|
|
||||||
public $data;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Subtree array
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $subtrees = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return buffer
|
|
||||||
*
|
|
||||||
* @return string buffer content
|
|
||||||
*/
|
|
||||||
abstract public function to_smarty_php();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A complete smarty tag.
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @ignore
|
|
||||||
*/
|
|
||||||
class _smarty_tag extends _smarty_parsetree
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Saved block nesting level
|
|
||||||
*
|
|
||||||
* @var int
|
|
||||||
*/
|
|
||||||
public $saved_block_nesting;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create parse tree buffer for Smarty tag
|
|
||||||
*
|
|
||||||
* @param object $parser parser object
|
|
||||||
* @param string $data content
|
|
||||||
*/
|
|
||||||
public function __construct($parser, $data)
|
|
||||||
{
|
|
||||||
$this->parser = $parser;
|
|
||||||
$this->data = $data;
|
|
||||||
$this->saved_block_nesting = $parser->block_nesting_level;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return buffer content
|
|
||||||
*
|
|
||||||
* @return string content
|
|
||||||
*/
|
|
||||||
public function to_smarty_php()
|
|
||||||
{
|
|
||||||
return $this->data;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return complied code that loads the evaluated output of buffer content into a temporary variable
|
|
||||||
*
|
|
||||||
* @return string template code
|
|
||||||
*/
|
|
||||||
public function assign_to_var()
|
|
||||||
{
|
|
||||||
$var = sprintf('$_tmp%d', ++Smarty_Internal_Templateparser::$prefix_number);
|
|
||||||
$this->parser->compiler->prefix_code[] = sprintf("<?php ob_start();\n%s\n%s=ob_get_clean();?>", preg_replace(array('/^\s*<\?php\s+/','/\s*\?>\s*$/'), '', $this->data), $var);
|
|
||||||
|
|
||||||
return $var;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Code fragment inside a tag.
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @ignore
|
|
||||||
*/
|
|
||||||
class _smarty_code extends _smarty_parsetree
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Create parse tree buffer for code fragment
|
|
||||||
*
|
|
||||||
* @param object $parser parser object
|
|
||||||
* @param string $data content
|
|
||||||
*/
|
|
||||||
public function __construct($parser, $data)
|
|
||||||
{
|
|
||||||
$this->parser = $parser;
|
|
||||||
$this->data = $data;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return buffer content in parentheses
|
|
||||||
*
|
|
||||||
* @return string content
|
|
||||||
*/
|
|
||||||
public function to_smarty_php()
|
|
||||||
{
|
|
||||||
return sprintf("(%s)", $this->data);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Double quoted string inside a tag.
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @ignore
|
|
||||||
*/
|
|
||||||
class _smarty_doublequoted extends _smarty_parsetree
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Create parse tree buffer for double quoted string subtrees
|
|
||||||
*
|
|
||||||
* @param object $parser parser object
|
|
||||||
* @param _smarty_parsetree $subtree parsetree buffer
|
|
||||||
*/
|
|
||||||
public function __construct($parser, _smarty_parsetree $subtree)
|
|
||||||
{
|
|
||||||
$this->parser = $parser;
|
|
||||||
$this->subtrees[] = $subtree;
|
|
||||||
if ($subtree instanceof _smarty_tag) {
|
|
||||||
$this->parser->block_nesting_level = count($this->parser->compiler->_tag_stack);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Append buffer to subtree
|
|
||||||
*
|
|
||||||
* @param _smarty_parsetree $subtree parsetree buffer
|
|
||||||
*/
|
|
||||||
public function append_subtree(_smarty_parsetree $subtree)
|
|
||||||
{
|
|
||||||
$last_subtree = count($this->subtrees) - 1;
|
|
||||||
if ($last_subtree >= 0 && $this->subtrees[$last_subtree] instanceof _smarty_tag && $this->subtrees[$last_subtree]->saved_block_nesting < $this->parser->block_nesting_level) {
|
|
||||||
if ($subtree instanceof _smarty_code) {
|
|
||||||
$this->subtrees[$last_subtree]->data .= '<?php echo ' . $subtree->data . ';?>';
|
|
||||||
} elseif ($subtree instanceof _smarty_dq_content) {
|
|
||||||
$this->subtrees[$last_subtree]->data .= '<?php echo "' . $subtree->data . '";?>';
|
|
||||||
} else {
|
|
||||||
$this->subtrees[$last_subtree]->data .= $subtree->data;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$this->subtrees[] = $subtree;
|
|
||||||
}
|
|
||||||
if ($subtree instanceof _smarty_tag) {
|
|
||||||
$this->parser->block_nesting_level = count($this->parser->compiler->_tag_stack);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Merge subtree buffer content together
|
|
||||||
*
|
|
||||||
* @return string compiled template code
|
|
||||||
*/
|
|
||||||
public function to_smarty_php()
|
|
||||||
{
|
|
||||||
$code = '';
|
|
||||||
foreach ($this->subtrees as $subtree) {
|
|
||||||
if ($code !== "") {
|
|
||||||
$code .= ".";
|
|
||||||
}
|
|
||||||
if ($subtree instanceof _smarty_tag) {
|
|
||||||
$more_php = $subtree->assign_to_var();
|
|
||||||
} else {
|
|
||||||
$more_php = $subtree->to_smarty_php();
|
|
||||||
}
|
|
||||||
|
|
||||||
$code .= $more_php;
|
|
||||||
|
|
||||||
if (!$subtree instanceof _smarty_dq_content) {
|
|
||||||
$this->parser->compiler->has_variable_string = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $code;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Raw chars as part of a double quoted string.
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @ignore
|
|
||||||
*/
|
|
||||||
class _smarty_dq_content extends _smarty_parsetree
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Create parse tree buffer with string content
|
|
||||||
*
|
|
||||||
* @param object $parser parser object
|
|
||||||
* @param string $data string section
|
|
||||||
*/
|
|
||||||
public function __construct($parser, $data)
|
|
||||||
{
|
|
||||||
$this->parser = $parser;
|
|
||||||
$this->data = $data;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return content as double quoted string
|
|
||||||
*
|
|
||||||
* @return string doubled quoted string
|
|
||||||
*/
|
|
||||||
public function to_smarty_php()
|
|
||||||
{
|
|
||||||
return '"' . $this->data . '"';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Template element
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @ignore
|
|
||||||
*/
|
|
||||||
class _smarty_template_buffer extends _smarty_parsetree
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Array of template elements
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $subtrees = Array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create root of parse tree for template elements
|
|
||||||
*
|
|
||||||
* @param object $parser parse object
|
|
||||||
*/
|
|
||||||
public function __construct($parser)
|
|
||||||
{
|
|
||||||
$this->parser = $parser;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Append buffer to subtree
|
|
||||||
*
|
|
||||||
* @param _smarty_parsetree $subtree
|
|
||||||
*/
|
|
||||||
public function append_subtree(_smarty_parsetree $subtree)
|
|
||||||
{
|
|
||||||
if ($subtree->data !== '') {
|
|
||||||
$this->subtrees[] = $subtree;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sanitize and merge subtree buffers together
|
|
||||||
*
|
|
||||||
* @return string template code content
|
|
||||||
*/
|
|
||||||
public function to_smarty_php()
|
|
||||||
{
|
|
||||||
$code = '';
|
|
||||||
for ($key = 0, $cnt = count($this->subtrees); $key < $cnt; $key ++) {
|
|
||||||
if ($this->subtrees[$key] instanceof _smarty_text) {
|
|
||||||
$subtree = $this->subtrees[$key]->to_smarty_php();
|
|
||||||
while ($key + 1 < $cnt && ($this->subtrees[$key+1] instanceof _smarty_text || $this->subtrees[$key +1]->data == '')) {
|
|
||||||
$key++;
|
|
||||||
if ($this->subtrees[$key]->data == '') {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
$subtree .= $this->subtrees[$key]->to_smarty_php();
|
|
||||||
}
|
|
||||||
if ($subtree == '') {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
$code .= preg_replace('/(<%|%>|<\?php|<\?|\?>|<\/?script)/', "<?php echo '\$1'; ?>\n", $subtree);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if ($this->subtrees[$key] instanceof _smarty_tag) {
|
|
||||||
$subtree = $this->subtrees[$key]->to_smarty_php();
|
|
||||||
while ($key + 1 < $cnt && ($this->subtrees[$key+1] instanceof _smarty_tag || $this->subtrees[$key +1]->data == '')) {
|
|
||||||
$key++;
|
|
||||||
if ($this->subtrees[$key]->data == '') {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
$newCode = $this->subtrees[$key]->to_smarty_php();
|
|
||||||
if ((preg_match('/^\s*<\?php\s+/', $newCode) && preg_match('/\s*\?>\s*$/', $subtree))) {
|
|
||||||
$subtree = preg_replace('/\s*\?>\s*$/', "\n", $subtree);
|
|
||||||
$subtree .= preg_replace('/^\s*<\?php\s+/', '', $newCode);
|
|
||||||
} else {
|
|
||||||
$subtree .= $newCode;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($subtree == '') {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
$code .= $subtree;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
$code .= $this->subtrees[$key]->to_smarty_php();
|
|
||||||
}
|
|
||||||
return $code;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* template text
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @ignore
|
|
||||||
*/
|
|
||||||
class _smarty_text extends _smarty_parsetree
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Create template text buffer
|
|
||||||
*
|
|
||||||
* @param object $parser parser object
|
|
||||||
* @param string $data text
|
|
||||||
*/
|
|
||||||
public function __construct($parser, $data)
|
|
||||||
{
|
|
||||||
$this->parser = $parser;
|
|
||||||
$this->data = $data;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return buffer content
|
|
||||||
*
|
|
||||||
* @return strint text
|
|
||||||
*/
|
|
||||||
public function to_smarty_php()
|
|
||||||
{
|
|
||||||
return $this->data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,89 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Resource File
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage TemplateResources
|
|
||||||
* @author Uwe Tews
|
|
||||||
* @author Rodney Rehm
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Resource File
|
|
||||||
* Implements the file system as resource for Smarty templates
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage TemplateResources
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Resource_File extends Smarty_Resource
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* populate Source Object with meta data from Resource
|
|
||||||
*
|
|
||||||
* @param Smarty_Template_Source $source source object
|
|
||||||
* @param Smarty_Internal_Template $_template template object
|
|
||||||
*/
|
|
||||||
public function populate(Smarty_Template_Source $source, Smarty_Internal_Template $_template = null)
|
|
||||||
{
|
|
||||||
$source->filepath = $this->buildFilepath($source, $_template);
|
|
||||||
|
|
||||||
if ($source->filepath !== false) {
|
|
||||||
if (is_object($source->smarty->security_policy)) {
|
|
||||||
$source->smarty->security_policy->isTrustedResourceDir($source->filepath);
|
|
||||||
}
|
|
||||||
|
|
||||||
$source->uid = sha1(realpath($source->filepath));
|
|
||||||
if ($source->smarty->compile_check && !isset($source->timestamp)) {
|
|
||||||
$source->timestamp = @filemtime($source->filepath);
|
|
||||||
$source->exists = !!$source->timestamp;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* populate Source Object with timestamp and exists from Resource
|
|
||||||
*
|
|
||||||
* @param Smarty_Template_Source $source source object
|
|
||||||
*/
|
|
||||||
public function populateTimestamp(Smarty_Template_Source $source)
|
|
||||||
{
|
|
||||||
$source->timestamp = @filemtime($source->filepath);
|
|
||||||
$source->exists = !!$source->timestamp;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Load template's source from file into current template object
|
|
||||||
*
|
|
||||||
* @param Smarty_Template_Source $source source object
|
|
||||||
*
|
|
||||||
* @return string template source
|
|
||||||
* @throws SmartyException if source cannot be loaded
|
|
||||||
*/
|
|
||||||
public function getContent(Smarty_Template_Source $source)
|
|
||||||
{
|
|
||||||
if ($source->timestamp) {
|
|
||||||
return file_get_contents($source->filepath);
|
|
||||||
}
|
|
||||||
if ($source instanceof Smarty_Config_Source) {
|
|
||||||
throw new SmartyException("Unable to read config {$source->type} '{$source->name}'");
|
|
||||||
}
|
|
||||||
throw new SmartyException("Unable to read template {$source->type} '{$source->name}'");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Determine basename for compiled filename
|
|
||||||
*
|
|
||||||
* @param Smarty_Template_Source $source source object
|
|
||||||
*
|
|
||||||
* @return string resource's basename
|
|
||||||
*/
|
|
||||||
public function getBasename(Smarty_Template_Source $source)
|
|
||||||
{
|
|
||||||
$_file = $source->name;
|
|
||||||
if (($_pos = strpos($_file, ']')) !== false) {
|
|
||||||
$_file = substr($_file, $_pos + 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
return basename($_file);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,140 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Smarty Template Compiler Base
|
|
||||||
* This file contains the basic classes and methods for compiling Smarty templates with lexer/parser
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ignore
|
|
||||||
*/
|
|
||||||
include 'smarty_internal_parsetree.php';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class SmartyTemplateCompiler
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_SmartyTemplateCompiler extends Smarty_Internal_TemplateCompilerBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Lexer class name
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $lexer_class;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parser class name
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $parser_class;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Lexer object
|
|
||||||
*
|
|
||||||
* @var object
|
|
||||||
*/
|
|
||||||
public $lex;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parser object
|
|
||||||
*
|
|
||||||
* @var object
|
|
||||||
*/
|
|
||||||
public $parser;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty object
|
|
||||||
*
|
|
||||||
* @var object
|
|
||||||
*/
|
|
||||||
public $smarty;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* array of vars which can be compiled in local scope
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $local_var = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Initialize compiler
|
|
||||||
*
|
|
||||||
* @param string $lexer_class class name
|
|
||||||
* @param string $parser_class class name
|
|
||||||
* @param Smarty $smarty global instance
|
|
||||||
*/
|
|
||||||
public function __construct($lexer_class, $parser_class, $smarty)
|
|
||||||
{
|
|
||||||
$this->smarty = $smarty;
|
|
||||||
parent::__construct();
|
|
||||||
// get required plugins
|
|
||||||
$this->lexer_class = $lexer_class;
|
|
||||||
$this->parser_class = $parser_class;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* method to compile a Smarty template
|
|
||||||
*
|
|
||||||
* @param mixed $_content template source
|
|
||||||
*
|
|
||||||
* @return bool true if compiling succeeded, false if it failed
|
|
||||||
*/
|
|
||||||
protected function doCompile($_content)
|
|
||||||
{
|
|
||||||
/* here is where the compiling takes place. Smarty
|
|
||||||
tags in the templates are replaces with PHP code,
|
|
||||||
then written to compiled files. */
|
|
||||||
// init the lexer/parser to compile the template
|
|
||||||
$this->lex = new $this->lexer_class($_content, $this);
|
|
||||||
$this->parser = new $this->parser_class($this->lex, $this);
|
|
||||||
if ($this->inheritance_child) {
|
|
||||||
// start state on child templates
|
|
||||||
$this->lex->yypushstate(Smarty_Internal_Templatelexer::CHILDBODY);
|
|
||||||
}
|
|
||||||
if (function_exists('mb_internal_encoding') && ((int) ini_get('mbstring.func_overload')) & 2) {
|
|
||||||
$mbEncoding = mb_internal_encoding();
|
|
||||||
mb_internal_encoding('ASCII');
|
|
||||||
} else {
|
|
||||||
$mbEncoding = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($this->smarty->_parserdebug) {
|
|
||||||
$this->parser->PrintTrace();
|
|
||||||
$this->lex->PrintTrace();
|
|
||||||
}
|
|
||||||
// get tokens from lexer and parse them
|
|
||||||
while ($this->lex->yylex() && !$this->abort_and_recompile) {
|
|
||||||
if ($this->smarty->_parserdebug) {
|
|
||||||
echo "<pre>Line {$this->lex->line} Parsing {$this->parser->yyTokenName[$this->lex->token]} Token " .
|
|
||||||
htmlentities($this->lex->value) . "</pre>";
|
|
||||||
}
|
|
||||||
$this->parser->doParse($this->lex->token, $this->lex->value);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($this->abort_and_recompile) {
|
|
||||||
// exit here on abort
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
// finish parsing process
|
|
||||||
$this->parser->doParse(0, 0);
|
|
||||||
if ($mbEncoding) {
|
|
||||||
mb_internal_encoding($mbEncoding);
|
|
||||||
}
|
|
||||||
// check for unclosed tags
|
|
||||||
if (count($this->_tag_stack) > 0) {
|
|
||||||
// get stacked info
|
|
||||||
list($openTag, $_data) = array_pop($this->_tag_stack);
|
|
||||||
$this->trigger_template_error("unclosed {$this->smarty->left_delimiter}" . $openTag . "{$this->smarty->right_delimiter} tag");
|
|
||||||
}
|
|
||||||
// return compiled code
|
|
||||||
// return str_replace(array("? >\n<?php","? ><?php"), array('',''), $this->parser->retvalue);
|
|
||||||
return $this->parser->retvalue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,738 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Template
|
|
||||||
* This file contains the Smarty template engine
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Template
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Main class with template data structures and methods
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Template
|
|
||||||
* @property Smarty_Template_Source $source
|
|
||||||
* @property Smarty_Template_Compiled $compiled
|
|
||||||
* @property Smarty_Template_Cached $cached
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Template extends Smarty_Internal_TemplateBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* cache_id
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $cache_id = null;
|
|
||||||
/**
|
|
||||||
* $compile_id
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $compile_id = null;
|
|
||||||
/**
|
|
||||||
* caching enabled
|
|
||||||
*
|
|
||||||
* @var boolean
|
|
||||||
*/
|
|
||||||
public $caching = null;
|
|
||||||
/**
|
|
||||||
* cache lifetime in seconds
|
|
||||||
*
|
|
||||||
* @var integer
|
|
||||||
*/
|
|
||||||
public $cache_lifetime = null;
|
|
||||||
/**
|
|
||||||
* Template resource
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $template_resource = null;
|
|
||||||
/**
|
|
||||||
* flag if compiled template is invalid and must be (re)compiled
|
|
||||||
*
|
|
||||||
* @var bool
|
|
||||||
*/
|
|
||||||
public $mustCompile = null;
|
|
||||||
/**
|
|
||||||
* flag if template does contain nocache code sections
|
|
||||||
*
|
|
||||||
* @var bool
|
|
||||||
*/
|
|
||||||
public $has_nocache_code = false;
|
|
||||||
/**
|
|
||||||
* special compiled and cached template properties
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $properties = array('file_dependency' => array(),
|
|
||||||
'nocache_hash' => '',
|
|
||||||
'function' => array());
|
|
||||||
/**
|
|
||||||
* required plugins
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $required_plugins = array('compiled' => array(), 'nocache' => array());
|
|
||||||
/**
|
|
||||||
* Global smarty instance
|
|
||||||
*
|
|
||||||
* @var Smarty
|
|
||||||
*/
|
|
||||||
public $smarty = null;
|
|
||||||
/**
|
|
||||||
* blocks for template inheritance
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $block_data = array();
|
|
||||||
/**
|
|
||||||
* variable filters
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $variable_filters = array();
|
|
||||||
/**
|
|
||||||
* optional log of tag/attributes
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $used_tags = array();
|
|
||||||
/**
|
|
||||||
* internal flag to allow relative path in child template blocks
|
|
||||||
*
|
|
||||||
* @var bool
|
|
||||||
*/
|
|
||||||
public $allow_relative_path = false;
|
|
||||||
/**
|
|
||||||
* internal capture runtime stack
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $_capture_stack = array(0 => array());
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create template data object
|
|
||||||
* Some of the global Smarty settings copied to template scope
|
|
||||||
* It load the required template resources and cacher plugins
|
|
||||||
*
|
|
||||||
* @param string $template_resource template resource string
|
|
||||||
* @param Smarty $smarty Smarty instance
|
|
||||||
* @param Smarty_Internal_Template $_parent back pointer to parent object with variables or null
|
|
||||||
* @param mixed $_cache_id cache id or null
|
|
||||||
* @param mixed $_compile_id compile id or null
|
|
||||||
* @param bool $_caching use caching?
|
|
||||||
* @param int $_cache_lifetime cache life-time in seconds
|
|
||||||
*/
|
|
||||||
public function __construct($template_resource, $smarty, $_parent = null, $_cache_id = null, $_compile_id = null, $_caching = null, $_cache_lifetime = null)
|
|
||||||
{
|
|
||||||
$this->smarty = & $smarty;
|
|
||||||
// Smarty parameter
|
|
||||||
$this->cache_id = $_cache_id === null ? $this->smarty->cache_id : $_cache_id;
|
|
||||||
$this->compile_id = $_compile_id === null ? $this->smarty->compile_id : $_compile_id;
|
|
||||||
$this->caching = $_caching === null ? $this->smarty->caching : $_caching;
|
|
||||||
if ($this->caching === true) {
|
|
||||||
$this->caching = Smarty::CACHING_LIFETIME_CURRENT;
|
|
||||||
}
|
|
||||||
$this->cache_lifetime = $_cache_lifetime === null ? $this->smarty->cache_lifetime : $_cache_lifetime;
|
|
||||||
$this->parent = $_parent;
|
|
||||||
// Template resource
|
|
||||||
$this->template_resource = $template_resource;
|
|
||||||
// copy block data of template inheritance
|
|
||||||
if ($this->parent instanceof Smarty_Internal_Template) {
|
|
||||||
$this->block_data = $this->parent->block_data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns if the current template must be compiled by the Smarty compiler
|
|
||||||
* It does compare the timestamps of template source and the compiled templates and checks the force compile configuration
|
|
||||||
*
|
|
||||||
* @throws SmartyException
|
|
||||||
* @return boolean true if the template must be compiled
|
|
||||||
*/
|
|
||||||
public function mustCompile()
|
|
||||||
{
|
|
||||||
if (!$this->source->exists) {
|
|
||||||
if ($this->parent instanceof Smarty_Internal_Template) {
|
|
||||||
$parent_resource = " in '$this->parent->template_resource}'";
|
|
||||||
} else {
|
|
||||||
$parent_resource = '';
|
|
||||||
}
|
|
||||||
throw new SmartyException("Unable to load template {$this->source->type} '{$this->source->name}'{$parent_resource}");
|
|
||||||
}
|
|
||||||
if ($this->mustCompile === null) {
|
|
||||||
$this->mustCompile = (!$this->source->uncompiled && ($this->smarty->force_compile || $this->source->recompiled || $this->compiled->timestamp === false ||
|
|
||||||
($this->smarty->compile_check && $this->compiled->timestamp < $this->source->timestamp)));
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->mustCompile;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles the template
|
|
||||||
* If the template is not evaluated the compiled template is saved on disk
|
|
||||||
*/
|
|
||||||
public function compileTemplateSource()
|
|
||||||
{
|
|
||||||
if (!$this->source->recompiled) {
|
|
||||||
$this->properties['file_dependency'] = array();
|
|
||||||
if ($this->source->components) {
|
|
||||||
// for the extends resource the compiler will fill it
|
|
||||||
// uses real resource for file dependency
|
|
||||||
// $source = end($this->source->components);
|
|
||||||
// $this->properties['file_dependency'][$this->source->uid] = array($this->source->filepath, $this->source->timestamp, $source->type);
|
|
||||||
} else {
|
|
||||||
$this->properties['file_dependency'][$this->source->uid] = array($this->source->filepath, $this->source->timestamp, $this->source->type);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// compile locking
|
|
||||||
if ($this->smarty->compile_locking && !$this->source->recompiled) {
|
|
||||||
if ($saved_timestamp = $this->compiled->timestamp) {
|
|
||||||
touch($this->compiled->filepath);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// call compiler
|
|
||||||
try {
|
|
||||||
$code = $this->compiler->compileTemplate($this);
|
|
||||||
}
|
|
||||||
catch (Exception $e) {
|
|
||||||
// restore old timestamp in case of error
|
|
||||||
if ($this->smarty->compile_locking && !$this->source->recompiled && $saved_timestamp) {
|
|
||||||
touch($this->compiled->filepath, $saved_timestamp);
|
|
||||||
}
|
|
||||||
throw $e;
|
|
||||||
}
|
|
||||||
// compiling succeded
|
|
||||||
if (!$this->source->recompiled && $this->compiler->write_compiled_code) {
|
|
||||||
// write compiled template
|
|
||||||
$_filepath = $this->compiled->filepath;
|
|
||||||
if ($_filepath === false) {
|
|
||||||
throw new SmartyException('getCompiledFilepath() did not return a destination to save the compiled template to');
|
|
||||||
}
|
|
||||||
Smarty_Internal_Write_File::writeFile($_filepath, $code, $this->smarty);
|
|
||||||
$this->compiled->exists = true;
|
|
||||||
$this->compiled->isCompiled = true;
|
|
||||||
}
|
|
||||||
// release compiler object to free memory
|
|
||||||
unset($this->compiler);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Writes the cached template output
|
|
||||||
*
|
|
||||||
* @param string $content
|
|
||||||
*
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
public function writeCachedContent($content)
|
|
||||||
{
|
|
||||||
if ($this->source->recompiled || !($this->caching == Smarty::CACHING_LIFETIME_CURRENT || $this->caching == Smarty::CACHING_LIFETIME_SAVED)) {
|
|
||||||
// don't write cache file
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
$this->cached->timestamp = time();
|
|
||||||
$this->properties['cache_lifetime'] = $this->cache_lifetime;
|
|
||||||
$this->properties['unifunc'] = 'content_' . str_replace(array('.', ','), '_', uniqid('', true));
|
|
||||||
$content = $this->createTemplateCodeFrame($content, true);
|
|
||||||
/** @var Smarty_Internal_Template $_smarty_tpl
|
|
||||||
* used in evaluated code
|
|
||||||
*/
|
|
||||||
$_smarty_tpl = $this;
|
|
||||||
eval("?>" . $content);
|
|
||||||
$this->cached->valid = true;
|
|
||||||
$this->cached->processed = true;
|
|
||||||
|
|
||||||
return $this->cached->write($this, $content);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Template code runtime function to get subtemplate content
|
|
||||||
*
|
|
||||||
* @param string $template the resource handle of the template file
|
|
||||||
* @param mixed $cache_id cache id to be used with this template
|
|
||||||
* @param mixed $compile_id compile id to be used with this template
|
|
||||||
* @param integer $caching cache mode
|
|
||||||
* @param integer $cache_lifetime life time of cache data
|
|
||||||
* @param $data
|
|
||||||
* @param int $parent_scope scope in which {include} should execute
|
|
||||||
*
|
|
||||||
* @returns string template content
|
|
||||||
*/
|
|
||||||
public function getSubTemplate($template, $cache_id, $compile_id, $caching, $cache_lifetime, $data, $parent_scope)
|
|
||||||
{
|
|
||||||
// already in template cache?
|
|
||||||
if ($this->smarty->allow_ambiguous_resources) {
|
|
||||||
$_templateId = Smarty_Resource::getUniqueTemplateName($this, $template) . $cache_id . $compile_id;
|
|
||||||
} else {
|
|
||||||
$_templateId = $this->smarty->joined_template_dir . '#' . $template . $cache_id . $compile_id;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isset($_templateId[150])) {
|
|
||||||
$_templateId = sha1($_templateId);
|
|
||||||
}
|
|
||||||
if (isset($this->smarty->template_objects[$_templateId])) {
|
|
||||||
// clone cached template object because of possible recursive call
|
|
||||||
$tpl = clone $this->smarty->template_objects[$_templateId];
|
|
||||||
$tpl->parent = $this;
|
|
||||||
$tpl->caching = $caching;
|
|
||||||
$tpl->cache_lifetime = $cache_lifetime;
|
|
||||||
} else {
|
|
||||||
$tpl = new $this->smarty->template_class($template, $this->smarty, $this, $cache_id, $compile_id, $caching, $cache_lifetime);
|
|
||||||
}
|
|
||||||
// get variables from calling scope
|
|
||||||
if ($parent_scope == Smarty::SCOPE_LOCAL) {
|
|
||||||
$tpl->tpl_vars = $this->tpl_vars;
|
|
||||||
$tpl->tpl_vars['smarty'] = clone $this->tpl_vars['smarty'];
|
|
||||||
} elseif ($parent_scope == Smarty::SCOPE_PARENT) {
|
|
||||||
$tpl->tpl_vars = & $this->tpl_vars;
|
|
||||||
} elseif ($parent_scope == Smarty::SCOPE_GLOBAL) {
|
|
||||||
$tpl->tpl_vars = & Smarty::$global_tpl_vars;
|
|
||||||
} elseif (($scope_ptr = $this->getScopePointer($parent_scope)) == null) {
|
|
||||||
$tpl->tpl_vars = & $this->tpl_vars;
|
|
||||||
} else {
|
|
||||||
$tpl->tpl_vars = & $scope_ptr->tpl_vars;
|
|
||||||
}
|
|
||||||
$tpl->config_vars = $this->config_vars;
|
|
||||||
if (!empty($data)) {
|
|
||||||
// set up variable values
|
|
||||||
foreach ($data as $_key => $_val) {
|
|
||||||
$tpl->tpl_vars[$_key] = new Smarty_variable($_val);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $tpl->fetch(null, null, null, null, false, false, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Template code runtime function to set up an inline subtemplate
|
|
||||||
*
|
|
||||||
* @param string $template the resource handle of the template file
|
|
||||||
* @param mixed $cache_id cache id to be used with this template
|
|
||||||
* @param mixed $compile_id compile id to be used with this template
|
|
||||||
* @param integer $caching cache mode
|
|
||||||
* @param integer $cache_lifetime life time of cache data
|
|
||||||
* @param $data
|
|
||||||
* @param int $parent_scope scope in which {include} should execute
|
|
||||||
* @param string $hash nocache hash code
|
|
||||||
*
|
|
||||||
* @returns string template content
|
|
||||||
*/
|
|
||||||
public function setupInlineSubTemplate($template, $cache_id, $compile_id, $caching, $cache_lifetime, $data, $parent_scope, $hash)
|
|
||||||
{
|
|
||||||
$tpl = new $this->smarty->template_class($template, $this->smarty, $this, $cache_id, $compile_id, $caching, $cache_lifetime);
|
|
||||||
$tpl->properties['nocache_hash'] = $hash;
|
|
||||||
// get variables from calling scope
|
|
||||||
if ($parent_scope == Smarty::SCOPE_LOCAL) {
|
|
||||||
$tpl->tpl_vars = $this->tpl_vars;
|
|
||||||
$tpl->tpl_vars['smarty'] = clone $this->tpl_vars['smarty'];
|
|
||||||
} elseif ($parent_scope == Smarty::SCOPE_PARENT) {
|
|
||||||
$tpl->tpl_vars = & $this->tpl_vars;
|
|
||||||
} elseif ($parent_scope == Smarty::SCOPE_GLOBAL) {
|
|
||||||
$tpl->tpl_vars = & Smarty::$global_tpl_vars;
|
|
||||||
} elseif (($scope_ptr = $this->getScopePointer($parent_scope)) == null) {
|
|
||||||
$tpl->tpl_vars = & $this->tpl_vars;
|
|
||||||
} else {
|
|
||||||
$tpl->tpl_vars = & $scope_ptr->tpl_vars;
|
|
||||||
}
|
|
||||||
$tpl->config_vars = $this->config_vars;
|
|
||||||
if (!empty($data)) {
|
|
||||||
// set up variable values
|
|
||||||
foreach ($data as $_key => $_val) {
|
|
||||||
$tpl->tpl_vars[$_key] = new Smarty_variable($_val);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $tpl;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create code frame for compiled and cached templates
|
|
||||||
*
|
|
||||||
* @param string $content optional template content
|
|
||||||
* @param bool $cache flag for cache file
|
|
||||||
*
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
public function createTemplateCodeFrame($content = '', $cache = false)
|
|
||||||
{
|
|
||||||
$plugins_string = '';
|
|
||||||
// include code for plugins
|
|
||||||
if (!$cache) {
|
|
||||||
if (!empty($this->required_plugins['compiled'])) {
|
|
||||||
$plugins_string = '<?php ';
|
|
||||||
foreach ($this->required_plugins['compiled'] as $tmp) {
|
|
||||||
foreach ($tmp as $data) {
|
|
||||||
$file = addslashes($data['file']);
|
|
||||||
if (is_Array($data['function'])) {
|
|
||||||
$plugins_string .= "if (!is_callable(array('{$data['function'][0]}','{$data['function'][1]}'))) include '{$file}';\n";
|
|
||||||
} else {
|
|
||||||
$plugins_string .= "if (!is_callable('{$data['function']}')) include '{$file}';\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$plugins_string .= '?>';
|
|
||||||
}
|
|
||||||
if (!empty($this->required_plugins['nocache'])) {
|
|
||||||
$this->has_nocache_code = true;
|
|
||||||
$plugins_string .= "<?php echo '/*%%SmartyNocache:{$this->properties['nocache_hash']}%%*/<?php \$_smarty = \$_smarty_tpl->smarty; ";
|
|
||||||
foreach ($this->required_plugins['nocache'] as $tmp) {
|
|
||||||
foreach ($tmp as $data) {
|
|
||||||
$file = addslashes($data['file']);
|
|
||||||
if (is_Array($data['function'])) {
|
|
||||||
$plugins_string .= addslashes("if (!is_callable(array('{$data['function'][0]}','{$data['function'][1]}'))) include '{$file}';\n");
|
|
||||||
} else {
|
|
||||||
$plugins_string .= addslashes("if (!is_callable('{$data['function']}')) include '{$file}';\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$plugins_string .= "?>/*/%%SmartyNocache:{$this->properties['nocache_hash']}%%*/';?>\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// build property code
|
|
||||||
$this->properties['has_nocache_code'] = $this->has_nocache_code;
|
|
||||||
$output = '';
|
|
||||||
if (!$this->source->recompiled) {
|
|
||||||
$output = "<?php /*%%SmartyHeaderCode:{$this->properties['nocache_hash']}%%*/";
|
|
||||||
if ($this->smarty->direct_access_security) {
|
|
||||||
$output .= "if(!defined('SMARTY_DIR')) exit('no direct access allowed');\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($cache) {
|
|
||||||
// remove compiled code of{function} definition
|
|
||||||
unset($this->properties['function']);
|
|
||||||
if (!empty($this->smarty->template_functions)) {
|
|
||||||
// copy code of {function} tags called in nocache mode
|
|
||||||
foreach ($this->smarty->template_functions as $name => $function_data) {
|
|
||||||
if (isset($function_data['called_nocache'])) {
|
|
||||||
foreach ($function_data['called_functions'] as $func_name) {
|
|
||||||
$this->smarty->template_functions[$func_name]['called_nocache'] = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
foreach ($this->smarty->template_functions as $name => $function_data) {
|
|
||||||
if (isset($function_data['called_nocache'])) {
|
|
||||||
unset($function_data['called_nocache'], $function_data['called_functions'], $this->smarty->template_functions[$name]['called_nocache']);
|
|
||||||
$this->properties['function'][$name] = $function_data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$this->properties['version'] = Smarty::SMARTY_VERSION;
|
|
||||||
if (!isset($this->properties['unifunc'])) {
|
|
||||||
$this->properties['unifunc'] = 'content_' . str_replace(array('.', ','), '_', uniqid('', true));
|
|
||||||
}
|
|
||||||
if (!$this->source->recompiled) {
|
|
||||||
$output .= "\$_valid = \$_smarty_tpl->decodeProperties(" . var_export($this->properties, true) . ',' . ($cache ? 'true' : 'false') . "); /*/%%SmartyHeaderCode%%*/?>\n";
|
|
||||||
$output .= '<?php if ($_valid && !is_callable(\'' . $this->properties['unifunc'] . '\')) {function ' . $this->properties['unifunc'] . '($_smarty_tpl) {?>';
|
|
||||||
}
|
|
||||||
$output .= $plugins_string;
|
|
||||||
$output .= $content;
|
|
||||||
if (!$this->source->recompiled) {
|
|
||||||
$output .= "<?php }} ?>\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $output;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This function is executed automatically when a compiled or cached template file is included
|
|
||||||
* - Decode saved properties from compiled template and cache files
|
|
||||||
* - Check if compiled or cache file is valid
|
|
||||||
*
|
|
||||||
* @param array $properties special template properties
|
|
||||||
* @param bool $cache flag if called from cache file
|
|
||||||
*
|
|
||||||
* @return bool flag if compiled or cache file is valid
|
|
||||||
*/
|
|
||||||
public function decodeProperties($properties, $cache = false)
|
|
||||||
{
|
|
||||||
$this->has_nocache_code = $properties['has_nocache_code'];
|
|
||||||
$this->properties['nocache_hash'] = $properties['nocache_hash'];
|
|
||||||
if (isset($properties['cache_lifetime'])) {
|
|
||||||
$this->properties['cache_lifetime'] = $properties['cache_lifetime'];
|
|
||||||
}
|
|
||||||
if (isset($properties['file_dependency'])) {
|
|
||||||
$this->properties['file_dependency'] = array_merge($this->properties['file_dependency'], $properties['file_dependency']);
|
|
||||||
}
|
|
||||||
if (!empty($properties['function'])) {
|
|
||||||
$this->properties['function'] = array_merge($this->properties['function'], $properties['function']);
|
|
||||||
$this->smarty->template_functions = array_merge($this->smarty->template_functions, $properties['function']);
|
|
||||||
}
|
|
||||||
$this->properties['version'] = (isset($properties['version'])) ? $properties['version'] : '';
|
|
||||||
$this->properties['unifunc'] = $properties['unifunc'];
|
|
||||||
// check file dependencies at compiled code
|
|
||||||
$is_valid = true;
|
|
||||||
if ($this->properties['version'] != Smarty::SMARTY_VERSION) {
|
|
||||||
$is_valid = false;
|
|
||||||
} elseif (((!$cache && $this->smarty->compile_check && empty($this->compiled->_properties) && !$this->compiled->isCompiled) || $cache && ($this->smarty->compile_check === true || $this->smarty->compile_check === Smarty::COMPILECHECK_ON)) && !empty($this->properties['file_dependency'])) {
|
|
||||||
foreach ($this->properties['file_dependency'] as $_file_to_check) {
|
|
||||||
if ($_file_to_check[2] == 'file' || $_file_to_check[2] == 'php') {
|
|
||||||
if ($this->source->filepath == $_file_to_check[0] && isset($this->source->timestamp)) {
|
|
||||||
// do not recheck current template
|
|
||||||
$mtime = $this->source->timestamp;
|
|
||||||
} else {
|
|
||||||
// file and php types can be checked without loading the respective resource handlers
|
|
||||||
$mtime = @filemtime($_file_to_check[0]);
|
|
||||||
}
|
|
||||||
} elseif ($_file_to_check[2] == 'string') {
|
|
||||||
continue;
|
|
||||||
} else {
|
|
||||||
$source = Smarty_Resource::source(null, $this->smarty, $_file_to_check[0]);
|
|
||||||
$mtime = $source->timestamp;
|
|
||||||
}
|
|
||||||
if (!$mtime || $mtime > $_file_to_check[1]) {
|
|
||||||
$is_valid = false;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($cache) {
|
|
||||||
// CACHING_LIFETIME_SAVED cache expiry has to be validated here since otherwise we'd define the unifunc
|
|
||||||
if ($this->caching === Smarty::CACHING_LIFETIME_SAVED &&
|
|
||||||
$this->properties['cache_lifetime'] >= 0 &&
|
|
||||||
(time() > ($this->cached->timestamp + $this->properties['cache_lifetime']))
|
|
||||||
) {
|
|
||||||
$is_valid = false;
|
|
||||||
}
|
|
||||||
$this->cached->valid = $is_valid;
|
|
||||||
} else {
|
|
||||||
$this->mustCompile = !$is_valid;
|
|
||||||
}
|
|
||||||
// store data in reusable Smarty_Template_Compiled
|
|
||||||
if (!$cache) {
|
|
||||||
$this->compiled->_properties = $properties;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $is_valid;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Template code runtime function to create a local Smarty variable for array assignments
|
|
||||||
*
|
|
||||||
* @param string $tpl_var tempate variable name
|
|
||||||
* @param bool $nocache cache mode of variable
|
|
||||||
* @param int $scope scope of variable
|
|
||||||
*/
|
|
||||||
public function createLocalArrayVariable($tpl_var, $nocache = false, $scope = Smarty::SCOPE_LOCAL)
|
|
||||||
{
|
|
||||||
if (!isset($this->tpl_vars[$tpl_var])) {
|
|
||||||
$this->tpl_vars[$tpl_var] = new Smarty_variable(array(), $nocache, $scope);
|
|
||||||
} else {
|
|
||||||
$this->tpl_vars[$tpl_var] = clone $this->tpl_vars[$tpl_var];
|
|
||||||
if ($scope != Smarty::SCOPE_LOCAL) {
|
|
||||||
$this->tpl_vars[$tpl_var]->scope = $scope;
|
|
||||||
}
|
|
||||||
if (!(is_array($this->tpl_vars[$tpl_var]->value) || $this->tpl_vars[$tpl_var]->value instanceof ArrayAccess)) {
|
|
||||||
settype($this->tpl_vars[$tpl_var]->value, 'array');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Template code runtime function to get pointer to template variable array of requested scope
|
|
||||||
*
|
|
||||||
* @param int $scope requested variable scope
|
|
||||||
*
|
|
||||||
* @return array array of template variables
|
|
||||||
*/
|
|
||||||
public function &getScope($scope)
|
|
||||||
{
|
|
||||||
if ($scope == Smarty::SCOPE_PARENT && !empty($this->parent)) {
|
|
||||||
return $this->parent->tpl_vars;
|
|
||||||
} elseif ($scope == Smarty::SCOPE_ROOT && !empty($this->parent)) {
|
|
||||||
$ptr = $this->parent;
|
|
||||||
while (!empty($ptr->parent)) {
|
|
||||||
$ptr = $ptr->parent;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $ptr->tpl_vars;
|
|
||||||
} elseif ($scope == Smarty::SCOPE_GLOBAL) {
|
|
||||||
return Smarty::$global_tpl_vars;
|
|
||||||
}
|
|
||||||
$null = null;
|
|
||||||
|
|
||||||
return $null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get parent or root of template parent chain
|
|
||||||
*
|
|
||||||
* @param int $scope pqrent or root scope
|
|
||||||
*
|
|
||||||
* @return mixed object
|
|
||||||
*/
|
|
||||||
public function getScopePointer($scope)
|
|
||||||
{
|
|
||||||
if ($scope == Smarty::SCOPE_PARENT && !empty($this->parent)) {
|
|
||||||
return $this->parent;
|
|
||||||
} elseif ($scope == Smarty::SCOPE_ROOT && !empty($this->parent)) {
|
|
||||||
$ptr = $this->parent;
|
|
||||||
while (!empty($ptr->parent)) {
|
|
||||||
$ptr = $ptr->parent;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $ptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* [util function] counts an array, arrayaccess/traversable or PDOStatement object
|
|
||||||
*
|
|
||||||
* @param mixed $value
|
|
||||||
*
|
|
||||||
* @return int the count for arrays and objects that implement countable, 1 for other objects that don't, and 0 for empty elements
|
|
||||||
*/
|
|
||||||
public function _count($value)
|
|
||||||
{
|
|
||||||
if (is_array($value) === true || $value instanceof Countable) {
|
|
||||||
return count($value);
|
|
||||||
} elseif ($value instanceof IteratorAggregate) {
|
|
||||||
// Note: getIterator() returns a Traversable, not an Iterator
|
|
||||||
// thus rewind() and valid() methods may not be present
|
|
||||||
return iterator_count($value->getIterator());
|
|
||||||
} elseif ($value instanceof Iterator) {
|
|
||||||
return iterator_count($value);
|
|
||||||
} elseif ($value instanceof PDOStatement) {
|
|
||||||
return $value->rowCount();
|
|
||||||
} elseif ($value instanceof Traversable) {
|
|
||||||
return iterator_count($value);
|
|
||||||
} elseif ($value instanceof ArrayAccess) {
|
|
||||||
if ($value->offsetExists(0)) {
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
} elseif (is_object($value)) {
|
|
||||||
return count($value);
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* runtime error not matching capture tags
|
|
||||||
|
|
||||||
*/
|
|
||||||
public function capture_error()
|
|
||||||
{
|
|
||||||
throw new SmartyException("Not matching {capture} open/close in \"{$this->template_resource}\"");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Empty cache for this template
|
|
||||||
*
|
|
||||||
* @param integer $exp_time expiration time
|
|
||||||
*
|
|
||||||
* @return integer number of cache files deleted
|
|
||||||
*/
|
|
||||||
public function clearCache($exp_time = null)
|
|
||||||
{
|
|
||||||
Smarty_CacheResource::invalidLoadedCache($this->smarty);
|
|
||||||
|
|
||||||
return $this->cached->handler->clear($this->smarty, $this->template_name, $this->cache_id, $this->compile_id, $exp_time);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* set Smarty property in template context
|
|
||||||
*
|
|
||||||
* @param string $property_name property name
|
|
||||||
* @param mixed $value value
|
|
||||||
*
|
|
||||||
* @throws SmartyException
|
|
||||||
*/
|
|
||||||
public function __set($property_name, $value)
|
|
||||||
{
|
|
||||||
switch ($property_name) {
|
|
||||||
case 'source':
|
|
||||||
case 'compiled':
|
|
||||||
case 'cached':
|
|
||||||
case 'compiler':
|
|
||||||
$this->$property_name = $value;
|
|
||||||
|
|
||||||
return;
|
|
||||||
|
|
||||||
// FIXME: routing of template -> smarty attributes
|
|
||||||
default:
|
|
||||||
if (property_exists($this->smarty, $property_name)) {
|
|
||||||
$this->smarty->$property_name = $value;
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
throw new SmartyException("invalid template property '$property_name'.");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* get Smarty property in template context
|
|
||||||
*
|
|
||||||
* @param string $property_name property name
|
|
||||||
*
|
|
||||||
* @throws SmartyException
|
|
||||||
*/
|
|
||||||
public function __get($property_name)
|
|
||||||
{
|
|
||||||
switch ($property_name) {
|
|
||||||
case 'source':
|
|
||||||
if (strlen($this->template_resource) == 0) {
|
|
||||||
throw new SmartyException('Missing template name');
|
|
||||||
}
|
|
||||||
$this->source = Smarty_Resource::source($this);
|
|
||||||
// cache template object under a unique ID
|
|
||||||
// do not cache eval resources
|
|
||||||
if ($this->source->type != 'eval') {
|
|
||||||
if ($this->smarty->allow_ambiguous_resources) {
|
|
||||||
$_templateId = $this->source->unique_resource . $this->cache_id . $this->compile_id;
|
|
||||||
} else {
|
|
||||||
$_templateId = $this->smarty->joined_template_dir . '#' . $this->template_resource . $this->cache_id . $this->compile_id;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isset($_templateId[150])) {
|
|
||||||
$_templateId = sha1($_templateId);
|
|
||||||
}
|
|
||||||
$this->smarty->template_objects[$_templateId] = $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->source;
|
|
||||||
|
|
||||||
case 'compiled':
|
|
||||||
$this->compiled = $this->source->getCompiled($this);
|
|
||||||
|
|
||||||
return $this->compiled;
|
|
||||||
|
|
||||||
case 'cached':
|
|
||||||
if (!class_exists('Smarty_Template_Cached')) {
|
|
||||||
include SMARTY_SYSPLUGINS_DIR . 'smarty_cacheresource.php';
|
|
||||||
}
|
|
||||||
$this->cached = new Smarty_Template_Cached($this);
|
|
||||||
|
|
||||||
return $this->cached;
|
|
||||||
|
|
||||||
case 'compiler':
|
|
||||||
$this->smarty->loadPlugin($this->source->compiler_class);
|
|
||||||
$this->compiler = new $this->source->compiler_class($this->source->template_lexer_class, $this->source->template_parser_class, $this->smarty);
|
|
||||||
|
|
||||||
return $this->compiler;
|
|
||||||
|
|
||||||
// FIXME: routing of template -> smarty attributes
|
|
||||||
default:
|
|
||||||
if (property_exists($this->smarty, $property_name)) {
|
|
||||||
return $this->smarty->$property_name;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
throw new SmartyException("template property '$property_name' does not exist.");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Template data object destructor
|
|
||||||
|
|
||||||
*/
|
|
||||||
public function __destruct()
|
|
||||||
{
|
|
||||||
if ($this->smarty->cache_locking && isset($this->cached) && $this->cached->is_locked) {
|
|
||||||
$this->cached->handler->releaseLock($this->smarty, $this->cached);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,860 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Smarty Template Base
|
|
||||||
* This file contains the basic shared methods for template handling
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Template
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class with shared template methods
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Template
|
|
||||||
*/
|
|
||||||
abstract class Smarty_Internal_TemplateBase extends Smarty_Internal_Data
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* fetches a rendered Smarty template
|
|
||||||
*
|
|
||||||
* @param string $template the resource handle of the template file or template object
|
|
||||||
* @param mixed $cache_id cache id to be used with this template
|
|
||||||
* @param mixed $compile_id compile id to be used with this template
|
|
||||||
* @param object $parent next higher level of Smarty variables
|
|
||||||
* @param bool $display true: display, false: fetch
|
|
||||||
* @param bool $merge_tpl_vars if true parent template variables merged in to local scope
|
|
||||||
* @param bool $no_output_filter if true do not run output filter
|
|
||||||
*
|
|
||||||
* @throws Exception
|
|
||||||
* @throws SmartyException
|
|
||||||
* @return string rendered template output
|
|
||||||
*/
|
|
||||||
public function fetch($template = null, $cache_id = null, $compile_id = null, $parent = null, $display = false, $merge_tpl_vars = true, $no_output_filter = false)
|
|
||||||
{
|
|
||||||
if ($template === null && $this instanceof $this->template_class) {
|
|
||||||
$template = $this;
|
|
||||||
}
|
|
||||||
if ($cache_id !== null && is_object($cache_id)) {
|
|
||||||
$parent = $cache_id;
|
|
||||||
$cache_id = null;
|
|
||||||
}
|
|
||||||
if ($parent === null && ($this instanceof Smarty || is_string($template))) {
|
|
||||||
$parent = $this;
|
|
||||||
}
|
|
||||||
// create template object if necessary
|
|
||||||
$_template = ($template instanceof $this->template_class)
|
|
||||||
? $template
|
|
||||||
: $this->smarty->createTemplate($template, $cache_id, $compile_id, $parent, false);
|
|
||||||
// if called by Smarty object make sure we use current caching status
|
|
||||||
if ($this instanceof Smarty) {
|
|
||||||
$_template->caching = $this->caching;
|
|
||||||
}
|
|
||||||
// merge all variable scopes into template
|
|
||||||
if ($merge_tpl_vars) {
|
|
||||||
// save local variables
|
|
||||||
$save_tpl_vars = $_template->tpl_vars;
|
|
||||||
$save_config_vars = $_template->config_vars;
|
|
||||||
$ptr_array = array($_template);
|
|
||||||
$ptr = $_template;
|
|
||||||
while (isset($ptr->parent)) {
|
|
||||||
$ptr_array[] = $ptr = $ptr->parent;
|
|
||||||
}
|
|
||||||
$ptr_array = array_reverse($ptr_array);
|
|
||||||
$parent_ptr = reset($ptr_array);
|
|
||||||
$tpl_vars = $parent_ptr->tpl_vars;
|
|
||||||
$config_vars = $parent_ptr->config_vars;
|
|
||||||
while ($parent_ptr = next($ptr_array)) {
|
|
||||||
if (!empty($parent_ptr->tpl_vars)) {
|
|
||||||
$tpl_vars = array_merge($tpl_vars, $parent_ptr->tpl_vars);
|
|
||||||
}
|
|
||||||
if (!empty($parent_ptr->config_vars)) {
|
|
||||||
$config_vars = array_merge($config_vars, $parent_ptr->config_vars);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!empty(Smarty::$global_tpl_vars)) {
|
|
||||||
$tpl_vars = array_merge(Smarty::$global_tpl_vars, $tpl_vars);
|
|
||||||
}
|
|
||||||
$_template->tpl_vars = $tpl_vars;
|
|
||||||
$_template->config_vars = $config_vars;
|
|
||||||
}
|
|
||||||
// dummy local smarty variable
|
|
||||||
if (!isset($_template->tpl_vars['smarty'])) {
|
|
||||||
$_template->tpl_vars['smarty'] = new Smarty_Variable;
|
|
||||||
}
|
|
||||||
if (isset($this->smarty->error_reporting)) {
|
|
||||||
$_smarty_old_error_level = error_reporting($this->smarty->error_reporting);
|
|
||||||
}
|
|
||||||
// check URL debugging control
|
|
||||||
if (!$this->smarty->debugging && $this->smarty->debugging_ctrl == 'URL') {
|
|
||||||
if (isset($_SERVER['QUERY_STRING'])) {
|
|
||||||
$_query_string = $_SERVER['QUERY_STRING'];
|
|
||||||
} else {
|
|
||||||
$_query_string = '';
|
|
||||||
}
|
|
||||||
if (false !== strpos($_query_string, $this->smarty->smarty_debug_id)) {
|
|
||||||
if (false !== strpos($_query_string, $this->smarty->smarty_debug_id . '=on')) {
|
|
||||||
// enable debugging for this browser session
|
|
||||||
setcookie('SMARTY_DEBUG', true);
|
|
||||||
$this->smarty->debugging = true;
|
|
||||||
} elseif (false !== strpos($_query_string, $this->smarty->smarty_debug_id . '=off')) {
|
|
||||||
// disable debugging for this browser session
|
|
||||||
setcookie('SMARTY_DEBUG', false);
|
|
||||||
$this->smarty->debugging = false;
|
|
||||||
} else {
|
|
||||||
// enable debugging for this page
|
|
||||||
$this->smarty->debugging = true;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (isset($_COOKIE['SMARTY_DEBUG'])) {
|
|
||||||
$this->smarty->debugging = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// must reset merge template date
|
|
||||||
$_template->smarty->merged_templates_func = array();
|
|
||||||
// get rendered template
|
|
||||||
// disable caching for evaluated code
|
|
||||||
if ($_template->source->recompiled) {
|
|
||||||
$_template->caching = false;
|
|
||||||
}
|
|
||||||
// checks if template exists
|
|
||||||
if (!$_template->source->exists) {
|
|
||||||
if ($_template->parent instanceof Smarty_Internal_Template) {
|
|
||||||
$parent_resource = " in '{$_template->parent->template_resource}'";
|
|
||||||
} else {
|
|
||||||
$parent_resource = '';
|
|
||||||
}
|
|
||||||
throw new SmartyException("Unable to load template {$_template->source->type} '{$_template->source->name}'{$parent_resource}");
|
|
||||||
}
|
|
||||||
// read from cache or render
|
|
||||||
if (!($_template->caching == Smarty::CACHING_LIFETIME_CURRENT || $_template->caching == Smarty::CACHING_LIFETIME_SAVED) || !$_template->cached->valid) {
|
|
||||||
// render template (not loaded and not in cache)
|
|
||||||
if (!$_template->source->uncompiled) {
|
|
||||||
/** @var Smarty_Internal_Template $_smarty_tpl
|
|
||||||
* used in evaluated code
|
|
||||||
*/
|
|
||||||
$_smarty_tpl = $_template;
|
|
||||||
if ($_template->source->recompiled) {
|
|
||||||
$code = $_template->compiler->compileTemplate($_template);
|
|
||||||
if ($this->smarty->debugging) {
|
|
||||||
Smarty_Internal_Debug::start_render($_template);
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
ob_start();
|
|
||||||
eval("?>" . $code);
|
|
||||||
unset($code);
|
|
||||||
}
|
|
||||||
catch (Exception $e) {
|
|
||||||
ob_get_clean();
|
|
||||||
throw $e;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (!$_template->compiled->exists || ($_template->smarty->force_compile && !$_template->compiled->isCompiled)) {
|
|
||||||
$_template->compileTemplateSource();
|
|
||||||
$code = file_get_contents($_template->compiled->filepath);
|
|
||||||
eval("?>" . $code);
|
|
||||||
unset($code);
|
|
||||||
$_template->compiled->loaded = true;
|
|
||||||
$_template->compiled->isCompiled = true;
|
|
||||||
}
|
|
||||||
if ($this->smarty->debugging) {
|
|
||||||
Smarty_Internal_Debug::start_render($_template);
|
|
||||||
}
|
|
||||||
if (!$_template->compiled->loaded) {
|
|
||||||
include($_template->compiled->filepath);
|
|
||||||
if ($_template->mustCompile) {
|
|
||||||
// recompile and load again
|
|
||||||
$_template->compileTemplateSource();
|
|
||||||
$code = file_get_contents($_template->compiled->filepath);
|
|
||||||
eval("?>" . $code);
|
|
||||||
unset($code);
|
|
||||||
$_template->compiled->isCompiled = true;
|
|
||||||
}
|
|
||||||
$_template->compiled->loaded = true;
|
|
||||||
} else {
|
|
||||||
$_template->decodeProperties($_template->compiled->_properties, false);
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
ob_start();
|
|
||||||
if (empty($_template->properties['unifunc']) || !is_callable($_template->properties['unifunc'])) {
|
|
||||||
throw new SmartyException("Invalid compiled template for '{$_template->template_resource}'");
|
|
||||||
}
|
|
||||||
array_unshift($_template->_capture_stack, array());
|
|
||||||
//
|
|
||||||
// render compiled template
|
|
||||||
//
|
|
||||||
$_template->properties['unifunc']($_template);
|
|
||||||
// any unclosed {capture} tags ?
|
|
||||||
if (isset($_template->_capture_stack[0][0])) {
|
|
||||||
$_template->capture_error();
|
|
||||||
}
|
|
||||||
array_shift($_template->_capture_stack);
|
|
||||||
}
|
|
||||||
catch (Exception $e) {
|
|
||||||
ob_get_clean();
|
|
||||||
throw $e;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if ($_template->source->uncompiled) {
|
|
||||||
if ($this->smarty->debugging) {
|
|
||||||
Smarty_Internal_Debug::start_render($_template);
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
ob_start();
|
|
||||||
$_template->source->renderUncompiled($_template);
|
|
||||||
}
|
|
||||||
catch (Exception $e) {
|
|
||||||
ob_get_clean();
|
|
||||||
throw $e;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
throw new SmartyException("Resource '$_template->source->type' must have 'renderUncompiled' method");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$_output = ob_get_clean();
|
|
||||||
if (!$_template->source->recompiled && empty($_template->properties['file_dependency'][$_template->source->uid])) {
|
|
||||||
$_template->properties['file_dependency'][$_template->source->uid] = array($_template->source->filepath, $_template->source->timestamp, $_template->source->type);
|
|
||||||
}
|
|
||||||
if ($_template->parent instanceof Smarty_Internal_Template) {
|
|
||||||
$_template->parent->properties['file_dependency'] = array_merge($_template->parent->properties['file_dependency'], $_template->properties['file_dependency']);
|
|
||||||
foreach ($_template->required_plugins as $code => $tmp1) {
|
|
||||||
foreach ($tmp1 as $name => $tmp) {
|
|
||||||
foreach ($tmp as $type => $data) {
|
|
||||||
$_template->parent->required_plugins[$code][$name][$type] = $data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($this->smarty->debugging) {
|
|
||||||
Smarty_Internal_Debug::end_render($_template);
|
|
||||||
}
|
|
||||||
// write to cache when nessecary
|
|
||||||
if (!$_template->source->recompiled && ($_template->caching == Smarty::CACHING_LIFETIME_SAVED || $_template->caching == Smarty::CACHING_LIFETIME_CURRENT)) {
|
|
||||||
if ($this->smarty->debugging) {
|
|
||||||
Smarty_Internal_Debug::start_cache($_template);
|
|
||||||
}
|
|
||||||
$_template->properties['has_nocache_code'] = false;
|
|
||||||
// get text between non-cached items
|
|
||||||
$cache_split = preg_split("!/\*%%SmartyNocache:{$_template->properties['nocache_hash']}%%\*\/(.+?)/\*/%%SmartyNocache:{$_template->properties['nocache_hash']}%%\*/!s", $_output);
|
|
||||||
// get non-cached items
|
|
||||||
preg_match_all("!/\*%%SmartyNocache:{$_template->properties['nocache_hash']}%%\*\/(.+?)/\*/%%SmartyNocache:{$_template->properties['nocache_hash']}%%\*/!s", $_output, $cache_parts);
|
|
||||||
$output = '';
|
|
||||||
// loop over items, stitch back together
|
|
||||||
foreach ($cache_split as $curr_idx => $curr_split) {
|
|
||||||
// escape PHP tags in template content
|
|
||||||
$output .= preg_replace('/(<%|%>|<\?php|<\?|\?>|<script\s+language\s*=\s*[\"\']?\s*php\s*[\"\']?\s*>)/', "<?php echo '\$1'; ?>\n", $curr_split);
|
|
||||||
if (isset($cache_parts[0][$curr_idx])) {
|
|
||||||
$_template->properties['has_nocache_code'] = true;
|
|
||||||
// remove nocache tags from cache output
|
|
||||||
$output .= preg_replace("!/\*/?%%SmartyNocache:{$_template->properties['nocache_hash']}%%\*/!", '', $cache_parts[0][$curr_idx]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!$no_output_filter && !$_template->has_nocache_code && (isset($this->smarty->autoload_filters['output']) || isset($this->smarty->registered_filters['output']))) {
|
|
||||||
$output = Smarty_Internal_Filter_Handler::runFilter('output', $output, $_template);
|
|
||||||
}
|
|
||||||
// rendering (must be done before writing cache file because of {function} nocache handling)
|
|
||||||
/** @var Smarty_Internal_Template $_smarty_tpl
|
|
||||||
* used in evaluated code
|
|
||||||
*/
|
|
||||||
$_smarty_tpl = $_template;
|
|
||||||
try {
|
|
||||||
ob_start();
|
|
||||||
eval("?>" . $output);
|
|
||||||
$_output = ob_get_clean();
|
|
||||||
}
|
|
||||||
catch (Exception $e) {
|
|
||||||
ob_get_clean();
|
|
||||||
throw $e;
|
|
||||||
}
|
|
||||||
// write cache file content
|
|
||||||
$_template->writeCachedContent($output);
|
|
||||||
if ($this->smarty->debugging) {
|
|
||||||
Smarty_Internal_Debug::end_cache($_template);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// var_dump('renderTemplate', $_template->has_nocache_code, $_template->template_resource, $_template->properties['nocache_hash'], $_template->parent->properties['nocache_hash'], $_output);
|
|
||||||
if (!empty($_template->properties['nocache_hash']) && !empty($_template->parent->properties['nocache_hash'])) {
|
|
||||||
// replace nocache_hash
|
|
||||||
$_output = str_replace("{$_template->properties['nocache_hash']}", $_template->parent->properties['nocache_hash'], $_output);
|
|
||||||
$_template->parent->has_nocache_code = $_template->parent->has_nocache_code || $_template->has_nocache_code;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if ($this->smarty->debugging) {
|
|
||||||
Smarty_Internal_Debug::start_cache($_template);
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
ob_start();
|
|
||||||
array_unshift($_template->_capture_stack, array());
|
|
||||||
//
|
|
||||||
// render cached template
|
|
||||||
//
|
|
||||||
$_template->properties['unifunc']($_template);
|
|
||||||
// any unclosed {capture} tags ?
|
|
||||||
if (isset($_template->_capture_stack[0][0])) {
|
|
||||||
$_template->capture_error();
|
|
||||||
}
|
|
||||||
array_shift($_template->_capture_stack);
|
|
||||||
$_output = ob_get_clean();
|
|
||||||
}
|
|
||||||
catch (Exception $e) {
|
|
||||||
ob_get_clean();
|
|
||||||
throw $e;
|
|
||||||
}
|
|
||||||
if ($this->smarty->debugging) {
|
|
||||||
Smarty_Internal_Debug::end_cache($_template);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ((!$this->caching || $_template->has_nocache_code || $_template->source->recompiled) && !$no_output_filter && (isset($this->smarty->autoload_filters['output']) || isset($this->smarty->registered_filters['output']))) {
|
|
||||||
$_output = Smarty_Internal_Filter_Handler::runFilter('output', $_output, $_template);
|
|
||||||
}
|
|
||||||
if (isset($this->error_reporting)) {
|
|
||||||
error_reporting($_smarty_old_error_level);
|
|
||||||
}
|
|
||||||
// display or fetch
|
|
||||||
if ($display) {
|
|
||||||
if ($this->caching && $this->cache_modified_check) {
|
|
||||||
$_isCached = $_template->isCached() && !$_template->has_nocache_code;
|
|
||||||
$_last_modified_date = @substr($_SERVER['HTTP_IF_MODIFIED_SINCE'], 0, strpos($_SERVER['HTTP_IF_MODIFIED_SINCE'], 'GMT') + 3);
|
|
||||||
if ($_isCached && $_template->cached->timestamp <= strtotime($_last_modified_date)) {
|
|
||||||
switch (PHP_SAPI) {
|
|
||||||
case 'cgi': // php-cgi < 5.3
|
|
||||||
case 'cgi-fcgi': // php-cgi >= 5.3
|
|
||||||
case 'fpm-fcgi': // php-fpm >= 5.3.3
|
|
||||||
header('Status: 304 Not Modified');
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'cli':
|
|
||||||
if ( /* ^phpunit */
|
|
||||||
!empty($_SERVER['SMARTY_PHPUNIT_DISABLE_HEADERS']) /* phpunit$ */
|
|
||||||
) {
|
|
||||||
$_SERVER['SMARTY_PHPUNIT_HEADERS'][] = '304 Not Modified';
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
header($_SERVER['SERVER_PROTOCOL'] . ' 304 Not Modified');
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
switch (PHP_SAPI) {
|
|
||||||
case 'cli':
|
|
||||||
if ( /* ^phpunit */
|
|
||||||
!empty($_SERVER['SMARTY_PHPUNIT_DISABLE_HEADERS']) /* phpunit$ */
|
|
||||||
) {
|
|
||||||
$_SERVER['SMARTY_PHPUNIT_HEADERS'][] = 'Last-Modified: ' . gmdate('D, d M Y H:i:s', $_template->cached->timestamp) . ' GMT';
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
header('Last-Modified: ' . gmdate('D, d M Y H:i:s', $_template->cached->timestamp) . ' GMT');
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
echo $_output;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
echo $_output;
|
|
||||||
}
|
|
||||||
// debug output
|
|
||||||
if ($this->smarty->debugging) {
|
|
||||||
Smarty_Internal_Debug::display_debug($_template);
|
|
||||||
}
|
|
||||||
if ($merge_tpl_vars) {
|
|
||||||
// restore local variables
|
|
||||||
$_template->tpl_vars = $save_tpl_vars;
|
|
||||||
$_template->config_vars = $save_config_vars;
|
|
||||||
}
|
|
||||||
|
|
||||||
return;
|
|
||||||
} else {
|
|
||||||
if ($merge_tpl_vars) {
|
|
||||||
// restore local variables
|
|
||||||
$_template->tpl_vars = $save_tpl_vars;
|
|
||||||
$_template->config_vars = $save_config_vars;
|
|
||||||
}
|
|
||||||
// return fetched content
|
|
||||||
return $_output;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* displays a Smarty template
|
|
||||||
*
|
|
||||||
* @param string $template the resource handle of the template file or template object
|
|
||||||
* @param mixed $cache_id cache id to be used with this template
|
|
||||||
* @param mixed $compile_id compile id to be used with this template
|
|
||||||
* @param object $parent next higher level of Smarty variables
|
|
||||||
*/
|
|
||||||
public function display($template = null, $cache_id = null, $compile_id = null, $parent = null)
|
|
||||||
{
|
|
||||||
// display template
|
|
||||||
$this->fetch($template, $cache_id, $compile_id, $parent, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* test if cache is valid
|
|
||||||
*
|
|
||||||
* @param string|object $template the resource handle of the template file or template object
|
|
||||||
* @param mixed $cache_id cache id to be used with this template
|
|
||||||
* @param mixed $compile_id compile id to be used with this template
|
|
||||||
* @param object $parent next higher level of Smarty variables
|
|
||||||
*
|
|
||||||
* @return boolean cache status
|
|
||||||
*/
|
|
||||||
public function isCached($template = null, $cache_id = null, $compile_id = null, $parent = null)
|
|
||||||
{
|
|
||||||
if ($template === null && $this instanceof $this->template_class) {
|
|
||||||
return $this->cached->valid;
|
|
||||||
}
|
|
||||||
if (!($template instanceof $this->template_class)) {
|
|
||||||
if ($parent === null) {
|
|
||||||
$parent = $this;
|
|
||||||
}
|
|
||||||
$template = $this->smarty->createTemplate($template, $cache_id, $compile_id, $parent, false);
|
|
||||||
}
|
|
||||||
// return cache status of template
|
|
||||||
return $template->cached->valid;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* creates a data object
|
|
||||||
*
|
|
||||||
* @param object $parent next higher level of Smarty variables
|
|
||||||
*
|
|
||||||
* @returns Smarty_Data data object
|
|
||||||
*/
|
|
||||||
public function createData($parent = null)
|
|
||||||
{
|
|
||||||
return new Smarty_Data($parent, $this);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Registers plugin to be used in templates
|
|
||||||
*
|
|
||||||
* @param string $type plugin type
|
|
||||||
* @param string $tag name of template tag
|
|
||||||
* @param callback $callback PHP callback to register
|
|
||||||
* @param boolean $cacheable if true (default) this fuction is cachable
|
|
||||||
* @param array $cache_attr caching attributes if any
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
* @throws SmartyException when the plugin tag is invalid
|
|
||||||
*/
|
|
||||||
public function registerPlugin($type, $tag, $callback, $cacheable = true, $cache_attr = null)
|
|
||||||
{
|
|
||||||
if (isset($this->smarty->registered_plugins[$type][$tag])) {
|
|
||||||
throw new SmartyException("Plugin tag \"{$tag}\" already registered");
|
|
||||||
} elseif (!is_callable($callback)) {
|
|
||||||
throw new SmartyException("Plugin \"{$tag}\" not callable");
|
|
||||||
} else {
|
|
||||||
$this->smarty->registered_plugins[$type][$tag] = array($callback, (bool) $cacheable, (array) $cache_attr);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Unregister Plugin
|
|
||||||
*
|
|
||||||
* @param string $type of plugin
|
|
||||||
* @param string $tag name of plugin
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function unregisterPlugin($type, $tag)
|
|
||||||
{
|
|
||||||
if (isset($this->smarty->registered_plugins[$type][$tag])) {
|
|
||||||
unset($this->smarty->registered_plugins[$type][$tag]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Registers a resource to fetch a template
|
|
||||||
*
|
|
||||||
* @param string $type name of resource type
|
|
||||||
* @param Smarty_Resource|array $callback or instance of Smarty_Resource, or array of callbacks to handle resource (deprecated)
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function registerResource($type, $callback)
|
|
||||||
{
|
|
||||||
$this->smarty->registered_resources[$type] = $callback instanceof Smarty_Resource ? $callback : array($callback, false);
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Unregisters a resource
|
|
||||||
*
|
|
||||||
* @param string $type name of resource type
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function unregisterResource($type)
|
|
||||||
{
|
|
||||||
if (isset($this->smarty->registered_resources[$type])) {
|
|
||||||
unset($this->smarty->registered_resources[$type]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Registers a cache resource to cache a template's output
|
|
||||||
*
|
|
||||||
* @param string $type name of cache resource type
|
|
||||||
* @param Smarty_CacheResource $callback instance of Smarty_CacheResource to handle output caching
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function registerCacheResource($type, Smarty_CacheResource $callback)
|
|
||||||
{
|
|
||||||
$this->smarty->registered_cache_resources[$type] = $callback;
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Unregisters a cache resource
|
|
||||||
*
|
|
||||||
* @param string $type name of cache resource type
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function unregisterCacheResource($type)
|
|
||||||
{
|
|
||||||
if (isset($this->smarty->registered_cache_resources[$type])) {
|
|
||||||
unset($this->smarty->registered_cache_resources[$type]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Registers object to be used in templates
|
|
||||||
*
|
|
||||||
* @param $object_name
|
|
||||||
* @param object $object_impl the referenced PHP object to register
|
|
||||||
* @param array $allowed list of allowed methods (empty = all)
|
|
||||||
* @param boolean $smarty_args smarty argument format, else traditional
|
|
||||||
* @param array $block_methods list of block-methods
|
|
||||||
*
|
|
||||||
* @throws SmartyException
|
|
||||||
* @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function registerObject($object_name, $object_impl, $allowed = array(), $smarty_args = true, $block_methods = array())
|
|
||||||
{
|
|
||||||
// test if allowed methods callable
|
|
||||||
if (!empty($allowed)) {
|
|
||||||
foreach ((array) $allowed as $method) {
|
|
||||||
if (!is_callable(array($object_impl, $method)) && !property_exists($object_impl, $method)) {
|
|
||||||
throw new SmartyException("Undefined method or property '$method' in registered object");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// test if block methods callable
|
|
||||||
if (!empty($block_methods)) {
|
|
||||||
foreach ((array) $block_methods as $method) {
|
|
||||||
if (!is_callable(array($object_impl, $method))) {
|
|
||||||
throw new SmartyException("Undefined method '$method' in registered object");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// register the object
|
|
||||||
$this->smarty->registered_objects[$object_name] =
|
|
||||||
array($object_impl, (array) $allowed, (boolean) $smarty_args, (array) $block_methods);
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* return a reference to a registered object
|
|
||||||
*
|
|
||||||
* @param string $name object name
|
|
||||||
*
|
|
||||||
* @return object
|
|
||||||
* @throws SmartyException if no such object is found
|
|
||||||
*/
|
|
||||||
public function getRegisteredObject($name)
|
|
||||||
{
|
|
||||||
if (!isset($this->smarty->registered_objects[$name])) {
|
|
||||||
throw new SmartyException("'$name' is not a registered object");
|
|
||||||
}
|
|
||||||
if (!is_object($this->smarty->registered_objects[$name][0])) {
|
|
||||||
throw new SmartyException("registered '$name' is not an object");
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->smarty->registered_objects[$name][0];
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* unregister an object
|
|
||||||
*
|
|
||||||
* @param string $name object name
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function unregisterObject($name)
|
|
||||||
{
|
|
||||||
if (isset($this->smarty->registered_objects[$name])) {
|
|
||||||
unset($this->smarty->registered_objects[$name]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Registers static classes to be used in templates
|
|
||||||
*
|
|
||||||
* @param $class_name
|
|
||||||
* @param string $class_impl the referenced PHP class to register
|
|
||||||
*
|
|
||||||
* @throws SmartyException
|
|
||||||
* @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function registerClass($class_name, $class_impl)
|
|
||||||
{
|
|
||||||
// test if exists
|
|
||||||
if (!class_exists($class_impl)) {
|
|
||||||
throw new SmartyException("Undefined class '$class_impl' in register template class");
|
|
||||||
}
|
|
||||||
// register the class
|
|
||||||
$this->smarty->registered_classes[$class_name] = $class_impl;
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Registers a default plugin handler
|
|
||||||
*
|
|
||||||
* @param callable $callback class/method name
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
* @throws SmartyException if $callback is not callable
|
|
||||||
*/
|
|
||||||
public function registerDefaultPluginHandler($callback)
|
|
||||||
{
|
|
||||||
if (is_callable($callback)) {
|
|
||||||
$this->smarty->default_plugin_handler_func = $callback;
|
|
||||||
} else {
|
|
||||||
throw new SmartyException("Default plugin handler '$callback' not callable");
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Registers a default template handler
|
|
||||||
*
|
|
||||||
* @param callable $callback class/method name
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
* @throws SmartyException if $callback is not callable
|
|
||||||
*/
|
|
||||||
public function registerDefaultTemplateHandler($callback)
|
|
||||||
{
|
|
||||||
if (is_callable($callback)) {
|
|
||||||
$this->smarty->default_template_handler_func = $callback;
|
|
||||||
} else {
|
|
||||||
throw new SmartyException("Default template handler '$callback' not callable");
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Registers a default template handler
|
|
||||||
*
|
|
||||||
* @param callable $callback class/method name
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
* @throws SmartyException if $callback is not callable
|
|
||||||
*/
|
|
||||||
public function registerDefaultConfigHandler($callback)
|
|
||||||
{
|
|
||||||
if (is_callable($callback)) {
|
|
||||||
$this->smarty->default_config_handler_func = $callback;
|
|
||||||
} else {
|
|
||||||
throw new SmartyException("Default config handler '$callback' not callable");
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Registers a filter function
|
|
||||||
*
|
|
||||||
* @param string $type filter type
|
|
||||||
* @param callback $callback
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function registerFilter($type, $callback)
|
|
||||||
{
|
|
||||||
$this->smarty->registered_filters[$type][$this->_get_filter_name($callback)] = $callback;
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Unregisters a filter function
|
|
||||||
*
|
|
||||||
* @param string $type filter type
|
|
||||||
* @param callback $callback
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function unregisterFilter($type, $callback)
|
|
||||||
{
|
|
||||||
$name = $this->_get_filter_name($callback);
|
|
||||||
if (isset($this->smarty->registered_filters[$type][$name])) {
|
|
||||||
unset($this->smarty->registered_filters[$type][$name]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return internal filter name
|
|
||||||
*
|
|
||||||
* @param callback $function_name
|
|
||||||
*
|
|
||||||
* @return string internal filter name
|
|
||||||
*/
|
|
||||||
public function _get_filter_name($function_name)
|
|
||||||
{
|
|
||||||
if (is_array($function_name)) {
|
|
||||||
$_class_name = (is_object($function_name[0]) ?
|
|
||||||
get_class($function_name[0]) : $function_name[0]);
|
|
||||||
|
|
||||||
return $_class_name . '_' . $function_name[1];
|
|
||||||
} else {
|
|
||||||
return $function_name;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* load a filter of specified type and name
|
|
||||||
*
|
|
||||||
* @param string $type filter type
|
|
||||||
* @param string $name filter name
|
|
||||||
*
|
|
||||||
* @throws SmartyException if filter could not be loaded
|
|
||||||
*/
|
|
||||||
public function loadFilter($type, $name)
|
|
||||||
{
|
|
||||||
$_plugin = "smarty_{$type}filter_{$name}";
|
|
||||||
$_filter_name = $_plugin;
|
|
||||||
if ($this->smarty->loadPlugin($_plugin)) {
|
|
||||||
if (class_exists($_plugin, false)) {
|
|
||||||
$_plugin = array($_plugin, 'execute');
|
|
||||||
}
|
|
||||||
if (is_callable($_plugin)) {
|
|
||||||
$this->smarty->registered_filters[$type][$_filter_name] = $_plugin;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
throw new SmartyException("{$type}filter \"{$name}\" not callable");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* unload a filter of specified type and name
|
|
||||||
*
|
|
||||||
* @param string $type filter type
|
|
||||||
* @param string $name filter name
|
|
||||||
*
|
|
||||||
* @return Smarty_Internal_Templatebase current Smarty_Internal_Templatebase (or Smarty or Smarty_Internal_Template) instance for chaining
|
|
||||||
*/
|
|
||||||
public function unloadFilter($type, $name)
|
|
||||||
{
|
|
||||||
$_filter_name = "smarty_{$type}filter_{$name}";
|
|
||||||
if (isset($this->smarty->registered_filters[$type][$_filter_name])) {
|
|
||||||
unset ($this->smarty->registered_filters[$type][$_filter_name]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* preg_replace callback to convert camelcase getter/setter to underscore property names
|
|
||||||
*
|
|
||||||
* @param string $match match string
|
|
||||||
*
|
|
||||||
* @return string replacemant
|
|
||||||
*/
|
|
||||||
private function replaceCamelcase($match)
|
|
||||||
{
|
|
||||||
return "_" . strtolower($match[1]);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Handle unknown class methods
|
|
||||||
*
|
|
||||||
* @param string $name unknown method-name
|
|
||||||
* @param array $args argument array
|
|
||||||
*
|
|
||||||
* @throws SmartyException
|
|
||||||
*/
|
|
||||||
public function __call($name, $args)
|
|
||||||
{
|
|
||||||
static $_prefixes = array('set' => true, 'get' => true);
|
|
||||||
static $_resolved_property_name = array();
|
|
||||||
static $_resolved_property_source = array();
|
|
||||||
|
|
||||||
// method of Smarty object?
|
|
||||||
if (method_exists($this->smarty, $name)) {
|
|
||||||
return call_user_func_array(array($this->smarty, $name), $args);
|
|
||||||
}
|
|
||||||
// see if this is a set/get for a property
|
|
||||||
$first3 = strtolower(substr($name, 0, 3));
|
|
||||||
if (isset($_prefixes[$first3]) && isset($name[3]) && $name[3] !== '_') {
|
|
||||||
if (isset($_resolved_property_name[$name])) {
|
|
||||||
$property_name = $_resolved_property_name[$name];
|
|
||||||
} else {
|
|
||||||
// try to keep case correct for future PHP 6.0 case-sensitive class methods
|
|
||||||
// lcfirst() not available < PHP 5.3.0, so improvise
|
|
||||||
$property_name = strtolower(substr($name, 3, 1)) . substr($name, 4);
|
|
||||||
// convert camel case to underscored name
|
|
||||||
$property_name = preg_replace_callback('/([A-Z])/', array($this, 'replaceCamelcase'), $property_name);
|
|
||||||
$_resolved_property_name[$name] = $property_name;
|
|
||||||
}
|
|
||||||
if (isset($_resolved_property_source[$property_name])) {
|
|
||||||
$_is_this = $_resolved_property_source[$property_name];
|
|
||||||
} else {
|
|
||||||
$_is_this = null;
|
|
||||||
if (property_exists($this, $property_name)) {
|
|
||||||
$_is_this = true;
|
|
||||||
} elseif (property_exists($this->smarty, $property_name)) {
|
|
||||||
$_is_this = false;
|
|
||||||
}
|
|
||||||
$_resolved_property_source[$property_name] = $_is_this;
|
|
||||||
}
|
|
||||||
if ($_is_this) {
|
|
||||||
if ($first3 == 'get') {
|
|
||||||
return $this->$property_name;
|
|
||||||
} else {
|
|
||||||
return $this->$property_name = $args[0];
|
|
||||||
}
|
|
||||||
} elseif ($_is_this === false) {
|
|
||||||
if ($first3 == 'get') {
|
|
||||||
return $this->smarty->$property_name;
|
|
||||||
} else {
|
|
||||||
return $this->smarty->$property_name = $args[0];
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
throw new SmartyException("property '$property_name' does not exist.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($name == 'Smarty') {
|
|
||||||
throw new SmartyException("PHP5 requires you to call __construct() instead of Smarty()");
|
|
||||||
}
|
|
||||||
// must be unknown
|
|
||||||
throw new SmartyException("Call of unknown method '$name'.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,823 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Internal Plugin Smarty Template Compiler Base
|
|
||||||
* This file contains the basic classes and methods for compiling Smarty templates with lexer/parser
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Main abstract compiler class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Compiler
|
|
||||||
*/
|
|
||||||
abstract class Smarty_Internal_TemplateCompilerBase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* hash for nocache sections
|
|
||||||
*
|
|
||||||
* @var mixed
|
|
||||||
*/
|
|
||||||
private $nocache_hash = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* suppress generation of nocache code
|
|
||||||
*
|
|
||||||
* @var bool
|
|
||||||
*/
|
|
||||||
public $suppressNocacheProcessing = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* suppress generation of merged template code
|
|
||||||
*
|
|
||||||
* @var bool
|
|
||||||
*/
|
|
||||||
public $suppressMergedTemplates = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* compile tag objects
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public static $_tag_objects = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* tag stack
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $_tag_stack = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* current template
|
|
||||||
*
|
|
||||||
* @var Smarty_Internal_Template
|
|
||||||
*/
|
|
||||||
public $template = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* merged templates
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $merged_templates = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* sources which must be compiled
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $sources = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* flag that we are inside {block}
|
|
||||||
*
|
|
||||||
* @var bool
|
|
||||||
*/
|
|
||||||
public $inheritance = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* flag when compiling inheritance child template
|
|
||||||
*
|
|
||||||
* @var bool
|
|
||||||
*/
|
|
||||||
public $inheritance_child = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* uid of templates called by {extends} for recursion check
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $extends_uid = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* source line offset for error messages
|
|
||||||
*
|
|
||||||
* @var int
|
|
||||||
*/
|
|
||||||
public $trace_line_offset = 0;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* trace uid
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $trace_uid = '';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* trace file path
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $trace_filepath = '';
|
|
||||||
/**
|
|
||||||
* stack for tracing file and line of nested {block} tags
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $trace_stack = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* plugins loaded by default plugin handler
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $default_handler_plugins = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* saved preprocessed modifier list
|
|
||||||
*
|
|
||||||
* @var mixed
|
|
||||||
*/
|
|
||||||
public $default_modifier_list = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* force compilation of complete template as nocache
|
|
||||||
*
|
|
||||||
* @var boolean
|
|
||||||
*/
|
|
||||||
public $forceNocache = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* suppress Smarty header code in compiled template
|
|
||||||
*
|
|
||||||
* @var bool
|
|
||||||
*/
|
|
||||||
public $suppressHeader = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* suppress template property header code in compiled template
|
|
||||||
*
|
|
||||||
* @var bool
|
|
||||||
*/
|
|
||||||
public $suppressTemplatePropertyHeader = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* suppress pre and post filter
|
|
||||||
*
|
|
||||||
* @var bool
|
|
||||||
*/
|
|
||||||
public $suppressFilter = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* flag if compiled template file shall we written
|
|
||||||
*
|
|
||||||
* @var bool
|
|
||||||
*/
|
|
||||||
public $write_compiled_code = true;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* flag if currently a template function is compiled
|
|
||||||
*
|
|
||||||
* @var bool
|
|
||||||
*/
|
|
||||||
public $compiles_template_function = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* called subfuntions from template function
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $called_functions = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* flags for used modifier plugins
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $modifier_plugins = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* type of already compiled modifier
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $known_modifier_type = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* method to compile a Smarty template
|
|
||||||
*
|
|
||||||
* @param mixed $_content template source
|
|
||||||
*
|
|
||||||
* @return bool true if compiling succeeded, false if it failed
|
|
||||||
*/
|
|
||||||
abstract protected function doCompile($_content);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Initialize compiler
|
|
||||||
*/
|
|
||||||
public function __construct()
|
|
||||||
{
|
|
||||||
$this->nocache_hash = str_replace(array('.', ','), '-', uniqid(rand(), true));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Method to compile a Smarty template
|
|
||||||
*
|
|
||||||
* @param Smarty_Internal_Template $template template object to compile
|
|
||||||
* @param bool $nocache true is shall be compiled in nocache mode
|
|
||||||
*
|
|
||||||
* @return bool true if compiling succeeded, false if it failed
|
|
||||||
*/
|
|
||||||
public function compileTemplate(Smarty_Internal_Template $template, $nocache = false)
|
|
||||||
{
|
|
||||||
if (empty($template->properties['nocache_hash'])) {
|
|
||||||
$template->properties['nocache_hash'] = $this->nocache_hash;
|
|
||||||
} else {
|
|
||||||
$this->nocache_hash = $template->properties['nocache_hash'];
|
|
||||||
}
|
|
||||||
// flag for nochache sections
|
|
||||||
$this->nocache = $nocache;
|
|
||||||
$this->tag_nocache = false;
|
|
||||||
// save template object in compiler class
|
|
||||||
$this->template = $template;
|
|
||||||
// reset has nocache code flag
|
|
||||||
$this->template->has_nocache_code = false;
|
|
||||||
$save_source = $this->template->source;
|
|
||||||
// template header code
|
|
||||||
$template_header = '';
|
|
||||||
if (!$this->suppressHeader) {
|
|
||||||
$template_header .= "<?php /* Smarty version " . Smarty::SMARTY_VERSION . ", created on " . strftime("%Y-%m-%d %H:%M:%S") . "\n";
|
|
||||||
$template_header .= " compiled from \"" . $this->template->source->filepath . "\" */ ?>\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
if (empty($this->template->source->components)) {
|
|
||||||
$this->sources = array($template->source);
|
|
||||||
} else {
|
|
||||||
// we have array of inheritance templates by extends: resource
|
|
||||||
$this->sources = array_reverse($template->source->components);
|
|
||||||
}
|
|
||||||
$loop = 0;
|
|
||||||
// the $this->sources array can get additional elements while compiling by the {extends} tag
|
|
||||||
while ($this->template->source = array_shift($this->sources)) {
|
|
||||||
$this->smarty->_current_file = $this->template->source->filepath;
|
|
||||||
if ($this->smarty->debugging) {
|
|
||||||
Smarty_Internal_Debug::start_compile($this->template);
|
|
||||||
}
|
|
||||||
$no_sources = count($this->sources);
|
|
||||||
if ($loop || $no_sources) {
|
|
||||||
$this->template->properties['file_dependency'][$this->template->source->uid] = array($this->template->source->filepath, $this->template->source->timestamp, $this->template->source->type);
|
|
||||||
}
|
|
||||||
$loop ++;
|
|
||||||
if ($no_sources) {
|
|
||||||
$this->inheritance_child = true;
|
|
||||||
} else {
|
|
||||||
$this->inheritance_child = false;
|
|
||||||
}
|
|
||||||
do {
|
|
||||||
$_compiled_code = '';
|
|
||||||
// flag for aborting current and start recompile
|
|
||||||
$this->abort_and_recompile = false;
|
|
||||||
// get template source
|
|
||||||
$_content = $this->template->source->content;
|
|
||||||
if ($_content != '') {
|
|
||||||
// run prefilter if required
|
|
||||||
if ((isset($this->smarty->autoload_filters['pre']) || isset($this->smarty->registered_filters['pre'])) && !$this->suppressFilter) {
|
|
||||||
$_content = Smarty_Internal_Filter_Handler::runFilter('pre', $_content, $template);
|
|
||||||
}
|
|
||||||
// call compiler
|
|
||||||
$_compiled_code = $this->doCompile($_content);
|
|
||||||
}
|
|
||||||
} while ($this->abort_and_recompile);
|
|
||||||
if ($this->smarty->debugging) {
|
|
||||||
Smarty_Internal_Debug::end_compile($this->template);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// restore source
|
|
||||||
$this->template->source = $save_source;
|
|
||||||
unset($save_source);
|
|
||||||
$this->smarty->_current_file = $this->template->source->filepath;
|
|
||||||
// free memory
|
|
||||||
unset($this->parser->root_buffer, $this->parser->current_buffer, $this->parser, $this->lex, $this->template);
|
|
||||||
self::$_tag_objects = array();
|
|
||||||
// return compiled code to template object
|
|
||||||
$merged_code = '';
|
|
||||||
if (!$this->suppressMergedTemplates && !empty($this->merged_templates)) {
|
|
||||||
foreach ($this->merged_templates as $code) {
|
|
||||||
$merged_code .= $code;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// run postfilter if required on compiled template code
|
|
||||||
if ((isset($this->smarty->autoload_filters['post']) || isset($this->smarty->registered_filters['post'])) && !$this->suppressFilter && $_compiled_code != '') {
|
|
||||||
$_compiled_code = Smarty_Internal_Filter_Handler::runFilter('post', $_compiled_code, $template);
|
|
||||||
}
|
|
||||||
if ($this->suppressTemplatePropertyHeader) {
|
|
||||||
$code = $_compiled_code . $merged_code;
|
|
||||||
} else {
|
|
||||||
$code = $template_header . $template->createTemplateCodeFrame($_compiled_code) . $merged_code;
|
|
||||||
}
|
|
||||||
// unset content because template inheritance could have replace source with parent code
|
|
||||||
unset ($template->source->content);
|
|
||||||
|
|
||||||
return $code;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compile Tag
|
|
||||||
* This is a call back from the lexer/parser
|
|
||||||
* It executes the required compile plugin for the Smarty tag
|
|
||||||
*
|
|
||||||
* @param string $tag tag name
|
|
||||||
* @param array $args array with tag attributes
|
|
||||||
* @param array $parameter array with compilation parameter
|
|
||||||
*
|
|
||||||
* @throws SmartyCompilerException
|
|
||||||
* @throws SmartyException
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function compileTag($tag, $args, $parameter = array())
|
|
||||||
{
|
|
||||||
// $args contains the attributes parsed and compiled by the lexer/parser
|
|
||||||
// assume that tag does compile into code, but creates no HTML output
|
|
||||||
$this->has_code = true;
|
|
||||||
$this->has_output = false;
|
|
||||||
// log tag/attributes
|
|
||||||
if (isset($this->smarty->get_used_tags) && $this->smarty->get_used_tags) {
|
|
||||||
$this->template->used_tags[] = array($tag, $args);
|
|
||||||
}
|
|
||||||
// check nocache option flag
|
|
||||||
if (in_array("'nocache'", $args) || in_array(array('nocache' => 'true'), $args)
|
|
||||||
|| in_array(array('nocache' => '"true"'), $args) || in_array(array('nocache' => "'true'"), $args)
|
|
||||||
) {
|
|
||||||
$this->tag_nocache = true;
|
|
||||||
}
|
|
||||||
// compile the smarty tag (required compile classes to compile the tag are autoloaded)
|
|
||||||
if (($_output = $this->callTagCompiler($tag, $args, $parameter)) === false) {
|
|
||||||
if (isset($this->smarty->template_functions[$tag])) {
|
|
||||||
// template defined by {template} tag
|
|
||||||
$args['_attr']['name'] = "'" . $tag . "'";
|
|
||||||
$_output = $this->callTagCompiler('call', $args, $parameter);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($_output !== false) {
|
|
||||||
if ($_output !== true) {
|
|
||||||
// did we get compiled code
|
|
||||||
if ($this->has_code) {
|
|
||||||
// Does it create output?
|
|
||||||
if ($this->has_output) {
|
|
||||||
$_output .= "\n";
|
|
||||||
}
|
|
||||||
// return compiled code
|
|
||||||
return $_output;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// tag did not produce compiled code
|
|
||||||
return null;
|
|
||||||
} else {
|
|
||||||
// map_named attributes
|
|
||||||
if (isset($args['_attr'])) {
|
|
||||||
foreach ($args['_attr'] as $key => $attribute) {
|
|
||||||
if (is_array($attribute)) {
|
|
||||||
$args = array_merge($args, $attribute);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// not an internal compiler tag
|
|
||||||
if (strlen($tag) < 6 || substr($tag, - 5) != 'close') {
|
|
||||||
// check if tag is a registered object
|
|
||||||
if (isset($this->smarty->registered_objects[$tag]) && isset($parameter['object_method'])) {
|
|
||||||
$method = $parameter['object_method'];
|
|
||||||
if (!in_array($method, $this->smarty->registered_objects[$tag][3]) &&
|
|
||||||
(empty($this->smarty->registered_objects[$tag][1]) || in_array($method, $this->smarty->registered_objects[$tag][1]))
|
|
||||||
) {
|
|
||||||
return $this->callTagCompiler('private_object_function', $args, $parameter, $tag, $method);
|
|
||||||
} elseif (in_array($method, $this->smarty->registered_objects[$tag][3])) {
|
|
||||||
return $this->callTagCompiler('private_object_block_function', $args, $parameter, $tag, $method);
|
|
||||||
} else {
|
|
||||||
// throw exception
|
|
||||||
$this->trigger_template_error('not allowed method "' . $method . '" in registered object "' . $tag . '"', $this->lex->taglineno);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// check if tag is registered
|
|
||||||
foreach (array(Smarty::PLUGIN_COMPILER, Smarty::PLUGIN_FUNCTION, Smarty::PLUGIN_BLOCK) as $plugin_type) {
|
|
||||||
if (isset($this->smarty->registered_plugins[$plugin_type][$tag])) {
|
|
||||||
// if compiler function plugin call it now
|
|
||||||
if ($plugin_type == Smarty::PLUGIN_COMPILER) {
|
|
||||||
$new_args = array();
|
|
||||||
foreach ($args as $key => $mixed) {
|
|
||||||
if (is_array($mixed)) {
|
|
||||||
$new_args = array_merge($new_args, $mixed);
|
|
||||||
} else {
|
|
||||||
$new_args[$key] = $mixed;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!$this->smarty->registered_plugins[$plugin_type][$tag][1]) {
|
|
||||||
$this->tag_nocache = true;
|
|
||||||
}
|
|
||||||
$function = $this->smarty->registered_plugins[$plugin_type][$tag][0];
|
|
||||||
if (!is_array($function)) {
|
|
||||||
return $function($new_args, $this);
|
|
||||||
} elseif (is_object($function[0])) {
|
|
||||||
return $this->smarty->registered_plugins[$plugin_type][$tag][0][0]->$function[1]($new_args, $this);
|
|
||||||
} else {
|
|
||||||
return call_user_func_array($function, array($new_args, $this));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// compile registered function or block function
|
|
||||||
if ($plugin_type == Smarty::PLUGIN_FUNCTION || $plugin_type == Smarty::PLUGIN_BLOCK) {
|
|
||||||
return $this->callTagCompiler('private_registered_' . $plugin_type, $args, $parameter, $tag);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// check plugins from plugins folder
|
|
||||||
foreach ($this->smarty->plugin_search_order as $plugin_type) {
|
|
||||||
if ($plugin_type == Smarty::PLUGIN_COMPILER && $this->smarty->loadPlugin('smarty_compiler_' . $tag) && (!isset($this->smarty->security_policy) || $this->smarty->security_policy->isTrustedTag($tag, $this))) {
|
|
||||||
$plugin = 'smarty_compiler_' . $tag;
|
|
||||||
if (is_callable($plugin)) {
|
|
||||||
// convert arguments format for old compiler plugins
|
|
||||||
$new_args = array();
|
|
||||||
foreach ($args as $key => $mixed) {
|
|
||||||
if (is_array($mixed)) {
|
|
||||||
$new_args = array_merge($new_args, $mixed);
|
|
||||||
} else {
|
|
||||||
$new_args[$key] = $mixed;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $plugin($new_args, $this->smarty);
|
|
||||||
}
|
|
||||||
if (class_exists($plugin, false)) {
|
|
||||||
$plugin_object = new $plugin;
|
|
||||||
if (method_exists($plugin_object, 'compile')) {
|
|
||||||
return $plugin_object->compile($args, $this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
throw new SmartyException("Plugin \"{$tag}\" not callable");
|
|
||||||
} else {
|
|
||||||
if ($function = $this->getPlugin($tag, $plugin_type)) {
|
|
||||||
if (!isset($this->smarty->security_policy) || $this->smarty->security_policy->isTrustedTag($tag, $this)) {
|
|
||||||
return $this->callTagCompiler('private_' . $plugin_type . '_plugin', $args, $parameter, $tag, $function);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (is_callable($this->smarty->default_plugin_handler_func)) {
|
|
||||||
$found = false;
|
|
||||||
// look for already resolved tags
|
|
||||||
foreach ($this->smarty->plugin_search_order as $plugin_type) {
|
|
||||||
if (isset($this->default_handler_plugins[$plugin_type][$tag])) {
|
|
||||||
$found = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!$found) {
|
|
||||||
// call default handler
|
|
||||||
foreach ($this->smarty->plugin_search_order as $plugin_type) {
|
|
||||||
if ($this->getPluginFromDefaultHandler($tag, $plugin_type)) {
|
|
||||||
$found = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($found) {
|
|
||||||
// if compiler function plugin call it now
|
|
||||||
if ($plugin_type == Smarty::PLUGIN_COMPILER) {
|
|
||||||
$new_args = array();
|
|
||||||
foreach ($args as $mixed) {
|
|
||||||
$new_args = array_merge($new_args, $mixed);
|
|
||||||
}
|
|
||||||
$function = $this->default_handler_plugins[$plugin_type][$tag][0];
|
|
||||||
if (!is_array($function)) {
|
|
||||||
return $function($new_args, $this);
|
|
||||||
} elseif (is_object($function[0])) {
|
|
||||||
return $this->default_handler_plugins[$plugin_type][$tag][0][0]->$function[1]($new_args, $this);
|
|
||||||
} else {
|
|
||||||
return call_user_func_array($function, array($new_args, $this));
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return $this->callTagCompiler('private_registered_' . $plugin_type, $args, $parameter, $tag);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// compile closing tag of block function
|
|
||||||
$base_tag = substr($tag, 0, - 5);
|
|
||||||
// check if closing tag is a registered object
|
|
||||||
if (isset($this->smarty->registered_objects[$base_tag]) && isset($parameter['object_method'])) {
|
|
||||||
$method = $parameter['object_method'];
|
|
||||||
if (in_array($method, $this->smarty->registered_objects[$base_tag][3])) {
|
|
||||||
return $this->callTagCompiler('private_object_block_function', $args, $parameter, $tag, $method);
|
|
||||||
} else {
|
|
||||||
// throw exception
|
|
||||||
$this->trigger_template_error('not allowed closing tag method "' . $method . '" in registered object "' . $base_tag . '"', $this->lex->taglineno);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// registered block tag ?
|
|
||||||
if (isset($this->smarty->registered_plugins[Smarty::PLUGIN_BLOCK][$base_tag]) || isset($this->default_handler_plugins[Smarty::PLUGIN_BLOCK][$base_tag])) {
|
|
||||||
return $this->callTagCompiler('private_registered_block', $args, $parameter, $tag);
|
|
||||||
}
|
|
||||||
// block plugin?
|
|
||||||
if ($function = $this->getPlugin($base_tag, Smarty::PLUGIN_BLOCK)) {
|
|
||||||
return $this->callTagCompiler('private_block_plugin', $args, $parameter, $tag, $function);
|
|
||||||
}
|
|
||||||
// registered compiler plugin ?
|
|
||||||
if (isset($this->smarty->registered_plugins[Smarty::PLUGIN_COMPILER][$tag])) {
|
|
||||||
// if compiler function plugin call it now
|
|
||||||
$args = array();
|
|
||||||
if (!$this->smarty->registered_plugins[Smarty::PLUGIN_COMPILER][$tag][1]) {
|
|
||||||
$this->tag_nocache = true;
|
|
||||||
}
|
|
||||||
$function = $this->smarty->registered_plugins[Smarty::PLUGIN_COMPILER][$tag][0];
|
|
||||||
if (!is_array($function)) {
|
|
||||||
return $function($args, $this);
|
|
||||||
} elseif (is_object($function[0])) {
|
|
||||||
return $this->smarty->registered_plugins[Smarty::PLUGIN_COMPILER][$tag][0][0]->$function[1]($args, $this);
|
|
||||||
} else {
|
|
||||||
return call_user_func_array($function, array($args, $this));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($this->smarty->loadPlugin('smarty_compiler_' . $tag)) {
|
|
||||||
$plugin = 'smarty_compiler_' . $tag;
|
|
||||||
if (is_callable($plugin)) {
|
|
||||||
return $plugin($args, $this->smarty);
|
|
||||||
}
|
|
||||||
if (class_exists($plugin, false)) {
|
|
||||||
$plugin_object = new $plugin;
|
|
||||||
if (method_exists($plugin_object, 'compile')) {
|
|
||||||
return $plugin_object->compile($args, $this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
throw new SmartyException("Plugin \"{$tag}\" not callable");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$this->trigger_template_error("unknown tag \"" . $tag . "\"", $this->lex->taglineno);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* lazy loads internal compile plugin for tag and calls the compile method
|
|
||||||
* compile objects cached for reuse.
|
|
||||||
* class name format: Smarty_Internal_Compile_TagName
|
|
||||||
* plugin filename format: Smarty_Internal_Tagname.php
|
|
||||||
*
|
|
||||||
* @param string $tag tag name
|
|
||||||
* @param array $args list of tag attributes
|
|
||||||
* @param mixed $param1 optional parameter
|
|
||||||
* @param mixed $param2 optional parameter
|
|
||||||
* @param mixed $param3 optional parameter
|
|
||||||
*
|
|
||||||
* @return string compiled code
|
|
||||||
*/
|
|
||||||
public function callTagCompiler($tag, $args, $param1 = null, $param2 = null, $param3 = null)
|
|
||||||
{
|
|
||||||
// re-use object if already exists
|
|
||||||
if (isset(self::$_tag_objects[$tag])) {
|
|
||||||
// compile this tag
|
|
||||||
return self::$_tag_objects[$tag]->compile($args, $this, $param1, $param2, $param3);
|
|
||||||
}
|
|
||||||
// lazy load internal compiler plugin
|
|
||||||
$class_name = 'Smarty_Internal_Compile_' . $tag;
|
|
||||||
if ($this->smarty->loadPlugin($class_name)) {
|
|
||||||
// check if tag allowed by security
|
|
||||||
if (!isset($this->smarty->security_policy) || $this->smarty->security_policy->isTrustedTag($tag, $this)) {
|
|
||||||
// use plugin if found
|
|
||||||
self::$_tag_objects[$tag] = new $class_name;
|
|
||||||
// compile this tag
|
|
||||||
return self::$_tag_objects[$tag]->compile($args, $this, $param1, $param2, $param3);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// no internal compile plugin for this tag
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check for plugins and return function name
|
|
||||||
*
|
|
||||||
* @param $plugin_name
|
|
||||||
* @param string $plugin_type type of plugin
|
|
||||||
*
|
|
||||||
* @return string call name of function
|
|
||||||
*/
|
|
||||||
public function getPlugin($plugin_name, $plugin_type)
|
|
||||||
{
|
|
||||||
$function = null;
|
|
||||||
if ($this->template->caching && ($this->nocache || $this->tag_nocache)) {
|
|
||||||
if (isset($this->template->required_plugins['nocache'][$plugin_name][$plugin_type])) {
|
|
||||||
$function = $this->template->required_plugins['nocache'][$plugin_name][$plugin_type]['function'];
|
|
||||||
} elseif (isset($this->template->required_plugins['compiled'][$plugin_name][$plugin_type])) {
|
|
||||||
$this->template->required_plugins['nocache'][$plugin_name][$plugin_type] = $this->template->required_plugins['compiled'][$plugin_name][$plugin_type];
|
|
||||||
$function = $this->template->required_plugins['nocache'][$plugin_name][$plugin_type]['function'];
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (isset($this->template->required_plugins['compiled'][$plugin_name][$plugin_type])) {
|
|
||||||
$function = $this->template->required_plugins['compiled'][$plugin_name][$plugin_type]['function'];
|
|
||||||
} elseif (isset($this->template->required_plugins['nocache'][$plugin_name][$plugin_type])) {
|
|
||||||
$this->template->required_plugins['compiled'][$plugin_name][$plugin_type] = $this->template->required_plugins['nocache'][$plugin_name][$plugin_type];
|
|
||||||
$function = $this->template->required_plugins['compiled'][$plugin_name][$plugin_type]['function'];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (isset($function)) {
|
|
||||||
if ($plugin_type == 'modifier') {
|
|
||||||
$this->modifier_plugins[$plugin_name] = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $function;
|
|
||||||
}
|
|
||||||
// loop through plugin dirs and find the plugin
|
|
||||||
$function = 'smarty_' . $plugin_type . '_' . $plugin_name;
|
|
||||||
$file = $this->smarty->loadPlugin($function, false);
|
|
||||||
|
|
||||||
if (is_string($file)) {
|
|
||||||
if ($this->template->caching && ($this->nocache || $this->tag_nocache)) {
|
|
||||||
$this->template->required_plugins['nocache'][$plugin_name][$plugin_type]['file'] = $file;
|
|
||||||
$this->template->required_plugins['nocache'][$plugin_name][$plugin_type]['function'] = $function;
|
|
||||||
} else {
|
|
||||||
$this->template->required_plugins['compiled'][$plugin_name][$plugin_type]['file'] = $file;
|
|
||||||
$this->template->required_plugins['compiled'][$plugin_name][$plugin_type]['function'] = $function;
|
|
||||||
}
|
|
||||||
if ($plugin_type == 'modifier') {
|
|
||||||
$this->modifier_plugins[$plugin_name] = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $function;
|
|
||||||
}
|
|
||||||
if (is_callable($function)) {
|
|
||||||
// plugin function is defined in the script
|
|
||||||
return $function;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check for plugins by default plugin handler
|
|
||||||
*
|
|
||||||
* @param string $tag name of tag
|
|
||||||
* @param string $plugin_type type of plugin
|
|
||||||
*
|
|
||||||
* @return boolean true if found
|
|
||||||
*/
|
|
||||||
public function getPluginFromDefaultHandler($tag, $plugin_type)
|
|
||||||
{
|
|
||||||
$callback = null;
|
|
||||||
$script = null;
|
|
||||||
$cacheable = true;
|
|
||||||
$result = call_user_func_array(
|
|
||||||
$this->smarty->default_plugin_handler_func, array($tag, $plugin_type, $this->template, &$callback, &$script, &$cacheable)
|
|
||||||
);
|
|
||||||
if ($result) {
|
|
||||||
$this->tag_nocache = $this->tag_nocache || !$cacheable;
|
|
||||||
if ($script !== null) {
|
|
||||||
if (is_file($script)) {
|
|
||||||
if ($this->template->caching && ($this->nocache || $this->tag_nocache)) {
|
|
||||||
$this->template->required_plugins['nocache'][$tag][$plugin_type]['file'] = $script;
|
|
||||||
$this->template->required_plugins['nocache'][$tag][$plugin_type]['function'] = $callback;
|
|
||||||
} else {
|
|
||||||
$this->template->required_plugins['compiled'][$tag][$plugin_type]['file'] = $script;
|
|
||||||
$this->template->required_plugins['compiled'][$tag][$plugin_type]['function'] = $callback;
|
|
||||||
}
|
|
||||||
include_once $script;
|
|
||||||
} else {
|
|
||||||
$this->trigger_template_error("Default plugin handler: Returned script file \"{$script}\" for \"{$tag}\" not found");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!is_string($callback) && !(is_array($callback) && is_string($callback[0]) && is_string($callback[1]))) {
|
|
||||||
$this->trigger_template_error("Default plugin handler: Returned callback for \"{$tag}\" must be a static function name or array of class and function name");
|
|
||||||
}
|
|
||||||
if (is_callable($callback)) {
|
|
||||||
$this->default_handler_plugins[$plugin_type][$tag] = array($callback, true, array());
|
|
||||||
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
$this->trigger_template_error("Default plugin handler: Returned callback for \"{$tag}\" not callable");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Inject inline code for nocache template sections
|
|
||||||
* This method gets the content of each template element from the parser.
|
|
||||||
* If the content is compiled code and it should be not cached the code is injected
|
|
||||||
* into the rendered output.
|
|
||||||
*
|
|
||||||
* @param string $content content of template element
|
|
||||||
* @param boolean $is_code true if content is compiled code
|
|
||||||
*
|
|
||||||
* @return string content
|
|
||||||
*/
|
|
||||||
public function processNocacheCode($content, $is_code)
|
|
||||||
{
|
|
||||||
// If the template is not evaluated and we have a nocache section and or a nocache tag
|
|
||||||
if ($is_code && !empty($content)) {
|
|
||||||
// generate replacement code
|
|
||||||
if ((!($this->template->source->recompiled) || $this->forceNocache) && $this->template->caching && !$this->suppressNocacheProcessing &&
|
|
||||||
($this->nocache || $this->tag_nocache)
|
|
||||||
) {
|
|
||||||
$this->template->has_nocache_code = true;
|
|
||||||
$_output = addcslashes($content, '\'\\');
|
|
||||||
$_output = str_replace("^#^", "'", $_output);
|
|
||||||
$_output = "<?php echo '/*%%SmartyNocache:{$this->nocache_hash}%%*/" . $_output . "/*/%%SmartyNocache:{$this->nocache_hash}%%*/';?>\n";
|
|
||||||
// make sure we include modifier plugins for nocache code
|
|
||||||
foreach ($this->modifier_plugins as $plugin_name => $dummy) {
|
|
||||||
if (isset($this->template->required_plugins['compiled'][$plugin_name]['modifier'])) {
|
|
||||||
$this->template->required_plugins['nocache'][$plugin_name]['modifier'] = $this->template->required_plugins['compiled'][$plugin_name]['modifier'];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$_output = $content;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$_output = $content;
|
|
||||||
}
|
|
||||||
$this->modifier_plugins = array();
|
|
||||||
$this->suppressNocacheProcessing = false;
|
|
||||||
$this->tag_nocache = false;
|
|
||||||
|
|
||||||
return $_output;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* push current file and line offset on stack for tracing {block} source lines
|
|
||||||
*
|
|
||||||
* @param string $file new filename
|
|
||||||
* @param string $uid uid of file
|
|
||||||
* @param int $line line offset to source
|
|
||||||
* @param bool $debug false debug end_compile shall not be called
|
|
||||||
*/
|
|
||||||
public function pushTrace($file, $uid, $line, $debug = true)
|
|
||||||
{
|
|
||||||
if ($this->smarty->debugging && $debug) {
|
|
||||||
Smarty_Internal_Debug::end_compile($this->template);
|
|
||||||
}
|
|
||||||
array_push($this->trace_stack, array($this->smarty->_current_file, $this->trace_filepath, $this->trace_uid, $this->trace_line_offset));
|
|
||||||
$this->trace_filepath = $this->smarty->_current_file = $file;
|
|
||||||
$this->trace_uid = $uid;
|
|
||||||
$this->trace_line_offset = $line;
|
|
||||||
if ($this->smarty->debugging) {
|
|
||||||
Smarty_Internal_Debug::start_compile($this->template);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* restore file and line offset
|
|
||||||
|
|
||||||
*/
|
|
||||||
public function popTrace()
|
|
||||||
{
|
|
||||||
if ($this->smarty->debugging) {
|
|
||||||
Smarty_Internal_Debug::end_compile($this->template);
|
|
||||||
}
|
|
||||||
$r = array_pop($this->trace_stack);
|
|
||||||
$this->smarty->_current_file = $r[0];
|
|
||||||
$this->trace_filepath = $r[1];
|
|
||||||
$this->trace_uid = $r[2];
|
|
||||||
$this->trace_line_offset = $r[3];
|
|
||||||
if ($this->smarty->debugging) {
|
|
||||||
Smarty_Internal_Debug::start_compile($this->template);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* display compiler error messages without dying
|
|
||||||
* If parameter $args is empty it is a parser detected syntax error.
|
|
||||||
* In this case the parser is called to obtain information about expected tokens.
|
|
||||||
* If parameter $args contains a string this is used as error message
|
|
||||||
*
|
|
||||||
* @param string $args individual error message or null
|
|
||||||
* @param string $line line-number
|
|
||||||
*
|
|
||||||
* @throws SmartyCompilerException when an unexpected token is found
|
|
||||||
*/
|
|
||||||
public function trigger_template_error($args = null, $line = null)
|
|
||||||
{
|
|
||||||
// get template source line which has error
|
|
||||||
if (!isset($line)) {
|
|
||||||
$line = $this->lex->line;
|
|
||||||
}
|
|
||||||
// $line += $this->trace_line_offset;
|
|
||||||
$match = preg_split("/\n/", $this->lex->data);
|
|
||||||
$error_text = 'Syntax error in template "' . (empty($this->trace_filepath) ? $this->template->source->filepath : $this->trace_filepath) . '" on line ' . ($line + $this->trace_line_offset) . ' "' . trim(preg_replace('![\t\r\n]+!', ' ', $match[$line - 1])) . '" ';
|
|
||||||
if (isset($args)) {
|
|
||||||
// individual error message
|
|
||||||
$error_text .= $args;
|
|
||||||
} else {
|
|
||||||
// expected token from parser
|
|
||||||
$error_text .= ' - Unexpected "' . $this->lex->value . '"';
|
|
||||||
if (count($this->parser->yy_get_expected_tokens($this->parser->yymajor)) <= 4) {
|
|
||||||
foreach ($this->parser->yy_get_expected_tokens($this->parser->yymajor) as $token) {
|
|
||||||
$exp_token = $this->parser->yyTokenName[$token];
|
|
||||||
if (isset($this->lex->smarty_token_names[$exp_token])) {
|
|
||||||
// token type from lexer
|
|
||||||
$expect[] = '"' . $this->lex->smarty_token_names[$exp_token] . '"';
|
|
||||||
} else {
|
|
||||||
// otherwise internal token name
|
|
||||||
$expect[] = $this->parser->yyTokenName[$token];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$error_text .= ', expected one of: ' . implode(' , ', $expect);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$e = new SmartyCompilerException($error_text);
|
|
||||||
$e->line = $line;
|
|
||||||
$e->source = trim(preg_replace('![\t\r\n]+!', ' ', $match[$line - 1]));
|
|
||||||
$e->desc = $args;
|
|
||||||
$e->template = $this->template->source->filepath;
|
|
||||||
throw $e;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@@ -1,837 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Project: Smarty: the PHP compiling template engine
|
|
||||||
* File: smarty_internal_utility.php
|
|
||||||
* SVN: $Id: $
|
|
||||||
* This library is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU Lesser General Public
|
|
||||||
* License as published by the Free Software Foundation; either
|
|
||||||
* version 2.1 of the License, or (at your option) any later version.
|
|
||||||
* This library 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 GNU
|
|
||||||
* Lesser General Public License for more details.
|
|
||||||
* You should have received a copy of the GNU Lesser General Public
|
|
||||||
* License along with this library; if not, write to the Free Software
|
|
||||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
||||||
* For questions, help, comments, discussion, etc., please join the
|
|
||||||
* Smarty mailing list. Send a blank e-mail to
|
|
||||||
* smarty-discussion-subscribe@googlegroups.com
|
|
||||||
*
|
|
||||||
* @link http://www.smarty.net/
|
|
||||||
* @copyright 2008 New Digital Group, Inc.
|
|
||||||
* @author Monte Ohrt <monte at ohrt dot com>
|
|
||||||
* @author Uwe Tews
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage PluginsInternal
|
|
||||||
* @version 3-SVN$Rev: 3286 $
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Utility class
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Security
|
|
||||||
*/
|
|
||||||
class Smarty_Internal_Utility
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* private constructor to prevent calls creation of new instances
|
|
||||||
*/
|
|
||||||
final private function __construct()
|
|
||||||
{
|
|
||||||
// intentionally left blank
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compile all template files
|
|
||||||
*
|
|
||||||
* @param string $extension template file name extension
|
|
||||||
* @param bool $force_compile force all to recompile
|
|
||||||
* @param int $time_limit set maximum execution time
|
|
||||||
* @param int $max_errors set maximum allowed errors
|
|
||||||
* @param Smarty $smarty Smarty instance
|
|
||||||
*
|
|
||||||
* @return integer number of template files compiled
|
|
||||||
*/
|
|
||||||
public static function compileAllTemplates($extension, $force_compile, $time_limit, $max_errors, Smarty $smarty)
|
|
||||||
{
|
|
||||||
// switch off time limit
|
|
||||||
if (function_exists('set_time_limit')) {
|
|
||||||
@set_time_limit($time_limit);
|
|
||||||
}
|
|
||||||
$smarty->force_compile = $force_compile;
|
|
||||||
$_count = 0;
|
|
||||||
$_error_count = 0;
|
|
||||||
// loop over array of template directories
|
|
||||||
foreach ($smarty->getTemplateDir() as $_dir) {
|
|
||||||
$_compileDirs = new RecursiveDirectoryIterator($_dir);
|
|
||||||
$_compile = new RecursiveIteratorIterator($_compileDirs);
|
|
||||||
foreach ($_compile as $_fileinfo) {
|
|
||||||
$_file = $_fileinfo->getFilename();
|
|
||||||
if (substr(basename($_fileinfo->getPathname()), 0, 1) == '.' || strpos($_file, '.svn') !== false) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (!substr_compare($_file, $extension, - strlen($extension)) == 0) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if ($_fileinfo->getPath() == substr($_dir, 0, - 1)) {
|
|
||||||
$_template_file = $_file;
|
|
||||||
} else {
|
|
||||||
$_template_file = substr($_fileinfo->getPath(), strlen($_dir)) . DS . $_file;
|
|
||||||
}
|
|
||||||
echo '<br>', $_dir, '---', $_template_file;
|
|
||||||
flush();
|
|
||||||
$_start_time = microtime(true);
|
|
||||||
try {
|
|
||||||
$_tpl = $smarty->createTemplate($_template_file, null, null, null, false);
|
|
||||||
if ($_tpl->mustCompile()) {
|
|
||||||
$_tpl->compileTemplateSource();
|
|
||||||
$_count ++;
|
|
||||||
echo ' compiled in ', microtime(true) - $_start_time, ' seconds';
|
|
||||||
flush();
|
|
||||||
} else {
|
|
||||||
echo ' is up to date';
|
|
||||||
flush();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch (Exception $e) {
|
|
||||||
echo 'Error: ', $e->getMessage(), "<br><br>";
|
|
||||||
$_error_count ++;
|
|
||||||
}
|
|
||||||
// free memory
|
|
||||||
$smarty->template_objects = array();
|
|
||||||
$_tpl->smarty->template_objects = array();
|
|
||||||
$_tpl = null;
|
|
||||||
if ($max_errors !== null && $_error_count == $max_errors) {
|
|
||||||
echo '<br><br>too many errors';
|
|
||||||
exit();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $_count;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compile all config files
|
|
||||||
*
|
|
||||||
* @param string $extension config file name extension
|
|
||||||
* @param bool $force_compile force all to recompile
|
|
||||||
* @param int $time_limit set maximum execution time
|
|
||||||
* @param int $max_errors set maximum allowed errors
|
|
||||||
* @param Smarty $smarty Smarty instance
|
|
||||||
*
|
|
||||||
* @return integer number of config files compiled
|
|
||||||
*/
|
|
||||||
public static function compileAllConfig($extension, $force_compile, $time_limit, $max_errors, Smarty $smarty)
|
|
||||||
{
|
|
||||||
// switch off time limit
|
|
||||||
if (function_exists('set_time_limit')) {
|
|
||||||
@set_time_limit($time_limit);
|
|
||||||
}
|
|
||||||
$smarty->force_compile = $force_compile;
|
|
||||||
$_count = 0;
|
|
||||||
$_error_count = 0;
|
|
||||||
// loop over array of template directories
|
|
||||||
foreach ($smarty->getConfigDir() as $_dir) {
|
|
||||||
$_compileDirs = new RecursiveDirectoryIterator($_dir);
|
|
||||||
$_compile = new RecursiveIteratorIterator($_compileDirs);
|
|
||||||
foreach ($_compile as $_fileinfo) {
|
|
||||||
$_file = $_fileinfo->getFilename();
|
|
||||||
if (substr(basename($_fileinfo->getPathname()), 0, 1) == '.' || strpos($_file, '.svn') !== false) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (!substr_compare($_file, $extension, - strlen($extension)) == 0) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if ($_fileinfo->getPath() == substr($_dir, 0, - 1)) {
|
|
||||||
$_config_file = $_file;
|
|
||||||
} else {
|
|
||||||
$_config_file = substr($_fileinfo->getPath(), strlen($_dir)) . DS . $_file;
|
|
||||||
}
|
|
||||||
echo '<br>', $_dir, '---', $_config_file;
|
|
||||||
flush();
|
|
||||||
$_start_time = microtime(true);
|
|
||||||
try {
|
|
||||||
$_config = new Smarty_Internal_Config($_config_file, $smarty);
|
|
||||||
if ($_config->mustCompile()) {
|
|
||||||
$_config->compileConfigSource();
|
|
||||||
$_count ++;
|
|
||||||
echo ' compiled in ', microtime(true) - $_start_time, ' seconds';
|
|
||||||
flush();
|
|
||||||
} else {
|
|
||||||
echo ' is up to date';
|
|
||||||
flush();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch (Exception $e) {
|
|
||||||
echo 'Error: ', $e->getMessage(), "<br><br>";
|
|
||||||
$_error_count ++;
|
|
||||||
}
|
|
||||||
if ($max_errors !== null && $_error_count == $max_errors) {
|
|
||||||
echo '<br><br>too many errors';
|
|
||||||
exit();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $_count;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Delete compiled template file
|
|
||||||
*
|
|
||||||
* @param string $resource_name template name
|
|
||||||
* @param string $compile_id compile id
|
|
||||||
* @param integer $exp_time expiration time
|
|
||||||
* @param Smarty $smarty Smarty instance
|
|
||||||
*
|
|
||||||
* @return integer number of template files deleted
|
|
||||||
*/
|
|
||||||
public static function clearCompiledTemplate($resource_name, $compile_id, $exp_time, Smarty $smarty)
|
|
||||||
{
|
|
||||||
$_compile_dir = realpath($smarty->getCompileDir()) . '/';
|
|
||||||
$_compile_id = isset($compile_id) ? preg_replace('![^\w\|]+!', '_', $compile_id) : null;
|
|
||||||
$_dir_sep = $smarty->use_sub_dirs ? '/' : '^';
|
|
||||||
if (isset($resource_name)) {
|
|
||||||
$_save_stat = $smarty->caching;
|
|
||||||
$smarty->caching = false;
|
|
||||||
$tpl = new $smarty->template_class($resource_name, $smarty);
|
|
||||||
$smarty->caching = $_save_stat;
|
|
||||||
|
|
||||||
// remove from template cache
|
|
||||||
$tpl->source; // have the template registered before unset()
|
|
||||||
if ($smarty->allow_ambiguous_resources) {
|
|
||||||
$_templateId = $tpl->source->unique_resource . $tpl->cache_id . $tpl->compile_id;
|
|
||||||
} else {
|
|
||||||
$_templateId = $smarty->joined_template_dir . '#' . $resource_name . $tpl->cache_id . $tpl->compile_id;
|
|
||||||
}
|
|
||||||
if (isset($_templateId[150])) {
|
|
||||||
$_templateId = sha1($_templateId);
|
|
||||||
}
|
|
||||||
unset($smarty->template_objects[$_templateId]);
|
|
||||||
|
|
||||||
if ($tpl->source->exists) {
|
|
||||||
$_resource_part_1 = basename(str_replace('^', '/', $tpl->compiled->filepath));
|
|
||||||
$_resource_part_1_length = strlen($_resource_part_1);
|
|
||||||
} else {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
$_resource_part_2 = str_replace('.php', '.cache.php', $_resource_part_1);
|
|
||||||
$_resource_part_2_length = strlen($_resource_part_2);
|
|
||||||
}
|
|
||||||
$_dir = $_compile_dir;
|
|
||||||
if ($smarty->use_sub_dirs && isset($_compile_id)) {
|
|
||||||
$_dir .= $_compile_id . $_dir_sep;
|
|
||||||
}
|
|
||||||
if (isset($_compile_id)) {
|
|
||||||
$_compile_id_part = str_replace('\\', '/', $_compile_dir . $_compile_id . $_dir_sep);
|
|
||||||
$_compile_id_part_length = strlen($_compile_id_part);
|
|
||||||
}
|
|
||||||
$_count = 0;
|
|
||||||
try {
|
|
||||||
$_compileDirs = new RecursiveDirectoryIterator($_dir);
|
|
||||||
// NOTE: UnexpectedValueException thrown for PHP >= 5.3
|
|
||||||
}
|
|
||||||
catch (Exception $e) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
$_compile = new RecursiveIteratorIterator($_compileDirs, RecursiveIteratorIterator::CHILD_FIRST);
|
|
||||||
foreach ($_compile as $_file) {
|
|
||||||
if (substr(basename($_file->getPathname()), 0, 1) == '.' || strpos($_file, '.svn') !== false) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
$_filepath = str_replace('\\', '/', (string) $_file);
|
|
||||||
|
|
||||||
if ($_file->isDir()) {
|
|
||||||
if (!$_compile->isDot()) {
|
|
||||||
// delete folder if empty
|
|
||||||
@rmdir($_file->getPathname());
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$unlink = false;
|
|
||||||
if ((!isset($_compile_id) || (isset($_filepath[$_compile_id_part_length]) && $a = !strncmp($_filepath, $_compile_id_part, $_compile_id_part_length)))
|
|
||||||
&& (!isset($resource_name)
|
|
||||||
|| (isset($_filepath[$_resource_part_1_length])
|
|
||||||
&& substr_compare($_filepath, $_resource_part_1, - $_resource_part_1_length, $_resource_part_1_length) == 0)
|
|
||||||
|| (isset($_filepath[$_resource_part_2_length])
|
|
||||||
&& substr_compare($_filepath, $_resource_part_2, - $_resource_part_2_length, $_resource_part_2_length) == 0))
|
|
||||||
) {
|
|
||||||
if (isset($exp_time)) {
|
|
||||||
if (time() - @filemtime($_filepath) >= $exp_time) {
|
|
||||||
$unlink = true;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$unlink = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($unlink && @unlink($_filepath)) {
|
|
||||||
$_count ++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// clear compiled cache
|
|
||||||
Smarty_Resource::$sources = array();
|
|
||||||
Smarty_Resource::$compileds = array();
|
|
||||||
|
|
||||||
return $_count;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return array of tag/attributes of all tags used by an template
|
|
||||||
*
|
|
||||||
* @param Smarty_Internal_Template $template
|
|
||||||
*
|
|
||||||
* @throws Exception
|
|
||||||
* @throws SmartyException
|
|
||||||
* @return array of tag/attributes
|
|
||||||
*/
|
|
||||||
public static function getTags(Smarty_Internal_Template $template)
|
|
||||||
{
|
|
||||||
$template->smarty->get_used_tags = true;
|
|
||||||
$template->compileTemplateSource();
|
|
||||||
|
|
||||||
return $template->used_tags;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* diagnose Smarty setup
|
|
||||||
* If $errors is secified, the diagnostic report will be appended to the array, rather than being output.
|
|
||||||
*
|
|
||||||
* @param Smarty $smarty Smarty instance to test
|
|
||||||
* @param array $errors array to push results into rather than outputting them
|
|
||||||
*
|
|
||||||
* @return bool status, true if everything is fine, false else
|
|
||||||
*/
|
|
||||||
public static function testInstall(Smarty $smarty, &$errors = null)
|
|
||||||
{
|
|
||||||
$status = true;
|
|
||||||
|
|
||||||
if ($errors === null) {
|
|
||||||
echo "<PRE>\n";
|
|
||||||
echo "Smarty Installation test...\n";
|
|
||||||
echo "Testing template directory...\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
$_stream_resolve_include_path = function_exists('stream_resolve_include_path');
|
|
||||||
|
|
||||||
// test if all registered template_dir are accessible
|
|
||||||
foreach ($smarty->getTemplateDir() as $template_dir) {
|
|
||||||
$_template_dir = $template_dir;
|
|
||||||
$template_dir = realpath($template_dir);
|
|
||||||
// resolve include_path or fail existence
|
|
||||||
if (!$template_dir) {
|
|
||||||
if ($smarty->use_include_path && !preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $_template_dir)) {
|
|
||||||
// try PHP include_path
|
|
||||||
if ($_stream_resolve_include_path) {
|
|
||||||
$template_dir = stream_resolve_include_path($_template_dir);
|
|
||||||
} else {
|
|
||||||
$template_dir = Smarty_Internal_Get_Include_Path::getIncludePath($_template_dir);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($template_dir !== false) {
|
|
||||||
if ($errors === null) {
|
|
||||||
echo "$template_dir is OK.\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
continue;
|
|
||||||
} else {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: $_template_dir does not exist (and couldn't be found in include_path either)";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['template_dir'] = $message;
|
|
||||||
}
|
|
||||||
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: $_template_dir does not exist";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['template_dir'] = $message;
|
|
||||||
}
|
|
||||||
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!is_dir($template_dir)) {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: $template_dir is not a directory";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['template_dir'] = $message;
|
|
||||||
}
|
|
||||||
} elseif (!is_readable($template_dir)) {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: $template_dir is not readable";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['template_dir'] = $message;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if ($errors === null) {
|
|
||||||
echo "$template_dir is OK.\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($errors === null) {
|
|
||||||
echo "Testing compile directory...\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
// test if registered compile_dir is accessible
|
|
||||||
$__compile_dir = $smarty->getCompileDir();
|
|
||||||
$_compile_dir = realpath($__compile_dir);
|
|
||||||
if (!$_compile_dir) {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: {$__compile_dir} does not exist";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['compile_dir'] = $message;
|
|
||||||
}
|
|
||||||
} elseif (!is_dir($_compile_dir)) {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: {$_compile_dir} is not a directory";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['compile_dir'] = $message;
|
|
||||||
}
|
|
||||||
} elseif (!is_readable($_compile_dir)) {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: {$_compile_dir} is not readable";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['compile_dir'] = $message;
|
|
||||||
}
|
|
||||||
} elseif (!is_writable($_compile_dir)) {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: {$_compile_dir} is not writable";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['compile_dir'] = $message;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if ($errors === null) {
|
|
||||||
echo "{$_compile_dir} is OK.\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($errors === null) {
|
|
||||||
echo "Testing plugins directory...\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
// test if all registered plugins_dir are accessible
|
|
||||||
// and if core plugins directory is still registered
|
|
||||||
$_core_plugins_dir = realpath(dirname(__FILE__) . '/../plugins');
|
|
||||||
$_core_plugins_available = false;
|
|
||||||
foreach ($smarty->getPluginsDir() as $plugin_dir) {
|
|
||||||
$_plugin_dir = $plugin_dir;
|
|
||||||
$plugin_dir = realpath($plugin_dir);
|
|
||||||
// resolve include_path or fail existence
|
|
||||||
if (!$plugin_dir) {
|
|
||||||
if ($smarty->use_include_path && !preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $_plugin_dir)) {
|
|
||||||
// try PHP include_path
|
|
||||||
if ($_stream_resolve_include_path) {
|
|
||||||
$plugin_dir = stream_resolve_include_path($_plugin_dir);
|
|
||||||
} else {
|
|
||||||
$plugin_dir = Smarty_Internal_Get_Include_Path::getIncludePath($_plugin_dir);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($plugin_dir !== false) {
|
|
||||||
if ($errors === null) {
|
|
||||||
echo "$plugin_dir is OK.\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
continue;
|
|
||||||
} else {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: $_plugin_dir does not exist (and couldn't be found in include_path either)";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['plugins_dir'] = $message;
|
|
||||||
}
|
|
||||||
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: $_plugin_dir does not exist";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['plugins_dir'] = $message;
|
|
||||||
}
|
|
||||||
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!is_dir($plugin_dir)) {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: $plugin_dir is not a directory";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['plugins_dir'] = $message;
|
|
||||||
}
|
|
||||||
} elseif (!is_readable($plugin_dir)) {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: $plugin_dir is not readable";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['plugins_dir'] = $message;
|
|
||||||
}
|
|
||||||
} elseif ($_core_plugins_dir && $_core_plugins_dir == realpath($plugin_dir)) {
|
|
||||||
$_core_plugins_available = true;
|
|
||||||
if ($errors === null) {
|
|
||||||
echo "$plugin_dir is OK.\n";
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if ($errors === null) {
|
|
||||||
echo "$plugin_dir is OK.\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!$_core_plugins_available) {
|
|
||||||
$status = false;
|
|
||||||
$message = "WARNING: Smarty's own libs/plugins is not available";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} elseif (!isset($errors['plugins_dir'])) {
|
|
||||||
$errors['plugins_dir'] = $message;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($errors === null) {
|
|
||||||
echo "Testing cache directory...\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
// test if all registered cache_dir is accessible
|
|
||||||
$__cache_dir = $smarty->getCacheDir();
|
|
||||||
$_cache_dir = realpath($__cache_dir);
|
|
||||||
if (!$_cache_dir) {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: {$__cache_dir} does not exist";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['cache_dir'] = $message;
|
|
||||||
}
|
|
||||||
} elseif (!is_dir($_cache_dir)) {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: {$_cache_dir} is not a directory";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['cache_dir'] = $message;
|
|
||||||
}
|
|
||||||
} elseif (!is_readable($_cache_dir)) {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: {$_cache_dir} is not readable";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['cache_dir'] = $message;
|
|
||||||
}
|
|
||||||
} elseif (!is_writable($_cache_dir)) {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: {$_cache_dir} is not writable";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['cache_dir'] = $message;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if ($errors === null) {
|
|
||||||
echo "{$_cache_dir} is OK.\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($errors === null) {
|
|
||||||
echo "Testing configs directory...\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
// test if all registered config_dir are accessible
|
|
||||||
foreach ($smarty->getConfigDir() as $config_dir) {
|
|
||||||
$_config_dir = $config_dir;
|
|
||||||
$config_dir = realpath($config_dir);
|
|
||||||
// resolve include_path or fail existence
|
|
||||||
if (!$config_dir) {
|
|
||||||
if ($smarty->use_include_path && !preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $_config_dir)) {
|
|
||||||
// try PHP include_path
|
|
||||||
if ($_stream_resolve_include_path) {
|
|
||||||
$config_dir = stream_resolve_include_path($_config_dir);
|
|
||||||
} else {
|
|
||||||
$config_dir = Smarty_Internal_Get_Include_Path::getIncludePath($_config_dir);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($config_dir !== false) {
|
|
||||||
if ($errors === null) {
|
|
||||||
echo "$config_dir is OK.\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
continue;
|
|
||||||
} else {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: $_config_dir does not exist (and couldn't be found in include_path either)";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['config_dir'] = $message;
|
|
||||||
}
|
|
||||||
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: $_config_dir does not exist";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['config_dir'] = $message;
|
|
||||||
}
|
|
||||||
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!is_dir($config_dir)) {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: $config_dir is not a directory";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['config_dir'] = $message;
|
|
||||||
}
|
|
||||||
} elseif (!is_readable($config_dir)) {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: $config_dir is not readable";
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['config_dir'] = $message;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if ($errors === null) {
|
|
||||||
echo "$config_dir is OK.\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($errors === null) {
|
|
||||||
echo "Testing sysplugin files...\n";
|
|
||||||
}
|
|
||||||
// test if sysplugins are available
|
|
||||||
$source = SMARTY_SYSPLUGINS_DIR;
|
|
||||||
if (is_dir($source)) {
|
|
||||||
$expected = array(
|
|
||||||
"smarty_cacheresource.php" => true,
|
|
||||||
"smarty_cacheresource_custom.php" => true,
|
|
||||||
"smarty_cacheresource_keyvaluestore.php" => true,
|
|
||||||
"smarty_config_source.php" => true,
|
|
||||||
"smarty_internal_cacheresource_file.php" => true,
|
|
||||||
"smarty_internal_compile_append.php" => true,
|
|
||||||
"smarty_internal_compile_assign.php" => true,
|
|
||||||
"smarty_internal_compile_block.php" => true,
|
|
||||||
"smarty_internal_compile_break.php" => true,
|
|
||||||
"smarty_internal_compile_call.php" => true,
|
|
||||||
"smarty_internal_compile_capture.php" => true,
|
|
||||||
"smarty_internal_compile_config_load.php" => true,
|
|
||||||
"smarty_internal_compile_continue.php" => true,
|
|
||||||
"smarty_internal_compile_debug.php" => true,
|
|
||||||
"smarty_internal_compile_eval.php" => true,
|
|
||||||
"smarty_internal_compile_extends.php" => true,
|
|
||||||
"smarty_internal_compile_for.php" => true,
|
|
||||||
"smarty_internal_compile_foreach.php" => true,
|
|
||||||
"smarty_internal_compile_function.php" => true,
|
|
||||||
"smarty_internal_compile_if.php" => true,
|
|
||||||
"smarty_internal_compile_include.php" => true,
|
|
||||||
"smarty_internal_compile_include_php.php" => true,
|
|
||||||
"smarty_internal_compile_insert.php" => true,
|
|
||||||
"smarty_internal_compile_ldelim.php" => true,
|
|
||||||
"smarty_internal_compile_nocache.php" => true,
|
|
||||||
"smarty_internal_compile_private_block_plugin.php" => true,
|
|
||||||
"smarty_internal_compile_private_function_plugin.php" => true,
|
|
||||||
"smarty_internal_compile_private_modifier.php" => true,
|
|
||||||
"smarty_internal_compile_private_object_block_function.php" => true,
|
|
||||||
"smarty_internal_compile_private_object_function.php" => true,
|
|
||||||
"smarty_internal_compile_private_print_expression.php" => true,
|
|
||||||
"smarty_internal_compile_private_registered_block.php" => true,
|
|
||||||
"smarty_internal_compile_private_registered_function.php" => true,
|
|
||||||
"smarty_internal_compile_private_special_variable.php" => true,
|
|
||||||
"smarty_internal_compile_rdelim.php" => true,
|
|
||||||
"smarty_internal_compile_section.php" => true,
|
|
||||||
"smarty_internal_compile_setfilter.php" => true,
|
|
||||||
"smarty_internal_compile_while.php" => true,
|
|
||||||
"smarty_internal_compilebase.php" => true,
|
|
||||||
"smarty_internal_config.php" => true,
|
|
||||||
"smarty_internal_config_file_compiler.php" => true,
|
|
||||||
"smarty_internal_configfilelexer.php" => true,
|
|
||||||
"smarty_internal_configfileparser.php" => true,
|
|
||||||
"smarty_internal_data.php" => true,
|
|
||||||
"smarty_internal_debug.php" => true,
|
|
||||||
"smarty_internal_filter_handler.php" => true,
|
|
||||||
"smarty_internal_function_call_handler.php" => true,
|
|
||||||
"smarty_internal_get_include_path.php" => true,
|
|
||||||
"smarty_internal_nocache_insert.php" => true,
|
|
||||||
"smarty_internal_parsetree.php" => true,
|
|
||||||
"smarty_internal_resource_eval.php" => true,
|
|
||||||
"smarty_internal_resource_extends.php" => true,
|
|
||||||
"smarty_internal_resource_file.php" => true,
|
|
||||||
"smarty_internal_resource_registered.php" => true,
|
|
||||||
"smarty_internal_resource_stream.php" => true,
|
|
||||||
"smarty_internal_resource_string.php" => true,
|
|
||||||
"smarty_internal_smartytemplatecompiler.php" => true,
|
|
||||||
"smarty_internal_template.php" => true,
|
|
||||||
"smarty_internal_templatebase.php" => true,
|
|
||||||
"smarty_internal_templatecompilerbase.php" => true,
|
|
||||||
"smarty_internal_templatelexer.php" => true,
|
|
||||||
"smarty_internal_templateparser.php" => true,
|
|
||||||
"smarty_internal_utility.php" => true,
|
|
||||||
"smarty_internal_write_file.php" => true,
|
|
||||||
"smarty_resource.php" => true,
|
|
||||||
"smarty_resource_custom.php" => true,
|
|
||||||
"smarty_resource_recompiled.php" => true,
|
|
||||||
"smarty_resource_uncompiled.php" => true,
|
|
||||||
"smarty_security.php" => true,
|
|
||||||
);
|
|
||||||
$iterator = new DirectoryIterator($source);
|
|
||||||
foreach ($iterator as $file) {
|
|
||||||
if (!$file->isDot()) {
|
|
||||||
$filename = $file->getFilename();
|
|
||||||
if (isset($expected[$filename])) {
|
|
||||||
unset($expected[$filename]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($expected) {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: files missing from libs/sysplugins: " . join(', ', array_keys($expected));
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['sysplugins'] = $message;
|
|
||||||
}
|
|
||||||
} elseif ($errors === null) {
|
|
||||||
echo "... OK\n";
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: " . SMARTY_SYSPLUGINS_DIR . ' is not a directory';
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['sysplugins_dir_constant'] = $message;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($errors === null) {
|
|
||||||
echo "Testing plugin files...\n";
|
|
||||||
}
|
|
||||||
// test if core plugins are available
|
|
||||||
$source = SMARTY_PLUGINS_DIR;
|
|
||||||
if (is_dir($source)) {
|
|
||||||
$expected = array(
|
|
||||||
"block.textformat.php" => true,
|
|
||||||
"function.counter.php" => true,
|
|
||||||
"function.cycle.php" => true,
|
|
||||||
"function.fetch.php" => true,
|
|
||||||
"function.html_checkboxes.php" => true,
|
|
||||||
"function.html_image.php" => true,
|
|
||||||
"function.html_options.php" => true,
|
|
||||||
"function.html_radios.php" => true,
|
|
||||||
"function.html_select_date.php" => true,
|
|
||||||
"function.html_select_time.php" => true,
|
|
||||||
"function.html_table.php" => true,
|
|
||||||
"function.mailto.php" => true,
|
|
||||||
"function.math.php" => true,
|
|
||||||
"modifier.capitalize.php" => true,
|
|
||||||
"modifier.date_format.php" => true,
|
|
||||||
"modifier.debug_print_var.php" => true,
|
|
||||||
"modifier.escape.php" => true,
|
|
||||||
"modifier.regex_replace.php" => true,
|
|
||||||
"modifier.replace.php" => true,
|
|
||||||
"modifier.spacify.php" => true,
|
|
||||||
"modifier.truncate.php" => true,
|
|
||||||
"modifiercompiler.cat.php" => true,
|
|
||||||
"modifiercompiler.count_characters.php" => true,
|
|
||||||
"modifiercompiler.count_paragraphs.php" => true,
|
|
||||||
"modifiercompiler.count_sentences.php" => true,
|
|
||||||
"modifiercompiler.count_words.php" => true,
|
|
||||||
"modifiercompiler.default.php" => true,
|
|
||||||
"modifiercompiler.escape.php" => true,
|
|
||||||
"modifiercompiler.from_charset.php" => true,
|
|
||||||
"modifiercompiler.indent.php" => true,
|
|
||||||
"modifiercompiler.lower.php" => true,
|
|
||||||
"modifiercompiler.noprint.php" => true,
|
|
||||||
"modifiercompiler.string_format.php" => true,
|
|
||||||
"modifiercompiler.strip.php" => true,
|
|
||||||
"modifiercompiler.strip_tags.php" => true,
|
|
||||||
"modifiercompiler.to_charset.php" => true,
|
|
||||||
"modifiercompiler.unescape.php" => true,
|
|
||||||
"modifiercompiler.upper.php" => true,
|
|
||||||
"modifiercompiler.wordwrap.php" => true,
|
|
||||||
"outputfilter.trimwhitespace.php" => true,
|
|
||||||
"shared.escape_special_chars.php" => true,
|
|
||||||
"shared.literal_compiler_param.php" => true,
|
|
||||||
"shared.make_timestamp.php" => true,
|
|
||||||
"shared.mb_str_replace.php" => true,
|
|
||||||
"shared.mb_unicode.php" => true,
|
|
||||||
"shared.mb_wordwrap.php" => true,
|
|
||||||
"variablefilter.htmlspecialchars.php" => true,
|
|
||||||
);
|
|
||||||
$iterator = new DirectoryIterator($source);
|
|
||||||
foreach ($iterator as $file) {
|
|
||||||
if (!$file->isDot()) {
|
|
||||||
$filename = $file->getFilename();
|
|
||||||
if (isset($expected[$filename])) {
|
|
||||||
unset($expected[$filename]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($expected) {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: files missing from libs/plugins: " . join(', ', array_keys($expected));
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['plugins'] = $message;
|
|
||||||
}
|
|
||||||
} elseif ($errors === null) {
|
|
||||||
echo "... OK\n";
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$status = false;
|
|
||||||
$message = "FAILED: " . SMARTY_PLUGINS_DIR . ' is not a directory';
|
|
||||||
if ($errors === null) {
|
|
||||||
echo $message . ".\n";
|
|
||||||
} else {
|
|
||||||
$errors['plugins_dir_constant'] = $message;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($errors === null) {
|
|
||||||
echo "Tests complete.\n";
|
|
||||||
echo "</PRE>\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
return $status;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,912 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Resource Plugin
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage TemplateResources
|
|
||||||
* @author Rodney Rehm
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Resource Plugin
|
|
||||||
* Base implementation for resource plugins
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage TemplateResources
|
|
||||||
*/
|
|
||||||
abstract class Smarty_Resource
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* cache for Smarty_Template_Source instances
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public static $sources = array();
|
|
||||||
/**
|
|
||||||
* cache for Smarty_Template_Compiled instances
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public static $compileds = array();
|
|
||||||
/**
|
|
||||||
* cache for Smarty_Resource instances
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public static $resources = array();
|
|
||||||
/**
|
|
||||||
* resource types provided by the core
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
protected static $sysplugins = array(
|
|
||||||
'file' => true,
|
|
||||||
'string' => true,
|
|
||||||
'extends' => true,
|
|
||||||
'stream' => true,
|
|
||||||
'eval' => true,
|
|
||||||
'php' => true
|
|
||||||
);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Name of the Class to compile this resource's contents with
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $compiler_class = 'Smarty_Internal_SmartyTemplateCompiler';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Name of the Class to tokenize this resource's contents with
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $template_lexer_class = 'Smarty_Internal_Templatelexer';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Name of the Class to parse this resource's contents with
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $template_parser_class = 'Smarty_Internal_Templateparser';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Load template's source into current template object
|
|
||||||
* {@internal The loaded source is assigned to $_template->source->content directly.}}
|
|
||||||
*
|
|
||||||
* @param Smarty_Template_Source $source source object
|
|
||||||
*
|
|
||||||
* @return string template source
|
|
||||||
* @throws SmartyException if source cannot be loaded
|
|
||||||
*/
|
|
||||||
abstract public function getContent(Smarty_Template_Source $source);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* populate Source Object with meta data from Resource
|
|
||||||
*
|
|
||||||
* @param Smarty_Template_Source $source source object
|
|
||||||
* @param Smarty_Internal_Template $_template template object
|
|
||||||
*/
|
|
||||||
abstract public function populate(Smarty_Template_Source $source, Smarty_Internal_Template $_template = null);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* populate Source Object with timestamp and exists from Resource
|
|
||||||
*
|
|
||||||
* @param Smarty_Template_Source $source source object
|
|
||||||
*/
|
|
||||||
public function populateTimestamp(Smarty_Template_Source $source)
|
|
||||||
{
|
|
||||||
// intentionally left blank
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* modify resource_name according to resource handlers specifications
|
|
||||||
*
|
|
||||||
* @param Smarty $smarty Smarty instance
|
|
||||||
* @param string $resource_name resource_name to make unique
|
|
||||||
* @param boolean $is_config flag for config resource
|
|
||||||
*
|
|
||||||
* @return string unique resource name
|
|
||||||
*/
|
|
||||||
protected function buildUniqueResourceName(Smarty $smarty, $resource_name, $is_config = false)
|
|
||||||
{
|
|
||||||
if ($is_config) {
|
|
||||||
return get_class($this) . '#' . $smarty->joined_config_dir . '#' . $resource_name;
|
|
||||||
} else {
|
|
||||||
return get_class($this) . '#' . $smarty->joined_template_dir . '#' . $resource_name;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* populate Compiled Object with compiled filepath
|
|
||||||
*
|
|
||||||
* @param Smarty_Template_Compiled $compiled compiled object
|
|
||||||
* @param Smarty_Internal_Template $_template template object
|
|
||||||
*/
|
|
||||||
public function populateCompiledFilepath(Smarty_Template_Compiled $compiled, Smarty_Internal_Template $_template)
|
|
||||||
{
|
|
||||||
$_compile_id = isset($_template->compile_id) ? preg_replace('![^\w\|]+!', '_', $_template->compile_id) : null;
|
|
||||||
$_filepath = $compiled->source->uid;
|
|
||||||
// if use_sub_dirs, break file into directories
|
|
||||||
if ($_template->smarty->use_sub_dirs) {
|
|
||||||
$_filepath = substr($_filepath, 0, 2) . DS
|
|
||||||
. substr($_filepath, 2, 2) . DS
|
|
||||||
. substr($_filepath, 4, 2) . DS
|
|
||||||
. $_filepath;
|
|
||||||
}
|
|
||||||
$_compile_dir_sep = $_template->smarty->use_sub_dirs ? DS : '^';
|
|
||||||
if (isset($_compile_id)) {
|
|
||||||
$_filepath = $_compile_id . $_compile_dir_sep . $_filepath;
|
|
||||||
}
|
|
||||||
// caching token
|
|
||||||
if ($_template->caching) {
|
|
||||||
$_cache = '.cache';
|
|
||||||
} else {
|
|
||||||
$_cache = '';
|
|
||||||
}
|
|
||||||
$_compile_dir = $_template->smarty->getCompileDir();
|
|
||||||
// set basename if not specified
|
|
||||||
$_basename = $this->getBasename($compiled->source);
|
|
||||||
if ($_basename === null) {
|
|
||||||
$_basename = basename(preg_replace('![^\w\/]+!', '_', $compiled->source->name));
|
|
||||||
}
|
|
||||||
// separate (optional) basename by dot
|
|
||||||
if ($_basename) {
|
|
||||||
$_basename = '.' . $_basename;
|
|
||||||
}
|
|
||||||
|
|
||||||
$compiled->filepath = $_compile_dir . $_filepath . '.' . $compiled->source->type . $_basename . $_cache . '.php';
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Normalize Paths "foo/../bar" to "bar"
|
|
||||||
*
|
|
||||||
* @param string $_path path to normalize
|
|
||||||
* @param boolean $ds respect windows directory separator
|
|
||||||
*
|
|
||||||
* @return string normalized path
|
|
||||||
*/
|
|
||||||
protected function normalizePath($_path, $ds = true)
|
|
||||||
{
|
|
||||||
if ($ds) {
|
|
||||||
// don't we all just love windows?
|
|
||||||
$_path = str_replace('\\', '/', $_path);
|
|
||||||
}
|
|
||||||
|
|
||||||
$offset = 0;
|
|
||||||
|
|
||||||
// resolve simples
|
|
||||||
$_path = preg_replace('#/\./(\./)*#', '/', $_path);
|
|
||||||
// resolve parents
|
|
||||||
while (true) {
|
|
||||||
$_parent = strpos($_path, '/../', $offset);
|
|
||||||
if (!$_parent) {
|
|
||||||
break;
|
|
||||||
} elseif ($_path[$_parent - 1] === '.') {
|
|
||||||
$offset = $_parent + 3;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
$_pos = strrpos($_path, '/', $_parent - strlen($_path) - 1);
|
|
||||||
if ($_pos === false) {
|
|
||||||
// don't we all just love windows?
|
|
||||||
$_pos = $_parent;
|
|
||||||
}
|
|
||||||
|
|
||||||
$_path = substr_replace($_path, '', $_pos, $_parent + 3 - $_pos);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($ds && DS != '/') {
|
|
||||||
// don't we all just love windows?
|
|
||||||
$_path = str_replace('/', '\\', $_path);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $_path;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* build template filepath by traversing the template_dir array
|
|
||||||
*
|
|
||||||
* @param Smarty_Template_Source $source source object
|
|
||||||
* @param Smarty_Internal_Template $_template template object
|
|
||||||
*
|
|
||||||
* @return string fully qualified filepath
|
|
||||||
* @throws SmartyException if default template handler is registered but not callable
|
|
||||||
*/
|
|
||||||
protected function buildFilepath(Smarty_Template_Source $source, Smarty_Internal_Template $_template = null)
|
|
||||||
{
|
|
||||||
$file = $source->name;
|
|
||||||
if ($source instanceof Smarty_Config_Source) {
|
|
||||||
$_directories = $source->smarty->getConfigDir();
|
|
||||||
$_default_handler = $source->smarty->default_config_handler_func;
|
|
||||||
} else {
|
|
||||||
$_directories = $source->smarty->getTemplateDir();
|
|
||||||
$_default_handler = $source->smarty->default_template_handler_func;
|
|
||||||
}
|
|
||||||
|
|
||||||
// go relative to a given template?
|
|
||||||
$_file_is_dotted = $file[0] == '.' && ($file[1] == '.' || $file[1] == '/' || $file[1] == "\\");
|
|
||||||
if ($_template && $_template->parent instanceof Smarty_Internal_Template && $_file_is_dotted) {
|
|
||||||
if ($_template->parent->source->type != 'file' && $_template->parent->source->type != 'extends' && !$_template->parent->allow_relative_path) {
|
|
||||||
throw new SmartyException("Template '{$file}' cannot be relative to template of resource type '{$_template->parent->source->type}'");
|
|
||||||
}
|
|
||||||
$file = dirname($_template->parent->source->filepath) . DS . $file;
|
|
||||||
$_file_exact_match = true;
|
|
||||||
if (!preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $file)) {
|
|
||||||
// the path gained from the parent template is relative to the current working directory
|
|
||||||
// as expansions (like include_path) have already been done
|
|
||||||
$file = getcwd() . DS . $file;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// resolve relative path
|
|
||||||
if (!preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $file)) {
|
|
||||||
// don't we all just love windows?
|
|
||||||
$_path = DS . trim($file, '/');
|
|
||||||
$_was_relative = true;
|
|
||||||
} else {
|
|
||||||
// don't we all just love windows?
|
|
||||||
$_path = str_replace('\\', '/', $file);
|
|
||||||
}
|
|
||||||
$_path = $this->normalizePath($_path, false);
|
|
||||||
if (DS != '/') {
|
|
||||||
// don't we all just love windows?
|
|
||||||
$_path = str_replace('/', '\\', $_path);
|
|
||||||
}
|
|
||||||
// revert to relative
|
|
||||||
if (isset($_was_relative)) {
|
|
||||||
$_path = substr($_path, 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
// this is only required for directories
|
|
||||||
$file = rtrim($_path, '/\\');
|
|
||||||
|
|
||||||
// files relative to a template only get one shot
|
|
||||||
if (isset($_file_exact_match)) {
|
|
||||||
return $this->fileExists($source, $file) ? $file : false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// template_dir index?
|
|
||||||
if (preg_match('#^\[(?P<key>[^\]]+)\](?P<file>.+)$#', $file, $match)) {
|
|
||||||
$_directory = null;
|
|
||||||
// try string indexes
|
|
||||||
if (isset($_directories[$match['key']])) {
|
|
||||||
$_directory = $_directories[$match['key']];
|
|
||||||
} elseif (is_numeric($match['key'])) {
|
|
||||||
// try numeric index
|
|
||||||
$match['key'] = (int) $match['key'];
|
|
||||||
if (isset($_directories[$match['key']])) {
|
|
||||||
$_directory = $_directories[$match['key']];
|
|
||||||
} else {
|
|
||||||
// try at location index
|
|
||||||
$keys = array_keys($_directories);
|
|
||||||
$_directory = $_directories[$keys[$match['key']]];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($_directory) {
|
|
||||||
$_file = substr($file, strpos($file, ']') + 1);
|
|
||||||
$_filepath = $_directory . $_file;
|
|
||||||
if ($this->fileExists($source, $_filepath)) {
|
|
||||||
return $_filepath;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$_stream_resolve_include_path = function_exists('stream_resolve_include_path');
|
|
||||||
|
|
||||||
// relative file name?
|
|
||||||
if (!preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $file)) {
|
|
||||||
foreach ($_directories as $_directory) {
|
|
||||||
$_filepath = $_directory . $file;
|
|
||||||
if ($this->fileExists($source, $_filepath)) {
|
|
||||||
return $this->normalizePath($_filepath);
|
|
||||||
}
|
|
||||||
if ($source->smarty->use_include_path && !preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $_directory)) {
|
|
||||||
// try PHP include_path
|
|
||||||
if ($_stream_resolve_include_path) {
|
|
||||||
$_filepath = stream_resolve_include_path($_filepath);
|
|
||||||
} else {
|
|
||||||
$_filepath = Smarty_Internal_Get_Include_Path::getIncludePath($_filepath);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($_filepath !== false) {
|
|
||||||
if ($this->fileExists($source, $_filepath)) {
|
|
||||||
return $this->normalizePath($_filepath);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// try absolute filepath
|
|
||||||
if ($this->fileExists($source, $file)) {
|
|
||||||
return $file;
|
|
||||||
}
|
|
||||||
|
|
||||||
// no tpl file found
|
|
||||||
if ($_default_handler) {
|
|
||||||
if (!is_callable($_default_handler)) {
|
|
||||||
if ($source instanceof Smarty_Config_Source) {
|
|
||||||
throw new SmartyException("Default config handler not callable");
|
|
||||||
} else {
|
|
||||||
throw new SmartyException("Default template handler not callable");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$_return = call_user_func_array($_default_handler,
|
|
||||||
array($source->type, $source->name, &$_content, &$_timestamp, $source->smarty));
|
|
||||||
if (is_string($_return)) {
|
|
||||||
$source->timestamp = @filemtime($_return);
|
|
||||||
$source->exists = !!$source->timestamp;
|
|
||||||
|
|
||||||
return $_return;
|
|
||||||
} elseif ($_return === true) {
|
|
||||||
$source->content = $_content;
|
|
||||||
$source->timestamp = $_timestamp;
|
|
||||||
$source->exists = true;
|
|
||||||
|
|
||||||
return $_filepath;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// give up
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* test is file exists and save timestamp
|
|
||||||
*
|
|
||||||
* @param Smarty_Template_Source $source source object
|
|
||||||
* @param string $file file name
|
|
||||||
*
|
|
||||||
* @return bool true if file exists
|
|
||||||
*/
|
|
||||||
protected function fileExists(Smarty_Template_Source $source, $file)
|
|
||||||
{
|
|
||||||
$source->timestamp = is_file($file) ? @filemtime($file) : false;
|
|
||||||
|
|
||||||
return $source->exists = !!$source->timestamp;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Determine basename for compiled filename
|
|
||||||
*
|
|
||||||
* @param Smarty_Template_Source $source source object
|
|
||||||
*
|
|
||||||
* @return string resource's basename
|
|
||||||
*/
|
|
||||||
protected function getBasename(Smarty_Template_Source $source)
|
|
||||||
{
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Load Resource Handler
|
|
||||||
*
|
|
||||||
* @param Smarty $smarty smarty object
|
|
||||||
* @param string $type name of the resource
|
|
||||||
*
|
|
||||||
* @throws SmartyException
|
|
||||||
* @return Smarty_Resource Resource Handler
|
|
||||||
*/
|
|
||||||
public static function load(Smarty $smarty, $type)
|
|
||||||
{
|
|
||||||
// try smarty's cache
|
|
||||||
if (isset($smarty->_resource_handlers[$type])) {
|
|
||||||
return $smarty->_resource_handlers[$type];
|
|
||||||
}
|
|
||||||
|
|
||||||
// try registered resource
|
|
||||||
if (isset($smarty->registered_resources[$type])) {
|
|
||||||
if ($smarty->registered_resources[$type] instanceof Smarty_Resource) {
|
|
||||||
$smarty->_resource_handlers[$type] = $smarty->registered_resources[$type];
|
|
||||||
// note registered to smarty is not kept unique!
|
|
||||||
return $smarty->_resource_handlers[$type];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!isset(self::$resources['registered'])) {
|
|
||||||
self::$resources['registered'] = new Smarty_Internal_Resource_Registered();
|
|
||||||
}
|
|
||||||
if (!isset($smarty->_resource_handlers[$type])) {
|
|
||||||
$smarty->_resource_handlers[$type] = self::$resources['registered'];
|
|
||||||
}
|
|
||||||
|
|
||||||
return $smarty->_resource_handlers[$type];
|
|
||||||
}
|
|
||||||
|
|
||||||
// try sysplugins dir
|
|
||||||
if (isset(self::$sysplugins[$type])) {
|
|
||||||
if (!isset(self::$resources[$type])) {
|
|
||||||
$_resource_class = 'Smarty_Internal_Resource_' . ucfirst($type);
|
|
||||||
self::$resources[$type] = new $_resource_class();
|
|
||||||
}
|
|
||||||
|
|
||||||
return $smarty->_resource_handlers[$type] = self::$resources[$type];
|
|
||||||
}
|
|
||||||
|
|
||||||
// try plugins dir
|
|
||||||
$_resource_class = 'Smarty_Resource_' . ucfirst($type);
|
|
||||||
if ($smarty->loadPlugin($_resource_class)) {
|
|
||||||
if (isset(self::$resources[$type])) {
|
|
||||||
return $smarty->_resource_handlers[$type] = self::$resources[$type];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (class_exists($_resource_class, false)) {
|
|
||||||
self::$resources[$type] = new $_resource_class();
|
|
||||||
|
|
||||||
return $smarty->_resource_handlers[$type] = self::$resources[$type];
|
|
||||||
} else {
|
|
||||||
$smarty->registerResource($type, array(
|
|
||||||
"smarty_resource_{$type}_source",
|
|
||||||
"smarty_resource_{$type}_timestamp",
|
|
||||||
"smarty_resource_{$type}_secure",
|
|
||||||
"smarty_resource_{$type}_trusted"
|
|
||||||
));
|
|
||||||
|
|
||||||
// give it another try, now that the resource is registered properly
|
|
||||||
return self::load($smarty, $type);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// try streams
|
|
||||||
$_known_stream = stream_get_wrappers();
|
|
||||||
if (in_array($type, $_known_stream)) {
|
|
||||||
// is known stream
|
|
||||||
if (is_object($smarty->security_policy)) {
|
|
||||||
$smarty->security_policy->isTrustedStream($type);
|
|
||||||
}
|
|
||||||
if (!isset(self::$resources['stream'])) {
|
|
||||||
self::$resources['stream'] = new Smarty_Internal_Resource_Stream();
|
|
||||||
}
|
|
||||||
|
|
||||||
return $smarty->_resource_handlers[$type] = self::$resources['stream'];
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: try default_(template|config)_handler
|
|
||||||
|
|
||||||
// give up
|
|
||||||
throw new SmartyException("Unknown resource type '{$type}'");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* extract resource_type and resource_name from template_resource and config_resource
|
|
||||||
* @note "C:/foo.tpl" was forced to file resource up till Smarty 3.1.3 (including).
|
|
||||||
*
|
|
||||||
* @param string $resource_name template_resource or config_resource to parse
|
|
||||||
* @param string $default_resource the default resource_type defined in $smarty
|
|
||||||
* @param string &$name the parsed resource name
|
|
||||||
* @param string &$type the parsed resource type
|
|
||||||
*
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
protected static function parseResourceName($resource_name, $default_resource, &$name, &$type)
|
|
||||||
{
|
|
||||||
$parts = explode(':', $resource_name, 2);
|
|
||||||
if (!isset($parts[1]) || !isset($parts[0][1])) {
|
|
||||||
// no resource given, use default
|
|
||||||
// or single character before the colon is not a resource type, but part of the filepath
|
|
||||||
$type = $default_resource;
|
|
||||||
$name = $resource_name;
|
|
||||||
} else {
|
|
||||||
$type = $parts[0];
|
|
||||||
$name = $parts[1];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* modify resource_name according to resource handlers specifications
|
|
||||||
*
|
|
||||||
* @param Smarty $smarty Smarty instance
|
|
||||||
* @param string $resource_name resource_name to make unique
|
|
||||||
*
|
|
||||||
* @return string unique resource name
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* modify template_resource according to resource handlers specifications
|
|
||||||
*
|
|
||||||
* @param Smarty_Internal_template $template Smarty instance
|
|
||||||
* @param string $template_resource template_resource to extract resource handler and name of
|
|
||||||
*
|
|
||||||
* @return string unique resource name
|
|
||||||
*/
|
|
||||||
public static function getUniqueTemplateName($template, $template_resource)
|
|
||||||
{
|
|
||||||
self::parseResourceName($template_resource, $template->smarty->default_resource_type, $name, $type);
|
|
||||||
// TODO: optimize for Smarty's internal resource types
|
|
||||||
$resource = Smarty_Resource::load($template->smarty, $type);
|
|
||||||
// go relative to a given template?
|
|
||||||
$_file_is_dotted = $name[0] == '.' && ($name[1] == '.' || $name[1] == '/' || $name[1] == "\\");
|
|
||||||
if ($template instanceof Smarty_Internal_Template && $_file_is_dotted && ($template->source->type == 'file' || $template->parent->source->type == 'extends')) {
|
|
||||||
$name = dirname($template->source->filepath) . DS . $name;
|
|
||||||
}
|
|
||||||
return $resource->buildUniqueResourceName($template->smarty, $name);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* initialize Source Object for given resource
|
|
||||||
* Either [$_template] or [$smarty, $template_resource] must be specified
|
|
||||||
*
|
|
||||||
* @param Smarty_Internal_Template $_template template object
|
|
||||||
* @param Smarty $smarty smarty object
|
|
||||||
* @param string $template_resource resource identifier
|
|
||||||
*
|
|
||||||
* @return Smarty_Template_Source Source Object
|
|
||||||
*/
|
|
||||||
public static function source(Smarty_Internal_Template $_template = null, Smarty $smarty = null, $template_resource = null)
|
|
||||||
{
|
|
||||||
if ($_template) {
|
|
||||||
$smarty = $_template->smarty;
|
|
||||||
$template_resource = $_template->template_resource;
|
|
||||||
}
|
|
||||||
|
|
||||||
// parse resource_name, load resource handler, identify unique resource name
|
|
||||||
self::parseResourceName($template_resource, $smarty->default_resource_type, $name, $type);
|
|
||||||
$resource = Smarty_Resource::load($smarty, $type);
|
|
||||||
// go relative to a given template?
|
|
||||||
$_file_is_dotted = isset($name[0]) && $name[0] == '.' && ($name[1] == '.' || $name[1] == '/' || $name[1] == "\\");
|
|
||||||
if ($_file_is_dotted && isset($_template) && $_template->parent instanceof Smarty_Internal_Template && ($_template->parent->source->type == 'file' || $_template->parent->source->type == 'extends')) {
|
|
||||||
$name2 = dirname($_template->parent->source->filepath) . DS . $name;
|
|
||||||
} else {
|
|
||||||
$name2 = $name;
|
|
||||||
}
|
|
||||||
$unique_resource_name = $resource->buildUniqueResourceName($smarty, $name2);
|
|
||||||
|
|
||||||
// check runtime cache
|
|
||||||
$_cache_key = 'template|' . $unique_resource_name;
|
|
||||||
if ($smarty->compile_id) {
|
|
||||||
$_cache_key .= '|' . $smarty->compile_id;
|
|
||||||
}
|
|
||||||
if (isset(self::$sources[$_cache_key])) {
|
|
||||||
return self::$sources[$_cache_key];
|
|
||||||
}
|
|
||||||
|
|
||||||
// create source
|
|
||||||
$source = new Smarty_Template_Source($resource, $smarty, $template_resource, $type, $name, $unique_resource_name);
|
|
||||||
$resource->populate($source, $_template);
|
|
||||||
|
|
||||||
// runtime cache
|
|
||||||
self::$sources[$_cache_key] = $source;
|
|
||||||
|
|
||||||
return $source;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* initialize Config Source Object for given resource
|
|
||||||
*
|
|
||||||
* @param Smarty_Internal_Config $_config config object
|
|
||||||
*
|
|
||||||
* @throws SmartyException
|
|
||||||
* @return Smarty_Config_Source Source Object
|
|
||||||
*/
|
|
||||||
public static function config(Smarty_Internal_Config $_config)
|
|
||||||
{
|
|
||||||
static $_incompatible_resources = array('eval' => true, 'string' => true, 'extends' => true, 'php' => true);
|
|
||||||
$config_resource = $_config->config_resource;
|
|
||||||
$smarty = $_config->smarty;
|
|
||||||
|
|
||||||
// parse resource_name
|
|
||||||
self::parseResourceName($config_resource, $smarty->default_config_type, $name, $type);
|
|
||||||
|
|
||||||
// make sure configs are not loaded via anything smarty can't handle
|
|
||||||
if (isset($_incompatible_resources[$type])) {
|
|
||||||
throw new SmartyException ("Unable to use resource '{$type}' for config");
|
|
||||||
}
|
|
||||||
|
|
||||||
// load resource handler, identify unique resource name
|
|
||||||
$resource = Smarty_Resource::load($smarty, $type);
|
|
||||||
$unique_resource_name = $resource->buildUniqueResourceName($smarty, $name, true);
|
|
||||||
|
|
||||||
// check runtime cache
|
|
||||||
$_cache_key = 'config|' . $unique_resource_name;
|
|
||||||
if (isset(self::$sources[$_cache_key])) {
|
|
||||||
return self::$sources[$_cache_key];
|
|
||||||
}
|
|
||||||
|
|
||||||
// create source
|
|
||||||
$source = new Smarty_Config_Source($resource, $smarty, $config_resource, $type, $name, $unique_resource_name);
|
|
||||||
$resource->populate($source, null);
|
|
||||||
|
|
||||||
// runtime cache
|
|
||||||
self::$sources[$_cache_key] = $source;
|
|
||||||
|
|
||||||
return $source;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Resource Data Object
|
|
||||||
* Meta Data Container for Template Files
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage TemplateResources
|
|
||||||
* @author Rodney Rehm
|
|
||||||
* @property integer $timestamp Source Timestamp
|
|
||||||
* @property boolean $exists Source Existence
|
|
||||||
* @property boolean $template Extended Template reference
|
|
||||||
* @property string $content Source Content
|
|
||||||
*/
|
|
||||||
class Smarty_Template_Source
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Name of the Class to compile this resource's contents with
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $compiler_class = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Name of the Class to tokenize this resource's contents with
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $template_lexer_class = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Name of the Class to parse this resource's contents with
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $template_parser_class = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Unique Template ID
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $uid = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Template Resource (Smarty_Internal_Template::$template_resource)
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $resource = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Resource Type
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $type = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Resource Name
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $name = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Unique Resource Name
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $unique_resource = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Source Filepath
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $filepath = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Source is bypassing compiler
|
|
||||||
*
|
|
||||||
* @var boolean
|
|
||||||
*/
|
|
||||||
public $uncompiled = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Source must be recompiled on every occasion
|
|
||||||
*
|
|
||||||
* @var boolean
|
|
||||||
*/
|
|
||||||
public $recompiled = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Components an extended template is made of
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $components = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Resource Handler
|
|
||||||
*
|
|
||||||
* @var Smarty_Resource
|
|
||||||
*/
|
|
||||||
public $handler = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty instance
|
|
||||||
*
|
|
||||||
* @var Smarty
|
|
||||||
*/
|
|
||||||
public $smarty = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* create Source Object container
|
|
||||||
*
|
|
||||||
* @param Smarty_Resource $handler Resource Handler this source object communicates with
|
|
||||||
* @param Smarty $smarty Smarty instance this source object belongs to
|
|
||||||
* @param string $resource full template_resource
|
|
||||||
* @param string $type type of resource
|
|
||||||
* @param string $name resource name
|
|
||||||
* @param string $unique_resource unique resource name
|
|
||||||
*/
|
|
||||||
public function __construct(Smarty_Resource $handler, Smarty $smarty, $resource, $type, $name, $unique_resource)
|
|
||||||
{
|
|
||||||
$this->handler = $handler; // Note: prone to circular references
|
|
||||||
|
|
||||||
$this->compiler_class = $handler->compiler_class;
|
|
||||||
$this->template_lexer_class = $handler->template_lexer_class;
|
|
||||||
$this->template_parser_class = $handler->template_parser_class;
|
|
||||||
$this->uncompiled = $this->handler instanceof Smarty_Resource_Uncompiled;
|
|
||||||
$this->recompiled = $this->handler instanceof Smarty_Resource_Recompiled;
|
|
||||||
|
|
||||||
$this->smarty = $smarty;
|
|
||||||
$this->resource = $resource;
|
|
||||||
$this->type = $type;
|
|
||||||
$this->name = $name;
|
|
||||||
$this->unique_resource = $unique_resource;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* get a Compiled Object of this source
|
|
||||||
*
|
|
||||||
* @param Smarty_Internal_Template|Smarty_Internal_Config $_template template object
|
|
||||||
*
|
|
||||||
* @return Smarty_Template_Compiled compiled object
|
|
||||||
*/
|
|
||||||
public function getCompiled($_template)
|
|
||||||
{
|
|
||||||
// check runtime cache
|
|
||||||
$_cache_key = $this->unique_resource . '#' . $_template->compile_id;
|
|
||||||
if (isset(Smarty_Resource::$compileds[$_cache_key])) {
|
|
||||||
return Smarty_Resource::$compileds[$_cache_key];
|
|
||||||
}
|
|
||||||
|
|
||||||
$compiled = new Smarty_Template_Compiled($this);
|
|
||||||
$this->handler->populateCompiledFilepath($compiled, $_template);
|
|
||||||
$compiled->timestamp = @filemtime($compiled->filepath);
|
|
||||||
$compiled->exists = !!$compiled->timestamp;
|
|
||||||
|
|
||||||
// runtime cache
|
|
||||||
Smarty_Resource::$compileds[$_cache_key] = $compiled;
|
|
||||||
|
|
||||||
return $compiled;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* render the uncompiled source
|
|
||||||
*
|
|
||||||
* @param Smarty_Internal_Template $_template template object
|
|
||||||
*/
|
|
||||||
public function renderUncompiled(Smarty_Internal_Template $_template)
|
|
||||||
{
|
|
||||||
return $this->handler->renderUncompiled($this, $_template);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <<magic>> Generic Setter.
|
|
||||||
*
|
|
||||||
* @param string $property_name valid: timestamp, exists, content, template
|
|
||||||
* @param mixed $value new value (is not checked)
|
|
||||||
*
|
|
||||||
* @throws SmartyException if $property_name is not valid
|
|
||||||
*/
|
|
||||||
public function __set($property_name, $value)
|
|
||||||
{
|
|
||||||
switch ($property_name) {
|
|
||||||
// regular attributes
|
|
||||||
case 'timestamp':
|
|
||||||
case 'exists':
|
|
||||||
case 'content':
|
|
||||||
// required for extends: only
|
|
||||||
case 'template':
|
|
||||||
$this->$property_name = $value;
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new SmartyException("invalid source property '$property_name'.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <<magic>> Generic getter.
|
|
||||||
*
|
|
||||||
* @param string $property_name valid: timestamp, exists, content
|
|
||||||
*
|
|
||||||
* @return mixed
|
|
||||||
* @throws SmartyException if $property_name is not valid
|
|
||||||
*/
|
|
||||||
public function __get($property_name)
|
|
||||||
{
|
|
||||||
switch ($property_name) {
|
|
||||||
case 'timestamp':
|
|
||||||
case 'exists':
|
|
||||||
$this->handler->populateTimestamp($this);
|
|
||||||
|
|
||||||
return $this->$property_name;
|
|
||||||
|
|
||||||
case 'content':
|
|
||||||
return $this->content = $this->handler->getContent($this);
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new SmartyException("source property '$property_name' does not exist.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Resource Data Object
|
|
||||||
* Meta Data Container for Template Files
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage TemplateResources
|
|
||||||
* @author Rodney Rehm
|
|
||||||
* @property string $content compiled content
|
|
||||||
*/
|
|
||||||
class Smarty_Template_Compiled
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Compiled Filepath
|
|
||||||
*
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
public $filepath = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiled Timestamp
|
|
||||||
*
|
|
||||||
* @var integer
|
|
||||||
*/
|
|
||||||
public $timestamp = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiled Existence
|
|
||||||
*
|
|
||||||
* @var boolean
|
|
||||||
*/
|
|
||||||
public $exists = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiled Content Loaded
|
|
||||||
*
|
|
||||||
* @var boolean
|
|
||||||
*/
|
|
||||||
public $loaded = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Template was compiled
|
|
||||||
*
|
|
||||||
* @var boolean
|
|
||||||
*/
|
|
||||||
public $isCompiled = false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Source Object
|
|
||||||
*
|
|
||||||
* @var Smarty_Template_Source
|
|
||||||
*/
|
|
||||||
public $source = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Metadata properties
|
|
||||||
* populated by Smarty_Internal_Template::decodeProperties()
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $_properties = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* create Compiled Object container
|
|
||||||
*
|
|
||||||
* @param Smarty_Template_Source $source source object this compiled object belongs to
|
|
||||||
*/
|
|
||||||
public function __construct(Smarty_Template_Source $source)
|
|
||||||
{
|
|
||||||
$this->source = $source;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,33 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty Resource Plugin
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage TemplateResources
|
|
||||||
* @author Rodney Rehm
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Smarty Resource Plugin
|
|
||||||
* Base implementation for resource plugins that don't compile cache
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage TemplateResources
|
|
||||||
*/
|
|
||||||
abstract class Smarty_Resource_Recompiled extends Smarty_Resource
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* populate Compiled Object with compiled filepath
|
|
||||||
*
|
|
||||||
* @param Smarty_Template_Compiled $compiled compiled object
|
|
||||||
* @param Smarty_Internal_Template $_template template object
|
|
||||||
*
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
public function populateCompiledFilepath(Smarty_Template_Compiled $compiled, Smarty_Internal_Template $_template)
|
|
||||||
{
|
|
||||||
$compiled->filepath = false;
|
|
||||||
$compiled->timestamp = false;
|
|
||||||
$compiled->exists = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,480 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Smarty plugin
|
|
||||||
*
|
|
||||||
* @package Smarty
|
|
||||||
* @subpackage Security
|
|
||||||
* @author Uwe Tews
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* FIXME: Smarty_Security API
|
|
||||||
* - getter and setter instead of public properties would allow cultivating an internal cache properly
|
|
||||||
* - current implementation of isTrustedResourceDir() assumes that Smarty::$template_dir and Smarty::$config_dir are immutable
|
|
||||||
* the cache is killed every time either of the variables change. That means that two distinct Smarty objects with differing
|
|
||||||
* $template_dir or $config_dir should NOT share the same Smarty_Security instance,
|
|
||||||
* as this would lead to (severe) performance penalty! how should this be handled?
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This class does contain the security settings
|
|
||||||
*/
|
|
||||||
class Smarty_Security
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* This determines how Smarty handles "<?php ... ?>" tags in templates.
|
|
||||||
* possible values:
|
|
||||||
* <ul>
|
|
||||||
* <li>Smarty::PHP_PASSTHRU -> echo PHP tags as they are</li>
|
|
||||||
* <li>Smarty::PHP_QUOTE -> escape tags as entities</li>
|
|
||||||
* <li>Smarty::PHP_REMOVE -> remove php tags</li>
|
|
||||||
* <li>Smarty::PHP_ALLOW -> execute php tags</li>
|
|
||||||
* </ul>
|
|
||||||
*
|
|
||||||
* @var integer
|
|
||||||
*/
|
|
||||||
public $php_handling = Smarty::PHP_PASSTHRU;
|
|
||||||
/**
|
|
||||||
* This is the list of template directories that are considered secure.
|
|
||||||
* $template_dir is in this list implicitly.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $secure_dir = array();
|
|
||||||
/**
|
|
||||||
* This is an array of directories where trusted php scripts reside.
|
|
||||||
* {@link $security} is disabled during their inclusion/execution.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $trusted_dir = array();
|
|
||||||
/**
|
|
||||||
* List of regular expressions (PCRE) that include trusted URIs
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $trusted_uri = array();
|
|
||||||
/**
|
|
||||||
* This is an array of trusted static classes.
|
|
||||||
* If empty access to all static classes is allowed.
|
|
||||||
* If set to 'none' none is allowed.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $static_classes = array();
|
|
||||||
/**
|
|
||||||
* This is an array of trusted PHP functions.
|
|
||||||
* If empty all functions are allowed.
|
|
||||||
* To disable all PHP functions set $php_functions = null.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $php_functions = array(
|
|
||||||
'isset', 'empty',
|
|
||||||
'count', 'sizeof',
|
|
||||||
'in_array', 'is_array',
|
|
||||||
'time',
|
|
||||||
'nl2br',
|
|
||||||
);
|
|
||||||
/**
|
|
||||||
* This is an array of trusted PHP modifiers.
|
|
||||||
* If empty all modifiers are allowed.
|
|
||||||
* To disable all modifier set $php_modifiers = null.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $php_modifiers = array(
|
|
||||||
'escape',
|
|
||||||
'count'
|
|
||||||
);
|
|
||||||
/**
|
|
||||||
* This is an array of allowed tags.
|
|
||||||
* If empty no restriction by allowed_tags.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $allowed_tags = array();
|
|
||||||
/**
|
|
||||||
* This is an array of disabled tags.
|
|
||||||
* If empty no restriction by disabled_tags.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $disabled_tags = array();
|
|
||||||
/**
|
|
||||||
* This is an array of allowed modifier plugins.
|
|
||||||
* If empty no restriction by allowed_modifiers.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $allowed_modifiers = array();
|
|
||||||
/**
|
|
||||||
* This is an array of disabled modifier plugins.
|
|
||||||
* If empty no restriction by disabled_modifiers.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $disabled_modifiers = array();
|
|
||||||
/**
|
|
||||||
* This is an array of trusted streams.
|
|
||||||
* If empty all streams are allowed.
|
|
||||||
* To disable all streams set $streams = null.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
public $streams = array('file');
|
|
||||||
/**
|
|
||||||
* + flag if constants can be accessed from template
|
|
||||||
*
|
|
||||||
* @var boolean
|
|
||||||
*/
|
|
||||||
public $allow_constants = true;
|
|
||||||
/**
|
|
||||||
* + flag if super globals can be accessed from template
|
|
||||||
*
|
|
||||||
* @var boolean
|
|
||||||
*/
|
|
||||||
public $allow_super_globals = true;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Cache for $resource_dir lookup
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
protected $_resource_dir = null;
|
|
||||||
/**
|
|
||||||
* Cache for $template_dir lookup
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
protected $_template_dir = null;
|
|
||||||
/**
|
|
||||||
* Cache for $config_dir lookup
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
protected $_config_dir = null;
|
|
||||||
/**
|
|
||||||
* Cache for $secure_dir lookup
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
protected $_secure_dir = null;
|
|
||||||
/**
|
|
||||||
* Cache for $php_resource_dir lookup
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
protected $_php_resource_dir = null;
|
|
||||||
/**
|
|
||||||
* Cache for $trusted_dir lookup
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
protected $_trusted_dir = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Smarty $smarty
|
|
||||||
*/
|
|
||||||
public function __construct($smarty)
|
|
||||||
{
|
|
||||||
$this->smarty = $smarty;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if PHP function is trusted.
|
|
||||||
*
|
|
||||||
* @param string $function_name
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
*
|
|
||||||
* @return boolean true if function is trusted
|
|
||||||
* @throws SmartyCompilerException if php function is not trusted
|
|
||||||
*/
|
|
||||||
public function isTrustedPhpFunction($function_name, $compiler)
|
|
||||||
{
|
|
||||||
if (isset($this->php_functions) && (empty($this->php_functions) || in_array($function_name, $this->php_functions))) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
$compiler->trigger_template_error("PHP function '{$function_name}' not allowed by security setting");
|
|
||||||
|
|
||||||
return false; // should not, but who knows what happens to the compiler in the future?
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if static class is trusted.
|
|
||||||
*
|
|
||||||
* @param string $class_name
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
*
|
|
||||||
* @return boolean true if class is trusted
|
|
||||||
* @throws SmartyCompilerException if static class is not trusted
|
|
||||||
*/
|
|
||||||
public function isTrustedStaticClass($class_name, $compiler)
|
|
||||||
{
|
|
||||||
if (isset($this->static_classes) && (empty($this->static_classes) || in_array($class_name, $this->static_classes))) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
$compiler->trigger_template_error("access to static class '{$class_name}' not allowed by security setting");
|
|
||||||
|
|
||||||
return false; // should not, but who knows what happens to the compiler in the future?
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if PHP modifier is trusted.
|
|
||||||
*
|
|
||||||
* @param string $modifier_name
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
*
|
|
||||||
* @return boolean true if modifier is trusted
|
|
||||||
* @throws SmartyCompilerException if modifier is not trusted
|
|
||||||
*/
|
|
||||||
public function isTrustedPhpModifier($modifier_name, $compiler)
|
|
||||||
{
|
|
||||||
if (isset($this->php_modifiers) && (empty($this->php_modifiers) || in_array($modifier_name, $this->php_modifiers))) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
$compiler->trigger_template_error("modifier '{$modifier_name}' not allowed by security setting");
|
|
||||||
|
|
||||||
return false; // should not, but who knows what happens to the compiler in the future?
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if tag is trusted.
|
|
||||||
*
|
|
||||||
* @param string $tag_name
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
*
|
|
||||||
* @return boolean true if tag is trusted
|
|
||||||
* @throws SmartyCompilerException if modifier is not trusted
|
|
||||||
*/
|
|
||||||
public function isTrustedTag($tag_name, $compiler)
|
|
||||||
{
|
|
||||||
// check for internal always required tags
|
|
||||||
if (in_array($tag_name, array('assign', 'call', 'private_filter', 'private_block_plugin', 'private_function_plugin', 'private_object_block_function',
|
|
||||||
'private_object_function', 'private_registered_function', 'private_registered_block', 'private_special_variable', 'private_print_expression', 'private_modifier'))
|
|
||||||
) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
// check security settings
|
|
||||||
if (empty($this->allowed_tags)) {
|
|
||||||
if (empty($this->disabled_tags) || !in_array($tag_name, $this->disabled_tags)) {
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
$compiler->trigger_template_error("tag '{$tag_name}' disabled by security setting", $compiler->lex->taglineno);
|
|
||||||
}
|
|
||||||
} elseif (in_array($tag_name, $this->allowed_tags) && !in_array($tag_name, $this->disabled_tags)) {
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
$compiler->trigger_template_error("tag '{$tag_name}' not allowed by security setting", $compiler->lex->taglineno);
|
|
||||||
}
|
|
||||||
|
|
||||||
return false; // should not, but who knows what happens to the compiler in the future?
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if modifier plugin is trusted.
|
|
||||||
*
|
|
||||||
* @param string $modifier_name
|
|
||||||
* @param object $compiler compiler object
|
|
||||||
*
|
|
||||||
* @return boolean true if tag is trusted
|
|
||||||
* @throws SmartyCompilerException if modifier is not trusted
|
|
||||||
*/
|
|
||||||
public function isTrustedModifier($modifier_name, $compiler)
|
|
||||||
{
|
|
||||||
// check for internal always allowed modifier
|
|
||||||
if (in_array($modifier_name, array('default'))) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
// check security settings
|
|
||||||
if (empty($this->allowed_modifiers)) {
|
|
||||||
if (empty($this->disabled_modifiers) || !in_array($modifier_name, $this->disabled_modifiers)) {
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
$compiler->trigger_template_error("modifier '{$modifier_name}' disabled by security setting", $compiler->lex->taglineno);
|
|
||||||
}
|
|
||||||
} elseif (in_array($modifier_name, $this->allowed_modifiers) && !in_array($modifier_name, $this->disabled_modifiers)) {
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
$compiler->trigger_template_error("modifier '{$modifier_name}' not allowed by security setting", $compiler->lex->taglineno);
|
|
||||||
}
|
|
||||||
|
|
||||||
return false; // should not, but who knows what happens to the compiler in the future?
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if stream is trusted.
|
|
||||||
*
|
|
||||||
* @param string $stream_name
|
|
||||||
*
|
|
||||||
* @return boolean true if stream is trusted
|
|
||||||
* @throws SmartyException if stream is not trusted
|
|
||||||
*/
|
|
||||||
public function isTrustedStream($stream_name)
|
|
||||||
{
|
|
||||||
if (isset($this->streams) && (empty($this->streams) || in_array($stream_name, $this->streams))) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
throw new SmartyException("stream '{$stream_name}' not allowed by security setting");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if directory of file resource is trusted.
|
|
||||||
*
|
|
||||||
* @param string $filepath
|
|
||||||
*
|
|
||||||
* @return boolean true if directory is trusted
|
|
||||||
* @throws SmartyException if directory is not trusted
|
|
||||||
*/
|
|
||||||
public function isTrustedResourceDir($filepath)
|
|
||||||
{
|
|
||||||
$_template = false;
|
|
||||||
$_config = false;
|
|
||||||
$_secure = false;
|
|
||||||
|
|
||||||
$_template_dir = $this->smarty->getTemplateDir();
|
|
||||||
$_config_dir = $this->smarty->getConfigDir();
|
|
||||||
|
|
||||||
// check if index is outdated
|
|
||||||
if ((!$this->_template_dir || $this->_template_dir !== $_template_dir)
|
|
||||||
|| (!$this->_config_dir || $this->_config_dir !== $_config_dir)
|
|
||||||
|| (!empty($this->secure_dir) && (!$this->_secure_dir || $this->_secure_dir !== $this->secure_dir))
|
|
||||||
) {
|
|
||||||
$this->_resource_dir = array();
|
|
||||||
$_template = true;
|
|
||||||
$_config = true;
|
|
||||||
$_secure = !empty($this->secure_dir);
|
|
||||||
}
|
|
||||||
|
|
||||||
// rebuild template dir index
|
|
||||||
if ($_template) {
|
|
||||||
$this->_template_dir = $_template_dir;
|
|
||||||
foreach ($_template_dir as $directory) {
|
|
||||||
$directory = realpath($directory);
|
|
||||||
$this->_resource_dir[$directory] = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// rebuild config dir index
|
|
||||||
if ($_config) {
|
|
||||||
$this->_config_dir = $_config_dir;
|
|
||||||
foreach ($_config_dir as $directory) {
|
|
||||||
$directory = realpath($directory);
|
|
||||||
$this->_resource_dir[$directory] = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// rebuild secure dir index
|
|
||||||
if ($_secure) {
|
|
||||||
$this->_secure_dir = $this->secure_dir;
|
|
||||||
foreach ((array) $this->secure_dir as $directory) {
|
|
||||||
$directory = realpath($directory);
|
|
||||||
$this->_resource_dir[$directory] = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$_filepath = realpath($filepath);
|
|
||||||
$directory = dirname($_filepath);
|
|
||||||
$_directory = array();
|
|
||||||
while (true) {
|
|
||||||
// remember the directory to add it to _resource_dir in case we're successful
|
|
||||||
$_directory[$directory] = true;
|
|
||||||
// test if the directory is trusted
|
|
||||||
if (isset($this->_resource_dir[$directory])) {
|
|
||||||
// merge sub directories of current $directory into _resource_dir to speed up subsequent lookup
|
|
||||||
$this->_resource_dir = array_merge($this->_resource_dir, $_directory);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
// abort if we've reached root
|
|
||||||
if (($pos = strrpos($directory, DS)) === false || !isset($directory[1])) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
// bubble up one level
|
|
||||||
$directory = substr($directory, 0, $pos);
|
|
||||||
}
|
|
||||||
|
|
||||||
// give up
|
|
||||||
throw new SmartyException("directory '{$_filepath}' not allowed by security setting");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if URI (e.g. {fetch} or {html_image}) is trusted
|
|
||||||
* To simplify things, isTrustedUri() resolves all input to "{$PROTOCOL}://{$HOSTNAME}".
|
|
||||||
* So "http://username:password@hello.world.example.org:8080/some-path?some=query-string"
|
|
||||||
* is reduced to "http://hello.world.example.org" prior to applying the patters from {@link $trusted_uri}.
|
|
||||||
*
|
|
||||||
* @param string $uri
|
|
||||||
*
|
|
||||||
* @return boolean true if URI is trusted
|
|
||||||
* @throws SmartyException if URI is not trusted
|
|
||||||
* @uses $trusted_uri for list of patterns to match against $uri
|
|
||||||
*/
|
|
||||||
public function isTrustedUri($uri)
|
|
||||||
{
|
|
||||||
$_uri = parse_url($uri);
|
|
||||||
if (!empty($_uri['scheme']) && !empty($_uri['host'])) {
|
|
||||||
$_uri = $_uri['scheme'] . '://' . $_uri['host'];
|
|
||||||
foreach ($this->trusted_uri as $pattern) {
|
|
||||||
if (preg_match($pattern, $_uri)) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
throw new SmartyException("URI '{$uri}' not allowed by security setting");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if directory of file resource is trusted.
|
|
||||||
*
|
|
||||||
* @param string $filepath
|
|
||||||
*
|
|
||||||
* @return boolean true if directory is trusted
|
|
||||||
* @throws SmartyException if PHP directory is not trusted
|
|
||||||
*/
|
|
||||||
public function isTrustedPHPDir($filepath)
|
|
||||||
{
|
|
||||||
if (empty($this->trusted_dir)) {
|
|
||||||
throw new SmartyException("directory '{$filepath}' not allowed by security setting (no trusted_dir specified)");
|
|
||||||
}
|
|
||||||
|
|
||||||
// check if index is outdated
|
|
||||||
if (!$this->_trusted_dir || $this->_trusted_dir !== $this->trusted_dir) {
|
|
||||||
$this->_php_resource_dir = array();
|
|
||||||
|
|
||||||
$this->_trusted_dir = $this->trusted_dir;
|
|
||||||
foreach ((array) $this->trusted_dir as $directory) {
|
|
||||||
$directory = realpath($directory);
|
|
||||||
$this->_php_resource_dir[$directory] = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$_filepath = realpath($filepath);
|
|
||||||
$directory = dirname($_filepath);
|
|
||||||
$_directory = array();
|
|
||||||
while (true) {
|
|
||||||
// remember the directory to add it to _resource_dir in case we're successful
|
|
||||||
$_directory[] = $directory;
|
|
||||||
// test if the directory is trusted
|
|
||||||
if (isset($this->_php_resource_dir[$directory])) {
|
|
||||||
// merge sub directories of current $directory into _resource_dir to speed up subsequent lookup
|
|
||||||
$this->_php_resource_dir = array_merge($this->_php_resource_dir, $_directory);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
// abort if we've reached root
|
|
||||||
if (($pos = strrpos($directory, DS)) === false || !isset($directory[2])) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
// bubble up one level
|
|
||||||
$directory = substr($directory, 0, $pos);
|
|
||||||
}
|
|
||||||
|
|
||||||
throw new SmartyException("directory '{$_filepath}' not allowed by security setting");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,163 +1,195 @@
|
|||||||
<?
|
<?
|
||||||
$DEBGU_ALL_OVERRIDE = 0; // set to 1 to debug on live/remote server locations
|
$DEBUG_ALL_OVERRIDE = 0; // set to 1 to debug on live/remote server locations
|
||||||
$DEBUG_ALL = 1;
|
$DEBUG_ALL = 1;
|
||||||
$PRINT_ALL = 1;
|
$PRINT_ALL = 1;
|
||||||
$DB_DEBUG = 1;
|
$DB_DEBUG = 1;
|
||||||
|
|
||||||
if ($DEBUG_ALL)
|
if ($DEBUG_ALL) {
|
||||||
error_reporting(E_ALL | E_STRICT | E_ERROR | E_WARNING | E_PARSE | E_COMPILE_ERROR);
|
error_reporting(E_ALL | E_STRICT | E_ERROR | E_WARNING | E_PARSE | E_COMPILE_ERROR);
|
||||||
|
}
|
||||||
|
|
||||||
define('USE_DATABASE', true);
|
define('USE_DATABASE', true);
|
||||||
// sample config
|
// sample config
|
||||||
require("config.inc");
|
require("config.inc");
|
||||||
// set session name
|
// set session name
|
||||||
DEFINE('SET_SESSION_NAME', EDIT_SESSION_NAME);
|
DEFINE('SET_SESSION_NAME', EDIT_SESSION_NAME);
|
||||||
// session_name(EDIT_SESSION_NAME);
|
// session_name(EDIT_SESSION_NAME);
|
||||||
// session_start();
|
// session_start();
|
||||||
// basic class test file
|
// basic class test file
|
||||||
// require(LIBS."Class.Basic.inc");
|
foreach (array ('Login', 'Admin.Backend') as $class) {
|
||||||
// require(LIBS."Class.DB.IO.inc");
|
_spl_autoload('Class.'.$class.'.inc');
|
||||||
require(LIBS."Class.Login.inc");
|
}
|
||||||
require(LIBS."Class.Admin.Backend.inc");
|
|
||||||
|
|
||||||
$lang = 'en_utf8';
|
$lang = 'en_utf8';
|
||||||
|
|
||||||
$login = new login($DB_CONFIG[LOGIN_DB], $lang);
|
DEFINE('LOG_FILE_ID', 'classTest');
|
||||||
// init with standard
|
$login = new login($DB_CONFIG[LOGIN_DB], $lang);
|
||||||
|
// init with standard
|
||||||
// $basic = new db_io($DB_CONFIG[MAIN_DB]);
|
// $basic = new db_io($DB_CONFIG[MAIN_DB]);
|
||||||
$basic = new AdminBackend($DB_CONFIG[MAIN_DB], $lang);
|
$basic = new AdminBackend($DB_CONFIG[MAIN_DB], $lang);
|
||||||
$basic->db_info(1);
|
$basic->db_info(1);
|
||||||
|
|
||||||
// set + check edit access id
|
// set + check edit access id
|
||||||
$edit_access_id = 3;
|
$edit_access_id = 3;
|
||||||
if ($login->login_check_edit_access($edit_access_id))
|
print "ACL UNIT: ".print_r(array_keys($login->acl['unit']), 1)."<br>";
|
||||||
$basic->edit_access_id = $edit_access_id;
|
print "ACCESS CHECK: ".$login->login_check_edit_access($edit_access_id)."<br>";
|
||||||
else
|
if ($login->login_check_edit_access($edit_access_id)) {
|
||||||
$basic->edit_access_id = $login->acl['info']['default_edit_access'];
|
$basic->edit_access_id = $edit_access_id;
|
||||||
|
} else {
|
||||||
|
$basic->edit_access_id = $login->acl['unit_id'];
|
||||||
|
}
|
||||||
|
|
||||||
// $basic->debug('SESSION', $basic->print_ar($_SESSION));
|
// $basic->debug('SESSION', $basic->print_ar($_SESSION));
|
||||||
|
|
||||||
print "<html><head><title>TEST CLASS</title><head>";
|
print "<html><head><title>TEST CLASS</title><head>";
|
||||||
print "<body>";
|
print "<body>";
|
||||||
print '<form method="post" name="loginlogout">';
|
print '<form method="post" name="loginlogout">';
|
||||||
print '<a href="javascript:document.loginlogout.login_logout.value=\'Logou\';document.loginlogout.submit();">Logout</a>';
|
print '<a href="javascript:document.loginlogout.login_logout.value=\'Logou\';document.loginlogout.submit();">Logout</a>';
|
||||||
print '<input type="hidden" name="login_logout" value="">';
|
print '<input type="hidden" name="login_logout" value="">';
|
||||||
print '</form>';
|
print '</form>';
|
||||||
|
|
||||||
// print the debug core vars
|
// print the debug core vars
|
||||||
print "DEBUG OUT: ".$basic->debug_output."<br>";
|
print "DEBUG OUT: ".$basic->debug_output."<br>";
|
||||||
print "ECHO OUT: ".$basic->echo_output."<br>";
|
print "ECHO OUT: ".$basic->echo_output."<br>";
|
||||||
print "PRINT OUT: ".$basic->print_output."<br>";
|
print "PRINT OUT: ".$basic->print_output."<br>";
|
||||||
print "NOT DEBUG OUT: ".$basic->debug_output_not."<br>";
|
print "NOT DEBUG OUT: ".$basic->debug_output_not."<br>";
|
||||||
print "NOT ECHO OUT: ".$basic->echo_output_not."<br>";
|
print "NOT ECHO OUT: ".$basic->echo_output_not."<br>";
|
||||||
print "NOT PRINT OUT: ".$basic->print_output_not."<br>";
|
print "NOT PRINT OUT: ".$basic->print_output_not."<br>";
|
||||||
print "DEBUG OUT ALL: ".$basic->debug_output_all."<br>";
|
print "DEBUG OUT ALL: ".$basic->debug_output_all."<br>";
|
||||||
print "ECHO OUT ALL: ".$basic->echo_output_all."<br>";
|
print "ECHO OUT ALL: ".$basic->echo_output_all."<br>";
|
||||||
print "PRINT OUT ALL: ".$basic->print_output_all."<br>";
|
print "PRINT OUT ALL: ".$basic->print_output_all."<br>";
|
||||||
// file name (logging)
|
|
||||||
print "FILENAME EXT: ".$basic->file_name_ext."<br>";
|
|
||||||
print "MAX FILESIZE: ".$basic->max_filesize."<br>";
|
|
||||||
|
|
||||||
print "CALLER BACKTRACE: ".$basic->get_caller_method()."<br>";
|
print "CALLER BACKTRACE: ".$basic->get_caller_method()."<br>";
|
||||||
$basic->debug('SOME MARK', 'Some error output');
|
$basic->debug('SOME MARK', 'Some error output');
|
||||||
|
|
||||||
print "EDIT ACCESS ID: ".$basic->edit_access_id."<br>";
|
print "EDIT ACCESS ID: ".$basic->edit_access_id."<br>";
|
||||||
// print "ACL: <br>".$basic->print_ar($login->acl)."<br>";
|
// print "ACL: <br>".$basic->print_ar($login->acl)."<br>";
|
||||||
$basic->debug('ACL', "ACL: ".$basic->print_ar($login->acl));
|
$basic->debug('ACL', "ACL: ".$basic->print_ar($login->acl));
|
||||||
// print "DEFAULT ACL: <br>".$basic->print_ar($login->default_acl_list)."<br>";
|
// print "DEFAULT ACL: <br>".$basic->print_ar($login->default_acl_list)."<br>";
|
||||||
// print "DEFAULT ACL: <br>".$basic->print_ar($login->default_acl_list)."<br>";
|
// print "DEFAULT ACL: <br>".$basic->print_ar($login->default_acl_list)."<br>";
|
||||||
// $result = array_flip(array_filter(array_flip($login->default_acl_list), function ($key) { if (is_numeric($key)) return $key; }));
|
// $result = array_flip(array_filter(array_flip($login->default_acl_list), function ($key) { if (is_numeric($key)) return $key; }));
|
||||||
// print "DEFAULT ACL: <br>".$basic->print_ar($result)."<br>";
|
// print "DEFAULT ACL: <br>".$basic->print_ar($result)."<br>";
|
||||||
// DEPRICATED CALL
|
// DEPRICATED CALL
|
||||||
// $basic->adbSetACL($login->acl);
|
// $basic->adbSetACL($login->acl);
|
||||||
|
|
||||||
while ($res = $basic->db_return("SELECT * FROM max_test"))
|
while ($res = $basic->db_return("SELECT * FROM max_test")) {
|
||||||
{
|
print "TIME: ".$res['time']."<br>";
|
||||||
print "TIME: ".$res['time']."<br>";
|
}
|
||||||
}
|
|
||||||
|
|
||||||
$status = $basic->db_exec("INSERT INTO foo (test) VALUES ('FOO TEST ".time()."') RETURNING test");
|
$status = $basic->db_exec("INSERT INTO foo (test) VALUES ('FOO TEST ".time()."') RETURNING test");
|
||||||
print "DIRECT INSERT STATUS: $status | PRIMARY KEY: ".$basic->insert_id."<br>";
|
print "DIRECT INSERT STATUS: $status | PRIMARY KEY: ".$basic->insert_id." | PRIMARY KEY EXT: ".print_r($basic->insert_id_ext, 1)."<br>";
|
||||||
print "DIRECT INSERT PREVIOUS INSERTED: ".print_r($basic->db_return_row("SELECT foo_id, test FROM foo WHERE foo_id = ".$basic->insert_id), 1)."<br>";
|
print "DIRECT INSERT PREVIOUS INSERTED: ".print_r($basic->db_return_row("SELECT foo_id, test FROM foo WHERE foo_id = ".$basic->insert_id), 1)."<br>";
|
||||||
$basic->db_prepare("ins_foo", "INSERT INTO foo (test) VALUES ($1)");
|
$basic->db_prepare("ins_foo", "INSERT INTO foo (test) VALUES ($1)");
|
||||||
$status = $basic->db_execute("ins_foo", array('BAR TEST '.time()));
|
$status = $basic->db_execute("ins_foo", array('BAR TEST '.time()));
|
||||||
print "PREPARE INSERT STATUS: $status | PRIMARY KEY: ".$basic->insert_id."<br>";
|
print "PREPARE INSERT STATUS: $status | PRIMARY KEY: ".$basic->insert_id." | PRIMARY KEY EXT: ".print_r($basic->insert_id_ext, 1)."<br>";
|
||||||
print "PREPARE INSERT PREVIOUS INSERTED: ".print_r($basic->db_return_row("SELECT foo_id, test FROM foo WHERE foo_id = ".$basic->insert_id), 1)."<br>";
|
print "PREPARE INSERT PREVIOUS INSERTED: ".print_r($basic->db_return_row("SELECT foo_id, test FROM foo WHERE foo_id = ".$basic->insert_id), 1)."<br>";
|
||||||
|
// returning test with multiple entries
|
||||||
|
// $status = $basic->db_exec("INSERT INTO foo (test) values ('BAR 1 ".time()."'), ('BAR 2 ".time()."'), ('BAR 3 ".time()."') RETURNING foo_id");
|
||||||
|
$status = $basic->db_exec("INSERT INTO foo (test) values ('BAR 1 ".time()."'), ('BAR 2 ".time()."'), ('BAR 3 ".time()."') RETURNING foo_id, test");
|
||||||
|
print "DIRECT MULTIPLE INSERT STATUS: $status | PRIMARY KEYS: ".print_r($basic->insert_id, 1)." | PRIMARY KEY EXT: ".print_r($basic->insert_id_ext, 1)."<br>";
|
||||||
|
// no returning, but not needed ;
|
||||||
|
$status = $basic->db_exec("INSERT INTO foo (test) VALUES ('FOO; TEST ".time()."');");
|
||||||
|
print "DIRECT INSERT STATUS: $status | PRIMARY KEY: ".$basic->insert_id." | PRIMARY KEY EXT: ".print_r($basic->insert_id_ext, 1)."<br>";
|
||||||
|
|
||||||
# async test queries
|
# db write class test
|
||||||
|
$table = 'foo';
|
||||||
|
print "TABLE META DATA: ".$basic->print_ar($basic->db_show_table_meta_data($table))."<br>";
|
||||||
|
$primary_key = ''; # unset
|
||||||
|
$db_write_table = array ('test', 'string_a', 'number_a', 'some_bool');
|
||||||
|
// $db_write_table = array ('test');
|
||||||
|
$object_fields_not_touch = array ();
|
||||||
|
$object_fields_not_update = array ();
|
||||||
|
$data = array ('test' => 'BOOL TEST SOMETHING '.time(), 'string_a' => 'SOME TEXT', 'number_a' => 5);
|
||||||
|
$primary_key = $basic->db_write_data_ext($db_write_table, $primary_key, $table, $object_fields_not_touch, $object_fields_not_update, $data);
|
||||||
|
print "Wrote to DB tabel $table and got primary key $primary_key<br>";
|
||||||
|
$data = array ('test' => 'BOOL TEST ON '.time(), 'string_a' => '', 'number_a' => 0, 'some_bool' => 1);
|
||||||
|
$primary_key = $basic->db_write_data_ext($db_write_table, $primary_key, $table, $object_fields_not_touch, $object_fields_not_update, $data);
|
||||||
|
print "Wrote to DB tabel $table and got primary key $primary_key<br>";
|
||||||
|
$data = array ('test' => 'BOOL TEST OFF '.time(), 'string_a' => null, 'number_a' => null, 'some_bool' => 0);
|
||||||
|
$primary_key = $basic->db_write_data_ext($db_write_table, $primary_key, $table, $object_fields_not_touch, $object_fields_not_update, $data);
|
||||||
|
print "Wrote to DB tabel $table and got primary key $primary_key<br>";
|
||||||
|
$data = array ('test' => 'BOOL TEST UNSET '.time());
|
||||||
|
$primary_key = $basic->db_write_data_ext($db_write_table, $primary_key, $table, $object_fields_not_touch, $object_fields_not_update, $data);
|
||||||
|
print "Wrote to DB tabel $table and got primary key $primary_key<br>";
|
||||||
|
|
||||||
|
# async test queries
|
||||||
/* $basic->db_exec_async("SELECT test FROM foo, (SELECT pg_sleep(10)) as sub WHERE foo_id IN (27, 50, 67, 44, 10)");
|
/* $basic->db_exec_async("SELECT test FROM foo, (SELECT pg_sleep(10)) as sub WHERE foo_id IN (27, 50, 67, 44, 10)");
|
||||||
echo "WAITING FOR ASYNC: ";
|
echo "WAITING FOR ASYNC: ";
|
||||||
$chars = array('|', '/', '-', '\\');
|
$chars = array('|', '/', '-', '\\');
|
||||||
while (($ret = $basic->db_check_async()) === true)
|
while (($ret = $basic->db_check_async()) === true)
|
||||||
|
{
|
||||||
|
if ((list($_, $char) = each($chars)) === FALSE)
|
||||||
{
|
{
|
||||||
if ((list($_, $char) = each($chars)) === FALSE)
|
reset($chars);
|
||||||
{
|
list($_, $char) = each($chars);
|
||||||
reset($chars);
|
|
||||||
list($_, $char) = each($chars);
|
|
||||||
}
|
|
||||||
print $char;
|
|
||||||
sleep(1);
|
|
||||||
flush();
|
|
||||||
}
|
}
|
||||||
print "<br>END STATUS: ".$ret."<br>";
|
print $char;
|
||||||
|
sleep(1);
|
||||||
|
flush();
|
||||||
|
}
|
||||||
|
print "<br>END STATUS: ".$ret."<br>";
|
||||||
// while ($res = $basic->db_fetch_array($ret))
|
// while ($res = $basic->db_fetch_array($ret))
|
||||||
while ($res = $basic->db_fetch_array())
|
while ($res = $basic->db_fetch_array())
|
||||||
{
|
{
|
||||||
echo "RES: ".$res['test']."<br>";
|
echo "RES: ".$res['test']."<br>";
|
||||||
}
|
}
|
||||||
# test async insert
|
# test async insert
|
||||||
$basic->db_exec_async("INSERT INTO foo (Test) VALUES ('ASYNC TEST ".time()."')");
|
$basic->db_exec_async("INSERT INTO foo (Test) VALUES ('ASYNC TEST ".time()."')");
|
||||||
echo "WAITING FOR ASYNC INSERT: ";
|
echo "WAITING FOR ASYNC INSERT: ";
|
||||||
while (($ret = $basic->db_check_async()) === true)
|
while (($ret = $basic->db_check_async()) === true)
|
||||||
{
|
{
|
||||||
print ".";
|
print ".";
|
||||||
sleep(1);
|
sleep(1);
|
||||||
flush();
|
flush();
|
||||||
}
|
}
|
||||||
print "<br>END STATUS: ".$ret." | PK: ".$basic->insert_id."<br>";
|
print "<br>END STATUS: ".$ret." | PK: ".$basic->insert_id."<br>";
|
||||||
print "ASYNC PREVIOUS INSERTED: ".print_r($basic->db_return_row("SELECT foo_id, test FROM foo WHERE foo_id = ".$basic->insert_id), 1)."<br>"; */
|
print "ASYNC PREVIOUS INSERTED: ".print_r($basic->db_return_row("SELECT foo_id, test FROM foo WHERE foo_id = ".$basic->insert_id), 1)."<br>"; */
|
||||||
|
|
||||||
$to_db_version = '9.1.9';
|
$to_db_version = '9.1.9';
|
||||||
print "VERSION DB: ".$basic->db_version()."<br>";
|
print "VERSION DB: ".$basic->db_version()."<br>";
|
||||||
print "DB Version smaller $to_db_version: ".$basic->db_compare_version('<'.$to_db_version)."<br>";
|
print "DB Version smaller $to_db_version: ".$basic->db_compare_version('<'.$to_db_version)."<br>";
|
||||||
print "DB Version smaller than $to_db_version: ".$basic->db_compare_version('<='.$to_db_version)."<br>";
|
print "DB Version smaller than $to_db_version: ".$basic->db_compare_version('<='.$to_db_version)."<br>";
|
||||||
print "DB Version equal $to_db_version: ".$basic->db_compare_version('='.$to_db_version)."<br>";
|
print "DB Version equal $to_db_version: ".$basic->db_compare_version('='.$to_db_version)."<br>";
|
||||||
print "DB Version bigger than $to_db_version: ".$basic->db_compare_version('>='.$to_db_version)."<br>";
|
print "DB Version bigger than $to_db_version: ".$basic->db_compare_version('>='.$to_db_version)."<br>";
|
||||||
print "DB Version bigger $to_db_version: ".$basic->db_compare_version('>'.$to_db_version)."<br>";
|
print "DB Version bigger $to_db_version: ".$basic->db_compare_version('>'.$to_db_version)."<br>";
|
||||||
|
|
||||||
$q = "SELECT FOO FRO BAR";
|
/* $q = "SELECT FOO FRO BAR";
|
||||||
// $q = "Select * from foo";
|
// $q = "Select * from foo";
|
||||||
$foo = $basic->db_exec_async($q);
|
$foo = $basic->db_exec_async($q);
|
||||||
print "[ERR] Query: ".$q."<br>";
|
print "[ERR] Query: ".$q."<br>";
|
||||||
print "[ERR] RESOURCE: $foo<br>";
|
print "[ERR] RESOURCE: $foo<br>";
|
||||||
while (($ret = $basic->db_check_async()) === true)
|
while (($ret = $basic->db_check_async()) === true)
|
||||||
{
|
{
|
||||||
print "[ERR]: $ret<br>";
|
print "[ERR]: $ret<br>";
|
||||||
// sleep(5);
|
// sleep(5);
|
||||||
}
|
} */
|
||||||
|
|
||||||
// search path check
|
// search path check
|
||||||
$q = "SHOW search_path";
|
$q = "SHOW search_path";
|
||||||
$cursor = $basic->db_exec($q);
|
$cursor = $basic->db_exec($q);
|
||||||
$data = $basic->db_fetch_array($cursor)['search_path'];
|
$data = $basic->db_fetch_array($cursor)['search_path'];
|
||||||
print "RETURN DATA FOR search_path: ".$data."<br>";
|
print "RETURN DATA FOR search_path: ".$data."<br>";
|
||||||
// print "RETURN DATA FOR search_path: ".$basic->print_ar($data)."<br>";
|
// print "RETURN DATA FOR search_path: ".$basic->print_ar($data)."<br>";
|
||||||
// insert something into test.schema_test and see if we get the PK back
|
// insert something into test.schema_test and see if we get the PK back
|
||||||
$status = $basic->db_exec("INSERT INTO test.schema_test (contents, id) VALUES ('TIME: ".time()."', ".rand(1, 10).")");
|
$status = $basic->db_exec("INSERT INTO test.schema_test (contents, id) VALUES ('TIME: ".time()."', ".rand(1, 10).")");
|
||||||
print "OTHER SCHEMA INSERT STATUS: ".$status." | PK NAME: ".$basic->pk_name.", PRIMARY KEY: ".$basic->insert_id."<br>";
|
print "OTHER SCHEMA INSERT STATUS: ".$status." | PK NAME: ".$basic->pk_name.", PRIMARY KEY: ".$basic->insert_id."<br>";
|
||||||
|
|
||||||
// time string thest
|
// time string thest
|
||||||
$timestamp = 5887998.33445;
|
$timestamp = 5887998.33445;
|
||||||
$time_string = $basic->TimeStringFormat($timestamp);
|
$time_string = $basic->TimeStringFormat($timestamp);
|
||||||
print "TIME STRING TEST: ".$time_string."<br>";
|
print "TIME STRING TEST: ".$time_string."<br>";
|
||||||
print "REVERSE TIME STRING: ".$basic->StringToTime($time_string);
|
print "REVERSE TIME STRING: ".$basic->StringToTime($time_string);
|
||||||
|
|
||||||
// magic links test
|
// magic links test
|
||||||
print $basic->magic_links('user@bubu.at').'<br>';
|
print $basic->magic_links('user@bubu.at').'<br>';
|
||||||
print $basic->magic_links('http://test.com/foo/bar.php?foo=1').'<br>';
|
print $basic->magic_links('http://test.com/foo/bar.php?foo=1').'<br>';
|
||||||
|
|
||||||
// print error messages
|
// compare date
|
||||||
print $basic->print_error_msg();
|
$date_1 = '2017/1/5';
|
||||||
|
$date_2 = '2017-01-05';
|
||||||
|
print "COMPARE DATE: ".$basic->CompareDate($date_1, $date_2)."<br>";
|
||||||
|
|
||||||
print "</body></html>";
|
// print error messages
|
||||||
?>
|
print $basic->print_error_msg();
|
||||||
|
|
||||||
|
print "</body></html>";
|
||||||
|
|||||||
@@ -1,340 +1,324 @@
|
|||||||
<?
|
<?
|
||||||
/********************************************************************
|
/********************************************************************
|
||||||
* AUTHOR: Clemens "Gullevek" Schwaighofer (www.gullevek.org)
|
* AUTHOR: Clemens "Gullevek" Schwaighofer (www.gullevek.org)
|
||||||
* CREATED: 2003/06/10
|
* CREATED: 2003/06/10
|
||||||
* SHORT DESCRIPTION:
|
* SHORT DESCRIPTION:
|
||||||
* central include for all edit_pages
|
* central include for all edit_pages
|
||||||
* - edit_groups.php
|
* - edit_groups.php
|
||||||
* - edit_languages.php
|
* - edit_languages.php
|
||||||
* - edit_pages.php
|
* - edit_pages.php
|
||||||
* - edit_schemes.php
|
* - edit_schemes.php
|
||||||
* - edit_users.php
|
* - edit_users.php
|
||||||
* - edit_visible_group.php
|
* - edit_visible_group.php
|
||||||
* HISTORY:
|
* HISTORY:
|
||||||
* 2005/06/30 (cs) remove color settings, they are in CSS File now
|
* 2005/06/30 (cs) remove color settings, they are in CSS File now
|
||||||
* 2005/06/22 (cs) moved load of config array into form class, set lang and lang is must set var for form class; removed the page name setting, moved it into the form class, remove all HTML from main page
|
* 2005/06/22 (cs) moved load of config array into form class, set lang and lang is must set var for form class; removed the page name setting, moved it into the form class, remove all HTML from main page
|
||||||
* 2004/09/30 (cs) changed layout to fit default layout & changed LIBS, etc
|
* 2004/09/30 (cs) changed layout to fit default layout & changed LIBS, etc
|
||||||
* 2003-06-10: creation of this page
|
* 2003-06-10: creation of this page
|
||||||
*********************************************************************/
|
*********************************************************************/
|
||||||
|
|
||||||
$DEBUG_ALL = 1;
|
$DEBUG_ALL = 1;
|
||||||
$DB_DEBUG = 1;
|
$DB_DEBUG = 1;
|
||||||
|
|
||||||
extract($_POST, EXTR_SKIP);
|
extract($_POST, EXTR_SKIP);
|
||||||
|
|
||||||
$table_width = 750;
|
$table_width = 750;
|
||||||
// this is for certain CMS modules that set a relative path
|
// this is for certain CMS modules that set a relative path
|
||||||
define(REL_PATH, '');
|
define(REL_PATH, '');
|
||||||
|
|
||||||
ob_start();
|
ob_start();
|
||||||
include("config.inc");
|
include("config.inc");
|
||||||
// overrride debug flags
|
// overrride debug flags
|
||||||
if (!DEBUG)
|
if (!DEBUG) {
|
||||||
{
|
$DEBUG_ALL = 0;
|
||||||
$DEBUG_ALL = 0;
|
$PRINT_ALL = 0;
|
||||||
$PRINT_ALL = 0;
|
$DB_DEBUG = 0;
|
||||||
$DB_DEBUG = 0;
|
$ECHO_ALL = 0;
|
||||||
$ECHO_ALL = 0;
|
|
||||||
// $DEBUG_TMPL = 0;
|
// $DEBUG_TMPL = 0;
|
||||||
}
|
}
|
||||||
// set session name here
|
// set session name here
|
||||||
define('SET_SESSION_NAME', EDIT_SESSION_NAME);
|
define('SET_SESSION_NAME', EDIT_SESSION_NAME);
|
||||||
// login class
|
// login class
|
||||||
require(LIBS."Class.Login.inc");
|
require(LIBS."Class.Login.inc");
|
||||||
// form generate for edit interface
|
// form generate for edit interface
|
||||||
require(LIBS."Class.Form.Generate.inc");
|
require(LIBS."Class.Form.Generate.inc");
|
||||||
// Smarty: and the small extend for l10n calls
|
// Smarty: and the small extend for l10n calls
|
||||||
require(LIBS.'Class.Smarty.Extend.inc');
|
require(LIBS.'Class.Smarty.Extend.inc');
|
||||||
|
|
||||||
// set default lang if not set otherwise
|
// set default lang if not set otherwise
|
||||||
if (!$lang)
|
if (!$lang) {
|
||||||
$lang = DEFAULT_LANG;
|
$lang = DEFAULT_LANG;
|
||||||
// should be utf8
|
}
|
||||||
header("Content-type: text/html; charset=".DEFAULT_ENCODING);
|
// should be utf8
|
||||||
ob_end_flush();
|
header("Content-type: text/html; charset=".DEFAULT_ENCODING);
|
||||||
$login = new login($DB_CONFIG[LOGIN_DB], $lang);
|
ob_end_flush();
|
||||||
|
$login = new login($DB_CONFIG[LOGIN_DB], $lang);
|
||||||
|
|
||||||
// create form class
|
// create form class
|
||||||
$form = new form($DB_CONFIG[MAIN_DB], $lang);
|
$form = new form($DB_CONFIG[MAIN_DB], $lang);
|
||||||
$form->db_exec("SET search_path TO ".LOGIN_DB_SCHEMA);
|
$form->db_exec("SET search_path TO ".LOGIN_DB_SCHEMA);
|
||||||
if ($form->mobile_phone)
|
if ($form->mobile_phone) {
|
||||||
{
|
echo "I am sorry, but this page cannot be viewed by a mobile phone";
|
||||||
echo "I am sorry, but this page cannot be viewed by a mobile phone";
|
exit;
|
||||||
exit;
|
}
|
||||||
}
|
// smarty template engine (extended Translation version)
|
||||||
// smarty template engine (extended Translation version)
|
$smarty = new SmartyML($lang);
|
||||||
$smarty = new SmartyML($lang);
|
|
||||||
|
|
||||||
if (TARGET == 'live' || TARGET == 'remote')
|
|
||||||
{
|
|
||||||
// login
|
|
||||||
$login->debug_output_all = DEBUG ? 1 : 0;
|
|
||||||
$login->echo_output_all = 0;
|
|
||||||
$login->print_output_all = DEBUG ? 1 : 0;
|
|
||||||
// form
|
|
||||||
$form->debug_output_all = DEBUG ? 1 : 0;
|
|
||||||
$form->echo_output_all = 0;
|
|
||||||
$form->print_output_all = DEBUG ? 1 : 0;
|
|
||||||
}
|
|
||||||
// set the template dir
|
|
||||||
// WARNING: this has a special check for the mailing tool layout (old layout)
|
|
||||||
if (defined('LAYOUT'))
|
|
||||||
{
|
|
||||||
$smarty->setTemplateDir(LAYOUT.DEFAULT_TEMPLATE.TEMPLATES);
|
|
||||||
$DATA['css'] = LAYOUT.DEFAULT_TEMPLATE.CSS;
|
|
||||||
$DATA['js'] = LAYOUT.DEFAULT_TEMPLATE.JS;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$smarty->setTemplateDir(TEMPLATES.DEFAULT_TEMPLATE);
|
|
||||||
$DATA['css'] = CSS.DEFAULT_TEMPLATE;
|
|
||||||
$DATA['js'] = JS.DEFAULT_TEMPLATE;
|
|
||||||
}
|
|
||||||
|
|
||||||
// space for setting special debug flags
|
if (TARGET == 'live' || TARGET == 'remote') {
|
||||||
$login->debug_output_all = 1;
|
// login
|
||||||
|
$login->debug_output_all = DEBUG ? 1 : 0;
|
||||||
|
$login->echo_output_all = 0;
|
||||||
|
$login->print_output_all = DEBUG ? 1 : 0;
|
||||||
|
// form
|
||||||
|
$form->debug_output_all = DEBUG ? 1 : 0;
|
||||||
|
$form->echo_output_all = 0;
|
||||||
|
$form->print_output_all = DEBUG ? 1 : 0;
|
||||||
|
}
|
||||||
|
// set the template dir
|
||||||
|
// WARNING: this has a special check for the mailing tool layout (old layout)
|
||||||
|
if (defined('LAYOUT')) {
|
||||||
|
$smarty->setTemplateDir(LAYOUT.DEFAULT_TEMPLATE.TEMPLATES);
|
||||||
|
$DATA['css'] = LAYOUT.DEFAULT_TEMPLATE.CSS;
|
||||||
|
$DATA['js'] = LAYOUT.DEFAULT_TEMPLATE.JS;
|
||||||
|
} else {
|
||||||
|
$smarty->setTemplateDir(TEMPLATES.DEFAULT_TEMPLATE);
|
||||||
|
$DATA['css'] = CSS.DEFAULT_TEMPLATE;
|
||||||
|
$DATA['js'] = JS.DEFAULT_TEMPLATE;
|
||||||
|
}
|
||||||
|
|
||||||
// define edit logging function. should be in a special edit interface class later
|
// space for setting special debug flags
|
||||||
// METHOD: EditLog()
|
$login->debug_output_all = 1;
|
||||||
// PARAMS: event -> any kind of event description, data -> any kind of data related to that event
|
|
||||||
// RETURN: none
|
|
||||||
// DESC: writes all action vars plus other info into edit_log table
|
|
||||||
function EditLog($event = '', $data = '')
|
|
||||||
{
|
|
||||||
$q = "INSERT INTO edit_log ";
|
|
||||||
$q .= "(euid, event_date, ip, event, data, page) ";
|
|
||||||
$q .= "VALUES (".$_SESSION['EUID'].", NOW(), '".$_SERVER["REMOTE_ADDR"]."', '".$GLOBALS['form']->db_escape_string($event)."', '".$GLOBALS['form']->db_escape_string($data)."', '".$GLOBALS['form']->get_page_name()."')";
|
|
||||||
}
|
|
||||||
|
|
||||||
// log backend data
|
// define edit logging function. should be in a special edit interface class later
|
||||||
// data part creation
|
// METHOD: EditLog()
|
||||||
$data = array (
|
// PARAMS: event -> any kind of event description, data -> any kind of data related to that event
|
||||||
'_SESSION' => $_SESSION,
|
// RETURN: none
|
||||||
'_GET' => $_GET,
|
// DESC: writes all action vars plus other info into edit_log table
|
||||||
'_POST' => $_POST,
|
function EditLog($event = '', $data = '')
|
||||||
'_FILES' => $_FILES
|
{
|
||||||
);
|
$q = "INSERT INTO edit_log ";
|
||||||
// log action
|
$q .= "(euid, event_date, ip, event, data, page) ";
|
||||||
EditLog('Edit Submit', serialize($data));
|
$q .= "VALUES (".$_SESSION['EUID'].", NOW(), '".$_SERVER["REMOTE_ADDR"]."', '".$GLOBALS['form']->db_escape_string($event)."', '".$GLOBALS['form']->db_escape_string($data)."', '".$GLOBALS['form']->get_page_name()."')";
|
||||||
|
}
|
||||||
|
|
||||||
$form->form_procedure_load(${$form->archive_pk_name});
|
// log backend data
|
||||||
$form->form_procedure_new();
|
// data part creation
|
||||||
$form->form_procedure_save();
|
$data = array (
|
||||||
$form->form_procedure_delete();
|
'_SESSION' => $_SESSION,
|
||||||
$form->form_procedure_delete_from_element_list($element_list, $remove_name);
|
'_GET' => $_GET,
|
||||||
|
'_POST' => $_POST,
|
||||||
|
'_FILES' => $_FILES
|
||||||
|
);
|
||||||
|
// log action
|
||||||
|
EditLog('Edit Submit', serialize($data));
|
||||||
|
|
||||||
// define all needed smarty stuff for the general HTML/page building
|
$form->form_procedure_load(${$form->archive_pk_name});
|
||||||
$HEADER['CSS'] = CSS;
|
$form->form_procedure_new();
|
||||||
$HEADER['DEFAULT_ENCODING'] = DEFAULT_ENCODING;
|
$form->form_procedure_save();
|
||||||
$HEADER['JS'] = JS;
|
$form->form_procedure_delete();
|
||||||
$HEADER['STYLESHEET'] = $EDIT_STYLESHEET;
|
$form->form_procedure_delete_from_element_list($element_list, $remove_name);
|
||||||
$HEADER['JAVASCRIPT'] = $EDIT_JAVASCRIPT;
|
|
||||||
|
|
||||||
$DATA['table_width'] = $table_width;
|
// define all needed smarty stuff for the general HTML/page building
|
||||||
|
$HEADER['CSS'] = CSS;
|
||||||
|
$HEADER['DEFAULT_ENCODING'] = DEFAULT_ENCODING;
|
||||||
|
$HEADER['JS'] = JS;
|
||||||
|
$HEADER['STYLESHEET'] = $EDIT_STYLESHEET;
|
||||||
|
$HEADER['JAVASCRIPT'] = $EDIT_JAVASCRIPT;
|
||||||
|
|
||||||
// write out error / status messages
|
$DATA['table_width'] = $table_width;
|
||||||
$messages[] = $form->form_error_msg();
|
|
||||||
$DATA['form_error_msg'] = $messages;
|
|
||||||
|
|
||||||
// MENU START
|
// write out error / status messages
|
||||||
// request some session vars
|
$messages[] = $form->form_error_msg();
|
||||||
if (!$HEADER_COLOR)
|
$DATA['form_error_msg'] = $messages;
|
||||||
$DATA['HEADER_COLOR'] = "#E0E2FF";
|
|
||||||
else
|
// MENU START
|
||||||
$DATA['HEADER_COLOR'] = $_SESSION['HEADER_COLOR'];
|
// request some session vars
|
||||||
$DATA['USER_NAME'] = $_SESSION["USER_NAME"];
|
if (!$HEADER_COLOR) {
|
||||||
$DATA['EUID'] = $_SESSION["EUID"];
|
$DATA['HEADER_COLOR'] = "#E0E2FF";
|
||||||
$DATA['GROUP_NAME'] = $_SESSION["GROUP_NAME"];
|
} else {
|
||||||
$DATA['GROUP_LEVEL'] = $_SESSION["GROUP_LEVEL"];
|
$DATA['HEADER_COLOR'] = $_SESSION['HEADER_COLOR'];
|
||||||
$PAGES = $_SESSION["PAGES"];
|
}
|
||||||
|
$DATA['USER_NAME'] = $_SESSION["USER_NAME"];
|
||||||
|
$DATA['EUID'] = $_SESSION["EUID"];
|
||||||
|
$DATA['GROUP_NAME'] = $_SESSION["GROUP_NAME"];
|
||||||
|
$DATA['GROUP_LEVEL'] = $_SESSION["GROUP_LEVEL"];
|
||||||
|
$PAGES = $_SESSION["PAGES"];
|
||||||
|
|
||||||
//$form->debug('menu', $form->print_ar($PAGES));
|
//$form->debug('menu', $form->print_ar($PAGES));
|
||||||
|
|
||||||
// baue nav aus $PAGES ...
|
// baue nav aus $PAGES ...
|
||||||
for ($i = 0; $i < count($PAGES); $i ++)
|
for ($i = 0; $i < count($PAGES); $i ++) {
|
||||||
{
|
if ($PAGES[$i]["menu"] && $PAGES[$i]["online"]) {
|
||||||
if ($PAGES[$i]["menu"] && $PAGES[$i]["online"])
|
$menuarray[] = $PAGES[$i];
|
||||||
{
|
|
||||||
$menuarray[] = $PAGES[$i];
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// split point for nav points
|
// split point for nav points
|
||||||
$COUNT_NAV_POINTS = count($menuarray);
|
$COUNT_NAV_POINTS = count($menuarray);
|
||||||
$SPLIT_FACTOR = 3;
|
$SPLIT_FACTOR = 3;
|
||||||
$START_SPLIT_COUNT = 3;
|
$START_SPLIT_COUNT = 3;
|
||||||
// WTF ?? I dunno what I am doing here ...
|
// WTF ?? I dunno what I am doing here ...
|
||||||
for ($i = 9; $i < $COUNT_NAV_POINTS; $i += $START_SPLIT_COUNT)
|
for ($i = 9; $i < $COUNT_NAV_POINTS; $i += $START_SPLIT_COUNT) {
|
||||||
{
|
if ($COUNT_NAV_POINTS > $i) {
|
||||||
if ($COUNT_NAV_POINTS > $i)
|
$SPLIT_FACTOR += 1;
|
||||||
$SPLIT_FACTOR += 1;
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
for ($i = 1; $i <= count($menuarray); $i ++)
|
for ($i = 1; $i <= count($menuarray); $i ++) {
|
||||||
{
|
// do that for new array
|
||||||
// do that for new array
|
$j = $i - 1;
|
||||||
$j = $i - 1;
|
$menu_data[$j]['pagename'] = htmlentities($menuarray[($i-1)]["page_name"]);
|
||||||
$menu_data[$j]['pagename'] = htmlentities($menuarray[($i-1)]["page_name"]);
|
$menu_data[$j]['filename'] = $menuarray[($i-1)]["filename"].$menuarray[($i-1)]["query_string"];
|
||||||
$menu_data[$j]['filename'] = $menuarray[($i-1)]["filename"].$menuarray[($i-1)]["query_string"];
|
if ($i == 1 || !(($i - 1) % $SPLIT_FACTOR)) {
|
||||||
if ($i == 1 || !(($i - 1) % $SPLIT_FACTOR))
|
$menu_data[$j]['splitfactor_in'] = 1;
|
||||||
{
|
}
|
||||||
$menu_data[$j]['splitfactor_in'] = 1;
|
if ($menuarray[($i - 1)]["filename"] == $form->get_page_name()) {
|
||||||
}
|
$position = $i - 1;
|
||||||
if ($menuarray[($i - 1)]["filename"] == $form->get_page_name())
|
$menu_data[$j]['position'] = 1;
|
||||||
{
|
} else {
|
||||||
$position = $i - 1;
|
// add query stuff
|
||||||
$menu_data[$j]['position'] = 1;
|
// HAS TO DONE LATER ... set urlencode, etc ...
|
||||||
}
|
// check if popup needed
|
||||||
else
|
if ($menuarray[($i - 1)]["popup"]) {
|
||||||
{
|
$menu_data[$j]['popup'] = 1;
|
||||||
// add query stuff
|
$menu_data[$j]['rand'] = uniqid(rand());
|
||||||
// HAS TO DONE LATER ... set urlencode, etc ...
|
$menu_data[$j]['width'] = $menuarray[($i-1)]["popup_x"];
|
||||||
// check if popup needed
|
$menu_data[$j]['height'] = $menuarray[($i-1)]["popup_y"];
|
||||||
if ($menuarray[($i - 1)]["popup"])
|
} // popup or not
|
||||||
{
|
} // highlight or not
|
||||||
$menu_data[$j]['popup'] = 1;
|
if (!($i % $SPLIT_FACTOR) || (($i + 1) > count($menuarray))) {
|
||||||
$menu_data[$j]['rand'] = uniqid(rand());
|
$menu_data[$j]['splitfactor_out'] = 1;
|
||||||
$menu_data[$j]['width'] = $menuarray[($i-1)]["popup_x"];
|
} // split
|
||||||
$menu_data[$j]['height'] = $menuarray[($i-1)]["popup_y"];
|
} // for
|
||||||
} // popup or not
|
$DATA['menu_data'] = $menu_data;
|
||||||
} // highlight or not
|
$DATA['page_name'] = $menuarray[$position]["page_name"];
|
||||||
if (!($i % $SPLIT_FACTOR) || (($i + 1) > count($menuarray)))
|
$L_TITLE = $DATA['page_name'];
|
||||||
{
|
// html title
|
||||||
$menu_data[$j]['splitfactor_out'] = 1;
|
$HEADER['HTML_TITLE'] = ((!$L_TITLE) ? $form->l->__($G_TITLE) : $form->l->__($L_TITLE));
|
||||||
} // split
|
// END MENU
|
||||||
} // for
|
// LOAD AND NEW
|
||||||
$DATA['menu_data'] = $menu_data;
|
$DATA['load'] = $form->form_create_load();
|
||||||
$DATA['page_name'] = $menuarray[$position]["page_name"];
|
$DATA['new'] = $form->form_create_new();
|
||||||
$L_TITLE = $DATA['page_name'];
|
// SHOW DATA PART
|
||||||
// html title
|
if ($form->yes) {
|
||||||
$HEADER['HTML_TITLE'] = ((!$L_TITLE) ? $form->l->__($G_TITLE) : $form->l->__($L_TITLE));
|
$DATA['form_yes'] = $form->yes;
|
||||||
// END MENU
|
$DATA['form_my_page_name'] = $form->my_page_name;
|
||||||
// LOAD AND NEW
|
|
||||||
$DATA['load'] = $form->form_create_load();
|
|
||||||
$DATA['new'] = $form->form_create_new();
|
|
||||||
// SHOW DATA PART
|
|
||||||
if ($form->yes)
|
|
||||||
{
|
|
||||||
$DATA['form_yes'] = $form->yes;
|
|
||||||
$DATA['form_my_page_name'] = $form->my_page_name;
|
|
||||||
|
|
||||||
// depending on the "get_page_name()" I show different stuff
|
// depending on the "get_page_name()" I show different stuff
|
||||||
switch ($form->my_page_name)
|
switch ($form->my_page_name) {
|
||||||
{
|
case "edit_users":
|
||||||
case "edit_users":
|
$elements[] = $form->form_create_element("login_error_count");
|
||||||
$elements[] = $form->form_create_element("login_error_count");
|
$elements[] = $form->form_create_element("login_error_date_last");
|
||||||
$elements[] = $form->form_create_element("login_error_date_last");
|
$elements[] = $form->form_create_element("login_error_date_first");
|
||||||
$elements[] = $form->form_create_element("login_error_date_first");
|
$elements[] = $form->form_create_element("enabled");
|
||||||
$elements[] = $form->form_create_element("enabled");
|
$elements[] = $form->form_create_element("username");
|
||||||
$elements[] = $form->form_create_element("username");
|
$elements[] = $form->form_create_element("password");
|
||||||
$elements[] = $form->form_create_element("password");
|
$elements[] = $form->form_create_element("password_change_interval");
|
||||||
$elements[] = $form->form_create_element("password_change_interval");
|
$elements[] = $form->form_create_element("email");
|
||||||
$elements[] = $form->form_create_element("email");
|
$elements[] = $form->form_create_element("last_name");
|
||||||
$elements[] = $form->form_create_element("edit_group_id");
|
$elements[] = $form->form_create_element("first_name");
|
||||||
$elements[] = $form->form_create_element("edit_access_right_id");
|
$elements[] = $form->form_create_element("edit_group_id");
|
||||||
$elements[] = $form->form_create_element("strict");
|
$elements[] = $form->form_create_element("edit_access_right_id");
|
||||||
$elements[] = $form->form_create_element("locked");
|
$elements[] = $form->form_create_element("strict");
|
||||||
$elements[] = $form->form_create_element("admin");
|
$elements[] = $form->form_create_element("locked");
|
||||||
$elements[] = $form->form_create_element("debug");
|
$elements[] = $form->form_create_element("admin");
|
||||||
$elements[] = $form->form_create_element("db_debug");
|
$elements[] = $form->form_create_element("debug");
|
||||||
$elements[] = $form->form_create_element("edit_language_id");
|
$elements[] = $form->form_create_element("db_debug");
|
||||||
$elements[] = $form->form_create_element("edit_scheme_id");
|
$elements[] = $form->form_create_element("edit_language_id");
|
||||||
$elements[] = $form->form_show_list_table("edit_access_user");
|
$elements[] = $form->form_create_element("edit_scheme_id");
|
||||||
|
$elements[] = $form->form_show_list_table("edit_access_user");
|
||||||
break;
|
break;
|
||||||
case "edit_schemes":
|
case "edit_schemes":
|
||||||
$elements[] = $form->form_create_element("enabled");
|
$elements[] = $form->form_create_element("enabled");
|
||||||
$elements[] = $form->form_create_element("name");
|
$elements[] = $form->form_create_element("name");
|
||||||
$elements[] = $form->form_create_element("header_color");
|
$elements[] = $form->form_create_element("header_color");
|
||||||
$elements[] = $form->form_create_element("template");
|
$elements[] = $form->form_create_element("template");
|
||||||
break;
|
break;
|
||||||
case "edit_pages":
|
case "edit_pages":
|
||||||
if (!$form->table_array["edit_page_id"]["value"])
|
if (!$form->table_array["edit_page_id"]["value"]) {
|
||||||
{
|
$q = "DELETE FROM temp_files";
|
||||||
$q = "DELETE FROM temp_files";
|
$form->db_exec($q);
|
||||||
$form->db_exec($q);
|
// gets all files in the current dir ending with .php
|
||||||
// gets all files in the current dir ending with .php
|
$crap = exec("ls *.php", $output, $status);
|
||||||
$crap = exec("ls *.php", $output, $status);
|
// now get all that are NOT in de DB
|
||||||
// now get all that are NOT in de DB
|
$q = "INSERT INTO temp_files VALUES ";
|
||||||
$q = "INSERT INTO temp_files VALUES ";
|
for ($i = 0; $i < count($output); $i ++) {
|
||||||
for ($i = 0; $i < count($output); $i ++)
|
$t_q = "('".$form->db_escape_string($output[$i])."')";
|
||||||
{
|
$form->db_exec($q.$t_q, 'NULL');
|
||||||
$t_q = "('".$form->db_escape_string($output[$i])."')";
|
|
||||||
$form->db_exec($q.$t_q, 'NULL');
|
|
||||||
}
|
|
||||||
$elements[] = $form->form_create_element("filename");
|
|
||||||
}
|
}
|
||||||
else // show file menu
|
$elements[] = $form->form_create_element("filename");
|
||||||
{
|
} else {
|
||||||
// just show name of file ...
|
// show file menu
|
||||||
$DATA['filename_exist'] = 1;
|
// just show name of file ...
|
||||||
$DATA['filename'] = $form->table_array["filename"]["value"];
|
$DATA['filename_exist'] = 1;
|
||||||
} // File Name View IF
|
$DATA['filename'] = $form->table_array["filename"]["value"];
|
||||||
$elements[] = $form->form_create_element("name");
|
} // File Name View IF
|
||||||
// $elements[] = $form->form_create_element("tag");
|
$elements[] = $form->form_create_element("name");
|
||||||
// $elements[] = $form->form_create_element("min_acl");
|
// $elements[] = $form->form_create_element("tag");
|
||||||
$elements[] = $form->form_create_element("order_number");
|
// $elements[] = $form->form_create_element("min_acl");
|
||||||
$elements[] = $form->form_create_element("online");
|
$elements[] = $form->form_create_element("order_number");
|
||||||
$elements[] = $form->form_create_element("menu");
|
$elements[] = $form->form_create_element("online");
|
||||||
$elements[] = $form->form_show_list_table("edit_query_string");
|
$elements[] = $form->form_create_element("menu");
|
||||||
$elements[] = $form->form_create_element("popup");
|
$elements[] = $form->form_show_list_table("edit_query_string");
|
||||||
$elements[] = $form->form_create_element("popup_x");
|
$elements[] = $form->form_create_element("popup");
|
||||||
$elements[] = $form->form_create_element("popup_y");
|
$elements[] = $form->form_create_element("popup_x");
|
||||||
$elements[] = $form->form_show_reference_table("edit_visible_group");
|
$elements[] = $form->form_create_element("popup_y");
|
||||||
$elements[] = $form->form_show_reference_table("edit_menu_group");
|
$elements[] = $form->form_show_reference_table("edit_visible_group");
|
||||||
|
$elements[] = $form->form_show_reference_table("edit_menu_group");
|
||||||
break;
|
break;
|
||||||
case "edit_languages":
|
case "edit_languages":
|
||||||
$elements[] = $form->form_create_element("enabled");
|
$elements[] = $form->form_create_element("enabled");
|
||||||
$elements[] = $form->form_create_element("short_name");
|
$elements[] = $form->form_create_element("short_name");
|
||||||
$elements[] = $form->form_create_element("long_name");
|
$elements[] = $form->form_create_element("long_name");
|
||||||
$elements[] = $form->form_create_element("iso_name");
|
$elements[] = $form->form_create_element("iso_name");
|
||||||
break;
|
break;
|
||||||
case "edit_groups":
|
case "edit_groups":
|
||||||
$elements[] = $form->form_create_element("enabled");
|
$elements[] = $form->form_create_element("enabled");
|
||||||
$elements[] = $form->form_create_element("name");
|
$elements[] = $form->form_create_element("name");
|
||||||
$elements[] = $form->form_create_element("edit_access_right_id");
|
$elements[] = $form->form_create_element("edit_access_right_id");
|
||||||
$elements[] = $form->form_create_element("edit_scheme_id");
|
$elements[] = $form->form_create_element("edit_scheme_id");
|
||||||
$elements[] = $form->form_show_list_table("edit_page_access");
|
$elements[] = $form->form_show_list_table("edit_page_access");
|
||||||
break;
|
break;
|
||||||
case "edit_visible_group":
|
case "edit_visible_group":
|
||||||
$elements[] = $form->form_create_element("name");
|
$elements[] = $form->form_create_element("name");
|
||||||
$elements[] = $form->form_create_element("flag");
|
$elements[] = $form->form_create_element("flag");
|
||||||
break;
|
break;
|
||||||
case "edit_menu_group":
|
case "edit_menu_group":
|
||||||
$elements[] = $form->form_create_element("name");
|
$elements[] = $form->form_create_element("name");
|
||||||
$elements[] = $form->form_create_element("flag");
|
$elements[] = $form->form_create_element("flag");
|
||||||
$elements[] = $form->form_create_element("order_number");
|
$elements[] = $form->form_create_element("order_number");
|
||||||
break;
|
break;
|
||||||
case "edit_access":
|
case "edit_access":
|
||||||
$elements[] = $form->form_create_element("name");
|
$elements[] = $form->form_create_element("name");
|
||||||
$elements[] = $form->form_create_element("color");
|
$elements[] = $form->form_create_element("color");
|
||||||
$elements[] = $form->form_create_element("description");
|
$elements[] = $form->form_create_element("description");
|
||||||
|
// add name/value list here
|
||||||
|
$elements[] = $form->form_show_list_table("edit_access_data");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
print "NO NO NOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOO!";
|
print "[No valid page definition given]";
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
//$form->debug('edit', "Elements: <pre>".$form->print_ar($elements));
|
|
||||||
$DATA['elements'] = $elements;
|
|
||||||
$DATA['hidden'] = $form->form_create_hidden_fields();
|
|
||||||
$DATA['save_delete'] = $form->form_create_save_delete();
|
|
||||||
}
|
|
||||||
|
|
||||||
// debug data, if DEBUG flag is on, this data is print out
|
|
||||||
$DEBUG_DATA['DEBUG'] = $DEBUG_TMPL;
|
|
||||||
|
|
||||||
// create main data array
|
|
||||||
$CONTENT_DATA = array_merge($HEADER, $DATA, $DEBUG_DATA);
|
|
||||||
// data is 1:1 mapping (all vars, values, etc)
|
|
||||||
while (list($key, $value) = each($CONTENT_DATA))
|
|
||||||
{
|
|
||||||
$smarty->assign($key, $value);
|
|
||||||
}
|
}
|
||||||
|
// $form->debug('edit', "Elements: <pre>".$form->print_ar($elements));
|
||||||
|
$DATA['elements'] = $elements;
|
||||||
|
$DATA['hidden'] = $form->form_create_hidden_fields();
|
||||||
|
$DATA['save_delete'] = $form->form_create_save_delete();
|
||||||
|
}
|
||||||
|
|
||||||
|
// debug data, if DEBUG flag is on, this data is print out
|
||||||
|
$DEBUG_DATA['DEBUG'] = $DEBUG_TMPL;
|
||||||
|
|
||||||
|
// create main data array
|
||||||
|
$CONTENT_DATA = array_merge($HEADER, $DATA, $DEBUG_DATA);
|
||||||
|
// data is 1:1 mapping (all vars, values, etc)
|
||||||
|
while (list($key, $value) = each($CONTENT_DATA)) {
|
||||||
|
$smarty->assign($key, $value);
|
||||||
|
}
|
||||||
|
|
||||||
// $smarty->assign('popup_page', 'mt_popup_'.$body_part.'.tpl');
|
// $smarty->assign('popup_page', 'mt_popup_'.$body_part.'.tpl');
|
||||||
|
|
||||||
$smarty->display('edit_body.tpl');
|
$smarty->display('edit_body.tpl');
|
||||||
|
|
||||||
// debug output
|
// debug output
|
||||||
echo $login->print_error_msg();
|
echo $login->print_error_msg();
|
||||||
echo $form->print_error_msg();
|
echo $form->print_error_msg();
|
||||||
?>
|
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
<?
|
<?
|
||||||
/********************************************************************
|
/********************************************************************
|
||||||
* AUTHOR: Clemens Schwaighofer
|
* AUTHOR: Clemens Schwaighofer
|
||||||
* CREATED: 2001/07/11
|
* CREATED: 2001/07/11
|
||||||
* SHORT DESCRIPTION:
|
* SHORT DESCRIPTION:
|
||||||
* sets the order from a table (edit_)
|
* sets the order from a table (edit_)
|
||||||
* HISTORY:
|
* HISTORY:
|
||||||
* 2005/07/11 (cs) adept to new edit interface
|
* 2005/07/11 (cs) adept to new edit interface
|
||||||
* 2002-10-18: little include changes
|
* 2002-10-18: little include changes
|
||||||
@@ -67,7 +67,7 @@
|
|||||||
$smarty->setTemplateDir(TEMPLATES.DEFAULT_TEMPLATE);
|
$smarty->setTemplateDir(TEMPLATES.DEFAULT_TEMPLATE);
|
||||||
$DATA['css'] = CSS.DEFAULT_TEMPLATE;
|
$DATA['css'] = CSS.DEFAULT_TEMPLATE;
|
||||||
$DATA['js'] = JS.DEFAULT_TEMPLATE;
|
$DATA['js'] = JS.DEFAULT_TEMPLATE;
|
||||||
}
|
}
|
||||||
|
|
||||||
// order name is _always_ order_number for the edit interface
|
// order name is _always_ order_number for the edit interface
|
||||||
|
|
||||||
@@ -125,7 +125,7 @@
|
|||||||
// get ...
|
// get ...
|
||||||
$q = "SELECT ".$table_name."_id, name, order_number FROM ".$table_name." ";
|
$q = "SELECT ".$table_name."_id, name, order_number FROM ".$table_name." ";
|
||||||
if ($where_string)
|
if ($where_string)
|
||||||
$q .= "WHERE $where_string ";
|
$q .= "WHERE $where_string ";
|
||||||
$q .= "ORDER BY order_number";
|
$q .= "ORDER BY order_number";
|
||||||
|
|
||||||
while ($res = $db->db_return($q))
|
while ($res = $db->db_return($q))
|
||||||
|
|||||||
18
www/admin/error_test.php
Normal file
18
www/admin/error_test.php
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$DEBUG_ALL_OVERRIDE = 0; // set to 1 to debug on live/remote server locations
|
||||||
|
$DEBUG_ALL = 1;
|
||||||
|
$PRINT_ALL = 1;
|
||||||
|
$DB_DEBUG = 1;
|
||||||
|
|
||||||
|
if ($DEBUG_ALL) {
|
||||||
|
error_reporting(E_ALL);
|
||||||
|
}
|
||||||
|
|
||||||
|
// sample config
|
||||||
|
require("config.inc");
|
||||||
|
require(LIBS."Error.Handling.inc");
|
||||||
|
|
||||||
|
if ($var) {
|
||||||
|
echo "OUT<br>";
|
||||||
|
}
|
||||||
@@ -1,486 +1,456 @@
|
|||||||
<?
|
<?
|
||||||
/********************************************************************
|
/********************************************************************
|
||||||
* AUTHOR: Clemens Schwaighofer
|
* AUTHOR: Clemens Schwaighofer
|
||||||
* CREATED: 2005/07/13
|
* CREATED: 2005/07/13
|
||||||
* SHORT DESCRIPTION:
|
* SHORT DESCRIPTION:
|
||||||
* Create categories for CMS
|
* Create categories for CMS
|
||||||
* HISTORY:
|
* HISTORY:
|
||||||
* 2005/08/19 (cs) changed the mime type get from the _FILE to mime get fkt
|
* 2005/08/19 (cs) changed the mime type get from the _FILE to mime get fkt
|
||||||
*********************************************************************/
|
*********************************************************************/
|
||||||
|
|
||||||
// DEBUG vars here
|
// DEBUG vars here
|
||||||
$DEBUG_ALL = 1;
|
$DEBUG_ALL = 1;
|
||||||
$DB_DEBUG = 1;
|
$DB_DEBUG = 1;
|
||||||
$DEBUG_TMPL = 1;
|
$DEBUG_TMPL = 1;
|
||||||
|
|
||||||
//------------------------------ header
|
//------------------------------ header
|
||||||
require("header.inc");
|
require("header.inc");
|
||||||
$MASTER_TEMPLATE_NAME = 'cms_popup.tpl';
|
$MASTER_TEMPLATE_NAME = 'cms_popup.tpl';
|
||||||
$TEMPLATE_NAME = 'cms_files.tpl';
|
$TEMPLATE_NAME = 'cms_files.tpl';
|
||||||
$PAGE_WIDTH = 750;
|
$PAGE_WIDTH = 750;
|
||||||
require("set_paths.inc");
|
require("set_paths.inc");
|
||||||
//------------------------------ header
|
//------------------------------ header
|
||||||
|
|
||||||
//------------------------------ processing data start
|
//------------------------------ processing data start
|
||||||
$form_name = $_GET['form'];
|
$form_name = $_GET['form'];
|
||||||
$value_name = $_GET['name'];
|
$value_name = $_GET['name'];
|
||||||
$data_id = $_GET['id'];
|
$data_id = $_GET['id'];
|
||||||
$show_type = $_GET['type']; // P (pic), F (flash), V (video), D (document: word), A (document: pdf), B (binary); , separated string
|
$show_type = $_GET['type']; // P (pic), F (flash), V (video), D (document: word), A (document: pdf), B (binary); , separated string
|
||||||
|
|
||||||
// default view is list
|
// default view is list
|
||||||
if (!$view && !$data_id)
|
if (!$view && !$data_id) {
|
||||||
$view = 'list';
|
$view = 'list';
|
||||||
elseif (!$view && $data_id)
|
} elseif (!$view && $data_id) {
|
||||||
$view = 'list';
|
$view = 'list';
|
||||||
// default is online
|
}
|
||||||
if (!isset($online))
|
// default is online
|
||||||
$online = 't';
|
if (!isset($online)) {
|
||||||
// if not set, it is a fresh load
|
$online = 't';
|
||||||
if (!$show_amount)
|
}
|
||||||
$fresh_load = 1;
|
// if not set, it is a fresh load
|
||||||
// the next two are for page view
|
if (!$show_amount) {
|
||||||
if (!$start_row)
|
$fresh_load = 1;
|
||||||
$start_row = 0;
|
}
|
||||||
if (!$show_amount)
|
// the next two are for page view
|
||||||
$show_amount = 12;
|
if (!$start_row) {
|
||||||
if (!$show_type)
|
$start_row = 0;
|
||||||
$show_type = 'P';
|
}
|
||||||
|
if (!$show_amount) {
|
||||||
|
$show_amount = 12;
|
||||||
|
}
|
||||||
|
if (!$show_type) {
|
||||||
|
$show_type = 'P';
|
||||||
|
}
|
||||||
|
|
||||||
// yes no list (online)
|
// yes no list (online)
|
||||||
$yesno_list['f'] = 'No';
|
$yesno_list['f'] = 'No';
|
||||||
$yesno_list['t'] = 'Yes';
|
$yesno_list['t'] = 'Yes';
|
||||||
// order list
|
// order list
|
||||||
$sort_order_list['date_created'] = 'ID / Insert time'; // default
|
$sort_order_list['date_created'] = 'ID / Insert time'; // default
|
||||||
$sort_order_list['file_name'] = 'File Name';
|
$sort_order_list['file_name'] = 'File Name';
|
||||||
$sort_order_list['file_size'] = 'File Size';
|
$sort_order_list['file_size'] = 'File Size';
|
||||||
$sort_order_list['mime_type'] = 'Mime Type';
|
$sort_order_list['mime_type'] = 'Mime Type';
|
||||||
$sort_order_list['name_en'] = 'Alt Name English';
|
$sort_order_list['name_en'] = 'Alt Name English';
|
||||||
$sort_order_list['name_ja'] = 'Alt Name Japanese';
|
$sort_order_list['name_ja'] = 'Alt Name Japanese';
|
||||||
$sort_order_list['date_updated'] = 'Updated';
|
$sort_order_list['date_updated'] = 'Updated';
|
||||||
if (!$sort_order)
|
if (!$sort_order) {
|
||||||
$sort_order = 'date_created';
|
$sort_order = 'date_created';
|
||||||
$sort_direction_list['ASC'] = 'Normal';
|
}
|
||||||
$sort_direction_list['DESC'] = 'Reverse';
|
$sort_direction_list['ASC'] = 'Normal';
|
||||||
if (!$sort_direction)
|
$sort_direction_list['DESC'] = 'Reverse';
|
||||||
$sort_direction = 'ASC';
|
if (!$sort_direction) {
|
||||||
// set if we need to write to any of the set live queues
|
$sort_direction = 'ASC';
|
||||||
// a) on page save with set_live
|
}
|
||||||
// b) global page with live_queue
|
// set if we need to write to any of the set live queues
|
||||||
// set via QUEUE variable
|
// a) on page save with set_live
|
||||||
|
// b) global page with live_queue
|
||||||
|
// set via QUEUE variable
|
||||||
|
|
||||||
// create 0 entries for: templates, menu, data_group?
|
// create 0 entries for: templates, menu, data_group?
|
||||||
if ($cms->action == 'new' && $cms->action_yes == 'true')
|
if ($cms->action == 'new' && $cms->action_yes == 'true') {
|
||||||
{
|
unset($file_uid);
|
||||||
unset($file_uid);
|
unset($file_id);
|
||||||
unset($file_id);
|
unset($file_type);
|
||||||
unset($file_type);
|
$new_okay = 1;
|
||||||
$new_okay = 1;
|
}
|
||||||
|
// file type: P picture, M mouse over picutre, F flash, V video, B binary
|
||||||
|
if ($cms->action == 'save') {
|
||||||
|
if (!$file_type) {
|
||||||
|
$file_type = 'B';
|
||||||
}
|
}
|
||||||
// file type: P picture, M mouse over picutre, F flash, V video, B binary
|
$file_ok = false;
|
||||||
if ($cms->action == 'save')
|
if (!$_FILES['file_up']['name'] && !$file_uid) {
|
||||||
{
|
$cms->messages[] = array('msg' => 'No file name given', 'class' => 'error');
|
||||||
if (!$file_type)
|
$error = 1;
|
||||||
$file_type = 'B';
|
}
|
||||||
$file_ok = false;
|
if (!$_FILES['file_up']['name'] && $file_uid) {
|
||||||
if (!$_FILES['file_up']['name'] && !$file_uid)
|
$file_ok = true;
|
||||||
{
|
}
|
||||||
$cms->messages[] = array('msg' => 'No file name given', 'class' => 'error');
|
// echo "FILE TYPE: ".$_FILES['file_up']['type']."<br>";
|
||||||
|
foreach (split(',', $show_type) as $_show_type) {
|
||||||
|
// check if the uploaded filename matches to the given type
|
||||||
|
if ($_FILES['file_up']['name'] && preg_match("/jpeg|png|gif/", $_FILES['file_up']['type']) && preg_match("/P/", $show_type)) {
|
||||||
|
$file_ok = true;
|
||||||
|
}
|
||||||
|
if ($_FILES['file_up']['name'] && preg_match("/swf/", $_FILES['file_up']['type']) && preg_match("/F/", $show_type)) {
|
||||||
|
$file_ok = true;
|
||||||
|
}
|
||||||
|
if ($_FILES['file_up']['name'] && preg_match("/video/", $_FILES['file_up']['type']) && preg_match("/V/", $show_type)) {
|
||||||
|
$file_ok = true;
|
||||||
|
}
|
||||||
|
if ($_FILES['file_up']['name'] && preg_match("/msword|vnd.oasis.opendocument.text/", $_FILES['file_up']['type']) && preg_match("/D/", $show_type)) {
|
||||||
|
$file_ok = true;
|
||||||
|
}
|
||||||
|
if ($_FILES['file_up']['name'] && preg_match("/pdf/", $_FILES['file_up']['type']) && preg_match("/A/", $show_type)) {
|
||||||
|
$file_ok = true;
|
||||||
|
}
|
||||||
|
if ($_FILES['file_up']['name'] && preg_match("/B/", $show_type)) {
|
||||||
|
$file_ok = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// write out error messages according to show type
|
||||||
|
if (!$file_ok) {
|
||||||
|
if (preg_match("/P/", $show_type)) {
|
||||||
|
$cms->messages[] = array('msg' => 'File is not a JPEG/PNG/GIF file', 'class' => 'error');
|
||||||
$error = 1;
|
$error = 1;
|
||||||
}
|
}
|
||||||
if (!$_FILES['file_up']['name'] && $file_uid)
|
if (preg_match("/F/", $show_type)) {
|
||||||
$file_ok = true;
|
$cms->messages[] = array('msg' => 'File is not a Flash File', 'class' => 'error');
|
||||||
// echo "FILE TYPE: ".$_FILES['file_up']['type']."<br>";
|
$error = 1;
|
||||||
foreach (split(',', $show_type) as $_show_type)
|
|
||||||
{
|
|
||||||
// check if the uploaded filename matches to the given type
|
|
||||||
if ($_FILES['file_up']['name'] && preg_match("/jpeg|png|gif/", $_FILES['file_up']['type']) && preg_match("/P/", $show_type))
|
|
||||||
{
|
|
||||||
$file_ok = true;
|
|
||||||
}
|
|
||||||
if ($_FILES['file_up']['name'] && preg_match("/swf/", $_FILES['file_up']['type']) && preg_match("/F/", $show_type))
|
|
||||||
{
|
|
||||||
$file_ok = true;
|
|
||||||
}
|
|
||||||
if ($_FILES['file_up']['name'] && preg_match("/video/", $_FILES['file_up']['type']) && preg_match("/V/", $show_type))
|
|
||||||
{
|
|
||||||
$file_ok = true;
|
|
||||||
}
|
|
||||||
if ($_FILES['file_up']['name'] && preg_match("/msword|vnd.oasis.opendocument.text/", $_FILES['file_up']['type']) && preg_match("/D/", $show_type))
|
|
||||||
{
|
|
||||||
$file_ok = true;
|
|
||||||
}
|
|
||||||
if ($_FILES['file_up']['name'] && preg_match("/pdf/", $_FILES['file_up']['type']) && preg_match("/A/", $show_type))
|
|
||||||
{
|
|
||||||
$file_ok = true;
|
|
||||||
}
|
|
||||||
if ($_FILES['file_up']['name'] && preg_match("/B/", $show_type))
|
|
||||||
$file_ok = true;
|
|
||||||
}
|
}
|
||||||
// write out error messages according to show type
|
if (preg_match("/V/", $show_type)) {
|
||||||
if (!$file_ok)
|
$cms->messages[] = array('msg' => 'File is not a Video', 'class' => 'error');
|
||||||
{
|
$error = 1;
|
||||||
if (preg_match("/P/", $show_type))
|
|
||||||
{
|
|
||||||
$cms->messages[] = array('msg' => 'File is not a JPEG/PNG/GIF file', 'class' => 'error');
|
|
||||||
$error = 1;
|
|
||||||
}
|
|
||||||
if (preg_match("/F/", $show_type))
|
|
||||||
{
|
|
||||||
$cms->messages[] = array('msg' => 'File is not a Flash File', 'class' => 'error');
|
|
||||||
$error = 1;
|
|
||||||
}
|
|
||||||
if (preg_match("/V/", $show_type))
|
|
||||||
{
|
|
||||||
$cms->messages[] = array('msg' => 'File is not a Video', 'class' => 'error');
|
|
||||||
$error = 1;
|
|
||||||
}
|
|
||||||
if (preg_match("/D/", $show_type))
|
|
||||||
{
|
|
||||||
$cms->messages[] = array('msg' => 'File is not a DOC/ODT file', 'class' => 'error');
|
|
||||||
$error = 1;
|
|
||||||
}
|
|
||||||
if (preg_match("/A/", $show_type))
|
|
||||||
{
|
|
||||||
$cms->messages[] = array('msg' => 'File is not a PDF file', 'class' => 'error');
|
|
||||||
$error = 1;
|
|
||||||
}
|
|
||||||
if (preg_match("/B/", $show_type))
|
|
||||||
{
|
|
||||||
$cms->messages[] = array('msg' => 'No valid file was given', 'class' => 'error');
|
|
||||||
$error = 1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
// binary: all okay
|
if (preg_match("/D/", $show_type)) {
|
||||||
// if no error, save data
|
$cms->messages[] = array('msg' => 'File is not a DOC/ODT file', 'class' => 'error');
|
||||||
if (!$error)
|
$error = 1;
|
||||||
{
|
|
||||||
if ($_FILES['file_up']['name'])
|
|
||||||
{
|
|
||||||
$mime_type = $_FILES['file_up']['type'];
|
|
||||||
$file_size = $_FILES['file_up']['size'];
|
|
||||||
$file_name = $_FILES['file_up']['name'];
|
|
||||||
// get picture size
|
|
||||||
list($width, $height) = getimagesize($_FILES['file_up']['tmp_name']);
|
|
||||||
$cms->debug('upload', "Width: $width X Height: $height");
|
|
||||||
// set the file type and the target folder
|
|
||||||
if (preg_match("/jpeg|png|gif/", $mime_type))
|
|
||||||
$file_type = 'P';
|
|
||||||
elseif (preg_match("/swf/", $mime_type))
|
|
||||||
$file_type = 'F';
|
|
||||||
elseif (preg_match("/video/", $mime_type))
|
|
||||||
$file_type = 'V';
|
|
||||||
elseif (preg_match("/msword|vnd.oasis.opendocument.text/", $mime_type))
|
|
||||||
$file_type = 'D';
|
|
||||||
elseif (preg_match("/pdf/", $mime_type))
|
|
||||||
$file_type = 'A';
|
|
||||||
elseif ($mime_type)
|
|
||||||
$file_type = 'B';
|
|
||||||
}
|
|
||||||
// if we have an id -> updated
|
|
||||||
if ($file_uid)
|
|
||||||
{
|
|
||||||
$q = "UPDATE file SET";
|
|
||||||
$q_set = " name_en = '".addslashes($name_en)."', name_ja = '".addslashes($name_ja)."', file_name = '".addslashes($file_name)."', online = '".$online."' ";
|
|
||||||
if ($_FILES['file_up']['name'])
|
|
||||||
{
|
|
||||||
$q_set .= ", type = '".$file_type."', mime_type = '$mime_type', file_size = $file_size, size_x = $width, size_y = $height ";
|
|
||||||
}
|
|
||||||
$q .= $q_set."WHERE file_uid = '".$file_uid."'";
|
|
||||||
$cms->db_exec($q);
|
|
||||||
if (QUEUE == 'live_queue')
|
|
||||||
{
|
|
||||||
$sql_action = 'UPDATE';
|
|
||||||
$sql_data = $q_set;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// insert new data
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$file_uid = md5(uniqid(rand(), true));
|
|
||||||
$q = "INSERT INTO file (name_en, name_ja, file_name, online, mime_type, file_size, size_x, size_y, file_uid, type) VALUES ('".addslashes($name_en)."', '".addslashes($name_ja)."', '".addslashes($file_name)."', '".$online."', '".$mime_type."', $file_size, ".(($width) ? $width : 'NULL').", ".(($height) ? $height : 'NULL').", '".$file_uid."', '".$file_type."')";
|
|
||||||
$cms->db_exec($q);
|
|
||||||
$file_id = $cms->insert_id;
|
|
||||||
// if queue
|
|
||||||
if (QUEUE == 'live_queue')
|
|
||||||
{
|
|
||||||
$sql_data = $q;
|
|
||||||
$sql_action = 'INSERT';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$size_x = $width;
|
|
||||||
$size_y = $height;
|
|
||||||
$file = DEV_SCHEMA."_".$file_uid;
|
|
||||||
// now upload the file
|
|
||||||
if ($_FILES['file_up']['name'])
|
|
||||||
{
|
|
||||||
$upload_file = ROOT.MEDIA.$cms->data_path[$file_type].$file;
|
|
||||||
// wipe out any old tmp data for this new upload
|
|
||||||
if (is_array(glob(ROOT.TMP."thumb_".$file."*")))
|
|
||||||
{
|
|
||||||
foreach (glob(ROOT.TMP."thumb_".$file."*") AS $filename)
|
|
||||||
@unlink($filename);
|
|
||||||
}
|
|
||||||
# copy file to correct path
|
|
||||||
$error = move_uploaded_file($_FILES['file_up']['tmp_name'], $upload_file);
|
|
||||||
|
|
||||||
$cms->debug('file_upload', "UP: $upload_file");
|
|
||||||
$cms->debug('file_upload', "Orig: ".$cms->print_ar($_FILES['file_up']));
|
|
||||||
|
|
||||||
// because I get bogus error info from move_uploaded_file ...
|
|
||||||
$error = 0;
|
|
||||||
if ($error)
|
|
||||||
{
|
|
||||||
$cms->debug('file_upload', "ERROR: $error | INI FSize: ".ini_get("upload_max_filesize"));
|
|
||||||
$cms->messages[] = array('msg' => 'File upload failed', 'class' => 'error');
|
|
||||||
$q = "DELETE FROM file WHERE file_uid = '".$file_uid."'";
|
|
||||||
$cms->db_exec($q);
|
|
||||||
unset($file_id);
|
|
||||||
unset($file_uid);
|
|
||||||
$view = 'list';
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$cms->messages[] = array('msg' => 'File upload successful', 'class' => 'warning');
|
|
||||||
// $vew = 'list';
|
|
||||||
}
|
|
||||||
} // if file upload
|
|
||||||
// create thumbs + file size
|
|
||||||
$picture = $cms->cache_pictures.$cms->adbCreateThumbnail($file, 400, 280, $file_type, '', $cms->cache_pictures_root);
|
|
||||||
$picture_small = $cms->cache_pictures.$cms->adbCreateThumbnail($file, 80, 60, $file_type, '', $cms->cache_pictures_root);
|
|
||||||
$file_size = $cms->adbByteStringFormat($file_size);
|
|
||||||
// for live queue this is here needed
|
|
||||||
if (QUEUE == 'live_queue')
|
|
||||||
{
|
|
||||||
$q = "INSERT INTO ".GLOBAL_DB_SCHEMA.".live_queue (queue_key, key_value, key_name, type, target, data, group_key, action";
|
|
||||||
if ($_FILES['file_up']['name'])
|
|
||||||
$q .= ", file";
|
|
||||||
$q .= ") VALUES ('".$cms->queue_name."', '".$file_uid."', 'file_uid', '".$sql_action."', 'file', '".$cms->db_escape_string($sql_data)."', '".$cms->queue_key."', '".$cms->action."'";
|
|
||||||
if ($_FILES['file_up']['name'])
|
|
||||||
$q .= ", '".ROOT.MEDIA.$cms->data_path[$file_type].$file."#".ROOT.MEDIA.$cms->data_path[$file_type].PUBLIC_SCHEMA."_".$file_uid."'";
|
|
||||||
$q .= ")";
|
|
||||||
$cms->db_exec($q);
|
|
||||||
}
|
|
||||||
} // if not error
|
|
||||||
}
|
|
||||||
if ($cms->action == 'delete' && $cms->action_yes == 'true')
|
|
||||||
{
|
|
||||||
$file_uid = $cms->action_id;
|
|
||||||
$q = "SELECT type FROM file WHERE file_uid = '".$file_uid."'";
|
|
||||||
list ($file_type) = $cms->db_return_row($q);
|
|
||||||
// get the file type for the file path
|
|
||||||
$q = "DELETE FROM file WHERE file_uid = '".$file_uid."'";
|
|
||||||
$cms->db_exec($q);
|
|
||||||
if (QUEUE == 'set_live')
|
|
||||||
{
|
|
||||||
$q = "INSERT INTO ".GLOBAL_DB_SCHEMA.".set_live (table_name, pkid, delete_flag) VALUES ('".$cms->page_name."', ".$file_uid.", 't')";
|
|
||||||
$cms->db_exec($q);
|
|
||||||
}
|
}
|
||||||
if (QUEUE == 'live_queue')
|
if (preg_match("/A/", $show_type)) {
|
||||||
{
|
$cms->messages[] = array('msg' => 'File is not a PDF file', 'class' => 'error');
|
||||||
$q = "INSERT INTO ".GLOBAL_DB_SCHEMA.".live_queue (queue_key, key_value, key_name, type, target, data, group_key, action, file) VALUES ('".$cms->queue_name."', '".$file_uid."', 'file_uid', 'DELETE', 'file', '', '".$cms->queue_key."', '".$cms->action."', '".ROOT.MEDIA.$cms->data_path[$file_type].PUBLIC_SCHEMA."_".$file_uid."')";
|
$error = 1;
|
||||||
|
}
|
||||||
|
if (preg_match("/B/", $show_type)) {
|
||||||
|
$cms->messages[] = array('msg' => 'No valid file was given', 'class' => 'error');
|
||||||
|
$error = 1;
|
||||||
}
|
}
|
||||||
@unlink(ROOT.MEDIA.$cms->data_path[$file_type].DEV_SCHEMA."_".$file_uid);
|
|
||||||
unset($file_uid);
|
|
||||||
unset($file_id);
|
|
||||||
$delete_done = 1;
|
|
||||||
$view = 'list';
|
|
||||||
}
|
}
|
||||||
if ($cms->action == 'load')
|
// binary: all okay
|
||||||
{
|
// if no error, save data
|
||||||
$file_uid = $cms->action_id;
|
if (!$error) {
|
||||||
// load the data
|
if ($_FILES['file_up']['name']) {
|
||||||
$q = "SELECT file_id, name_en, name_ja, file_name, online, mime_type, file_size, size_x, size_y, type FROM file WHERE file_uid = '".$file_uid."'";
|
$mime_type = $_FILES['file_up']['type'];
|
||||||
list($file_id, $name_en, $name_ja, $file_name, $online, $mime_type, $file_size, $size_x, $size_y, $file_type) = $cms->db_return_row($q);
|
$file_size = $_FILES['file_up']['size'];
|
||||||
// create thumbnail for edit view
|
$file_name = $_FILES['file_up']['name'];
|
||||||
|
// get picture size
|
||||||
|
list($width, $height) = getimagesize($_FILES['file_up']['tmp_name']);
|
||||||
|
$cms->debug('upload', "Width: $width X Height: $height");
|
||||||
|
// set the file type and the target folder
|
||||||
|
if (preg_match("/jpeg|png|gif/", $mime_type)) {
|
||||||
|
$file_type = 'P';
|
||||||
|
} elseif (preg_match("/swf/", $mime_type)) {
|
||||||
|
$file_type = 'F';
|
||||||
|
} elseif (preg_match("/video/", $mime_type)) {
|
||||||
|
$file_type = 'V';
|
||||||
|
} elseif (preg_match("/msword|vnd.oasis.opendocument.text/", $mime_type)) {
|
||||||
|
$file_type = 'D';
|
||||||
|
} elseif (preg_match("/pdf/", $mime_type)) {
|
||||||
|
$file_type = 'A';
|
||||||
|
} elseif ($mime_type) {
|
||||||
|
$file_type = 'B';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// if we have an id -> updated
|
||||||
|
if ($file_uid) {
|
||||||
|
$q = "UPDATE file SET";
|
||||||
|
$q_set = " name_en = '".addslashes($name_en)."', name_ja = '".addslashes($name_ja)."', file_name = '".addslashes($file_name)."', online = '".$online."' ";
|
||||||
|
if ($_FILES['file_up']['name']) {
|
||||||
|
$q_set .= ", type = '".$file_type."', mime_type = '$mime_type', file_size = $file_size, size_x = $width, size_y = $height ";
|
||||||
|
}
|
||||||
|
$q .= $q_set."WHERE file_uid = '".$file_uid."'";
|
||||||
|
$cms->db_exec($q);
|
||||||
|
if (QUEUE == 'live_queue') {
|
||||||
|
$sql_action = 'UPDATE';
|
||||||
|
$sql_data = $q_set;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// insert new data
|
||||||
|
$file_uid = md5(uniqid(rand(), true));
|
||||||
|
$q = "INSERT INTO file (name_en, name_ja, file_name, online, mime_type, file_size, size_x, size_y, file_uid, type) VALUES (";
|
||||||
|
$q .= "'".addslashes($name_en)."', '".addslashes($name_ja)."', '".addslashes($file_name)."', '".$online."', '".$mime_type."', ";
|
||||||
|
$q .= "$file_size, ".(($width) ? $width : 'NULL').", ".(($height) ? $height : 'NULL').", '".$file_uid."', '".$file_type."')";
|
||||||
|
$cms->db_exec($q);
|
||||||
|
$file_id = $cms->insert_id;
|
||||||
|
// if queue
|
||||||
|
if (QUEUE == 'live_queue') {
|
||||||
|
$sql_data = $q;
|
||||||
|
$sql_action = 'INSERT';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$size_x = $width;
|
||||||
|
$size_y = $height;
|
||||||
$file = DEV_SCHEMA."_".$file_uid;
|
$file = DEV_SCHEMA."_".$file_uid;
|
||||||
// thumbnails are only valid for pictures
|
// now upload the file
|
||||||
|
if ($_FILES['file_up']['name']) {
|
||||||
|
$upload_file = ROOT.MEDIA.$cms->data_path[$file_type].$file;
|
||||||
|
// wipe out any old tmp data for this new upload
|
||||||
|
if (is_array(glob(ROOT.TMP."thumb_".$file."*"))) {
|
||||||
|
foreach (glob(ROOT.TMP."thumb_".$file."*") as $filename) {
|
||||||
|
@unlink($filename);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
# copy file to correct path
|
||||||
|
$error = move_uploaded_file($_FILES['file_up']['tmp_name'], $upload_file);
|
||||||
|
|
||||||
|
$cms->debug('file_upload', "UP: $upload_file");
|
||||||
|
$cms->debug('file_upload', "Orig: ".$cms->print_ar($_FILES['file_up']));
|
||||||
|
|
||||||
|
// because I get bogus error info from move_uploaded_file ...
|
||||||
|
$error = 0;
|
||||||
|
if ($error) {
|
||||||
|
$cms->debug('file_upload', "ERROR: $error | INI FSize: ".ini_get("upload_max_filesize"));
|
||||||
|
$cms->messages[] = array('msg' => 'File upload failed', 'class' => 'error');
|
||||||
|
$q = "DELETE FROM file WHERE file_uid = '".$file_uid."'";
|
||||||
|
$cms->db_exec($q);
|
||||||
|
unset($file_id);
|
||||||
|
unset($file_uid);
|
||||||
|
$view = 'list';
|
||||||
|
} else {
|
||||||
|
$cms->messages[] = array('msg' => 'File upload successful', 'class' => 'warning');
|
||||||
|
// $view = 'list';
|
||||||
|
}
|
||||||
|
} // if file upload
|
||||||
|
// create thumbs + file size
|
||||||
$picture = $cms->cache_pictures.$cms->adbCreateThumbnail($file, 400, 280, $file_type, '', $cms->cache_pictures_root);
|
$picture = $cms->cache_pictures.$cms->adbCreateThumbnail($file, 400, 280, $file_type, '', $cms->cache_pictures_root);
|
||||||
$picture_small = $cms->cache_pictures.$cms->adbCreateThumbnail($file, 80, 60, $file_type, '', $cms->cache_pictures_root);
|
$picture_small = $cms->cache_pictures.$cms->adbCreateThumbnail($file, 80, 60, $file_type, '', $cms->cache_pictures_root);
|
||||||
$file_size = $cms->adbByteStringFormat($file_size);
|
$file_size = $cms->adbByteStringFormat($file_size);
|
||||||
// view to edit
|
// for live queue this is here needed
|
||||||
$view = 'edit';
|
if (QUEUE == 'live_queue') {
|
||||||
}
|
$q = "INSERT INTO ".GLOBAL_DB_SCHEMA.".live_queue (queue_key, key_value, key_name, type, target, data, group_key, action";
|
||||||
if ($cms->action == 'add_new')
|
if ($_FILES['file_up']['name']) {
|
||||||
{
|
$q .= ", file";
|
||||||
$view = 'edit';
|
}
|
||||||
}
|
$q .= ") VALUES ('".$cms->queue_name."', '".$file_uid."', 'file_uid', '".$sql_action."', 'file', '".$cms->db_escape_string($sql_data)."', '".$cms->queue_key."', '".$cms->action."'";
|
||||||
if ($cms->action == 'view_files' && $cms->action_yes == 'true')
|
if ($_FILES['file_up']['name']) {
|
||||||
{
|
$q .= ", '".ROOT.MEDIA.$cms->data_path[$file_type].$file."#".ROOT.MEDIA.$cms->data_path[$file_type].PUBLIC_SCHEMA."_".$file_uid."'";
|
||||||
$view = 'list';
|
}
|
||||||
}
|
$q .= ")";
|
||||||
// set delete live
|
$cms->db_exec($q);
|
||||||
if ($cms->action_flag == 'set_live' && $cms->action = 'set_delete')
|
|
||||||
{
|
|
||||||
$q = "SELECT file_uid, pkid, type FROM ".LOGIN_DB_SCHEMA.".set_live sl, file f WHERE sl.pkid = f.file_uid table_name = '".$cms->page_name."' AND delete_flag = 't'";
|
|
||||||
while ($res = $cms->db_return($q))
|
|
||||||
{
|
|
||||||
$q_del = "DELETE FROM ".PUBLIC_SCHEMA.".file WHERE file_uid = '".$res['pkid'].'"';
|
|
||||||
$cms->db_exec($q_del);
|
|
||||||
@unlink(ROOT.MEDIA.$cms->data_path[$res['type']].PUBLIC_SCHEMA."_".$res['file_uid']);
|
|
||||||
}
|
}
|
||||||
$q = "DELETE FROM ".LOGIN_DB_SCHEMA.".set_live WHERE table_name = '".$cms->page_name."' AND delete_flag = 't'";
|
} // if not error
|
||||||
|
}
|
||||||
|
if ($cms->action == 'delete' && $cms->action_yes == 'true') {
|
||||||
|
$file_uid = $cms->action_id;
|
||||||
|
$q = "SELECT type FROM file WHERE file_uid = '".$file_uid."'";
|
||||||
|
list ($file_type) = $cms->db_return_row($q);
|
||||||
|
// get the file type for the file path
|
||||||
|
$q = "DELETE FROM file WHERE file_uid = '".$file_uid."'";
|
||||||
|
$cms->db_exec($q);
|
||||||
|
if (QUEUE == 'set_live') {
|
||||||
|
$q = "INSERT INTO ".GLOBAL_DB_SCHEMA.".set_live (table_name, pkid, delete_flag) VALUES ('".$cms->page_name."', ".$file_uid.", 't')";
|
||||||
$cms->db_exec($q);
|
$cms->db_exec($q);
|
||||||
}
|
}
|
||||||
if (DEV_SCHEMA != PUBLIC_SCHEMA)
|
if (QUEUE == 'live_queue') {
|
||||||
{
|
$q = "INSERT INTO ".GLOBAL_DB_SCHEMA.".live_queue (queue_key, key_value, key_name, type, target, data, group_key, action, file) VALUES (";
|
||||||
// read out possible deleted, to add "delete from live"
|
$q .= "'".$cms->queue_name."', '".$file_uid."', 'file_uid', 'DELETE', 'file', '', '".$cms->queue_key."', '".$cms->action."', '".ROOT.MEDIA.$cms->data_path[$file_type].PUBLIC_SCHEMA."_".$file_uid."')";
|
||||||
$q = "SELECT pkid FROM ".LOGIN_DB_SCHEMA.".set_live WHERE table_name = '".$cms->page_name."' AND delete_flag = 't'";
|
|
||||||
while ($res = $cms->db_return($q, 3))
|
|
||||||
{
|
|
||||||
$cms->DATA['set_delete'][]['pkid'] = $res['pkid'];
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
// get th max entries
|
@unlink(ROOT.MEDIA.$cms->data_path[$file_type].DEV_SCHEMA."_".$file_uid);
|
||||||
$q = "SELECT COUNT(file_uid) FROM file ";
|
unset($file_uid);
|
||||||
$q_search_where = "WHERE type in ('".str_replace(',', "','", $show_type)."') ";
|
unset($file_id);
|
||||||
if ($search_what)
|
$delete_done = 1;
|
||||||
{
|
$view = 'list';
|
||||||
$q_search_where .= "AND LOWER(name_en) LIKE '%".addslashes(strtolower($search_what))."%' OR name_ja LIKE '%".addslashes($search_what)."%' OR LOWER(file_name) LIKE '%".addslashes(strtolower($search_what))."%' ";
|
}
|
||||||
|
if ($cms->action == 'load') {
|
||||||
|
$file_uid = $cms->action_id;
|
||||||
|
// load the data
|
||||||
|
$q = "SELECT file_id, name_en, name_ja, file_name, online, mime_type, file_size, size_x, size_y, type FROM file WHERE file_uid = '".$file_uid."'";
|
||||||
|
list($file_id, $name_en, $name_ja, $file_name, $online, $mime_type, $file_size, $size_x, $size_y, $file_type) = $cms->db_return_row($q);
|
||||||
|
// create thumbnail for edit view
|
||||||
|
$file = DEV_SCHEMA."_".$file_uid;
|
||||||
|
// thumbnails are only valid for pictures
|
||||||
|
$picture = $cms->cache_pictures.$cms->adbCreateThumbnail($file, 400, 280, $file_type, '', $cms->cache_pictures_root);
|
||||||
|
$picture_small = $cms->cache_pictures.$cms->adbCreateThumbnail($file, 80, 60, $file_type, '', $cms->cache_pictures_root);
|
||||||
|
$file_size = $cms->adbByteStringFormat($file_size);
|
||||||
|
// view to edit
|
||||||
|
$view = 'edit';
|
||||||
|
}
|
||||||
|
if ($cms->action == 'add_new') {
|
||||||
|
$view = 'edit';
|
||||||
|
}
|
||||||
|
if ($cms->action == 'view_files' && $cms->action_yes == 'true') {
|
||||||
|
$view = 'list';
|
||||||
|
}
|
||||||
|
// set delete live
|
||||||
|
if ($cms->action_flag == 'set_live' && $cms->action = 'set_delete') {
|
||||||
|
$q = "SELECT file_uid, pkid, type FROM ".LOGIN_DB_SCHEMA.".set_live sl, file f WHERE sl.pkid = f.file_uid table_name = '".$cms->page_name."' AND delete_flag = 't'";
|
||||||
|
while ($res = $cms->db_return($q)) {
|
||||||
|
$q_del = "DELETE FROM ".PUBLIC_SCHEMA.".file WHERE file_uid = '".$res['pkid'].'"';
|
||||||
|
$cms->db_exec($q_del);
|
||||||
|
@unlink(ROOT.MEDIA.$cms->data_path[$res['type']].PUBLIC_SCHEMA."_".$res['file_uid']);
|
||||||
}
|
}
|
||||||
$q .= $q_search_where;
|
$q = "DELETE FROM ".LOGIN_DB_SCHEMA.".set_live WHERE table_name = '".$cms->page_name."' AND delete_flag = 't'";
|
||||||
// get selection from show_type
|
$cms->db_exec($q);
|
||||||
list ($file_count) = $cms->db_return_row($q);
|
}
|
||||||
|
if (DEV_SCHEMA != PUBLIC_SCHEMA) {
|
||||||
|
// read out possible deleted, to add "delete from live"
|
||||||
|
$q = "SELECT pkid FROM ".LOGIN_DB_SCHEMA.".set_live WHERE table_name = '".$cms->page_name."' AND delete_flag = 't'";
|
||||||
|
while ($res = $cms->db_return($q, 3)) {
|
||||||
|
$cms->DATA['set_delete'][]['pkid'] = $res['pkid'];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// get th max entries
|
||||||
|
$q = "SELECT COUNT(file_uid) FROM file ";
|
||||||
|
$q_search_where = "WHERE type in ('".str_replace(',', "','", $show_type)."') ";
|
||||||
|
if ($search_what) {
|
||||||
|
$q_search_where .= "AND LOWER(name_en) LIKE '%".addslashes(strtolower($search_what))."%' OR name_ja LIKE '%".addslashes($search_what)."%' OR LOWER(file_name) LIKE '%".addslashes(strtolower($search_what))."%' ";
|
||||||
|
}
|
||||||
|
$q .= $q_search_where;
|
||||||
|
// get selection from show_type
|
||||||
|
list ($file_count) = $cms->db_return_row($q);
|
||||||
|
|
||||||
if ($cms->action == 'browse')
|
if ($cms->action == 'browse') {
|
||||||
{
|
// browse in the list of data
|
||||||
// browse in the list of data
|
switch ($cms->action_id) {
|
||||||
switch ($cms->action_id)
|
case "<<<<":
|
||||||
{
|
$start_row = 0;
|
||||||
case "<<<<":
|
break;
|
||||||
$start_row = 0;
|
case "<":
|
||||||
break;
|
$start_row -= $show_amount;
|
||||||
case "<":
|
break;
|
||||||
$start_row -= $show_amount;
|
case ">":
|
||||||
break;
|
$start_row += $show_amount;
|
||||||
case ">":
|
break;
|
||||||
$start_row += $show_amount;
|
case ">>>>":
|
||||||
break;
|
$start_row = $file_count - $show_amount;
|
||||||
case ">>>>":
|
break;
|
||||||
$start_row = $file_count - $show_amount;
|
case "gopage":
|
||||||
break;
|
// for page is page -1, so page 1 start from 0, etc
|
||||||
case "gopage":
|
$start_row = ((($cms->action_value - 1) > 0) ? ($cms->action_value - 1) * $show_amount : 0);
|
||||||
// for page is page -1, so page 1 start from 0, etc
|
$current_page = $cms->action_value;
|
||||||
$start_row = ((($cms->action_value - 1) > 0) ? ($cms->action_value - 1) * $show_amount : 0);
|
break;
|
||||||
$current_page = $cms->action_value;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// check overflow
|
// check overflow
|
||||||
if ($start_row < 0)
|
if ($start_row < 0) {
|
||||||
$start_row = 0;
|
$start_row = 0;
|
||||||
if ($start_row > $file_count)
|
}
|
||||||
$start_row = $file_count - $show_amount;
|
if ($start_row > $file_count) {
|
||||||
|
$start_row = $file_count - $show_amount;
|
||||||
|
}
|
||||||
|
|
||||||
// if we have a "fresh_load"
|
// if we have a "fresh_load"
|
||||||
if ($fresh_load)
|
if ($fresh_load) {
|
||||||
{
|
$count = 1;
|
||||||
$count = 1;
|
$q = "SELECT file_uid FROM file ";
|
||||||
$q = "SELECT file_uid FROM file ";
|
if ($q_search_where) {
|
||||||
if ($q_search_where)
|
|
||||||
$q .= $q_search_where;
|
|
||||||
$q .= "ORDER BY ".$sort_order." ".$sort_direction." ";
|
|
||||||
while ($res = $cms->db_return($q))
|
|
||||||
{
|
|
||||||
// if data_id is set and not file_id, go to the page where the current highlight is, but only if this is a "virgin" load of the page
|
|
||||||
if ($data_id && ($data_id == $res['file_uid']))
|
|
||||||
{
|
|
||||||
$current_page = floor(($count / $show_amount));
|
|
||||||
$start_row = $current_page * $show_amount;
|
|
||||||
$current_page ++;
|
|
||||||
}
|
|
||||||
$count ++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// page forward/back buttons settings
|
|
||||||
if ($start_row > 0)
|
|
||||||
{
|
|
||||||
$cms->DATA['show_back'] = 1;
|
|
||||||
}
|
|
||||||
$cms->DATA['page_number'] = ceil($start_row / $show_amount) + 1;
|
|
||||||
$cms->DATA['page_count'] = ceil($file_count / $show_amount);
|
|
||||||
if ($cms->DATA['page_count'] > 2 && !$current_page)
|
|
||||||
{
|
|
||||||
$current_page = 1;
|
|
||||||
}
|
|
||||||
if (($start_row + $show_amount) < $file_count)
|
|
||||||
{
|
|
||||||
$cms->DATA['show_forward'] = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
$q = "SELECT file_id, name_en, name_ja, file_name, online, mime_type, file_size, size_x, size_y, file_uid, type FROM file ";
|
|
||||||
// if search what, search in name_en, name_ja, file_name for the string
|
|
||||||
if ($q_search_where)
|
|
||||||
$q .= $q_search_where;
|
$q .= $q_search_where;
|
||||||
|
}
|
||||||
$q .= "ORDER BY ".$sort_order." ".$sort_direction." ";
|
$q .= "ORDER BY ".$sort_order." ".$sort_direction." ";
|
||||||
$q .= "LIMIT ".$show_amount." OFFSET ".$start_row;
|
while ($res = $cms->db_return($q)) {
|
||||||
while ($res = $cms->db_return($q))
|
// if data_id is set and not file_id, go to the page where the current highlight is, but only if this is a "virgin" load of the page
|
||||||
{
|
if ($data_id && ($data_id == $res['file_uid'])) {
|
||||||
$data_files[] = array (
|
$current_page = floor(($count / $show_amount));
|
||||||
'id' => $res['file_id'],
|
$start_row = $current_page * $show_amount;
|
||||||
'name_en' => $res['name_en'],
|
$current_page ++;
|
||||||
'name_ja' => $res['name_ja'],
|
}
|
||||||
'file_name' => $res['file_name'],
|
$count ++;
|
||||||
'online' => $res['online'],
|
|
||||||
'mime_type' => $res['mime_type'],
|
|
||||||
'file_size' => $cms->adbByteStringFormat($res['file_size']),
|
|
||||||
'size_x' => $res['size_x'],
|
|
||||||
'size_y' => $res['size_y'],
|
|
||||||
'file_uid' => $res['file_uid'],
|
|
||||||
'file_type' => $res['type'],
|
|
||||||
'picture' => $cms->cache_pictures.$cms->adbCreateThumbnail(DEV_SCHEMA.'_'.$res['file_uid'], 80, 60, $res['type'], '', $cms->cache_pictures_root)
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$cms->DATA['show_type'] = $show_type;
|
// page forward/back buttons settings
|
||||||
$cms->DATA['data_files'] = $data_files;
|
if ($start_row > 0) {
|
||||||
$cms->DATA['view'] = $view;
|
$cms->DATA['show_back'] = 1;
|
||||||
$cms->DATA['images_path'] = MEDIA.$cms->data_path[$file_type];
|
}
|
||||||
// get vars for position (only when)
|
$cms->DATA['page_number'] = ceil($start_row / $show_amount) + 1;
|
||||||
$cms->DATA['form_name'] = $form_name;
|
$cms->DATA['page_count'] = ceil($file_count / $show_amount);
|
||||||
$cms->DATA['value_name'] = $value_name;
|
if ($cms->DATA['page_count'] > 2 && !$current_page) {
|
||||||
$cms->DATA['file_id'] = $file_id;
|
$current_page = 1;
|
||||||
$cms->DATA['file_uid'] = $file_uid;
|
}
|
||||||
|
if (($start_row + $show_amount) < $file_count) {
|
||||||
|
$cms->DATA['show_forward'] = 1;
|
||||||
|
}
|
||||||
|
|
||||||
// write back all the other vars
|
$q = "SELECT file_id, name_en, name_ja, file_name, online, mime_type, file_size, size_x, size_y, file_uid, type FROM file ";
|
||||||
if (!($delete_done || $new_okay))
|
// if search what, search in name_en, name_ja, file_name for the string
|
||||||
{
|
if ($q_search_where) {
|
||||||
// data name
|
$q .= $q_search_where;
|
||||||
$cms->DATA['file_name'] = $file_name;
|
}
|
||||||
$cms->DATA['name_en'] = $name_en;
|
$q .= "ORDER BY ".$sort_order." ".$sort_direction." ";
|
||||||
$cms->DATA['name_ja'] = $name_ja;
|
$q .= "LIMIT ".$show_amount." OFFSET ".$start_row;
|
||||||
$cms->DATA['mime_type'] = $mime_type;
|
while ($res = $cms->db_return($q)) {
|
||||||
$cms->DATA['file_size'] = $file_size;
|
$data_files[] = array (
|
||||||
$cms->DATA['size_x'] = $size_x;
|
'id' => $res['file_id'],
|
||||||
$cms->DATA['size_y'] = $size_y;
|
'name_en' => $res['name_en'],
|
||||||
$cms->DATA['online'] = $online;
|
'name_ja' => $res['name_ja'],
|
||||||
$cms->DATA['picture'] = $picture;
|
'file_name' => $res['file_name'],
|
||||||
$cms->DATA['picture_small'] = $picture_small;
|
'online' => $res['online'],
|
||||||
$cms->DATA['file_type'] = $file_type;
|
'mime_type' => $res['mime_type'],
|
||||||
}
|
'file_size' => $cms->adbByteStringFormat($res['file_size']),
|
||||||
$cms->DATA['sort_order_list'] = $sort_order_list;
|
'size_x' => $res['size_x'],
|
||||||
$cms->DATA['sort_order'] = $sort_order;
|
'size_y' => $res['size_y'],
|
||||||
$cms->DATA['sort_direction_list'] = $sort_direction_list;
|
'file_uid' => $res['file_uid'],
|
||||||
$cms->DATA['sort_direction'] = $sort_direction;
|
'file_type' => $res['type'],
|
||||||
$cms->DATA['search_what'] = $search_what;
|
'picture' => $cms->cache_pictures.$cms->adbCreateThumbnail(DEV_SCHEMA.'_'.$res['file_uid'], 80, 60, $res['type'], '', $cms->cache_pictures_root)
|
||||||
$cms->DATA['current_page'] = $current_page;
|
);
|
||||||
$cms->DATA['yesno_list'] = $yesno_list;
|
}
|
||||||
$cms->DATA['start_row'] = $start_row;
|
|
||||||
$cms->DATA['show_amount'] = $show_amount;
|
|
||||||
if ($data_id)
|
|
||||||
$cms->DATA['data_id'] = $data_id;
|
|
||||||
$cms->DATA['top'] = 0;
|
|
||||||
$cms->DATA['left'] = 0;
|
|
||||||
|
|
||||||
//------------------------------ processing data end
|
$cms->DATA['show_type'] = $show_type;
|
||||||
|
$cms->DATA['data_files'] = $data_files;
|
||||||
|
$cms->DATA['view'] = $view;
|
||||||
|
$cms->DATA['images_path'] = MEDIA.$cms->data_path[$file_type];
|
||||||
|
// get vars for position (only when)
|
||||||
|
$cms->DATA['form_name'] = $form_name;
|
||||||
|
$cms->DATA['value_name'] = $value_name;
|
||||||
|
$cms->DATA['file_id'] = $file_id;
|
||||||
|
$cms->DATA['file_uid'] = $file_uid;
|
||||||
|
|
||||||
//------------------------------ smarty start
|
// write back all the other vars
|
||||||
require("smarty.inc");
|
if (!($delete_done || $new_okay)) {
|
||||||
//------------------------------ smarty end
|
// data name
|
||||||
|
$cms->DATA['file_name'] = $file_name;
|
||||||
|
$cms->DATA['name_en'] = $name_en;
|
||||||
|
$cms->DATA['name_ja'] = $name_ja;
|
||||||
|
$cms->DATA['mime_type'] = $mime_type;
|
||||||
|
$cms->DATA['file_size'] = $file_size;
|
||||||
|
$cms->DATA['size_x'] = $size_x;
|
||||||
|
$cms->DATA['size_y'] = $size_y;
|
||||||
|
$cms->DATA['online'] = $online;
|
||||||
|
$cms->DATA['picture'] = $picture;
|
||||||
|
$cms->DATA['picture_small'] = $picture_small;
|
||||||
|
$cms->DATA['file_type'] = $file_type;
|
||||||
|
}
|
||||||
|
$cms->DATA['sort_order_list'] = $sort_order_list;
|
||||||
|
$cms->DATA['sort_order'] = $sort_order;
|
||||||
|
$cms->DATA['sort_direction_list'] = $sort_direction_list;
|
||||||
|
$cms->DATA['sort_direction'] = $sort_direction;
|
||||||
|
$cms->DATA['search_what'] = $search_what;
|
||||||
|
$cms->DATA['current_page'] = $current_page;
|
||||||
|
$cms->DATA['yesno_list'] = $yesno_list;
|
||||||
|
$cms->DATA['start_row'] = $start_row;
|
||||||
|
$cms->DATA['show_amount'] = $show_amount;
|
||||||
|
if ($data_id) {
|
||||||
|
$cms->DATA['data_id'] = $data_id;
|
||||||
|
}
|
||||||
|
$cms->DATA['top'] = 0;
|
||||||
|
$cms->DATA['left'] = 0;
|
||||||
|
|
||||||
//------------------------------ footer
|
//------------------------------ processing data end
|
||||||
require("footer.inc");
|
|
||||||
//------------------------------ footer
|
//------------------------------ smarty start
|
||||||
|
require("smarty.inc");
|
||||||
?>
|
//------------------------------ smarty end
|
||||||
|
|
||||||
|
//------------------------------ footer
|
||||||
|
require("footer.inc");
|
||||||
|
//------------------------------ footer
|
||||||
|
|||||||
@@ -1,13 +1,12 @@
|
|||||||
<?
|
<?
|
||||||
/********************************************************************
|
/********************************************************************
|
||||||
* AUTHOR: Clemens Schwaighofer
|
* AUTHOR: Clemens Schwaighofer
|
||||||
* CREATED: 2008/08/14
|
* CREATED: 2008/08/14
|
||||||
* SHORT DESCRIPTION:
|
* SHORT DESCRIPTION:
|
||||||
* URL redirect header
|
* URL redirect header
|
||||||
* HISTORY:
|
* HISTORY:
|
||||||
*********************************************************************/
|
*********************************************************************/
|
||||||
|
|
||||||
// print debug messages
|
// print debug messages
|
||||||
echo $login->print_error_msg();
|
echo $login->print_error_msg();
|
||||||
echo $cms->print_error_msg();
|
echo $cms->print_error_msg();
|
||||||
?>
|
|
||||||
|
|||||||
@@ -1,105 +1,104 @@
|
|||||||
<?
|
<?
|
||||||
/********************************************************************
|
/********************************************************************
|
||||||
* AUTHOR: Clemens Schwaighofer
|
* AUTHOR: Clemens Schwaighofer
|
||||||
* CREATED: 2008/08/01
|
* CREATED: 2008/08/01
|
||||||
* SHORT DESCRIPTION:
|
* SHORT DESCRIPTION:
|
||||||
* URL redirect header
|
* URL redirect header
|
||||||
* HISTORY:
|
* HISTORY:
|
||||||
*********************************************************************/
|
*********************************************************************/
|
||||||
|
|
||||||
//------------------------------ variable init start
|
//------------------------------ variable init start
|
||||||
// for dev test we set full error reporting; writes everything, except E_ERROR into logs/php_error-<day>.log
|
// for dev test we set full error reporting; writes everything, except E_ERROR into logs/php_error-<day>.log
|
||||||
if ($DEBUG_ALL && $ENABLE_ERROR_HANDLING)
|
if ($DEBUG_ALL && $ENABLE_ERROR_HANDLING) {
|
||||||
include("libs/Error.Handling.inc");
|
include("libs/Error.Handling.inc");
|
||||||
// predefine vars
|
}
|
||||||
$lang = '';
|
// predefine vars
|
||||||
$messages = array ();
|
$lang = '';
|
||||||
// import all POST vars
|
$messages = array ();
|
||||||
extract($_POST, EXTR_SKIP);
|
// import all POST vars
|
||||||
//------------------------------ variable init end
|
extract($_POST, EXTR_SKIP);
|
||||||
|
//------------------------------ variable init end
|
||||||
|
|
||||||
//------------------------------ library include start
|
//------------------------------ library include start
|
||||||
// set output to quiet for load of classes & session settings
|
// set output to quiet for load of classes & session settings
|
||||||
ob_start();
|
ob_start();
|
||||||
require("config.inc");
|
require("config.inc");
|
||||||
// set the session name
|
|
||||||
define('SET_SESSION_NAME', EDIT_SESSION_NAME);
|
|
||||||
// login class
|
|
||||||
require(LIBS."Class.Login.inc");
|
|
||||||
// DB connection & work time class
|
|
||||||
require(LIBS.'Class.Admin.Backend.inc');
|
|
||||||
// Smarty: and the small extend for l10n calls
|
|
||||||
require(LIBS.'Class.Smarty.Extend.inc');
|
|
||||||
//------------------------------ library include end
|
|
||||||
|
|
||||||
//------------------------------ basic variable settings start
|
// login class, DB connections & Admin class, Smarty extension
|
||||||
// set encoding
|
foreach (array ('Login', 'Admin.Backend', 'Smarty.Extend') as $class) {
|
||||||
if (!isset($encoding))
|
_spl_autoload('Class.'.$class.'.inc');
|
||||||
$encoding = DEFAULT_ENCODING;
|
}
|
||||||
// set the default lang, if not given
|
//------------------------------ library include end
|
||||||
if (session_id() && $_SESSION['DEFAULT_LANG'])
|
|
||||||
$lang = $_SESSION['DEFAULT_LANG'];
|
|
||||||
elseif (!$lang)
|
|
||||||
$lang = DEFAULT_LANG;
|
|
||||||
// end the stop of the output flow, but only if we didn't request a csv file download
|
|
||||||
if ($_POST['action'] != 'download_csv')
|
|
||||||
{
|
|
||||||
header("Content-type: text/html; charset=".$encoding);
|
|
||||||
ob_end_flush();
|
|
||||||
}
|
|
||||||
//------------------------------ basic variable settings start
|
|
||||||
|
|
||||||
//------------------------------ class init start
|
//------------------------------ basic variable settings start
|
||||||
// login & page access check
|
// set encoding
|
||||||
$login = new login($DB_CONFIG[LOGIN_DB], $lang);
|
if (!isset($encoding)) {
|
||||||
// post login lang check
|
$encoding = DEFAULT_ENCODING;
|
||||||
if ($_SESSION['DEFAULT_LANG'])
|
}
|
||||||
$lang = $_SESSION['DEFAULT_LANG'];
|
// set the default lang, if not given
|
||||||
// create smarty object
|
if (session_id() && $_SESSION['DEFAULT_LANG']) {
|
||||||
$smarty = new SmartyML($lang);
|
$lang = $_SESSION['DEFAULT_LANG'];
|
||||||
// create new DB class
|
} elseif (!$lang) {
|
||||||
$cms = new AdminBackend($DB_CONFIG[MAIN_DB], $lang);
|
$lang = DEFAULT_LANG;
|
||||||
// set daily rotation
|
}
|
||||||
$cms->file_name_ext = '_'.date('Y-m-d').'.log';
|
// end the stop of the output flow, but only if we didn't request a csv file download
|
||||||
// set search path to the default DB schema
|
if (array_key_exists('action', $_POST) && $_POST['action'] != 'download_csv') {
|
||||||
$cms->db_exec("SET search_path TO ".DB_SCHEMA);
|
header("Content-type: text/html; charset=".$encoding);
|
||||||
// the menu show flag (what menu to show)
|
ob_end_flush();
|
||||||
$cms->menu_show_flag = 'main';
|
}
|
||||||
// db nfo
|
//------------------------------ basic variable settings start
|
||||||
$cms->db_info();
|
|
||||||
//------------------------------ class init end
|
|
||||||
|
|
||||||
//------------------------------ logging start
|
//------------------------------ class init start
|
||||||
// log backend data
|
// login & page access check
|
||||||
// data part creation
|
$login = new login($DB_CONFIG[LOGIN_DB], $lang);
|
||||||
$data = array (
|
// post login lang check
|
||||||
'_SESSION' => $_SESSION,
|
if ($_SESSION['DEFAULT_LANG']) {
|
||||||
'_GET' => $_GET,
|
$lang = $_SESSION['DEFAULT_LANG'];
|
||||||
'_POST' => $_POST,
|
}
|
||||||
'_FILES' => $_FILES
|
// create smarty object
|
||||||
);
|
$smarty = new SmartyML($lang);
|
||||||
// log action
|
// create new DB class
|
||||||
// no log if login
|
$cms = new AdminBackend($DB_CONFIG[MAIN_DB], $lang);
|
||||||
if (!$login->login)
|
// set search path to the default DB schema
|
||||||
$cms->adbEditLog('Submit', $data, 'BINARY');
|
$cms->db_exec("SET search_path TO ".DB_SCHEMA);
|
||||||
//------------------------------ logging end
|
// the menu show flag (what menu to show)
|
||||||
|
$cms->menu_show_flag = 'main';
|
||||||
|
// db nfo
|
||||||
|
$cms->db_info();
|
||||||
|
// set acl
|
||||||
|
$cms->acl = $login->acl;
|
||||||
|
//------------------------------ class init end
|
||||||
|
|
||||||
//------------------------------ page rights start
|
//------------------------------ logging start
|
||||||
// flag if to show the edit access id drop down list
|
// log backend data
|
||||||
// check if we have more than one EA ID
|
// data part creation
|
||||||
$cms->DATA['show_ea_extra'] = $login->acl['acl']['show_ea_extra'];
|
$data = array (
|
||||||
//------------------------------ page rights ned
|
'_SESSION' => $_SESSION,
|
||||||
|
'_GET' => $_GET,
|
||||||
|
'_POST' => $_POST,
|
||||||
|
'_FILES' => $_FILES
|
||||||
|
);
|
||||||
|
// log action
|
||||||
|
// no log if login
|
||||||
|
if (!$login->login) {
|
||||||
|
$cms->adbEditLog('Submit', $data, 'BINARY');
|
||||||
|
}
|
||||||
|
//------------------------------ logging end
|
||||||
|
|
||||||
// automatic hide for DEBUG messages on live server
|
//------------------------------ page rights start
|
||||||
// can be overridden when setting DEBUG_ALL_OVERRIDE on top of the script (for emergency debugging of one page only)
|
// flag if to show the edit access id drop down list
|
||||||
if ((TARGET == 'live' || TARGET == 'remote') && !$DEBUG_ALL_OVERRIDE)
|
// check if we have more than one EA ID
|
||||||
{
|
$cms->DATA['show_ea_extra'] = $login->acl['acl']['show_ea_extra'];
|
||||||
$login->debug_output_all = 0;
|
//------------------------------ page rights ned
|
||||||
$login->echo_output_all = 0;
|
|
||||||
$login->print_output_all = 0;
|
// automatic hide for DEBUG messages on live server
|
||||||
$cms->debug_output_all = 0;
|
// can be overridden when setting DEBUG_ALL_OVERRIDE on top of the script (for emergency debugging of one page only)
|
||||||
$cms->echo_output_all = 0;
|
if ((TARGET == 'live' || TARGET == 'remote') && !$DEBUG_ALL_OVERRIDE) {
|
||||||
$cms->print_output_all = 0;
|
$login->debug_output_all = 0;
|
||||||
}
|
$login->echo_output_all = 0;
|
||||||
$cms->DATA['JS_DEBUG'] = DEBUG;
|
$login->print_output_all = 0;
|
||||||
?>
|
$cms->debug_output_all = 0;
|
||||||
|
$cms->echo_output_all = 0;
|
||||||
|
$cms->print_output_all = 0;
|
||||||
|
}
|
||||||
|
$cms->DATA['JS_DEBUG'] = DEBUG;
|
||||||
|
|||||||
@@ -1,53 +1,51 @@
|
|||||||
<?
|
<?
|
||||||
/********************************************************************
|
/********************************************************************
|
||||||
* AUTHOR: Clemens Schwaighofer
|
* AUTHOR: Clemens Schwaighofer
|
||||||
* CREATED: 2005/07/19
|
* CREATED: 2005/07/19
|
||||||
* SHORT DESCRIPTION:
|
* SHORT DESCRIPTION:
|
||||||
* preset date variables
|
* preset date variables
|
||||||
* HISTORY:
|
* HISTORY:
|
||||||
*********************************************************************/
|
*********************************************************************/
|
||||||
|
|
||||||
$day_short[1] = "Mon";
|
$day_short[1] = "Mon";
|
||||||
$day_short[2] = "Tue";
|
$day_short[2] = "Tue";
|
||||||
$day_short[3] = "Wed";
|
$day_short[3] = "Wed";
|
||||||
$day_short[4] = "Thu";
|
$day_short[4] = "Thu";
|
||||||
$day_short[5] = "Fri";
|
$day_short[5] = "Fri";
|
||||||
$day_short[6] = "Sat";
|
$day_short[6] = "Sat";
|
||||||
$day_short[7] = "Sun";
|
$day_short[7] = "Sun";
|
||||||
|
|
||||||
$day_long[1] = "Monday";
|
$day_long[1] = "Monday";
|
||||||
$day_long[2] = "Tuesday";
|
$day_long[2] = "Tuesday";
|
||||||
$day_long[3] = "Wednesday";
|
$day_long[3] = "Wednesday";
|
||||||
$day_long[4] = "Thursday";
|
$day_long[4] = "Thursday";
|
||||||
$day_long[5] = "Friday";
|
$day_long[5] = "Friday";
|
||||||
$day_long[6] = "Saturday";
|
$day_long[6] = "Saturday";
|
||||||
$day_long[7] = "Sunday";
|
$day_long[7] = "Sunday";
|
||||||
|
|
||||||
// monate
|
// monate
|
||||||
$month_long[1] = "January";
|
$month_long[1] = "January";
|
||||||
$month_long[2] = "February";
|
$month_long[2] = "February";
|
||||||
$month_long[3] = "March";
|
$month_long[3] = "March";
|
||||||
$month_long[4] = "April";
|
$month_long[4] = "April";
|
||||||
$month_long[5] = "May";
|
$month_long[5] = "May";
|
||||||
$month_long[6] = "June";
|
$month_long[6] = "June";
|
||||||
$month_long[7] = "July";
|
$month_long[7] = "July";
|
||||||
$month_long[8] = "August";
|
$month_long[8] = "August";
|
||||||
$month_long[9] = "September";
|
$month_long[9] = "September";
|
||||||
$month_long[10] = "October";
|
$month_long[10] = "October";
|
||||||
$month_long[11] = "November";
|
$month_long[11] = "November";
|
||||||
$month_long[12] = "December";
|
$month_long[12] = "December";
|
||||||
|
|
||||||
$month_short[1] = "Jan";
|
$month_short[1] = "Jan";
|
||||||
$month_short[2] = "Feb";
|
$month_short[2] = "Feb";
|
||||||
$month_short[3] = "Mar";
|
$month_short[3] = "Mar";
|
||||||
$month_short[4] = "Apr";
|
$month_short[4] = "Apr";
|
||||||
$month_short[5] = "May";
|
$month_short[5] = "May";
|
||||||
$month_short[6] = "Jun";
|
$month_short[6] = "Jun";
|
||||||
$month_short[7] = "Jul";
|
$month_short[7] = "Jul";
|
||||||
$month_short[8] = "Aug";
|
$month_short[8] = "Aug";
|
||||||
$month_short[9] = "Sep";
|
$month_short[9] = "Sep";
|
||||||
$month_short[10] = "Oct";
|
$month_short[10] = "Oct";
|
||||||
$month_short[11] = "Nov";
|
$month_short[11] = "Nov";
|
||||||
$month_short[12] = "Dec";
|
$month_short[12] = "Dec";
|
||||||
|
|
||||||
?>
|
|
||||||
|
|||||||
@@ -1,111 +1,119 @@
|
|||||||
<?
|
<?
|
||||||
/********************************************************************
|
/********************************************************************
|
||||||
* AUTHOR: Clemens Schwaighofer
|
* AUTHOR: Clemens Schwaighofer
|
||||||
* CREATED: 2007/09/03
|
* CREATED: 2007/09/03
|
||||||
* SHORT DESCRIPTION:
|
* SHORT DESCRIPTION:
|
||||||
* set paths & language variables
|
* set paths & language variables
|
||||||
* HISTORY:
|
* HISTORY:
|
||||||
*********************************************************************/
|
*********************************************************************/
|
||||||
|
|
||||||
// template path
|
// template path
|
||||||
if ($_SESSION['TEMPLATE'])
|
if ($_SESSION['TEMPLATE']) {
|
||||||
$TEMPLATE = $_SESSION['TEMPLATE'];
|
$TEMPLATE = $_SESSION['TEMPLATE'];
|
||||||
elseif ($LOCAL_TEMPLATE)
|
} elseif ($LOCAL_TEMPLATE) {
|
||||||
$TEMPLATE = $LOCAL_TEMPLATE;
|
$TEMPLATE = $LOCAL_TEMPLATE;
|
||||||
else
|
} else {
|
||||||
$TEMPLATE = DEFAULT_TEMPLATE;
|
$TEMPLATE = DEFAULT_TEMPLATE;
|
||||||
$TEMPLATE_DIR = $TEMPLATE.'/';
|
}
|
||||||
// master template
|
$TEMPLATE_DIR = $TEMPLATE.'/';
|
||||||
if (!$MASTER_TEMPLATE_NAME)
|
// master template
|
||||||
$MASTER_TEMPLATE_NAME = MASTER_TEMPLATE_NAME;
|
if (!$MASTER_TEMPLATE_NAME) {
|
||||||
|
$MASTER_TEMPLATE_NAME = MASTER_TEMPLATE_NAME;
|
||||||
|
}
|
||||||
|
|
||||||
// just emergency fallback for language
|
// just emergency fallback for language
|
||||||
// set encoding
|
// set encoding
|
||||||
if ($_SESSION['DEFAULT_CHARSET'])
|
if ($_SESSION['DEFAULT_CHARSET']) {
|
||||||
$encoding = $_SESSION['DEFAULT_CHARSET'];
|
$encoding = $_SESSION['DEFAULT_CHARSET'];
|
||||||
elseif (!$encoding)
|
} elseif (!$encoding) {
|
||||||
$encoding = DEFAULT_ENCODING;
|
$encoding = DEFAULT_ENCODING;
|
||||||
// just emergency fallback for language
|
}
|
||||||
if ($_SESSION['DEFAULT_LANG'])
|
// just emergency fallback for language
|
||||||
$lang = $_SESSION['DEFAULT_LANG'];
|
if ($_SESSION['DEFAULT_LANG']) {
|
||||||
elseif (!$lang)
|
$lang = $_SESSION['DEFAULT_LANG'];
|
||||||
$lang = DEFAULT_LANG;
|
} elseif (!$lang) {
|
||||||
// create the char lang encoding
|
$lang = DEFAULT_LANG;
|
||||||
$lang_short = substr($lang, 0, 2);
|
}
|
||||||
|
// create the char lang encoding
|
||||||
|
$lang_short = substr($lang, 0, 2);
|
||||||
|
|
||||||
// set include & template names
|
// set include & template names
|
||||||
$CONTENT_INCLUDE = str_replace(".php", ".tpl", $cms->page_name);
|
$CONTENT_INCLUDE = str_replace(".php", ".tpl", $cms->page_name);
|
||||||
$FORM_NAME = !$FORM_NAME ? str_replace(".php", "", $cms->page_name) : $FORM_NAME;
|
$FORM_NAME = !isset($FORM_NAME) || !$FORM_NAME ? str_replace(".php", "", $cms->page_name) : $FORM_NAME;
|
||||||
// strip tpl and replace it with inc
|
// set local page title
|
||||||
// php include file per page
|
$L_TITLE = ucfirst(str_replace('_', ' ', $cms->get_page_name(1))).' - '.$G_TITLE;
|
||||||
$cms->INC_TEMPLATE_NAME = str_replace(".tpl", ".inc", $CONTENT_INCLUDE);
|
// strip tpl and replace it with inc
|
||||||
// javascript include per page
|
// php include file per page
|
||||||
$cms->JS_TEMPLATE_NAME = str_replace(".tpl", ".js", $CONTENT_INCLUDE);
|
$cms->INC_TEMPLATE_NAME = str_replace(".tpl", ".inc", $CONTENT_INCLUDE);
|
||||||
// css per page
|
// javascript include per page
|
||||||
$cms->CSS_TEMPLATE_NAME = str_replace(".tpl", ".css", $CONTENT_INCLUDE);
|
$cms->JS_TEMPLATE_NAME = str_replace(".tpl", ".js", $CONTENT_INCLUDE);
|
||||||
// special CSS file
|
// css per page
|
||||||
$cms->CSS_SPECIAL_TEMPLATE_NAME = $CSS_NAME;
|
$cms->CSS_TEMPLATE_NAME = str_replace(".tpl", ".css", $CONTENT_INCLUDE);
|
||||||
// special JS file
|
// special CSS file
|
||||||
$cms->JS_SPECIAL_TEMPLATE_NAME = $JS_NAME;
|
$cms->CSS_SPECIAL_TEMPLATE_NAME = @$CSS_NAME;
|
||||||
|
// special JS file
|
||||||
|
$cms->JS_SPECIAL_TEMPLATE_NAME = @$JS_NAME;
|
||||||
|
|
||||||
// set basic template path (tmp)
|
// set basic template path (tmp)
|
||||||
$smarty->setTemplateDir(LAYOUT.$TEMPLATE_DIR.TEMPLATES.'/');
|
$smarty->setTemplateDir(LAYOUT.$TEMPLATE_DIR.TEMPLATES.'/');
|
||||||
$cms->lang_dir = LAYOUT.$TEMPLATE_DIR.LANG."/";
|
$cms->lang_dir = LAYOUT.$TEMPLATE_DIR.LANG."/";
|
||||||
$cms->includes = LAYOUT.$TEMPLATE_DIR.INCLUDES."/";
|
$cms->includes = LAYOUT.$TEMPLATE_DIR.INCLUDES."/";
|
||||||
$cms->javascript = LAYOUT.$TEMPLATE_DIR.JS."/";
|
$cms->javascript = LAYOUT.$TEMPLATE_DIR.JS."/";
|
||||||
$cms->css = LAYOUT.$TEMPLATE_DIR.CSS."/";
|
$cms->css = LAYOUT.$TEMPLATE_DIR.CSS."/";
|
||||||
$cms->pictures = LAYOUT.$TEMPLATE_DIR.IMAGES."/";
|
$cms->pictures = LAYOUT.$TEMPLATE_DIR.IMAGES."/";
|
||||||
$cms->cache_pictures = LAYOUT.$TEMPLATE_DIR.CACHE.IMAGES.'/';
|
$cms->cache_pictures = LAYOUT.$TEMPLATE_DIR.CACHE.IMAGES.'/';
|
||||||
$cms->cache_pictures_root = ROOT.$cms->cache_pictures;
|
$cms->cache_pictures_root = ROOT.$cms->cache_pictures;
|
||||||
if (!is_dir($cms->cache_pictures_root))
|
if (!is_dir($cms->cache_pictures_root)) {
|
||||||
mkdir($cms->cache_pictures_root);
|
mkdir($cms->cache_pictures_root);
|
||||||
$template_set = $TEMPLATE;
|
}
|
||||||
|
$template_set = $TEMPLATE;
|
||||||
|
|
||||||
// if we don't find the master template, set the template path back AND set the insert template as absolute path
|
// if we don't find the master template, set the template path back AND set the insert template as absolute path
|
||||||
if (!file_exists(ROOT.$smarty->getTemplateDir()[0]."/".MASTER_TEMPLATE_NAME))
|
if (!file_exists(ROOT.$smarty->getTemplateDir()[0]."/".MASTER_TEMPLATE_NAME)) {
|
||||||
{
|
if (file_exists(ROOT.$smarty->getTemplateDir()[0]."/".$TEMPLATE_NAME)) {
|
||||||
if (file_exists(ROOT.$smarty->getTemplateDir()[0]."/".$TEMPLATE_NAME))
|
$TEMPLATE_NAME = ROOT.$smarty->getTemplateDir()[0]."/".$TEMPLATE_NAME;
|
||||||
$TEMPLATE_NAME = ROOT.$smarty->getTemplateDir()[0]."/".$TEMPLATE_NAME;
|
|
||||||
$smarty->setTemplateDir(LAYOUT.DEFAULT_TEMPLATE.TEMPLATES);
|
|
||||||
$template_set = DEFAULT_TEMPLATE;
|
|
||||||
}
|
}
|
||||||
|
$smarty->setTemplateDir(LAYOUT.DEFAULT_TEMPLATE.TEMPLATES);
|
||||||
|
$template_set = DEFAULT_TEMPLATE;
|
||||||
|
} elseif (!file_exists(ROOT.$smarty->getTemplateDir()[0]."/".$TEMPLATE_NAME)) {
|
||||||
// check if the template exists in the template path, if not, set path to to default
|
// check if the template exists in the template path, if not, set path to to default
|
||||||
elseif (!file_exists(ROOT.$smarty->getTemplateDir()[0]."/".$TEMPLATE_NAME))
|
$smarty->setTemplateDir(LAYOUT.DEFAULT_TEMPLATE.TEMPLATES);
|
||||||
{
|
$template_set = DEFAULT_TEMPLATE;
|
||||||
$smarty->setTemplateDir(LAYOUT.DEFAULT_TEMPLATE.TEMPLATES);
|
}
|
||||||
$template_set = DEFAULT_TEMPLATE;
|
// loop to check if dir exists
|
||||||
}
|
// check if file exists, if not reset to default path
|
||||||
// loop to check if dir exists
|
|
||||||
// check if file exists, if not reset to default path
|
|
||||||
|
|
||||||
// check if the javascript folder exists in the template path, if not fall back to default
|
// check if the javascript folder exists in the template path, if not fall back to default
|
||||||
if (!is_dir($cms->javascript))
|
if (!is_dir($cms->javascript)) {
|
||||||
$cms->javascript = LAYOUT.DEFAULT_TEMPLATE.JS."/";
|
$cms->javascript = LAYOUT.DEFAULT_TEMPLATE.JS."/";
|
||||||
// check if lang_dir folder exists in the template path, if not fall back to default
|
}
|
||||||
if (!is_dir($cms->lang_dir))
|
// check if lang_dir folder exists in the template path, if not fall back to default
|
||||||
$cms->lang_dir = LAYOUT.DEFAULT_TEMPLATE.LANG."/";
|
if (!is_dir($cms->lang_dir)) {
|
||||||
// check if include folder exists in the template path, if not fall back to default
|
$cms->lang_dir = LAYOUT.DEFAULT_TEMPLATE.LANG."/";
|
||||||
if (!is_dir($cms->includes))
|
}
|
||||||
$cms->includes = LAYOUT.DEFAULT_TEMPLATE.INCLUDES."/";
|
// check if include folder exists in the template path, if not fall back to default
|
||||||
// check if css folder exists in the template path, if not fall back to default
|
if (!is_dir($cms->includes)) {
|
||||||
if (!is_dir($cms->css))
|
$cms->includes = LAYOUT.DEFAULT_TEMPLATE.INCLUDES."/";
|
||||||
$cms->css = LAYOUT.DEFAULT_TEMPLATE.CSS."/";
|
}
|
||||||
if (!is_dir($cms->pictures))
|
// check if css folder exists in the template path, if not fall back to default
|
||||||
$cms->pictures = LAYOUT.DEFAULT_TEMPLATE.PICTURES.'/';
|
if (!is_dir($cms->css)) {
|
||||||
if (!is_dir($cms->cache_pictures))
|
$cms->css = LAYOUT.DEFAULT_TEMPLATE.CSS."/";
|
||||||
$cms->cache_pictures = LAYOUT.DEFAULT_TEMPLATE.CACHE.IMAGES.'/';
|
}
|
||||||
|
if (!is_dir($cms->pictures)) {
|
||||||
|
$cms->pictures = LAYOUT.DEFAULT_TEMPLATE.PICTURES.'/';
|
||||||
|
}
|
||||||
|
if (!is_dir($cms->cache_pictures)) {
|
||||||
|
$cms->cache_pictures = LAYOUT.DEFAULT_TEMPLATE.CACHE.IMAGES.'/';
|
||||||
|
}
|
||||||
|
|
||||||
// if the template_dir is != DEFAULT_TEMPLATE, then try to make a lang switch
|
// if the template_dir is != DEFAULT_TEMPLATE, then try to make a lang switch
|
||||||
// if the default lang is not like the lang given, switch lang
|
// if the default lang is not like the lang given, switch lang
|
||||||
if (false === strstr(LAYOUT.DEFAULT_TEMPLATE.LANG, $cms->lang_dir) || strcasecmp(DEFAULT_LANG, $lang))
|
if (false === strstr(LAYOUT.DEFAULT_TEMPLATE.LANG, $cms->lang_dir) || strcasecmp(DEFAULT_LANG, $lang)) {
|
||||||
{
|
$cms->debug('LANG', 'Orig: '.LAYOUT.DEFAULT_TEMPLATE.LANG.', New: '.$cms->lang_dir.' | Orig Lang: '.DEFAULT_LANG.', New Lang: '.$lang);
|
||||||
$cms->debug('LANG', 'Orig: '.LAYOUT.DEFAULT_TEMPLATE.LANG.', New: '.$cms->lang_dir.' | Orig Lang: '.DEFAULT_LANG.', New Lang: '.$lang);
|
$cms->l->l10nReloadMOfile($lang, $cms->lang_dir);
|
||||||
$cms->l->l10nReloadMOfile($lang, $cms->lang_dir);
|
$smarty->l10n->l10nReloadMOfile($lang, $cms->lang_dir);
|
||||||
$smarty->l10n->l10nReloadMOfile($lang, $cms->lang_dir);
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// $cms->debug("LANGUAGE", "L: $lang | ".$cms->lang_dir." | MO File: ".$cms->l->mofile);
|
// $cms->debug("LANGUAGE", "L: $lang | ".$cms->lang_dir." | MO File: ".$cms->l->mofile);
|
||||||
$cms->debug("LANGUAGE", "SL: ".$_SESSION['DEFAULT_CHARSET']." | ".$_SESSION['LANG']." | ".$_SESSION['DEFAULT_LANG']);
|
$cms->debug("LANGUAGE", "SL: ".$_SESSION['DEFAULT_CHARSET']." | ".$_SESSION['LANG']." | ".$_SESSION['DEFAULT_LANG']);
|
||||||
$cms->debug("TEMPLATE", "P: ".$smarty->getTemplateDir()[0]);
|
$cms->debug("TEMPLATE", "P: ".$smarty->getTemplateDir()[0]);
|
||||||
|
|
||||||
?>
|
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user