Skip to content
Greg Bowler edited this page Sep 7, 2018 · 82 revisions
PHP.Gt logo

Welcome to PHP.Gt WebEngine — an application development toolkit aimed at streamlining development and respecting web technologies.

Web frameworks offer many features, but often come with steep learning curves or imposing rules. The motivation behind this project is the belief that what a framework can offer can be achieved by eliminating code rather than adding more.

Introduction

The core concept behind the WebEngine is that applications start static first, the simplest application consisting of a single file at page/index.html.

A clean separation of concerns is promoted as described in application architecture, so that the business logic can be written and maintained separately to the page logic.

When a page is ready to be made dynamic, PHP files can be added with the same name as their HTML counterparts; index.html is powered by index.php, about.html is powered by about.php, etc. Read more about the relationship between Page View and Page Logic. Dynamic pages are made possible by binding data to the DOM.

Main features

  • DOM Templates - Bind dynamic data to reusable HTML templates.
  • Security - Provides automatically encrypted user input and secures against CSRF.
  • Database - Organise and template database queries.
  • Protected Globals - Replaces superglobals with object-oriented alternatives.
  • Build system - Copies and compiles client-side code automatically without needing to run tasks or "watch" directories.
  • gt commands - Create, serve, test and deploy your application from the command line.
  • Blueprints - Start coding new applications from the blueprint of example applications.

Separation of concerns

Each component within a WebEngine application can be developed within its own ??context??, usually within its own file on disk, so that WebEngine can hook everything up and make the magic happen. There is a strong separation of concerns promoted throughout the WebEngine and within applications built upon it.

Separate areas of concern:

  • Page View - the representation of a page or template, in HTML.
  • Page Logic - the business logic that makes Views dynamic, in PHP.
  • Database - the database queries, in SQL.
  • Service View and Logic - the same concept as Page View/Logic, but for building webservice requests rather than pages, in JSON/XML.
  • Class - the separate areas of functionality that build up your application's logic, in PHP.
  • Client side assets - the source code for pages' JavaScript and CSS (or preprocessors).

Getting started

If you're new to WebEngine, read the quick start guide first, and work through the beginner tutorials (Hello, World! and Hello, You!) to get the best introduction to the toolkit.

The core concepts to know are detailed in the "User guide", starting with the request-response lifecycle.

Help & Support

Use Stack Overflow to get help with technical issues. Tag your question with webengine and a developer will be alerted to answer your question as soon as possible.

Report bugs and suggest features on the Github issue tracker.

Clone this wiki locally