ProcessWire

ProcessWire
Initial release2007
Stable release
3.0.229[1] [2] / 2023-09-29[±]
Repository
Written inPHP
Available inEnglish, others as contributed
TypeContent Management System
LicenseMozilla Public License 2.0
Websiteprocesswire.com

ProcessWire is a free and open source content management system (CMS), content management framework (CMF) and web application framework (WAF) written in the PHP programming language. It is distributed under the Mozilla Public License 2.0. ProcessWire is built around an API with usage and naming conventions similar to the JavaScript framework jQuery. The stated goal behind the API is to provide the level of accessibility and control to pages in a website that jQuery provides to the DOM.[3] Content is managed either via the API or the web-based admin control panel. ProcessWire is largely used for development of web sites, web applications, services, content feeds and related applications.

Features

  • jQuery-styled API with comprehensive documentation[4]
  • Graphical web-based installer
  • All fields are custom fields, indexed for find operations in the API
  • Can be bootstrapped from other PHP applications or command-line scripts[5]
  • Interactive and API-based image manipulation functions
  • Drag-and-drop tree-based page list
  • Drag-and-drop file and image uploads and editing functions
  • Support for larger scale (100k+ page) installations
  • Use of string-based selectors for API calls[6]
  • Role-based access control system
  • Core development emphasis on security[7]
  • Markup agnostic output, leaving all output to the developer
  • Template files are PHP-based, with no template engine used by default
  • Output caching of entire pages or individual parts
  • Multi-language support with multi-language text fields and URLs[8]
  • Modular plugin architecture and available 3rd party modules[9]
  • Field and input types are themselves plugin modules
  • Hook system enabling most core functions to be hooked and altered[10]
  • Fields and groups of fields are repeatable using built-in Repeater field types
  • Support for rich text editing using CKEditor

Audience

Before and during development of a website or application, the audience for ProcessWire consists largely of web developers and web designers.[11] Within this audience, ProcessWire is used as both a development tool and a CMS.

Post-development the audience changes to individuals that manage content for web sites and applications, who typically are not web designer/developers. This audience uses ProcessWire primarily as a CMS to manage content.

History

ProcessWire has been in active development since 2003. From 2003 to 2007 it was developed under the name Dictator CMS. From 2007 to 2010 it was developed as ProcessWire 1.x. ProcessWire became an open source community project in 2010 and it is currently developed as ProcessWire 2.x and 3.x.[12]

ProcessWire has had 8 significant version releases, and more than 100 minor version releases since the first open source release. Version 3.0 released in September 2016 is the second major version release.[13]

Translations and community

ProcessWire has active, global end-user and developer communities. These communities have translated ProcessWire from English into their native languages, including: Chinese, Croatian, Czech, Dutch, French, German, Greek, Hebrew, Hungarian, Italian, Japanese, Portuguese, Russian, Slovak, Spanish, Swedish, Turkish, Ukrainian and Vietnamese. The central hub of the ProcessWire communities are found in the developer support forums.[11]

Awards and publications

In November 2016 ProcessWire was awarded as CMS Critic's Best Small Business CMS.[14]

In July 2016 Smashing Magazine published A Beginners Guide to ProcessWire.[15]

Since January 2016 Envato Tuts+ has published several articles and tutorials on ProcessWire.[16]

In January 2015 ProcessWire was awarded as CMS Critic's Best Free PHP CMS.[17]

In December 2014 PHP Architect published ProcessWire: Flexibility, Power, and a Generous Dose of Pure Fun.[18]

In December 2012 ProcessWire was awarded as CMS Critic's Best Free CMS.[19]

Architecture

ProcessWire is built around a page content tree (as opposed to a bucket system). The URL or path of each page is always reflective of its place in the hierarchy. One uses this same path to reference the page in the API. As a result, this connection of the path to the internal tree hierarchy defines the architecture of ProcessWire. Beyond the parent-child relationship implied by a content tree, ProcessWire supports relational one-to-one and one-to-many references between pages in the tree.

Template architecture

Templates in ProcessWire are a content type that contains one or more custom fields representing the definition of the content type. Every page in ProcessWire is assigned to a template which then represents the type of page. A template is typically shared among multiple pages. Templates also define access control, caching and other settings shared among pages using the template.

Templates optionally have an associated PHP file, referred to as the template-file. This file is executed whenever the URL for a page using the template is accessed. As a result, template-files are typically used for output purposes. The template-file is provided with several API variables, the most notable being the $page API variable, which contains all the fields and content of the current page being viewed.[20]

Template-files serve multiple contexts, depending on the application. ProcessWire's default web site profiles use template-files primarily for output of direct and dynamically generated HTML markup. Template-files may also be used as intermediate controllers between a model and a separate view. Because template-files are regular PHP files, they are able to call upon other web services or PHP applications where appropriate, without a separate parsing layer.

Field architecture

All fields in ProcessWire are custom fields defined by the user. A given field may be assigned to multiple templates, which in turn hold individual chunks of content for each page using that template. Every field has a type, referred to as the “fieldtype” (1 word), a type of plugin module. ProcessWire includes several fieldtype modules including those that support text, numbers, files, images, page references, URLs, email addresses, dates and comments. Additional fieldtype modules are installed as 3rd party modules.

Distribution and requirements

ProcessWire's source code is hosted on GitHub and is also distributed on Softaculous, Bitnami and Composer/Packagist.

ProcessWire runs in the AMP (Apache, MySQL or MariaDB, PHP) platform used by many hosting providers and web development environments. ProcessWire requires PHP version 5.3.8 or newer, and MySQL or MariaDB 5.0.15 or newer.[21]

References

  1. ^ "Download ProcessWire core". processwire.com. Retrieved 2024-05-03.
  2. ^ "processwire/processwire commits". github.com. Retrieved 2024-05-03.
  3. ^ "The concept behind the API".
  4. ^ "ProcessWire API reference documentation".
  5. ^ "Bootstrapping ProcessWire".
  6. ^ "Selectors in ProcessWire".
  7. ^ "ProcessWire Security".
  8. ^ "Multi-language support".
  9. ^ "Directory of modules".
  10. ^ "ProcessWire Hooks".
  11. ^ a b "ProcessWire community". 26 January 2024.
  12. ^ "ProcessWire history and background".
  13. ^ "ProcessWire 3.0 changelog".
  14. ^ "CMS Critic 2016 awards (November 2016)". 12 November 2012.
  15. ^ "Smashing Magazine: A Beginners Guide to ProcessWire". 2016-07-22.
  16. ^ "Envato Tuts+: ProcessWire tutorials and articles". 22 August 2017.
  17. ^ "CMS Critic Best Free PHP CMS award (January 2015)". 2015-01-21.
  18. ^ "ProcessWire published in PHP Architect Magazine (December 2014)".
  19. ^ "CMS Critic Best Free CMS award (December 2012)". 2012-12-03.
  20. ^ "The $page API variable".
  21. ^ "How to install ProcessWire CMS". processwire.com. Retrieved 2024-05-02.