Merge branch 'master' of github.com:shish/shimmie2
64
.gitignore
vendored
|
@ -3,67 +3,3 @@ data
|
|||
images
|
||||
thumbs
|
||||
!lib/images
|
||||
ext/admin
|
||||
ext/amazon_s3
|
||||
ext/artists
|
||||
ext/autocomplete
|
||||
ext/ban_words
|
||||
ext/blocks
|
||||
ext/blotter
|
||||
ext/bookmarks
|
||||
ext/browser_search
|
||||
ext/bulk_add
|
||||
ext/danbooru_api
|
||||
ext/downtime
|
||||
ext/emoticons
|
||||
ext/et
|
||||
ext/event_log
|
||||
ext/favorites
|
||||
ext/featured
|
||||
ext/forum
|
||||
ext/handle_archive
|
||||
ext/handle_flash
|
||||
ext/handle_ico
|
||||
ext/handle_mp3
|
||||
ext/handle_svg
|
||||
ext/holiday
|
||||
ext/home
|
||||
ext/image_hash_ban
|
||||
ext/ipban
|
||||
ext/link_image
|
||||
ext/log_db
|
||||
ext/log_net
|
||||
ext/mass_tagger
|
||||
ext/news
|
||||
ext/notes
|
||||
ext/not_a_tag
|
||||
ext/numeric_score
|
||||
ext/oekaki
|
||||
ext/piclens
|
||||
ext/pm
|
||||
ext/pools
|
||||
ext/qr_code
|
||||
ext/random_image
|
||||
ext/rating
|
||||
ext/regen_thumb
|
||||
ext/report_image
|
||||
ext/resize
|
||||
ext/res_limit
|
||||
ext/rss_comments
|
||||
ext/rss_images
|
||||
ext/shimmie_api
|
||||
ext/simpletest
|
||||
ext/site_description
|
||||
ext/sitemap
|
||||
ext/svn_update
|
||||
ext/tagger
|
||||
ext/tag_editcloud
|
||||
ext/tag_history
|
||||
ext/text_score
|
||||
ext/tips
|
||||
ext/twitter_soc
|
||||
ext/upload_cmd
|
||||
ext/update
|
||||
ext/wiki
|
||||
ext/word_filter
|
||||
ext/zoom
|
||||
|
|
21
README.txt
|
@ -42,17 +42,16 @@ Installation
|
|||
|
||||
Upgrade from 2.3.X
|
||||
~~~~~~~~~~~~~~~~~~
|
||||
config.php has been moved from /config.php to /data/config/shimmie.conf.php
|
||||
|
||||
The database connection setting in config.php has changed; now using
|
||||
PDO DSN format rather than ADODB URI:
|
||||
- Backup your current files and database!
|
||||
- Unzip into a clean folder
|
||||
- Copy across the images, thumbs, and data folders
|
||||
- Move old/config.php to new/data/config/shimmie.conf.php
|
||||
- Edit shimmie.conf.php to use the new database connection format:
|
||||
|
||||
OLD: $database_dsn = "<proto>://<username>:<password>@<host>/<database>";
|
||||
NEW: define("DATABASE_DSN", "<proto>:user=<username>;password=<password>;host=<host>;dbname=<database>");
|
||||
|
||||
The rest should be automatic, just unzip into a clean folder and copy across
|
||||
config.php, images and thumbs folders from the old version. This
|
||||
includes automatically messing with the database -- back it up first!
|
||||
The rest should be automatic~
|
||||
|
||||
If there are any errors with the upgrade process, "in_upgrade=true" will
|
||||
be left in the config table and the process will be paused for the admin
|
||||
|
@ -70,10 +69,10 @@ enough to be a pain.
|
|||
|
||||
Custom Configuration
|
||||
~~~~~~~~~~~~~~~~~~~~
|
||||
Various aspects of Shimmie can be configured to suit your site specific
|
||||
needs via the file "config.php" (created after installation).
|
||||
Take a look at "core/default_config.inc.php" for the available options
|
||||
that can used.
|
||||
Various aspects of Shimmie can be configured to suit your site specific needs
|
||||
via the file "data/config/shimmie.conf.php" (created after installation).
|
||||
Take a look at "core/sys_config.inc.php" for the available options that can
|
||||
be used.
|
||||
|
||||
|
||||
Custom User Classes
|
||||
|
|
|
@ -349,7 +349,7 @@ class Database {
|
|||
return $stmt;
|
||||
}
|
||||
catch(PDOException $pdoe) {
|
||||
throw new SCoreException($pdoe->getMessage()."<p>Query: ".$query);
|
||||
throw new SCoreException($pdoe->getMessage()."<p><b>Query:</b> ".$query);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -1,6 +1,14 @@
|
|||
<?php
|
||||
/*
|
||||
* First, load the user-specified settings
|
||||
*/
|
||||
@include_once "data/config/shimmie.conf.php";
|
||||
@include_once "data/config/extensions.conf.php";
|
||||
|
||||
|
||||
/**
|
||||
* These are the default configuration options for Shimmie.
|
||||
* For any values that aren't defined in the above files, Shimmie
|
||||
* will set the values to their defaults
|
||||
*
|
||||
* All of these can be over-ridden by placing a 'define' in data/config/shimmie.conf.php
|
||||
*
|
||||
|
@ -10,7 +18,6 @@
|
|||
* define("SPEED_HAX", true);
|
||||
*
|
||||
*/
|
||||
|
||||
function _d($name, $value) {if(!defined($name)) define($name, $value);}
|
||||
_d("DATABASE_DSN", null); // string PDO database connection details
|
||||
_d("CACHE_DSN", null); // string cache connection details
|
||||
|
@ -27,6 +34,15 @@ _d("COMPILE_ELS", false); // boolean pre-build the list of event listeners
|
|||
_d("NICE_URLS", false); // boolean force niceurl mode
|
||||
_d("WH_SPLITS", 1); // int how many levels of subfolders to put in the warehouse
|
||||
_d("VERSION", 'trunk'); // string shimmie version
|
||||
_d("SCORE_VERSION", 's2hack/'.VERSION); // string SCore version
|
||||
_d("TIMEZONE", null); // string timezone
|
||||
_d("CORE_EXTS", "bbcode,user,mail,upload,image,view,handle_pixel,ext_manager,setup,upgrade,handle_404,comment,tag_list,index,tag_edit,alias_editor"); // extensions to always enable
|
||||
_d("EXTRA_EXTS", ""); // optional extra extensions
|
||||
|
||||
|
||||
/*
|
||||
* Calculated settings - you should never need to change these
|
||||
* directly, only the things they're built from
|
||||
*/
|
||||
_d("SCORE_VERSION", 's2hack/'.VERSION); // string SCore version
|
||||
_d("ENABLED_EXTS", CORE_EXTS.",".EXTRA_EXTS);
|
||||
?>
|
|
@ -30,7 +30,17 @@ class UserClass {
|
|||
return $this->parent->can($ability);
|
||||
}
|
||||
else {
|
||||
die("Unknown ability: ".html_escape($ability));
|
||||
global $_user_classes;
|
||||
$min_dist = 9999;
|
||||
$min_ability = null;
|
||||
foreach($_user_classes['base']->abilities as $a => $cando) {
|
||||
$v = levenshtein($ability, $a);
|
||||
if($v < $min_dist) {
|
||||
$min_dist = $v;
|
||||
$min_ability = $a;
|
||||
}
|
||||
}
|
||||
throw new SCoreException("Unknown ability '".html_escape($ability)."'. Did the developer mean '".html_escape($min_ability)."'?");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -52,6 +62,7 @@ new UserClass("base", null, array(
|
|||
|
||||
"edit_user_password" => False,
|
||||
"edit_user_info" => False, # email address, etc
|
||||
"edit_user_class" => False,
|
||||
"delete_user" => False,
|
||||
|
||||
"create_comment" => False,
|
||||
|
@ -64,6 +75,7 @@ new UserClass("base", null, array(
|
|||
"edit_image_owner" => False,
|
||||
"edit_image_lock" => False,
|
||||
"bulk_edit_image_tag" => False,
|
||||
"bulk_edit_image_source" => False,
|
||||
"delete_image" => False,
|
||||
|
||||
"ban_image" => False,
|
||||
|
@ -85,6 +97,7 @@ new UserClass("base", null, array(
|
|||
"edit_feature" => False,
|
||||
"bulk_edit_vote" => False,
|
||||
"edit_other_vote" => False,
|
||||
"view_sysinfo" => False,
|
||||
|
||||
"protected" => False, # only admins can modify protected users (stops a moderator changing an admin's password)
|
||||
));
|
||||
|
@ -110,6 +123,7 @@ new UserClass("admin", "base", array(
|
|||
"ban_ip" => True,
|
||||
"edit_user_password" => True,
|
||||
"edit_user_info" => True,
|
||||
"edit_user_class" => True,
|
||||
"delete_user" => True,
|
||||
"create_image" => True,
|
||||
"delete_image" => True,
|
||||
|
@ -123,6 +137,7 @@ new UserClass("admin", "base", array(
|
|||
"edit_image_source" => True,
|
||||
"edit_image_owner" => True,
|
||||
"bulk_edit_image_tag" => True,
|
||||
"bulk_edit_image_source" => True,
|
||||
"mass_tag_edit" => True,
|
||||
"create_image_report" => True,
|
||||
"view_image_report" => True,
|
||||
|
@ -136,6 +151,7 @@ new UserClass("admin", "base", array(
|
|||
"edit_feature" => True,
|
||||
"bulk_edit_vote" => True,
|
||||
"edit_other_vote" => True,
|
||||
"view_sysinfo" => True,
|
||||
"protected" => True,
|
||||
));
|
||||
|
||||
|
|
|
@ -1006,29 +1006,14 @@ function _sanitise_environment() {
|
|||
}
|
||||
|
||||
function _get_themelet_files($_theme) {
|
||||
$themelets = array();
|
||||
if(file_exists('themes/'.$_theme.'/custompage.class.php')) $base_themelets[] = 'themes/'.$_theme.'/custompage.class.php';
|
||||
$base_themelets[] = 'themes/'.$_theme.'/layout.class.php';
|
||||
$base_themelets[] = 'themes/'.$_theme.'/themelet.class.php';
|
||||
|
||||
if(file_exists('themes/'.$_theme.'/custompage.class.php')) $themelets[] = 'themes/'.$_theme.'/custompage.class.php';
|
||||
$themelets[] = 'themes/'.$_theme.'/layout.class.php';
|
||||
$themelets[] = 'themes/'.$_theme.'/themelet.class.php';
|
||||
$ext_themelets = glob("ext/{".ENABLED_EXTS."}/theme.php", GLOB_BRACE);
|
||||
$custom_themelets = glob('themes/'.$_theme.'/{'.ENABLED_EXTS.'}.theme.php', GLOB_BRACE);
|
||||
|
||||
$themelet_files = glob("ext/*/theme.php");
|
||||
foreach($themelet_files as $filename) {
|
||||
$themelets[] = $filename;
|
||||
}
|
||||
|
||||
$custom_themelets = glob('themes/'.$_theme.'/*.theme.php');
|
||||
if($custom_themelets) {
|
||||
$m = array();
|
||||
foreach($custom_themelets as $filename) {
|
||||
if(preg_match('/themes\/'.$_theme.'\/(.*)\.theme\.php/',$filename,$m)
|
||||
&& in_array('ext/'.$m[1].'/theme.php', $themelets)) {
|
||||
$themelets[] = $filename;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return $themelets;
|
||||
return array_merge($base_themelets, $ext_themelets, $custom_themelets);
|
||||
}
|
||||
|
||||
function _load_extensions() {
|
||||
|
@ -1094,7 +1079,13 @@ function _load_extensions() {
|
|||
function _fatal_error(Exception $e) {
|
||||
$version = VERSION;
|
||||
$message = $e->getMessage();
|
||||
|
||||
//$trace = var_dump($e->getTrace());
|
||||
|
||||
//$hash = exec("git rev-parse HEAD");
|
||||
//$h_hash = $hash ? "<p><b>Hash:</b> $hash" : "";
|
||||
//'.$h_hash.'
|
||||
|
||||
header("HTTP/1.0 500 Internal Error");
|
||||
echo '
|
||||
<html>
|
||||
|
@ -1103,7 +1094,8 @@ function _fatal_error(Exception $e) {
|
|||
</head>
|
||||
<body>
|
||||
<h1>Internal Error</h1>
|
||||
<p>'.$message.'
|
||||
<p><b>Message:</b> '.$message.'
|
||||
<p><b>Version:</b> '.$version.'
|
||||
</body>
|
||||
</html>
|
||||
';
|
||||
|
|
1728
doxygen.conf
Before Width: | Height: | Size: 170 B After Width: | Height: | Size: 170 B |
Before Width: | Height: | Size: 172 B After Width: | Height: | Size: 172 B |
Before Width: | Height: | Size: 171 B After Width: | Height: | Size: 171 B |
Before Width: | Height: | Size: 172 B After Width: | Height: | Size: 172 B |
Before Width: | Height: | Size: 498 B After Width: | Height: | Size: 498 B |
Before Width: | Height: | Size: 170 B After Width: | Height: | Size: 170 B |
Before Width: | Height: | Size: 236 B After Width: | Height: | Size: 236 B |
Before Width: | Height: | Size: 236 B After Width: | Height: | Size: 236 B |
Before Width: | Height: | Size: 171 B After Width: | Height: | Size: 171 B |
Before Width: | Height: | Size: 176 B After Width: | Height: | Size: 176 B |
Before Width: | Height: | Size: 336 B After Width: | Height: | Size: 336 B |
Before Width: | Height: | Size: 174 B After Width: | Height: | Size: 174 B |
Before Width: | Height: | Size: 349 B After Width: | Height: | Size: 349 B |
Before Width: | Height: | Size: 171 B After Width: | Height: | Size: 171 B |
Before Width: | Height: | Size: 248 B After Width: | Height: | Size: 248 B |
Before Width: | Height: | Size: 176 B After Width: | Height: | Size: 176 B |
Before Width: | Height: | Size: 650 B After Width: | Height: | Size: 650 B |
Before Width: | Height: | Size: 485 B After Width: | Height: | Size: 485 B |
Before Width: | Height: | Size: 171 B After Width: | Height: | Size: 171 B |
Before Width: | Height: | Size: 174 B After Width: | Height: | Size: 174 B |
Before Width: | Height: | Size: 174 B After Width: | Height: | Size: 174 B |
Before Width: | Height: | Size: 238 B After Width: | Height: | Size: 238 B |
Before Width: | Height: | Size: 170 B After Width: | Height: | Size: 170 B |
|
@ -16,7 +16,7 @@ class ET extends Extension {
|
|||
public function onPageRequest(PageRequestEvent $event) {
|
||||
global $user;
|
||||
if($event->page_matches("system_info")) {
|
||||
if($user->is_admin()) {
|
||||
if($user->can("view_sysinfo")) {
|
||||
$this->theme->display_info_page($this->get_info());
|
||||
}
|
||||
}
|
||||
|
@ -24,7 +24,7 @@ class ET extends Extension {
|
|||
|
||||
public function onUserBlockBuilding(UserBlockBuildingEvent $event) {
|
||||
global $user;
|
||||
if($user->is_admin()) {
|
||||
if($user->can("view_sysinfo")) {
|
||||
$event->add_link("System Info", make_link("system_info"));
|
||||
}
|
||||
}
|
|
@ -26,8 +26,8 @@ class ExtensionInfo {
|
|||
$matches = array();
|
||||
$lines = file($main);
|
||||
$number_of_lines = count($lines);
|
||||
preg_match("#(ext|contrib)/(.*)/main.php#", $main, $matches);
|
||||
$this->ext_name = $matches[2];
|
||||
preg_match("#ext/(.*)/main.php#", $main, $matches);
|
||||
$this->ext_name = $matches[1];
|
||||
$this->name = $this->ext_name;
|
||||
$this->enabled = $this->is_enabled($this->ext_name);
|
||||
|
||||
|
@ -81,9 +81,12 @@ class ExtensionInfo {
|
|||
}
|
||||
|
||||
private function is_enabled(/*string*/ $fname) {
|
||||
if(file_exists("ext/$fname") && file_exists("contrib/$fname")) return true; // both
|
||||
if(file_exists("contrib/$fname")) return false; // only disabled (optional)
|
||||
return null; // only active (core)
|
||||
$core = explode(",", CORE_EXTS);
|
||||
$extra = explode(",", EXTRA_EXTS);
|
||||
|
||||
if(in_array($fname, $extra)) return true; // enabled
|
||||
if(in_array($fname, $core)) return null; // core
|
||||
return false; // not enabled
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -93,14 +96,14 @@ class ExtManager extends Extension {
|
|||
if($event->page_matches("ext_manager")) {
|
||||
if($user->can("manage_extension_list")) {
|
||||
if($event->get_arg(0) == "set" && $user->check_auth_token()) {
|
||||
if(is_writable("ext")) {
|
||||
if(is_writable("data/config")) {
|
||||
$this->set_things($_POST);
|
||||
$page->set_mode("redirect");
|
||||
$page->set_redirect(make_link("ext_manager"));
|
||||
}
|
||||
else {
|
||||
$this->theme->display_error(500, "File Operation Failed",
|
||||
"The extension folder isn't writable by the web server :(");
|
||||
"The config file (data/config/extensions.conf.php) isn't writable by the web server :(");
|
||||
}
|
||||
}
|
||||
else {
|
||||
|
@ -118,10 +121,6 @@ class ExtManager extends Extension {
|
|||
$info = new ExtensionInfo("ext/$ext/main.php");
|
||||
$this->theme->display_doc($page, $info);
|
||||
}
|
||||
else if(file_exists("contrib/$ext/main.php")) {
|
||||
$info = new ExtensionInfo("contrib/$ext/main.php");
|
||||
$this->theme->display_doc($page, $info);
|
||||
}
|
||||
else {
|
||||
$this->theme->display_table($page, $this->get_extensions(false), false);
|
||||
}
|
||||
|
@ -142,15 +141,10 @@ class ExtManager extends Extension {
|
|||
private function get_extensions(/*bool*/ $all) {
|
||||
$extensions = array();
|
||||
if($all) {
|
||||
$exts = glob("ext/*/main.php");
|
||||
foreach(glob("contrib/*/main.php") as $ae) {
|
||||
if(!in_array("ext".substr($ae, 7), $exts)) {
|
||||
$exts[] = $ae;
|
||||
}
|
||||
}
|
||||
$exts = glob("ext/*/main.php", GLOB_BRACE);
|
||||
}
|
||||
else {
|
||||
$exts = glob("ext/*/main.php");
|
||||
$exts = glob("ext/{".ENABLED_EXTS."}/main.php", GLOB_BRACE);
|
||||
}
|
||||
foreach($exts as $main) {
|
||||
$extensions[] = new ExtensionInfo($main);
|
||||
|
@ -160,46 +154,24 @@ class ExtManager extends Extension {
|
|||
}
|
||||
|
||||
private function set_things($settings) {
|
||||
foreach(glob("contrib/*/main.php") as $main) {
|
||||
$core = explode(",", CORE_EXTS);
|
||||
|
||||
foreach(glob("ext/*/main.php") as $main) {
|
||||
$matches = array();
|
||||
preg_match("#contrib/(.*)/main.php#", $main, $matches);
|
||||
preg_match("#ext/(.*)/main.php#", $main, $matches);
|
||||
$fname = $matches[1];
|
||||
|
||||
if(!isset($settings["ext_$fname"])) $settings["ext_$fname"] = 0;
|
||||
$this->set_enabled($fname, $settings["ext_$fname"]);
|
||||
if(!in_array($fname, $core) && isset($settings["ext_$fname"])) {
|
||||
$extras[] = $fname;
|
||||
}
|
||||
}
|
||||
|
||||
private function set_enabled(/*string*/ $fname, /*bool*/ $enabled) {
|
||||
if($enabled) {
|
||||
// enable if currently disabled
|
||||
if(!file_exists("ext/$fname")) {
|
||||
if(function_exists("symlink")) {
|
||||
// yes, even though we are in /, and thus the path to contrib is
|
||||
// ./contrib, the link needs to be ../ because it is literal data
|
||||
// which will be interpreted relative to ./ext/ by the OS
|
||||
|
||||
//Because Windows (I know, bad excuse)
|
||||
if (PHP_OS === 'WINNT') {
|
||||
symlink(realpath("./contrib/$fname"), realpath("./ext/").'/'.$fname);
|
||||
}
|
||||
else {
|
||||
symlink("../contrib/$fname", "ext/$fname");
|
||||
}
|
||||
}
|
||||
else {
|
||||
full_copy("contrib/$fname", "ext/$fname");
|
||||
}
|
||||
log_info("ext_manager", "Enabling $fname");
|
||||
}
|
||||
}
|
||||
else {
|
||||
// disable if currently enabled
|
||||
if(file_exists("ext/$fname")) {
|
||||
deltree("ext/$fname");
|
||||
log_info("ext_manager", "Disabling $fname");
|
||||
}
|
||||
}
|
||||
file_put_contents(
|
||||
"data/config/extensions.conf.php",
|
||||
'<'.'?php'."\n".
|
||||
'define("EXTRA_EXTS", "'.implode(",", $extras).'");'."\n".
|
||||
'?'.">"
|
||||
);
|
||||
}
|
||||
}
|
||||
?>
|
||||
|
|
Before Width: | Height: | Size: 7.1 KiB After Width: | Height: | Size: 7.1 KiB |
Before Width: | Height: | Size: 5.6 KiB After Width: | Height: | Size: 5.6 KiB |
Before Width: | Height: | Size: 5.5 KiB After Width: | Height: | Size: 5.5 KiB |
Before Width: | Height: | Size: 1.8 KiB After Width: | Height: | Size: 1.8 KiB |
Before Width: | Height: | Size: 1.7 KiB After Width: | Height: | Size: 1.7 KiB |
Before Width: | Height: | Size: 1.8 KiB After Width: | Height: | Size: 1.8 KiB |