This tutorial is the first of three parts:
-
Application creation
This tutorial assumes that you're creating this new project in your development environment, and then later deploying the code into your production environment. If you have no development environment, you can follow these same instructions to create a new project into your development environment.
To complete this tutorial, you must first have:
-
A working development php web server environment
-
Access to the command-line command
php
-
A development MySQL database which can be dedicated to this project, plus user credentials for a user with full privileges on that database
-
Create the development project web root:
Like any other PHP project, your Framework project needs to live inside of a web root. You can create a directory inside of your server's web root and use that as a project web root, or you can use the server's web root directly as your project web root.
For example, if your server's web root is
/www
, then you could create the directory/www/myproject
. The directory/www/myproject
would be your project web root.All of the example commands in this tutorial are issued from within your project web root. All files created are relative to your project web root.
-
Install Composer:
Composer is a dependency manager for Php: you tell it what packages your project requires, and it fetches the appropriate versions of those packages, along with any packages required by those packages.
There are two flavors of Composer installation available: local or global. In a local install, Composer resides as a file
composer.phar
in your web root. In a global install, Composer resides in your system files and may be called from any directory.In a local install, you invoke Composer using
php composer.phar ...
from your project web root. In a global install, you invoke Composer usingcomposer ...
. This tutorial assumes that you are using a local install, but if you have a global install then replace all examples which usephp composer.phar ...
withcomposer ...
.To install locally in a *nix environment
cd
into your project web root and type:curl -sS https://getcomposer.org/installer | php
To install in a Windows environment, see the Composer downloads page. If you use the Composer Windows installer, then you'll end up with a global install.
-
Create the project's
composer.json
:Create the following file, named
composer.json
in your project's web root:{ "require": { "propel/propel": "~2.0@dev", "athens/core": "0.*" }, "require-dev": { "phpunit/phpunit": "4.5.*", "phpunit/phpunit-selenium": ">=1.2", "phpdocumentor/phpdocumentor": "2.7.*" } }
This is where you tell Composer which packages your projects require. Notice that we have included Framework as a dependency. You can add more packages to this list later. For more information, see the composer.json schema documentation.
-
Initial install of requirements:
Now we tell composer to download our project's dependencies:
php composer.phar update
-
Initialize the project:
Now that Framework is installed, we use it to create the bare-bones of a Framework project.
vendor/bin/athens init
This command creates a handful of directories and files in your project web root, as well as adding a few directives to your composer.json.
-
Edit the local settings:
Edit the file
local-settings.php
and replace all instances ofSET_ME
with the appropriate values. All of the settings should be string literals--enclosed in quotes--unless otherwise indicated.Note that
local-settings.php
is excluded from version control. This means that it will not be synchronized between your development and production environments. It also doesn't go into your code repository, so it's OK to put passwords into it, unless you exposelocal-settings.php
to other risks. -
Edit the file
settings.php
:Edit the database
APPLICATION_NAME
constant to the same value asMYSQL_DB_NAME
inlocal-settings.php
. -
Edit the file `project-schema/schema.xml':
First, edit the database
name
attribute to the same value asMYSQL_DB_NAME
inlocal-settings.php
. Then edit the databasenamespace
attribute with a PascalCased class name for your project. This tutorial uses "MyProject".Framework uses Propel to manage the code<->database interface. This kind of helper library is known as an ORM.
The file
project-schema/schema.xml
is where we define the database tables which will house our data. Propel then both creates these tables in our database and also creates a set of Php classes which allow us to retrieve and insert records using an object interface. To learn more about schema creation read the Propel documentation, beginning with 'The Build Time'.The initial Framework project includes a commented-out definition for a student table. To proceed with this tutorial, uncomment that definition. If you are already familiar with Framework, then at this point you could delete the student table definition and create your own table definitions.
-
Build the database and objects:
cd
intoproject-schema
and then issue the following commands:php ../vendor/bin/propel model:build; php ../vendor/bin/propel sql:build; php ../vendor/bin/propel sql:insert;
These commands generate Php classes from your
project-schema/schema.xml
, generate SQL statements to create a database table for each of your schema classes, and then insert those tables into your database.Now
cd
back into your project web root and issue the following:php composer.phar dump-autoload
-
Edit your .htaccess files:
The default project assumes that you may have some set of pages which will be accessible to all users, and some set of pages which will only be accessible to some privileged class of users. The former can be placed in
pages/
and the latter can be placed inadmin/
.You must edit
pages/.htaccess
andadmin/.htaccess
to reflect these rules. By default, bothpages/.htaccess
andadmin/.htaccess
will block all requests. -
(Optional) Install a template set:
Framework comes with a set of functional, utilitarian templates for document layout and styling. You can create your own templates or template packages to convey your unique brand and styling. This example uses the Athens Framework example theme.
If you don't have a set of templates to use, you can skip this step and create and install templates later; just changing one line of code in one file will update all of your pages to use your new templates!
To proceed with the University of Washington templates, add the
uwdoem/boundless
theme to yourcomposer.json
requirements:"require": { ... "athens/theme": "0.*", ... },
Then add the Boundless templates in your project's
setup.php
, below the line that adds your project-templates:Settings::getInstance()->addTemplateDirectories(dirname(__FILE__) ."/project-templates"); Settings::getInstance()->addTemplateDirectories(dirname(__FILE__) ."/vendor/athens/theme/templates");
Finally, you have to tell composer to download the
athens/theme
requirement you added. Socd
into your project root and issue the following:php composer.phar update
-
Create a couple of simple pages:
You can now create a couple of simple web pages. Assuming that you are using the student table provided by Framework, let's create a public form which allows us to enter students into the database, and a private table for viewing students.
Create the following
pages/enter-student.php
file:<?php require_once dirname(__FILE__) .'/../setup.php'; use Athens\Core\Form\FormBuilder; use Athens\Core\Page\PageBuilder; use Athens\Core\Page\Page; use MyProject\Student; $form = FormBuilder::begin() ->setId('student-form') ->addClass('inline-fields') ->addObject(new Student()) ->build(); $page = PageBuilder::begin() ->setId('student-entry-page') ->setType(Page::TYPE_FULL_HEADER) ->setTitle('My Project: Enter a Student') ->setHeader('My Project') ->setSubHeader('Enter a Student') ->setBaseHref('..') ->addLabel('Enter a Student') ->addWritable($form) ->build(); $page->initialize()->render();
Now try visiting
pages/enter-student.php
in your web browser. Try submitting a student. Try submitting a student while neglecting to provide a required field. Try submitting a student and then viewing the results in your database.
Your student entry page. At only 20 lines, it knows how to validate fields and save students to the database.It's an extremely basic form, but it already knows how to detect and report form errors, and how to save its results in the database. We'll make some improvements to this form in the following section on making changes to an existing project.
Now create the following
admin/student-table.php
file:<?php require_once dirname(__FILE__) .'/../setup.php'; use Athens\Core\Page\PageBuilder; use Athens\Core\Page\Page; use Athens\Core\Row\RowBuilder; use Athens\Core\Table\TableBuilder; use MyProject\StudentQuery; $students = StudentQuery::create()->find(); $rows = []; foreach ($students as $student) { $rows[] = RowBuilder::begin()->addObject($student)->build(); } $table = TableBuilder::begin() ->setId('students-table') ->addRows($rows) ->build(); $page = PageBuilder::begin() ->setId('student-view-page') ->setType(Page::TYPE_FULL_HEADER) ->setTitle('My Project: View Students') ->setHeader('My Project') ->setSubHeader('View Students') ->setBaseHref('..') ->addWritable($table) ->build(); $page->initialize()->render();
Your table of students. At only 30 lines, it knows how to retrieve and display students.This is also a very basic table, but it already knows how to load students from the database, display them as rows, and include the appropriate column headers. We'll also make some improvements to it on the section below on making changes to an existing project.
-
Upload to your code repository:
If you use an IDE, it may place files into your project web root. Before uploading your code to your repository, be sure to exclude those files using your .gitignore file.
However, creating a code repository, initializing your code directory, and pushing it to the repo are beyond the scope of this tutorial.
See the next step in this tutorial: Application deployment.