Architecture

Table of contents

/*<![CDATA[*/ div.rbtoc1597330884914 {padding: 0px;} div.rbtoc1597330884914 ul {list-style: disc;margin-left: 0px;} div.rbtoc1597330884914 li {margin-left: 0px;padding-left: 0px;} /*]]>*/

Architecture

PrestaShop uses Model-View-Controller (MVC) for its software architecture, which is often used in web applications where webpages are dynamically generated. MVC isolates application logic from the input and presentation, so that they can be separately developed, tested and maintained. A view provides the user interface presented to the customer in the browser. A controller receives input from the browser, decides what to do with it and then passes information to models that carry out specific tasks. In PrestaShop, the models are in the /classes directory, the views are in the /themes directory and the controllers are in the /controllers directory. The files in the root directory are the public interface used to call the controllers.

All these files have a warning at the top of them telling you not to modify them if you wish to upgrade PrestaShop to newer versions in the future. That is because PrestaShop allows you to override its classes and controllers in the override directory. By overriding classes and controllers instead of modifying them, you can safely overwrite them with new versions in the future without having to worry about losing any changes you have made. PrestaShop’s modules also have the same warning, since they can be overridden in a theme by mirroring the module’s directory inside the theme, e.g. themes/themename/modules/blockuserinfo/blockuserinfo.tpl.

Models

The models in the /classes directory of PrestaShop are all PHP classes that extend the ObjectModel class. This class gives the model a unique ID and a table name and identifier to link it to a row in the database. For example, in the Address model, the ID is a positive integer, the table name is address and the table identifier is id_address. The ObjectModel class also defines the model’s field sizes and the functions in the Validate class that are used to validate fields. It also links the model to the webservice feature and provides a cache. The model class names all end in Core so they can be overridden in the /override/classes directory. Here is a description of each PrestaShop model:

Model Filename

Description

Address.php

Customer, manufacturer and supplier addresses.

AddressFormat.php

Address format for each country.

Alias.php

Aliases used to redirect typos in the search box in the Front Office.

Attachment.php

File attachments that are added to products.

Attribute.php

Product attributes that display as dropdowns on the product page.

AttributeGroup.php

Product attribute groups that display as labels for the dropdowns.

Carrier.php

Carriers used to ship products to customers.

Cart.php

Customer carts including those that didn’t result in an order.

Category.php

Product categories used to organise products.

CMS.php

CMS pages used to display information.

CMSCategory.php

Categories used to organise CMS pages.

Combination.php

Combinations of product attributes and their prices.

Configuration.php

All of PrestaShop’s configuration settings.

Connection.php

Statistics about page visits.

ConnectionsSource.php

Statistics about the source of page visits.

Contact.php

Departments that can be selected on the contact form.

Country.php

Countries used in addresses.

Currency.php

Currencies used in prices.

Customer.php

Customers who have registered.

CustomerMessage.php

Individual messages sent between customers and employees.

CustomerThread.php

Threads of messages sent between customers and employees.

DateRange.php

Date ranges used in page visits.

Delivery.php

Links between carriers, zones and ranges.

Discount.php

Vouchers that can be used by customers.

Employee.php

Employees who can log in to the Back Office.

Feature.php

Product feature labels on the product page.

FeatureValue.php

Product feature values on the product page.

Group.php

Customer groups and display methods.

GroupReduction.php

Customer group reductions.

Guest.php

Customers who haven’t registered.

Hook.php

Hooks where modules can be placed.

Image.php

Product images.

ImageType.php

Image thumbnail sizes.

Language.php

Languages used on the website.

Manufacturer.php

Product manufacturers.

Message.php

Customer messages sent from the order history page.

Meta.php

Meta-information of PrestaShop’s pages.

Order.php

Customer order information.

OrderDetail.php

Customer order products.

OrderDiscount.php

Customer order vouchers.

OrderHistory.php

Customer order status history.

OrderMessage.php

Prefilled order messages that employees can use.

OrderReturn.php

Merchandise returns.

OrderReturnState.php

Merchandise return statuses.

OrderSlip.php

Credit slips.

OrderState.php

Order statuses.

Pack.php

Product packs (extends Product class).

Page.php

PrestaShop’s non-CMS pages.

PaymentCC.php

Order credit card information.

Product.php

Product information.

ProductDownload.php

Downloadable products.

Profile.php

Profiles used to restrict employee access.

QuickAccess.php

Shortcuts in the dropdown at the top of the Back Office.

RangePrice.php

Carrier price ranges.

RangeWeight.php

Carrier weight ranges.

Referrer.php

Affiliate program data.

SearchEngine.php

Search engines tracked when guests visit.

Scene.php

Image maps that link products to banners.

Shop.php

Multiple shops (not yet implemented).

SpecificPrice.php

Specific prices including quantity discounts.

State.php

States used in addresses.

Store.php

Stores used in the store locator module.

StockMvt.php

Stock movements used to track employees’ changes.

StockMvtReason.php

Stock movement reasons.

SubDomain.php

Subdomains used by PrestaShop’s cookie.

Supplier.php

Product suppliers.

Tab.php

Back Office tabs and positions.

Tag.php

Product tags used by the tag cloud module.

Tax.php

Tax names and rates.

TaxRules.php

Specific tax rules.

TaxRulesGroup.php

Groups of the tax rules.

Webservice.php

External access to the database.

Zone.php

Zones used by the carriers.

Here’s a description of the other PrestaShop classes that do not store data in the database:

Class Filename

Description

AdminTab.php

Provides basic Back Office tab functionality.

Backup.php

Creates backups of the PrestaShop database.

Blowfish.php

Encrypts the PrestaShop cookie with Blowfish.

Cache.php

Provides basic caching functionality.

CacheFS.php

Perform File System caching.

CarrierModule.php

Provides basic shipping module functionality.

Chart.php

Creates charts.

ControllerFactory.php

Calls a controller and any overrides.

Cookie.php

Reads and writes PrestaShop’s cookie.

Customization.php

Gets product customization.

Db.php

Provides basic database functionality.

FrontController.php

Initialises Smarty variables and other basic controller code.

HelpAccess.php

Displays help tooltips and documentation.

ImportModule.php

Provides basic shop import functionality.

Link.php

Gets links to products, categories, CMS pages, etc.

LocalizationPack.php

Installs localisation packs.

Mail.php

Sends emails.

MCached.php

Performs Memcaching.

Module.php

Provides basic module functionality.

ModuleGraph.php

Provides module graph functionality.

ModuleGraphEngine.php

Provides module graph engine functionality.

ModuleGrid.php

Provides module grid functionality.

ModuleGridEngine.php

Provides module grid engine functionality.

MySQL.php

Provides access to a MySQL database.

PaymentModule.php

Provides basic payment module functionality.

PDF.php

Creates PDF invoices and delivery slips.

ProductSale.php

Manages product sale numbers.

Rijndael.php

Encrypts PrestaShop’s cookie using mcrypt.

Search.php

Performs searchs on products.

Validate.php

Validates data.

Here’s a description of the ObjectModel members:

Member Name

Description

$_cache

Stores a cache of all object.

$fieldsRequired

The required fields.

$fieldsRequiredDatabase

The required fields that have been overridden by an employee.

$fieldsSize

The maximum size of each non-translatable field.

$fieldsSizeLang

The maximum size of each translatable field.

$fieldsValidate

Array of validation functions that check non-translatable fields.

$fieldsValidateLang

Array of validation functions that check translatable fields.

$id

The integer ID of the object, e.g. 1

$identifier

The name of the ID of the object, e.g. id_address

$table

The main table used by the object.

$tables

All the tables used by the object.

$webserviceParameters

The webservice parameters for the object.

Here’s a description of the ObjectModel functions:

Function Name

Description

__construct()

Loads an object with the specified ID and language.

add()

Adds the current object to the database.

clearCache()

Used to clear the cache whenever an object is modified.

delete()

Deletes the current object from the database.

deleteSelection()

Deletes the specified list of objects from the database.

displayFieldName()

Gets the unique name of a field.

getFields()

Gets the non-translatable fields for the object.

getFieldsRequiredDatabase()

Gets the required fields overridden by an employee.

getTranslationFields()

Gets the translatable fields for the object.

getValidationRules()

Gets the validation rules for the object.

getWebserviceObjectList()

Gets a list of all webservice objects.

getWebserviceParameters()

Gets the webservice parameters for the object.

save()

Saves the object, adding it or updating it as necessary.

toggleStatus()

Toggles whether the object is visible on the website.

update()

Updates the current object in the database.

validateController()

Checks whether required fields have valid data.

validateFields()

Checks whether required non-translatable fields have valid data.

validateFieldsLang()

Checks whether required translatable fields have valid data.

Here’s a description of the validation functions:

Function Name

Description

isAbsoluteUrl()

isAddress()

Is an address line (^!<>?=+@{}_$% not allowed).

isAnything()

Accepts anything without doing any validation.

isBirthDate()

Is empty date or a date in yyyy-mm-dd format at least 9 years ago.

isBool()

Is a Boolean value 0 or 1.

isBool_Id()

Is a Boolean id (0 or 1 followed by an underscore, then digits).

isCarrierName()

Is a valid carrier name (^<>;=#{} not allowed).

isCatalogName()

Is a catalog name (^<>;=#{} not allowed).

isCityName()

Is a city name (^!<>;?=+@#"°{}_$% not allowed).

isCleanHtml()

Is HTML without script tags or events.

isColor()

Is a colour keyword or hexadecimal code.

isConfigName()

Is a configuration key (alphanumeric and hypens).

isCookie()

Is an instance of the Cookie class.

isCoordinate()

Is a coordinate (up to 6 digits, a period, then up to 6 digits).

isCountryName()

Is a country name (lowercase letters, spaces and hyphens).

isDate()

Is a date in yyyy-mm-dd format.

isDateFormat()

Is a valid date in yyyy-mm-dd format.

isDiscountName()

Is a valid voucher code (3-32 characters except ^!<>,;?=+()@"°{}_$%:).

isDistanceUnit()

Is a distance unit (up to 2 letters).

isDni()

Is a valid DNI, NIF, CIF or NIE code and return an error code (deprecated).

isDniBool()

Whether an error code was returned from isDni (deprecated).

isEan13()

Is a 13-digit EAN13 code.

isEmail()

Is an email of the form username@domain.tld.

isFileName()

Is a valid filename (alphanumeric, hyphens, underscores and periods).

isFloat()

Is a valid float value.

isGenderIsoCode()

Is a valid gender ISO code (0, 1 [male], 2 [female] or 9 [unknown]) (deprecated).

isGenderName()

Is a valid gender name (lowercase alphanumeric and period) (deprecated).

isGenericName()

Is a generic name (^<>;=#{} not allowed).

isGranularityValue()

Is a date format using lowercase d, m and y (deprecated).

isHookName()

Is a valid hook name (lowercase alphanumeric and hyphens).

isImageSize()

Is an image size (up to 4 digits).

isIcoFile()

Is a valid filename ending in .ico (deprecated).

isIconFile()

Is a valid filename ending in .gif, .jpg, .jpeg or .png (deprecated).

isImageTypeName()

Is a valid image type name (lowercase alphanumeric, spaces and hyphens).

isInt()

Is an integer.

isIp2Long()

Is a valid IP address.

isLabel()

Is a customisation field label (^{}<> allowed).

isLangIsoCode()

Is a language iso code (2 or 3 alphanumeric).

isLanguageFileName()

Is a language filename (2 or 3 alphanumeric followed by .gzip).

isLanguageIsoCode()

Is a valid language ISO code (2 or 3 lowercase letters).

isLinkRewrite()

Is a rewritten link (lowercase alphanumeric, hypens and underscores).

isLoadedObject()

Is a variable is an object and has a valid ID.

isLocalizationPackSelection()

Is "states", "taxes", "currencies", "languages" or "units".

isMailName()

Is a valid mail name (^<>;=#{} not allowed).

isMailSubject()

Is a valid mail subject (^<>{} not allowed).

isMessage()

Is a message (<>{} not allowed except <br />).

isMd5()

Is a valid MD5 hash.

isModuleName()

Is a valid module name (lowercase alphanumeric and hyphens).

isModuleUrl()

Is a valid URL to a zip, tgz or tar.gz file.

isName()

Is a valid name (^0-9!<>,;?=+()@#"°{}_$%: not allowed).

isOptFloat()

Is an empty field or valid float value.

isOptId()

Is an empty field or a positive integer (deprecated).

isOrderWay()

Is a valid order way 'ASC', 'DESC', 'asc' or 'desc'.

isOrderBy()

Is a valid order (lowercase alphanumeric, hyphens and underscores).

isPasswd()

Is a customer password (5-32 alphanumeric and (). -!@#$%\^&*).

isPasswdAdmin()

Is an employee password (8-32 alphanumeric and (). -!@#$%\^&*).

isPostCode()

Is a postcode (alphanumeric and hyphens).

isPrice()

Is a valid price (up to 10 digits, a period, then up to 9 digits).

isPriceDisplayMethod()

Is a price display method (must be PS_TAX_EXC or PS_TAX_INC values).

isProtocol()

Is the protocol http or https (deprecated).

isReductionType()

Is a reduction type "amount" or "percentage".

isReference()

Is a reference (^<>;={} not allowed).

isSerializedArray()

Is a serialised array.

isSha1()

Is a valid SHA1 hash.

IsSortDirection()

Is a sort direction 'ASC' or 'DESC'.

isStateIsoCode()

Is a valid state ISO code (up to 4 lowercase alphanumeric).

isString()

Is a string.

isSubDomainName()

Is a subdomain name.

isTableOrIdentifier()

Is a table name (lowercase alphanumeric, hyphens and underscores).

isTabName()

Is a valid tab name (alphanumeric, hyphens and underscores).

isTagsList()

Is a tags list (^!<>;?=+#"°{}_$% not allowed).

isTplFileName()

Is a valid template filename (alphanumeric, hyphens and underscores) (deprecated).

isTplName()

Is a valid template name (lowercase alphanumeric and hyphens).

isUnsignedFloat()

Is a valid positive float value.

isUnsignedId()

Is a positive integer.

isUnsignedInt()

Is a positive integer.

isUrl()

Is a valid URL.

isUpc()

Is a 12-digit UPC code.

isValidSearch()

Is a valid search (up to 64 characters except ^<>;=#{}).

isValuesList()

Is a MySQL query values list (deprecated).

isVoucherDescription()

Is a voucher description (<>{} not allowed except <br />).

isWeightUnit()

Is a weight unit (up to 3 letters).

isZipCodeFormat()

Is a zip code format (using uppercase letters N, L, C, spaces and hyphens).

isZoneName()

Is a zone name (lowercase letters, hyphens, spaces and parentheses) (deprecated).

Views

PrestaShop uses Smarty templating for its views, which supplements HTML with a flexible syntax to add variables, if statements, loops and other PHP code to the view. Most of the TPL files have the same name as the PHP file that calls them. For example, 404.php calls 404.tpl. Here is a description of PrestaShop’s templates:

View Filename

Description

404.tpl

The “Page not found” page.

address.tpl

The address form.

addresses.tpl

Lists customer addresses.

authentication.tpl

The login and registration forms.

best-sales.tpl

Lists the best-selling products.

breadcrumb.tpl

The breadcrumb bar at the top of the centre column.

category-cms-tree.tpl

Used by sitemap.php to list CMS pages on the sitemap.

category-tree-branch.tpl

Used by sitemap.php to list subcategories on the sitemap.

category.tpl

Lists a category’s subcategories and products.

cms.tpl

Displays a CMS page.

contact-form.tpl

The customer service contact form.

discount.tpl

Lists vouchers available to a customer.

errors.tpl

Displays error messages.

footer.tpl

The footer at the bottom of the website.

guest-tracking.tpl

The guest order tracking form.

header.tpl

The header at the top of the website.

history.tpl

Lists a customer’s orders.

identity.tpl

The customer’s personal information form.

index.tpl

The center column on the homepage.

maintenance.tpl

The maintenance page when the shop is disabled.

manufacturer-list.tpl

Lists manufacturers.

manufacturer.tpl

Lists the products of a manufacturer.

my-account.tpl

The account page of a customer.

new-products.tpl

Lists new products.

order-address.tpl

Used by order.php and order-opc.php for the address step.

order-carrier.tpl

Used by order.php and order-opc.php for the carrier step.

order-confirmation.tpl

The order confirmation page.

order-detail.tpl

Used by guest-tracking.php and history.php for order details.

order-follow.tpl

Lists a customer’s merchandise returns.

order-opc.tpl

The one-page checkout page.

order-opc-new-account.tpl

Used by order-opc.php for the login and new account forms.

order-payment.tpl

Used by order-opc.php for the payment step.

order-return.tpl

Displays information about a merchandise return.

order-slip.tpl

Lists a customer’s credit clips.

order-steps.tpl

Used by order.php to display the order steps.

pagination.tpl

The page navigation at the bottom of the centre column.

password.tpl

The lost password form.

prices-drop.tpl

Lists discounted products.

product-compare.tpl

Adds product comparison checkboxes to the product listings.

product-list.tpl

Lists products.

product-sort.tpl

The “Sort by” form at the top of product listings.

product.tpl

Information about a product.

products-comparison.tpl

The product comparison page.

restricted-country.tpl

Displays a message when a customer has been restricted by country.

scenes.tpl

Used by category.php to display banners that link to products.

search.tpl

List the search results page.

shopping-cart-product-line.tpl

Used by shopping-cart.tpl to display a product line in the cart summary.

shopping-cart.tpl

Used by order.php and order-opc.php to display the cart summary.

sitemap.tpl

The sitemap of the website.

store_infos.tpl

The store opening hours.

stores.tpl

The store information and Google map.

supplier-list.tpl

Lists suppliers.

supplier.tpl

Lists products from a supplier.

Controllers

Here’s a list of PrestaShop’s controllers and a description of what each of them do:

Controller Name

Description

AddressController.php

Used by address.php to edit a customer’s address.

AddressesController.php

Used by addresses.php to get a customer’s addresses.

AuthController.php

Used by authentication.php to manage customer login.

BestSalesController.php

Used by best-sales.php to get the best-selling products.

CartController.php

Used by cart.php to manage the customer’s cart.

CategoryController.php

Used by category.php to get product categories.

CMSController.php

Used by cms.php to get a CMS page.

CompareController.php

Used by products-comparison.php to compare products.

ContactController.php

Used by contact-form.php to send messages to employees.

DiscountController.php

Used by discount.php to get vouchers available to a customer.

GuestTrackingController.php

Used by guest-tracking.php to manage guest orders.

HistoryController.php

Used by history.php to get a customer’s orders.

IdentityController.php

Used by identity.php to get a customer’s personal information.

IndexController.php

Used by index.php to display the homepage.

ManufacturerController.php

Used by manufacturer.php to get manufacturers and their products.

MyAccountController.php

Used by my-account.php to display a customer’s account page.

NewProductsController.php

Used by new-products.php to get a list of new products.

OrderConfirmationController.php

Used by order-confirmation.php to manage the order confirmation page.

OrderController.php

Used by order.php to manage the five-step checkout pages.

OrderDetailController.php

Used by order-detail.php to get a single customer order.

OrderFollowController.php

Used by order-follow.php to get a list of a customer’s merchandise returns.

OrderOpcController.php

Used by order-opc.php to manage the one-page checkout page.

OrderReturnController.php

Used by order-return.php to get a single merchandise return.

OrderSlipController.php

Used by order-slip.php to get a list of a customer’s credit slips.

PageNotFoundController.php

Used by 404.php to manage the “Page not found” page.

ParentOrderController.php

Used by OrderController.php and OrderOpcController.php for shared code.

PasswordController.php

Used by password.php to allow a customer to reset a lost password.

PricesDropController.php

Used by prices-drop.php to get a list of discounted products.

ProductController.php

Used by product.php to get a product.

SearchController.php

Used by search.php to perform a search and get the results.

SitemapController.php

Used by sitemap.php to get the sitemap of the website.

StoresController.php

Used by stores.php to get store information and Google map coordinates.

SupplierController.php

Used by supplier.php to get suppliers and their products.

All controllers in PrestaShop extend the FrontController class. Here’s a description of the FrontController members:

Member Name

Description

$auth

Whether a customer must log in before they can access the page.

$authRedirection

The page redirected to after logging in.

$cart

The current customer’s or guest’s cart.

$cookie

Used to access PrestaShop’s cookie variables.

$currentCustomerGroups

Caches the current customer’s groups.

$errors

An array of errors that have occurred.

$guestAllowed

Whether a customer who has signed out can access the page.

$initialized

Whether the init() function has been called.

$iso

The iso code of the currently selected language.

$link

Used to generate PrestaShop links.

$n

The number of items per page.

$orderBy

The field used to sort.

$orderWay

Whether to sort ascending or descending ("ASC" or "DESC").

$p

The current page number.

$smarty

Used to access Smarty variables and functions.

$ssl

Whether the page is loaded using SSL when it is available.

Here’s a description of the controller functions in the order they are executed:

Function Name

Description

__construct()

Sets all the controller’s member variables.

preProcess()

Assigns variables that can be used in the header template file.

setMedia()

Adds all JavaScript and CSS specific to the page so it can be combined, compressed and cached.

displayHeader()

Calls the header template file.

process()

Assigns variables that can be used by the content template file.

displayContent()

Calls the content template file.

displayFooter()

Calls the footer template file.

Last updated