Track URL shares
This is source code for simple webapp that tracks how many times given URL was shared on social media. It returns information from: Facebook, Twitter, Google+, LinkedIn, Pinterest and StumbleUpon.
Try it on: shares.webit.pl
Requirements
As it uses PHP as backend (api endpoint) you need to be running PHP 5.4+. Backend build on top of Silex. Additionally it stores data in MySQL database, so you will need one.
Installation
- PHP dependencies are managed by Composer. To install everything required run following command in main application directory:
composer install
. If you didn't use Composer before - check how to install it.
IMPORTANT you must run composer in Linux/Unix shell as it created some directories using mkdir
command.
It will install Silex micro framework, Doctrine DBAL, Monolog and Symphony Yaml and shares-counter-php library that's responsible for checking social media APIs.
-
Frontend dependencies are manages by Bower. Installing dependencies is as easy as running
bower install
assuming you already have installed Bower. If not - check how to install Bower.It will install: AngularJS with additional modules, Bootstrap and jQuery. Because on inconsistency Bower package vs GitHub repository - Material Design for Bootstrap is bundled with application assets.
-
Finally you need to create MySQL tables. Assuming you have running MySQL server and already created new database, easiest way to create tabels is to run:
mysql -h{host} -u{username} -p {database name} < database.sql
. Check MySQL command line tool for additional parameters and how-to.
Configuration
There's one configuration file. It stores database access information (for now) and is located in /app/config.yml
Just fill in informations about: host, database name, username and password.
By default after Composer during installation will create two directories in api/
:
api/cache/
for storing Silex cacheapi/log/
log directory where are logged request & response information as well application issues
SECURITY NOTE both directories have default access permissions set to 777 (full access). Please change it allowing write from web-server user only (apache, www-data, etc.)
Todo
Unit testing
License
Copyright (c) 2014 Dominik Bułaj. See the LICENSE file for license rights and limitations (MIT)