Giter VIP home page Giter VIP logo

laravel-google-keywords's Introduction

Laravel Google Keywords

A Laravel package for synchronizing with Google Search Console to get visitors' search keywords.

Laravel-Poster by HighSolutions

Installation

Add the following line to the require section of your Laravel webapp's composer.json file:

    "require": {
        "HighSolutions/GoogleKeywords": "1.*"
    }

Run composer update to install the package.

This package uses Laravel 5.5 Package Auto-Discovery. For previous versions of Laravel, you need to update config/app.php by adding an entry for the service provider:

'providers' => [
    // ...
    HighSolutions\GoogleKeywords\GoogleKeywordsServiceProvider::class,
];

Next, publish all package resources:

    php artisan vendor:publish --provider="HighSolutions\GoogleKeywords\GoogleKeywordsServiceProvider"

This will add to your project:

- migration - database table for storing keywords
- configuration - package configurations

Remember to launch migration:

    php artisan migrate

Next step is to add cron task via Scheduler (app\Console\Kernel.php):

    protected function schedule(Schedule $schedule)
    {
    	// ...
        $schedule->command('keywords:fetch')->daily();
    }

Configuration

Setting name Description Default value
websites.*.url URL of website (with protocol) ''
websites.*.credentials JSON credentials file on server storage_path('app/google-search-credentials.json')

Websites are defined in configuration as:

<?php

return [
    'websites' => [
    	[
    		'url' => 'http://highsolutions.pl',
    		'credentials' => storage_path('app/HS-Credentials.json'),
    	],
    	// ...
    ],
];

Invalid configuration will return information about error.

Google Search Console and Google Cloud Platform integration

In order to get access to keywords from Google Search you need to complete 2 steps:

  1. Google Search Console (https://www.google.com/webmasters/tools/home)
  • Add your website
  • Verify your ownership of website
  1. Google Cloud Platform (https://console.cloud.google.com/apis/credentials)

Model structure

Model consists of fields:

  • id - primary key
  • url - URL of website
  • keyword - full keyword
  • date - date of result
  • clicks - number of clicks on link in search view with particular keyword
  • impressions - number of views of link in search view with particular keyword
  • ctr - click through rate (clicks / impressions)
  • avg_position - average position of link on list of results in search view with particular keyword

Model API

To make usage of gathered data easier, there is a simple API for most common use cases:

  • url('http://example.com') - adds where clause for limiting results to only one website (not necessary when you fetch only one website)
  • grouped() - prepares sum of clicks and impressions of each keyword gathered for the website
  • byDay() - prepares sum of clicks and impressions of each day
  • orderByDate($dir = 'asc') - sorts results by date
  • orderBySum($param = 'clicks') - sorts results by sum of clicks/impressions (works with grouped scope)
  • orderByAlpha($dir = 'asc') - sorts results alphabetically

Usage

  1. Get most popular keywords of your website:
<?php
	use HighSolutions\GoogleKeywords\Models\GoogleKeyword;

	$results = GoogleKeyword::url('http://highsolutions.pl')->grouped()->orderBySum('clicks')->take(10)->get();
  1. Get all keywords stored day by day:
<?php
	use HighSolutions\GoogleKeywords\Models\GoogleKeyword;

	$results = GoogleKeyword::url('http://highsolutions.pl')->orderByDate()->get();
  1. Get number of clicks/impressions in the last month:
<?php
	use Carbon\Carbon;
	use HighSolutions\GoogleKeywords\Models\GoogleKeyword;

	$results = GoogleKeyword::url('http://highsolutions.pl')->byDate()->where('date', '>=', Carbon::now()->subMonth(1))->orderByDate()->get();

Changelog

1.1.0

  • Laravel 6.0 support

1.0.3

  • Support Package Auto-Discovery

1.0.2

  • Fix error with checking config

1.0.0

  • Create package
  • Model API

Roadmap

  • Gather info about subsites also
  • Examples of usage as controllers and views
  • Comments
  • Unit tests!

Credits

This package is developed by HighSolutions, software house from Poland in love in Laravel.

laravel-google-keywords's People

Contributors

adammatysiak avatar

Watchers

James Cloos avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.