ZRECore - The most intuitive approach to e-commerce application development. This application provides a native Mobile and E-Commerce API to all types of PHP applications, including Wordpress, Drupal, Joomla, and many more. Built upon the Zend Framework MVC library, the ZRECore application provides a stable and easily modified e-commerce API you can use directly in any PHP project. ZRECore leverages various technologies, including Doctrine 2, Sqlite3, and jQuery in order to provide a powerful, yet intuitive code base that any PHP programmer can quickly understand and extend to suite their project needs.
This code is provided to you under the terms of the GNU General Public License V3 or higher. It can be found at http://www.gnu.org/copyleft/gpl.html Copyrights 2009 The Alex Venture Project http://www.alexventure.com. All rights reserved.
You can contact me with questions/comments at my website: http://www.alexventure.com
This installation is made to work on Unix/Linux operating systems. If you're really inclined to make this application work on a Windows machine, feel free to port it.
- Apache 2 or higher with the PHP module, Rewrite module, and the SSL module enabled.
- SSL Certificate - You can create a "snake oil" SSL certificate for development purposes on your own machine, but you should purchase and install a reputable SSL certificate on a production machine.
- Zend Framework 1.10 or higher - See http://code.google.com/p/zend/ if you want to install it via PEAR or http://framework.zend.com if you plan to copy the Zend/ folder directly into the application library/ folder
- PHP 5.3 or higher with the Standard PHP Library (SPL, usually included by default)
- SQLight3 or higher (Use your package manager tool such as yast on CentOS/Red Hat or apt-get on Debian based servers. You will need
sqlite
andphp5-sqlite
or higher. Remember to restart Apache after installing. You can also download from http://www.sqlite.org/download.html if you don't use a package manager) - Doctrine 2 - The Zend Framework provides the Zend_Db_Table class, but it's not exactly what I need for this project. I feel the Doctrine 2 library is a much more appropriate tool for the job, thanks mainly to it's object-relational mapper. See http://www.doctrine-project.org/ for more information regarding setup and usage.
I was inspired by some of the nicer features found in Wordpress, Joomla, and a few things I did right during the ZRECommerce project. I can be contacted via my blog at http://www.alexventure.com
This application uses the phpass library (public domain). See http://www.openwall.com/phpass/ This application uses the jQuery and jQuery UI library + css. Copyrights 2010 The jQuery Project and the jQuery UI Team. See http://jquery.org/ I did not include jQuery UI's "Hot Sneaks", "Dot Luv", or "Swanky Purse" themes because they have CSS breakage issues not present in the other themes.
The Zend Framework, phpass library, jQuery library, jQuery UI library, PayPal API, Doctrine, and other third-party files are copyright their respective owners. Any third-party files distributed herein is distributed under the terms of each third-party file license. This application uses the phpass library, hence, you are responsible for following encryption/hashing laws in your own country if applicable.
Always back up. Just copy your ZRECore installation directory somewhere safe every so often (or commit to your own github fork). That way, if you ever need to undo a boo-boo, you'll be fine.
Your data.sq3
file is especially important. Wherever you decide to keep it, don't forget to back it up too. (Keep reading, you'll see what that's all about further down.)
Downloads can be found at https://github.com/aalbino/ZRECore/downloads
Additionally, you can fork me off of http://github.com/aalbino/ZRECore/ and then check out your own fork onto your local machine using git (read below).
The _install.sql
inserts the admin
user, with a temporary password of password321
Extract the contents of the ZRECore download archive into /var/www/ZRECore/
(or whatever directory you plan to host these files from)
For example, let's say you downloaded aalbino-ZRECore-a6a4749.tar.gz
and extracted the archive into /home/User/Downloads/aalbino-ZRECore-a6a4749/
If you are going to run this installation under /var/www/www.mywebsite.com/
you could do the following:
cd /home/User/Downloads/aalbino-ZRECore-a6a4749/
mv * /var/www/www.mywebsite.com/
For those of you who prefer the bleeding edge of technology, you can just check out a copy from github.com directly into /var/www/www.mywebsite.com/
The .sq3 database file location can be specified in (your installation directory)/application/configs/application.ini
under the '; Database'
comment
You can use the default sqlite3 database file in (your installation directory)/data/sqlite/data.sq3
...Feel free to use the sqlite3
client to open the .sq3 file and then use the .read
command on the _install.sql
file to restore the database to it's begining state, or use the .read
command on whatever provided .sql file to (re)create a table. Each table is individually wrapped in its own .sql file for your convenience.
Then, move or copy data.sq3 into some directory outside your installation and update application.ini
accordingly.
NOTE: You are responsible for setting permissions on the copied/moved data.sq3 file in order to keep it secure, yet accessible by this application.
You will need to create two files in /etc/apache2/sites-available
...one for the HTTP version of your installation, and one for the HTTPS version.
Here is a sample (HTTP) Apache2 virtual host configuration file named www.example.com
(usually saved as /etc/apache2/sites-available/www.example.com
):
<VirtualHost *:80>
ServerName www.example.com
DocumentRoot /var/www/www.example.com/public
SetEnv APPLICATION_ENV "development"
<Directory /var/www/www.example.com/public>
DirectoryIndex index.php
AllowOverride All
Order allow,deny
Allow from all
</Directory>
</VirtualHost>
Here is a sample (HTTPS) Apache2 virtual host configuration file named www.example.com-ssl
(usually saved as /etc/apache2/sites-available/www.example.com-ssl
):
<VirtualHost *:443>
ServerName www.example.com
DocumentRoot /var/www/www.example.com/public
SetEnv APPLICATION_ENV "development"
<Directory /var/www/www.example.com/public>
DirectoryIndex index.php
AllowOverride All
Order allow,deny
Allow from all
</Directory>
SSLEngine on
SSLCertificateFile /etc/ssl/certs/ssl-cert-snakeoil.pem
SSLCertificateKeyFile /etc/ssl/private/ssl-cert-snakeoil.key
<FilesMatch "\.(cgi|shtml|phtml|php)$">
SSLOptions +StdEnvVars
</FilesMatch>
<Directory /usr/lib/cgi-bin>
SSLOptions +StdEnvVars
</Directory>
BrowserMatch "MSIE [2-6]" \
nokeepalive ssl-unclean-shutdown \
downgrade-1.0 force-response-1.0
BrowserMatch "MSIE [17-9]" ssl-unclean-shutdown
</VirtualHost>
Remember to modify these host files to reflect the correct server name, document root, and SSL certificate file locations accordingly.
If you are installing on your own local development machine, you may need to add the following entry into your /etc/hosts
file as well (under the last entry for 127.0.0.1
):
127.0.0.1 www.example.com
That way, when you browse to www.example.com
, you will actually request your local machine's virtual host "www.example.com"
Finally, type a2ensite www.example.com
and hit enter, then a2ensite www.example.com-ssl
and hit enter, then type sudo service apache2 reload
to reload the Apache2 server configuration files.
This enables the HTTP and HTTPS versions of your virtual hosts, and reloads the Apache 2 server.
If you did everything correctly, you should be able to open up your browser and go to www.example.com
(or whatever fake URL you've been using in its place up to this point) and see a working installation.
To enable/disable an observer plug-in, simple add or comment out the corresponding file path entry in /application/configs/observers.ini
If you would like to learn what this section is all about, read http://softcoded.com/pdfs/subject_observer.pdf
The Observer Design Pattern used here is actually based off the PHP SplSubject/SplObserver classes (interfaces) http://php.net/manual/en/class.splobserver.php
Sample observer - Hooks into our Observer/Subject environment and echos "Hello World!" when the "Auth" subject's "authenticate()" method is called. This sample is an introduction to creating your own custom observer classes.
- See: /custom/Auth.HelloWorld.php
Sample shopping cart for service providers - Overrides the shopping cart system behavior (via the Observer/Subject environment) to provide a "Service" oriented shopping cart.
Available observer subjects are in associative array format and can be retrieved anywhere within the application as follows:
$observerSubjects = Zend_Registry::get('OBSERVER_SUBJECTS');
$theSubject = $observerSubjects['NameOfObserverSubject'];
Simply replace the key 'NameOfObserverSubject' with one of the following:
-
Auth
- Notifies attached observers when the following methods are called, and passes along the arguments:authenticate(string $username, string $password, array $options = null)
-
-
Cart
- Notifies attached observers when the following methods are called:renderForm(string $formKey, Zend_View $view)
- Renders the requested form view helper.redirectToForm(string $currentFormKey, string $newFormKey, array $data )
- Notifies the observers that the controller logic requests a redirect to a new form, using the supplied data.redirectToURL(string $currentFormKey, string $returnFormKey, array $data, string $method = 'POST')
- Notifies the observers that the controller logic requests a redirect to another URL, using the supplied data, and using the method requested. The method specified can be GET or POST (POST is the default).redirectFromURL(string $returnFormKey, array $data)
- Notifies the observers that we have received a response from a previously supplied URL, and gives the observer a copy of the returned data.addToCart(array $item_data)
-onSubmitForm(string $formKey, array $input)
- Notifies observers that the specified form has been submitted with the provided input.