Changes

Jump to navigation Jump to search
8,948 bytes added ,  08:01, 29 May 2022
Line 1: Line 1:  
{{Languages}}
 
{{Languages}}
 +
{{usefulnote}}
 +
<blockquote style="float: right;">
 +
[[File:Wordpress.png|100px]]
 +
</blockquote>
 
===Maintainer===
 
===Maintainer===
[http://www.dungog.net Dungog.net] (Software)
+
[mailto:stephdl@de-labrusse.fr stephdl] Stéphane de Labrusse AKA [[User:stephdl|Stephdl]]<br />
 +
 
 +
[http://www.dungog.net Dungog.net] (Software) : original developper
 +
=== Version ===
 +
 
 +
{{#smeversion: smeserver-wordpress }}
    
===Description===
 
===Description===
Line 7: Line 16:     
WordPress is a state-of-the-art semantic personal publishing platform with a focus on aesthetics, web standards, and usability.
 
WordPress is a state-of-the-art semantic personal publishing platform with a focus on aesthetics, web standards, and usability.
 +
 +
If you want to create a site in Wordpress and host it as your primary domain on SME Server you should not use this contrib. This contrib will only allow site visitors to type in yourdomain.com/wordpress to get to the wordpress site.
 +
 +
Installation in an iBay is more flexible and is recommended. See the PART ONE steps at [[Wordpress_Multisite|Wordpress Multisite]]. At the completion of PART ONE, you will have a fully functional Wordpress site with the exception of automatic updating. Automatic Updating requires FTP access to the core files. You can manage FTP access to iBays with the contrib located [[FTP_Access_to_Ibays|here]].
    
===Installation===
 
===Installation===
Install from the SME Contribs repository by issuing the following command on the SME Server shell:
     −
  yum --enablerepo=smecontribs install smeserver-wordpress
+
  yum install --enablerepo=smecontribs smeserver-wordpress
 +
 
 +
====SME10====
 +
 
 +
The SME10 version has been recast to download  the latest version of WordPress from the Wordpress website while installing on SME10, and does not need a support rpm containing the Wordpress php code.
 +
 
 +
Consequently the Wordpress site can be upgraded in place manually or automatically, rather than by an RPM update.  There is no need for any further signal-event as the install itself makes sure that all files etc are up to date.
   −
There is no need to run the suggested signal-event commands or do a reboot.
+
If you remove the smeserver-wordpress rpm, then the current parameter file and wordpress code will be deleted, but the corresponding database will not be deleted.  If you want to delete it then you should use the phpmyadmin contrib.
===Installation for wordpress 3.5.1===
  −
The rpm is not in the smecontribs tree yet, you have to download manually in my [http://mirror.de-labrusse.fr/Sme-Server/Wordpress/ web area] and install them. Raise a bug or mail me for bugs and new features mailto:stephdl@de-labrusse.fr
     −
This is just an update from the work of stephen nobles
+
If you re-install after a remove, without deleting the database then the old website will be re-instated, and the version of  Wordpress installed will be the latest. However you will loose any templates and plugins that you might have installed on top of the standard install.  These can be re-installed of course.
   −
wget http://mirror.de-labrusse.fr/Sme-Server/Wordpress/smeserver-wordpress-1.0-3.noarch.rpm
+
====SME9====
wget http://mirror.de-labrusse.fr/Sme-Server/Wordpress/wordpress-3.5.1-4.noarch.rpm
  −
yum localinstall smeserver-wordpress-1.0-3.noarch.rpm wordpress-3.5.1-4.noarch.rpm
     −
{{Note box|msg=see [[bugzilla:7652]] you have to set the upload_tmp_dir in the php.ini as described [[Uploadtmpdir|here]] For SME Server V8}}
+
If installation shows a blank page, then refer the fix at https://bugs.contribs.org/show_bug.cgi?id=10735#c10.
   −
I have added a backup process (web-content, mysql-base, wordpress-db) before update or remove, you can find your files in /opt/Wordpress_RPM_BACKUP with a date string. Some languages are available now (es, fr, it, se, nl, en), see [[Wordpress#Options|db configuration]]
+
After installation, you need to make the installation effective. If you do not want to reboot your server then enter:
 +
signal-event wordpress-update ; config set UnsavedChanges no
 +
or for a full reboot:
 +
signal-event post-upgrade; signal-event reboot
    
====Initial Setup====
 
====Initial Setup====
Line 41: Line 58:  
Optional: If you want to change the domain URL that wordpress will be accessed with, apply any changes to the URL property '''before setting up wordpress''', refer to options below, default is wordpress.
 
Optional: If you want to change the domain URL that wordpress will be accessed with, apply any changes to the URL property '''before setting up wordpress''', refer to options below, default is wordpress.
   −
====Upgrade Setup====
+
Fail2ban can help protect your new Wordpress site from common attacks, using a [https://wordpress.org/plugins/wp-fail2ban/ Wordpress plugin], but you will probably need to change the backend to "polling" as described [https://forums.contribs.org/index.php?topic=53711 here].
If you already have an earlier version of wordpress installed, then you will need to run the upgrade option first. After installing the new rpm with yum (as per Installation instructions above), go to
+
 
 +
====Upgrade Wordpress version====
 +
 
 +
{{Note box|msg=The in place update process of Wordpress is not available per se, you need to update rpm as we rely on EPEL for SME8 and SME9.}}
 +
yum update wordpress --enablerepo=smecontribs
 +
If the version you want is not yet available in smecontribs, and you do not want to wait, you can do
 +
yum update wordpress --enablerepo=smetest
 +
or you can install [[Epel]] repo for your SME version and issue
 +
yum update wordpress --enablerepo=epel
 +
then go to  
 
  http://www.yourmaindomain/wordpress/wp-admin/upgrade.php
 
  http://www.yourmaindomain/wordpress/wp-admin/upgrade.php
 
and follow the instructions given.
 
and follow the instructions given.
 +
 +
====Upgrade from previous SME7/SME8 contrib smeserver-wordpress <1.0-10 ====
 +
{{Note box|msg=according to  [[bugzilla:8007]], when you upgrade your wordpress website from the old version of Noble/Stephdl to the newer (=>3.7.1) of smecontribs, you may have a blank page, do not panic, it is mainly due to the lack of your theme/template in the new location (/usr/share/wordpress). You can either install another theme or play with rsync to copy your old wp-content folder to the new location
 +
'''before to proceed, you NEED all your backups (DB and /opt/wordpress folder)'''
 +
rsync -avz /opt/wordpress/wp-content/* /usr/share/wordpress/wp-content/}}
    
=== Usage ===
 
=== Usage ===
Line 55: Line 86:  
   
 
   
 
http://wiki.contribs.org/Web_Application_RPM#New_DB_settings
 
http://wiki.contribs.org/Web_Application_RPM#New_DB_settings
 +
 +
# config show wordpress
 +
wordpress=service
 +
    AllowOverrideAll=disabled
 +
    BackupFiles=enabled
 +
    DbName=wordpress
 +
    DbPassword=804896988746808
 +
    DbUser=wordpress
 +
    Https=enabled
 +
    Indexes=disabled
 +
    Name=Wordpress weblog
 +
    PublicAccess=global
 +
    SymLinks=disabled
 +
    WpLang=en
 +
    status=enabled
 +
 +
 +
* To disable wordpress. (default is enabled)
 +
config setprop wordpress status disabled
 +
signal-event wordpress-update
 +
 +
* Force HTTP (it is a bad idea)
 +
config setprop wordpress Https disabled
 +
signal-event wordpress-update
 +
 +
* Enable Indexes 
 +
config setprop wordpress Indexes enabled
 +
signal-event wordpress-update
 +
 +
* Enabled FollowSymLinks
 +
config setprop wordpress Symlinks enabled
 +
signal-event wordpress-update
 +
 +
* Enabled AllowOverrideAll
 +
config setprop wordpress AllowOverrideAll enabled
 +
signal-event wordpress-update
 +
 +
* To limit access to wordpress.
 +
config setprop wordpress PublicAccess OPTION
 +
 +
OPTION is either of the following.
 +
 +
        none            => No access
 +
        local            => Local network  (no password required)
 +
        local-pw        => Local network  (password required)
 +
        global          => Entire Internet(no password required)
 +
        global-pw        => Entire Internet(password required)
 +
        global-pw-remote => Entire Internet(password required outside local network)
 +
 +
 +
* To add a different URL eg. yourserver.net/different-url
 +
Note, this adds another url, it doesn't remove the default yourserver.net/wordpress
 +
 +
config setprop wordpress URL new-url-wordpress
 +
 +
This setting writes a new Alias to the httpd.conf file. Whatever you enter as new-url-wordpress is appended to your domain(s).
 +
 +
* Disconnect all users and force them to reconnect (default enabled)
 +
 +
config setprop wordpress Salt enabled
 +
signal-event wordpress-update
 +
or
 +
signal-event console-save
 +
 +
every time you do a signal-event you change the random 'salt' in cookies, all users will be forced to log again.
    
* Local Settings
 
* Local Settings
 
The config file is now templated, so changes need to be made in a new fragment, eg  
 
The config file is now templated, so changes need to be made in a new fragment, eg  
nano /etc/e-smith/templates/opt/wordpress/wp-config.php/05local
+
  # ls /etc/e-smith/templates/etc/wordpress/wp-config.php/
 +
  10db  20inc_dist  template-begin  template-end
 +
 
 
check which setting you want to change with  
 
check which setting you want to change with  
cat /opt/wordpress/wp-config-sample.php
+
  cat /usr/share/wordpress/wp-config-sample.php
 
then add the new setting in the new fragment and expand, it will overrule the old
 
then add the new setting in the new fragment and expand, it will overrule the old
  expand-template /opt/wordpress/wp-config.php
+
  expand-template /etc/wordpress/wp-config.php
    
If you think your setting should be the default raise a bug
 
If you think your setting should be the default raise a bug
  −
* different languages
  −
  −
if you want to change the language use config setprop
  −
  −
config setprop wordpress WpLang fr_FR
  −
or
  −
config setprop wordpress WpLang es_ES
  −
or
  −
config setprop wordpress WpLang EN
  −
or
  −
config setprop wordpress WpLang sv_SE
  −
or
  −
config setprop wordpress WpLang it_IT
  −
or
  −
config setprop wordpress WpLang nl_NL
  −
and them
  −
expand-template /opt/wordpress/wp-config.php
      
=== Recommended Plugins ===
 
=== Recommended Plugins ===
Line 115: Line 195:  
Configure other Akismet settings as required.
 
Configure other Akismet settings as required.
 
Save your changes, exit as admin user, and start using your blogsite.
 
Save your changes, exit as admin user, and start using your blogsite.
 +
 +
==== Fail2Ban ====
 +
Fail2Ban is a contrib that blocks IP addresses involved in brute force logon attempts and such. First you need to add the fail2ban plugin inside wordpress. Then see [[Fail2ban]] wiki page for initial setup of fail2ban. Then you simply need to enable the jail for wordpress by using the server-manager fail2ban page.  Basically there will be 3 jails for wordpress, one soft (auth error) and one hard ( blocked user attempt to login) and one for xmlrpc attacks. Refer [https://forums.contribs.org/index.php/topic,53711.msg279902.html original post]
 +
 +
If you want more tweak you can change few options using command line. Note that by defualt they are not set in the db and will use fail2ban respective default value, which you could also set globally. Values presented are only for the purpose of example. WPH prefix is for wordpress-hard, WPS for wordpress-soft and WPX for wordpress-xmlrpc
 +
* db configuration setprop fail2ban WPHbantime 5000
 +
* db configuration setprop fail2ban WPSbantime 1000
 +
* db configuration setprop fail2ban WPXbantime 10000
 +
* db configuration setprop fail2ban WPHfindtime 800
 +
* db configuration setprop fail2ban WPSfindtime 800
 +
* db configuration setprop fail2ban WPXfindtime 800
 +
* db configuration setprop fail2ban WPHmaxretry 1
 +
* db configuration setprop fail2ban WPSmaxretry 3
 +
* db configuration setprop fail2ban WPXmaxretry 2
 +
then you will need a signal-event fail2ban-update
 +
 +
===Backup of Wordpress===
 +
{{Warning box|You are responsible for the backup process :)}}
 +
the folder 'wp-content' and the mysql database are now included in the official backup of smeserver. If you use that backup way you will retrieve the mysql database and the folder wp-content.
 +
 +
if you dont want to use that backup way you can do
 +
config setprop wordpress BackupFiles disabled
 +
signal-event wordpress-update
    
=== Uninstallation ===
 
=== Uninstallation ===
Line 120: Line 223:  
  rpm -e wordpress smeserver-wordpress
 
  rpm -e wordpress smeserver-wordpress
    +
or
 +
 +
yum remove smeserver-wordpress
 +
yum remove wordpress.noarch
 
To remove mysql database and user, both are named wordpress, see [[MySQL#Remove a database]] and [[MySQL#Remove a user]]. There is no need to reboot.
 
To remove mysql database and user, both are named wordpress, see [[MySQL#Remove a database]] and [[MySQL#Remove a user]]. There is no need to reboot.
 +
 +
1. Delete MySQL database:
 +
mysql
 +
drop database wordpress;
 +
 +
2. Delete MySQL user:
 +
mysql
 +
USE mysql;
 +
DELETE FROM user WHERE user = 'wordpress';
 +
FLUSH PRIVILEGES;
 +
 +
3. Cleanup filesystem
 +
rm -rf /etc/wordpress
 +
rm -rf /usr/share/wordpress
 +
config delete wordpress
 +
db accounts delete wordpress
 +
signal-event console-save
 +
 +
=== Move Contrib to iBay ===
 +
These instructions assume you have installed this contrib as described on this page and that you understand how to use Wordpress. If you have done anything else these instructions are not for you.
 +
 +
The Wordpress files are installed to <tt>/usr/share/wordpress</tt> by the wordpress contrib. The main configuration file '''wp-config.php''' in this location is a symlink to <tt>/etc/wordpress/wp-config.php</tt>. The template for the ''wp-config.php'' file is located at <tt>/etc/e-smith/templates/etc/wordpress/wp-config.php</tt> and creates the /etc/wordpress/wp-config.php file. After completing these steps, you will not be able to use the wordpress events or information in the configuration database to regenerate your site's wp-config.php file. You will have to manually modify the ''wp-config.php'' file to suit your needs.
 +
 +
Follow the steps at [[Wordpress_Multisite|Wordpress Multisite]] with the exception of steps A4, A5, and A7.
 +
 +
A4 step: If you are moving an existing install, the database and user already exist. Backup the Wordpress database using phpmyadmin ([[PHPMyAdmin]]) and get the database user and password from /etc/wordpress/wp-config.php.
 +
 +
A5 step: You are going to be using an existing installation so use midnight commander (mc at the terminal) to copy the files from <tt>/usr/share/wordpress/</tt> to the ibay directory. Once copied, navigate to the ibay directory and delete the symlink for wp-config.php. Copy wp-config.php from /etc/wordpress to the ibay directory. You should now have all of the wordpress base, config file, plugins, and content located in the new ibay you created.
 +
 +
Edit the wp-config.php file and find the line that references the definition of ABSPATH. Edit the directory to match your ibay location. The default entry created by the contrib is:
 +
 +
  /** Absolute path to the WordPress directory. */
 +
define('ABSPATH', '/usr/share/wordpress/');
 +
 +
Using phpmyadmin, go into the wordpress database wp_options table and change the siteurl and home records to reflect your new url. You do not have to use https if you created the ibay using the steps outlined in the Wordpress Multisite wiki page.
 +
 +
A7 step: Navigate to yourdomain.com/wp-admin and login using the same credentials setup when you installed the contrib. Verify the settings are correct and save the configuration. No reconfiguration necessary.
 +
 +
You can disable the wordpress contrib with
 +
 +
config setprop wordpress status disabled
 +
signal-event post-upgrade; signal-event reboot
 +
 +
Once you are satisfied with the site's performance, you can remove the wordpress contrib. Do not remove the mysql database or your site will not function.
    
=== Bugs ===
 
=== Bugs ===
 
Please raise bugs under the SME-Contribs section in {{BugzillaFileBug|product=|component=|title=bugzilla}}and select the smeserver-wordpress component or use {{BugzillaFileBug|product=SME%20Contribs|component=smeserver-wordpress|title=this link}}.
 
Please raise bugs under the SME-Contribs section in {{BugzillaFileBug|product=|component=|title=bugzilla}}and select the smeserver-wordpress component or use {{BugzillaFileBug|product=SME%20Contribs|component=smeserver-wordpress|title=this link}}.
   −
 
+
{{#bugzilla:columns=id,product,version,status,summary |sort=id|order=desc |component=smeserver-wordpress|noresultsmessage="No open bugs found."}}
 
      
[[Category: Contrib]]
 
[[Category: Contrib]]
Super Admin, Wiki & Docs Team, Bureaucrats, Interface administrators, Administrators
3,254

edits

Navigation menu