Build a WebDav-Enabled Intranet With eZ Publish

Get eZ Publish Running

eZ Publish site. In this article, I used the 3.5 version of the system.
I will not cover the eZ Publish installation process, since it's well-covered in other sources, such as the official eZ Publish install documentation . During the installation, you will be asked to select the site type; choose "intranet". The next step in the installer is to select the functionality; there, select:

  • files
  • forum
  • image gallery
  • news

The intranet site type is pre-configured to require users to log in before they can use the site. This differs from the other site types, for which all content is public by default. The image below shows how our intranet site looks immediately after installation.

Post-Installation Configuration

Once eZ Publish is installed you can instantly start to publish content such as articles, files and images. But, we want to change the look and feel of our intranet to fit the corporate profile. Let's do this before we start to add content to the site.

eZ Publish provides many possibilities for the application of design styles, with the easiest being simply to change the CSS. Since eZ Publish is tagged with a so-called "table-less div layout", you can change most of the design just by altering the CSS definitions. If you're not as comfortable with CSS as you'd like to be, see SitePoint's HTML Utopia: Designing Without Tables Using CSS.

For the purpose of this tutorial, we're going to use one of the sample themes that come with the eZ Publish installation. To change the style sheet with one of the 20 supplied themes, go to the Design tab in the Administration interface, and click on "Look and Feel". There, you can change the site tile, edit some meta data, upload a new logo, and change the theme. I changed the title to "SitePoint Intranet" and picked theme 20.

By changing the template, you can make the site look different, but if you have very specific demands that cannot be met through alterations to the CSS file, you can always edit the templates yourself. All the visual parts of eZ Publish are defined in templates and can be changed: the eZ Publish site has detailed information about altering templates.

Toolbars are an eZ Publish mechanism that enable you to configure the boxes with functionality on the top, right, or bottom of the default eZ Publish installation. These are, of course, template-based, so you can alter or add additional toolbars, or change their positions. The Intranet site style comes with a tool that shows the most recently published files by default.

Let's use Toolbar Management, found under the Design tab, to make eZ Publish show the last file, the last news article, and the last images published. To do this, edit the right toolbar, adding three node list tools. Select the source from which the objects are fetched by clicking the item source browse button. Change the number of items to 1, and enter a new title for each box. The screenshot below shows the toolbar configuration page.

Post-Installation Configuration

Once eZ Publish is installed you can instantly start to publish content such as articles, files and images. But, we want to change the look and feel of our intranet to fit the corporate profile. Let's do this before we start to add content to the site.

eZ Publish provides many possibilities for the application of design styles, with the easiest being simply to change the CSS. Since eZ Publish is tagged with a so-called "table-less div layout", you can change most of the design just by altering the CSS definitions. If you're not as comfortable with CSS as you'd like to be, see SitePoint's HTML Utopia: Designing Without Tables Using CSS.

For the purpose of this tutorial, we're going to use one of the sample themes that come with the eZ Publish installation. To change the style sheet with one of the 20 supplied themes, go to the Design tab in the Administration interface, and click on "Look and Feel". There, you can change the site tile, edit some meta data, upload a new logo, and change the theme. I changed the title to "SitePoint Intranet" and picked theme 20.

By changing the template, you can make the site look different, but if you have very specific demands that cannot be met through alterations to the CSS file, you can always edit the templates yourself. All the visual parts of eZ Publish are defined in templates and can be changed: the eZ Publish site has detailed information about altering templates.

Documents such as Word, Excel, Power Point, PDF, etc. are the most common content containers on every intranet. An intranet solution will not be used if uploading and accessing these files is too hard. It is therefore vital that every intranet has a well-planned process to manage this.

The users are used to saving the documents either on their local discs, or on a mounted network drive. We should try to make the transition to saving files on the intranet as smooth as possible. The users can use the intranet as a virtual file system if we use the WebDav functionality in eZ publish. Files that are uploaded via the WebDav Interface will then instantly be accessible on the intranet, and vise versa. The content of known files such as Word and PDF documents will also be indexed in the search engine, so retrieving the documents is simple. The eZ publush site offers information on how to configure the binary file indexer.

As a bonus, all documents in the system are versioned. This means that if you overwrite a file, eZ publish will create a new version of the document; you can roll back to the previous version later if the need arises.

As mentioned earlier, eZ Publish comes with a WebDav interface as standard. To get this interface up and running, we need to create a new virtualhost. To do so, we edit the Apache configuration file, httpd.conf. To add a new virtualhost directive in httpd.conf, you'll need to add a configuration like the one shown below. Just replace the path, /var/www/intranet, with the root of your eZ Publish installation, and the ServerName webdav.no with the DNS name for your WebDav virtualhost.

<VirtualHost *> 

Options FollowSymLinks Indexes

ServerAdmin nospam@ez.no

DocumentRoot /var/www/intranet

RewriteEngine On

RewriteRule !\.(css|jar|js|html|php)$ /var/www/intranet/webdav.php 

ServerName webdav.no

ErrorLog logs/error_log 

CustomLog logs/access_log common

</VirtualHost>

If you do not have access to a DNS server, you can add an entry in your 'hosts' configuration file; alternatively, you could have Apache listen to another port, for example, port 81. If you add the webdav host name to the 'hosts' configuration file, it will not be accessible from any other computer.
The webdav interface also needs to be enabled in eZ Publish. This can be done by altering settings/webdav.ini. Below you find the setting that enables the WebDav interface.

[GeneralSettings] 

EnableWebDAV=true

To access eZ publish via the WebDav interface, you need a WebDav-enabled client. Some WebDav clients include Windows Explorer, OS-X Finder and Konqueror, but there are several other clients as well. In this article I'll use the Konqueror client, as I use KDE under Linux on my workstation.

To access the WebDav interface, simply type "webdav://webdav.no" into the location toolbar. Remember to replace the domain with the domain you used in your configuration. The available "site accesses" should show up as folders. A site access is a virtual site defined in eZ publish; you can define several virtual sites within the same eZ publish installation.

When you enter the intranet site access, you will be prompted for your login and password. Use any valid eZ publish user for the login. From there, you can use eZ publish as a usual remote virtual file system. The tasks the user can perform are controlled by the permissions defined in the role system. So, "Area 51" will not be visible if you do not have permissions to view it.

Since eZ publish has a much more advanced structure than a normal file system, it will show as folders all the objects that are not images or files. This can, however, be configured in the webdav.ini configuration file.

The screenshot below shows the appearance of the WebDav interface as images are browsed in the gallery. It's just like navigating on your local file system: you can drag and drop images, files or folders, and they will automatically be imported into eZ publish and published.

The screenshot below shows the image gallery displayed on the Web page. You can navigate files in the file folder in the same way. Also notice that the page has a new color theme, a new title and new toolbar boxes on the right hand side, resulting from the configuration options we set above.

Any content in eZ publish is controlled by the role-based permission system. To create a restricted area, we establish a folder in the root of the intranet. Go to the administration interface in eZ publish and click on the Content Structure tab. This allows you to navigate the content root. Select "folder" from the drop-down and click the "Create here" button. You will then be redirected to the editing interface for the folder. Enter a name for the folder, for example, "Area 51", and click on the "Send for publishing" button.

This folder will appear in the menu on the user site automatically, but it is not yet restricted in any way. We can assign a new "section" to this folder to make it unique. A section is an eZ publish mechanism that's used, for example, to assign restricted permissions to objects.

First, we need to create this new section. If you go to the Setup tab and click on the Sections menu item, you'll be given the option to create a new section; do so, and name the section "Restricted". To assign the section to the folder, click on the paper clip icon in the section list. In the location browser choose the "Area 51" folder, and click ok.

To verify that the section is assigned correctly, go back to the navigation root by clicking the Content Structure tab. Click on Detailed View of the sub items. The screenshot below shows this detailed view. Notice that the section assigned to "Area 51" is restricted. Any content published under this folder will inherit the section information, and the content will therefore be restricted in the same way.

Creating a User

We need to create a new user since, by default, we have only the administrator user, who has permissions to view any object. To create a new user, go to the "User Accounts" tab and click on the "Guest Accounts" user group. Select user from the drop-down and click on the "Create Here" button. Then, enter the information about the user and click "Send for publishing". You can now log in with this new user account; notice that you cannot access the "Area 51" folder any more. The reason for this is that guest users are assigned the anonymous role, which allows them to read only the content in the standard section.

Notice that this is the same kind of editing interface you used when we created the "Area 51" folder. This is because all the content in eZ publish is handled in the same way, and a user is just a particular type of content. If you like, you can define several different user types with different attributes. You can, for example, add phone number and address information to the user accounts.

A Word on Policies and Roles

The role-based permission system in eZ publish is based on roles. A role consists of a list of policies. A policy defines access to something, for example, to read articles, remove folders or log in to the administration interface. By default, users do not have access to anything unless that access is specifically defined in an assigned role. One role can be assigned to one or more users or groups.

You can create a hierarchy of user groups simply by adding a new user group under an existing group. Any role assigned to a user group is inherited by sub-users or -groups (this feature can be restricted to one level of inheritance in the configuration files if desired).

We have looked at how the free, open source content management system eZ publish can be used to power a typical intranet site. The CMS has the essential functionality required by an intranet, including an alternative central document storage and integrated search. And all of it can be achieved with very little effort. If you have access to an Apache Web server, you can configure eZ publish as an intranet site within 30 minutes.

If you do not have access to an Apache Web server, but still want to try out eZ publish, you can use the eZ publish demo site. The username is "admin" and the password is "publish". This site is publicly available with administration permissions. It is reset every two hours, so you can test any features you wish. But be aware that quite a few people might test the installation at the same time.

This article has also been published at SitePoint.

Powered by eZ Publish™ CMS Open Source Web Content Management. Copyright © 1999-2014 eZ Systems AS (except where otherwise noted). All rights reserved.

eZ debug

Timing: Jan 18 2025 03:02:18
Script start
Timing: Jan 18 2025 03:02:18
Module start 'layout'
Timing: Jan 18 2025 03:02:18
Module start 'content'
Timing: Jan 18 2025 03:02:18
Module end 'content'
Timing: Jan 18 2025 03:02:18
Script end

Main resources:

Total runtime0.1194 sec
Peak memory usage4,096.0000 KB
Database Queries42

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0053 588.0469152.6406
Module start 'layout' 0.00530.0024 740.687539.4766
Module start 'content' 0.00770.1105 780.1641677.2656
Module end 'content' 0.11820.0012 1,457.429720.2813
Script end 0.1194  1,477.7109 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00322.6817160.0002
Check MTime0.00131.0600160.0001
Mysql Total
Database connection0.00060.470510.0006
Mysqli_queries0.035729.9228420.0009
Looping result0.00030.2132400.0000
Template Total0.091576.620.0457
Template load0.00282.351020.0014
Template processing0.088674.210620.0443
Template load and register function0.00010.107010.0001
states
state_id_array0.00262.208650.0005
state_identifier_array0.00191.551560.0003
Override
Cache load0.00332.7265850.0000
Sytem overhead
Fetch class attribute name0.00181.465450.0004
Fetch class attribute can translate value0.00010.052940.0000
class_abstraction
Instantiating content class attribute0.00000.012850.0000
XML
Image XML parsing0.00554.586240.0014
General
dbfile0.00514.2865180.0003
String conversion0.00000.006840.0000
Note: percentages do not add up to 100% because some accumulators overlap

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1node/view/full.tplfull/article.tplextension/sevenx/design/simple/override/templates/full/article.tplEdit templateOverride template
1content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
5content/datatype/view/ezxmltags/header.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/header.tplEdit templateOverride template
9content/datatype/view/ezxmltags/link.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/link.tplEdit templateOverride template
2content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
23content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
1content/datatype/view/ezxmltags/li.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/li.tplEdit templateOverride template
1content/datatype/view/ezxmltags/ul.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/ul.tplEdit templateOverride template
4content/datatype/view/ezxmltags/embed.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/embed.tplEdit templateOverride template
4content/view/embed.tplembed/image.tplextension/sevenx/design/simple/override/templates/embed/image.tplEdit templateOverride template
4content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
6content/datatype/view/ezxmltags/newpage.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/newpage.tplEdit templateOverride template
2content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 64
 Number of unique templates used: 14

Time used to render debug report: 0.0001 secs