Wiki-Admin-Log
Wiki issue: Error creating thumbnail: Invalid thumbnail parameters
Tony Ford (talk) 18:38, 23 February 2013 (CET)
added in Localsettings.php
$wgMaxImageArea=64000000;
$wgMaxShellMemory = 202400;
$wgUseImageMagick = false;
$wgImageMagickConvertCommand = "/usr/bin/convert";
fix the wiki entry of TiVA (convert latex tags)
Tony Ford (talk) 18:38, 23 February 2013 (CET)
File: includes/EditPage.php
insert after
# These fields need to be checked for encoding.
# Also remove trailing whitespace, but don't remove _initial_
# whitespace from the text boxes. This may be significant formatting.
$this->textbox1 = $this->safeUnicodeInput( $request, 'wpTextbox1' );
this
$this->textbox1=preg_replace('/<math>/','<math>',$this->textbox1);
$this->textbox1=preg_replace('/<\/m>/','</math>',$this->textbox1);
http://www.mediawiki.org/wiki/Extension:Code
Tony Ford (talk) 18:51, 23 February 2013 (CET)
add image files to folder skins/common/images
- http://wiki.opensourceecology.de/File:Button_code_php.png
- http://wiki.opensourceecology.de/File:Button_code_java.png
- http://wiki.opensourceecology.de/File:Button_code_html.png
- http://wiki.opensourceecology.de/File:Button_code_cpp.png
- http://wiki.opensourceecology.de/File:Button_code_asp.png
- http://wiki.opensourceecology.de/File:Button_code_asm.png
- http://wiki.opensourceecology.de/File:Button_code.png
- http://wiki.opensourceecology.de/File:Button_trello.png
File: languages/messages/MessagesDe.php
insert after
'sig_tip' => 'Deine Signatur mit Zeitstempel',
'hr_tip' => 'Horizontale Linie (sparsam verwenden)',
this
'code_tip' => 'Codemarkierung allgemein',
'code_asm_tip' => 'Assembler-Code',
'code_asp_tip' => 'ASP-Code',
'code_cpp_tip' => 'C++-Code',
'code_html_tip' => 'HTML-Code',
'code_php_tip' => 'PHP-Code',
'code_java_tip' => 'Java-Code',
'trello_tip' => 'Trello einbinden',
File: languages/messages/MessagesEn.php
insert after
'button-sig' => 'button_sig.png',
'button-hr' => 'button_hr.png',
this
'button-code' => 'button_code.png',
'button-code-asm' => 'button_code_asm.png',
'button-code-asp' => 'button_code_asp.png',
'button-code-cpp' => 'button_code_cpp.png',
'button-code-html' => 'button_code_html.png',
'button-code-java' => 'button_code_java.png',
'button-code-php' => 'button_code_php.png',
'button-trello' => 'button_trello.png',
insert after
'sig_tip' => 'Your signature with timestamp',
'hr_tip' => 'Horizontal line (use sparingly)',
this
'code_tip' => 'code marking general',
'code_asm_tip' => 'Assembler-Code',
'code_asp_tip' => 'ASP-Code',
'code_cpp_tip' => 'C++-Code',
'code_html_tip' => 'HTML-Code',
'code_php_tip' => 'PHP-Code',
'code_java_tip' => 'Java-Code',
'trello_tip' => 'include Trello',
File: includes/EditPage.php
find
array(
'image' => $wgLang->getImageFile( 'button-hr' ),
'id' => 'mw-editbutton-hr',
'open' => "\n----\n",
'close' => '',
'sample' => '',
'tip' => wfMsg( 'hr_tip' ),
'key' => 'R'
),
add after
array(
'image' => $wgLang->getImageFile( 'button-code' ), # added
'id' => 'mw-code',
'open' => "<"."code>\n",
'close' => "\n</code".">",
'sample' => '',
'tip' => wfMsg( 'code_tip' ),
'key' => 'S'
),
array(
'image' => $wgLang->getImageFile( 'button-code-asm' ), # added
'id' => 'mw-code-asm',
'open' => "<"."source lang=\"asm\">\n",
'close' => "\n</source".">",
'sample' => '',
'tip' => wfMsg( 'code_asm_tip' ),
'key' => ''
),
array(
'image' => $wgLang->getImageFile( 'button-code-asp' ), # added
'id' => 'mw-code-asp',
'open' => "<"."source lang=\"asp\">\n",
'close' => "\n</source".">",
'sample' => '',
'tip' => wfMsg( 'code_asp_tip' ),
'key' => ''
),
array(
'image' => $wgLang->getImageFile( 'button-code-cpp' ), # added
'id' => 'mw-code-cpp',
'open' => "<"."source lang=\"cpp\">\n",
'close' => "\n</source".">",
'sample' => '',
'tip' => wfMsg( 'code_cpp_tip' ),
'key' => ''
),
array(
'image' => $wgLang->getImageFile( 'button-code-html' ), # added
'id' => 'mw-code-html',
'open' => "<"."source lang=\"html4strict\">\n",
'close' => "\n</source".">",
'sample' => '',
'tip' => wfMsg( 'code_html_tip' ),
'key' => ''
),
array(
'image' => $wgLang->getImageFile( 'button-code-php' ), # added
'id' => 'mw-code-php',
'open' => "<"."source lang=\"php\">\n",
'close' => "\n</source".">",
'sample' => '',
'tip' => wfMsg( 'code_php_tip' ),
'key' => ''
),
array(
'image' => $wgLang->getImageFile( 'button-code-java' ), # added
'id' => 'mw-code-java',
'open' => "<"."source lang=\"java\">\n",
'close' => "\n</source".">\n",
'sample' => '',
'tip' => wfMsg( 'code_java_tip' ),
'key' => ''
),
array(
'image' => $wgLang->getImageFile( 'button-trello' ), # added (sg 2013-05-18)
'id' => 'mw-trello',
'open' => '{{Trello_einbinden\n|username=\n|board=\n|card=\n|no_done=\n}}',
'close' => '',
'sample' => '',
'tip' => wfMsg( 'trello_tip' ),
'key' => ''
)
Wiki - Sitemap extension
Tony Ford (talk) 09:14, 15 March 2013 (CET)
create the sitemap extension
create directory "Sitemap" in wiki/extensions
create and copy file sitemap.php into this folder (note: the file DBSettings.php in the wiki - root directory should contain the SQL-Server Settings $wgDBserver, $wgDBuser, $wgDBpassword, $wgDBname and $wgDBprefix / If the file doesn't exists then create it and copy / cut this settings from LocalSettings.php)
<?php
include("../../DBSettings.php");
class db
{
public $db;
function __construct() {
//#### Datenbankverbindung herstellen ####
global $wgDBuser;
global $wgDBpassword;
global $wgDBname;
global $wgDBserver;
$this->db = new mysqli($wgDBserver,$wgDBuser,$wgDBpassword,$wgDBname);
}
function __destruct(){
//#### Datenbankverbindung schließen ####
$this->db->close();
}
}
class sitemap
{
public $linkarray=array();
public $page;
public $db;
public $zeiger;
public $marktitle;
function getSitemap_page_title($page_title){
global $wgDBprefix;
$sql = 'SELECT *
FROM '.$wgDBprefix.'page AS A
INNER JOIN '.$wgDBprefix.'revision AS B ON B.rev_id = A.page_latest
INNER JOIN '.$wgDBprefix.'text AS C ON C.old_id = B.rev_text_id
INNER JOIN '.$wgDBprefix.'user AS D ON D.user_id = B.rev_user
WHERE A.page_title ="'.$page_title.'"';
$TEMP="";
$result = $this->db->query($sql);
while($row = $result->fetch_object()){
$arr=preg_split('/\[\[/',$this->filterNoWiki($this->loadTemplate($row->old_text)));
array_shift($arr);
while(sizeof($arr)>0){
$arr2=preg_split('/\]\]/',array_shift($arr));
$arr2[0]=preg_replace('/\//','#',$arr2[0]);
if(!preg_match('/'.$arr2[0].'/',$TEMP)){
if(!preg_match('/User:/',$arr2[0]) && !preg_match('/User talk:/',$arr2[0]) && !preg_match('/Template:/',$arr2[0]) && !preg_match('/Category:/',$arr2[0]) && !preg_match('/File:/',$arr2[0])){
$arrr=preg_split('/[|#]/',$arr2[0]);
if(sizeof($arrr)>1){
$arr2[0]=$arrr[0];
} else {
}
array_push($this->linkarray,preg_replace('/ /','_',$arr2[0]));
$TEMP.=$arr2[0];
}
}
}
}
$this->zeiger=0;
}
function loadTemplate($text){
$text=preg_replace('/\{\{\{/','',$text);
$arr=preg_split('/\{\{/',$text);
for($i=1;$i<sizeof($arr);$i++){
$arrr=preg_split('/\}\}/',$arr[$i]);
if($arrr[0]!=""){
$arrrr=preg_split('/\|/',$arrr[0]);
$text.=$this->getTemplate($arrrr[0]);
}
}
return $text;
}
function getTemplate($page_title){
global $wgDBprefix;
$sql = 'SELECT *
FROM '.$wgDBprefix.'page AS A
INNER JOIN '.$wgDBprefix.'revision AS B ON B.rev_id = A.page_latest
INNER JOIN '.$wgDBprefix.'text AS C ON C.old_id = B.rev_text_id
INNER JOIN '.$wgDBprefix.'user AS D ON D.user_id = B.rev_user
WHERE A.page_title ="'.$page_title.'"';
$result = $this->db->query($sql);
if($row = $result->fetch_object()){
return $row->old_text;
}
}
function getSitemap_namespace($namespace){
global $wgDBprefix;
$sql = 'SELECT *
FROM '.$wgDBprefix.'page AS A
INNER JOIN '.$wgDBprefix.'revision AS B ON B.rev_id = A.page_latest
INNER JOIN '.$wgDBprefix.'text AS C ON C.old_id = B.rev_text_id
INNER JOIN '.$wgDBprefix.'user AS D ON D.user_id = B.rev_user
WHERE A.page_namespace ='.$namespace;
$result = $db->db->query($sql);
while($row = $result->fetch_object()){
array_push($this->linkarray,$row->page_title);
}
$this->zeiger=0;
}
function outSitemap($level){
if($this->zeiger<sizeof($this->linkarray)){
$this->page=(isset($this->linkarray[$this->zeiger])) ? $this->linkarray[$this->zeiger] : "";
if($this->page!=""){
for($i=0;$i<$level;$i++){
echo " ";
}
echo "<a href='../../".$this->page."'><font style='".(($this->marktitle==$this->page) ? "color:yellow; font-weight:bold;" : "color:white;")."'> ".$this->page."</font></a><br>";
}
$this->zeiger++;
return true;
} else {
return false;
}
}
function dropDuplicates($array1){
$this->linkarray=array_diff($this->linkarray,$array1);
$this->linkarray=array_unique($this->linkarray);
sort($this->linkarray);
}
function filterNoWiki($text){
$arr=explode('<nowiki>',$text);
$text_neu='';
if(sizeof($arr)>0){
$text_neu.=$arr[0];
for($i=1;$i<sizeof($arr);$i++){
$arrr=explode('</nowiki>',$arr[$i]);
$text_neu.=$arrr[0];
}
} else {
$text_neu.=$text;
}
return $text_neu;
}
}
$sitemap_refresh= ( ! empty( $_GET[ 'sitemap_refresh' ] ) ) ? $_GET[ 'sitemap_refresh' ] : '';
$title= ( ! empty( $_GET[ 'title' ] ) ) ? $_GET[ 'title' ] : 'Main_Page';
$marktitle= ( ! empty( $_GET[ 'marktitle' ] ) ) ? $_GET[ 'marktitle' ] : '';
$div_head='
<div style="position:fixed; top:0%; left:0%; width:100%; height:100%; z-index:2; background:black; opacity:0.9;"></div>
<script>
$(document).ready(function(){
$("iframe").each(function() {
var src= $(this).attr("style");
$(this).attr("style",src + " display:none;");
});
});
</script>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<div id="sitemap" style="position:fixed; left:12%; bottom:5%; top:5%; right:40%; background:black; opacity:0.7; font-size:0.8em; color:white; overflow:auto; border:1em solid darkgreen; z-index:10;">
<div style="position:fixed; right:42%;">
<a href="javascript:unload_sitemap()"><font style="color:red; font-size:4em; font-weight:bold;">[X]</font></a>
</div>
<b> '.$title.'</b><br>';
echo $div_head;
$db=new db;
$sx=array();
$s0=new sitemap;
$s0->db=$db->db;
$s0->marktitle=$marktitle;
$s0->getSitemap_page_title($title);
$s0->dropDuplicates(array());
while($s0->outSitemap(1)){
$s1=new sitemap;
$s1->db=$db->db;
$s1->marktitle=$marktitle;
$s1->getSitemap_page_title($s0->page);
$s1->dropDuplicates(array_merge($sx,$s0->linkarray));
$sx=array_merge($sx,$s1->linkarray);
while($s1->outSitemap(2)){
$s2=new sitemap;
$s2->db=$db->db;
$s2->marktitle=$marktitle;
$s2->getSitemap_page_title($s1->page);
$s2->dropDuplicates(array_merge($sx, $s0->linkarray, $s1->linkarray));
$sx=array_merge($sx,$s2->linkarray);
while($s2->outSitemap(3)){
$s3=new sitemap;
$s3->db=$db->db;
$s3->marktitle=$marktitle;
$s3->getSitemap_page_title($s2->page);
$s3->dropDuplicates(array_merge($sx, $s0->linkarray, $s1->linkarray, $s2->linkarray));
$sx=array_merge($sx,$s3->linkarray);
while($s3->outSitemap(4)){
$s4=new sitemap;
$s4->db=$db->db;
$s4->marktitle=$marktitle;
$s4->getSitemap_page_title($s3->page);
$s4->dropDuplicates(array_merge($sx ,$s0->linkarray, $s1->linkarray, $s2->linkarray, $s3->linkarray));
$sx=array_merge($sx,$s4->linkarray);
while($s4->outSitemap(5)){
$s5=new sitemap;
$s5->db=$db->db;
$s5->marktitle=$marktitle;
$s5->getSitemap_page_title($s4->page);
$s5->dropDuplicates(array_merge($sx, $s0->linkarray, $s1->linkarray, $s2->linkarray, $s3->linkarray, $s4->linkarray));
$sx=array_merge($sx,$s5->linkarray);
while($s5->outSitemap(6)){
$s6=new sitemap;
$s6->db=$db->db;
$s6->marktitle=$marktitle;
$s6->getSitemap_page_title($s5->page);
$s6->dropDuplicates(array_merge($sx, $s0->linkarray, $s1->linkarray, $s2->linkarray, $s3->linkarray, $s4->linkarray, $s5->linkarray));
$sx=array_merge($sx,$s6->linkarray);
while($s6->outSitemap(7)){
}
unset($s6);
}
unset($s5);
}
unset($s4);
}
unset($s3);
}
unset($s2);
};
unset ($s1);
}
unset($s0);
unset($db);
?>
modify the skin(s)
Here the modification for the skin Vector
find
<div id="mw-page-base" class="noprint"></div>
<div id="mw-head-base" class="noprint"></div>
add lines
<?php
// #### Sitemap-Extension (sg 13.03.2013)
$sitemap_marktitle=rawurlencode($this->data['title']);
?>
and lines
<div id="sitemap"></div>
<script>
function load_sitemap(){
$('#sitemap').load("/extensions/Sitemap/sitemap.php?marktitle=<?php echo $sitemap_marktitle; ?>&title=Open_Source_Ecology_Germany");
}
function unload_sitemap(){
$('#sitemap').html("");
$("iframe").each(function() {
var src= $(this).attr("style");
$(this).attr("style",src.replace(/ display:none;/g,""));
});
}
$('document').ready(function(){
if(parent.location.href.toString().search(/osegradio_index.+/)==-1){
document.getElementById('OSEGradio').style.visibility='';
}
} );
</script>
find
<?php $this->renderPortals( $this->data['sidebar'] ); ?>
add lines before
<!-- OSEGradio - Extension (sg 23.03.2013) -->
<!-- sitemap - extension -->
<div id="sitemap" style="position:fixed; width:150px; left:-70px; top:35px; font-size:0.8em; -webkit-transform: rotate(-90deg); -moz-transform: rotate(-90deg); transform: rotate(-90deg); -ms-transform: rotate(-90deg); ">
<span id="OSEGradio" style="cursor:pointer; visibility:hidden;" onclick="parent.location.href='<?php echo $wgProto; ?>://wiki.opensourceecology.de/extensions/OSEGradio/osegradio_index.php?title=' + parent.location.href;" onmouseover="this.style.color='blue';" onmouseout="this.style.color='black';">oseg-radio</span>
<span style="cursor:pointer;" onclick="javascript:load_sitemap();" onmouseover="this.style.color='blue';" onmouseout="this.style.color='black';">sitemap</span>
</div>
<!-- /sitemap -->
add profile - extension
add new custom namespaces Profil
--Tony Ford (talk) 09:53, 2 May 2013 (CEST)
define("NS_PROFIL",290);
define("NS_PROFIL_TALK",291);
$wgExtraNamespaces[290] = "Profil";
$wgExtraNamespaces[291] = "Profil_talk";
edit EditPage.php
--Tony Ford (talk) 09:23, 7 May 2013 (CEST)
find
$wgOut->addHTML( EditPage::getEditToolbar()
);
add before
if($this->mTitle->getNamespace()==NS_PROFIL){
//##### profil-extension (sg 06.05.2013) #####
$fp=fopen('./images/1/11/Profilsetup.txt','r');
$profil=fread($fp,20000);
fclose($fp);
$fp=fopen('./images/9/95/Profilsetup_info.txt','r');
$profil_info=fread($fp,1000);
fclose($fp);
$profil_info=preg_replace('/
/','',$profil_info);
$profil_arr=explode('
|',$profil);
$radio_flag=false; $TEMP2=''; $i=0; $radio_count=0;
array_shift($profil_arr);
$TEMP='<div style="display:; position:relative; left:0%; width:70%; top:0%; overflow:auto; opacity:1; height:80%;"><table class="table table-condensed" style="border:2px solid grey; border-radius:5px;">';
while(sizeof($profil_arr)>0){
$arr=explode('=',(array_shift($profil_arr)));
if(preg_match('/>/',$arr[1])){
if($radio_count==0){
$TEMP.='<tr><td></td><td width="80">keine Kenntnisse</td><td width="80">Basiskenntnisse</td><td width="80">Fortgeschritten</td><td width="80">Experte</td></tr>
';
}
$TEMP.='<tr align="center"><td align="left">'.preg_replace('/
|>/','',$arr[1]).'</td><td><input type="radio" name="'.$arr[0].'" value="" checked onclick="editProfil()"></td>
<td><input type="radio" name="'.$arr[0].'" value="1" onclick="editProfil()"></td>
<td><input type="radio" name="'.$arr[0].'" value="2" onclick="editProfil()"></td>
<td><input type="radio" name="'.$arr[0].'" value="3" onclick="editProfil()"></td>
</tr>';
$radio_count++;
if($radio_count>10) $radio_count=0;
} elseif(preg_match('/\.\.\./',$arr[1])){
$TEMP.='<tr><td>'.preg_replace('/
/','',$arr[1]).'</td><td colspan="4"><textarea class="input-xlarge" name="'.$arr[0].'" onchange="editProfil()"></textarea></td></tr>';
} else {
$TEMP.='<tr><td>'.preg_replace('/
/','',$arr[1]).'</td><td colspan="4"><input type="text" class="input-xlarge" size="40" name="'.$arr[0].'" onchange="editProfil()"></td></tr>';
}
$TEMP2.='arrrr['.$i++.']="'.$arr[0].'";
';
}
$TEMP.='</table></div>
';
$wgOut->addHTML($TEMP.'
<script type="text/JavaScript">
function loadProfil(){
arrr=new Array();
arrrr=new Array();
arrrrr=new Array();
'.$TEMP2.'
var arr=document.getElementById("wpTextbox1").value.toString().split("\{\{Profil");
if(arr.length>1){
arr_=arr[1].split("\\n|");
for(i=0;i<arr_.length;i++){
arr__=arr_[i].split("=");
arrrrr[arr__[0]]=arr__[1];
if(arr__[0]!=""){
arr__[1]=arr__[1].replace(/}}/g,"");
if($("input[name=" + arr__[0] + "]").attr("type")!=undefined){
arr__[1]=arr__[1].replace(/\n/g,"");
if($("input[name=" + arr__[0] + "]").attr("type")=="text"){
$("input[name=" + arr__[0] + "]").val(arr__[1]);
} else {
if(arr__[1]!=""){
$("input[name=" + arr__[0] + "]")[arr__[1]].checked="checked";
} else {
$("input[name=" + arr__[0] + "]")[0].checked="checked";
}
}
} else if($("textarea[name=" + arr__[0] + "]").val()!=undefined){
$("textarea[name=" + arr__[0] + "]").val(arr__[1]);
}
}
}
arrrrr[arr__[0]]=arr__[1].replace(/\n}}/g,"");
} else {
for(i=0;i<arrrr.length;i++){
arrrrr[arrrr[i]]="";
}
arr[1]="";
}
for (i=0;i<arrrr.length;i++){
document.getElementsByName(arrr[arrrr[i]]).value=arrrrr[arrrr[i]];
}
}
function editProfil(){
arrr=new Array();
arrrr=new Array();
arrrrr=new Array();
'.$TEMP2.'
var arr=document.getElementById("wpTextbox1").value.toString().split("\{\{Profil");
if(arr.length>1){
arr_=arr[1].split("\\n|");
}
var neu="{{Profil";
for(i=0;i<arrrr.length;i++){
if($("textarea[name=" + arrrr[i] + "]").val()!=undefined){
neu+="\\n|" + arrrr[i] + "=" + $("textarea[name=" + arrrr[i] + "]").val();
} else {
if($("input[name=" + arrrr[i] + "]").attr("type")=="text"){
neu+="\\n|" + arrrr[i] + "=" + $("input[name=" + arrrr[i] + "]").val();
} else {
neu+="\\n|" + arrrr[i] + "=" + $("input[name=" + arrrr[i] + "]:checked").val();
}
}
}
neu+="\\n}}";
if(arr.length>1){
neu_arr=arr[1].split("}}");
if(neu_arr.length>1){
neu=arr[0] + neu + neu_arr[1];
} else {
neu=arr[0] + neu;
}
}
document.getElementById("wpTextbox1").value=neu;
}
'.((trim($this->textbox1)!='') ? '
if (window.addEventListener) {
window.addEventListener("load", loadProfil, false);
} else if (window.attachEvent) {
window.attachEvent("load", loadProfil);
}
' : '').'
</script>
<input type="button" value="Profil erstellen/editieren" onclick="editProfil()">
<p></p>
');
//##### end profilextension #####
}
bugfix Vector.php
find
$currentURL = $_SERVER['PATH_INFO'];
replace with
$currentURL = getcwd();
add Trello extension
Create Trello extension
create Folder ./extensions/Trello
and ./extensions/Trello/trello
add file load_trello.php in ./extensions/Trello
load_trello.php
<table>
<?php
$u_sel= ( ! empty( $_GET[ 'u_sel' ] ) ) ? $_GET[ 'u_sel' ] : '';
$b_sel= ( ! empty( $_GET[ 'b_sel' ] ) ) ? $_GET[ 'b_sel' ] : '';
$no_done= ( ! empty( $_GET[ 'no_done' ] ) ) ? $_GET[ 'no_done' ] : '0';
//$only_todo= ( ! empty( $_GET[ 'only_todo' ] ) ) ? $_GET[ 'only_todo' ] : '0';
$c_filter= ( ! empty( $_GET[ 'c_filter' ] ) ) ? $_GET[ 'c_filter' ] : '';
$refresh= ( ! empty( $_GET[ 'refresh' ] ) ) ? $_GET[ 'refresh' ] : '0';
include('./definitions.php');
define('PATH','./trello/');
if($refresh){
define('REFRESHTIMER',0);
} else {
define('REFRESHTIMER',3600*24);
}
function load_json($file,$opt){
switch($file){
case 'members':
$filename_local=PATH.$file.'.json';
$filename='https://api.trello.com/1/organizations/osegermany/members?fields=username,fullName,url,initials&key='.KEY.'&token='.TOKEN;
break;
case 'boards':
$filename_local=PATH.$file.'.json';
$filename='https://api.trello.com/1/organizations/osegermany/boards?key='.KEY.'&token='.TOKEN;
break;
case 'cards':
$filename_local=PATH.$file.'_'.$opt.'.json';
$filename='https://api.trello.com/1/boards/'.$opt.'/lists?cards=open&card_fields=name,url,closed,dateLastActivity,idMembers&fields=name,closed&key='.KEY.'&token='.TOKEN;
break;
}
$json='';
if(filemtime($filename_local)<time()-REFRESHTIMER){
$fp=fopen($filename,'r');
while(!feof($fp)) $json.=fread($fp,20000);
fclose($fp);
$fp=fopen($filename_local,'w+');
fwrite($fp,$json);
fclose($fp);
} else {
$fp=fopen($filename_local,'r');
while(!feof($fp)) $json.=fread($fp,20000);
fclose($fp);
}
$obj=json_decode($json);
return $obj;
}
echo '<tr><td colspan="4"><i>letzte Aktualisierung: '.date('Y-m-d H:i',filemtime(PATH.'boards.json')).'</i></td></tr>';
$members=array();
$obj=load_json('members','');
foreach($obj as $o){
$members[$o->id]=$o;
}
$obj=load_json('boards','');
foreach($obj as $o){
if(!$o->closed){
$members_temp=''; $members_flag=false; $board_temp='';
foreach($o->memberships as $member){
if(isset($members[$member->idMember])){
if($members[$member->idMember]->username==$u_sel){
$members_flag=true;
}
$members_temp.=' ('.((is_object($members[$member->idMember])) ? '<a href="'.$members[$member->idMember]->url.'" title="'.$members[$member->idMember]->fullName.'" target="trello">'.$members[$member->idMember]->initials.'</a>' : 'n.a.').')';
}
}
$board_temp.=(((($u_sel!='' && $members_flag) || $u_sel=='') && (($b_sel!='' && preg_match('/'.$b_sel.'/',$o->name)) || $b_sel=='')) ? '<tr><td colspan="4" style="border-bottom:2px solid darkgrey;"> </td></tr><tr><td colspan="3" style="background:lightgrey;"><b><a href="'.$o->url.'" target="trello">'.$o->name.'</a></b></td><td style="background:lightgrey;"><font style="font-size:0.8em;"><i>'.$members_temp.'</i></font></td></tr>
' : '');
$obj2=load_json('cards',$o->id);
$cards_temp='';
foreach($obj2 as $o2){
if(!$o2->closed){
foreach($o2->cards as $o3){
if(!$o3->closed) {
$members_temp=''; $members_flag=false;
foreach($o3->idMembers as $member){
if(isset($members[$member])){
if($members[$member]->username==$u_sel){
$members_flag=true;
$members_temp.='<b>('.$members[$member]->initials.')</b>';
} else {
$members_temp.='('.((is_object($members[$member])) ? $members[$member]->initials : 'n.a.').')';
}
}
}
if((($u_sel!='' && $members_flag) || $u_sel=='' && $c_filter=='') && $board_temp!=''){
echo $board_temp;
$board_temp='';
}
$cards_temp.=(((($u_sel!='' && $members_flag) || $u_sel=='') && (($no_done && $o2->name!='Done') || !$no_done) && (($c_filter!='' && preg_match('/'.$c_filter.'/',$o3->name)) || $c_filter=='')) ? '<tr><td style="'.(($members_temp!='') ? 'background:#BBFFBB;' : 'background:#FFBBBB;').' border-top:1px solid lightgrey;">'.substr($o3->dateLastActivity,0,10).'</td><td align="center" style="color:'.(($o2->name=='Done') ? 'green' : 'red').'; border-top:1px solid lightgrey;">'.$o2->name.'</td><td style="border-top:1px solid lightgrey;"><a href="'.$o3->url.'" target="trello">'.$o3->name.'</a></td><td style="border-top:1px solid lightgrey;"><i>'.$members_temp.'</i></td></tr>
' : '');
}
}
}
}
echo ($board_temp!='' && $c_filter=='' || ($c_filter!='' && $cards_temp!='')) ? $board_temp : '';
echo (($b_sel!='' && preg_match('/'.$b_sel.'/',$o->name)) || $b_sel=='') ? $cards_temp : '';
}
}
//echo print_r($obj);
?>
</table>
add Trello in wiki editor
appended in Extension:Code
add wiki2code extension
Create wiki2code extension
create Folder ./extensions/wiki2code
add file wiki2json.php in ./extensions/wiki2code
wiki2json.php
<?php
include("../../DBSettings.php");
$ln= ( ! empty( $_GET[ 'ln' ] ) ) ? $_GET[ 'ln' ] : 'de';
$dev= ( ! empty( $_GET[ 'dev' ] ) ) ? $_GET[ 'dev' ] : false;
$page_title= ( ! empty( $_GET[ 'title' ] ) ) ? $_GET[ 'title' ] : '';
if($page_title=='') exit;
$wgProto = (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') ? 'https' : 'http';
class db
{
public $db;
function __construct() {
//#### Datenbankverbindung herstellen ####
global $wgDBuser;
global $wgDBpassword;
global $wgDBname;
global $wgDBserver;
$this->db = new mysqli($wgDBserver,$wgDBuser,$wgDBpassword,$wgDBname);
}
function __destruct(){
//#### Datenbankverbindung schließen ####
$this->db->close();
}
}
class variable
{
public $vars=array();
public $A=array();
public $varindex=0;
public $varindex_min=0;
function add_var($var){
array_push($this->vars,$var);
$this->A[$var]=array();
}
function add_value($val){
array_push($this->A[$this->vars[$this->varindex]],$val);
$this->switch_var();
}
function switch_var(){
$this->varindex++;
if($this->varindex>=sizeof($this->vars)) $this->varindex=$this->varindex_min;
}
}
function getLang($str){
global $ln;
if(preg_match('/\{\{([a-z][a-z])\}\}/',$str)){
$A=preg_split('/\{\{'.$ln.'\}\}/',$str);
if(sizeof($A)==1) $A=preg_split('/\{\{de\}\}/',$str);
$AA=preg_split('/\{\{/',$A[1]);
return preg_replace('/<(\/|)html>/','',trim($AA[0]));
}
return preg_replace('/<(\/|)html>/','', trim($str));
}
$db=new db;
$vars=new variable;
$sql = 'SELECT *
FROM '.$wgDBprefix.'page AS A
INNER JOIN '.$wgDBprefix.'revision AS B ON B.rev_id = A.page_latest
INNER JOIN '.$wgDBprefix.'text AS C ON C.old_id = B.rev_text_id
INNER JOIN '.$wgDBprefix.'user AS D ON D.user_id = B.rev_user
WHERE A.page_title ="'.$page_title.'"';
$result = $db->db->query($sql);
while($row = $result->fetch_object()){
//###### Tables ######
$A=preg_split('/\{\|/',$row->old_text);
if(sizeof($A)>0) array_shift($A);
while(sizeof($A)>0){
$AA=preg_split('/
\|\}/',array_shift($A));
$AAA=preg_split('/
\!/',$AA[0]);
$var=new variable;
foreach($AAA as $aaa){
$aaaa=preg_split('/
/',$aaa);
if($aaaa[0]!=''){
$var->add_var($aaaa[0]);
}
}
$AAA=preg_split('/
\|-/',$AA[0]);
if(sizeof($AAA)>0) array_shift($AAA);
while(sizeof($AAA)>0){
$AAAA=preg_split('/
\|/',array_shift($AAA));
foreach($AAAA as $aaaa){
$aaaaa=preg_split('/
\|/',$aaaa);
if($aaaaa[0]!='' && $aaaaa[0]!='}'){
$var->add_value(getLang($aaaaa[0]));
}
}
}
$vars->A=array_merge($vars->A, $var->A);
}
//####### Headings #######
$A=preg_split('/===/',$row->old_text);
$a=array();
if(sizeof($A)>1) array_shift($A);
while(sizeof($A)>1){
$name=array_shift($A);
$value=array_shift($A);
$a[$name]=getLang(substr($value,1,strlen($value)));
}
$vars->A=array_merge($vars->A,$a);
if($dev) print_r($vars->A);
echo json_encode($vars->A);
}
?>