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

Summary

Joomla! is a secure platform with a robust framework that allows us to deliver safe applications to our users. But as with any other tool, if we do not pay attention to the details, we might include vulnerabilities in our code.

In this chapter, we learned about important security practices that allow for safer coding in Joomla!. First, we learned how to filter the requests we receive in our extension through the entry points we defined in our component. Then, we focused on how to secure our queries to the database using prepared statements and also casting our values to the specific types. Finally, we provided some tips to handle our static assets securely, looked at how to prevent random access to our PHP files, and learned how to automatically check our extensions using the JED Checker component.

With that, we have developed a fully equipped project manager, added automatic tests, and hardened ourselves against vulnerabilities. In the next chapter, we will look at all...