Installing Elgg - Community Builder Based Open Source
Installing Elgg - Community Builder Based Open Source
Installing Elgg
Before you begin, make sure you have read Elgg's technical requirements. If you discover problems
after following these instructions, check out the troubleshootingpage.
1. Upload Elgg
Download the latest version of Elgg. Unzip Elgg and upload it to your webserver.
If you want Elgg in your root domain (e.g. http://example.com), move or upload the contents of
the unzipped Elgg folder into the document root directory of your server.
If you want Elgg in its own subdirectory on your website (e.g.http://example.com/elgg),
rename your unzipped directory to the name you would like the subdirectory to have and upload
the directory to your document root.
Elgg needs a special folder to store uploaded files, including profile icons and photos. You will need to
create this directory.
We recommend that this folder is called data. For security reasons this must be stored outside of your
document root. For example, if Elgg is installed in /home/elgg/html/, you might create it
in /home/elgg/data. Alternately, if Elgg is installed/home/username/public_html/, then you may want
to create it in/home/username/elgg/.
Once this folder has been created, you'll need to make sure the web server Elgg is running on has
permission to write to it and create directories in it. This shouldn't be a problem on Windows-based
servers, but if your server runs Linux or a UNIX variant, you'll need to type something like:
If you use a graphical client to upload files, you can usually set permissions by right or shift-clicking on the
folder and selecting 'properties' or 'Get Info'.
NOTE: Setting your data directory to 777 will work, but it is insecure and so not recommended. If you are
unsure how to correctly set permissions, contact your host for more information. Again, you need to make
sure your web server has full permissions to the directory.
3. Create a database
www.almuhibbin.com
2
Using your database administration tool of choice (if you're unsure about this, ask your system
administrator), create a new database for Elgg. Add a user to the database with all privileges. Make sure
you know the database name, username and password necessary to access this as you will be prompted
to add this information in the installer.
You will be prompted for the database name, the username, and password when you install Elgg. With
cPanel, the database and user names must be proceeded by the cPanel username and an underscore.
For example:
Database: cpanelloginname_databasename
Username: cpanelloginname_username
1. Log in to phpMyAdmin
2. Create the database
3. Select your database on the sidebar menu
4. Go to the Priviledges tab and click Add a new user
www.almuhibbin.com
3
5. Fill out the top 4 fields, setting Host to localhost and then click Go
The database name, username, and password set here are used in the first install screen of Elgg.
Once you've performed these steps, visit your Elgg site in your web browser. Elgg will take you through
the rest of the installation process from there. The first account that you create at the end of the
installation process will be an administrator account.
The Elgg installer will try and create two files for you:
If these files can't be automatically generated, for example because the web server doesn't have write
permissions in the directories, Elgg will tell you how to create them. You could also temporarily change
the permissions on the root directory and the engine directory. Set the permissions on those two
directories so that the web server can write those two files, complete the install process, and them
change the permissions back to their original settings. If, for some reason, this won't work, you will need
to:
www.almuhibbin.com
4
For installation to proceed successfully, modify the .htaccess file in the root, and uncomment out:
117: #RewriteBase /
To be:
117: RewriteBase /
Windows EasyPHP
Windows XAMPP
Mac OSX MAMP
Ubuntu Linux
Install Ubuntu
www.almuhibbin.com
5
Install Troubleshooting
Help! I'm having trouble installing Elgg
You'll want to first recheck that your server meets the technical requirements for Elgg. Are you sure that
your server is not configured to run in cgi mode or safe mode? Have you verified that mod_rewrite is
being loaded? Is the mysql apache being loaded?
Keep notes on steps that you take to fix the install. Sometimes changing some setting or file to try to fix a
problem may cause some other problem later on. If you need to start over, just delete all the files, drop
your database, and begin again.
I can't save my settings on installation (I get a 404 error when saving settings)
Elgg relies on the mod_rewrite Apache extension in order to simulate certain URLs. For example,
whenever you perform an action in Elgg, or when you visit a user's profile, the URL is translated by the
server into something Elgg understands internally. This is done using rules defined in an .htaccess file,
which is Apache's standard way of defining extra configuration for a site.
This error suggests that the mod_rewrite rules aren't being picked up correctly. This may be for several
reasons. If you're not comfortable implementing the solutions provided below, we strongly recommend
that you contact your system administrator or technical support and forward this page to them.
Check your httpd.conf to make sure that this module is being loaded by Apache. You may have to
restart Apache to get it to pick up any changes in configuration. You can also use PHP info to check to
see if the module is being loaded.
In your virtual host configuration settings (which may be contained withinhttpd.conf), change the
AllowOverride setting so that it reads:
AllowOverride all
This will tell Apache to pick up the mod_rewrite rules from .htaccess.
www.almuhibbin.com
6
See the item below about installing in a subdirectory of your html root.
This is a problem with your mod_rewrite setup (see previous troubleshooting item).
Notice that the requested URL begins with elgg. That means you installed Elgg in a subdirectory rather
than your site's html document root. You may need to give mod_rewrite a pointer to where your Elgg
installation is.
Please note that the path you are using is the web path, minus the host.
/var/www/html/elgg/
RewriteBase /elgg/
I did everything! mod_rewrite is working fine, but still the 404 error
Maybe there is a problem with the file .htaccess. Sometimes the elgg install routine is unable to create
one and unable to tell you that. If you are on this point and tried evrything thats written above:
www.almuhibbin.com
7
check if it is really the elgg-created .htaccess (not only a dummy provided from the server
provider)
if it is a dummy, use the htaccess_dist (rename it to .htaccess)and edit it in a texteditor, you'll find
the entryRewriteBase commented out with an "#"
delete the "#" and add your path (i.e.:RewriteBase /path/to/your/elgg/installation/ Don't
forget the trailing slash)
Check that the Apache mysql module is installed and is being loaded.
If you see a 404 error during the install or on the creation of the first user with a url
like:http://example.com/homepages/26/d147515119/htdocs/elgg/action/register that means
your site url is incorrect in your sites_entity table in your database. This was set by you on the second
page of the install. Elgg tries to guess the correct value but has difficulty with shared hosting sites. Use
phpMyAdmin to edit this value to the correct base url.
This is highly server specific so it is difficult to give specific advice. If you have created a directory for
uploading data, make sure your http server can access it. The easiest way to do this is give it permissions
777.
Make sure the path is correct and ends with a /. You can check the path in your database in the datalists
table.
If you only have ftp access to your server and created a directory but do not know the path of it, you might
be able to figure it out from the www file path set in your datalists database table. Asking for help from
your hosting help team is recommended at this stage.
If your server uses PHP in the deprecated safe mode, you may need to add the data directory to the
open_basedir restrictions. Ask your host for more information.
www.almuhibbin.com
8
On certain versions of MAMP, Elgg will either fail to install or have intermittent problems while running.
This is a known issue with MAMP and is related to the Zend Optimizer. Until Zend/MAMP have resolved
this issue it is recommended that you turn off the Zend Optimizer in your PHP settings.
While it's true that normal accounts (aside from those created from the admin panel) require their email
address to be authenticated before they can log in, the admin account does not.
Once you have registered your first account you will be able to log in using the credentials you have
provided!
I'm installing over an existing Elgg classic install and am getting all kinds of errors (e.g.
500 Internal server error)
Don't!
Elgg 1.0 is an entirely new codebase and data model, and is not backwards compatible with Elgg Classic!
Additionally, it has different installation requirements.
You must install Elgg 1.0 to a new database, and in a different directory on your server.
We will be providing a way of migrating between 0.92 and 1.0 in due course.
Remember, PHP has three components - the php module, php cli and php cgi. Running php -v on the
console and getting 5.x.x back does not necessarily mean that the apache module is running PHP 5!
I have tried all of these suggestions and I still cannot install Elgg
It is possible that during the process of debugging your install you have broken something else. Make
sure that you have confirmed that your server meets Elgg's technical requirements. Test your
mod_rewrite. Then do a clean install (drop your elgg database, delete all the files in your elgg directory,
and start the process again).
www.almuhibbin.com
9
If that fails, you may want to seek the help of the Elgg community by posting at Elgg community site. Be
sure to mention what version of Elgg you are installing, details of your server platform, and any error
messages that you may have received including ones in the error log of your server.
Getting Started
You have installed Elgg on your server and worked through any initial server issues. The question you
may be asking yourself is now what? The answer to that question partly depends on why you installed
Elgg in the first place. Let's assume your evaluating Elgg as the basis of a social networking project.
While it may be tempting to go to the community site and install every interesting plugin, it is better to
initially stick with the plugins included with the installation package. This will allow you to get a sense of
what the platform is like without any issues possibly introduced by a plugin that's not written well.
Assuming that you have already created your first user (who is automatically an admin), using the toolbar
on top go to Site Administration -> Tools Administration and then enable all plugins. This should give you
a basic set of social networking functionality: blog, social bookmarking, files, internal messaging,
microblogging, notifications, activity feed, message board, user profiles.
You have two choices for creating test users with the plain install. You can sign them up by going to the
home page or as an admin, you can create users by using the administrative interface (Administration ->
User Administration). You'll probably want to use a different browser when using a test user since only
one user can be logged in at a time in a browser.
Now use your test users to create blogs, add widgets to your profile or dashboard, post to the wire
(microblogging), and create pages (wiki-like page creation). Make sure to investigate the Settings off the
toolbar. This is where a user sets notification settings and configures tools (which will be blank as none of
the default plugins add controls here).
All of the admin controls are found by clicking Administration on the toolbar. You have already used the
administration section to turn on plugins and you may have created some users with it also. Now use it to
www.almuhibbin.com
10
browse the log or play around with modifying the default profile fields. You will also want to go to the
Tools Administration page and look for plugins that have settings. With the riverdashboard plugin, turn its
dashboard override setting to yes and then notice how the dashboard has changed from an individual
page with widgets to a site-wide activity stream.
Extending Elgg
After satisfying yourself on what Elgg can do out of the box, you will want to try out some themes and
plugins. You can find many plugins and themes at the community site. As is normal with this sort of thing,
the quality varies so be sure to notice what sort of comments a plugin is getting.
Plugins
The easiest way to look through the plugins is to sort by the number of downloads (most popular). Plugins
are installed in the mod directory and activated on the Tools Administration page. You can find
instructions on installing and configuring pluginshere. If you run into any difficulty, be sure to check
the Administration FAQ.
Themes
Themes are plugins that override display aspects of Elgg. They should normally be placed at the bottom
of the plugin list so that the theme runs last. There were some significant changes between Elgg 1.2 and
Elgg 1.5 so beware what versions the theme supports. Also, the default theme is built into Elgg and does
not need to be turned off. Whenever you install a theme, you are overriding all or portions of the default.
Be sure to read the instructions on installing a theme.
Configuration/Themes
Changing the Look and Feel of Elgg
The look and feel of Elgg can be easily changed through the use of themes. A theme is a type of plugin
that overrides display aspects of Elgg.
www.almuhibbin.com
11
Theme installation
A theme is installed just as all plugins are installed. Simply copy the theme's folder to the "mod" directory
in your Elgg install and then activate it from the Elgg admin panel.
Often you will want the theme to be the last plugin to run. The order of the plugins in the Tool
Administration page determines their loading order; to make the theme run last, click the bottom link.
Theme development
Themes
In Elgg, a theme is a plugin. Themes are built and installed just as any other plugin. To begin, it is
advisable to familiarise yourself with Plugins and the Views system.
View extension
The first way is to add extra stuff to an existing view via the extend view function from within your
start.php’s initialisation function.
For example, the following start.php will add mytheme/spotlight to the already existing site spotlight:
<?php
www.almuhibbin.com
12
function mytheme_init()
extend_view('page_elements/spotlight','mytheme/spotlight');
register_elgg_event_handler('init','system','mytheme_init');
?>
View overloading
Plugins can have a view hierarchy, any file that exists here will replace any files in the existing core view
hierarchy... so for example, if my plugin has a file:
/mod/myplugin/views/default/page_elements/spotlight.php
it will replace:
/views/default/page_elements/spotlight.php
This gives you total control over the way elgg looks and behaves. It gives you the option to either slightly
modify or totally replace existing views.
More information
Themes for Elgg are both extremely easy to develop and incredibly powerful. Using themes you can
completely change how an Elgg install looks and feels (and even behaves).
Since there has been a fair amount of discussion of themes on the groups, I thought it would be a good
idea to write a brief post about it.
Themes use two key Elgg concepts - namely, the plugin architecture and the views system.
By far the easiest and flexible way to make a theme for Elgg is to build it as a plugin. This makes it easy
to distribute (since they are self contained) and lets you turn the theme on and off from the admin panel
(making the theming process far less invasive!)
What you must first do is create a new plugin directory under /mod (documented here). In a nutshell;
create a directory in the name of your theme, a new start.php and a new manifest.xml.
www.almuhibbin.com
13
Once you’ve done this you then can start modifying views. This can be done either by extension or by
view overriding.
View extension The first way is to add extra stuff to an existing view via the extend view function from
within your start.php’s initialisation function.
For example, the following start.php will add mytheme/spotlight to the already existing site spotlight:
<?php
function mytheme_init()
extend_view('page_elements/spotlight','mytheme/spotlight');
register_elgg_event_handler('init','system','mytheme_init');
?>
View overriding The next method is to override an existing theme, completely replacing it with the one
provided by your plugin.
View files provided by plugins automatically take precedence over views from the core. So all we have to
do to entirely replace the existing spotlight is to create a new spotlight.php in the appropriate hierarchy.
Now, when we go to the admin panel and activate our theme the spotlight will be replaced by whatever
you put in that file. Simple eh?
Using a combination of these methods means you can replace the entire look and feel of a site very
quickly indeed, although I would suggest that you start slowly since many views do some quite
complicated things.
www.almuhibbin.com
14
Upgrading Elgg
Upgrade Instructions
1. Before upgrading, back up your Elgg database and code. Disable non-core plugins.
2. Download the new version of Elgg from elgg.org.
3. Overwrite your existing Elgg files. Any modifications should have been written within plugins, so
that they are not lost on overwriting. If this is not the case, take care to maintain your
modifications.
4. Visit http://your-elgg-site-URL/upgrade.php
5. Copy htaccess_dist to .htaccess, replacing your existing version. If you modified the default
.htaccess, be sure to move your modifications over to the new one.
Other notes
It is best to try out a new version on a test site before doing an upgrade
As you turn your plugins and theme back on when the upgrade is finished, be careful to note
problems with those plugins so that you can report them to the plugin authors.
Administration Manual
Elgg Administrator's Manual
This is mostly a skeleton at this point. Anyone interested in helping to build out an Administration Manual,
please join the Elgg Documentation group. Right now we are assembling an outline of what to include
in such a manual.
Installing Extensions
Configuration/Plugins
Extending Elgg
Elgg can be easily extended to add extra functionality, this is accomplished through the use of Plugins.
www.almuhibbin.com
15
Elgg.org
The Elgg community site
Plugin installation
To install a plugin, unzip the plugin and copy the plugin's main folder to the "mod" directory in your Elgg
installation.
Installing a theme
The look and feel of Elgg can be easily changed through the use of themes. A theme is a type of plugin
that overrides display aspects of Elgg.
Theme installation
A theme is installed just as all plugins are installed. Simply copy the theme's folder to the "mod" directory
in your Elgg install and then activate it from the Elgg admin panel.
Often you will want the theme to be the last plugin to run. The order of the plugins in the Tool
Administration page determines their loading order; to make the theme run last, click the bottom link.
www.almuhibbin.com
16
Theme development
Configuration/LanguagePacks
Adding Language Support to Elgg
Language packs are available for download at the Elgg community site. There are language packs
for the core and they are usually installed in the languages directory off the elgg root directory. Other
language packs are provided for various plugins. Generally, the authors make it easy to copy those files
into the languages directory of each plugin under the mod directory.
Configuring Cron
Cron
Contents
[hide]
1 What is cron?
2 Elgg and cron
3 How does it work?
4 Example crontab
5 Installation
6 See also
What is cron?
Cron is a program available on Unix-based operating systems that enables users to run commands and
scripts at set intervals or at specific times. A common use of cron is to rotate server logs to prevent them
from becoming too large.
www.almuhibbin.com
17
Elgg has a cron handler for executing functionality periodically. This enables the administrator to setup
jobs to be run periodically. Two common examples would be rotating the system log in the database or
doing garbage collection in the database (compacting the database by removing entries that are no
longer required).
The Elgg cron handler is activated when particular pages are loaded. As an example,
loadinghttp://example.com/pg/cron/hourly/ in a web browser would activate the hourly hook. To
automate this, a cron job is setup to hit those pages at certain times. This is done by setting up a crontab
which is a configuration file that determines when and what cron runs.
The crontab needs to specify a script or command that will hit the Elgg cron pages. Two commonly
available programs for this are GET and wget. You will need to determine the location of one of these on
your server. Your crontab also needs to specify the location of your website.
Note: If you choose the utility "wget", then we suggest that you specify the option "--output-document"
(see manual for wget). For example, under Debian: /usr/bin/wget --output-document=/dev/null. If you don't
do that, files will be created in the home directory of the CRON user. The number of created files will
increase over and over...
Example crontab
# Location of GET
GET='/usr/bin/GET'
www.almuhibbin.com
18
ELGG='http://www.example.com/'
# The crontab
Installation
Take the example and change the ELGG and GET variables according to your server setup. If you have
ssh access to your Linux servers, type crontab -e and enter the crontab details into the text editor that
results. If you already have a crontab setup, you will have to merge the Elgg information into it. If you
don't have ssh access, you will have use a web-based configuration tool to set your crontab. This will vary
depending on hosting provider.
For wget, you should try using the flag --spider so that it does not download the file each time. For more
information on wget, see the wget manual.
www.almuhibbin.com
19
Log rotation
Permission error
You do not have permission to do that, for the following reasons:
The action you have requested is limited to users in one of the groups user, Sysops.
Elgg Documentation has restricted the ability to create new pages. You can go back and edit an
existing page, or log in or create an account.
Garbage collection
Duplicate Installation
Contents
[hide]
1 Introduction
o 1.1 Why Duplicate an Elgg Installation?
o 1.2 What Is Not Covered in This
Tutorial
o 1.3 Before You Start
2 Copy Elgg Code to the Test Server
3 Copy Data to the Test Server
4 Edit engine/settings.php
5 Copy Elgg Database
6 Database Entries
o 6.1 Change the installation path
o 6.2 Change the data directory
o 6.3 Change the site URL
www.almuhibbin.com
20
[edit]Introduction
There are many reasons you may want to duplicate an Elgg installation: moving the site to another
server, creating a test or development server, and creating functional backups are the most common. To
create a successful duplicate of an Elgg site, 3 things need to be copied:
database
data from the data directory
code
Also at least 5 pieces of information must be changed from the copied installation:
engine/settings.php file
.htaccess file
database entry for your site entity
database entry for the installation path
database entry for the data path
This tutorial expects a basic knowledge of Apache, MySQL, and Linux commands. As such, a few things
will not be covered in this tutorial. These include:
* How to backup and restore MySQL databases.
Before you start, make sure the Elgg installation you want to duplicate is fully functional. You will also
need the following items:
* A backup of the live Elgg database.
www.almuhibbin.com
21
Backups of the database can be obtained various ways, including phpMyAdmin, the MySQL official GUI,
and the command line. Talk to your host for information on how to backup and restore databases or use
Google to find information on this.
During this tutorial, we will make these assumptions about the production Elgg site:
* The URL is http://www.myelgg.org/
At the end of the tutorial, our test Elgg installation details will be:
* The URL is http://test.myelgg.org/
www.almuhibbin.com
22
The very first step is to duplicate the production Elgg code. In our example, this is as simple as copying
/var/www/elgg/ to /var/www/elgg_test/.
cp -a /var/www/elgg/ /var/www/elgg_test/
cp -a /var/data/elgg/ /var/data/elgg_test/
If you don't have shell access to your server and have to ftp the data, you may need to change ownership
and permissions on the files.
Note that you also need to delete the views cache on the test server after the copy process. This is a
directory calledviews_simplecache in your data directory and the file called view_paths.
[edit]Edit engine/settings.php
The engine/settings.php file contains the database configuration details. These need to be adjusted for
your new test Elgg installation. In our example, we'll look in /var/www/elgg_test/engine/settings.php and
find the lines that look like this:
// Database username
$CONFIG->dbuser = 'db_user';
// Database password
$CONFIG->dbpass = 'db_password';
// Database name
$CONFIG->dbname = 'elgg_production';
// Database server
$CONFIG->dbhost = 'localhost';
www.almuhibbin.com
23
// If you're sharing a database with other applications, you will want to use this
$CONFIG->dbprefix = 'elgg';
$CONFIG->dbuser = 'db_user';
// Database password
$CONFIG->dbpass = 'db_password';
// Database name
$CONFIG->dbname = 'elgg_test';
// Database server
$CONFIG->dbhost = 'localhost';
// If you're sharing a database with other applications, you will want to use this
$CONFIG->dbprefix = 'elgg';
Now the database must be copied from 'elgg_production' to 'elgg_test'. See your favorite MySQL
manager's documentation for how to make a duplicate database. You will generally export the current
database tables to a file, create the new database, and then import the tables that you previously
exported.
You have two options on updating the values in the database. You could change the values in the export
file or you could import the file and change the values with database queries. One advantage of modifying
www.almuhibbin.com
24
the dump file is that you can also change links that people have created to content within your site. For
example, if people have bookmarked pages using the bookmark plugin, the bookmarks will point to the
old site unless your update their URLs.
[edit]Database Entries
We must now change 4 entries in the database. This is easily accomplished with 4 simple SQL
commands:
[edit]Change the installation path
from elggmetadata where name_id = (SELECT * FROM (SELECT id FROM elggmetastrings WHERE
[edit]Check .htaccess
If you have made changes to .htaccess that modify any paths, make sure you update them in the test
installation.
For this example, you must edit the Apache config to enable a subdomain with a document root of
/var/www/elgg_test/. If you plan to install into a subdirectory of your document root, this step is
unnecessary.
[edit]Run upgrade.php
[edit]Tips
www.almuhibbin.com
25
It is a good idea to keep a test server around to experiment with installing new mods and doing
development work. If you automate restorations to the 'elgg_test' database, changing the $CONFIG
values and adding the follow lines to the end of the elgg_test/engine/settings.php file will allow seamless
re-writing of the MySQL database entries.
$con = mysql_connect($CONFIG->dbhost, $CONFIG->dbuser, $CONFIG->dbpass);
mysql_select_db($CONFIG->dbname, $con);
mysql_query($sql);
print mysql_error();
mysql_query($sql);
print mysql_error();
mysql_query($sql);
print mysql_error();
Managing Users
www.almuhibbin.com
26
Managing Content
Dashboard
Tools
Settings
Administration
Security Guide
Debugging a Site
Development
Finding a developer
www.almuhibbin.com