Four years ago, I started out on a journey to build an eCommerce plugin for myself so that I could sell a few of the plugins I was building. A plugin to sell plugins, how meta. As with most of the projects I choose to dedicate my time and energy to, Easy Digital Downloads was built for me by me but in such a way that others could make use of it if they wished. Today, Easy Digital Downloads is installed on over 50,000 websites, has reached nearly one million downloads, and has grown to a sustainable business that supports the livelihood of an ever-growing team comprised of full time employees and active contractors.
Two years ago I wrote a post on this site to introduce my latest plugin, AffiliateWP. The plugin quickly became a staple in my company’s product portfolio and has done quite well for us. Today marks the second anniversary of our version 1.0 release so I would like to take a few minutes to look back on some of the highlights and the journey of building one of my most successful plugins.
A few weeks ago I announced that my Easy Content Types plugin was available for purchase. After five years of maintaining the plugin, I felt it was time to find a new home for the plugin where it would be properly cared for and developed. Today I’m thrilled to announce that the plugin has been acquired and is now under new management.
In early 2011 I released Easy Content Types, an advanced plugin that provides a graphical interface for creating post types, taxonomies, and metaboxes in WordPress. The plugin was originally released on Code Canyon.net and did quite well there. It was in the weekly top sellers nearly every week that it resided there. Then in February, 2013, the plugin was moved to this site and was one of the first plugins used to stock my own small plugin shop. Now, with some sadness and great happiness at the same time, it is time for Easy Content Types to find a new home.
In the previous sections of this series, we have looked at reasons you should build a custom database API, we have discussed how to structure your data, and we have looked at how to create the database tables. Now it is time to build the basic API that we will use to actually interact with our database. This will involve writing an API class with all of the necessary methods for retrieving, inserting, updating, and deleting data.
I love side projects. They are what wake me up at night with excitement; they are what causes light bulbs to flash on inside my brain while walking my dog; they are what motivate me when all other motivation is lost; they are the distraction from my worries; they are a fundamental part of who I am as a developer; and they are an integral part to the success of so many of this world’s greatest developers and business owners.
Several years ago, I wrote a tutorial on how to create custom registration and log in forms. That tutorial was shortly after transformed into a complete plugin that has been sold on this site since. It was a fun and popular plugin but over the last few years it was lost focus from me, primarily due to the growth of my other projects. Today I’m thrilled to announce the plugin has a new owner that will keep it updated and breath new life into it.
Since early child hood, I have always been a do-it-myself individual. It is an attitude I attribute largely to the way my father raised me and my brother. The three of us were always working around the farm making repairs and handling new construction. We did our own plumbing, electrical work, mowing, cleaning, car maintenance, and everything else. My family was reasonably well off financially so we could have hired plumbers, electricians, mechanics, etc, if something needed built or repaired, but that just was not in our nature.
When starting out with building an API for your custom tables, one of the very first things you need to do is determine what data you need to store in your tables, and what format that data will be stored in. This is a fundamental aspect of creating your API as it is one of the defining factors for how your tables are structured.