Difference between revisions of "MediaWiki"

From Things and Stuff Wiki
Jump to navigation Jump to search
 
(39 intermediate revisions by 2 users not shown)
Line 5: Line 5:
  
 
* https://www.mediawiki.org/wiki/Future/The_big_picture
 
* https://www.mediawiki.org/wiki/Future/The_big_picture
 +
 +
 +
* [https://secluded.site/documenting-with-mediawiki/ Documenting With MediaWiki] - [https://lobste.rs/s/wlqu3t/documenting_with_mediawiki]
  
 
== Setup ==
 
== Setup ==
Line 51: Line 54:
 
* https://github.com/milkmiruku/backup-mediawiki
 
* https://github.com/milkmiruku/backup-mediawiki
 
* https://github.com/milkmiruku/backup-mediawiki-remote
 
* https://github.com/milkmiruku/backup-mediawiki-remote
 +
 +
=== Compress ===
 +
* https://www.mediawiki.org/wiki/Manual:Reduce_size_of_the_database
  
 
== Configuration ==
 
== Configuration ==
 
* http://www.mediawiki.org/wiki/Manual:Configuration
 
* http://www.mediawiki.org/wiki/Manual:Configuration
 
* http://www.mediawiki.org/wiki/Manual:System_administration
 
* http://www.mediawiki.org/wiki/Manual:System_administration
 +
 +
* https://en.wikipedia.org/wiki/MediaWiki_extension
 
* http://www.mediawiki.org/wiki/How_to_become_a_MediaWiki_hacker
 
* http://www.mediawiki.org/wiki/How_to_become_a_MediaWiki_hacker
  
 
* http://www.mediawiki.org/wiki/Manual:Robots.txt
 
* http://www.mediawiki.org/wiki/Manual:Robots.txt
  
=== Performance ===
+
=== Caching ===
 
* https://www.mediawiki.org/wiki/Manual:Cache
 
* https://www.mediawiki.org/wiki/Manual:Cache
  
Line 65: Line 73:
 
   PHP acceleration, i.e., APC
 
   PHP acceleration, i.e., APC
  
* http://www.mediawiki.org/wiki/Manual:Varnish_caching
+
* https://www.mediawiki.org/wiki/Manual:Varnish_caching
 +
 
 +
* https://www.mediawiki.org/wiki/Manual:Purge
 +
 
 +
* https://www.mediawiki.org/wiki/Manual:PurgeList.php
 +
 
 +
php purgeList.php --all
 +
 
 +
* https://www.mediawiki.org/wiki/Extension:Purge - extension adds a purge tab on all normal pages, allowing for quick purging of the cache.
  
 
== Usage ==
 
== Usage ==
 
=== Markup ===
 
=== Markup ===
 
* http://en.wikipedia.org/wiki/Wikipedia:Cheatsheet
 
* http://en.wikipedia.org/wiki/Wikipedia:Cheatsheet
 +
 +
 
* http://en.wikipedia.org/wiki/Help:Table
 
* http://en.wikipedia.org/wiki/Help:Table
 +
** https://en.wikipedia.org/wiki/Help:Basic_table_markup
 +
 +
<pre>{| class="wikitable"
 +
|-
 +
! Header 1
 +
! Header 2
 +
! Header 3
 +
|-
 +
| row 1, cell 1
 +
| row 1, cell 2
 +
| row 1, cell 3
 +
|-
 +
| row 2, cell 1
 +
| row 2, cell 2
 +
| row 2, cell 3
 +
|}</pre>
 +
  
 
* https://en.wikipedia.org/wiki/Help:HTML_in_wikitext
 
* https://en.wikipedia.org/wiki/Help:HTML_in_wikitext
 +
 +
* https://wincent.com/products/wikitext
 +
 +
=== ToC ===
 +
* https://www.mediawiki.org/wiki/Manual:Table_of_contents
 +
 +
<pre>__TOC__</pre>
 +
 +
 +
* https://www.mediawiki.org/wiki/Extension:TocTree - Extension for the expansion and collapsing of the table of contents
  
 
=== Hotkeys ===
 
=== Hotkeys ===
 
* http://meta.wikimedia.org/wiki/Help:Keyboard_shortcuts#Default_Shortcuts
 
* http://meta.wikimedia.org/wiki/Help:Keyboard_shortcuts#Default_Shortcuts
 +
 +
=== Content ===
 +
* https://www.mediawiki.org/wiki/Extension:Replace_Text
 +
 +
 +
* https://www.mediawiki.org/wiki/Manual:Collapsible_elements - Add the class mw-collapsible to any element (div, table, list, anything) to trigger it.
  
 
=== Interwiki ===
 
=== Interwiki ===
Line 87: Line 138:
 
== Theming and frontend ==
 
== Theming and frontend ==
 
* http://www.mediawiki.org/wiki/Manual:Skinning/Tutorial
 
* http://www.mediawiki.org/wiki/Manual:Skinning/Tutorial
 +
 
* http://blog.redwerks.org/2012/02/28/mediawiki-subskin-tutorial/
 
* http://blog.redwerks.org/2012/02/28/mediawiki-subskin-tutorial/
 +
  
 
* http://www.mediawiki.org/wiki/Manual:Skinning/Vector
 
* http://www.mediawiki.org/wiki/Manual:Skinning/Vector
 
** http://www.mediawiki.org/wiki/Extension:Vector
 
** http://www.mediawiki.org/wiki/Extension:Vector
 +
  
 
* http://www.mediawiki.org/wiki/Extension:WebFonts
 
* http://www.mediawiki.org/wiki/Extension:WebFonts
  
=== Toolbox ===
+
 
A mess. Hack SkinTemplate.php
+
=== Bootstrap ===
 +
 
 +
* https://github.com/armadillica/mediawiki-bootstrap - Minimal Mediawiki skin with Bootstrap 4
 +
 
 +
 
 +
* https://github.com/answeropedia/BootSkin - A MediaWiki skin using Bootstrap 4 for project AnswersWiki.org
 +
 
 +
 
 +
* https://github.com/cmln/chameleon/tree/2.0-devel
 +
 
 +
 
 +
=== Print.css ===
 +
* [[MediaWiki:Print.css]]
 +
 
  
 
=== Footer links ===
 
=== Footer links ===
Line 101: Line 168:
 
  MediaWiki:Aboutsite
 
  MediaWiki:Aboutsite
 
  MediaWiki:Disclaimers
 
  MediaWiki:Disclaimers
 +
  
 
=== Layout ===
 
=== Layout ===
Line 108: Line 176:
  
 
* http://www.mediawiki.org/wiki/Extension:PCR_GUI_Inserts
 
* http://www.mediawiki.org/wiki/Extension:PCR_GUI_Inserts
 +
  
 
=== Social ===
 
=== Social ===
 
* http://www.mediawiki.org/wiki/Extension:OpenID
 
* http://www.mediawiki.org/wiki/Extension:OpenID
 +
  
 
* http://www.mediawiki.org/wiki/Extension:AddThis
 
* http://www.mediawiki.org/wiki/Extension:AddThis
 +
 +
 +
* https://www.mediawiki.org/wiki/Extension:OpenGraphMeta - provides OpenGraph protocol metadata for articles on the wiki for 3rd parties like Facebook to extract. The primary use for this extension is for any wiki that provides its users a button to "Like" pages on the wiki, especially if the wiki uses a custom default skin. As sometimes Facebook can extract undesirable parts from the page (known on some custom skins to potentially extract random images irrelevant to the content) providing this data gives Facebook clean data to display in likes, and cleans up the long title into a pair of clean site and page titles.
 +
  
 
=== Content ===
 
=== Content ===
Line 119: Line 193:
  
 
* http://www.mediawiki.org/wiki/Extension:SyntaxHighlight_GeSHi
 
* http://www.mediawiki.org/wiki/Extension:SyntaxHighlight_GeSHi
 +
  
 
=== WYSIWYM ===
 
=== WYSIWYM ===
Line 125: Line 200:
 
* https://www.mediawiki.org/wiki/Extension:VisualEditor
 
* https://www.mediawiki.org/wiki/Extension:VisualEditor
 
** https://www.mediawiki.org/wiki/VisualEditor - for WikiText markup based RDFa, linked with [https://www.mediawiki.org/wiki/Parsoid Parsoid] wikitext parer project
 
** https://www.mediawiki.org/wiki/VisualEditor - for WikiText markup based RDFa, linked with [https://www.mediawiki.org/wiki/Parsoid Parsoid] wikitext parer project
 +
  
 
=== Real-time ===
 
=== Real-time ===
Line 133: Line 209:
 
* http://www.mediawiki.org/wiki/Future/Real-time_collaboration
 
* http://www.mediawiki.org/wiki/Future/Real-time_collaboration
  
=== Print.css ===
+
 
* [[MediaWiki:Print.css]]
+
=== Upload ===
 +
* https://www.mediawiki.org/wiki/Extension:UploadWizard
 +
 
 +
* https://www.mediawiki.org/wiki/Extension:MsUpload
  
 
== Users ==
 
== Users ==
Line 155: Line 234:
  
 
* https://github.com/aaronpk/IndieAuth-MediaWiki
 
* https://github.com/aaronpk/IndieAuth-MediaWiki
 +
 +
* http://www.mediawiki.org/wiki/Extension:Persona
 +
** https://github.com/wikimedia/mediawiki-extensions-Persona
 +
** https://bugzilla.mozilla.org/show_bug.cgi?id=879460
 +
 +
* https://www.mediawiki.org/wiki/Extension:SecureSessions
 +
* https://www.mediawiki.org/wiki/Extension:SSLClientAuthentication
  
 
=== Permissions ===
 
=== Permissions ===
Line 166: Line 252:
 
* [http://www.mediawiki.org/wiki/Manual:$wgGroupPermissions Manual:$wgGroupPermissions]
 
* [http://www.mediawiki.org/wiki/Manual:$wgGroupPermissions Manual:$wgGroupPermissions]
  
== Namespace protection ==
+
* https://www.mediawiki.org/wiki/Security_issues_with_authorization_extensions
 +
 
 +
* https://www.mediawiki.org/wiki/Extension:Page_access_restriction
 +
* https://www.mediawiki.org/wiki/Extension:Restrict_access_by_category_and_group
 +
* https://www.mediawiki.org/wiki/Extension:EditSubpages
 +
 
 +
==== Namespace protection ====
 
* http://www.mediawiki.org/wiki/Manual:$wgNamespaceProtection
 
* http://www.mediawiki.org/wiki/Manual:$wgNamespaceProtection
  
Line 188: Line 280:
 
== Resources ==
 
== Resources ==
 
* http://www.mediawiki.org/wiki/ResourceLoader
 
* http://www.mediawiki.org/wiki/ResourceLoader
 +
 +
 +
* [https://wikimediafoundation.org/news/2023/12/05/introducing-wikifunctions-first-wikimedia-project-to-launch-in-a-decade-creates-new-forms-of-knowledge/ Introducing Wikifunctions: first Wikimedia project to launch in a decade creates new forms of knowledge – Wikimedia Foundation] [https://news.ycombinator.com/item?id=38548130]
  
 
== Anti-spam ==
 
== Anti-spam ==
Line 219: Line 314:
 
  $wgCaptchaTriggers['createaccount'] = true;
 
  $wgCaptchaTriggers['createaccount'] = true;
 
  $wgCaptchaTriggers['badlogin']      = true;
 
  $wgCaptchaTriggers['badlogin']      = true;
 +
  
 
* http://www.mediawiki.org/wiki/Extension:SpamBlacklist
 
* http://www.mediawiki.org/wiki/Extension:SpamBlacklist
 
** not tried
 
** not tried
 +
 +
 +
* https://www.mediawiki.org/wiki/Extension:BlockAndNuke
 +
** https://github.com/wikimedia/mediawiki-extensions-BlockAndNuke
 +
 +
 +
* https://www.mediawiki.org/wiki/Extension:SmiteSpam - provides a special page "Special:SmiteSpam" helping administrators identify and delete spam pages.
 +
 +
 +
* https://superuser.com/questions/100452/mass-rollback-on-mediawiki
 +
 +
 +
* https://github.com/wikimedia/mediawiki-extensions-DeleteBatch
  
 
== Tools ==
 
== Tools ==
 
* http://www.nozicaa.com/fr/page.content/T%C3%A9l%C3%A9chargements#Mediawiki
 
* http://www.nozicaa.com/fr/page.content/T%C3%A9l%C3%A9chargements#Mediawiki
 +
  
 
* http://en.wikipedia.org/wiki/Wikipedia:Tools
 
* http://en.wikipedia.org/wiki/Wikipedia:Tools
 +
 
* http://www.mediawiki.org/wiki/Manual:Maintenance_scripts
 
* http://www.mediawiki.org/wiki/Manual:Maintenance_scripts
 +
  
 
* http://robertelwell.info/blog/mediawiki-more-than-wikipedia/
 
* http://robertelwell.info/blog/mediawiki-more-than-wikipedia/
  
 
* http://wikiapiary.com/
 
* http://wikiapiary.com/
 +
  
 
=== Visualization ===
 
=== Visualization ===
Line 239: Line 352:
  
 
* http://www.youtube.com/watch?v=baVQ5MPcXaI
 
* http://www.youtube.com/watch?v=baVQ5MPcXaI
 +
 
* https://www.dokuwiki.org/tips:gource_analysis
 
* https://www.dokuwiki.org/tips:gource_analysis
 +
 +
 +
=== IRC bots ===
 +
* https://www.mediawiki.org/wiki/Manual:IRC_RC_Bot
 +
  
 
== Templates ==
 
== Templates ==
 
* http://en.wikipedia.org/wiki/Template:Col-begin-small
 
* http://en.wikipedia.org/wiki/Template:Col-begin-small
 +
 +
 +
== URL ==
 +
* https://www.mediawiki.org/wiki/Extension:ShortUrl
 +
  
 
== API ==
 
== API ==
 
* http://www.mediawiki.org/wiki/API:Data_formats
 
* http://www.mediawiki.org/wiki/API:Data_formats
  
== Semantic / Data ==
+
 
* http://semantic-mediawiki.org/
+
== Archive ==
 +
* https://www.mediawiki.org/wiki/Extension:Memento
 +
 
 +
* http://mementoweb.org/depot/
 +
 
 +
 
 +
== SEO ==
 +
* http://www.mediawiki.org/wiki/Manual:GenerateSitemap.php
 +
 
 +
php maintenance/generateSitemap.php \
 +
  --fspath sitemap \
 +
  --server http://mydomain.org \
 +
  --urlpath http://mydomain.org/sitemap
 +
 
 +
 
 +
=== Tags ===
 +
* https://www.mediawiki.org/wiki/Extension:WikiSEO - allows you to replace, append or prepend the html title tag content, and allows you to add common SEO meta keywords and a meta description.
 +
 
 +
* https://www.mediawiki.org/wiki/Extension:GoogleRichCards - Automatically generates Google Rich Cards in JSON+LD format for mediawiki article pages.
 +
 
 +
* https://www.mediawiki.org/wiki/Extension:AdvancedMeta - extension allows setting the robots, keywords and description meta tags for MediaWiki, for SEO purposes
 +
 
 +
 
 +
 
 +
== Data / semantic ==
 +
 
 +
* https://www.mediawiki.org/wiki/Extension:Page_Schemas - a MediaWiki extension that allows for defining all the schema information about a "class", or data type - for naming, display, data input, and browsing - within a single piece of XML contained within a category page. This XML then is used to generate all the necessary additional pages needed to put the schema into effect, such as template pages and, for instance, if Page Forms is installed, form pages. The XML can be created and edited via a helper form, preventing users from having to generate or modify it manually.Page Schemas allows other extensions to define their own fields to add to the XML, using hooks.
 +
 
 +
Currently, the following extensions hook into Page Schemas:
 +
* Cargo
 +
* Page Forms
 +
* Semantic MediaWiki
 +
* Semantic Drilldown
 +
* Semantic Internal Objects
 +
 
 +
 
 +
 
 +
* http://semantic-mediawiki.org
 +
** http://semantic-mediawiki.org/wiki/Data_visualization
 
** http://www.mediawiki.org/wiki/Extension:Semantic_MediaWiki
 
** http://www.mediawiki.org/wiki/Extension:Semantic_MediaWiki
 
** http://semantic-mediawiki.org/wiki/WikiNode
 
** http://semantic-mediawiki.org/wiki/WikiNode
  
 
* http://semantic-mediawiki.org/wiki/Help:Inline_queries
 
* http://semantic-mediawiki.org/wiki/Help:Inline_queries
 +
  
 
* http://en.wikipedia.org/wiki/Wikidata
 
* http://en.wikipedia.org/wiki/Wikidata
 +
 
* http://en.wikipedia.org/wiki/DBpedia
 
* http://en.wikipedia.org/wiki/DBpedia
  
 
* http://semanticweb.org/wiki/Semantic_MediaWiki
 
* http://semanticweb.org/wiki/Semantic_MediaWiki
 +
 +
  
 
* http://www.kennel17.co.uk/testwiki/WikiDB/Tutorial
 
* http://www.kennel17.co.uk/testwiki/WikiDB/Tutorial
 +
 +
 +
* http://discoursedb.org/wiki/Main_Page
 +
 +
 +
* http://aksw.org/Projects/OntoWiki.html
 +
  
 
=== JSON ===
 
=== JSON ===
Line 269: Line 442:
 
** https://github.com/robla/mediawiki-jsondata
 
** https://github.com/robla/mediawiki-jsondata
 
** https://github.com/atdt/mediawiki-jsondata - newer fork
 
** https://github.com/atdt/mediawiki-jsondata - newer fork
 +
 +
== Flow ==
 +
* http://www.mediawiki.org/wiki/Flow_Portal
 +
 +
* http://unicorn.wmflabs.org/flow

Latest revision as of 11:44, 5 February 2024

General


Setup

Nginx

Upgrade

Download latest, extract on-top of current. Be careful with overwriting if you have hacked a core theme.

tar xvzf mediawiki-1.19.1.tar.gz -C . --strip-components=1
php maintenance/update.php

Upgrade requires DB user grants for: select, insert, update, delete, alter, index

http://www.mediawiki.org/w/api.php?action=expandtemplates&text=http://download.wikimedia.org/mediawiki/{{MW%20stable%20branch%20number}}/mediawiki-{{MW%20stable%20release%20number}}.tar.gz

Backup

change vars;

nice -n 19 mysqldump -u $USER --password=$PASSWORD $DATABASE -c
nice -n 19 gzip -9 > wiki-$DATABASE-$(date '+%Y%m%d').sql.gz

Script

Compress

Configuration

Caching

$wgMainCacheType = CACHE_ACCEL;
  PHP acceleration, i.e., APC
php purgeList.php --all

Usage

Markup


{| class="wikitable"
|-
! Header 1
! Header 2
! Header 3
|-
| row 1, cell 1
| row 1, cell 2
| row 1, cell 3
|-
| row 2, cell 1
| row 2, cell 2
| row 2, cell 3
|}


ToC

__TOC__


Hotkeys

Content


Interwiki

Categories

Theming and frontend




Bootstrap




Print.css


Footer links

MediaWiki:Privacy
MediaWiki:Aboutsite
MediaWiki:Disclaimers


Layout


Social



  • https://www.mediawiki.org/wiki/Extension:OpenGraphMeta - provides OpenGraph protocol metadata for articles on the wiki for 3rd parties like Facebook to extract. The primary use for this extension is for any wiki that provides its users a button to "Like" pages on the wiki, especially if the wiki uses a custom default skin. As sometimes Facebook can extract undesirable parts from the page (known on some custom skins to potentially extract random images irrelevant to the content) providing this data gives Facebook clean data to display in likes, and cleans up the long title into a pair of clean site and page titles.


Content


WYSIWYM


Real-time


Upload

Users

Signup

Login

Permissions

  • Special:UserRights - User rights management

Namespace protection

# Only allow autoconfirmed users to edit Project namespace
$wgNamespaceProtection[NS_PROJECT] = array( 'autoconfirmed' );
 
# Don't allow anyone to edit non-talk pages until they've confirmed their
# e-mail address (assuming we have no custom namespaces and allow edits
# from non-emailconfirmed users to start with)
# Note for 1.13: emailconfirmed group and right were removed from default
# setup, if you want to use it, you'll have to re-enable it manually
$wgNamespaceProtection[NS_MAIN]     = $wgNamespaceProtection[NS_USER]  =
$wgNamespaceProtection[NS_PROJECT]  = $wgNamespaceProtection[NS_IMAGE] =
$wgNamespaceProtection[NS_TEMPLATE] = $wgNamespaceProtection[NS_HELP]  =
 $wgNamespaceProtection[NS_CATEGORY] = array( 'emailconfirmed' );
 
# Only allow sysops to edit "Policy" namespace
$wgGroupPermissions['sysop']['editpolicy'] = true;
$wgNamespaceProtection[NS_POLICY] = array( 'editpolicy' );

Resources


Anti-spam

# Protect shit
require_once("$IP/extensions/ConfirmEdit/ConfirmEdit.php");
require_once("$IP/extensions/ConfirmEdit/QuestyCaptcha.php"); 
$wgCaptchaClass = 'QuestyCaptcha';
$wgCaptchaQuestions[] = array( 'question' => '123 + 1 =', 'answer' => '124' );
$wgCaptchaQuestions[] = array( 'question' => '321 + 2 =', 'answer' => '323' );
etc.
 
$wgGroupPermissions['*'            ]['skipcaptcha'] = false;
$wgGroupPermissions['user'         ]['skipcaptcha'] = false;
$wgGroupPermissions['autoconfirmed']['skipcaptcha'] = false;
$wgGroupPermissions['bot'          ]['skipcaptcha'] = true; // registered bots
$wgGroupPermissions['sysop'        ]['skipcaptcha'] = true;

$wgGroupPermissions['emailconfirmed']['skipcaptcha'] = true;
$ceAllowConfirmedEmail = true;

$wgCaptchaTriggers['edit']          = false; 
$wgCaptchaTriggers['create']        = false; 
$wgCaptchaTriggers['addurl']        = true; 
$wgCaptchaTriggers['createaccount'] = true;
$wgCaptchaTriggers['badlogin']      = true;






Tools




Visualization


IRC bots


Templates


URL


API


Archive


SEO

php maintenance/generateSitemap.php \
  --fspath sitemap \
  --server http://mydomain.org \
  --urlpath http://mydomain.org/sitemap


Tags


Data / semantic

  • https://www.mediawiki.org/wiki/Extension:Page_Schemas - a MediaWiki extension that allows for defining all the schema information about a "class", or data type - for naming, display, data input, and browsing - within a single piece of XML contained within a category page. This XML then is used to generate all the necessary additional pages needed to put the schema into effect, such as template pages and, for instance, if Page Forms is installed, form pages. The XML can be created and edited via a helper form, preventing users from having to generate or modify it manually.Page Schemas allows other extensions to define their own fields to add to the XML, using hooks.

Currently, the following extensions hook into Page Schemas:

  • Cargo
  • Page Forms
  • Semantic MediaWiki
  • Semantic Drilldown
  • Semantic Internal Objects







JSON

Flow