Book Image

Developing Extensions for Joomla! 5

By : Carlos M. Cámara Mora
5 (2)
Book Image

Developing Extensions for Joomla! 5

5 (2)
By: Carlos M. Cámara Mora

Overview of this book

Joomla! 5 is a groundbreaking CMS that helps you take a significant leap into the world of content management systems. Joomla! 5 features a variety of impressive new features that align with current web standards and enable you to experience lightning-fast performance for optimal web page optimization, leverage the new code architecture, and tap into the WebService API, among others. This book takes you on a journey of extending Joomla's capabilities by developing your own extensions. The chapters not only explain the key concepts behind Joomla's architecture but also equip you with the latest techniques for crafting components and plugins. You’ll discover how to leverage existing features within Joomla! to empower your extensions and create tailored solutions. The book takes you from the initial stages of planning your extension development to a fully featured finished product. As you advance, you'll learn invaluable techniques for testing your extension, addressing common issues, and preparing it for publication. The concluding chapters of this comprehensive guide teach you how to test your extension for common issues, along with how to publish the extension for everyone to use. By the end of this book, you’ll have the confidence and skills to complete the cycle of extension development.
Table of Contents (21 chapters)
1
Part 1: Developing Components
8
Part 2: Developing Modules and Plugins
12
Part 3: Extending Templates
15
Part 4: Distributing Your Extensions

Hardening access to your files

Joomla! is a CMS with a powerful framework, and developing extensions for Joomla! is fun and easy thanks to all the code contributed by all the volunteers. But we should not forget that our web application in Joomla! is a collection of single PHP files working together as a whole.

Joomla! usually runs on a web server (commonly Apache or Nginx) that can execute PHP code. If you upload a custom .php file with some valid code to your Joomla! website and you try to access it, you will see that it works with no issues.

This also happens with the files of our extensions when you try to access them directly. Right now, if you have followed all the examples in this book, your files can be executed without Joomla!. As we are using lots of classes and libraries from Joomla!, it’s very likely that, when accessed directly, you will get errors. However, these errors might offer clues to attackers, so we need to secure our files to prevent direct access...