Replaced usage of title.group with title.group_edit.
[timetracker.git] / WEB-INF / config.php.dist
1 <?php
2 // +----------------------------------------------------------------------+
3 // | Anuko Time Tracker
4 // +----------------------------------------------------------------------+
5 // | Copyright (c) Anuko International Ltd. (https://www.anuko.com)
6 // +----------------------------------------------------------------------+
7 // | LIBERAL FREEWARE LICENSE: This source code document may be used
8 // | by anyone for any purpose, and freely redistributed alone or in
9 // | combination with other software, provided that the license is obeyed.
10 // |
11 // | There are only two ways to violate the license:
12 // |
13 // | 1. To redistribute this code in source form, with the copyright
14 // |    notice or license removed or altered. (Distributing in compiled
15 // |    forms without embedded copyright notices is permitted).
16 // |
17 // | 2. To redistribute modified versions of this code in *any* form
18 // |    that bears insufficient indications that the modifications are
19 // |    not the work of the original author(s).
20 // |
21 // | This license applies to this document only, not any other software
22 // | that it may be combined with.
23 // |
24 // +----------------------------------------------------------------------+
25 // | Contributors:
26 // | https://www.anuko.com/time_tracker/credits.htm
27 // +----------------------------------------------------------------------+
28
29
30 // Set include path for PEAR and its modules, which we include in the distribution.
31 //
32 set_include_path(realpath(dirname(__FILE__).'/lib/pear') . PATH_SEPARATOR . get_include_path());
33
34
35 // Database connection parameters.
36 //
37 // CHANGE 3 PARAMETERS HERE!
38 // In this example: "root" is username, "no" is password, "dbname" is database name.
39 //
40 define('DSN', 'mysqli://root:no@localhost/dbname?charset=utf8mb4');
41 // Do NOT change charset unless you upgraded from an older Time Tracker where charset was NOT specified
42 // and now you see some corrupted characters. See http://dev.mysql.com/doc/refman/5.0/en/charset-mysql.html
43
44
45 // MULTITEAM_MODE option defines whether users can create their own top groups (organizations).
46 // When false, a Time Tracker server is managed by admin, who creates top groups (one or many).
47 //
48 // Available values are true or false.
49 //
50 define('MULTITEAM_MODE', true);
51
52
53 // Application name.
54 // If you install time tracker into a sub-directory of your site reflect this in the APP_NAME parameter.
55 // For example, for http://localhost/timetracker/ define APP_NAME as 'timetracker'.
56 //
57 // define('APP_NAME', 'timetracker');
58 //
59 define('APP_NAME', '');
60
61
62 // OLD_PASSWORDS
63 //
64 // You may need to set this option if you migrate an older version of TT installation to a new server.
65 // Older versions of TT used mysql password function to hash user passwords. Newer versions use md5.
66 // Because the password function may behave differently between servers, the OLD_PASSWORD settings
67 // gives you an opportunity to control it, if needed.
68 //  
69 // define('OLD_PASSWORDS', true);
70
71
72 // WEEKEND_START_DAY
73 //
74 // This option defines which days are highlighted with weekend color.
75 // 6 means Saturday. For Saudi Arabia, etc. set it to 4 for Thursday and Friday to be weekend days.
76 //
77 define('WEEKEND_START_DAY', 6);
78
79
80 // PHPSESSID_TTL
81 //
82 // Lifetime in seconds for tt_PHPSESSID cookie. Time to live is extended by this value
83 // with each visit to the site so that users don't have to re-login. 
84 // define('PHPSESSID_TTL', 86400);
85 //
86 // Note: see also PHP_SESSION_PATH below as you may have to use it together with
87 // PHPSESSID_TTL to avoid premature session expirations.
88
89
90 // PHP_SESSION_PATH
91 // Local file system path for PHP sessions. Use it to isolate session deletions
92 // (garbage collection interference) by other PHP scripts potentially running on the system.
93 // define('PHP_SESSION_PATH', '/tmp/timetracker'); // Directory must exist and be writable.
94
95
96 // Forum and help links from the main menu.
97 //
98 define('FORUM_LINK', 'https://www.anuko.com/forum/viewforum.php?f=4');
99 define('HELP_LINK', 'https://www.anuko.com/time_tracker/user_guide/index.htm');
100
101
102 // Default sender for mail.
103 //
104 define('SENDER', '"Anuko Time Tracker" <no-reply@timetracker.anuko.com>');
105
106
107 // MAIL_MODE - mail sending mode. Can be 'mail' or 'smtp'.
108 // 'mail' - sending through php mail() function.
109 // 'smtp' - sending directly through SMTP server.
110 // See https://www.anuko.com/time_tracker/install_guide/mail.htm
111 //
112 define('MAIL_MODE', 'smtp');
113 define('MAIL_SMTP_HOST', 'localhost'); // For gmail use 'ssl://smtp.gmail.com' instead of 'localhost' and port 465.
114 // define('MAIL_SMTP_PORT', '465');
115 // define('MAIL_SMTP_USER', 'yourname@yourdomain.com');
116 // define('MAIL_SMTP_PASSWORD', 'yourpassword');
117 // define('MAIL_SMTP_AUTH', true);
118 // define('MAIL_SMTP_DEBUG', true);
119
120
121 // CSS files. They are located in the root of Time Tracker installation.
122 //
123 define('DEFAULT_CSS', 'default.css');
124 define('RTL_CSS', 'rtl.css'); // For right to left languages.
125
126
127 // Default date format. Behaviour with not included formats is undefined. Possible values:
128 // '%Y-%m-%d'
129 // '%m/%d/%Y'
130 // '%d.%m.%Y'
131 // '%d.%m.%Y %a'
132 define('DATE_FORMAT_DEFAULT', '%Y-%m-%d');
133
134
135 // Default time format. Behaviour with not included formats is undefined. Possible values:
136 // '%H:%M'
137 // '%I:%M %p'
138 define('TIME_FORMAT_DEFAULT', '%H:%M');
139
140
141 // Default week start day.
142 // Possible values: 0 - 6. 0 means Sunday.
143 //
144 define('WEEK_START_DEFAULT', 0);
145
146
147 // Default language of the application.
148 // Possible values: en, fr, nl, etc. Empty string means the language is defined by user browser.
149 // 
150 define('LANG_DEFAULT', '');
151
152
153 // Default currency symbol. Use €, £, a more specific dollar like US$, CAD, etc.
154 // 
155 define('CURRENCY_DEFAULT', '$');
156
157
158 // EXPORT_DECIMAL_DURATION - defines whether time duration values are decimal in CSV and XML data exports (1.25 or 1,25 vs 1:15).
159 // 
160 define('EXPORT_DECIMAL_DURATION', true);
161
162
163 // REPORT_FOOTER - defines whether to use a footer on reports.
164 // 
165 define('REPORT_FOOTER', true);
166
167
168 // Authentication module (see WEB-INF/lib/auth/)
169 // Possible authentication methods:
170 //   db - internal database, logins and password hashes are stored in time tracker database.
171 //   ldap - authentication against an LDAP directory such as OpenLDAP or Windows Active Directory.
172 define('AUTH_MODULE', 'db');
173
174 // LDAP authentication examples.
175 // Go to https://www.anuko.com/time_tracker/install_guide/ldap_auth/index.htm for detailed configuration instructions.
176
177 // Configuration example for OpenLDAP server:
178 // define('AUTH_MODULE', 'ldap');
179 // $GLOBALS['AUTH_MODULE_PARAMS'] = array(
180 //  'server' => '127.0.0.1',                    // OpenLDAP server address or name. For secure LDAP use ldaps://hostname:port here.
181 //  'type' => 'openldap',                       // Type of server. openldap type should also work with Sun Directory Server when member_of is empty.
182                                                 // It may work with other (non Windows AD) LDAP servers. For Windows AD use the 'ad' type.
183 //  'base_dn' => 'ou=People,dc=example,dc=com', // Base distinguished name in LDAP catalog.
184 //  'default_domain' => 'example.com',          // Default domain.
185 //  'member_of' => array());                    // List of groups, membership in which is required for user to be authenticated.
186
187
188 // Configuration example for Windows domains with Active Directory:
189 // define('AUTH_MODULE', 'ldap');
190 // $GLOBALS['AUTH_MODULE_PARAMS'] = array(
191 //  'server' => '127.0.0.1',            // Domain controller IP address or name. For secure LDAP use ldaps://hostname:port here.
192 //  'type' => 'ad',                     // Type of server.
193 //  'base_dn' => 'DC=example,DC=com',   // Base distinguished name in LDAP catalog.
194 //  'default_domain' => 'example.com',  // Default domain.
195 //  'member_of' => array());            // List of groups, membership in which is required for user to be authenticated.
196                                         // Leave it empty if membership is not necessary. Otherwise list CN parts only.
197                                         // For example:
198                                         // array('Ldap Testers') means that the user must be a member Ldap Testers group.
199                                         // array('Ldap Testers', 'Ldap Users') means the user must be a member of both Ldap Testers and Ldap Users groups.
200
201 // define('AUTH_DEBUG', false); // Note: enabling AUTH_DEBUG breaks redirects as debug output is printed before setting redirect header. Do not enable on production systems.
202
203
204 // Team managers can set monthly work hour quota for years between the following  values.
205 // define('MONTHLY_QUOTA_YEAR_START', 2010); // If nothing is specified, it falls back to 2015.
206 // define('MONTHLY_QUOTA_YEAR_END', 2025);   // If nothing is specified, it falls back to 2030.
207
208 // Height in pixels for the note input field in time.php. Defaults to 40.
209 // define('NOTE_INPUT_HEIGHT', 100);
210
211 // A temporary config option while development of subgroup support is ongoing. To be removed later.
212 // define('SUBGROUP_DEBUG', false);