I used to have a domain name addiction (and still kind of do... but, hey, baby steps!) with Porkbun being my registrar of choice.
While their prices and overall experience is good, there didn't seem to be an easy way to see how much your total renewal costs would be for the year, which I personally really wanted so I'd be able to budget accordingly.
Introducing Piggybank π ~ a simple-to-use web app that allows you to easily calculate the total registration and renewal costs of your Porkbun domains.
All you need to do is copy-and-paste your simple list of domains from Porkbun (or if you're just brainstorming, type in any domain offered by Porkbun on a new line) into the box on the homepage and hit "Calculate".
Your total registration and renewal costs will then be calculated and displayed for you to marvel at. π€©
This repository contains the full source code for Piggybank which is open-sourced under the MIT License - see the LICENSE file for details. Piggybank is not affiliated with Porkbun LLC and was made for fun.
Porkbun allows you to view a plain text or "simple" list of your currently registered domains as well as offers a public API for accessing their pricing data.
Piggybank is set up to make an API request twice per week (Tuesdays and Fridays) for this pricing data which is then stored in the database.
When you copy-and-paste or enter a list of domains into the box, it is then parsed to extract the TLD (top-level domain or its "extension") from each individual domain name which is then finally used to calculate the total registration and renewal costs using the stored pricing data.
βοΈ Please note that there are a couple of small caveats with Piggybank:
- Domain prices can and will fluctuate over time due to registry (the company that owns the TLD) changes or special offers by Porkbun, the calculated costs should be seen more as an estimation or "ballpark" figure to help you budget your domains.
- Some domain names are considered "premium" by their registry in which Porkbun is charged a higher-than-normal cost to register and/or renew it, which is then passed onto you. Pricing data from Porkbun is based on TLD and thus Piggybank has no knowledge of which names may be considered premium.
You can set up and run Piggybank yourself by following the below instructions:
-
Download (and extract) or clone Piggybank's repository to your local machine or server.
-
Enter Piggybank's directory and via the terminal execute the following commands:
composer install cp .env.example .env php artisan key:generate
-
In the
.env
file ensure that your database details are correct and then run the below command:php artisan migrate
Your database should now be filled with the required tables.
-
To fetch and store the current domain prices from Porkbun run the below command (Porkbun currently offers around 800 different TLDs, so it may take a minute):
php artisan piggybank:get-domain-prices
-
If you'd like the domain prices to be automatically fetched and stored as described in the "How it Works" section you'll need to do the following:
-
In the
.env
file, set thePIGGYBANK_EMAIL_TO_SEND_TO_ON_FAILURE
key to a valid email address. The details of any failed API requests will be sent there. -
Add the below CRON entry to your server/machine (this process may vary depending on your OS and any hosting control panel you may be running in addition, use Google if you're unsure):
* * * * * cd /path/to/piggybank && php artisan schedule:run >> /dev/null 2>&1
The automatic fetch is powered by Laravel's built-in task scheduler and so it might be helpful to view its documentation if you'd like to modify things further.
-
-
Lastly, ensure that the
APP_URL
andASSET_URL
keys in the.env
file are correct for your case, and then run the below command to host Piggybank locally on your machine:php artisan serve
Go to the URL given in your browser and you should be all set! Enter some domains to calculate the costs and have fun!
Piggybank, as any good project should π, includes automated tests powered by PHPUnit. You can run them by running the below command:
php artisan test --order-by random
If you'd like to view or edit the tests you can find them all within the tests/Unit
and tests/Feature
directories, organized accordingly.
Any tests that involve the DB are configured to use an in-memory SQLite database, if you'd like to change this, you can do so in the phpunit.xml
file in the project's root.
I built Piggybank using these awesome things made by awesome people, here's a big thanks to them:
- Porkbun API
- Laravel
- Livewire
- PHPUnit
- Laravel Money
- Bootstrap
- Font Awesome
- Animate.css
- Bunny Fonts
- Fesliyan Studios (for logo sound effects)
And an honorable mention to this article on Laravel Daily that helped me with how to handle storing and displaying the domain prices.
I've only been working with Laravel since last November. π If you spot anything wrong with my code or it's design then please feel free to submit an issue or PR. I'd really appreciate it.