1. Download the latest eZ Authorize package. eZ Authorize packages (tar.gz, tar.bz2 and .zip) are built from the project's repository hosted by the eZ community's subversion server pubsvn.ez.no.
2. Unpack the package into the 'extension/' folder of your eZ Publish installation. Rename the unpacked eZ Authorize folder to 'ezauthorize' if it is not already named as such.
3. On Unix-like operating systems, set file ownership and permission of the 'ezauthorize' folder and configuration files to '750'.
Activate eZ Authorize via the eZ Publish Administration Interface:
1. Click on the Setup link on the top menu. On the left menu click Extensions. In the Available extensions window, check the checkbox under the Activate column that corresponds to the 'ezauthorize' extension. Click Apply changes.
2. Alternatively, you can edit the 'site.ini' override file. Typically, this involves opening the file 'settings/override/site.ini.append.php' in your preferred text editor. Add an entry to the 'ActiveExtensions[]' array with the text string 'ezauthorize' under the [ExtensionSettings] block. The basic activation settings might look similar to the following:
[ExtensionSettings] ActiveExtensions[] ActiveExtensions[]=ezauthorize
1. Copy the configuration file 'ezauthorize.ini.append.php' (located in 'extension/ezauthorize/settings/') into the 'settings/override/' directory.
2. Log in to your Authorize.Net account to obtain the optional and required settings to configure your payment gateway merchant settings in eZ Authorize.
3. Customize the settings in the file 'ezauthorize.ini.append.php', replacing the relevant values with your merchant-specific settings. One of the non merchant-specific settings is to enable or disable test mode. For testing purposes in this tutorial, make sure this value is set to 'true'. You should set it to 'false' once you have finished setting up eZ Authorize and are ready to accept payments.
Now that the extension has been installed, set up the appropriate workflows to use eZ Authorize.
Click on the Setup tab on the top menu of the Administration Interface. On the left menu, near the bottom, click Workflows. The Workflow groups window will be displayed.
Workflow groups help to organize the management of workflows.
Create a new workflow group containing your site's payment gateway workflow events.
Click the New workflow group button. The New workflow group view will be displayed. Enter a name for the workflow group, such as 'Payment Gateways', then click the OK button.
This creates a new workflow group named 'Payment Gateways' and returns to the Workflow groups view.
Next we want to add a new workflow to the 'Payment Gateways' group. Click the workflow group link Payment Gateways.
The workflows associated with the workflow group 'Payment Gateways' will be displayed. Add a new workflow to the workflow group by clicking the New workflow button.
Name the workflow 'Authorize.Net Gateway'.
On the workflow event dropdown list, select Event / Payment Gateway. Click the Add event button.
The Edit workflow view will be displayed, where you can edit the workflow name, description and type. Notice the Type multi-select list of installed payment gateways workflow events. Select Authorize.Net.
Optionally, enter some descriptive text in the Description / comments field, but it is not a required field and thus can be left empty. Click the OK button.
You can also let customers select from multiple payment gateways. Repeat the steps from the previous three sections to add another payment gateway, but name the workflow 'All Gateways' and select All from the Type multi-select list when selecting the workflow event type.
You will now have two workflows in the Workflows window (below the Payment Gateway window).
Now that we have payment gateway workflow events, we must specify when we want this payment gateway event to happen.
In the Setup tab, click the Triggers link in the left menu.
Payment gateway events always happen in the 'shop' module during the 'checkout' function. The connection type is 'before'.
Click the select box under the Workflow column on the row shop, checkout, before.
You will be presented with the workflows that are configured in your application. Select the Authorize.Net workflow if you would like your customers to be required to pay via Authorize.Net. Alternatively, if you would like to give your customers the choice of paying by any additional payment gateways (eZ PayPal or Paynet being popular examples), select the 'All Gateways' workflow instead.
For the purposes of this tutorial, the 'All Gateways' workflow is selected so that we can see how the Select payment method view would look. Click Apply Changes. We have now completed all the steps you need to install a payment gateway!
Access the front-end user view of your website. Add a product to the shopping cart and click the Checkout button. Fill in the relevant information in the Account information form, then click the Continue button. On the Confirm order page, review your order details, then click the Confirm button.
If the trigger 'shop.checkout.before' is set to the 'All Gateways' workflow, the Select payment method view will be displayed.
For this checkout example, choose the Authorize.Net option and click Select. This will start the payment gateway workflow.
If, however, the trigger 'shop.checkout.before' is set to the 'Authorize.Net' workflow, you will automatically be presented with the Payment / credit card information form.
Next, you will be presented with the Payment / credit card information form.
Complete the form and click Submit. If test mode is not enabled, the payment information will be submitted to the payment gateway service and verified.
If the transaction is approved you will be directed to the order view (receipt). Payment is thus complete!
If the transaction is declined, you can re-enter the payment information and submit again until the transaction is approved. You will not be able to continue without payment approval.
When you are ready to accept payments on your site, remember to disable test mode in the configuration file 'ezauthorize.ini.append.php' (located in 'extension/ezauthorize/settings/').
You can enable verbose debugging by first enabling the 'eZ Publish' debug output and then enabling the 'eZ Authorize' debug output (see example settings below).
In the file 'settings/override/site.ini.append.php':
[DebugSettings] # DebugOutput=disabled DebugOutput=enabled
In the file 'settings/override/ezauthorize.ini.append.php':
[eZAuthorizeSettings] # Extension Debug # Debug=false Debug=true
Enabling this debug output will display the transaction key, merchant login, md5 secret word, and transaction hash sent to and returned from Authorize.Net.
We hope this tutorial has been helpful and interesting to the eZ Publish community, providing useful information about workflows, events, triggers, extensions and payment gateways in eZ Publish.
eZ Publish makes implementing payment gateway solutions simple by providing support for multiple payment gateways and powerful tools for building advanced commerce solutions.
This work is licensed under the GNU Free Documentation License (GFDL).
Timing: | Jan 18 2025 02:58:18 |
Script start | |
Timing: | Jan 18 2025 02:58:18 |
Module start 'layout' | |
Timing: | Jan 18 2025 02:58:18 |
Module start 'content' | |
Timing: | Jan 18 2025 02:58:18 |
Module end 'content' | |
Timing: | Jan 18 2025 02:58:18 |
Script end |
Total runtime | 0.1830 sec |
Peak memory usage | 4,096.0000 KB |
Database Queries | 66 |
Checkpoint | Start (sec) | Duration (sec) | Memory at start (KB) | Memory used (KB) |
---|---|---|---|---|
Script start | 0.0000 | 0.0052 | 589.1641 | 152.6406 |
Module start 'layout' | 0.0052 | 0.0017 | 741.8047 | 39.4766 |
Module start 'content' | 0.0070 | 0.1750 | 781.2813 | 823.4375 |
Module end 'content' | 0.1820 | 0.0009 | 1,604.7188 | 20.8125 |
Script end | 0.1829 | 1,625.5313 |
Accumulator | Duration (sec) | Duration (%) | Count | Average (sec) |
---|---|---|---|---|
Ini load | ||||
Load cache | 0.0030 | 1.6549 | 16 | 0.0002 |
Check MTime | 0.0012 | 0.6741 | 16 | 0.0001 |
Mysql Total | ||||
Database connection | 0.0009 | 0.4782 | 1 | 0.0009 |
Mysqli_queries | 0.0476 | 26.0230 | 66 | 0.0007 |
Looping result | 0.0004 | 0.2108 | 64 | 0.0000 |
Template Total | 0.1600 | 87.5 | 2 | 0.0800 |
Template load | 0.0018 | 1.0073 | 2 | 0.0009 |
Template processing | 0.1582 | 86.4454 | 2 | 0.0791 |
Template load and register function | 0.0001 | 0.0650 | 1 | 0.0001 |
states | ||||
state_id_array | 0.0048 | 2.6173 | 11 | 0.0004 |
state_identifier_array | 0.0037 | 2.0156 | 12 | 0.0003 |
Override | ||||
Cache load | 0.0038 | 2.0843 | 170 | 0.0000 |
Sytem overhead | ||||
Fetch class attribute name | 0.0015 | 0.7983 | 11 | 0.0001 |
Fetch class attribute can translate value | 0.0001 | 0.0511 | 10 | 0.0000 |
class_abstraction | ||||
Instantiating content class attribute | 0.0000 | 0.0108 | 11 | 0.0000 |
XML | ||||
Image XML parsing | 0.0135 | 7.3669 | 10 | 0.0013 |
General | ||||
dbfile | 0.0113 | 6.2026 | 31 | 0.0004 |
String conversion | 0.0000 | 0.0046 | 4 | 0.0000 |
Note: percentages do not add up to 100% because some accumulators overlap |
Usage | Requested template | Template | Template loaded | Edit | Override |
---|---|---|---|---|---|
1 | node/view/full.tpl | full/article.tpl | extension/sevenx/design/simple/override/templates/full/article.tpl | ||
1 | content/datatype/view/ezxmltext.tpl | <No override> | extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tpl | ||
17 | content/datatype/view/ezxmltags/header.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/header.tpl | ||
9 | content/datatype/view/ezxmltags/link.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/link.tpl | ||
6 | content/datatype/view/ezxmltags/li.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/li.tpl | ||
2 | content/datatype/view/ezxmltags/ul.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/ul.tpl | ||
5 | content/datatype/view/ezxmltags/newpage.tpl | <No override> | extension/community/design/standard/templates/content/datatype/view/ezxmltags/newpage.tpl | ||
34 | content/datatype/view/ezxmltags/paragraph.tpl | <No override> | extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tpl | ||
22 | content/datatype/view/ezxmltags/strong.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/strong.tpl | ||
3 | content/datatype/view/ezxmltags/literal.tpl | <No override> | extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tpl | ||
10 | content/datatype/view/ezxmltags/embed.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/embed.tpl | ||
10 | content/view/embed.tpl | embed/image.tpl | extension/sevenx/design/simple/override/templates/embed/image.tpl | ||
10 | content/datatype/view/ezimage.tpl | <No override> | extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tpl | ||
1 | print_pagelayout.tpl | <No override> | extension/community/design/community/templates/print_pagelayout.tpl | ||
Number of times templates used: 131 Number of unique templates used: 14 |
Time used to render debug report: 0.0001 secs