This article is relevant for advanced content managers and webmasters responsible for setting up and managing sections in an eZ Publish site. This is important in situations such as defining structural content segmentation and setting up a protected area. It is useful when managing webshop discount rules, since one of the discount rule limitations is the Section limitation. Also, user permissions can be applied based on many criteria, of which sections is one of them.
Note that this article assumes that you have administrator-like permissions in order to access the Setup tab in the Administration Interface. For information about the general layout of the Administration Interface, see the eZ Publish Content Management Basics book. It also assumes that you have knowledge about the content node tree and the concept of multiple locations.
This article was written to be compatible with eZ Publish 4.0, although the concepts and procedures should be similar for other versions.
On its own, a section consists of only a section ID, a name and a navigation part. It is best to think about a section in terms of how its ID is used. Consequently, the most applicable definition is "a virtual collection of nodes that belong together". In other words, it is a logical hierarchy or structure, different than the content node tree but applied to the nodes within it, as shown in the illustration below.
Segmentation example
The following functionality is provided through the eZ Publish section mechanism:
A section ID is an identification number that can be assigned to an object and denotes which section that object belongs to. It is stored in a special-purpose attribute within a content object, and you will not see this attribute in the main editing window. A section can be assigned to many objects, but a single object can have only one section.
It is the assignment of different section IDs to different objects that enables you to have a logical hierarchy in parallel with your sitemap-like content hierarchy. Your site can have as many virtual collections of nodes as you have section IDs.
Each section ID is also associated with a more user-friendly name, such as "Standard" or "Restricted", and a navigation part, such as the Content structure or Webshop tab. The name is used for easy identification of sections in the Administration Interface. The navigation part determines which main menu tab is accessed when you work with an object. In other words, when an object is requested in the Administration Interface, the system looks up the section that the object belongs to; the system then looks up the navigation part of that section and then displays the object in the tab as specified by the navigation part.
eZ Publish comes with a set of built-in sections. The following list shows the built-in sections for sites with the Website Interface. Note that the first five sections correspond to the top-level nodes, although the section corresponding to the Content top-level node is named "Standard".
The Setup section is used to isolate configuration-related objects from ordinary content. This is achieved in conjunction with the permission and template systems. Similarly, the Design section is associated with the Design tab. It isolates template and look settings (such as the site title and URL, labels and footer text) from ordinary content and other configuration. The Restricted section is a protected area of the site, as achieved in conjunction with the permission system. By default, it is applied to a partner area, which can only be accessed by users in the Partner user group (or higher). Additional sections can be added as needed, as described later.
When an object is first created, but is not yet published and thus has a "Draft" status, its section is set to the default Standard section. Recall that an object is not visible to site visitors, nor does it show up in the left menu of the Administration Interface, until it has been published. In other words, a Draft object does not have a location within the hierarchy, and it is only accessible to the user creating it. As a result, it does not matter what the section ID is at this time.
When the object is published, usually when you click the Send for publishing button, it automatically inherits the section ID assigned to the object encapsulated by its parent node. For example, if you create and publish a new object within a folder belonging to the Media section, the Media section is automatically assigned to the newly created object.
The picture is slightly more complicated when multiple locations exist for the parent node's encapsulated object. Cross-publishing is usually used only for non-container objects such as articles and documentation pages or product sheets, since adding a location does not include a node's subtree. In these cases, the section ID inheritance follows the main node of the object referenced by the parent node.
There are three windows that display the name of the section to which an object belongs. These are the Details, Sub items (with the detailed list type toggled) and Section windows.
The Details window is shown in the main area of the Administration Interface when viewing some content (and when the corresponding switch has been selected). This displays information about the selected node and the object that it encapsulates:
Details window
The entry in the third column shows the section name. Clicking it brings up the Section view interface, which displays information about the section, the roles, users, and user groups associated with the section, and the objects within the section.
The Sub items window is shown at the bottom of the main area of the Administration Interface when viewing some content. When the detailed list type is selected (in the top right of the window), the sixth column shows the section name for each of the children of the object being viewed. Clicking one of the names brings up the Section view interface, as previously described.
Sub items window
The Section window is shown in the bottom left area of the Object Edit Interface. This displays the name of the currently assigned section, and lets you change it. The number in square brackets in the title bar shows how many available sections you can choose from.
The Sections interface is your most important tool for managing sections. From here you can bring up the Section editing interface and the Section view interface. You can open the Sections interface by clicking on the Sections link in the left menu of the Setup tab. This interface is shown below:
Sections interface
The Sections interface has a header bar showing how many unique sections there are; a main area listing the name and ID of these sections; and a toolbar at the bottom. If you have many sections, you can toggle the number of sections that are listed per page by clicking the numbers "10", "25" and "50" in the top left corner below the header bar. Section management tasks such as creating, editing, assigning and deleting are carried out by using the buttons on the toolbar and the right side of the listing, along with the checkboxes to the left of the section listing.
To create a new section, all you have to do is to provide a name and a navigation part, as explained in the procedure below:
1. Click the New section button in the Sections interface. This will take you to the Section editing interface for the new section:
Section editing interface
2. Enter a name for the new section in the Name input field.
3. Select a navigation part from the dropdown list. You will recognize the names of the Administration Interface main menu tabs within this list. Recall that the navigation part dictates which tab is accessed when working with objects in the section.
4. Click the OK button to create the section or the Cancel button to abort the procedure.
The newly created section will show up in the section listing. It will automatically be assigned the next unused section ID. As seen in the screenshot below, our new section is titled "My new section" and has an ID of "7".
Section added
To assign a section to a subtree, follow the procedure below. Note that you cannot assign a section directly when creating or editing the section itself.
You can also assign a section to a subtree by opening the target object for editing and changing the section in the Section window before publishing a new version. However, if you are not going to make any content changes to the object, it is best to use the Sections interface.
This article has introduced the concept of sections and described how to work with them in the Administration Interface. In the next article, we will talk about managing users, user groups, roles, and policies, including an example on creating a protected section.
Timing: | Jan 18 2025 02:48:37 |
Script start | |
Timing: | Jan 18 2025 02:48:37 |
Module start 'layout' | |
Timing: | Jan 18 2025 02:48:37 |
Module start 'content' | |
Timing: | Jan 18 2025 02:48:37 |
Module end 'content' | |
Timing: | Jan 18 2025 02:48:37 |
Script end |
Total runtime | 0.1630 sec |
Peak memory usage | 4,096.0000 KB |
Database Queries | 54 |
Checkpoint | Start (sec) | Duration (sec) | Memory at start (KB) | Memory used (KB) |
---|---|---|---|---|
Script start | 0.0000 | 0.0063 | 589.5703 | 152.6406 |
Module start 'layout' | 0.0063 | 0.0036 | 742.2109 | 39.4766 |
Module start 'content' | 0.0100 | 0.1516 | 781.6875 | 756.5781 |
Module end 'content' | 0.1616 | 0.0015 | 1,538.2656 | 20.7969 |
Script end | 0.1630 | 1,559.0625 |
Accumulator | Duration (sec) | Duration (%) | Count | Average (sec) |
---|---|---|---|---|
Ini load | ||||
Load cache | 0.0033 | 2.0302 | 16 | 0.0002 |
Check MTime | 0.0014 | 0.8331 | 16 | 0.0001 |
Mysql Total | ||||
Database connection | 0.0009 | 0.5655 | 1 | 0.0009 |
Mysqli_queries | 0.0517 | 31.6967 | 54 | 0.0010 |
Looping result | 0.0004 | 0.2404 | 52 | 0.0000 |
Template Total | 0.1367 | 83.9 | 2 | 0.0684 |
Template load | 0.0021 | 1.2782 | 2 | 0.0010 |
Template processing | 0.1346 | 82.5805 | 2 | 0.0673 |
Template load and register function | 0.0001 | 0.0662 | 1 | 0.0001 |
states | ||||
state_id_array | 0.0057 | 3.5001 | 8 | 0.0007 |
state_identifier_array | 0.0032 | 1.9722 | 9 | 0.0004 |
Override | ||||
Cache load | 0.0034 | 2.0947 | 148 | 0.0000 |
Sytem overhead | ||||
Fetch class attribute name | 0.0017 | 1.0192 | 8 | 0.0002 |
Fetch class attribute can translate value | 0.0001 | 0.0484 | 7 | 0.0000 |
class_abstraction | ||||
Instantiating content class attribute | 0.0000 | 0.0072 | 8 | 0.0000 |
XML | ||||
Image XML parsing | 0.0094 | 5.7887 | 7 | 0.0013 |
General | ||||
dbfile | 0.0089 | 5.4737 | 24 | 0.0004 |
String conversion | 0.0000 | 0.0061 | 4 | 0.0000 |
Note: percentages do not add up to 100% because some accumulators overlap |
Usage | Requested template | Template | Template loaded | Edit | Override |
---|---|---|---|---|---|
1 | node/view/full.tpl | full/article.tpl | extension/sevenx/design/simple/override/templates/full/article.tpl | ||
1 | content/datatype/view/ezxmltext.tpl | <No override> | extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tpl | ||
29 | content/datatype/view/ezxmltags/paragraph.tpl | <No override> | extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tpl | ||
8 | content/datatype/view/ezxmltags/link.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/link.tpl | ||
4 | content/datatype/view/ezxmltags/newpage.tpl | <No override> | extension/community/design/standard/templates/content/datatype/view/ezxmltags/newpage.tpl | ||
7 | content/datatype/view/ezxmltags/embed.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/embed.tpl | ||
7 | content/view/embed.tpl | embed/image.tpl | extension/sevenx/design/simple/override/templates/embed/image.tpl | ||
7 | content/datatype/view/ezimage.tpl | <No override> | extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tpl | ||
6 | content/datatype/view/ezxmltags/emphasize.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/emphasize.tpl | ||
11 | content/datatype/view/ezxmltags/li.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/li.tpl | ||
3 | content/datatype/view/ezxmltags/ul.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/ul.tpl | ||
9 | content/datatype/view/ezxmltags/header.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/header.tpl | ||
18 | content/datatype/view/ezxmltags/strong.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/strong.tpl | ||
1 | content/datatype/view/ezxmltags/line.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/line.tpl | ||
1 | content/datatype/view/ezxmltags/ol.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/ol.tpl | ||
1 | print_pagelayout.tpl | <No override> | extension/community/design/community/templates/print_pagelayout.tpl | ||
Number of times templates used: 114 Number of unique templates used: 16 |
Time used to render debug report: 0.0001 secs