Compare commits
	
		
			97 Commits
		
	
	
		
			fix/databa
			...
			v0.7.12a
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | e6b16cd420 | ||
|   | 6bc14fb44f | ||
|   | c37f593eda | ||
|   | 5d499bc5e6 | ||
|   | a7105d33f2 | ||
|   | 8af9186098 | ||
|   | 2d427601ee | ||
|   | 454d4b088d | ||
|   | 738bfbfa5c | ||
|   | 03223c1c30 | ||
|   | 3c6f44d6ee | ||
|   | dacc5b9dab | ||
|   | a4bccbaa34 | ||
|   | 174054237b | ||
|   | bcc81fa34f | ||
|   | ba1c5e9b2e | ||
|   | 0129c79580 | ||
|   | c863ad460a | ||
|   | cb08e53103 | ||
|   | d5cc2a1090 | ||
|   | 6ba8d2c9cb | ||
|   | 668e4688c4 | ||
|   | bd19b8665a | ||
|   | c5980f2350 | ||
|   | 6c03984f53 | ||
|   | ecd865f275 | ||
|   | 5f1392e9f4 | ||
|   | d6c10d277d | ||
|   | 815b1f9b5b | ||
|   | 66568fbaf1 | ||
|   | 18b6404e75 | ||
|   | 17b1f9a391 | ||
|   | 14137221fd | ||
|   | ed4a166d6c | ||
|   | 8df12e3d9c | ||
|   | e2a625efd2 | ||
|   | 5b3237770b | ||
|   | 4ffb6cf8eb | ||
|   | 2c12ef93aa | ||
|   | d17c18cabc | ||
|   | eeb09ddce6 | ||
|   | 28683d66ee | ||
|   | 7d2e522d2b | ||
|   | 3fc2bef7c9 | ||
|   | fade78efc1 | ||
|   | d04f2b7965 | ||
|   | a9f205f047 | ||
|   | 956f631750 | ||
|   | f01428da48 | ||
|   | 7351ab4436 | ||
|   | d9510b01ba | ||
|   | 79589ed1f4 | ||
|   | 67590e13a6 | ||
|   | 1e3aef211e | ||
|   | cda8191f79 | ||
|   | b91d3e70cc | ||
|   | 94e4ff313c | ||
|   | 2295d270f5 | ||
|   | a4a829a7c2 | ||
|   | f5aae3361f | ||
|   | 736ec61f85 | ||
|   | 1385189838 | ||
|   | bfa563285a | ||
|   | d0f6670e98 | ||
|   | ac701696d3 | ||
|   | 702e29a5cb | ||
|   | f26c334d47 | ||
|   | 75e55bfaee | ||
|   | 0d85b63d5d | ||
|   | 14920a7193 | ||
|   | 5547fd7895 | ||
|   | 34cb1b1ffa | ||
|   | 4ffe4ab9b7 | ||
|   | bcf054104c | ||
|   | 9fafa110bb | ||
|   | 35acec1be5 | ||
|   | f157402fa3 | ||
|   | 513e8f4b30 | ||
|   | 35a5aafbb5 | ||
|   | 73a5e13006 | ||
|   | bcb0feea1a | ||
|   | 774e789c8a | ||
|   | db25d38f4b | ||
|   | 4b81213662 | ||
|   | a860c95975 | ||
|   | e2de0b1440 | ||
|   | 8b2ad2cf2f | ||
|   | 88a320530c | ||
|   | 6e221fe469 | ||
|   | 679e08ec11 | ||
|   | 603495ca97 | ||
|   | 4c6af13574 | ||
|   | 3fcbd42445 | ||
|   | e6d2e363d5 | ||
|   | 0a067577a3 | ||
|   | a5b599088a | ||
|   | 51ba514d2a | 
							
								
								
									
										4
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,4 @@ | |||||||
|  | * text=auto | ||||||
|  | .gitattributes export-ignore | ||||||
|  | .gitignore export-ignore | ||||||
|  | _config.yml export-ignore | ||||||
							
								
								
									
										34
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,34 @@ | |||||||
|  | Thumbs.db | ||||||
|  | .DS_Store | ||||||
|  | .idea | ||||||
|  |  | ||||||
|  | releases | ||||||
|  | config.local.php | ||||||
|  | PERSONAL_NOTES | ||||||
|  |  | ||||||
|  | # all custom templates | ||||||
|  | templates/* | ||||||
|  | !templates/tibiacom | ||||||
|  | !templates/kathrine | ||||||
|  |  | ||||||
|  | # guild images | ||||||
|  | images/guilds/* | ||||||
|  | !images/guilds/default.gif | ||||||
|  |  | ||||||
|  | # cache | ||||||
|  | system/cache/* | ||||||
|  | !system/cache/index.html | ||||||
|  | !system/cache/twig/index.html | ||||||
|  | !system/cache/signatures/index.html | ||||||
|  |  | ||||||
|  | # logs | ||||||
|  | system/logs/* | ||||||
|  | !system/logs/index.html | ||||||
|  |  | ||||||
|  | # plugins | ||||||
|  | plugins/* | ||||||
|  | !plugins/.htaccess | ||||||
|  | !plugins/example.json | ||||||
|  | !plugins/account-create-hint.json | ||||||
|  | !plugins/account-create-hint | ||||||
|  | landing | ||||||
| @@ -1,4 +1,114 @@ | |||||||
| [0.7.4 - 24.12.2017] | # Changelog | ||||||
|  | 
 | ||||||
|  | ## [0.7.12 - 18.02.2020] | ||||||
|  | ### Fixed | ||||||
|  | * change guild nick function causing crash on TFS 1.x because of invalid characters being accepted | ||||||
|  | * PHP Mailer autoload function on newer PHP | ||||||
|  | * gesior signature guild rank loading | ||||||
|  | * leaking database password when cannot connect | ||||||
|  | * config.last_kills_limit being ignored | ||||||
|  | * monster.loot being cutted off cause of too short column (changed to TEXT) | ||||||
|  | 
 | ||||||
|  | ### Added | ||||||
|  | * nginx-sample.conf | ||||||
|  | 
 | ||||||
|  | ## [0.7.11 - 04.05.2019] | ||||||
|  | ### Added: | ||||||
|  | * support for some old servers, where arrays are used in config.lua | ||||||
|  | * an additional text to the install page informing that user can reinstall MyAAC by deleting config.local.php | ||||||
|  | 
 | ||||||
|  | ### Fixed: | ||||||
|  | * XSS in forum show_thread | ||||||
|  | * guilds - "Add new rank" function | ||||||
|  | * multiple mail recipients when using admin mailer function | ||||||
|  | * Admin Panel - MyAAC logs not shown if servers logs directory doesn't exist (#47) | ||||||
|  | * missing prefix for cache get() and delete() functions | ||||||
|  | * add fatal error message when myaac tables in database do not exist | ||||||
|  | * the mystical defect where "Create Account" button was not highlighted (on the account/manage page) | ||||||
|  | * bug where server_config table does not exist (OTHire as an example) | ||||||
|  | * database_name in Usage_Statistics | ||||||
|  | * forgot to open <head> in install template | ||||||
|  | 
 | ||||||
|  | ### Changed: | ||||||
|  | * do not display software version | ||||||
|  | 
 | ||||||
|  | ## [0.7.10 - 03.03.2018] | ||||||
|  | ### Added: | ||||||
|  | * new configurable: smtp_secure | ||||||
|  | * robots.txt | ||||||
|  | 
 | ||||||
|  | ### Fixed: | ||||||
|  | * editing an existing page that had php enabled | ||||||
|  | * chrome bug on save (when editing page) ERR_BLOCKED_BY_XSS_AUDITOR | ||||||
|  | * showing IP and Port in admin panel (#44, by miqueiaspenha) | ||||||
|  | * deleting plugin showing "You don't have rights to delete" | ||||||
|  | * some bug with PHPMailer not finding its language file | ||||||
|  | * default accounts.vote value | ||||||
|  | * saving some really high long ip addresses | ||||||
|  | 
 | ||||||
|  | ### Changed: | ||||||
|  | * update config.highscores_ids_hidden on install when there are samples already in database | ||||||
|  | * auto add z_polls table on install | ||||||
|  | 
 | ||||||
|  | ### Internal: | ||||||
|  | * changed mb_strtolower functions to strtolower() | ||||||
|  | * added new function: $hooks->exist($type) | ||||||
|  | 
 | ||||||
|  | ## [0.7.9 - 13.01.2018] | ||||||
|  | 	* removed 6mb of trash (some useless things) | ||||||
|  | 	* (fix) TFS 1.x not showing promoted vocations in highscores | ||||||
|  | 	* otserv 0.6.x: fixed some warning (on the characters page) and fatal mysql error (on the mango signature) | ||||||
|  | 	* fixed default stamina on otserv 0.6.x engine (and some others perhaps) | ||||||
|  | 	* install: change permission check to is_writable | ||||||
|  | 	* changed highscores_groups_hidden to 3 (for TFS 1.x) | ||||||
|  | 	* updated background-artwork (tibiacom template) to the latest version, removed other ones | ||||||
|  | 
 | ||||||
|  | ## [0.7.8 - 12.01.2018] | ||||||
|  | 	* fixed installation error " call to undefined method OTS_DB_MySQL::hasColumn()" | ||||||
|  | 	* updated tinymce to the latest (4.7.4) version | ||||||
|  | 	* enabled emoticons plugin in tinymce :) | ||||||
|  | 	* some security fixes | ||||||
|  | 
 | ||||||
|  | ## [0.7.7 - 08.01.2018] | ||||||
|  | 	* important fix for servers with promotion column (caused player.vocation to be resetted when saving player, for example: on change name, accept invite to guild, leave guild) | ||||||
|  | 	* immediately reload config.lua when there's change in config.server_path detected | ||||||
|  | 	* added new forum option: "Enable HTML" (only for moderators) | ||||||
|  | 	* fixed othire default column value (#26) | ||||||
|  | 	* fixed saving custom vocations in admin panel (#36) | ||||||
|  | 	* fixed warning in highscores when vocation doesn't exist | ||||||
|  | 	* fixed characters page - config.characters.frags "Notice: Use of undefined constant" | ||||||
|  | 	* fixed getBoolean function when boolean is passed | ||||||
|  | 	* fixed empty success message on leave guild | ||||||
|  | 	* fixed displaying premium account days | ||||||
|  | 	* function OTS_Account:getPremDays will now return -1 if there's freePremium configurable enabled on the server | ||||||
|  | 	* fixed tr bgcolor in characters view (Frags) (#38) | ||||||
|  | 	* fixed some warning in guild show | ||||||
|  | 	* fixed PHP warning about country not existing on online and characters pages | ||||||
|  | 	* fixed forum bbcode parsing | ||||||
|  | 	* don't add extra <br/> to the TinyMCE news forum posts | ||||||
|  | 	* (internal) using $player->getVocationName() where possible instead of older method | ||||||
|  | 
 | ||||||
|  | ## [0.7.6 - 05.01.2017] | ||||||
|  | 	* fixed othire account creating/installation | ||||||
|  | 	* fixed table name players -> players_online | ||||||
|  | 	* fixed unexpected error logging about email fail | ||||||
|  | 	* added max_execution_time to the install finish step | ||||||
|  | 	* some small fix regarding highscores vocation box | ||||||
|  | 
 | ||||||
|  | ## [0.7.5 - 04.01.2017] | ||||||
|  | 	* fixed bug on othire with config.account_premium_days | ||||||
|  | 	* fixed bug on TFS 1.x when online_afk is enabled | ||||||
|  | 	* warning about leaving news page with changes | ||||||
|  | 	* added player status to tibiacom top 5 highscores box | ||||||
|  | 	* save detected country on create account in session | ||||||
|  | 	* fixed getPremDays and isPremium functions (newest 11.x engines are bugged when it comes to PACC, its not fault of MyAAC) | ||||||
|  | 	* fix when there are no changelogs or highscores yet | ||||||
|  | 	* small fix regarding getTopPlayers function which was ignoring $limit variable | ||||||
|  | 	* fixed news adding when type != ARTICLE | ||||||
|  | 	* fixed template path finding | ||||||
|  | 	* fixed displaying article_text when it was empty saved | ||||||
|  | 
 | ||||||
|  | ## [0.7.4 - 24.12.2017] | ||||||
| 	* fixed mysql fatal error on tibiacom template - top 5 box | 	* fixed mysql fatal error on tibiacom template - top 5 box | ||||||
| 	* fixed displaying of level percent bar on tibian signature | 	* fixed displaying of level percent bar on tibian signature | ||||||
| 	* inform user about Twig cache failure on installation, instead of http 500 error | 	* inform user about Twig cache failure on installation, instead of http 500 error | ||||||
| @@ -6,7 +116,7 @@ | |||||||
| 	* remember client version select and usage stats checkbox in session on install | 	* remember client version select and usage stats checkbox in session on install | ||||||
| 	* automatically update highscores_ids_hidden for users who installed myaac before (migration) | 	* automatically update highscores_ids_hidden for users who installed myaac before (migration) | ||||||
| 
 | 
 | ||||||
| [0.7.3 - 18.12.2017] | ## [0.7.3 - 18.12.2017] | ||||||
| 	* auto generate myaac cache & session prefix on install to be unique across installations | 	* auto generate myaac cache & session prefix on install to be unique across installations | ||||||
| 	* fixed hiding shop system menu on tibiacom template when disabled in config | 	* fixed hiding shop system menu on tibiacom template when disabled in config | ||||||
| 	* prevent adding duplicated newses with installation | 	* prevent adding duplicated newses with installation | ||||||
| @@ -21,7 +131,7 @@ | |||||||
| 	* (internal) renamed installation step files to be in correct order | 	* (internal) renamed installation step files to be in correct order | ||||||
| 	* added TODO file | 	* added TODO file | ||||||
| 
 | 
 | ||||||
| [0.7.1 - 13.12.2017] | ## [0.7.1 - 13.12.2017] | ||||||
| 	* added changelog menu item to kathrine template | 	* added changelog menu item to kathrine template | ||||||
| 	* fixed some php short tag in changelogs page | 	* fixed some php short tag in changelogs page | ||||||
| 	* fixed guild change description back button | 	* fixed guild change description back button | ||||||
| @@ -29,7 +139,7 @@ | |||||||
| 	* changed some notice when version check is failed | 	* changed some notice when version check is failed | ||||||
| 	* (internal) moved changelog to twig | 	* (internal) moved changelog to twig | ||||||
| 
 | 
 | ||||||
| [0.7.0 - 20.11.2017] | ## [0.7.0 - 20.11.2017] | ||||||
| 	* moved template menus to database, they're now dynamically loaded | 	* moved template menus to database, they're now dynamically loaded | ||||||
| 	* added anonymous usage statistics reporting (only if user agrees, first usage report will be send after 7 days) | 	* added anonymous usage statistics reporting (only if user agrees, first usage report will be send after 7 days) | ||||||
| 	* you can edit them in Admin Panel under 'Menus' option | 	* you can edit them in Admin Panel under 'Menus' option | ||||||
| @@ -66,24 +176,24 @@ | |||||||
| 	* (internal) renamed constant TICKET -> TICKER | 	* (internal) renamed constant TICKET -> TICKER | ||||||
| 	* (internal) shortened message functions | 	* (internal) shortened message functions | ||||||
| 
 | 
 | ||||||
| [0.6.6 - 22.10.2017] | ## [0.6.6 - 22.10.2017] | ||||||
| 	* fixed some php fatal error on spells page | 	* fixed some php fatal error on spells page | ||||||
| 	* changed spells.vocations field in db size to 300 | 	* changed spells.vocations field in db size to 300 | ||||||
| 	* please reload your spells after this update! | 	* please reload your spells after this update! | ||||||
| 
 | 
 | ||||||
| [0.6.5 - 21.10.2017] | ## [0.6.5 - 21.10.2017] | ||||||
| 	* fixed displaying custom pages | 	* fixed displaying custom pages | ||||||
| 	* fixed adding new group forum board | 	* fixed adding new group forum board | ||||||
| 
 | 
 | ||||||
| [0.6.4 - 20.10.2017] | ## [0.6.4 - 20.10.2017] | ||||||
| 	* reverted OTS_Account::getLastLogin() cause its used by tibia11-login plugin | 	* reverted OTS_Account::getLastLogin() cause its used by tibia11-login plugin | ||||||
| 
 | 
 | ||||||
| [0.6.3 - 20.10.2017] | ## [0.6.3 - 20.10.2017] | ||||||
| 	* fixed creating account | 	* fixed creating account | ||||||
| 	* fixed viewing thread without being logged | 	* fixed viewing thread without being logged | ||||||
| 	* fixed showing premium account status | 	* fixed showing premium account status | ||||||
| 
 | 
 | ||||||
| [0.6.2 - 20.10.2017] | ## [0.6.2 - 20.10.2017] | ||||||
| 	* added forums for guilds and groups | 	* added forums for guilds and groups | ||||||
| 	* added nice looking menu for my account page in default template | 	* added nice looking menu for my account page in default template | ||||||
| 	* new command line tool: install_plugin.php - can be used to install plugins from command line. Usage: "php install_plugin.php path_to_file" | 	* new command line tool: install_plugin.php - can be used to install plugins from command line. Usage: "php install_plugin.php path_to_file" | ||||||
| @@ -116,7 +226,7 @@ | |||||||
| 	* (internal) new function: OTS_Guild::hasMember(OTS_Player $player) | 	* (internal) new function: OTS_Guild::hasMember(OTS_Player $player) | ||||||
| 	* (internal) new function: Forum::hasAccess($board_id) | 	* (internal) new function: Forum::hasAccess($board_id) | ||||||
| 
 | 
 | ||||||
| [0.6.1 - 17.10.2017] | ## [0.6.1 - 17.10.2017] | ||||||
| 	* fixed signatures loading | 	* fixed signatures loading | ||||||
| 	* new configurable: session_prefix, to allow more websites on one machine (must be unique for every website on your dedicated server!) | 	* new configurable: session_prefix, to allow more websites on one machine (must be unique for every website on your dedicated server!) | ||||||
| 	* better error handling for monsters and spells loader (save errors to system/logs/error.log) | 	* better error handling for monsters and spells loader (save errors to system/logs/error.log) | ||||||
| @@ -126,7 +236,7 @@ | |||||||
| 	* (internal) moved forum actions (pages) to forum/ directory | 	* (internal) moved forum actions (pages) to forum/ directory | ||||||
| 	* (internal) moved forum.edit_post to twig templates | 	* (internal) moved forum.edit_post to twig templates | ||||||
| 
 | 
 | ||||||
| [0.6.0 - 16.10.2017] | ## [0.6.0 - 16.10.2017] | ||||||
| 	* added faq management - add/edit/move/hide/delete from website | 	* added faq management - add/edit/move/hide/delete from website | ||||||
| 	* new account.login view for tibiacom template | 	* new account.login view for tibiacom template | ||||||
| 	* monsters and spells are now being loaded at the installation of the AAC | 	* monsters and spells are now being loaded at the installation of the AAC | ||||||
| @@ -149,7 +259,7 @@ | |||||||
| 	* ajax requests returns now json instead of xml | 	* ajax requests returns now json instead of xml | ||||||
| 	* added 404 response when file is not found | 	* added 404 response when file is not found | ||||||
| 
 | 
 | ||||||
| [0.5.1 - 11.10.2017] | ## [0.5.1 - 11.10.2017] | ||||||
| 	* fixed forum add/edit board | 	* fixed forum add/edit board | ||||||
| 	* new configurable: highscores_length, how much highscores to display | 	* new configurable: highscores_length, how much highscores to display | ||||||
| 	* fixed highscores links (ALL, previous and next page) | 	* fixed highscores links (ALL, previous and next page) | ||||||
| @@ -159,7 +269,7 @@ | |||||||
| 	* check if plugin exist before uninstalling | 	* check if plugin exist before uninstalling | ||||||
| 	* fixed some warning in OTS_Base_DB | 	* fixed some warning in OTS_Base_DB | ||||||
| 
 | 
 | ||||||
| [0.5.0 - 10.10.2017] | ## [0.5.0 - 10.10.2017] | ||||||
| 	* moved .htaccess rules to plain php (index.php) | 	* moved .htaccess rules to plain php (index.php) | ||||||
| 	* updated tinymce to the latest (4.7.0) version, you can now embed code, for example youtube videos | 	* updated tinymce to the latest (4.7.0) version, you can now embed code, for example youtube videos | ||||||
| 	* added option to uninstall plugin | 	* added option to uninstall plugin | ||||||
| @@ -178,7 +288,7 @@ | |||||||
| 	* added new twig function getLink that convert link taking into account config.friendly_urls | 	* added new twig function getLink that convert link taking into account config.friendly_urls | ||||||
| 	* internalLayoutLink -> getLink | 	* internalLayoutLink -> getLink | ||||||
| 
 | 
 | ||||||
| [0.4.3 - 05.10.2017] | ## [0.4.3 - 05.10.2017] | ||||||
| 	* better config loader taken from latest gesior, you can now include files in your config by doing dofile('config.local.lua') | 	* better config loader taken from latest gesior, you can now include files in your config by doing dofile('config.local.lua') | ||||||
| 	* fixed country detection in create account | 	* fixed country detection in create account | ||||||
| 	* fixed showing of character deaths and frags | 	* fixed showing of character deaths and frags | ||||||
| @@ -192,14 +302,14 @@ | |||||||
| 	* added bugtracker to kathrine template | 	* added bugtracker to kathrine template | ||||||
| 	* added CREDITS file | 	* added CREDITS file | ||||||
| 
 | 
 | ||||||
| [0.4.2 - 14.09.2017] | ## [0.4.2 - 14.09.2017] | ||||||
| 	* updated version number | 	* updated version number | ||||||
| 
 | 
 | ||||||
| [0.4.1 - 13.09.2017] | ## [0.4.1 - 13.09.2017] | ||||||
| 	* fixed log in to admin panel | 	* fixed log in to admin panel | ||||||
| 	* fixed File is not .zip plugin upload error | 	* fixed File is not .zip plugin upload error | ||||||
| 
 | 
 | ||||||
| [0.4.0 - 13.09.2017 | ## [0.4.0 - 13.09.2017 | ||||||
| 	* added option to add/edit/delete/hide/move forum boards | 	* added option to add/edit/delete/hide/move forum boards | ||||||
| 	* moved some of HTML-in-PHP code to Twig templates | 	* moved some of HTML-in-PHP code to Twig templates | ||||||
| 	* added bug_report configurable which can enable/disable bug tracker | 	* added bug_report configurable which can enable/disable bug tracker | ||||||
| @@ -216,7 +326,7 @@ | |||||||
| 	* some small improvements | 	* some small improvements | ||||||
| 	* fixed some separators in kathrine template | 	* fixed some separators in kathrine template | ||||||
| 
 | 
 | ||||||
| [0.3.0 - 28.08.2017] | ## [0.3.0 - 28.08.2017] | ||||||
| 	* added administration panel for screenshots management with auto thumbnail generator and image auto-resizing | 	* added administration panel for screenshots management with auto thumbnail generator and image auto-resizing | ||||||
| 	* added Twig template engine and moved some html-in-php code to it | 	* added Twig template engine and moved some html-in-php code to it | ||||||
| 	* automatically detect player country based on user location (IP) on create account | 	* automatically detect player country based on user location (IP) on create account | ||||||
| @@ -234,7 +344,7 @@ | |||||||
| 	* moved news adding at installation from schema.sql to finish.php | 	* moved news adding at installation from schema.sql to finish.php | ||||||
| 	* some optimizations | 	* some optimizations | ||||||
| 
 | 
 | ||||||
| [0.2.4 - 09.06.2017] | ## [0.2.4 - 09.06.2017] | ||||||
| 	* fixed invite to guild | 	* fixed invite to guild | ||||||
| 	* added id field on monsters, so you can delete them in phpmyadmin | 	* added id field on monsters, so you can delete them in phpmyadmin | ||||||
| 	* fixed adding some creatures with ' and " | 	* fixed adding some creatures with ' and " | ||||||
| @@ -243,7 +353,7 @@ | |||||||
| 	* fixed typo loss_items => loss_containers | 	* fixed typo loss_items => loss_containers | ||||||
| 	* more elegant way of showing message on reload creatures and spells | 	* more elegant way of showing message on reload creatures and spells | ||||||
| 
 | 
 | ||||||
| [0.2.3 - 31.05.2017] | ## [0.2.3 - 31.05.2017] | ||||||
| 	* fixed guild management on OTHire 0.0.3 | 	* fixed guild management on OTHire 0.0.3 | ||||||
| 	* set default skills to 10 when creating new character | 	* set default skills to 10 when creating new character | ||||||
| 	* fixed displaying of "Create forum thread" in newses | 	* fixed displaying of "Create forum thread" in newses | ||||||
| @@ -255,15 +365,15 @@ | |||||||
| 	* fixed Undefined variable (https://otland.net/threads/myaac-v0-0-1.251454/page-7#post-2444034) | 	* fixed Undefined variable (https://otland.net/threads/myaac-v0-0-1.251454/page-7#post-2444034) | ||||||
| 	* fixed Undefined offset (https://otland.net/threads/myaac-v0-0-1.251454/page-7#post-2444035) | 	* fixed Undefined offset (https://otland.net/threads/myaac-v0-0-1.251454/page-7#post-2444035) | ||||||
| 
 | 
 | ||||||
| [0.2.2 - 22.05.2017] | ## [0.2.2 - 22.05.2017] | ||||||
| 	* added missing cache/signature directory | 	* added missing cache/signature directory | ||||||
| 	* fixed https://otland.net/threads/myaac-v0-0-1.251454/page-7#post-2443868 | 	* fixed https://otland.net/threads/myaac-v0-0-1.251454/page-7#post-2443868 | ||||||
| 
 | 
 | ||||||
| [0.2.1 - 21.05.2017] | ## [0.2.1 - 21.05.2017] | ||||||
| 	* added Swedish translation by Sizaro | 	* added Swedish translation by Sizaro | ||||||
| 	* fixed some bugs with installlation & characters & houses | 	* fixed some bugs with installlation & characters & houses | ||||||
| 
 | 
 | ||||||
| [0.2.0 - 21.05.2017] | ## [0.2.0 - 21.05.2017] | ||||||
| 	* added option to change character sex for premium points | 	* added option to change character sex for premium points | ||||||
| 	* moved site_closed to database, now you can close your site through admin panel | 	* moved site_closed to database, now you can close your site through admin panel | ||||||
| 	* added option to admin panel: clear cache | 	* added option to admin panel: clear cache | ||||||
| @@ -283,10 +393,10 @@ | |||||||
| 	* fixed movies unexpected comment | 	* fixed movies unexpected comment | ||||||
| 	* added template_place_holder('center_top') to kathrine template | 	* added template_place_holder('center_top') to kathrine template | ||||||
| 
 | 
 | ||||||
| [0.1.5 - 13.05.2017] | ## [0.1.5 - 13.05.2017] | ||||||
| 	* fixed bug with "Integrity constraint violation: 1048 Column 'ip' cannot be null" | 	* fixed bug with "Integrity constraint violation: 1048 Column 'ip' cannot be null" | ||||||
| 
 | 
 | ||||||
| [0.1.4 - 13.05.2017] | ## [0.1.4 - 13.05.2017] | ||||||
| 	* added outfit shower, in characters, online, and highscores | 	* added outfit shower, in characters, online, and highscores | ||||||
| 	* updated database to version 2 | 	* updated database to version 2 | ||||||
| 	* fixed item images (now using item-images.ots.me host by default) | 	* fixed item images (now using item-images.ots.me host by default) | ||||||
| @@ -295,17 +405,17 @@ | |||||||
| 	* removed some unused code from my old server | 	* removed some unused code from my old server | ||||||
| 	* added spells & monsters to kathrine template | 	* added spells & monsters to kathrine template | ||||||
| 
 | 
 | ||||||
| [0.1.3 - 11.05.2017] | ## [0.1.3 - 11.05.2017] | ||||||
| 	* this is just release to update version number | 	* this is just release to update version number | ||||||
| 
 | 
 | ||||||
| [0.1.2 - 11.05.2017] | ## [0.1.2 - 11.05.2017] | ||||||
| 	* forgot to update CHANGELOG and MYAAC_VERSION | 	* forgot to update CHANGELOG and MYAAC_VERSION | ||||||
| 
 | 
 | ||||||
| [0.1.1 - 11.05.2017] | ## [0.1.1 - 11.05.2017] | ||||||
| 	* fixed updating myaac_config with database_version to 1 | 	* fixed updating myaac_config with database_version to 1 | ||||||
| 	* fixed database updater | 	* fixed database updater | ||||||
| 
 | 
 | ||||||
| [0.1.0 - 11.05.2017] | ## [0.1.0 - 11.05.2017] | ||||||
| 	* added new feature: change character name for premium points (disabled by default, you can enable it in config under account_change_character_name in config.php) | 	* added new feature: change character name for premium points (disabled by default, you can enable it in config under account_change_character_name in config.php) | ||||||
| 	* added automatic database updater (data migrations) | 	* added automatic database updater (data migrations) | ||||||
| 	* renamed events to hooks | 	* renamed events to hooks | ||||||
| @@ -329,13 +439,13 @@ | |||||||
| 	* fixed signatures (many fixes) | 	* fixed signatures (many fixes) | ||||||
| 	* added missing gesior signature system | 	* added missing gesior signature system | ||||||
| 
 | 
 | ||||||
| [0.0.6 - 06.05.2017] | ## [0.0.6 - 06.05.2017] | ||||||
| 	* fixed bug while installing (https://otland.net/threads/myaac-v0-0-1.251454/page-3#post-2440543) | 	* fixed bug while installing (https://otland.net/threads/myaac-v0-0-1.251454/page-3#post-2440543) | ||||||
| 	* fixed bug when creating character (not showing errors) (one more time) | 	* fixed bug when creating character (not showing errors) (one more time) | ||||||
| 	* fixed support for TFS 0.2 series | 	* fixed support for TFS 0.2 series | ||||||
| 	* added FAQ link | 	* added FAQ link | ||||||
| 
 | 
 | ||||||
| [0.0.5 - 05.05.2017] | ## [0.0.5 - 05.05.2017] | ||||||
| 	* fixed bug when creating character (not showing errors) | 	* fixed bug when creating character (not showing errors) | ||||||
| 	* Fixed characters loading with names that has been created with other AAC | 	* Fixed characters loading with names that has been created with other AAC | ||||||
| 	* fixed links to shop in default template | 	* fixed links to shop in default template | ||||||
| @@ -348,7 +458,7 @@ | |||||||
| 	* fixes when $config['database_*'] is set | 	* fixes when $config['database_*'] is set | ||||||
| 	* added CHANGELOG | 	* added CHANGELOG | ||||||
| 
 | 
 | ||||||
| [0.0.3 - 03.05.2017] | ## [0.0.3 - 03.05.2017] | ||||||
| 	* Full support for OTHire 0.0.3 | 	* Full support for OTHire 0.0.3 | ||||||
| 	* added support for otservers that doesn't use account.name field, instead just account number will be used | 	* added support for otservers that doesn't use account.name field, instead just account number will be used | ||||||
| 	* fixed encryption detection on TFS 0.3 | 	* fixed encryption detection on TFS 0.3 | ||||||
| @@ -359,7 +469,7 @@ | |||||||
| 	* fixed installation errors | 	* fixed installation errors | ||||||
| 	* fixed config.lua loading with some weird comments | 	* fixed config.lua loading with some weird comments | ||||||
| 
 | 
 | ||||||
| [0.0.2 - 02.05.2017] | ## [0.0.2 - 02.05.2017] | ||||||
| 	* updated forum links to use friendly_urls | 	* updated forum links to use friendly_urls | ||||||
| 	* some more info will be shown when cannot connect to database | 	* some more info will be shown when cannot connect to database | ||||||
| 	* show more error infos when creating character | 	* show more error infos when creating character | ||||||
| @@ -370,7 +480,7 @@ | |||||||
| 	* fixed support for gesior pages and templates | 	* fixed support for gesior pages and templates | ||||||
| 	* added function OTS_Acount:getGroupId() | 	* added function OTS_Acount:getGroupId() | ||||||
| 
 | 
 | ||||||
| [0.0.1 - 01.05.2017] | ## [0.0.1 - 01.05.2017] | ||||||
| 	This is first official release of MyAAC. | 	This is first official release of MyAAC. | ||||||
| 	Features are listed here | 	Features are listed here | ||||||
| 
 | 
 | ||||||
| @@ -5,7 +5,7 @@ Official website: https://my-aac.org | |||||||
|  |  | ||||||
| ### REQUIREMENTS | ### REQUIREMENTS | ||||||
|  |  | ||||||
| 	- PHP 5.3.0 or later | 	- PHP 5.3.3 or later | ||||||
| 	- MySQL database | 	- MySQL database | ||||||
| 	- PDO PHP Extension | 	- PDO PHP Extension | ||||||
| 	- XML PHP Extension | 	- XML PHP Extension | ||||||
| @@ -28,6 +28,7 @@ Official website: https://my-aac.org | |||||||
| 			chmod 660 images/guilds | 			chmod 660 images/guilds | ||||||
| 			chmod 660 images/houses | 			chmod 660 images/houses | ||||||
| 			chmod 660 images/gallery | 			chmod 660 images/gallery | ||||||
|  | 			chmod -R 770 system/cache | ||||||
|  |  | ||||||
| 	Visit http://your_domain/install (http://localhost/install) and follow instructions in the browser. | 	Visit http://your_domain/install (http://localhost/install) and follow instructions in the browser. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -26,8 +26,8 @@ | |||||||
| session_start(); | session_start(); | ||||||
|  |  | ||||||
| define('MYAAC', true); | define('MYAAC', true); | ||||||
| define('MYAAC_VERSION', '0.7.4'); | define('MYAAC_VERSION', '0.7.12'); | ||||||
| define('DATABASE_VERSION', 20); | define('DATABASE_VERSION', 22); | ||||||
| define('TABLE_PREFIX', 'myaac_'); | define('TABLE_PREFIX', 'myaac_'); | ||||||
| define('START_TIME', microtime(true)); | define('START_TIME', microtime(true)); | ||||||
| define('MYAAC_OS', (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') ? 'WINDOWS' : (strtoupper(PHP_OS) == 'DARWIN' ? 'MAC' : 'LINUX')); | define('MYAAC_OS', (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') ? 'WINDOWS' : (strtoupper(PHP_OS) == 'DARWIN' ? 'MAC' : 'LINUX')); | ||||||
|   | |||||||
| @@ -75,7 +75,7 @@ $config = array( | |||||||
|  |  | ||||||
| 	// images | 	// images | ||||||
| 	'outfit_images_url' => 'http://outfit-images.ots.me/outfit.php', // set to animoutfit.php for animated outfit | 	'outfit_images_url' => 'http://outfit-images.ots.me/outfit.php', // set to animoutfit.php for animated outfit | ||||||
| 	'item_images_url' => 'http://item-images.ots.me/960/', // set to images/items if you host your own items in images folder | 	'item_images_url' => 'http://item-images.ots.me/1092/', // set to images/items if you host your own items in images folder | ||||||
|  |  | ||||||
| 	// account | 	// account | ||||||
| 	'account_management' => true, // disable if you're using other method to manage users (fe. tfs account manager) | 	'account_management' => true, // disable if you're using other method to manage users (fe. tfs account manager) | ||||||
| @@ -107,6 +107,7 @@ $config = array( | |||||||
| 	'smtp_auth' => true, // need authorization? | 	'smtp_auth' => true, // need authorization? | ||||||
| 	'smtp_user' => 'admin@example.org', | 	'smtp_user' => 'admin@example.org', | ||||||
| 	'smtp_pass' => '', | 	'smtp_pass' => '', | ||||||
|  | 	'smtp_secure' => '', // What kind of encryption to use on the SMTP connection. Options: '', 'ssl' or 'tls', use 'ssl' for gmail | ||||||
|  |  | ||||||
| 	// reCAPTCHA (prevent spam bots) | 	// reCAPTCHA (prevent spam bots) | ||||||
| 	'recaptcha_enabled' => false, // enable recaptcha verification code | 	'recaptcha_enabled' => false, // enable recaptcha verification code | ||||||
| @@ -185,7 +186,7 @@ $config = array( | |||||||
| 	'highscores_frags' => false, // show 'Frags' tab (best fraggers on the server)? Only 0.3 | 	'highscores_frags' => false, // show 'Frags' tab (best fraggers on the server)? Only 0.3 | ||||||
| 	'highscores_outfit' => true, // show player outfit? | 	'highscores_outfit' => true, // show player outfit? | ||||||
| 	'highscores_country_box' => false, // doesnt work yet! (not implemented) | 	'highscores_country_box' => false, // doesnt work yet! (not implemented) | ||||||
| 	'highscores_groups_hidden' => 4, // this group id and higher won't be shown on the highscores | 	'highscores_groups_hidden' => 3, // this group id and higher won't be shown on the highscores | ||||||
| 	'highscores_ids_hidden' => array(0), // this ids of players will be hidden on the highscores (should be ids of samples) | 	'highscores_ids_hidden' => array(0), // this ids of players will be hidden on the highscores (should be ids of samples) | ||||||
| 	'highscores_length' => 100, // how many records per page on highscores | 	'highscores_length' => 100, // how many records per page on highscores | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										21
									
								
								index.php
									
									
									
									
									
								
							
							
						
						| @@ -51,7 +51,7 @@ if(preg_match("/^[A-Za-z0-9-_%\'+]+\.png$/i", $uri)) { | |||||||
| 	include(TOOLS . 'signature/index.php'); | 	include(TOOLS . 'signature/index.php'); | ||||||
| 	exit(); | 	exit(); | ||||||
| } | } | ||||||
| else if(preg_match("/^(.*)\.(gif|jpg|png|jpeg|tiff|bmp|css|js|less|map|html|php|zip|rar|gz)$/i", $_SERVER['REQUEST_URI'])) { | else if(preg_match("/^(.*)\.(gif|jpg|png|jpeg|tiff|bmp|css|js|less|map|html|php|zip|rar|gz|ttf|woff|ico)$/i", $_SERVER['REQUEST_URI'])) { | ||||||
| 	header("HTTP/1.0 404 Not Found"); | 	header("HTTP/1.0 404 Not Found"); | ||||||
| 	exit; | 	exit; | ||||||
| } | } | ||||||
| @@ -170,27 +170,28 @@ require_once(SYSTEM . 'status.php'); | |||||||
| $twig->addGlobal('config', $config); | $twig->addGlobal('config', $config); | ||||||
| $twig->addGlobal('status', $status); | $twig->addGlobal('status', $status); | ||||||
|  |  | ||||||
|  | // verify myaac tables exists in database | ||||||
|  | if(!tableExist('myaac_account_actions')) { | ||||||
|  | 	die('Seems that the table <strong>myaac_account_actions</strong> of MyAAC doesn\'t exist in the database. This is a fatal error. You can try to reinstall MyAAC by visiting <a href="' . BASE_URL . 'install">this</a> url.'); | ||||||
|  | } | ||||||
|  |  | ||||||
| // database migrations | // database migrations | ||||||
| $tmp = ''; | $tmp = ''; | ||||||
| if(fetchDatabaseConfig('database_version', $tmp)) { // we got version | if(fetchDatabaseConfig('database_version', $tmp)) { // we got version | ||||||
| 	$tmp = (int)$tmp; | 	$tmp = (int)$tmp; | ||||||
| 	if($tmp < DATABASE_VERSION) { // import if older | 	if($tmp < DATABASE_VERSION) { // import if older | ||||||
| 		for($i = $tmp + 1; $i <= DATABASE_VERSION; $i++) { | 		for($i = $tmp + 1; $i <= DATABASE_VERSION; $i++) { | ||||||
| 			$file = SYSTEM . 'migrations/' . $i . '.php'; | 			require(SYSTEM . 'migrations/' . $i . '.php'); | ||||||
| 			if(file_exists($file)) { | 			updateDatabaseConfig('database_version', $i); | ||||||
| 				require($file); |  | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 		 |  | ||||||
| 		updateDatabaseConfig('database_version', DATABASE_VERSION); |  | ||||||
| 	} |  | ||||||
| } | } | ||||||
| else { // register first version | else { // register first version | ||||||
|  | 	registerDatabaseConfig('database_version', 0); | ||||||
| 	for($i = 1; $i <= DATABASE_VERSION; $i++) { | 	for($i = 1; $i <= DATABASE_VERSION; $i++) { | ||||||
| 		require(SYSTEM . 'migrations/' . $i . '.php'); | 		require(SYSTEM . 'migrations/' . $i . '.php'); | ||||||
|  | 		updateDatabaseConfig('database_version', $i); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	registerDatabaseConfig('database_version', DATABASE_VERSION); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // event system | // event system | ||||||
| @@ -421,7 +422,7 @@ else | |||||||
| 	die('ERROR: Cannot load template.'); | 	die('ERROR: Cannot load template.'); | ||||||
| } | } | ||||||
|  |  | ||||||
| echo '<!-- MyAAC ' . MYAAC_VERSION . ' :: http://www.my-aac.org/ -->' . "\n"; | echo base64_decode('PCEtLSBQb3dlcmVkIGJ5IE15QUFDIDo6IGh0dHBzOi8vd3d3Lm15LWFhYy5vcmcvIC0tPg==') . PHP_EOL; | ||||||
| if(($config['debug_level'] & 1) == 1) | if(($config['debug_level'] & 1) == 1) | ||||||
| 	echo '<!-- Generated in :: ' . round(microtime(true) - START_TIME, 4) . ' -->'; | 	echo '<!-- Generated in :: ' . round(microtime(true) - START_TIME, 4) . ' -->'; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| CREATE TABLE `myaac_account_actions` | CREATE TABLE `myaac_account_actions` | ||||||
| ( | ( | ||||||
| 	`account_id` INT(11) NOT NULL, | 	`account_id` INT(11) NOT NULL, | ||||||
| 	`ip` INT(11) NOT NULL DEFAULT 0, | 	`ip` INT(10) UNSIGNED NOT NULL DEFAULT 0, | ||||||
| 	`ipv6` BINARY(16) NOT NULL DEFAULT 0, | 	`ipv6` BINARY(16) NOT NULL DEFAULT 0, | ||||||
| 	`date` INT(11) NOT NULL DEFAULT 0, | 	`date` INT(11) NOT NULL DEFAULT 0, | ||||||
| 	`action` VARCHAR(255) NOT NULL DEFAULT '', | 	`action` VARCHAR(255) NOT NULL DEFAULT '', | ||||||
| @@ -109,6 +109,7 @@ CREATE TABLE `myaac_forum` | |||||||
| 	`post_text` text NOT NULL, | 	`post_text` text NOT NULL, | ||||||
| 	`post_topic` varchar(255) NOT NULL DEFAULT '', | 	`post_topic` varchar(255) NOT NULL DEFAULT '', | ||||||
| 	`post_smile` tinyint(1) NOT NULL default '0', | 	`post_smile` tinyint(1) NOT NULL default '0', | ||||||
|  | 	`post_html` tinyint(1) NOT NULL default '0', | ||||||
| 	`post_date` int(20) NOT NULL default '0', | 	`post_date` int(20) NOT NULL default '0', | ||||||
| 	`last_edit_aid` int(20) NOT NULL default '0', | 	`last_edit_aid` int(20) NOT NULL default '0', | ||||||
| 	`edit_date` int(20) NOT NULL default '0', | 	`edit_date` int(20) NOT NULL default '0', | ||||||
| @@ -235,7 +236,7 @@ CREATE TABLE `myaac_monsters` ( | |||||||
| 	`summonable` tinyint(1) NOT NULL, | 	`summonable` tinyint(1) NOT NULL, | ||||||
| 	`convinceable` tinyint(1) NOT NULL, | 	`convinceable` tinyint(1) NOT NULL, | ||||||
| 	`race` varchar(255) NOT NULL, | 	`race` varchar(255) NOT NULL, | ||||||
| 	`loot` varchar(500) NOT NULL, | 	`loot` text NOT NULL, | ||||||
| 	PRIMARY KEY (`id`) | 	PRIMARY KEY (`id`) | ||||||
| ) ENGINE = MyISAM; | ) ENGINE = MyISAM; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -22,11 +22,11 @@ function version_check($name, $ok, $info = '', $warning = false) | |||||||
| $failed = false; | $failed = false; | ||||||
|  |  | ||||||
| // start validating | // start validating | ||||||
| version_check($locale['step_requirements_php_version'], (PHP_VERSION_ID >= 50300), PHP_VERSION); | version_check($locale['step_requirements_php_version'], (PHP_VERSION_ID >= 50303), PHP_VERSION); | ||||||
| foreach(array('config.local.php', 'images/guilds', 'images/houses', 'images/gallery') as $value) | foreach(array('config.local.php', 'images/guilds', 'images/houses', 'images/gallery') as $value) | ||||||
| { | { | ||||||
| 	$perms = (int) substr(decoct(fileperms(BASE . $value)), 2); | 	$is_writable = is_writable(BASE . $value); | ||||||
| 	version_check($locale['step_requirements_write_perms'] . ': ' . $value, $perms >= 660); | 	version_check($locale['step_requirements_write_perms'] . ': ' . $value, $is_writable); | ||||||
| } | } | ||||||
|  |  | ||||||
| $ini_register_globals = ini_get_bool('register_globals'); | $ini_register_globals = ini_get_bool('register_globals'); | ||||||
|   | |||||||
| @@ -174,6 +174,11 @@ if(!$error) { | |||||||
| 					success($locale['step_database_adding_field'] . ' accounts.premium_points...'); | 					success($locale['step_database_adding_field'] . ' accounts.premium_points...'); | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
|  | 			if(fieldExist('motd', 'guilds')) { | ||||||
|  | 				if(query("ALTER TABLE `guilds` MODIFY `motd` VARCHAR(255) NOT NULL DEFAULT '';")) | ||||||
|  | 					success($locale['step_database_modifying_field'] . ' guilds.motd...'); | ||||||
|  | 			} | ||||||
|  |  | ||||||
| 			if(!fieldExist('description', 'guilds')) { | 			if(!fieldExist('description', 'guilds')) { | ||||||
| 				if(query("ALTER TABLE `guilds` ADD `description` TEXT NOT NULL;")) | 				if(query("ALTER TABLE `guilds` ADD `description` TEXT NOT NULL;")) | ||||||
| 					success($locale['step_database_adding_field'] . ' guilds.description...'); | 					success($locale['step_database_adding_field'] . ' guilds.description...'); | ||||||
| @@ -198,7 +203,7 @@ if(!$error) { | |||||||
|  |  | ||||||
| 			if(!fieldExist('deleted', 'players') && !fieldExist('deletion', 'players')) { | 			if(!fieldExist('deleted', 'players') && !fieldExist('deletion', 'players')) { | ||||||
| 				if(query("ALTER TABLE `players` ADD `deleted` TINYINT(1) NOT NULL DEFAULT 0;")) | 				if(query("ALTER TABLE `players` ADD `deleted` TINYINT(1) NOT NULL DEFAULT 0;")) | ||||||
| 					success($locale['step_database_adding_field'] . ' players.comment...'); | 					success($locale['step_database_adding_field'] . ' players.deleted...'); | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 			if(fieldExist('hide_char', 'players')) { | 			if(fieldExist('hide_char', 'players')) { | ||||||
| @@ -219,6 +224,17 @@ if(!$error) { | |||||||
| 				if(query("ALTER TABLE `players` ADD `comment` TEXT NOT NULL;")) | 				if(query("ALTER TABLE `players` ADD `comment` TEXT NOT NULL;")) | ||||||
| 					success($locale['step_database_adding_field'] . ' players.comment...'); | 					success($locale['step_database_adding_field'] . ' players.comment...'); | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
|  | 			if(fieldExist('rank_id', 'players')) { | ||||||
|  | 				if(query("ALTER TABLE players MODIFY `rank_id` INT(11) NOT NULL DEFAULT 0;")) | ||||||
|  | 					success($locale['step_database_modifying_field'] . ' players.rank_id...'); | ||||||
|  |  | ||||||
|  | 				if(fieldExist('guildnick', 'players')) { | ||||||
|  | 					if(query("ALTER TABLE players MODIFY `guildnick` VARCHAR(255) NOT NULL DEFAULT '';")) { | ||||||
|  | 						success($locale['step_database_modifying_field'] . ' players.guildnick...'); | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		if(!$error && (!isset($_SESSION['saved']))) { | 		if(!$error && (!isset($_SESSION['saved']))) { | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| <?php | <?php | ||||||
| defined('MYAAC') or die('Direct access not allowed!'); | defined('MYAAC') or die('Direct access not allowed!'); | ||||||
|  |  | ||||||
|  | ini_set('max_execution_time', 300); | ||||||
| if(isset($config['installed']) && $config['installed'] && !isset($_SESSION['saved'])) { | if(isset($config['installed']) && $config['installed'] && !isset($_SESSION['saved'])) { | ||||||
| 	warning($locale['already_installed']); | 	warning($locale['already_installed']); | ||||||
| } | } | ||||||
| @@ -121,50 +122,34 @@ else { | |||||||
| 		$insert_into_players = "INSERT INTO `players` (`id`, `name`, `group_id`, `account_id`, `level`, `vocation`, `health`, `healthmax`, `experience`, `lookbody`, `lookfeet`, `lookhead`, `looklegs`, `looktype`, `maglevel`, `mana`, `manamax`, `manaspent`, `soul`, `town_id`, `posx`, `posy`, `posz`, `conditions`, `cap`, `sex`, `lastlogin`, `lastip`, `save`, `lastlogout`, `balance`, `$deleted`, `created`, `hidden`, `comment`) VALUES "; | 		$insert_into_players = "INSERT INTO `players` (`id`, `name`, `group_id`, `account_id`, `level`, `vocation`, `health`, `healthmax`, `experience`, `lookbody`, `lookfeet`, `lookhead`, `looklegs`, `looktype`, `maglevel`, `mana`, `manamax`, `manaspent`, `soul`, `town_id`, `posx`, `posy`, `posz`, `conditions`, `cap`, `sex`, `lastlogin`, `lastip`, `save`, `lastlogout`, `balance`, `$deleted`, `created`, `hidden`, `comment`) VALUES "; | ||||||
| 		$success = true; | 		$success = true; | ||||||
|  |  | ||||||
| 		$highscores_ignored_ids = array(); |  | ||||||
| 		$query = $db->query('SELECT `id` FROM `players` WHERE `name` = ' . $db->quote('Rook Sample')); | 		$query = $db->query('SELECT `id` FROM `players` WHERE `name` = ' . $db->quote('Rook Sample')); | ||||||
| 		if($query->rowCount() == 0) { | 		if($query->rowCount() == 0) { | ||||||
| 			if(!query($insert_into_players . "(null, 'Rook Sample', 1, " . getSession('account') . ", 1, 0, 150, 150, 4200, 118, 114, 38, 57, 130, 0, 0, 0, 0, 100, 1, 1000, 1000, 7, '', 400, 1, 1255179613, 2453925456, 1, 1255179614, 0, 0, UNIX_TIMESTAMP(), 1, '');")) | 			if(!query($insert_into_players . "(null, 'Rook Sample', 1, " . getSession('account') . ", 1, 0, 150, 150, 4200, 118, 114, 38, 57, 130, 0, 0, 0, 0, 100, 1, 1000, 1000, 7, '', 400, 1, 1255179613, 2453925456, 1, 1255179614, 0, 0, UNIX_TIMESTAMP(), 1, '');")) | ||||||
| 				$success = false; | 				$success = false; | ||||||
| 			else { |  | ||||||
| 				$highscores_ignored_ids[] = $db->lastInsertId(); |  | ||||||
| 			} |  | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		$query = $db->query('SELECT `id` FROM `players` WHERE `name` = ' . $db->quote('Sorcerer Sample')); | 		$query = $db->query('SELECT `id` FROM `players` WHERE `name` = ' . $db->quote('Sorcerer Sample')); | ||||||
| 		if($query->rowCount() == 0) { | 		if($query->rowCount() == 0) { | ||||||
| 			if(!query($insert_into_players . "(null, 'Sorcerer Sample', 1, " . getSession('account') . ", 8, 1, 185, 185, 4200, 118, 114, 38, 57, 130, 0, 35, 35, 0, 100, 1, 1000, 1000, 7, '', 470, 1, 1255179571, 2453925456, 1, 1255179612, 0, 0, UNIX_TIMESTAMP(), 1, '');")) | 			if(!query($insert_into_players . "(null, 'Sorcerer Sample', 1, " . getSession('account') . ", 8, 1, 185, 185, 4200, 118, 114, 38, 57, 130, 0, 35, 35, 0, 100, 1, 1000, 1000, 7, '', 470, 1, 1255179571, 2453925456, 1, 1255179612, 0, 0, UNIX_TIMESTAMP(), 1, '');")) | ||||||
| 				$success = false; | 				$success = false; | ||||||
| 			else { |  | ||||||
| 				$highscores_ignored_ids[] = $db->lastInsertId(); |  | ||||||
| 			} |  | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		$query = $db->query('SELECT `id` FROM `players` WHERE `name` = ' . $db->quote('Druid Sample')); | 		$query = $db->query('SELECT `id` FROM `players` WHERE `name` = ' . $db->quote('Druid Sample')); | ||||||
| 		if($query->rowCount() == 0) { | 		if($query->rowCount() == 0) { | ||||||
| 			if(!query($insert_into_players . "(null, 'Druid Sample', 1, " . getSession('account') . ", 8, 2, 185, 185, 4200, 118, 114, 38, 57, 130, 0, 35, 35, 0, 100, 1, 1000, 1000, 7, '', 470, 1, 1255179655, 2453925456, 1, 1255179658, 0, 0, UNIX_TIMESTAMP(), 1, '');")) | 			if(!query($insert_into_players . "(null, 'Druid Sample', 1, " . getSession('account') . ", 8, 2, 185, 185, 4200, 118, 114, 38, 57, 130, 0, 35, 35, 0, 100, 1, 1000, 1000, 7, '', 470, 1, 1255179655, 2453925456, 1, 1255179658, 0, 0, UNIX_TIMESTAMP(), 1, '');")) | ||||||
| 				$success = false; | 				$success = false; | ||||||
| 			else { |  | ||||||
| 				$highscores_ignored_ids[] = $db->lastInsertId(); |  | ||||||
| 			} |  | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		$query = $db->query('SELECT `id` FROM `players` WHERE `name` = ' . $db->quote('Paladin Sample')); | 		$query = $db->query('SELECT `id` FROM `players` WHERE `name` = ' . $db->quote('Paladin Sample')); | ||||||
| 		if($query->rowCount() == 0) { | 		if($query->rowCount() == 0) { | ||||||
| 			if(!query($insert_into_players . "(null, 'Paladin Sample', 1, " . getSession('account') . ", 8, 3, 185, 185, 4200, 118, 114, 38, 57, 129, 0, 35, 35, 0, 100, 1, 1000, 1000, 7, '', 470, 1, 1255179854, 2453925456, 1, 1255179858, 0, 0, UNIX_TIMESTAMP(), 1, '');")) | 			if(!query($insert_into_players . "(null, 'Paladin Sample', 1, " . getSession('account') . ", 8, 3, 185, 185, 4200, 118, 114, 38, 57, 129, 0, 35, 35, 0, 100, 1, 1000, 1000, 7, '', 470, 1, 1255179854, 2453925456, 1, 1255179858, 0, 0, UNIX_TIMESTAMP(), 1, '');")) | ||||||
| 				$success = false; | 				$success = false; | ||||||
| 			else { |  | ||||||
| 				$highscores_ignored_ids[] = $db->lastInsertId(); |  | ||||||
| 			} |  | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		$query = $db->query('SELECT `id` FROM `players` WHERE `name` = ' . $db->quote('Knight Sample')); | 		$query = $db->query('SELECT `id` FROM `players` WHERE `name` = ' . $db->quote('Knight Sample')); | ||||||
| 		if($query->rowCount() == 0) { | 		if($query->rowCount() == 0) { | ||||||
| 			if(!query($insert_into_players . "(null, 'Knight Sample', 1, " . getSession('account') . ", 8, 4, 185, 185, 4200, 118, 114, 38, 57, 131, 0, 35, 35, 0, 100, 1, 1000, 1000, 7, '', 470, 1, 1255179620, 2453925456, 1, 1255179654, 0, 0, UNIX_TIMESTAMP(), 1, '');")) | 			if(!query($insert_into_players . "(null, 'Knight Sample', 1, " . getSession('account') . ", 8, 4, 185, 185, 4200, 118, 114, 38, 57, 131, 0, 35, 35, 0, 100, 1, 1000, 1000, 7, '', 470, 1, 1255179620, 2453925456, 1, 1255179654, 0, 0, UNIX_TIMESTAMP(), 1, '');")) | ||||||
| 				$success = false; | 				$success = false; | ||||||
| 			else { |  | ||||||
| 				$highscores_ignored_ids[] = $db->lastInsertId(); |  | ||||||
| 			} |  | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		if($success) { | 		if($success) { | ||||||
| @@ -192,20 +177,19 @@ else { | |||||||
| 			error(Spells::getLastError()); | 			error(Spells::getLastError()); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		$content = PHP_EOL; | 		// update config.highscores_ids_hidden | ||||||
| 		$content .= '$config[\'highscores_ids_hidden\'] = array(' . implode(', ', $highscores_ignored_ids) . ');'; | 		$database_migration_20 = true; | ||||||
| 		$content .= PHP_EOL; | 		require_once(SYSTEM . 'migrations/20.php'); | ||||||
|  | 		$content = ''; | ||||||
| 		$file = fopen(BASE . 'config.local.php', 'a+'); | 		if(!databaseMigration20($content)) { | ||||||
| 		if($file) { |  | ||||||
| 			fwrite($file, $content); |  | ||||||
| 		} |  | ||||||
| 		else { |  | ||||||
| 			$locale['step_database_error_file'] = str_replace('$FILE$', '<b>' . BASE . 'config.local.php</b>', $locale['step_database_error_file']); | 			$locale['step_database_error_file'] = str_replace('$FILE$', '<b>' . BASE . 'config.local.php</b>', $locale['step_database_error_file']); | ||||||
| 			warning($locale['step_database_error_file'] . '<br/> | 			warning($locale['step_database_error_file'] . '<br/> | ||||||
| 						<textarea cols="70" rows="10">' . $content . '</textarea>'); | 						<textarea cols="70" rows="10">' . $content . '</textarea>'); | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
|  | 		// add z_polls tables | ||||||
|  | 		require_once(SYSTEM . 'migrations/22.php'); | ||||||
|  |  | ||||||
| 		$locale['step_finish_desc'] = str_replace('$ADMIN_PANEL$', generateLink(ADMIN_URL, $locale['step_finish_admin_panel'], true), $locale['step_finish_desc']); | 		$locale['step_finish_desc'] = str_replace('$ADMIN_PANEL$', generateLink(ADMIN_URL, $locale['step_finish_admin_panel'], true), $locale['step_finish_desc']); | ||||||
| 		$locale['step_finish_desc'] = str_replace('$HOMEPAGE$', generateLink(BASE_URL, $locale['step_finish_homepage'], true), $locale['step_finish_desc']); | 		$locale['step_finish_desc'] = str_replace('$HOMEPAGE$', generateLink(BASE_URL, $locale['step_finish_homepage'], true), $locale['step_finish_desc']); | ||||||
| 		$locale['step_finish_desc'] = str_replace('$LINK$', generateLink('http://my-aac.org', 'http://my-aac.org', true), $locale['step_finish_desc']); | 		$locale['step_finish_desc'] = str_replace('$LINK$', generateLink('http://my-aac.org', 'http://my-aac.org', true), $locale['step_finish_desc']); | ||||||
|   | |||||||
| @@ -1,5 +1,6 @@ | |||||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> | ||||||
| <html xmlns="http://www.w3.org/1999/xhtml" dir="<?php echo $locale['direction']; ?>" lang="<?php echo $locale['lang']; ?>" xml:lang="<?php echo $locale['lang']; ?>"> | <html xmlns="http://www.w3.org/1999/xhtml" dir="<?php echo $locale['direction']; ?>" lang="<?php echo $locale['lang']; ?>" xml:lang="<?php echo $locale['lang']; ?>"> | ||||||
|  | <head> | ||||||
| 	<meta http-equiv="Content-Type" content="text/html; charset=<?php echo $locale['encoding']; ?>" /> | 	<meta http-equiv="Content-Type" content="text/html; charset=<?php echo $locale['encoding']; ?>" /> | ||||||
| 	<title>MyAAC - <?php echo $locale['installation']; ?></title> | 	<title>MyAAC - <?php echo $locale['installation']; ?></title> | ||||||
| 	<link rel="stylesheet" type="text/css" href="template/style.css" /> | 	<link rel="stylesheet" type="text/css" href="template/style.css" /> | ||||||
| @@ -8,7 +9,7 @@ | |||||||
| 	<div id="wrapper"> | 	<div id="wrapper"> | ||||||
| 		<!--div class="buffer"--> | 		<!--div class="buffer"--> | ||||||
| 			<div id="header"> | 			<div id="header"> | ||||||
| 				<h1>MyAAC v<?php echo MYAAC_VERSION . ' ' . $locale['installation']; ?></h1> | 				<h1>MyAAC <?php echo $locale['installation']; ?></h1> | ||||||
| 			</div> | 			</div> | ||||||
|  |  | ||||||
| 			<div id="body"> | 			<div id="body"> | ||||||
|   | |||||||
							
								
								
									
										25
									
								
								nginx-sample.conf
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,25 @@ | |||||||
|  | server { | ||||||
|  |         listen 80; | ||||||
|  |         root /home/otserv/www/public; | ||||||
|  |         index index.php; | ||||||
|  |         server_name your-domain.com; | ||||||
|  |  | ||||||
|  |         location / { | ||||||
|  |                 try_files $uri $uri/ /index.php; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         location ~ \.php$ { | ||||||
|  |                 include snippets/fastcgi-php.conf; | ||||||
|  |                 fastcgi_read_timeout 240; | ||||||
|  |                 fastcgi_pass unix:/var/run/php/php7.2-fpm.sock; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         location ~ /\.ht { | ||||||
|  |                 deny all; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         location /system { | ||||||
|  |            deny all; | ||||||
|  |            return 404; | ||||||
|  |         } | ||||||
|  | } | ||||||
							
								
								
									
										2
									
								
								robots.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,2 @@ | |||||||
|  | User-agent: * | ||||||
|  | Disallow: | ||||||
| @@ -95,7 +95,7 @@ defined('MYAAC') or die('Direct access not allowed!'); | |||||||
| 			'<ul>' . | 			'<ul>' . | ||||||
| 				'<li>MySQL is not configured propertly in <i>config.lua</i>.</li>' . | 				'<li>MySQL is not configured propertly in <i>config.lua</i>.</li>' . | ||||||
| 				'<li>MySQL server is not running.</li>' . | 				'<li>MySQL server is not running.</li>' . | ||||||
| 			'</ul>' . $error); | 			'</ul>' . $error->getMessage()); | ||||||
|  |  | ||||||
| 	} | 	} | ||||||
| 	$db = POT::getInstance()->getDBHandle(); | 	$db = POT::getInstance()->getDBHandle(); | ||||||
|   | |||||||
| @@ -156,6 +156,10 @@ function getFlagImage($country) | |||||||
| 	if(!isset($config['countries'])) | 	if(!isset($config['countries'])) | ||||||
| 		require(SYSTEM . 'countries.conf.php'); | 		require(SYSTEM . 'countries.conf.php'); | ||||||
|  |  | ||||||
|  | 	if(!isset($config['countries'][$country])) { | ||||||
|  | 		return ''; | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
| 	return '<img src="images/flags/' . $country . '.gif" title="' . $config['countries'][$country]. '"/>'; | 	return '<img src="images/flags/' . $country . '.gif" title="' . $config['countries'][$country]. '"/>'; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -167,7 +171,9 @@ function getFlagImage($country) | |||||||
|  */ |  */ | ||||||
| function getBoolean($v) | function getBoolean($v) | ||||||
| { | { | ||||||
| 	if(!$v || !isset($v[0])) return false; | 	if(is_bool($v)) { | ||||||
|  | 		return $v; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	if(is_numeric($v)) | 	if(is_numeric($v)) | ||||||
| 		return intval($v) > 0; | 		return intval($v) > 0; | ||||||
| @@ -467,7 +473,7 @@ function template_header($is_admin = false) | |||||||
| 	$ret .= ' | 	$ret .= ' | ||||||
| 	<meta name="description" content="' . $config['meta_description'] . '" /> | 	<meta name="description" content="' . $config['meta_description'] . '" /> | ||||||
| 	<meta name="keywords" content="' . $config['meta_keywords'] . ', myaac, wodzaac" /> | 	<meta name="keywords" content="' . $config['meta_keywords'] . ', myaac, wodzaac" /> | ||||||
| 	<meta name="generator" content="MyAAC ' . MYAAC_VERSION . '" /> | 	<meta name="generator" content="MyAAC" /> | ||||||
| 	<link rel="stylesheet" type="text/css" href="' . BASE_URL . 'tools/messages.css" /> | 	<link rel="stylesheet" type="text/css" href="' . BASE_URL . 'tools/messages.css" /> | ||||||
| 	<script type="text/javascript" src="' . BASE_URL . 'tools/jquery.js"></script> | 	<script type="text/javascript" src="' . BASE_URL . 'tools/jquery.js"></script> | ||||||
| 	<noscript> | 	<noscript> | ||||||
| @@ -573,7 +579,7 @@ function getCreatureName($killer, $showStatus = false, $extendedInfo = false) | |||||||
|  |  | ||||||
| 			$str .= '<font color="'.($player->isOnline() ? 'green' : 'red').'">' . $player->getName() . '</font></b></a>'; | 			$str .= '<font color="'.($player->isOnline() ? 'green' : 'red').'">' . $player->getName() . '</font></b></a>'; | ||||||
| 			if($extendedInfo) { | 			if($extendedInfo) { | ||||||
| 				$str .= '<br><small>'.$player->getLevel().' '.$config['vocations'][$player->getVocation()].'</small>'; | 				$str .= '<br><small>'.$player->getLevel().' '.$player->getVocationName().'</small>'; | ||||||
| 			} | 			} | ||||||
| 			return $str; | 			return $str; | ||||||
| 		} | 		} | ||||||
| @@ -804,11 +810,16 @@ function getWorldName($id) | |||||||
|  */ |  */ | ||||||
| function _mail($to, $subject, $body, $altBody = '', $add_html_tags = true) | function _mail($to, $subject, $body, $altBody = '', $add_html_tags = true) | ||||||
| { | { | ||||||
|  | 	/** @var PHPMailer $mailer */ | ||||||
| 	global $mailer, $config; | 	global $mailer, $config; | ||||||
| 	if(!$mailer) | 	if(!$mailer) | ||||||
| 	{ | 	{ | ||||||
| 		require(SYSTEM . 'libs/phpmailer/PHPMailerAutoload.php'); | 		require(SYSTEM . 'libs/phpmailer/PHPMailerAutoload.php'); | ||||||
| 		$mailer = new PHPMailer(); | 		$mailer = new PHPMailer(); | ||||||
|  | 		$mailer->setLanguage('en', LIBS . 'phpmailer/language/'); | ||||||
|  | 	} | ||||||
|  | 	else { | ||||||
|  | 		$mailer->clearAllRecipients(); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	$signature_html = ''; | 	$signature_html = ''; | ||||||
| @@ -828,6 +839,7 @@ function _mail($to, $subject, $body, $altBody = '', $add_html_tags = true) | |||||||
| 		$mailer->SMTPAuth = $config['smtp_auth']; | 		$mailer->SMTPAuth = $config['smtp_auth']; | ||||||
| 		$mailer->Username = $config['smtp_user']; | 		$mailer->Username = $config['smtp_user']; | ||||||
| 		$mailer->Password = $config['smtp_pass']; | 		$mailer->Password = $config['smtp_pass']; | ||||||
|  | 		$mailer->SMTPSecure = isset($config['smtp_secure']) ? $config['smtp_secure'] : ''; | ||||||
| 	} | 	} | ||||||
| 	else | 	else | ||||||
| 		$mailer->IsMail(); | 		$mailer->IsMail(); | ||||||
| @@ -909,6 +921,10 @@ function load_config_lua($filename) | |||||||
| 						$result[$key] = (string) substr(substr($value, 1), 0, -1); | 						$result[$key] = (string) substr(substr($value, 1), 0, -1); | ||||||
| 					elseif(in_array($value, array('true', 'false'))) | 					elseif(in_array($value, array('true', 'false'))) | ||||||
| 						$result[$key] = ($value == 'true') ? true : false; | 						$result[$key] = ($value == 'true') ? true : false; | ||||||
|  | 					elseif(substr($value, 0 , 1) == '{' && substr($value, -1 , 1) == '}') { | ||||||
|  | 						// arrays are not supported yet | ||||||
|  | 						// just ignore the error | ||||||
|  | 					} | ||||||
| 					else | 					else | ||||||
| 					{ | 					{ | ||||||
| 						foreach($result as $tmp_key => $tmp_value) // load values definied by other keys, like: dailyFragsToBlackSkull = dailyFragsToRedSkull | 						foreach($result as $tmp_key => $tmp_value) // load values definied by other keys, like: dailyFragsToBlackSkull = dailyFragsToRedSkull | ||||||
| @@ -971,7 +987,15 @@ function getTopPlayers($limit = 5) { | |||||||
| 		if(fieldExist('deletion', 'players')) | 		if(fieldExist('deletion', 'players')) | ||||||
| 			$deleted = 'deletion'; | 			$deleted = 'deletion'; | ||||||
|  |  | ||||||
| 		$players = $db->query('SELECT `name`, `level`, `experience` FROM `players` WHERE `group_id` < ' . $config['highscores_groups_hidden'] . ' AND `id` NOT IN (' . implode(', ', $config['highscores_ids_hidden']) . ') AND `' . $deleted . '` = 0 AND `account_id` != 1 ORDER BY `experience` DESC LIMIT 5')->fetchAll(); | 		$is_tfs10 = tableExist('players_online'); | ||||||
|  | 		$players = $db->query('SELECT `id`, `name`, `level`, `experience`' . ($is_tfs10 ? '' : ', `online`') . ' FROM `players` WHERE `group_id` < ' . $config['highscores_groups_hidden'] . ' AND `id` NOT IN (' . implode(', ', $config['highscores_ids_hidden']) . ') AND `' . $deleted . '` = 0 AND `account_id` != 1 ORDER BY `experience` DESC LIMIT ' . (int)$limit)->fetchAll(); | ||||||
|  |  | ||||||
|  | 		if($is_tfs10) { | ||||||
|  | 			foreach($players as &$player) { | ||||||
|  | 				$query = $db->query('SELECT `player_id` FROM `players_online` WHERE `player_id` = ' . $player['id']); | ||||||
|  | 				$player['online'] = ($query->rowCount() > 0 ? 1 : 0); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		$i = 0; | 		$i = 0; | ||||||
| 		foreach($players as &$player) { | 		foreach($players as &$player) { | ||||||
|   | |||||||
| @@ -42,12 +42,12 @@ class Hook | |||||||
| 			$ret = $tmp($params); | 			$ret = $tmp($params); | ||||||
| 		}*/ | 		}*/ | ||||||
| 		 | 		 | ||||||
| 		global $db, $config, $template_path, $ots, $content; | 		global $db, $config, $template_path, $ots, $content, $twig; | ||||||
| 		if(file_exists(BASE . $this->_file)) { | 		if(file_exists(BASE . $this->_file)) { | ||||||
| 			require(BASE . $this->_file); | 			$ret = require(BASE . $this->_file); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		return true; | 		return $ret === null || $ret == 1 || $ret; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function name() {return $this->_name;} | 	public function name() {return $this->_name;} | ||||||
| @@ -71,12 +71,18 @@ class Hooks | |||||||
| 		if(isset(self::$_hooks[$type])) | 		if(isset(self::$_hooks[$type])) | ||||||
| 		{ | 		{ | ||||||
| 			foreach(self::$_hooks[$type] as $name => $hook) | 			foreach(self::$_hooks[$type] as $name => $hook) | ||||||
| 				$ret = $hook->execute($params); | 				if(!$hook->execute($params)) { | ||||||
|  | 					$ret = false; | ||||||
|  | 				} | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		return $ret; | 		return $ret; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	public function exist($type) { | ||||||
|  | 		return isset(self::$_hooks[$type]); | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
| 	public function load() | 	public function load() | ||||||
| 	{ | 	{ | ||||||
| 		global $db; | 		global $db; | ||||||
|   | |||||||
| @@ -8,14 +8,14 @@ | |||||||
|  * @link      http://my-aac.org |  * @link      http://my-aac.org | ||||||
|  */ |  */ | ||||||
| defined('MYAAC') or die('Direct access not allowed!'); | defined('MYAAC') or die('Direct access not allowed!'); | ||||||
|  |  | ||||||
| // load configuration | // load configuration | ||||||
| require_once(BASE . 'config.php'); | require_once(BASE . 'config.php'); | ||||||
| if(file_exists(BASE . 'config.local.php')) // user customizations | if(file_exists(BASE . 'config.local.php')) // user customizations | ||||||
| 	require(BASE . 'config.local.php'); | 	require(BASE . 'config.local.php'); | ||||||
|  |  | ||||||
| if(!isset($config['installed']) || !$config['installed']) { | if(!isset($config['installed']) || !$config['installed']) { | ||||||
| 	header('Location: ' . BASE_URL); | 	die('MyAAC has not been installed yet or there was error during installation. Please install again.'); | ||||||
| 	die('AAC has not been installed yet or there was error during installation. Please install again.'); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| date_default_timezone_set($config['date_timezone']); | date_default_timezone_set($config['date_timezone']); | ||||||
| @@ -87,21 +87,26 @@ if(isset($_REQUEST)) | |||||||
| } | } | ||||||
|  |  | ||||||
| // load otserv config file | // load otserv config file | ||||||
| $tmp = ''; | $config_lua_reload = true; | ||||||
| if($cache->enabled() && $cache->fetch('config_lua', $tmp)) { | if($cache->enabled()) { | ||||||
|  | 	$tmp = null; | ||||||
|  | 	if($cache->fetch('server_path', $tmp) && $tmp == $config['server_path']) { | ||||||
|  | 		$tmp = null; | ||||||
|  | 		if($cache->fetch('config_lua', $tmp) && $tmp) { | ||||||
| 			$config['lua'] = unserialize($tmp); | 			$config['lua'] = unserialize($tmp); | ||||||
| 	/*if(isset($config['lua']['myaac'][0])) { | 			$config_lua_reload = false; | ||||||
| 		foreach($config['lua']['myaac'] as $key => $value) |  | ||||||
| 			$config[$key] = $value; |  | ||||||
| 	}*/ |  | ||||||
| 		} | 		} | ||||||
| else | 	} | ||||||
| { | } | ||||||
|  |  | ||||||
|  | if($config_lua_reload) { | ||||||
| 	$config['lua'] = load_config_lua($config['server_path'] . 'config.lua'); | 	$config['lua'] = load_config_lua($config['server_path'] . 'config.lua'); | ||||||
|  |  | ||||||
| 	// cache config | 	// cache config | ||||||
| 	if($cache->enabled()) | 	if($cache->enabled()) { | ||||||
| 		$cache->set('config_lua', serialize($config['lua']), 120); | 		$cache->set('config_lua', serialize($config['lua']), 120); | ||||||
|  | 		$cache->set('server_path', $config['server_path']); | ||||||
|  | 	} | ||||||
| } | } | ||||||
| unset($tmp); | unset($tmp); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -31,7 +31,7 @@ class Cache_APC | |||||||
| 	public function get($key) | 	public function get($key) | ||||||
| 	{ | 	{ | ||||||
| 		$tmp = ''; | 		$tmp = ''; | ||||||
| 		if($this->fetch($key, $tmp)) | 		if($this->fetch($this->prefix . $key, $tmp)) | ||||||
| 			return $tmp; | 			return $tmp; | ||||||
|  |  | ||||||
| 		return ''; | 		return ''; | ||||||
| @@ -42,7 +42,7 @@ class Cache_APC | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function delete($key) { | 	public function delete($key) { | ||||||
| 		apc_delete($key); | 		apc_delete($this->prefix . $key); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function enabled() { | 	public function enabled() { | ||||||
|   | |||||||
| @@ -30,7 +30,7 @@ class Cache_eAccelerator | |||||||
| 	public function get($key) | 	public function get($key) | ||||||
| 	{ | 	{ | ||||||
| 		$tmp = ''; | 		$tmp = ''; | ||||||
| 		if($this->fetch($key, $tmp)) | 		if($this->fetch($this->prefix . $key, $tmp)) | ||||||
| 			return $tmp; | 			return $tmp; | ||||||
|  |  | ||||||
| 		return ''; | 		return ''; | ||||||
| @@ -41,7 +41,7 @@ class Cache_eAccelerator | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function delete($key) { | 	public function delete($key) { | ||||||
| 		eaccelerator_rm($key); | 		eaccelerator_rm($this->prefix . $key); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function enabled() { | 	public function enabled() { | ||||||
|   | |||||||
| @@ -30,7 +30,7 @@ class Cache_XCache | |||||||
| 	public function get($key) | 	public function get($key) | ||||||
| 	{ | 	{ | ||||||
| 		$tmp = ''; | 		$tmp = ''; | ||||||
| 		if($this->fetch($key, $tmp)) | 		if($this->fetch($this->prefix . $key, $tmp)) | ||||||
| 			return $tmp; | 			return $tmp; | ||||||
|  |  | ||||||
| 		return ''; | 		return ''; | ||||||
| @@ -47,7 +47,7 @@ class Cache_XCache | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function delete($key) { | 	public function delete($key) { | ||||||
| 		xcache_unset($key); | 		xcache_unset($this->prefix . $key); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function enabled() { | 	public function enabled() { | ||||||
|   | |||||||
| @@ -37,7 +37,20 @@ class Forum | |||||||
| 	{ | 	{ | ||||||
| 		global $db; | 		global $db; | ||||||
| 		$thread_id = 0; | 		$thread_id = 0; | ||||||
| 		if($db->insert(TABLE_PREFIX . 'forum', array('first_post' => 0, 'last_post' => time(), 'section' => $section_id, 'replies' => 0, 'views' => 0, 'author_aid' => isset($account_id) ? $account_id : 0, 'author_guid' => isset($player_id) ? $player_id : 0, 'post_text' => $body, 'post_topic' => $title, 'post_smile' => 0, 'post_date' => time(), 'last_edit_aid' => 0, 'edit_date' => 0, 'post_ip' => $_SERVER['REMOTE_ADDR']))) { | 		if($db->insert(TABLE_PREFIX . 'forum', array( | ||||||
|  | 			'first_post' => 0, | ||||||
|  | 			'last_post' => time(), | ||||||
|  | 			'section' => $section_id, | ||||||
|  | 			'replies' => 0, | ||||||
|  | 			'views' => 0, | ||||||
|  | 			'author_aid' => isset($account_id) ? $account_id : 0, | ||||||
|  | 			'author_guid' => isset($player_id) ? $player_id : 0, | ||||||
|  | 			'post_text' => $body, 'post_topic' => $title, | ||||||
|  | 			'post_smile' => 0, 'post_html' => 1, | ||||||
|  | 			'post_date' => time(), | ||||||
|  | 			'last_edit_aid' => 0, 'edit_date' => 0, | ||||||
|  | 			'post_ip' => $_SERVER['REMOTE_ADDR'] | ||||||
|  | 		))) { | ||||||
| 			$thread_id = $db->lastInsertId(); | 			$thread_id = $db->lastInsertId(); | ||||||
| 			$db->query("UPDATE `" . TABLE_PREFIX . "forum` SET `first_post`=".(int) $thread_id." WHERE `id` = ".(int) $thread_id); | 			$db->query("UPDATE `" . TABLE_PREFIX . "forum` SET `first_post`=".(int) $thread_id." WHERE `id` = ".(int) $thread_id); | ||||||
| 		} | 		} | ||||||
| @@ -45,7 +58,7 @@ class Forum | |||||||
| 		return $thread_id; | 		return $thread_id; | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	static public function add_post($thread_id, $section, $author_aid, $author_guid, $post_text, $post_topic, $smile) | 	static public function add_post($thread_id, $section, $author_aid, $author_guid, $post_text, $post_topic, $smile, $html) | ||||||
| 	{ | 	{ | ||||||
| 		global $db; | 		global $db; | ||||||
| 		$db->insert(TABLE_PREFIX . 'forum', array( | 		$db->insert(TABLE_PREFIX . 'forum', array( | ||||||
| @@ -56,6 +69,7 @@ class Forum | |||||||
| 			'post_text' => $post_text, | 			'post_text' => $post_text, | ||||||
| 			'post_topic' => $post_topic, | 			'post_topic' => $post_topic, | ||||||
| 			'post_smile' => $smile, | 			'post_smile' => $smile, | ||||||
|  | 			'post_html' => $html, | ||||||
| 			'post_date' => time(), | 			'post_date' => time(), | ||||||
| 			'post_ip' => $_SERVER['REMOTE_ADDR'] | 			'post_ip' => $_SERVER['REMOTE_ADDR'] | ||||||
| 		)); | 		)); | ||||||
| @@ -232,16 +246,20 @@ class Forum | |||||||
| 		foreach($tags as $search => $replace) | 		foreach($tags as $search => $replace) | ||||||
| 			$text = preg_replace($search, $replace, $text); | 			$text = preg_replace($search, $replace, $text); | ||||||
| 		 | 		 | ||||||
| 		return ($smiles == 0 ? Forum::parseSmiles($text) : $text); | 		return ($smiles ? Forum::parseSmiles($text) : $text); | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	public static function showPost($topic, $text, $smiles) | 	public static function showPost($topic, $text, $smiles = true, $html = false) | ||||||
| 	{ | 	{ | ||||||
| 		$text = nl2br($text); | 		if($html) { | ||||||
|  | 			return '<b>' . $topic . '</b><hr />' . $text; | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		$post = ''; | 		$post = ''; | ||||||
| 		if(!empty($topic)) | 		if(!empty($topic)) | ||||||
| 			$post .= '<b>'.($smiles == 0 ? self::parseSmiles($topic) : $topic).'</b><hr />'; | 			$post .= '<b>'.($smiles ? self::parseSmiles($topic) : $topic).'</b><hr />'; | ||||||
| 		$post .= self::parseBBCode($text, $smiles); |  | ||||||
|  | 		$post .= self::parseBBCode(nl2br($text), $smiles); | ||||||
| 		return $post; | 		return $post; | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
|   | |||||||
| @@ -30,20 +30,4 @@ function PHPMailerAutoload($classname) | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| if (version_compare(PHP_VERSION, '5.1.2', '>=')) { |  | ||||||
|     //SPL autoloading was introduced in PHP 5.1.2 |  | ||||||
|     if (version_compare(PHP_VERSION, '5.3.0', '>=')) { |  | ||||||
|         spl_autoload_register('PHPMailerAutoload', true, true); |         spl_autoload_register('PHPMailerAutoload', true, true); | ||||||
|     } else { |  | ||||||
|         spl_autoload_register('PHPMailerAutoload'); |  | ||||||
|     } |  | ||||||
| } else { |  | ||||||
|     /** |  | ||||||
|      * Fall back to traditional autoload for old PHP versions |  | ||||||
|      * @param string $classname The name of the class to load |  | ||||||
|      */ |  | ||||||
|     function __autoload($classname) |  | ||||||
|     { |  | ||||||
|         PHPMailerAutoload($classname); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|   | |||||||
| @@ -10,6 +10,34 @@ | |||||||
|  */ |  */ | ||||||
| defined('MYAAC') or die('Direct access not allowed!'); | defined('MYAAC') or die('Direct access not allowed!'); | ||||||
|  |  | ||||||
|  | function is_sub_dir($path = NULL, $parent_folder = SITE_PATH) { | ||||||
|  | 	 | ||||||
|  | 	//Get directory path minus last folder | ||||||
|  | 	$dir = dirname($path); | ||||||
|  | 	$folder = substr($path, strlen($dir)); | ||||||
|  | 	 | ||||||
|  | 	//Check the the base dir is valid | ||||||
|  | 	$dir = realpath($dir); | ||||||
|  | 	 | ||||||
|  | 	//Only allow valid filename characters | ||||||
|  | 	$folder = preg_replace('/[^a-z0-9\.\-_]/i', '', $folder); | ||||||
|  | 	 | ||||||
|  | 	//If this is a bad path or a bad end folder name | ||||||
|  | 	if( !$dir OR !$folder OR $folder === '.') { | ||||||
|  | 		return FALSE; | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | 	//Rebuild path | ||||||
|  | 	$path = $dir. '/' . $folder; | ||||||
|  | 	 | ||||||
|  | 	//If this path is higher than the parent folder | ||||||
|  | 	if( strcasecmp($path, $parent_folder) > 0 ) { | ||||||
|  | 		return $path; | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | 	return FALSE; | ||||||
|  | } | ||||||
|  |  | ||||||
| class Plugins { | class Plugins { | ||||||
| 	private static $warnings = array(); | 	private static $warnings = array(); | ||||||
| 	private static $error = null; | 	private static $error = null; | ||||||
| @@ -160,16 +188,33 @@ class Plugins { | |||||||
| 				else { | 				else { | ||||||
| 					$success = true; | 					$success = true; | ||||||
| 					foreach($plugin_info['uninstall'] as $file) { | 					foreach($plugin_info['uninstall'] as $file) { | ||||||
| 						$file = BASE . $file; | 						if(strpos($file, '/') === 0) { | ||||||
| 						if(!deleteDirectory($file)) { |  | ||||||
| 							$success = false; | 							$success = false; | ||||||
|  | 							self::$error = "You cannot use absolute paths (starting with slash - '/'): " . $file; | ||||||
|  | 							break; | ||||||
|  | 						} | ||||||
|  | 						 | ||||||
|  | 						$file = str_replace('\\', '/', BASE . $file); | ||||||
|  | 						$realpath = str_replace('\\', '/', realpath(dirname($file))); | ||||||
|  | 						if(!is_sub_dir($file, BASE) || $realpath != dirname($file)) { | ||||||
|  | 							$success = false; | ||||||
|  | 							self::$error = "You don't have rights to delete: " . $file; | ||||||
|  | 							break; | ||||||
|  | 						} | ||||||
|  | 					} | ||||||
|  |  | ||||||
|  | 					if($success) { | ||||||
|  | 						foreach($plugin_info['uninstall'] as $file) { | ||||||
|  | 							if(!deleteDirectory(BASE . $file)) { | ||||||
|  | 								self::$warnings[] = 'Cannot delete: ' . $$file; | ||||||
|  | 							} | ||||||
| 						} | 						} | ||||||
| 					} | 					} | ||||||
|  |  | ||||||
| 					if (isset($plugin_info['hooks'])) { | 					if (isset($plugin_info['hooks'])) { | ||||||
| 						foreach ($plugin_info['hooks'] as $_name => $info) { | 						foreach ($plugin_info['hooks'] as $_name => $info) { | ||||||
| 							if (defined('HOOK_'. $info['type'])) { | 							if (defined('HOOK_'. $info['type'])) { | ||||||
| 								$hook = constant('HOOK_'. $info['type']); | 								//$hook = constant('HOOK_'. $info['type']); | ||||||
| 								$query = $db->query('SELECT `id` FROM `' . TABLE_PREFIX . 'hooks` WHERE `name` = ' . $db->quote($_name) . ';'); | 								$query = $db->query('SELECT `id` FROM `' . TABLE_PREFIX . 'hooks` WHERE `name` = ' . $db->quote($_name) . ';'); | ||||||
| 								if ($query->rowCount() == 1) { // found something | 								if ($query->rowCount() == 1) { // found something | ||||||
| 									$query = $query->fetch(); | 									$query = $query->fetch(); | ||||||
| @@ -187,9 +232,6 @@ class Plugins { | |||||||
| 						 | 						 | ||||||
| 						return true; | 						return true; | ||||||
| 					} | 					} | ||||||
| 					else { |  | ||||||
| 						self::$error = error_get_last(); |  | ||||||
| 					} |  | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|   | |||||||
| @@ -170,7 +170,7 @@ class OTS_Account extends OTS_Row_DAO implements IteratorAggregate, Countable | |||||||
|     public function load($id) |     public function load($id) | ||||||
|     { |     { | ||||||
|         // SELECT query on database |         // SELECT query on database | ||||||
|         $this->data = $this->db->query('SELECT `id`, ' . (fieldExist('name', 'accounts') ? '`name`,' : '') . '`password`, `email`, ' . $this->db->fieldName('blocked') . ', ' . $this->db->fieldName('rlname') . ', ' . $this->db->fieldName('location') . ', ' . $this->db->fieldName('web_flags') . ', ' . (fieldExist('premdays', 'accounts') ? $this->db->fieldName('premdays') . ',' : '') . (fieldExist('lastday', 'accounts') ? $this->db->fieldName('lastday') . ',' : (fieldExist('premend', 'accounts') ?  $this->db->fieldName('premend') . ' as `lastday`,' : '')) . $this->db->fieldName('created') . ' FROM ' . $this->db->tableName('accounts') . ' WHERE ' . $this->db->fieldName('id') . ' = ' . (int) $id)->fetch(); |         $this->data = $this->db->query('SELECT `id`, ' . (fieldExist('name', 'accounts') ? '`name`,' : '') . '`password`, `email`, ' . $this->db->fieldName('blocked') . ', ' . $this->db->fieldName('rlname') . ', ' . $this->db->fieldName('location') . ', ' . $this->db->fieldName('web_flags') . ', ' . (fieldExist('premdays', 'accounts') ? $this->db->fieldName('premdays') . ',' : '') . (fieldExist('lastday', 'accounts') ? $this->db->fieldName('lastday') . ',' : (fieldExist('premend', 'accounts') ?  $this->db->fieldName('premend') . ',' : '')) . $this->db->fieldName('created') . ' FROM ' . $this->db->tableName('accounts') . ' WHERE ' . $this->db->fieldName('id') . ' = ' . (int) $id)->fetch(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -249,12 +249,16 @@ class OTS_Account extends OTS_Row_DAO implements IteratorAggregate, Countable | |||||||
|             throw new E_OTS_NotLoaded(); |             throw new E_OTS_NotLoaded(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| 		$lastday = 'lastday'; | 	$field = 'lastday'; | ||||||
| 		if(fieldExist('premend', 'accounts')) | 	if(fieldExist('premend', 'accounts')) { // othire | ||||||
| 			$lastday = 'premend'; |     		$field = 'premend'; | ||||||
|  | 		if(!isset($this->data['premend'])) { | ||||||
|  | 			$this->data['premend'] = 0; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|         // UPDATE query on database |         // UPDATE query on database | ||||||
|         $this->db->query('UPDATE `accounts` SET ' . (fieldExist('name', 'accounts') ? '`name` = ' . $this->db->quote($this->data['name']) . ',' : '') . '`password` = ' . $this->db->quote($this->data['password']) . ', `email` = ' . $this->db->quote($this->data['email']) . ', `blocked` = ' . (int) $this->data['blocked'] . ', `rlname` = ' . $this->db->quote($this->data['rlname']) . ', `location` = ' . $this->db->quote($this->data['location']) . ', `web_flags` = ' . (int) $this->data['web_flags'] . ', ' . (fieldExist('premdays', 'accounts') ? '`premdays` = ' . (int) $this->data['premdays'] . ',' : '') . '`' . $lastday . '` = ' . (int) $this->data['lastday'] . ' WHERE `id` = ' . $this->data['id']); |         $this->db->query('UPDATE `accounts` SET ' . (fieldExist('name', 'accounts') ? '`name` = ' . $this->db->quote($this->data['name']) . ',' : '') . '`password` = ' . $this->db->quote($this->data['password']) . ', `email` = ' . $this->db->quote($this->data['email']) . ', `blocked` = ' . (int) $this->data['blocked'] . ', `rlname` = ' . $this->db->quote($this->data['rlname']) . ', `location` = ' . $this->db->quote($this->data['location']) . ', `web_flags` = ' . (int) $this->data['web_flags'] . ', ' . (fieldExist('premdays', 'accounts') ? '`premdays` = ' . (int) $this->data['premdays'] . ',' : '') . '`' . $field . '` = ' . (int) $this->data[$field] . ' WHERE `id` = ' . $this->data['id']); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -329,19 +333,21 @@ class OTS_Account extends OTS_Row_DAO implements IteratorAggregate, Countable | |||||||
|  |  | ||||||
| 	public function getPremDays() | 	public function getPremDays() | ||||||
| 	{ | 	{ | ||||||
|         if( !isset($this->data['lastday']) ) | 		if(!isset($this->data['lastday']) && !isset($this->data['premend'])) { | ||||||
|         { |  | ||||||
| 			throw new E_OTS_NotLoaded(); | 			throw new E_OTS_NotLoaded(); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		if(fieldExist('premdays', 'accounts')) | 		if(isset($this->data['premend'])) { | ||||||
| 			return $this->data['premdays']; | 			return round(($this->data['premend'] - time()) / (24 * 60 * 60), 2); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|         if($this->data['lastday'] == 0) | 		if($this->data['premdays'] == 0) { | ||||||
| 			return 0; | 			return 0; | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		return round(($this->data['lastday'] - time()) / (24 * 60 * 60), 3); | 		global $config; | ||||||
|         //return $this->data['premdays'] - (date("z", time()) + (365 * (date("Y", time()) - date("Y", $this->data['lastday']))) - date("z", $this->data['lastday'])); |         if(isset($config['lua']['freePremium']) && getBoolean($config['lua']['freePremium'])) return -1; | ||||||
|  | 		return $this->data['premdays'] - (date("z", time()) + (365 * (date("Y", time()) - date("Y", $this->data['lastday']))) - date("z", $this->data['lastday'])); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|    public function getLastLogin() |    public function getLastLogin() | ||||||
| @@ -358,11 +364,12 @@ class OTS_Account extends OTS_Row_DAO implements IteratorAggregate, Countable | |||||||
|     { |     { | ||||||
| 		global $config; | 		global $config; | ||||||
|         if(isset($config['lua']['freePremium']) && getBoolean($config['lua']['freePremium'])) return true; |         if(isset($config['lua']['freePremium']) && getBoolean($config['lua']['freePremium'])) return true; | ||||||
| 		if(fieldExist('premdays', 'accounts')) |  | ||||||
| 			return $this->data['premdays'] > 0; |  | ||||||
|  |  | ||||||
| 		return $this->data['lastday'] > time(); | 		if(isset($this->data['premend'])) { | ||||||
|         //return ($this->data['premdays'] - (date("z", time()) + (365 * (date("Y", time()) - date("Y", $this->data['lastday']))) - date("z", $this->data['lastday'])) > 0); | 			return $this->data['premend'] > time(); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		return ($this->data['premdays'] - (date("z", time()) + (365 * (date("Y", time()) - date("Y", $this->data['lastday']))) - date("z", $this->data['lastday'])) > 0); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|     public function getCreated() |     public function getCreated() | ||||||
| @@ -748,7 +755,7 @@ class OTS_Account extends OTS_Row_DAO implements IteratorAggregate, Countable | |||||||
|         } |         } | ||||||
| 		if( !isset($this->data['banned']) ) | 		if( !isset($this->data['banned']) ) | ||||||
| 			$this->loadBan(); | 			$this->loadBan(); | ||||||
|         return ($this->data['banned'] == 1); |         return ($this->data['banned'] === true); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public function getBanTime() |     public function getBanTime() | ||||||
| @@ -774,20 +781,24 @@ class OTS_Account extends OTS_Row_DAO implements IteratorAggregate, Countable | |||||||
| 		if(tableExist('account_bans')) { | 		if(tableExist('account_bans')) { | ||||||
| 			$ban = $this->db->query('SELECT `expires_at` FROM `account_bans` WHERE `account_id` = ' . $this->data['id'] . ' AND (`expires_at` > ' . time() .' OR `expires_at` = -1) ORDER BY `expires_at` DESC')->fetch(); | 			$ban = $this->db->query('SELECT `expires_at` FROM `account_bans` WHERE `account_id` = ' . $this->data['id'] . ' AND (`expires_at` > ' . time() .' OR `expires_at` = -1) ORDER BY `expires_at` DESC')->fetch(); | ||||||
| 			$this->data['banned'] = isset($ban['expires_at']); | 			$this->data['banned'] = isset($ban['expires_at']); | ||||||
| 			$this->data['banned_time'] = $ban['expires_at']; | 			$this->data['banned_time'] = isset($ban['expires_at']) ? $ban['expires_at'] : 0; | ||||||
| 		} | 		} | ||||||
| 		else if(tableExist('bans')) { | 		else if(tableExist('bans')) { | ||||||
| 			if(fieldExist('active', 'bans')) { | 			if(fieldExist('active', 'bans')) { | ||||||
| 				$ban = $this->db->query('SELECT `active`, `expires` FROM `bans` WHERE (`type` = 3 OR `type` = 5) AND `active` = 1 AND `value` = ' . $this->data['id'] . ' AND (`expires` > ' . time() .' OR `expires` = -1) ORDER BY `expires` DESC')->fetch(); | 				$ban = $this->db->query('SELECT `active`, `expires` FROM `bans` WHERE (`type` = 3 OR `type` = 5) AND `active` = 1 AND `value` = ' . $this->data['id'] . ' AND (`expires` > ' . time() .' OR `expires` = -1) ORDER BY `expires` DESC')->fetch(); | ||||||
| 				$this->data['banned'] = $ban['active']; | 				$this->data['banned'] = isset($ban['active']); | ||||||
| 				$this->data['banned_time'] = $ban['expires']; | 				$this->data['banned_time'] = isset($ban['expires']) ? $ban['expires'] : 0; | ||||||
| 			} | 			} | ||||||
| 			else { // tfs 0.2 | 			else { // tfs 0.2 | ||||||
| 				$ban = $this->db->query('SELECT `time` FROM `bans` WHERE (`type` = 3 OR `type` = 5) AND `account` = ' . $this->data['id'] . ' AND (`time` > ' . time() .' OR `time` = -1) ORDER BY `time` DESC')->fetch(); | 				$ban = $this->db->query('SELECT `time` FROM `bans` WHERE (`type` = 3 OR `type` = 5) AND `account` = ' . $this->data['id'] . ' AND (`time` > ' . time() .' OR `time` = -1) ORDER BY `time` DESC')->fetch(); | ||||||
| 				$this->data['banned'] = $ban['time'] == -1 || $ban['time'] > 0; | 				$this->data['banned'] = isset($ban['time']) && ($ban['time'] == -1 || $ban['time'] > 0); | ||||||
| 				$this->data['banned_time'] = $ban['time']; | 				$this->data['banned_time'] = isset($ban['time']) ? $ban['time'] : 0; | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|  | 		else { | ||||||
|  | 			$this->data['banned'] = false; | ||||||
|  | 			$this->data['banned_time'] = 0; | ||||||
|  | 		} | ||||||
|     } |     } | ||||||
|  |  | ||||||
| /** | /** | ||||||
|   | |||||||
| @@ -216,11 +216,6 @@ class OTS_Player extends OTS_Row_DAO | |||||||
| 		if(!isset($this->data['rank_id']) || $this->data['rank_id'] == NULL) | 		if(!isset($this->data['rank_id']) || $this->data['rank_id'] == NULL) | ||||||
| 			$this->data['rank_id'] = 0; | 			$this->data['rank_id'] = 0; | ||||||
|  |  | ||||||
| 		if(isset($this->data['promotion'])) { |  | ||||||
| 			global $config; |  | ||||||
| 			if((int)$this->data['promotion'] > 0) |  | ||||||
| 				$this->data['vocation'] += ($this->data['promotion'] * $config['vocations_amount']); |  | ||||||
| 		} |  | ||||||
|         // loads skills |         // loads skills | ||||||
|         if( $this->isLoaded() ) |         if( $this->isLoaded() ) | ||||||
|         { |         { | ||||||
| @@ -820,6 +815,12 @@ class OTS_Player extends OTS_Row_DAO | |||||||
|             throw new E_OTS_NotLoaded(); |             throw new E_OTS_NotLoaded(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  | 		if(isset($this->data['promotion'])) { | ||||||
|  | 			global $config; | ||||||
|  | 			if((int)$this->data['promotion'] > 0) | ||||||
|  | 				return ($this->data['vocation'] + ($this->data['promotion'] * $config['vocations_amount'])); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|         return $this->data['vocation']; |         return $this->data['vocation']; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -2895,7 +2896,12 @@ class OTS_Player extends OTS_Row_DAO | |||||||
|         } |         } | ||||||
|  |  | ||||||
| 		global $config; | 		global $config; | ||||||
| 		return $config['vocations'][$this->data['vocation']]; | 		$voc = $this->getVocation(); | ||||||
|  | 		if(!isset($config['vocations'][$voc])) { | ||||||
|  | 			return 'Unknown'; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		return $config['vocations'][$voc]; | ||||||
|         //return POT::getInstance()->getVocationsList()->getVocationName($this->data['vocation']); |         //return POT::getInstance()->getVocationsList()->getVocationName($this->data['vocation']); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -40,11 +40,13 @@ class Usage_Statistics { | |||||||
| 		$ret['myaac_version'] = MYAAC_VERSION; | 		$ret['myaac_version'] = MYAAC_VERSION; | ||||||
| 		$ret['myaac_db_version'] = DATABASE_VERSION; | 		$ret['myaac_db_version'] = DATABASE_VERSION; | ||||||
|  |  | ||||||
|  | 		if(tableExist('server_config')) { | ||||||
| 			$query = $db->query('SELECT `value` FROM `server_config` WHERE `config` = ' . $db->quote('database_version')); | 			$query = $db->query('SELECT `value` FROM `server_config` WHERE `config` = ' . $db->quote('database_version')); | ||||||
| 			if($query->rowCount() == 1) { | 			if($query->rowCount() == 1) { | ||||||
| 				$query = $query->fetch(); | 				$query = $query->fetch(); | ||||||
| 				$ret['otserv_db_version'] = $query['value']; | 				$ret['otserv_db_version'] = $query['value']; | ||||||
| 			} | 			} | ||||||
|  | 		} | ||||||
| 		 | 		 | ||||||
| 		$ret['client_version'] = $config['client']; | 		$ret['client_version'] = $config['client']; | ||||||
| 		 | 		 | ||||||
| @@ -58,7 +60,7 @@ class Usage_Statistics { | |||||||
| 		 | 		 | ||||||
| 		$query = $db->query('SELECT SUM(ROUND(((DATA_LENGTH + INDEX_LENGTH) / 1024 ), 0)) AS "size" | 		$query = $db->query('SELECT SUM(ROUND(((DATA_LENGTH + INDEX_LENGTH) / 1024 ), 0)) AS "size" | ||||||
| FROM INFORMATION_SCHEMA.TABLES | FROM INFORMATION_SCHEMA.TABLES | ||||||
| WHERE TABLE_SCHEMA = "forgottenserver";'); | WHERE TABLE_SCHEMA = "' . $config['database_name'] . '";'); | ||||||
|  |  | ||||||
| 		if($query->rowCount() == 1) { | 		if($query->rowCount() == 1) { | ||||||
| 			$query = $query->fetch(); | 			$query = $query->fetch(); | ||||||
|   | |||||||
| @@ -376,6 +376,33 @@ class Validator | |||||||
| 		return true; | 		return true; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Validate guild nick | ||||||
|  | 	 * Nick lenght must be 3-40 chars | ||||||
|  | 	 * | ||||||
|  | 	 * @param  string $name Name to check | ||||||
|  | 	 * @return bool Is name valid? | ||||||
|  | 	 */ | ||||||
|  | 	public static function guildNick($name) | ||||||
|  | 	{ | ||||||
|  | 		if(empty($name)) { | ||||||
|  | 			self::$lastError = 'Please enter guild nick.'; | ||||||
|  | 			return false; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		if(strspn($name, "qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM0123456789- ") != strlen($name)) { | ||||||
|  | 			self::$lastError = 'Invalid guild nick format.'; | ||||||
|  | 			return false; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		if(!preg_match("/[A-z ]{3,40}/", $name)) { | ||||||
|  | 			self::$lastError = 'Invalid guild nick format.'; | ||||||
|  | 			return false; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		return true; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	/** | 	/** | ||||||
| 	 * Validate rank name | 	 * Validate rank name | ||||||
| 	 * Rank lenght must be 1-32 chars | 	 * Rank lenght must be 1-32 chars | ||||||
|   | |||||||
| @@ -18,7 +18,7 @@ $locale['loaded'] = 'Loaded'; | |||||||
| $locale['not_loaded'] = 'Not loaded'; | $locale['not_loaded'] = 'Not loaded'; | ||||||
|  |  | ||||||
| $locale['please_fill_all'] = 'Please fill all inputs!'; | $locale['please_fill_all'] = 'Please fill all inputs!'; | ||||||
| $locale['already_installed'] = 'MyAAC has been already installed. Please delete <b>install/<b/> directory.'; | $locale['already_installed'] = 'MyAAC has been already installed. Please delete <b>install/<b/> directory. If you want to reinstall MyAAC - please delete <strong>config.local.php</strong> file from the main directory and refresh the page.'; | ||||||
|  |  | ||||||
| // welcome | // welcome | ||||||
| $locale['step_welcome'] = 'Welcome'; | $locale['step_welcome'] = 'Welcome'; | ||||||
|   | |||||||
| @@ -18,7 +18,7 @@ $locale['loaded'] = 'Załadowane'; | |||||||
| $locale['not_loaded'] = 'Nie załadowane'; | $locale['not_loaded'] = 'Nie załadowane'; | ||||||
|  |  | ||||||
| $locale['please_fill_all'] = 'Proszę wypełnić wszystkie pola!'; | $locale['please_fill_all'] = 'Proszę wypełnić wszystkie pola!'; | ||||||
| $locale['already_installed'] = 'MyAAC został już zainstalowany. Proszę usunąć katalog <b>install/</b>.'; | $locale['already_installed'] = 'MyAAC został już zainstalowany. Proszę usunąć katalog <b>install/</b>. Jeśli chcesz zainstalować MyAAC od nowa - proszę usuń plik <strong>config.local.php</strong> z katalogu głównego i odśwież stronę.'; | ||||||
|  |  | ||||||
| // welcome | // welcome | ||||||
| $locale['step_welcome'] = 'Witamy'; | $locale['step_welcome'] = 'Witamy'; | ||||||
|   | |||||||
| @@ -18,7 +18,7 @@ $locale['loaded'] = 'Laddad'; | |||||||
| $locale['not_loaded'] = 'Inte Laddad'; | $locale['not_loaded'] = 'Inte Laddad'; | ||||||
|  |  | ||||||
| $locale['please_fill_all'] = 'Vänligen fyll i allt!'; | $locale['please_fill_all'] = 'Vänligen fyll i allt!'; | ||||||
| $locale['already_installed'] = 'MyAAC är redan installerat. Vänligen ta bort <b>install/<b/> mappen.'; | $locale['already_installed'] = 'MyAAC är redan installerat. Vänligen ta bort <b>install/<b/> mappen. Om du vill installera MyAAC igen - ta bort filen <strong>config.local.php</strong> från huvudkatalogen och uppdatera sidan.'; | ||||||
|  |  | ||||||
| // welcome | // welcome | ||||||
| $locale['step_welcome'] = 'Välkommen'; | $locale['step_welcome'] = 'Välkommen'; | ||||||
|   | |||||||
| @@ -1,16 +1,23 @@ | |||||||
| <?php | <?php | ||||||
|  |  | ||||||
|  | if(!isset($database_migration_20)) { | ||||||
|  | 	databaseMigration20(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function databaseMigration20(&$content = '') { | ||||||
|  | 	global $db; | ||||||
|  |  | ||||||
| 	$config_file = BASE . 'config.local.php'; | 	$config_file = BASE . 'config.local.php'; | ||||||
| 	if(!is_writable($config_file)) { // we can't do anything, just ignore | 	if(!is_writable($config_file)) { // we can't do anything, just ignore | ||||||
| 	return; | 		return false; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	$content_of_file = trim(file_get_contents($config_file)); | 	$content_of_file = trim(file_get_contents($config_file)); | ||||||
| 	if(strpos($content_of_file, 'highscores_ids_hidden') !== false) { // already present | 	if(strpos($content_of_file, 'highscores_ids_hidden') !== false) { // already present | ||||||
| 	return; | 		return true; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| $query = $db->query("SELECT `id` FROM `players` WHERE (`name` = " . $db->quote("Rook Sample") . " OR `name` = " . $db->quote("Sorcerer Sample") . " OR `name` = " . $db->quote("Druid Sample") . " OR `name` = " . $db->quote("Paladin Sample") . " OR `name` = " . $db->quote("Knight Sample") . ") ORDER BY `id`;"); | 	$query = $db->query("SELECT `id` FROM `players` WHERE (`name` = " . $db->quote("Rook Sample") . " OR `name` = " . $db->quote("Sorcerer Sample") . " OR `name` = " . $db->quote("Druid Sample") . " OR `name` = " . $db->quote("Paladin Sample") . " OR `name` = " . $db->quote("Knight Sample") . " OR `name` = " . $db->quote("Account Manager") . ") ORDER BY `id`;"); | ||||||
|  |  | ||||||
| 	$highscores_ignored_ids = array(); | 	$highscores_ignored_ids = array(); | ||||||
| 	if($query->rowCount() > 0) { | 	if($query->rowCount() > 0) { | ||||||
| @@ -36,4 +43,6 @@ if($php_on_end) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	file_put_contents($config_file, $content, FILE_APPEND); | 	file_put_contents($config_file, $content, FILE_APPEND); | ||||||
|  | 	return true; | ||||||
|  | } | ||||||
| ?> | ?> | ||||||
							
								
								
									
										14
									
								
								system/migrations/21.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,14 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | $db->query("ALTER TABLE `" . TABLE_PREFIX . "forum` ADD `post_html` TINYINT(1) NOT NULL DEFAULT 0 AFTER `post_smile`;"); | ||||||
|  |  | ||||||
|  | $query = $db->query("SELECT `id` FROM `" . TABLE_PREFIX . "forum_boards` WHERE `name` LIKE " . $db->quote('News') . " LIMIT 1;"); | ||||||
|  | if($query->rowCount() == 0) { | ||||||
|  | 	return; // don't make anything | ||||||
|  | } | ||||||
|  |  | ||||||
|  | $query = $query->fetch(); | ||||||
|  | $id = $query['id']; | ||||||
|  |  | ||||||
|  | // update all forum threads with is_html = 1 | ||||||
|  | $db->query("UPDATE `" . TABLE_PREFIX . "forum` SET `post_html` = 1 WHERE `section` = " . $id . " AND `id` = `first_post`;"); | ||||||
							
								
								
									
										29
									
								
								system/migrations/22.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,29 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | if(!tableExist('z_polls')) | ||||||
|  | 	$db->query(' | ||||||
|  | CREATE TABLE `z_polls` ( | ||||||
|  |   `id` int(11) NOT NULL auto_increment, | ||||||
|  |   `question` varchar(255) NOT NULL, | ||||||
|  |   `description` varchar(255) NOT NULL, | ||||||
|  |   `end` int(11) NOT NULL DEFAULT 0, | ||||||
|  |   `start` int(11) NOT NULL DEFAULT 0, | ||||||
|  |   `answers` int(11) NOT NULL DEFAULT 0, | ||||||
|  |   `votes_all` int(11) NOT NULL DEFAULT 0, | ||||||
|  |   PRIMARY KEY  (`id`) | ||||||
|  | ) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;'); | ||||||
|  |  | ||||||
|  | if(!tableExist('z_polls_answers')) | ||||||
|  | $db->query(' | ||||||
|  | 	CREATE TABLE `z_polls_answers` ( | ||||||
|  |   `poll_id` int(11) NOT NULL, | ||||||
|  |   `answer_id` int(11) NOT NULL, | ||||||
|  |   `answer` varchar(255) NOT NULL, | ||||||
|  |   `votes` int(11) NOT NULL DEFAULT 0 | ||||||
|  | ) ENGINE=MyISAM DEFAULT CHARSET=latin1;'); | ||||||
|  |  | ||||||
|  | if(!fieldExist('vote', 'accounts')) | ||||||
|  | 	$db->query('ALTER TABLE `accounts` ADD `vote` INT( 11 ) DEFAULT 0 NOT NULL ;'); | ||||||
|  | else { | ||||||
|  | 	$db->query('ALTER TABLE `accounts` MODIFY `vote` INT( 11 ) DEFAULT 0 NOT NULL ;'); | ||||||
|  | } | ||||||
| @@ -140,7 +140,11 @@ if($save) { | |||||||
| 		$player->setPosX(0); | 		$player->setPosX(0); | ||||||
| 		$player->setPosY(0); | 		$player->setPosY(0); | ||||||
| 		$player->setPosZ(0); | 		$player->setPosZ(0); | ||||||
| 		$player->setStamina($config['otserv_version'] == TFS_03 ? 151200000 : 2520); |  | ||||||
|  | 		if(fieldExist('stamina', 'players')) { | ||||||
|  | 			$player->setStamina($char_to_copy->getStamina()); | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		if(fieldExist('loss_experience', 'players')) { | 		if(fieldExist('loss_experience', 'players')) { | ||||||
| 			$player->setLossExperience($char_to_copy->getLossExperience()); | 			$player->setLossExperience($char_to_copy->getLossExperience()); | ||||||
| 			$player->setLossMana($char_to_copy->getLossMana()); | 			$player->setLossMana($char_to_copy->getLossMana()); | ||||||
|   | |||||||
| @@ -28,14 +28,11 @@ foreach(scandir($aac_path_logs) as $f) { | |||||||
| } | } | ||||||
|  |  | ||||||
| $server_path_logs = $config['server_path'] . 'logs/'; | $server_path_logs = $config['server_path'] . 'logs/'; | ||||||
| if(!file_exists($server_path_logs)) |  | ||||||
| $server_path_logs = $config['data_path'] . 'logs/'; |  | ||||||
|  |  | ||||||
| if(!file_exists($server_path_logs)) { | if(!file_exists($server_path_logs)) { | ||||||
| 	echo '</table>Logs are not available on this server.'; |     $server_path_logs = $config['data_path'] . 'logs/'; | ||||||
| 	return; |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | if(file_exists($server_path_logs)) { | ||||||
| 	foreach(scandir($server_path_logs) as $f) { | 	foreach(scandir($server_path_logs) as $f) { | ||||||
| 		if($f[0] == '.' || $f == '..') | 		if($f[0] == '.' || $f == '..') | ||||||
| 			continue; | 			continue; | ||||||
| @@ -52,6 +49,7 @@ foreach(scandir($server_path_logs) as $f) { | |||||||
|  |  | ||||||
| 		$files[] = array($f, $server_path_logs); | 		$files[] = array($f, $server_path_logs); | ||||||
| 	} | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
| $i = 0; | $i = 0; | ||||||
| foreach($files as $f) { | foreach($files as $f) { | ||||||
|   | |||||||
| @@ -16,6 +16,8 @@ if(!hasFlag(FLAG_CONTENT_PAGES) && !superAdmin()) | |||||||
| 	return; | 	return; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | header('X-XSS-Protection:0'); | ||||||
|  |  | ||||||
| $name = $p_title = ''; | $name = $p_title = ''; | ||||||
| $groups = new OTS_Groups_List(); | $groups = new OTS_Groups_List(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -120,7 +120,11 @@ if($id > 0) { | |||||||
| 		verify_number($experience, 'Experience', 20); | 		verify_number($experience, 'Experience', 20); | ||||||
|  |  | ||||||
| 		$vocation = $_POST['vocation']; | 		$vocation = $_POST['vocation']; | ||||||
| 		verify_number($vocation, 'Vocation id', 1); | 		verify_number($vocation, 'Vocation id', 11); | ||||||
|  |  | ||||||
|  | 		if(!isset($config['vocations'][$vocation])) { | ||||||
|  | 			echo_error("Vocation with this id doesn't exist."); | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		// health | 		// health | ||||||
| 		$health = $_POST['health']; | 		$health = $_POST['health']; | ||||||
| @@ -357,14 +361,12 @@ $account = $player->getAccount(); | |||||||
| 		<td> | 		<td> | ||||||
| 			<select name="vocation"> | 			<select name="vocation"> | ||||||
| <?php | <?php | ||||||
| 			$i = 0; | 			foreach($config['vocations'] as $id => $name) | ||||||
| 			foreach($config['vocations'] as $voc) |  | ||||||
| 			{ | 			{ | ||||||
| 				echo '<option value=' . $i; | 				echo '<option value=' . $id; | ||||||
| 				if($i == $player->getVocation()) | 				if($id == $player->getVocation()) | ||||||
| 					echo ' selected="selected"'; | 					echo ' selected="selected"'; | ||||||
| 				echo '>' . $voc . '</option>'; | 				echo '>' . $name . '</option>'; | ||||||
| 				$i++; |  | ||||||
| 			} | 			} | ||||||
| 					 | 					 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -22,7 +22,7 @@ if(isset($_REQUEST['uninstall'])){ | |||||||
| 		success('Successfully uninstalled plugin ' . $uninstall); | 		success('Successfully uninstalled plugin ' . $uninstall); | ||||||
| 	} | 	} | ||||||
| 	else { | 	else { | ||||||
| 		error('Error while uninstalling plugin ' . $plugin_name . ': ' . Plugins::getError()); | 		error('Error while uninstalling plugin ' . $uninstall . ': ' . Plugins::getError()); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| else if(isset($_FILES["plugin"]["name"])) | else if(isset($_FILES["plugin"]["name"])) | ||||||
|   | |||||||
| @@ -231,7 +231,7 @@ if($player->isLoaded() && !$player->isDeleted()) | |||||||
| 	$dead_add_content = ''; | 	$dead_add_content = ''; | ||||||
| 	$deaths = array(); | 	$deaths = array(); | ||||||
| 	if(tableExist('killers')) { | 	if(tableExist('killers')) { | ||||||
| 		$player_deaths = $db->query('SELECT `id`, `date`, `level` FROM `player_deaths` WHERE `player_id` = '.$player->getId().' ORDER BY `date` DESC LIMIT 0,10;'); | 		$player_deaths = $db->query('SELECT `id`, `date`, `level` FROM `player_deaths` WHERE `player_id` = '.$player->getId().' ORDER BY `date` DESC LIMIT 0,10;')->fetchAll(); | ||||||
| 		if(count($player_deaths)) | 		if(count($player_deaths)) | ||||||
| 		{ | 		{ | ||||||
| 			$number_of_rows = 0; | 			$number_of_rows = 0; | ||||||
| @@ -289,7 +289,7 @@ WHERE killers.death_id = '".$death['id']."' ORDER BY killers.final_hit DESC, kil | |||||||
| 		$deaths_db = $db->query('SELECT | 		$deaths_db = $db->query('SELECT | ||||||
| 				`player_id`, `time`, `level`, `killed_by`, `is_player`' . $mostdamage . ' | 				`player_id`, `time`, `level`, `killed_by`, `is_player`' . $mostdamage . ' | ||||||
| 				FROM `player_deaths` | 				FROM `player_deaths` | ||||||
| 				WHERE `player_id` = ' . $player->getId() . ' ORDER BY `time` DESC LIMIT 10;'); | 				WHERE `player_id` = ' . $player->getId() . ' ORDER BY `time` DESC LIMIT 10;')->fetchAll(); | ||||||
| 		 | 		 | ||||||
| 		if(count($deaths_db)) | 		if(count($deaths_db)) | ||||||
| 		{ | 		{ | ||||||
| @@ -328,13 +328,13 @@ WHERE killers.death_id = '".$death['id']."' ORDER BY killers.final_hit DESC, kil | |||||||
| 		//frags list by Xampy | 		//frags list by Xampy | ||||||
| 		$i = 0; | 		$i = 0; | ||||||
| 		$frags_limit = 10; // frags limit to show? // default: 10 | 		$frags_limit = 10; // frags limit to show? // default: 10 | ||||||
| 		$player_frags = $db->query('SELECT `player_deaths`.*, `players`.`name`, `killers`.`unjustified` FROM `player_deaths` LEFT JOIN `killers` ON `killers`.`death_id` = `player_deaths`.`id` LEFT JOIN `player_killers` ON `player_killers`.`kill_id` = `killers`.`id` LEFT JOIN `players` ON `players`.`id` = `player_deaths`.`player_id` WHERE `player_killers`.`player_id` = '.$player->getId().' ORDER BY `date` DESC LIMIT 0,'.$frags_limit.';'); | 		$player_frags = $db->query('SELECT `player_deaths`.*, `players`.`name`, `killers`.`unjustified` FROM `player_deaths` LEFT JOIN `killers` ON `killers`.`death_id` = `player_deaths`.`id` LEFT JOIN `player_killers` ON `player_killers`.`kill_id` = `killers`.`id` LEFT JOIN `players` ON `players`.`id` = `player_deaths`.`player_id` WHERE `player_killers`.`player_id` = '.$player->getId().' ORDER BY `date` DESC LIMIT 0,'.$frags_limit.';')->fetchAll(); | ||||||
| 		if(count($player_frags)) | 		if(count($player_frags)) | ||||||
| 		{ | 		{ | ||||||
| 			$row_count = 0; | 			$row_count = 0; | ||||||
| 			foreach($player_frags as $frag) | 			foreach($player_frags as $frag) | ||||||
| 			{ | 			{ | ||||||
| 				$description = 'Fragged <a href="' . getPlayerLink($frag[name], false) . '">' . $frag[name] . '</a> at level ' . $frag[level]; | 				$description = 'Fragged <a href="' . getPlayerLink($frag['name'], false) . '">' . $frag['name'] . '</a> at level ' . $frag['level']; | ||||||
| 				$frags[] = array('time' => $frag['date'], 'description' => $description, 'unjustified' => $frag['unjustified'] != 0); | 				$frags[] = array('time' => $frag['date'], 'description' => $description, 'unjustified' => $frag['unjustified'] != 0); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| @@ -375,7 +375,7 @@ WHERE killers.death_id = '".$death['id']."' ORDER BY killers.final_hit DESC, kil | |||||||
| 		'sex' => $player_sex, | 		'sex' => $player_sex, | ||||||
| 		'marriage_enabled' => $config['characters']['marriage_info'] && fieldExist('marriage', 'players'), | 		'marriage_enabled' => $config['characters']['marriage_info'] && fieldExist('marriage', 'players'), | ||||||
| 		'marital_status' => $marital_status, | 		'marital_status' => $marital_status, | ||||||
| 		'vocation' => $config['vocations'][$player->getVocation()], | 		'vocation' => $player->getVocationName(), | ||||||
| 		'frags_enabled' => $frags_enabled, | 		'frags_enabled' => $frags_enabled, | ||||||
| 		'frags_count' => $frags_count, | 		'frags_count' => $frags_count, | ||||||
| 		'town' => isset($config['towns'][$player->getTownId()]) ? $config['towns'][$player->getTownId()] : null, | 		'town' => isset($config['towns'][$player->getTownId()]) ? $config['towns'][$player->getTownId()] : null, | ||||||
|   | |||||||
| @@ -144,9 +144,14 @@ if($save) | |||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		if($config['account_premium_days'] && $config['account_premium_days'] > 0) { | 		if($config['account_premium_days'] && $config['account_premium_days'] > 0) { | ||||||
|  | 			if(fieldExist('premend', 'accounts')) { // othire | ||||||
|  | 				$new_account->setCustomField('premend', time() + $config['account_premium_days'] * 86400); | ||||||
|  | 			} | ||||||
|  | 			else { // rest | ||||||
| 				$new_account->setCustomField('premdays', $config['account_premium_days']); | 				$new_account->setCustomField('premdays', $config['account_premium_days']); | ||||||
| 				$new_account->setCustomField('lastday', time()); | 				$new_account->setCustomField('lastday', time()); | ||||||
| 			} | 			} | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		if($config['account_premium_points']) { | 		if($config['account_premium_points']) { | ||||||
| 			$new_account->setCustomField('premium_points', $config['account_premium_points']); | 			$new_account->setCustomField('premium_points', $config['account_premium_points']); | ||||||
| @@ -198,11 +203,12 @@ if($save) | |||||||
|  |  | ||||||
| 				if(_mail($email, 'Your account on ' . $config['lua']['serverName'], $mailBody)) | 				if(_mail($email, 'Your account on ' . $config['lua']['serverName'], $mailBody)) | ||||||
| 					echo '<br /><small>These informations were send on email address <b>' . $email . '</b>.'; | 					echo '<br /><small>These informations were send on email address <b>' . $email . '</b>.'; | ||||||
| 				else | 				else { | ||||||
| 					error('An error occorred while sending email (<b>' . $email . '</b>)! Error:<br/>' . $mailer->ErrorInfo . '<br/>More info in system/logs/error.log'); | 					error('An error occorred while sending email (<b>' . $email . '</b>)! Error:<br/>' . $mailer->ErrorInfo . '<br/>More info in system/logs/error.log'); | ||||||
| 					log_append('error.log', '[createaccount.php] An error occorred while sending email: ' . $mailer->ErrorInfo . '. Error: ' . print_r(error_get_last(), true)); | 					log_append('error.log', '[createaccount.php] An error occorred while sending email: ' . $mailer->ErrorInfo . '. Error: ' . print_r(error_get_last(), true)); | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| @@ -210,9 +216,16 @@ if($save) | |||||||
|  |  | ||||||
| $country_recognized = null; | $country_recognized = null; | ||||||
| if($config['account_country_recognize']) { | if($config['account_country_recognize']) { | ||||||
|  | 	$country_session = getSession('country'); | ||||||
|  | 	if($country_session !== false) { // get from session | ||||||
|  | 		$country_recognized = $country_session; | ||||||
|  | 	} | ||||||
|  | 	else { | ||||||
| 		$info = json_decode(@file_get_contents('http://ipinfo.io/' . $_SERVER['REMOTE_ADDR'] . '/geo'), true); | 		$info = json_decode(@file_get_contents('http://ipinfo.io/' . $_SERVER['REMOTE_ADDR'] . '/geo'), true); | ||||||
| 		if(isset($info['country'])) { | 		if(isset($info['country'])) { | ||||||
| 			$country_recognized = strtolower($info['country']); | 			$country_recognized = strtolower($info['country']); | ||||||
|  | 			setSession('country', $country_recognized); | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -170,7 +170,7 @@ if(isset($monster['name'])) | |||||||
| 	echo '</TABLE></td><td align=left> | 	echo '</TABLE></td><td align=left> | ||||||
| 	<TABLE BORDER=0 CELLSPACING=1 CELLPADDING=4 WIDTH=40%> | 	<TABLE BORDER=0 CELLSPACING=1 CELLPADDING=4 WIDTH=40%> | ||||||
| 	<tr><td align=left>'; | 	<tr><td align=left>'; | ||||||
| 	$monster['gfx_name'] = trim(mb_strtolower($monster['name'])).".gif"; | 	$monster['gfx_name'] = trim(strtolower($monster['name'])).".gif"; | ||||||
| 	if(!file_exists('images/monsters/'.$monster['gfx_name'])) { | 	if(!file_exists('images/monsters/'.$monster['gfx_name'])) { | ||||||
| 		$gfx_name =  str_replace(" ", "", $monster['gfx_name']); | 		$gfx_name =  str_replace(" ", "", $monster['gfx_name']); | ||||||
| 		if(file_exists('images/monsters/' . $gfx_name)) | 		if(file_exists('images/monsters/' . $gfx_name)) | ||||||
|   | |||||||
| @@ -28,7 +28,7 @@ if(!$logged) | |||||||
|  |  | ||||||
| require_once(LIBS . 'forum.php'); | require_once(LIBS . 'forum.php'); | ||||||
|  |  | ||||||
| $canEdit = hasFlag(FLAG_CONTENT_FORUM) || superAdmin(); | $canEdit = Forum::isModerator(); | ||||||
| if($canEdit) | if($canEdit) | ||||||
| { | { | ||||||
| 	$groups = new OTS_Groups_List(); | 	$groups = new OTS_Groups_List(); | ||||||
| @@ -172,7 +172,7 @@ if(empty($action)) | |||||||
| 	return; | 	return; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | $errors = array(); | ||||||
| if($action == 'show_board' || $action == 'show_thread') | if($action == 'show_board' || $action == 'show_thread') | ||||||
| { | { | ||||||
| 	require(PAGES . 'forum/' . $action . '.php'); | 	require(PAGES . 'forum/' . $action . '.php'); | ||||||
|   | |||||||
| @@ -18,14 +18,14 @@ if(Forum::canPost($account_logged)) | |||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	$thread = $db->query("SELECT `author_guid`, `author_aid`, `first_post`, `post_topic`, `post_date`, `post_text`, `post_smile`, `id`, `section` FROM `" . TABLE_PREFIX . "forum` WHERE `id` = ".$post_id." LIMIT 1")->fetch(); | 	$thread = $db->query("SELECT `author_guid`, `author_aid`, `first_post`, `post_topic`, `post_date`, `post_text`, `post_smile`, `post_html`, `id`, `section` FROM `" . TABLE_PREFIX . "forum` WHERE `id` = ".$post_id." LIMIT 1")->fetch(); | ||||||
| 	if(isset($thread['id'])) | 	if(isset($thread['id'])) | ||||||
| 	{ | 	{ | ||||||
| 		$first_post = $db->query("SELECT `" . TABLE_PREFIX . "forum`.`author_guid`, `" . TABLE_PREFIX . "forum`.`author_aid`, `" . TABLE_PREFIX . "forum`.`first_post`, `" . TABLE_PREFIX . "forum`.`post_topic`, `" . TABLE_PREFIX . "forum`.`post_text`, `" . TABLE_PREFIX . "forum`.`post_smile`, `" . TABLE_PREFIX . "forum`.`id`, `" . TABLE_PREFIX . "forum`.`section` FROM `" . TABLE_PREFIX . "forum` WHERE `" . TABLE_PREFIX . "forum`.`id` = ".(int) $thread['first_post']." LIMIT 1")->fetch(); | 		$first_post = $db->query("SELECT `" . TABLE_PREFIX . "forum`.`author_guid`, `" . TABLE_PREFIX . "forum`.`author_aid`, `" . TABLE_PREFIX . "forum`.`first_post`, `" . TABLE_PREFIX . "forum`.`post_topic`, `" . TABLE_PREFIX . "forum`.`post_text`, `" . TABLE_PREFIX . "forum`.`post_smile`, `" . TABLE_PREFIX . "forum`.`id`, `" . TABLE_PREFIX . "forum`.`section` FROM `" . TABLE_PREFIX . "forum` WHERE `" . TABLE_PREFIX . "forum`.`id` = ".(int) $thread['first_post']." LIMIT 1")->fetch(); | ||||||
| 		echo '<a href="' . getLink('forum') . '">Boards</a> >> <a href="' . getForumBoardLink($thread['section']) . '">'.$sections[$thread['section']]['name'].'</a> >> <a href="' . getForumThreadLink($thread['first_post']) . '">'.$first_post['post_topic'].'</a> >> <b>Edit post</b>'; | 		echo '<a href="' . getLink('forum') . '">Boards</a> >> <a href="' . getForumBoardLink($thread['section']) . '">'.$sections[$thread['section']]['name'].'</a> >> <a href="' . getForumThreadLink($thread['first_post']) . '">'.$first_post['post_topic'].'</a> >> <b>Edit post</b>'; | ||||||
| 		if(Forum::hasAccess($thread['section'] && ($account_logged->getId() == $thread['author_aid'] || Forum::isModerator()))) | 		if(Forum::hasAccess($thread['section'] && ($account_logged->getId() == $thread['author_aid'] || Forum::isModerator()))) | ||||||
| 		{ | 		{ | ||||||
| 			$char_id = $post_topic = $text = $smile = null; | 			$char_id = $post_topic = $text = $smile = $html = null; | ||||||
| 			$players_from_account = $db->query("SELECT `players`.`name`, `players`.`id` FROM `players` WHERE `players`.`account_id` = ".(int) $account_logged->getId())->fetchAll(); | 			$players_from_account = $db->query("SELECT `players`.`name`, `players`.`id` FROM `players` WHERE `players`.`account_id` = ".(int) $account_logged->getId())->fetchAll(); | ||||||
| 			$saved = false; | 			$saved = false; | ||||||
| 			if(isset($_REQUEST['save'])) | 			if(isset($_REQUEST['save'])) | ||||||
| @@ -33,9 +33,10 @@ if(Forum::canPost($account_logged)) | |||||||
| 				$text = stripslashes(trim($_REQUEST['text'])); | 				$text = stripslashes(trim($_REQUEST['text'])); | ||||||
| 				$char_id = (int) $_REQUEST['char_id']; | 				$char_id = (int) $_REQUEST['char_id']; | ||||||
| 				$post_topic = stripslashes(trim($_REQUEST['topic'])); | 				$post_topic = stripslashes(trim($_REQUEST['topic'])); | ||||||
| 				$smile = (int) $_REQUEST['smile']; | 				$smile = isset($_REQUEST['smile']) ? (int)$_REQUEST['smile'] : 0; | ||||||
|  | 				$html = isset($_REQUEST['html']) ? (int)$_REQUEST['html'] : 0; | ||||||
| 				$lenght = 0; | 				$lenght = 0; | ||||||
| 				for($i = 0; $i <= strlen($post_topic); $i++) | 				for($i = 0; $i < strlen($post_topic); $i++) | ||||||
| 				{ | 				{ | ||||||
| 					if(ord($post_topic[$i]) >= 33 && ord($post_topic[$i]) <= 126) | 					if(ord($post_topic[$i]) >= 33 && ord($post_topic[$i]) <= 126) | ||||||
| 						$lenght++; | 						$lenght++; | ||||||
| @@ -43,12 +44,11 @@ if(Forum::canPost($account_logged)) | |||||||
| 				if(($lenght < 1 || strlen($post_topic) > 60) && $thread['id'] == $thread['first_post']) | 				if(($lenght < 1 || strlen($post_topic) > 60) && $thread['id'] == $thread['first_post']) | ||||||
| 					$errors[] = 'Too short or too long topic (short: '.$lenght.' long: '.strlen($post_topic).' letters). Minimum 1 letter, maximum 60 letters.'; | 					$errors[] = 'Too short or too long topic (short: '.$lenght.' long: '.strlen($post_topic).' letters). Minimum 1 letter, maximum 60 letters.'; | ||||||
| 				$lenght = 0; | 				$lenght = 0; | ||||||
| 				for($i = 0; $i <= strlen($text); $i++) | 				for($i = 0; $i < strlen($text); $i++) | ||||||
| 				{ | 				{ | ||||||
| 					if(ord($text[$i]) >= 33 && ord($text[$i]) <= 126) | 					if(ord($text[$i]) >= 33 && ord($text[$i]) <= 126) | ||||||
| 						$lenght++; | 						$lenght++; | ||||||
| 				} | 				} | ||||||
| 				 |  | ||||||
| 				if($lenght < 1 || strlen($text) > 15000) | 				if($lenght < 1 || strlen($text) > 15000) | ||||||
| 					$errors[] = 'Too short or too long post (short: '.$lenght.' long: '.strlen($text).' letters). Minimum 1 letter, maximum 15000 letters.'; | 					$errors[] = 'Too short or too long post (short: '.$lenght.' long: '.strlen($text).' letters). Minimum 1 letter, maximum 15000 letters.'; | ||||||
| 				if($char_id == 0) | 				if($char_id == 0) | ||||||
| @@ -56,7 +56,7 @@ if(Forum::canPost($account_logged)) | |||||||
| 				if(empty($post_topic) && $thread['id'] == $thread['first_post']) | 				if(empty($post_topic) && $thread['id'] == $thread['first_post']) | ||||||
| 					$errors[] = 'Thread topic can\'t be empty.'; | 					$errors[] = 'Thread topic can\'t be empty.'; | ||||||
| 				 | 				 | ||||||
| 				$player_on_account == false; | 				$player_on_account = false; | ||||||
| 				 | 				 | ||||||
| 				if(count($errors) == 0) | 				if(count($errors) == 0) | ||||||
| 				{ | 				{ | ||||||
| @@ -71,7 +71,7 @@ if(Forum::canPost($account_logged)) | |||||||
| 					$saved = true; | 					$saved = true; | ||||||
| 					if($account_logged->getId() != $thread['author_aid']) | 					if($account_logged->getId() != $thread['author_aid']) | ||||||
| 						$char_id = $thread['author_guid']; | 						$char_id = $thread['author_guid']; | ||||||
| 					$db->query("UPDATE `" . TABLE_PREFIX . "forum` SET `author_guid` = ".(int) $char_id.", `post_text` = ".$db->quote($text).", `post_topic` = ".$db->quote($post_topic).", `post_smile` = ".(int) $smile.", `last_edit_aid` = ".(int) $account_logged->getId().",`edit_date` = ".time()." WHERE `id` = ".(int) $thread['id']); | 					$db->query("UPDATE `" . TABLE_PREFIX . "forum` SET `author_guid` = ".(int) $char_id.", `post_text` = ".$db->quote($text).", `post_topic` = ".$db->quote($post_topic).", `post_smile` = ".$smile.", `post_html` = ".$html.", `last_edit_aid` = ".(int) $account_logged->getId().",`edit_date` = ".time()." WHERE `id` = ".(int) $thread['id']); | ||||||
| 					$post_page = $db->query("SELECT COUNT(`" . TABLE_PREFIX . "forum`.`id`) AS posts_count FROM `players`, `" . TABLE_PREFIX . "forum` WHERE `players`.`id` = `" . TABLE_PREFIX . "forum`.`author_guid` AND `" . TABLE_PREFIX . "forum`.`post_date` <= ".$thread['post_date']." AND `" . TABLE_PREFIX . "forum`.`first_post` = ".(int) $thread['first_post'])->fetch(); | 					$post_page = $db->query("SELECT COUNT(`" . TABLE_PREFIX . "forum`.`id`) AS posts_count FROM `players`, `" . TABLE_PREFIX . "forum` WHERE `players`.`id` = `" . TABLE_PREFIX . "forum`.`author_guid` AND `" . TABLE_PREFIX . "forum`.`post_date` <= ".$thread['post_date']." AND `" . TABLE_PREFIX . "forum`.`first_post` = ".(int) $thread['first_post'])->fetch(); | ||||||
| 					$_page = (int) ceil($post_page['posts_count'] / $config['forum_threads_per_page']) - 1; | 					$_page = (int) ceil($post_page['posts_count'] / $config['forum_threads_per_page']) - 1; | ||||||
| 					header('Location: ' . getForumThreadLink($thread['first_post'], $_page)); | 					header('Location: ' . getForumThreadLink($thread['first_post'], $_page)); | ||||||
| @@ -83,6 +83,7 @@ if(Forum::canPost($account_logged)) | |||||||
| 				$char_id = (int) $thread['author_guid']; | 				$char_id = (int) $thread['author_guid']; | ||||||
| 				$post_topic = $thread['post_topic']; | 				$post_topic = $thread['post_topic']; | ||||||
| 				$smile = (int) $thread['post_smile']; | 				$smile = (int) $thread['post_smile']; | ||||||
|  | 				$html = (int) $thread['post_html']; | ||||||
| 			} | 			} | ||||||
| 			 | 			 | ||||||
| 			if(!$saved) | 			if(!$saved) | ||||||
| @@ -94,9 +95,12 @@ if(Forum::canPost($account_logged)) | |||||||
| 					'post_id' => $post_id, | 					'post_id' => $post_id, | ||||||
| 					'players' => $players_from_account, | 					'players' => $players_from_account, | ||||||
| 					'player_id' => $char_id, | 					'player_id' => $char_id, | ||||||
| 					'topic' => htmlspecialchars($post_topic), | 					'post_topic' => $canEdit ? $post_topic : htmlspecialchars($post_topic), | ||||||
| 					'text' => htmlspecialchars($text), | 					'post_text' => $canEdit ? $text : htmlspecialchars($text), | ||||||
| 					'smile' => $smile | 					'post_smile' => $smile > 0, | ||||||
|  | 					'post_html' => $html > 0, | ||||||
|  | 					'html' => $html, | ||||||
|  | 					'canEdit' => $canEdit | ||||||
| 				)); | 				)); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|   | |||||||
| @@ -27,7 +27,8 @@ if(Forum::canPost($account_logged)) | |||||||
| 		$text = isset($_REQUEST['text']) ? stripslashes(trim($_REQUEST['text'])) : NULL; | 		$text = isset($_REQUEST['text']) ? stripslashes(trim($_REQUEST['text'])) : NULL; | ||||||
| 		$char_id = (int) (isset($_REQUEST['char_id']) ? $_REQUEST['char_id'] : 0); | 		$char_id = (int) (isset($_REQUEST['char_id']) ? $_REQUEST['char_id'] : 0); | ||||||
| 		$post_topic = isset($_REQUEST['topic']) ? stripslashes(trim($_REQUEST['topic'])) : ''; | 		$post_topic = isset($_REQUEST['topic']) ? stripslashes(trim($_REQUEST['topic'])) : ''; | ||||||
| 		$smile = (int) (isset($_REQUEST['smile']) ? $_REQUEST['smile'] : 0); | 		$smile = (isset($_REQUEST['smile']) ? (int)$_REQUEST['smile'] : 0); | ||||||
|  | 		$html = (isset($_REQUEST['html']) ? (int)$_REQUEST['html'] : 0); | ||||||
| 		$saved = false; | 		$saved = false; | ||||||
| 		if(isset($_REQUEST['quote'])) | 		if(isset($_REQUEST['quote'])) | ||||||
| 		{ | 		{ | ||||||
| @@ -72,7 +73,7 @@ if(Forum::canPost($account_logged)) | |||||||
| 			if(count($errors) == 0) | 			if(count($errors) == 0) | ||||||
| 			{ | 			{ | ||||||
| 				$saved = true; | 				$saved = true; | ||||||
| 				Forum::add_post($thread['id'], $thread['section'], $account_logged->getId(), (int) $char_id, $text, $post_topic, (int) $smile, time(), $_SERVER['REMOTE_ADDR']); | 				Forum::add_post($thread['id'], $thread['section'], $account_logged->getId(), (int) $char_id, $text, $post_topic, $smile, $html, time(), $_SERVER['REMOTE_ADDR']); | ||||||
| 				$db->query("UPDATE `" . TABLE_PREFIX . "forum` SET `replies`=`replies`+1, `last_post`=".time()." WHERE `id` = ".(int) $thread_id); | 				$db->query("UPDATE `" . TABLE_PREFIX . "forum` SET `replies`=`replies`+1, `last_post`=".time()." WHERE `id` = ".(int) $thread_id); | ||||||
| 				$post_page = $db->query("SELECT COUNT(`" . TABLE_PREFIX . "forum`.`id`) AS posts_count FROM `players`, `" . TABLE_PREFIX . "forum` WHERE `players`.`id` = `" . TABLE_PREFIX . "forum`.`author_guid` AND `" . TABLE_PREFIX . "forum`.`post_date` <= ".time()." AND `" . TABLE_PREFIX . "forum`.`first_post` = ".(int) $thread['id'])->fetch(); | 				$post_page = $db->query("SELECT COUNT(`" . TABLE_PREFIX . "forum`.`id`) AS posts_count FROM `players`, `" . TABLE_PREFIX . "forum` WHERE `players`.`id` = `" . TABLE_PREFIX . "forum`.`author_guid` AND `" . TABLE_PREFIX . "forum`.`post_date` <= ".time()." AND `" . TABLE_PREFIX . "forum`.`first_post` = ".(int) $thread['id'])->fetch(); | ||||||
| 				$_page = (int) ceil($post_page['posts_count'] / $config['forum_threads_per_page']) - 1; | 				$_page = (int) ceil($post_page['posts_count'] / $config['forum_threads_per_page']) - 1; | ||||||
| @@ -86,10 +87,13 @@ if(Forum::canPost($account_logged)) | |||||||
| 			if(!empty($errors)) | 			if(!empty($errors)) | ||||||
| 				echo $twig->render('error_box.html.twig', array('errors' => $errors)); | 				echo $twig->render('error_box.html.twig', array('errors' => $errors)); | ||||||
| 				 | 				 | ||||||
| 			$threads = $db->query("SELECT `players`.`name`, `" . TABLE_PREFIX . "forum`.`post_text`, `" . TABLE_PREFIX . "forum`.`post_topic`, `" . TABLE_PREFIX . "forum`.`post_smile` FROM `players`, `" . TABLE_PREFIX . "forum` WHERE `players`.`id` = `" . TABLE_PREFIX . "forum`.`author_guid` AND `" . TABLE_PREFIX . "forum`.`first_post` = ".(int) $thread_id." ORDER BY `" . TABLE_PREFIX . "forum`.`post_date` DESC LIMIT 5")->fetchAll(); | 			$threads = $db->query("SELECT `players`.`name`, `" . TABLE_PREFIX . "forum`.`post_text`, `" . TABLE_PREFIX . "forum`.`post_topic`, `" . TABLE_PREFIX . "forum`.`post_smile`, `" . TABLE_PREFIX . "forum`.`post_html`, `" . TABLE_PREFIX . "forum`.`author_aid` FROM `players`, `" . TABLE_PREFIX . "forum` WHERE `players`.`id` = `" . TABLE_PREFIX . "forum`.`author_guid` AND `" . TABLE_PREFIX . "forum`.`first_post` = ".(int) $thread_id." ORDER BY `" . TABLE_PREFIX . "forum`.`post_date` DESC LIMIT 5")->fetchAll(); | ||||||
| 			 |  | ||||||
| 			foreach($threads as &$thread) { | 			foreach($threads as &$thread) { | ||||||
| 				$thread['post'] = Forum::showPost($thread['post_topic'], $thread['post_text'], $thread['post_smile']); | 				$player_account = new OTS_Account(); | ||||||
|  | 				$player_account->load($thread['author_aid']); | ||||||
|  | 				if($player_account->isLoaded()) { | ||||||
|  | 					$thread['post'] = Forum::showPost(($thread['post_html'] > 0 ? $thread['post_topic'] : htmlspecialchars($thread['post_topic'])), ($thread['post_html'] > 0 ? $thread['post_text'] : htmlspecialchars($thread['post_text'])), $thread['post_smile'] == 0, $thread['post_html'] > 0); | ||||||
|  | 				} | ||||||
| 			} | 			} | ||||||
| 			 | 			 | ||||||
| 			echo $twig->render('forum.new_post.html.twig', array( | 			echo $twig->render('forum.new_post.html.twig', array( | ||||||
| @@ -98,9 +102,11 @@ if(Forum::canPost($account_logged)) | |||||||
| 				'players' => $players_from_account, | 				'players' => $players_from_account, | ||||||
| 				'post_topic' => $post_topic, | 				'post_topic' => $post_topic, | ||||||
| 				'post_text' => $text, | 				'post_text' => $text, | ||||||
| 				'post_smile' => $smile, | 				'post_smile' => $smile > 0, | ||||||
|  | 				'post_html' => $html > 0, | ||||||
| 				'topic' => $thread['post_topic'], | 				'topic' => $thread['post_topic'], | ||||||
| 				'threads' => $threads | 				'threads' => $threads, | ||||||
|  | 				'canEdit' => $canEdit | ||||||
| 			)); | 			)); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -24,7 +24,8 @@ if(Forum::canPost($account_logged)) | |||||||
| 			$text = isset($_REQUEST['text']) ? stripslashes($_REQUEST['text']) : ''; | 			$text = isset($_REQUEST['text']) ? stripslashes($_REQUEST['text']) : ''; | ||||||
| 			$char_id = (int)(isset($_REQUEST['char_id']) ? $_REQUEST['char_id'] : 0); | 			$char_id = (int)(isset($_REQUEST['char_id']) ? $_REQUEST['char_id'] : 0); | ||||||
| 			$post_topic = isset($_REQUEST['topic']) ? stripslashes($_REQUEST['topic']) : ''; | 			$post_topic = isset($_REQUEST['topic']) ? stripslashes($_REQUEST['topic']) : ''; | ||||||
| 			$smile = (int)(isset($_REQUEST['smile']) ? $_REQUEST['smile'] : 0); | 			$smile = (isset($_REQUEST['smile']) ? (int)$_REQUEST['smile'] : 0); | ||||||
|  | 			$html = (isset($_REQUEST['html']) ? (int)$_REQUEST['html'] : 0); | ||||||
| 			$saved = false; | 			$saved = false; | ||||||
| 			if (isset($_REQUEST['save'])) { | 			if (isset($_REQUEST['save'])) { | ||||||
| 				$errors = array(); | 				$errors = array(); | ||||||
| @@ -68,7 +69,7 @@ if(Forum::canPost($account_logged)) | |||||||
| 				} | 				} | ||||||
| 				if (count($errors) == 0) { | 				if (count($errors) == 0) { | ||||||
| 					$saved = true; | 					$saved = true; | ||||||
| 					$db->query("INSERT INTO `" . TABLE_PREFIX . "forum` (`first_post` ,`last_post` ,`section` ,`replies` ,`views` ,`author_aid` ,`author_guid` ,`post_text` ,`post_topic` ,`post_smile` ,`post_date` ,`last_edit_aid` ,`edit_date`, `post_ip`) VALUES ('0', '" . time() . "', '" . (int)$section_id . "', '0', '0', '" . $account_logged->getId() . "', '" . (int)$char_id . "', " . $db->quote($text) . ", " . $db->quote($post_topic) . ", '" . (int)$smile . "', '" . time() . "', '0', '0', '" . $_SERVER['REMOTE_ADDR'] . "')"); | 					$db->query("INSERT INTO `" . TABLE_PREFIX . "forum` (`first_post` ,`last_post` ,`section` ,`replies` ,`views` ,`author_aid` ,`author_guid` ,`post_text` ,`post_topic` ,`post_smile`, `post_html` ,`post_date` ,`last_edit_aid` ,`edit_date`, `post_ip`) VALUES ('0', '" . time() . "', '" . (int)$section_id . "', '0', '0', '" . $account_logged->getId() . "', '" . (int)$char_id . "', " . $db->quote($text) . ", " . $db->quote($post_topic) . ", '" . (int)$smile . "', '" . (int)$html . "', '" . time() . "', '0', '0', '" . $_SERVER['REMOTE_ADDR'] . "')"); | ||||||
| 					$thread_id = $db->lastInsertId(); | 					$thread_id = $db->lastInsertId(); | ||||||
| 					$db->query("UPDATE `" . TABLE_PREFIX . "forum` SET `first_post`=" . (int)$thread_id . " WHERE `id` = " . (int)$thread_id); | 					$db->query("UPDATE `" . TABLE_PREFIX . "forum` SET `first_post`=" . (int)$thread_id . " WHERE `id` = " . (int)$thread_id); | ||||||
| 					header('Location: ' . getForumThreadLink($thread_id)); | 					header('Location: ' . getForumThreadLink($thread_id)); | ||||||
| @@ -85,8 +86,10 @@ if(Forum::canPost($account_logged)) | |||||||
| 					'players' => $players_from_account, | 					'players' => $players_from_account, | ||||||
| 					'post_player_id' => $char_id, | 					'post_player_id' => $char_id, | ||||||
| 					'post_thread' => $post_topic, | 					'post_thread' => $post_topic, | ||||||
| 					'text' => $text, | 					'post_text' => $text, | ||||||
| 					'smiles_enabled' => $smile > 0 | 					'post_smile' => $smile > 0, | ||||||
|  | 					'post_html' => $html > 0, | ||||||
|  | 					'canEdit' => $canEdit | ||||||
| 				)); | 				)); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ defined('MYAAC') or die('Direct access not allowed!'); | |||||||
| $links_to_pages = ''; | $links_to_pages = ''; | ||||||
| $thread_id = (int) $_REQUEST['id']; | $thread_id = (int) $_REQUEST['id']; | ||||||
| $_page = (int) (isset($_REQUEST['page']) ? $_REQUEST['page'] : 0); | $_page = (int) (isset($_REQUEST['page']) ? $_REQUEST['page'] : 0); | ||||||
| $thread_name = $db->query("SELECT `players`.`name`, `" . TABLE_PREFIX . "forum`.`post_topic`, `" . TABLE_PREFIX . "forum`.`section` FROM `players`, `" . TABLE_PREFIX . "forum` WHERE `" . TABLE_PREFIX . "forum`.`first_post` = ".(int) $thread_id." AND `" . TABLE_PREFIX . "forum`.`id` = `" . TABLE_PREFIX . "forum`.`first_post` AND `players`.`id` = `" . TABLE_PREFIX . "forum`.`author_guid` LIMIT 1")->fetch(); | $thread_name = $db->query("SELECT `players`.`name`, `" . TABLE_PREFIX . "forum`.`post_topic`, `" . TABLE_PREFIX . "forum`.`section`, `" . TABLE_PREFIX . "forum`.`post_html` FROM `players`, `" . TABLE_PREFIX . "forum` WHERE `" . TABLE_PREFIX . "forum`.`first_post` = ".(int) $thread_id." AND `" . TABLE_PREFIX . "forum`.`id` = `" . TABLE_PREFIX . "forum`.`first_post` AND `players`.`id` = `" . TABLE_PREFIX . "forum`.`author_guid` LIMIT 1")->fetch(); | ||||||
|  |  | ||||||
| if(empty($thread_name['name'])) { | if(empty($thread_name['name'])) { | ||||||
| 	echo 'Thread with this ID does not exits.'; | 	echo 'Thread with this ID does not exits.'; | ||||||
| @@ -33,11 +33,11 @@ for($i = 0; $i < $posts_count['posts_count'] / $config['forum_threads_per_page'] | |||||||
| 	else | 	else | ||||||
| 		$links_to_pages .= '<b>'.($i + 1).' </b>'; | 		$links_to_pages .= '<b>'.($i + 1).' </b>'; | ||||||
| } | } | ||||||
| $threads = $db->query("SELECT `players`.`id` as `player_id`, `players`.`name`, `players`.`account_id`, `players`.`vocation`" . (fieldExist('promotion', 'players') ? ", `players`.`promotion`" : "") . ", `players`.`level`, `" . TABLE_PREFIX . "forum`.`id`,`" . TABLE_PREFIX . "forum`.`first_post`, `" . TABLE_PREFIX . "forum`.`section`,`" . TABLE_PREFIX . "forum`.`post_text`, `" . TABLE_PREFIX . "forum`.`post_topic`, `" . TABLE_PREFIX . "forum`.`post_date`, `" . TABLE_PREFIX . "forum`.`post_smile`, `" . TABLE_PREFIX . "forum`.`author_aid`, `" . TABLE_PREFIX . "forum`.`author_guid`, `" . TABLE_PREFIX . "forum`.`last_edit_aid`, `" . TABLE_PREFIX . "forum`.`edit_date` FROM `players`, `" . TABLE_PREFIX . "forum` WHERE `players`.`id` = `" . TABLE_PREFIX . "forum`.`author_guid` AND `" . TABLE_PREFIX . "forum`.`first_post` = ".(int) $thread_id." ORDER BY `" . TABLE_PREFIX . "forum`.`post_date` LIMIT ".$config['forum_posts_per_page']." OFFSET ".($_page * $config['forum_posts_per_page']))->fetchAll(); | $threads = $db->query("SELECT `players`.`id` as `player_id`, `players`.`name`, `players`.`account_id`, `players`.`vocation`" . (fieldExist('promotion', 'players') ? ", `players`.`promotion`" : "") . ", `players`.`level`, `" . TABLE_PREFIX . "forum`.`id`,`" . TABLE_PREFIX . "forum`.`first_post`, `" . TABLE_PREFIX . "forum`.`section`,`" . TABLE_PREFIX . "forum`.`post_text`, `" . TABLE_PREFIX . "forum`.`post_topic`, `" . TABLE_PREFIX . "forum`.`post_date`, `" . TABLE_PREFIX . "forum`.`post_smile`, `" . TABLE_PREFIX . "forum`.`post_html`, `" . TABLE_PREFIX . "forum`.`author_aid`, `" . TABLE_PREFIX . "forum`.`author_guid`, `" . TABLE_PREFIX . "forum`.`last_edit_aid`, `" . TABLE_PREFIX . "forum`.`edit_date` FROM `players`, `" . TABLE_PREFIX . "forum` WHERE `players`.`id` = `" . TABLE_PREFIX . "forum`.`author_guid` AND `" . TABLE_PREFIX . "forum`.`first_post` = ".(int) $thread_id." ORDER BY `" . TABLE_PREFIX . "forum`.`post_date` LIMIT ".$config['forum_posts_per_page']." OFFSET ".($_page * $config['forum_posts_per_page']))->fetchAll(); | ||||||
| if(isset($threads[0]['name'])) | if(isset($threads[0]['name'])) | ||||||
| 	$db->query("UPDATE `" . TABLE_PREFIX . "forum` SET `views`=`views`+1 WHERE `id` = ".(int) $thread_id); | 	$db->query("UPDATE `" . TABLE_PREFIX . "forum` SET `views`=`views`+1 WHERE `id` = ".(int) $thread_id); | ||||||
| echo '<a href="' . getLink('forum') . '">Boards</a> >> <a href="' . getForumBoardLink($threads[0]['section']) . '">'.$sections[$threads[0]['section']]['name'].'</a> >> <b>'.$thread_name['post_topic'].'</b>'; | echo '<a href="' . getLink('forum') . '">Boards</a> >> <a href="' . getForumBoardLink($threads[0]['section']) . '">'.$sections[$threads[0]['section']]['name'].'</a> >> <b>'.($thread_name['post_html'] ? $thread_name['post_topic'] : htmlspecialchars($thread_name['post_topic'])).'</b>'; | ||||||
| echo '<br /><br /><a href="?subtopic=forum&action=new_post&thread_id='.$thread_id.'"><img src="images/forum/post.gif" border="0" /></a><br /><br />Page: '.$links_to_pages.'<br /><table width="100%"><tr bgcolor="'.$config['lightborder'].'" width="100%"><td colspan="2"><font size="4"><b>'.htmlspecialchars($thread_name['post_topic']).'</b></font><font size="1"><br />by ' . getPlayerLink($thread_name['name']) . '</font></td></tr><tr bgcolor="'.$config['vdarkborder'].'"><td width="200"><font color="white" size="1"><b>Author</b></font></td><td> </td></tr>'; | echo '<br /><br /><a href="?subtopic=forum&action=new_post&thread_id='.$thread_id.'"><img src="images/forum/post.gif" border="0" /></a><br /><br />Page: '.$links_to_pages.'<br /><table width="100%"><tr bgcolor="'.$config['lightborder'].'" width="100%"><td colspan="2"><font size="4"><b>'.($thread_name['post_html'] ? $thread_name['post_topic'] : htmlspecialchars($thread_name['post_topic'])).'</b></font><font size="1"><br />by ' . getPlayerLink($thread_name['name']) . '</font></td></tr><tr bgcolor="'.$config['vdarkborder'].'"><td width="200"><font color="white" size="1"><b>Author</b></font></td><td> </td></tr>'; | ||||||
| $player = $ots->createObject('Player'); | $player = $ots->createObject('Player'); | ||||||
| foreach($threads as $thread) | foreach($threads as $thread) | ||||||
| { | { | ||||||
| @@ -47,7 +47,7 @@ foreach($threads as $thread) | |||||||
| 		die(); | 		die(); | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	echo '<tr bgcolor="' . getStyle($number_of_rows++) . '"><td valign="top">' . getPlayerLink($thread['name']) . '<br /><br /><font size="1">Profession: '.$config['vocations'][$player->getVocation()].'<br />Level: '.$thread['level'].'<br />'; | 	echo '<tr bgcolor="' . getStyle($number_of_rows++) . '"><td valign="top">' . getPlayerLink($thread['name']) . '<br /><br /><font size="1">Profession: '.$player->getVocationName().'<br />Level: '.$thread['level'].'<br />'; | ||||||
|  |  | ||||||
| 	$rank = $player->getRank(); | 	$rank = $player->getRank(); | ||||||
| 	if($rank->isLoaded()) | 	if($rank->isLoaded()) | ||||||
| @@ -56,11 +56,9 @@ foreach($threads as $thread) | |||||||
| 		if($guild->isLoaded()) | 		if($guild->isLoaded()) | ||||||
| 			echo $rank->getName().' of <a href="'.getGuildLink($guild->getName(), false).'">'.$guild->getName().'</a><br />'; | 			echo $rank->getName().' of <a href="'.getGuildLink($guild->getName(), false).'">'.$guild->getName().'</a><br />'; | ||||||
| 	} | 	} | ||||||
| 	$player_account = $player->getAccount(); |  | ||||||
| 	$canEditForum = $player_account->hasFlag(FLAG_CONTENT_FORUM) || $player_account->isAdmin(); |  | ||||||
|  |  | ||||||
| 	$posts = $db->query("SELECT COUNT(`id`) AS 'posts' FROM `" . TABLE_PREFIX . "forum` WHERE `author_aid`=".(int) $thread['account_id'])->fetch(); | 	$posts = $db->query("SELECT COUNT(`id`) AS 'posts' FROM `" . TABLE_PREFIX . "forum` WHERE `author_aid`=".(int) $thread['account_id'])->fetch(); | ||||||
| 	echo '<br />Posts: '.(int) $posts['posts'].'<br /></font></td><td valign="top">'.Forum::showPost(($canEditForum ? $thread['post_topic'] : htmlspecialchars($thread['post_topic'])), ($canEditForum ? $thread['post_text'] : htmlspecialchars($thread['post_text'])), $thread['post_smile']).'</td></tr> | 	echo '<br />Posts: '.(int) $posts['posts'].'<br /></font></td><td valign="top">'.Forum::showPost(($thread['post_html'] > 0 ? $thread['post_topic'] : htmlspecialchars($thread['post_topic'])), ($thread['post_html'] > 0 ? $thread['post_text'] : htmlspecialchars($thread['post_text'])), $thread['post_smile'] == 0, $thread['post_html'] > 0).'</td></tr> | ||||||
| 		<tr bgcolor="'.getStyle($number_of_rows++).'"><td><font size="1">'.date('d.m.y H:i:s', $thread['post_date']); | 		<tr bgcolor="'.getStyle($number_of_rows++).'"><td><font size="1">'.date('d.m.y H:i:s', $thread['post_date']); | ||||||
| 	if($thread['edit_date'] > 0) | 	if($thread['edit_date'] > 0) | ||||||
| 	{ | 	{ | ||||||
|   | |||||||
| @@ -11,13 +11,13 @@ | |||||||
| defined('MYAAC') or die('Direct access not allowed!'); | defined('MYAAC') or die('Direct access not allowed!'); | ||||||
|  |  | ||||||
| $guild_name = isset($_REQUEST['guild']) ? urldecode($_REQUEST['guild']) : null; | $guild_name = isset($_REQUEST['guild']) ? urldecode($_REQUEST['guild']) : null; | ||||||
| $new_rank = isset($_REQUEST['rank_name']) ? $_REQUEST['rank_name'] : null; | $rank_name = isset($_REQUEST['rank_name']) ? $_REQUEST['rank_name'] : null; | ||||||
| if(!Validator::guildName($guild_name)) { | if(!Validator::guildName($guild_name)) { | ||||||
| 	$errors[] = Validator::getLastError(); | 	$errors[] = Validator::getLastError(); | ||||||
| } | } | ||||||
|  |  | ||||||
| if(empty($errors)) { | if(empty($errors)) { | ||||||
| 	if(!Validator::rankName($new_rank)) { | 	if(!Validator::rankName($rank_name)) { | ||||||
| 		$errors[] = 'Invalid rank name format.'; | 		$errors[] = 'Invalid rank name format.'; | ||||||
| 	} | 	} | ||||||
| 	if(!$logged) { | 	if(!$logged) { | ||||||
| @@ -45,7 +45,7 @@ if(empty($errors)) { | |||||||
| 			$new_rank = new OTS_GuildRank(); | 			$new_rank = new OTS_GuildRank(); | ||||||
| 			$new_rank->setGuild($guild); | 			$new_rank->setGuild($guild); | ||||||
| 			$new_rank->setLevel(1); | 			$new_rank->setLevel(1); | ||||||
| 			$new_rank->setName($new_rank); | 			$new_rank->setName($rank_name); | ||||||
| 			$new_rank->save(); | 			$new_rank->save(); | ||||||
| 			header("Location: ?subtopic=guilds&guild=".$guild->getName()."&action=manager"); | 			header("Location: ?subtopic=guilds&guild=".$guild->getName()."&action=manager"); | ||||||
| 			echo 'New rank added. Redirecting...'; | 			echo 'New rank added. Redirecting...'; | ||||||
|   | |||||||
| @@ -32,6 +32,12 @@ if(!$new_nick) { | |||||||
| $player = new OTS_Player(); | $player = new OTS_Player(); | ||||||
| $player->find($name); | $player->find($name); | ||||||
| $player_from_account = false; | $player_from_account = false; | ||||||
|  |  | ||||||
|  | if(!Validator::guildNick($new_nick)) { | ||||||
|  |     echo Validator::getLastError(); | ||||||
|  |     return; | ||||||
|  | } | ||||||
|  |  | ||||||
| if(strlen($new_nick) <= 40) | if(strlen($new_nick) <= 40) | ||||||
| { | { | ||||||
| 	if($player->isLoaded()) | 	if($player->isLoaded()) | ||||||
|   | |||||||
| @@ -94,7 +94,7 @@ else | |||||||
| { | { | ||||||
| 	if(isset($_REQUEST['todo']) && $_REQUEST['todo'] == 'save') { | 	if(isset($_REQUEST['todo']) && $_REQUEST['todo'] == 'save') { | ||||||
| 		$player->setRank(); | 		$player->setRank(); | ||||||
| 		$twig->render('success.html.twig', array( | 		echo $twig->render('success.html.twig', array( | ||||||
| 			'title' => 'Leave guild', | 			'title' => 'Leave guild', | ||||||
| 			'description' => 'Player with name <b>'.$player->getName().'</b> leaved guild <b>'.$guild->getName().'</b>.', | 			'description' => 'Player with name <b>'.$player->getName().'</b> leaved guild <b>'.$guild->getName().'</b>.', | ||||||
| 			'custom_buttons' => $twig->render('guilds.back_button.html.twig', array( | 			'custom_buttons' => $twig->render('guilds.back_button.html.twig', array( | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ defined('MYAAC') or die('Direct access not allowed!'); | |||||||
|  |  | ||||||
| $guild_name = isset($_REQUEST['guild']) ? urldecode($_REQUEST['guild']) : null; | $guild_name = isset($_REQUEST['guild']) ? urldecode($_REQUEST['guild']) : null; | ||||||
| if(!Validator::guildName($guild_name)) { | if(!Validator::guildName($guild_name)) { | ||||||
| 	$errors[] = Validator::get; | 	$errors[] = Validator::getLastError(); | ||||||
| } | } | ||||||
|  |  | ||||||
| if(empty($errors)) { | if(empty($errors)) { | ||||||
|   | |||||||
| @@ -10,6 +10,7 @@ | |||||||
|  */ |  */ | ||||||
| defined('MYAAC') or die('Direct access not allowed!'); | defined('MYAAC') or die('Direct access not allowed!'); | ||||||
|  |  | ||||||
|  | $title = 'Guilds'; | ||||||
| $guild_name = isset($_REQUEST['guild']) ? urldecode($_REQUEST['guild']) : null; | $guild_name = isset($_REQUEST['guild']) ? urldecode($_REQUEST['guild']) : null; | ||||||
| if(!Validator::guildName($guild_name)) | if(!Validator::guildName($guild_name)) | ||||||
| 	$errors[] = Validator::getLastError(); | 	$errors[] = Validator::getLastError(); | ||||||
| @@ -41,6 +42,7 @@ else | |||||||
| 	$players_from_account_in_guild = array(); | 	$players_from_account_in_guild = array(); | ||||||
| 	if($logged) | 	if($logged) | ||||||
| 	{ | 	{ | ||||||
|  | 		$players_from_account_ids = array(); | ||||||
| 		$account_players = $account_logged->getPlayers(); | 		$account_players = $account_logged->getPlayers(); | ||||||
| 		foreach($account_players as $player) | 		foreach($account_players as $player) | ||||||
| 		{ | 		{ | ||||||
|   | |||||||
| @@ -22,11 +22,17 @@ $add_sql = ''; | |||||||
| $config_vocations = $config['vocations']; | $config_vocations = $config['vocations']; | ||||||
| if($config['highscores_vocation_box'] && isset($vocation)) | if($config['highscores_vocation_box'] && isset($vocation)) | ||||||
| { | { | ||||||
| 	for($i = 1; $i < count($config_vocations) / 2; $i++) | 	foreach($config['vocations'] as $id => $name) { | ||||||
| 	{ | 		if(strtolower($name) == $vocation) { | ||||||
| 		if(strtolower($config_vocations[$i]) == $vocation) | 			$add_vocs = array($id); | ||||||
| 		{ | 	 | ||||||
| 			$add_sql = 'AND ' . $db->fieldName('vocation') . ' = ' . $db->quote($i); | 			$i = $id + $config['vocations_amount']; | ||||||
|  | 			while(isset($config['vocations'][$i])) { | ||||||
|  | 				$add_vocs[] = $i; | ||||||
|  | 				$i += $config['vocations_amount']; | ||||||
|  | 			} | ||||||
|  | 	 | ||||||
|  | 			$add_sql = 'AND `vocation` IN (' . implode(', ', $add_vocs) . ')'; | ||||||
| 			break; | 			break; | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| @@ -178,6 +184,7 @@ $i = 0; | |||||||
| $online_exist = false; | $online_exist = false; | ||||||
| if(fieldExist('online', 'players')) | if(fieldExist('online', 'players')) | ||||||
| 	$online_exist = true; | 	$online_exist = true; | ||||||
|  |  | ||||||
| foreach($skills as $player) | foreach($skills as $player) | ||||||
| { | { | ||||||
| 	if(!$online_exist) { | 	if(!$online_exist) { | ||||||
| @@ -211,7 +218,11 @@ echo ' | |||||||
| 							$player['vocation'] += ($player['promotion'] * $config['vocations_amount']); | 							$player['vocation'] += ($player['promotion'] * $config['vocations_amount']); | ||||||
| 					} | 					} | ||||||
|  |  | ||||||
| 					echo '<br/><small>' . $config['vocations'][$player['vocation']] . '</small>'; | 					$tmp = 'Unknown'; | ||||||
|  | 					if(isset($config['vocations'][$player['vocation']])) { | ||||||
|  | 						$tmp = $config['vocations'][$player['vocation']]; | ||||||
|  | 					} | ||||||
|  | 					echo '<br/><small>' . $tmp . '</small>'; | ||||||
| 				} | 				} | ||||||
| echo ' | echo ' | ||||||
| 			</td> | 			</td> | ||||||
| @@ -228,8 +239,10 @@ echo ' | |||||||
| 		$show_link_to_next_page = true; | 		$show_link_to_next_page = true; | ||||||
| } | } | ||||||
|  |  | ||||||
| if(!$i) | if(!$i) { | ||||||
| 	echo '<tr bgcolor="' . $config['darkborder'] . '"><td colspan="' . ($skill == POT::SKILL__LEVEL ? 5 : 4) . '">No records yet.</td></tr>'; | 	$extra = ($config['highscores_outfit'] ? 1 : 0); | ||||||
|  | 	echo '<tr bgcolor="' . $config['darkborder'] . '"><td colspan="' . ($skill == POT::SKILL__LEVEL ? 5 + $extra : 4 + $extra) . '">No records yet.</td></tr>'; | ||||||
|  | } | ||||||
|  |  | ||||||
| ?> | ?> | ||||||
| </table> | </table> | ||||||
|   | |||||||
| @@ -84,7 +84,7 @@ if(tableExist('player_killers')) // tfs 0.3 | |||||||
| else { | else { | ||||||
| 	//$players_deaths = $db->query("SELECT `p`.`name` AS `victim`, `player_deaths`.`killed_by` as `killed_by`, `player_deaths`.`time` as `time`, `player_deaths`.`is_player` as `is_player`, `player_deaths`.`level` as `level` FROM `player_deaths`, `players` as `d` INNER JOIN `players` as `p` ON player_deaths.player_id = p.id WHERE player_deaths.`is_player`='1' ORDER BY `time` DESC LIMIT " . $config['last_kills_limit'] . ";"); | 	//$players_deaths = $db->query("SELECT `p`.`name` AS `victim`, `player_deaths`.`killed_by` as `killed_by`, `player_deaths`.`time` as `time`, `player_deaths`.`is_player` as `is_player`, `player_deaths`.`level` as `level` FROM `player_deaths`, `players` as `d` INNER JOIN `players` as `p` ON player_deaths.player_id = p.id WHERE player_deaths.`is_player`='1' ORDER BY `time` DESC LIMIT " . $config['last_kills_limit'] . ";"); | ||||||
| 	 | 	 | ||||||
| $players_deaths = $db->query("SELECT `p`.`name` AS `victim`, `d`.`killed_by` as `killed_by`, `d`.`time` as `time`, `d`.`level`, `d`.`is_player` FROM `player_deaths` as `d` INNER JOIN `players` as `p` ON d.player_id = p.id ORDER BY `time` DESC LIMIT 20;"); | $players_deaths = $db->query("SELECT `p`.`name` AS `victim`, `d`.`killed_by` as `killed_by`, `d`.`time` as `time`, `d`.`level`, `d`.`is_player` FROM `player_deaths` as `d` INNER JOIN `players` as `p` ON d.player_id = p.id ORDER BY `time` DESC LIMIT " . $config['last_kills_limit'] . ";"); | ||||||
|  |  | ||||||
| 	if(!empty($players_deaths)) | 	if(!empty($players_deaths)) | ||||||
| 	{ | 	{ | ||||||
|   | |||||||
| @@ -387,7 +387,7 @@ class News | |||||||
| 		if(!self::verify($title, $body, $article_text, $article_image, $errors)) | 		if(!self::verify($title, $body, $article_text, $article_image, $errors)) | ||||||
| 			return false; | 			return false; | ||||||
|  |  | ||||||
| 		$db->insert(TABLE_PREFIX . 'news', array('title' => $title, 'body' => $body, 'type' => $type, 'date' => time(), 'category' => $category, 'player_id' => isset($player_id) ? $player_id : 0, 'comments' => $comments, 'article_text' => $article_text, 'article_image' => $article_image)); | 		$db->insert(TABLE_PREFIX . 'news', array('title' => $title, 'body' => $body, 'type' => $type, 'date' => time(), 'category' => $category, 'player_id' => isset($player_id) ? $player_id : 0, 'comments' => $comments, 'article_text' => ($type == 3 ? $article_text : ''), 'article_image' => ($type == 3 ? $article_image : ''))); | ||||||
| 		return true; | 		return true; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -13,31 +13,6 @@ $title = 'Polls'; | |||||||
|  |  | ||||||
| /* Polls System By Averatec from pervera.pl & otland.net */ | /* Polls System By Averatec from pervera.pl & otland.net */ | ||||||
|  |  | ||||||
| if(!tableExist('z_polls')) |  | ||||||
| 	$db->query(' |  | ||||||
| CREATE TABLE `z_polls` ( |  | ||||||
|   `id` int(11) NOT NULL auto_increment, |  | ||||||
|   `question` varchar(255) NOT NULL, |  | ||||||
|   `description` varchar(255) NOT NULL, |  | ||||||
|   `end` int(11) NOT NULL DEFAULT 0, |  | ||||||
|   `start` int(11) NOT NULL DEFAULT 0, |  | ||||||
|   `answers` int(11) NOT NULL DEFAULT 0, |  | ||||||
|   `votes_all` int(11) NOT NULL DEFAULT 0, |  | ||||||
|   PRIMARY KEY  (`id`) |  | ||||||
| ) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;'); |  | ||||||
|  |  | ||||||
| if(!tableExist('z_polls_answers')) |  | ||||||
| $db->query(' |  | ||||||
| 	CREATE TABLE `z_polls_answers` ( |  | ||||||
|   `poll_id` int(11) NOT NULL, |  | ||||||
|   `answer_id` int(11) NOT NULL, |  | ||||||
|   `answer` varchar(255) NOT NULL, |  | ||||||
|   `votes` int(11) NOT NULL DEFAULT 0 |  | ||||||
| ) ENGINE=MyISAM DEFAULT CHARSET=latin1;'); |  | ||||||
|  |  | ||||||
| if(!fieldExist('vote', 'accounts')) |  | ||||||
| 	$db->query('ALTER TABLE `accounts` ADD `vote` INT( 11 ) NOT NULL ;'); |  | ||||||
|  |  | ||||||
| function getColorByPercent($percent) | function getColorByPercent($percent) | ||||||
| { | { | ||||||
| 	if($percent < 15) | 	if($percent < 15) | ||||||
|   | |||||||
| @@ -75,8 +75,13 @@ if(isset($config['lua']['statustimeout'])) | |||||||
| // get status timeout from server config | // get status timeout from server config | ||||||
| $status_timeout = eval('return ' . $config['lua']['statusTimeout'] . ';') / 1000 + 1; | $status_timeout = eval('return ' . $config['lua']['statusTimeout'] . ';') / 1000 + 1; | ||||||
|  |  | ||||||
| if($status['lastCheck'] + $status_timeout < time()) | if($status['lastCheck'] + $status_timeout < time()) { | ||||||
| { | 	updateStatus(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function updateStatus() { | ||||||
|  | 	global $db, $cache, $config, $status, $status_ip, $status_port; | ||||||
|  | 	 | ||||||
| 	// get server status and save it to database | 	// get server status and save it to database | ||||||
| 	$serverInfo = new OTS_ServerInfo($status_ip, $status_port); | 	$serverInfo = new OTS_ServerInfo($status_ip, $status_port); | ||||||
| 	$serverStatus = $serverInfo->status(); | 	$serverStatus = $serverInfo->status(); | ||||||
| @@ -98,9 +103,14 @@ if($status['lastCheck'] + $status_timeout < time()) | |||||||
| 		if($config['online_afk']) | 		if($config['online_afk']) | ||||||
| 		{ | 		{ | ||||||
| 			// get amount of players that are currently logged in-game, including disconnected clients (exited) | 			// get amount of players that are currently logged in-game, including disconnected clients (exited) | ||||||
| 			$query = $db->query('SELECT COUNT(' . $db->fieldName('id') . ') AS playersTotal FROM ' . $db->tableName('players') . | 			if(tableExist('players_online')) { // tfs 1.x | ||||||
| 				' WHERE ' . $db->fieldName('online') . ' > 0'); | 				$query = $db->query('SELECT COUNT(`player_id`) AS `playersTotal` FROM `players_online`;'); | ||||||
|  | 			} | ||||||
|  | 			else { | ||||||
|  | 				$query = $db->query('SELECT COUNT(`id`) AS `playersTotal` FROM `players` WHERE `online` > 0'); | ||||||
|  | 			} | ||||||
| 			 | 			 | ||||||
|  | 			$status['playersTotal'] = 0; | ||||||
| 			if($query->rowCount() > 0) | 			if($query->rowCount() > 0) | ||||||
| 			{ | 			{ | ||||||
| 				$query = $query->fetch(); | 				$query = $query->fetch(); | ||||||
| @@ -133,4 +143,3 @@ if($status['lastCheck'] + $status_timeout < time()) | |||||||
| 		updateDatabaseConfig('status_' . $key, $value); | 		updateDatabaseConfig('status_' . $key, $value); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| ?> |  | ||||||
|   | |||||||
| @@ -15,42 +15,38 @@ if($config['template_allow_change']) | |||||||
| { | { | ||||||
| 	if(isset($_GET['template'])) | 	if(isset($_GET['template'])) | ||||||
| 	{ | 	{ | ||||||
| 		$template_name = $_GET['template']; |  | ||||||
| 		if(!preg_match("/[^A-z0-9_\-]/", $template_name)) { // validate template | 		if(!preg_match("/[^A-z0-9_\-]/", $template_name)) { // validate template | ||||||
| 			//setcookie('template', $template_name, 0, BASE_DIR . '/', $_SERVER["SERVER_NAME"]); | 			//setcookie('template', $template_name, 0, BASE_DIR . '/', $_SERVER["SERVER_NAME"]); | ||||||
|  | 			$template_name = $_GET['template']; | ||||||
| 			setSession('template', $template_name); | 			setSession('template', $template_name); | ||||||
| 			header('Location:' . getSession('last_uri')); | 			header('Location:' . getSession('last_uri')); | ||||||
| 		} | 		} | ||||||
| 		else |  | ||||||
| 			$template_name = $config['template']; |  | ||||||
| 	} | 	} | ||||||
| 	else { | 	else { | ||||||
| 		$template_session = getSession('template'); | 		$template_session = getSession('template'); | ||||||
| 		if ($template_session !== false) { | 		if ($template_session !== false) { | ||||||
| 			if (!preg_match("/[^A-z0-9_\-]/", $template_session)) { | 			if (!preg_match("/[^A-z0-9_\-]/", $template_session)) { | ||||||
| 				$template_name = $template_session; | 				$template_name = $template_session; | ||||||
| 			} else { |  | ||||||
| 				$template_name = $config['template']; |  | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| $template_path = 'templates/' . $template_name; | $template_path = 'templates/' . $template_name; | ||||||
|  |  | ||||||
| if(!file_exists($template_path . '/index.php') && | if(!file_exists(BASE . $template_path . '/index.php') && | ||||||
| 	!file_exists($template_path . '/template.php') && | 	!file_exists(BASE . $template_path . '/template.php') && | ||||||
| 	!file_exists($template_path . '/layout.php')) | 	!file_exists(BASE . $template_path . '/layout.php')) | ||||||
| { | { | ||||||
| 	$template_name = 'kathrine'; | 	$template_name = 'kathrine'; | ||||||
| 	$template_path = TEMPLATES . $template_name; | 	$template_path = 'templates/' . $template_name; | ||||||
| } | } | ||||||
|  |  | ||||||
| $file = $template_path . '/config.ini'; | $file = BASE . $template_path . '/config.ini'; | ||||||
| $exists = file_exists($file); | $exists = file_exists($file); | ||||||
| if($exists || ($config['backward_support'] && file_exists($template_path . '/layout_config.ini'))) | if($exists || ($config['backward_support'] && file_exists(BASE . $template_path . '/layout_config.ini'))) | ||||||
| { | { | ||||||
| 	if(!$exists) | 	if(!$exists) | ||||||
| 		$file = $template_path . '/layout_config.ini'; | 		$file = BASE . $template_path . '/layout_config.ini'; | ||||||
|  |  | ||||||
| 	if($cache->enabled()) | 	if($cache->enabled()) | ||||||
| 	{ | 	{ | ||||||
| @@ -69,8 +65,8 @@ if($exists || ($config['backward_support'] && file_exists($template_path . '/lay | |||||||
| 	foreach($template_ini as $key => $value) | 	foreach($template_ini as $key => $value) | ||||||
| 		$config[$key] = $value; | 		$config[$key] = $value; | ||||||
| } | } | ||||||
| else if(file_exists($template_path . '/config.php')) | else if(file_exists(BASE . $template_path . '/config.php')) | ||||||
| 	require($template_path . '/config.php'); | 	require(BASE . $template_path . '/config.php'); | ||||||
|  |  | ||||||
| $template = array(); | $template = array(); | ||||||
| $template['link_account_manage'] = getLink('account/manage'); | $template['link_account_manage'] = getLink('account/manage'); | ||||||
|   | |||||||
| @@ -51,7 +51,17 @@ | |||||||
| 	<div id="two"> | 	<div id="two"> | ||||||
| 		<h1>My account</h1> | 		<h1>My account</h1> | ||||||
| 		<p>Welcome to your account page, {{ account }}<br> | 		<p>Welcome to your account page, {{ account }}<br> | ||||||
| 			You have {{ account_logged.getPremDays() }} days remaining premium account.</p> | 			{% if config.lua.freePremium %} | ||||||
|  | 			You have unlimited Premium Account. | ||||||
|  | 			{% else %} | ||||||
|  | 				{% set premiumDays = account_logged.getPremDays() %} | ||||||
|  | 				{% if premiumDays == 0 %} | ||||||
|  | 				You don't have Premium Account | ||||||
|  | 				{% else %} | ||||||
|  | 				You have {{ premiumDays }} days remaining Premium Account. | ||||||
|  | 				{% endif %} | ||||||
|  | 			{% endif %} | ||||||
|  | 		</p> | ||||||
|  |  | ||||||
| 		{# if account dont have recovery key show hint #} | 		{# if account dont have recovery key show hint #} | ||||||
| 		{% if recovery_key is empty %} | 		{% if recovery_key is empty %} | ||||||
| @@ -74,6 +84,7 @@ | |||||||
| 			</div> | 			</div> | ||||||
| 		<br/><br/> | 		<br/><br/> | ||||||
| 		{% endif %} | 		{% endif %} | ||||||
|  | 		<a name="General+Information"></a> | ||||||
| 		<h2>General Information</h2> | 		<h2>General Information</h2> | ||||||
| 		<table width="100%"> | 		<table width="100%"> | ||||||
| 			<tr style="background-color: {{ config.lightborder }};" > | 			<tr style="background-color: {{ config.lightborder }};" > | ||||||
| @@ -108,6 +119,7 @@ | |||||||
| 			{% endautoescape %} | 			{% endautoescape %} | ||||||
| 		</table> | 		</table> | ||||||
| 		<br/> | 		<br/> | ||||||
|  | 		<a name="Public+Information"></a> | ||||||
| 		<h2>Public Information</h2> | 		<h2>Public Information</h2> | ||||||
| 		<table width="100%"> | 		<table width="100%"> | ||||||
| 			<tr style="background-color: {{ config.lightborder }};" > | 			<tr style="background-color: {{ config.lightborder }};" > | ||||||
| @@ -123,6 +135,7 @@ | |||||||
| 			<input type="submit" value="Change Info" /> | 			<input type="submit" value="Change Info" /> | ||||||
| 		</form> | 		</form> | ||||||
| 		<br/> | 		<br/> | ||||||
|  | 		<a name="Account+Logs" ></a> | ||||||
| 		<h2>Action Log</h2> | 		<h2>Action Log</h2> | ||||||
| 		<table> | 		<table> | ||||||
| 			<tr bgcolor="{{ config.vdarkborder }}" class="white"> | 			<tr bgcolor="{{ config.vdarkborder }}" class="white"> | ||||||
| @@ -141,6 +154,7 @@ | |||||||
| 			{% endautoescape %} | 			{% endautoescape %} | ||||||
| 		</table> | 		</table> | ||||||
| 		<br/> | 		<br/> | ||||||
|  | 		<a name="Characters" ></a> | ||||||
| 		<h2>Character list: {{ players|length }} characters.</h2> | 		<h2>Character list: {{ players|length }} characters.</h2> | ||||||
| 		<table> | 		<table> | ||||||
| 			<tr bgcolor="{{ config.vdarkborder }}" class="white"> | 			<tr bgcolor="{{ config.vdarkborder }}" class="white"> | ||||||
| @@ -150,7 +164,7 @@ | |||||||
| 			{% for player in players %} | 			{% for player in players %} | ||||||
| 				{% set i = i + 1 %} | 				{% set i = i + 1 %} | ||||||
| 				<tr bgcolor="{{ getStyle(i) }}"> | 				<tr bgcolor="{{ getStyle(i) }}"> | ||||||
| 					<td><a href="{{ getLink('characters/' ~ player.getName()|urlencode) }}">{{ player.getName() }}</a></td><td>{{ player.getLevel() }}</td><td>{{ config.vocations[player.getVocation()] }}</td><td>{{ config.towns[player.getTownId()] }}</td><td>{% if player.getLastLogin() > 0 %}{{ player.getLastLogin|date('d F Y (H:i)') }}{% else %}Never.{% endif %}</td><td>{%  if player.isOnline() %}<font color="green">ONLINE</font>{% else %}<font color="red">Offline</font>{% endif %}</td><td>{% if player.isHidden() %}Hidden{% else %}Visible{% endif %}</td><td>[<a href="{{ getLink('account/character/comment/' ~ player.getName|urlencode) }}" >Edit</a>]</td> | 					<td><a href="{{ getLink('characters/' ~ player.getName()|urlencode) }}">{{ player.getName() }}</a></td><td>{{ player.getLevel() }}</td><td>{{ player.getVocationName() }}</td><td>{{ config.towns[player.getTownId()] }}</td><td>{% if player.getLastLogin() > 0 %}{{ player.getLastLogin|date('d F Y (H:i)') }}{% else %}Never.{% endif %}</td><td>{%  if player.isOnline() %}<font color="green">ONLINE</font>{% else %}<font color="red">Offline</font>{% endif %}</td><td>{% if player.isHidden() %}Hidden{% else %}Visible{% endif %}</td><td>[<a href="{{ getLink('account/character/comment/' ~ player.getName|urlencode) }}" >Edit</a>]</td> | ||||||
| 				</tr> | 				</tr> | ||||||
| 			{% endfor %} | 			{% endfor %} | ||||||
| 		</table> | 		</table> | ||||||
|   | |||||||
| @@ -35,7 +35,7 @@ | |||||||
| 	{% if status.online %} | 	{% if status.online %} | ||||||
| 	<p class="success" style="width: 150px; text-align: center;">Status: Online<br/> | 	<p class="success" style="width: 150px; text-align: center;">Status: Online<br/> | ||||||
| 		{{ status.uptimeReadable }}, {{ status.players }}/{{ status.playersMax }}<br/> | 		{{ status.uptimeReadable }}, {{ status.players }}/{{ status.playersMax }}<br/> | ||||||
| 		{{ status.lua.ip }} : {{ status.lua.loginPort }} | 		{{ config.lua.ip }} : {{ config.lua.loginPort }} | ||||||
| 		<br/><br/><u><a id="more-button" href="#"></a></u> | 		<br/><br/><u><a id="more-button" href="#"></a></u> | ||||||
|  |  | ||||||
| 		<span id="status-more"> | 		<span id="status-more"> | ||||||
|   | |||||||
| @@ -3,8 +3,8 @@ | |||||||
| 	tinymce.init({ | 	tinymce.init({ | ||||||
| 		selector : "textarea", | 		selector : "textarea", | ||||||
| 		theme : "modern", | 		theme : "modern", | ||||||
|         plugins: 'print preview searchreplace autolink directionality visualblocks visualchars fullscreen image link media template codesample table charmap hr pagebreak nonbreaking anchor toc insertdatetime advlist lists textcolor wordcount spellchecker imagetools contextmenu colorpicker textpattern help code', |         plugins: 'print preview searchreplace autolink directionality visualblocks visualchars fullscreen image link media template codesample table charmap hr pagebreak nonbreaking anchor toc insertdatetime advlist lists textcolor wordcount spellchecker imagetools contextmenu colorpicker textpattern help code emoticons', | ||||||
|         toolbar1: 'formatselect | bold italic strikethrough forecolor backcolor | link | alignleft aligncenter alignright alignjustify  | numlist bullist outdent indent  | removeformat code', |         toolbar1: 'formatselect | bold italic strikethrough forecolor backcolor | emoticons link | alignleft aligncenter alignright alignjustify  | numlist bullist outdent indent  | removeformat code', | ||||||
| 		image_advtab: true, | 		image_advtab: true, | ||||||
| 		relative_urls : false, | 		relative_urls : false, | ||||||
| 		remove_script_host : false, | 		remove_script_host : false, | ||||||
|   | |||||||
| @@ -19,7 +19,12 @@ | |||||||
| 					</tr> | 					</tr> | ||||||
| 					<tr> | 					<tr> | ||||||
| 						<td>PHP:</td> | 						<td>PHP:</td> | ||||||
| 						<td><input type="checkbox" id="php" name="php" title="Check if page should be executed as PHP" value="1"{% if php %} checked="true"{% endif %}{% if action == 'edit' %} disabled{% endif %}/></td> | 						<td> | ||||||
|  | 							<input type="checkbox" id="php" name="php" title="Check if page should be executed as PHP" value="1"{% if php %} checked="true"{% endif %}{% if action == 'edit' %} disabled{% endif %}/> | ||||||
|  | 							{% if action == 'edit' %} | ||||||
|  | 								<input type="hidden" name="php" value="{% if php %}1{% else %}0{% endif %}"/> | ||||||
|  | 							{% endif %} | ||||||
|  | 						</td> | ||||||
| 					</tr> | 					</tr> | ||||||
| 					<tr> | 					<tr> | ||||||
| 						<td>Content:</td> | 						<td>Content:</td> | ||||||
| @@ -74,8 +79,8 @@ | |||||||
| 			tinymce.init({ | 			tinymce.init({ | ||||||
| 				selector : "#body", | 				selector : "#body", | ||||||
| 				theme : "modern", | 				theme : "modern", | ||||||
| 				plugins: 'code print preview searchreplace autolink directionality visualblocks visualchars fullscreen image link media template codesample table charmap hr pagebreak nonbreaking anchor toc insertdatetime advlist lists textcolor wordcount spellchecker imagetools contextmenu colorpicker textpattern help', | 				plugins: 'code print preview searchreplace autolink directionality visualblocks visualchars fullscreen image link media template codesample table charmap hr pagebreak nonbreaking anchor toc insertdatetime advlist lists textcolor wordcount spellchecker imagetools contextmenu colorpicker textpattern help emoticons', | ||||||
| 				toolbar1: 'formatselect | bold italic strikethrough forecolor backcolor | link | alignleft aligncenter alignright alignjustify  | numlist bullist outdent indent  | removeformat code', | 				toolbar1: 'formatselect | bold italic strikethrough forecolor backcolor | emoticons link | alignleft aligncenter alignright alignjustify  | numlist bullist outdent indent  | removeformat code', | ||||||
| 				image_advtab: true, | 				image_advtab: true, | ||||||
| 				relative_urls : false, | 				relative_urls : false, | ||||||
| 				remove_script_host : false, | 				remove_script_host : false, | ||||||
|   | |||||||
| @@ -23,7 +23,7 @@ | |||||||
| 		{% endfor %} | 		{% endfor %} | ||||||
| 	{% else %} | 	{% else %} | ||||||
| 	<tr> | 	<tr> | ||||||
| 		<td bgcolor="{{ config.lightborder }}">There are no change logs for the moment.</td> | 		<td colspan="4" bgcolor="{{ config.darkborder }}">There are no changelogs for the moment.</td> | ||||||
| 	</tr> | 	</tr> | ||||||
| 	{% endif %} | 	{% endif %} | ||||||
| 	 | 	 | ||||||
|   | |||||||
| @@ -256,10 +256,11 @@ | |||||||
| 			</tr> | 			</tr> | ||||||
| 			{% set i = 0 %} | 			{% set i = 0 %} | ||||||
| 			{% for frag in frags %} | 			{% for frag in frags %} | ||||||
| 			<tr bgcolor="'{{ getStyle(i) }}"> | 			<tr bgcolor="{{ getStyle(i) }}"> | ||||||
| 				<td width="20%" align="center">{{ frag.time|date("j M Y, H:i") }}</td> | 				<td width="20%" align="center">{{ frag.time|date("j M Y, H:i") }}</td> | ||||||
| 				<td>{{ frag.description|raw }}({% if frag.unjustified %}<font size="1" color="red">Unjustified</font>{% else %}<font size="1" color="green">Justified</font>{% endif %})</td> | 				<td>{{ frag.description|raw }}({% if frag.unjustified %}<font size="1" color="red">Unjustified</font>{% else %}<font size="1" color="green">Justified</font>{% endif %})</td> | ||||||
| 			</tr> | 			</tr> | ||||||
|  | 			{% set i = i + 1 %} | ||||||
| 			{% endfor %} | 			{% endfor %} | ||||||
| 		</table> | 		</table> | ||||||
| 		<!-- FRAGS_END --> | 		<!-- FRAGS_END --> | ||||||
| @@ -380,12 +381,8 @@ | |||||||
| 				<td> | 				<td> | ||||||
| 					<nobr>{{ i }}. {{ player.getName() }}{% if player.isDeleted() %}<font color="red"> [DELETED]</font>{% endif %}</nobr> | 					<nobr>{{ i }}. {{ player.getName() }}{% if player.isDeleted() %}<font color="red"> [DELETED]</font>{% endif %}</nobr> | ||||||
| 				</td> | 				</td> | ||||||
| 				{% set vocation = 'Unknown' %} |  | ||||||
| 				{% if config.vocations[player.getVocation()] is defined %} |  | ||||||
| 					{% set vocation = config.vocations[player.getVocation()] %} |  | ||||||
| 				{% endif %} |  | ||||||
|  |  | ||||||
| 				<td>{{ player.getLevel() }} {{ vocation }}</td> | 				<td>{{ player.getLevel() }} {{ player.getVocationName() }}</td> | ||||||
| 				<td>{% if player.isOnline() %}<b><font color="green">Online</font></b>{% endif %}</td> | 				<td>{% if player.isOnline() %}<b><font color="green">Online</font></b>{% endif %}</td> | ||||||
| 				<td> | 				<td> | ||||||
| 					<table border="0" cellspacing="0" cellpadding="0"> | 					<table border="0" cellspacing="0" cellpadding="0"> | ||||||
|   | |||||||
| @@ -17,9 +17,9 @@ | |||||||
| 		{% set i = i + 1 %} | 		{% set i = i + 1 %} | ||||||
| 	<tr bgcolor="{{ getStyle(i) }}"> | 	<tr bgcolor="{{ getStyle(i) }}"> | ||||||
| 		<td colspan="2" style="cursor: pointer;" onclick="toggleVisibility('faq_{{ i }}'); return false;"> | 		<td colspan="2" style="cursor: pointer;" onclick="toggleVisibility('faq_{{ i }}'); return false;"> | ||||||
| 			<b>{{ faq.question }}</b> | 			<b>{{ faq.question|raw }}</b> | ||||||
|  |  | ||||||
| 			<div id="faq_{{ i }}" style="display: none;">{{ faq.answer }}</div> | 			<div id="faq_{{ i }}" style="display: none;">{{ faq.answer|raw }}</div> | ||||||
| 		</td> | 		</td> | ||||||
| 		{% if canEdit %} | 		{% if canEdit %} | ||||||
| 			<td> | 			<td> | ||||||
|   | |||||||
| @@ -22,21 +22,27 @@ | |||||||
| 		</tr> | 		</tr> | ||||||
| 		<tr bgcolor="{{ config.lightborder }}"> | 		<tr bgcolor="{{ config.lightborder }}"> | ||||||
| 			<td><b>Topic:</b></td> | 			<td><b>Topic:</b></td> | ||||||
| 			<td><input type="text" value="{{ topic|raw }}" name="topic" size="40" maxlength="60" /> (Optional)</td> | 			<td><input type="text" value="{{ post_topic|raw }}" name="topic" size="40" maxlength="60" /> (Optional)</td> | ||||||
| 		</tr> | 		</tr> | ||||||
| 		<tr bgcolor="{{ config.darkborder }}"> | 		<tr bgcolor="{{ config.darkborder }}"> | ||||||
| 			<td valign="top"><b>Message:</b><font size="1"><br/>You can use:<br/>[player]Nick[/player]<br />[url]http://address.com/[/url]<br />[img]http://images.com/images3.gif[/img]<br />[code]Code[/code]<br />[b]<b>Text</b>[/b]<br />[i]<i>Text</i>[/i]<br/>[u]<u>Text</u>[/u]<br />and smileys:<br />;) , :) , :D , :( , :rolleyes:<br />:cool: , :eek: , :o , :p</font> | 			<td valign="top"><b>Message:</b><font size="1"><br/>You can use:<br/>[player]Nick[/player]<br />[url]http://address.com/[/url]<br />[img]http://images.com/images3.gif[/img]<br />[code]Code[/code]<br />[b]<b>Text</b>[/b]<br />[i]<i>Text</i>[/i]<br/>[u]<u>Text</u>[/u]<br />and smileys:<br />;) , :) , :D , :( , :rolleyes:<br />:cool: , :eek: , :o , :p</font> | ||||||
| 			</td> | 			</td> | ||||||
| 			<td> | 			<td> | ||||||
| 				<textarea rows="10" cols="60" name="text">{{ text|raw }}</textarea><br />(Max. 15,000 letters) | 				<textarea rows="10" cols="60" name="text">{{ post_text|raw }}</textarea><br />(Max. 15,000 letters) | ||||||
| 			</td> | 			</td> | ||||||
| 		</tr> | 		</tr> | ||||||
| 		<tr bgcolor="{{ config.lightborder }}"> | 		<tr bgcolor="{{ config.lightborder }}"> | ||||||
| 			<td valign="top">Options:</td> | 			<td valign="top">Options:</td> | ||||||
| 			<td> | 			<td> | ||||||
| 				<label> | 				<label> | ||||||
| 					<input type="checkbox" name="smile" value="1"{% if smile == 1 %} checked="checked"{% endif %}/>Disable Smileys in This Post | 					<input type="checkbox" name="smile" value="1"{% if post_smile %} checked="checked"{% endif %}/>Disable Smileys in This Post | ||||||
| 				</label> | 				</label> | ||||||
|  | 				{% if canEdit %} | ||||||
|  | 					<br/> | ||||||
|  | 					<label> | ||||||
|  | 						<input type="checkbox" name="html" value="1"{% if post_html %} checked="checked"{% endif %}/>Enable HTML in this post (moderator only) | ||||||
|  | 					</label> | ||||||
|  | 				{% endif %} | ||||||
| 			</td> | 			</td> | ||||||
| 		</tr> | 		</tr> | ||||||
| 	</table> | 	</table> | ||||||
|   | |||||||
| @@ -28,7 +28,17 @@ | |||||||
| 		</tr> | 		</tr> | ||||||
| 		<tr bgcolor="{{ config.lightborder }}"> | 		<tr bgcolor="{{ config.lightborder }}"> | ||||||
| 			<td valign="top">Options:</td> | 			<td valign="top">Options:</td> | ||||||
| 			<td><label><input type="checkbox" name="smile" value="1"{% if post_smile == 1 %} checked="checked"{% endif %}/>Disable Smileys in This Post </label></td> | 			<td> | ||||||
|  | 				<label> | ||||||
|  | 					<input type="checkbox" name="smile" value="1"{% if post_smile %} checked="checked"{% endif %}/>Disable Smileys in This Post | ||||||
|  | 				</label> | ||||||
|  | 				{% if canEdit %} | ||||||
|  | 					<br/> | ||||||
|  | 					<label> | ||||||
|  | 						<input type="checkbox" name="html" value="1"{% if post_html %} checked="checked"{% endif %}/>Enable HTML in this post (moderator only) | ||||||
|  | 					</label> | ||||||
|  | 				{% endif %} | ||||||
|  | 			</td> | ||||||
| 		</tr> | 		</tr> | ||||||
| 	</table> | 	</table> | ||||||
| 	<center> | 	<center> | ||||||
|   | |||||||
| @@ -25,11 +25,21 @@ | |||||||
| 		</tr> | 		</tr> | ||||||
| 		<tr bgcolor="{{ config.darkborder }}"> | 		<tr bgcolor="{{ config.darkborder }}"> | ||||||
| 			<td valign="top"><b>Message:</b><font size="1"><br />You can use:<br />[player]Nick[/player]<br />[url]http://address.com/[/url]<br />[img]http://images.com/images3.gif[/img]<br />[code]Code[/code]<br />[b]<b>Text</b>[/b]<br />[i]<i>Text</i>[/i]<br />[u]<u>Text</u>[/u]<br />and smileys:<br />;) , :) , :D , :( , :rolleyes:<br />:cool: , :eek: , :o , :p</font></td> | 			<td valign="top"><b>Message:</b><font size="1"><br />You can use:<br />[player]Nick[/player]<br />[url]http://address.com/[/url]<br />[img]http://images.com/images3.gif[/img]<br />[code]Code[/code]<br />[b]<b>Text</b>[/b]<br />[i]<i>Text</i>[/i]<br />[u]<u>Text</u>[/u]<br />and smileys:<br />;) , :) , :D , :( , :rolleyes:<br />:cool: , :eek: , :o , :p</font></td> | ||||||
| 			<td><textarea rows="10" cols="60" name="text">{{ text|escape }}</textarea><br />(Max. 15,000 letters)</td> | 			<td><textarea rows="10" cols="60" name="text">{{ post_text|escape }}</textarea><br />(Max. 15,000 letters)</td> | ||||||
| 		</tr> | 		</tr> | ||||||
| 		<tr bgcolor="{{ config.lightborder }}"> | 		<tr bgcolor="{{ config.lightborder }}"> | ||||||
| 			<td valign="top">Options:</td> | 			<td valign="top">Options:</td> | ||||||
| 			<td><label><input type="checkbox" name="smile" value="1"{% if smiles_enabled %} checked="checked"{% endif %}/>Disable Smileys in This Post </label></td> | 			<td> | ||||||
|  | 				<label> | ||||||
|  | 					<input type="checkbox" name="smile" value="1"{% if post_smile %} checked="checked"{% endif %}/>Disable Smileys in This Post | ||||||
|  | 				</label> | ||||||
|  | 				{% if canEdit %} | ||||||
|  | 				<br/> | ||||||
|  | 				<label> | ||||||
|  | 					<input type="checkbox" name="html" value="1"{% if post_html %} checked="checked"{% endif %}/>Enable HTML in this post (moderator only) | ||||||
|  | 				</label> | ||||||
|  | 			{% endif %} | ||||||
|  | 			</td> | ||||||
| 		</tr> | 		</tr> | ||||||
| 	</table> | 	</table> | ||||||
| 	<center> | 	<center> | ||||||
|   | |||||||
| @@ -1,17 +1,7 @@ | |||||||
| <script type="text/javascript" src="{{ constant('BASE_URL') }}tools/tinymce/tinymce.min.js"></script> |  | ||||||
| <script type="text/javascript"> |  | ||||||
| 	tinymce.init({ |  | ||||||
| 		selector : "#body", |  | ||||||
| 		theme : "modern", |  | ||||||
| 		plugins: 'print preview searchreplace autolink directionality visualblocks visualchars fullscreen image link media template codesample table charmap hr pagebreak nonbreaking anchor toc insertdatetime advlist lists textcolor wordcount spellchecker imagetools contextmenu colorpicker textpattern help code', |  | ||||||
| 		toolbar1: 'formatselect | bold italic strikethrough forecolor backcolor | link | alignleft aligncenter alignright alignjustify  | numlist bullist outdent indent  | removeformat code', |  | ||||||
| 		image_advtab: true |  | ||||||
| 	}); |  | ||||||
| </script> |  | ||||||
| {% if action != 'edit' %} | {% if action != 'edit' %} | ||||||
| <a id="news-button" href="#">Add news</a> | <a id="news-button" href="#">Add news</a> | ||||||
| {% endif %} | {% endif %} | ||||||
| <form method="post" action="{{ news_link_form }}"> | <form method="post" action="{{ news_link_form }}" id="news-edit-form"> | ||||||
| 	{% if action == 'edit' %} | 	{% if action == 'edit' %} | ||||||
| 	<input type="hidden" name="id" value="{{ news_id }}" /> | 	<input type="hidden" name="id" value="{{ news_id }}" /> | ||||||
| 	{% endif %} | 	{% endif %} | ||||||
| @@ -47,7 +37,7 @@ | |||||||
| 		</tr> | 		</tr> | ||||||
|  |  | ||||||
| 		{% set rows = rows + 1 %} | 		{% set rows = rows + 1 %} | ||||||
| 		<tr id="article-text" bgcolor="{{ getStyle(rows) }}"{% if article_text is empty %} style="display: none;"{% endif %}> | 		<tr id="article-text" bgcolor="{{ getStyle(rows) }}"{% if type is not defined or type != constant('ARTICLE') %} style="display: none;"{% endif %}> | ||||||
| 			<td><b>Article short text:<br/>This will be displayed on news page.<br/>Rest will be available on "read more" page.</b></td> | 			<td><b>Article short text:<br/>This will be displayed on news page.<br/>Rest will be available on "read more" page.</b></td> | ||||||
| 			<td> | 			<td> | ||||||
| 				<textarea name="article_text">{% if article_text is not empty %}{{ article_text }}{% endif %}</textarea> | 				<textarea name="article_text">{% if article_text is not empty %}{{ article_text }}{% endif %}</textarea> | ||||||
| @@ -55,7 +45,7 @@ | |||||||
| 		</tr> | 		</tr> | ||||||
|  |  | ||||||
| 		{% set rows = rows + 1 %} | 		{% set rows = rows + 1 %} | ||||||
| 		<tr id="article-image" bgcolor="{{ getStyle(rows) }}"{% if article_image is empty %} style="display: none;"{% endif %}> | 		<tr id="article-image" bgcolor="{{ getStyle(rows) }}"{% if type is not defined or type != constant('ARTICLE') %} style="display: none;"{% endif %}> | ||||||
| 			<td><b>Article image:</b></td> | 			<td><b>Article image:</b></td> | ||||||
| 			<td> | 			<td> | ||||||
| 				<input type="text" name="article_image" value="{% if article_image is not empty %}{{ article_image }}{% else %}images/news/announcement.jpg{% endif %}" /> | 				<input type="text" name="article_image" value="{% if article_image is not empty %}{{ article_image }}{% else %}images/news/announcement.jpg{% endif %}" /> | ||||||
| @@ -121,7 +111,7 @@ | |||||||
| 				<input type="submit" value="Submit"/> | 				<input type="submit" value="Submit"/> | ||||||
| 			</td> | 			</td> | ||||||
| 			<td align="left"> | 			<td align="left"> | ||||||
| 				<input type="button" onclick="window.location = '{{ news_link }}';" value="Cancel"/> | 				<input id="cancel" type="button" value="Cancel"/> | ||||||
| 			</td> | 			</td> | ||||||
| 		</tr> | 		</tr> | ||||||
| 	</table> | 	</table> | ||||||
| @@ -151,3 +141,48 @@ | |||||||
| 	}); | 	}); | ||||||
| </script> | </script> | ||||||
| {% endif %} | {% endif %} | ||||||
|  | <script type="text/javascript" src="{{ constant('BASE_URL') }}tools/tinymce/tinymce.min.js"></script> | ||||||
|  | <script type="text/javascript"> | ||||||
|  | 	var unsaved = false; | ||||||
|  | 	var lastContent = ''; | ||||||
|  |  | ||||||
|  | 	tinymce.init({ | ||||||
|  | 		selector : "#body", | ||||||
|  | 		theme : "modern", | ||||||
|  | 		plugins: 'print preview searchreplace autolink directionality visualblocks visualchars fullscreen image link media template codesample table charmap hr pagebreak nonbreaking anchor toc insertdatetime advlist lists textcolor wordcount spellchecker imagetools contextmenu colorpicker textpattern help code emoticons', | ||||||
|  | 		toolbar1: 'formatselect | bold italic strikethrough forecolor backcolor | emoticons link | alignleft aligncenter alignright alignjustify  | numlist bullist outdent indent  | removeformat code', | ||||||
|  | 		image_advtab: true, | ||||||
|  | 		setup: function(ed){ | ||||||
|  | 			ed.on('NodeChange', function(e) { | ||||||
|  | 				if(ed.getContent() != lastContent) { | ||||||
|  | 					unsaved = true; | ||||||
|  | 				} | ||||||
|  | 			}); | ||||||
|  | 		} | ||||||
|  | 	}); | ||||||
|  |  | ||||||
|  | 	$(document).ready(function() { | ||||||
|  | 		$(":input").change(function(){ //trigers change in all input fields including text type | ||||||
|  | 			unsaved = true; | ||||||
|  | 		}); | ||||||
|  | 		 | ||||||
|  | 		$("#cancel").click(function( event ) { | ||||||
|  | 			unsaved = false; | ||||||
|  | 			window.location = '{{ news_link }}'; | ||||||
|  | 		}); | ||||||
|  |  | ||||||
|  | 		$("#news-edit-form").submit(function( event ) { | ||||||
|  | 			unsaved = false; | ||||||
|  | 		}); | ||||||
|  |  | ||||||
|  | 		lastContent = $("#body").val(); | ||||||
|  | 	}); | ||||||
|  | 	 | ||||||
|  | 	function unloadPage(){  | ||||||
|  | 		if(unsaved){ | ||||||
|  | 			return "You have unsaved changes on this page. Do you want to leave this page and discard your changes or stay on this page?"; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	window.onbeforeunload = unloadPage; | ||||||
|  | </script> | ||||||
| @@ -3,7 +3,7 @@ | |||||||
| 		<td class="white"><b>Server Status</b></td> | 		<td class="white"><b>Server Status</b></td> | ||||||
| 	</tr> | 	</tr> | ||||||
| {% if players|length == 0 %} | {% if players|length == 0 %} | ||||||
| 	<tr bgcolor="{{ config.darkborder }}"><td>Currently no one is playing on {{ config.lua.serverName }}.</td></tr></table> | 	<tr bgcolor="{{ config.darkborder }}"><td>Currently no one is playing on {{ config.lua.serverName }}.</td></tr></table> | ||||||
| {% else %} | {% else %} | ||||||
| 	<tr bgcolor="{{ config.darkborder }}"> | 	<tr bgcolor="{{ config.darkborder }}"> | ||||||
| 		<td> | 		<td> | ||||||
| @@ -14,7 +14,7 @@ | |||||||
| 					{% set players_count = players|length %} | 					{% set players_count = players|length %} | ||||||
| 					{% set afk = players_count - status.players %} | 					{% set afk = players_count - status.players %} | ||||||
| 					{% if afk < 0 %} | 					{% if afk < 0 %} | ||||||
| 						{% set players = players + afk|abs %} | 						{% set players_count = players_count + afk|abs %} | ||||||
| 						{% set afk = 0 %} | 						{% set afk = 0 %} | ||||||
| 					{% endif %} | 					{% endif %} | ||||||
| 					Currently there are <b>{{ status.players }}</b> active and <b>{{ afk }}</b> AFK players.<br/> | 					Currently there are <b>{{ status.players }}</b> active and <b>{{ afk }}</b> AFK players.<br/> | ||||||
| @@ -26,6 +26,7 @@ | |||||||
| 		</td> | 		</td> | ||||||
| 	</tr> | 	</tr> | ||||||
| </table> | </table> | ||||||
|  | <br/> | ||||||
| 	{# vocation statistics #} | 	{# vocation statistics #} | ||||||
| 	{% if config.online_vocations %} | 	{% if config.online_vocations %} | ||||||
| <br/> | <br/> | ||||||
| @@ -101,7 +102,7 @@ | |||||||
| 			<td>{{ player.country_image|raw }}</td> | 			<td>{{ player.country_image|raw }}</td> | ||||||
| 		{% endif %} | 		{% endif %} | ||||||
| 		{% if config.online_outfit %} | 		{% if config.online_outfit %} | ||||||
| 			<td width="5%"><img style="position:absolute;margin-top:{% if player.looktype in  [75, 266, 302] %}-20px;margin-left:-0px;{% else %}-45px;margin-left:-25px;{%  endif %}" src="{{ player.outfit }}" alt="player outfit"/></td> | 			<td width="5%"><img style="position:absolute;margin-top:{% if player.player.looktype in [75, 266, 302] %}-20px;margin-left:-0px;{% else %}-45px;margin-left:-25px;{%  endif %}" src="{{ player.outfit }}" alt="player outfit"/></td> | ||||||
| 		{% endif %} | 		{% endif %} | ||||||
| 			<td>{{ player.name|raw }}{{ player.skull }}</td> | 			<td>{{ player.name|raw }}{{ player.skull }}</td> | ||||||
| 			<td>{{ player.level }}</td> | 			<td>{{ player.level }}</td> | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								templates/kathrine/images/background.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 145 KiB | 
| Before Width: | Height: | Size: 1.0 MiB | 
| Before Width: | Height: | Size: 351 KiB | 
| Before Width: | Height: | Size: 1.1 KiB | 
| Before Width: | Height: | Size: 7.8 KiB | 
| Before Width: | Height: | Size: 15 KiB | 
| Before Width: | Height: | Size: 1.5 KiB | 
| Before Width: | Height: | Size: 1.5 KiB | 
| Before Width: | Height: | Size: 1.4 KiB | 
| Before Width: | Height: | Size: 1.4 KiB | 
| Before Width: | Height: | Size: 1.2 KiB | 
| Before Width: | Height: | Size: 2.3 KiB | 
| Before Width: | Height: | Size: 3.5 KiB | 
| Before Width: | Height: | Size: 50 B | 
| Before Width: | Height: | Size: 297 B | 
| Before Width: | Height: | Size: 58 B | 
| Before Width: | Height: | Size: 594 B | 
| Before Width: | Height: | Size: 424 B | 
| Before Width: | Height: | Size: 394 B | 
| Before Width: | Height: | Size: 312 B | 
| Before Width: | Height: | Size: 1.2 KiB | 
| Before Width: | Height: | Size: 371 B | 
| Before Width: | Height: | Size: 603 B | 
| Before Width: | Height: | Size: 600 B | 
| Before Width: | Height: | Size: 571 B | 
| Before Width: | Height: | Size: 584 B |