GithubHelp home page GithubHelp logo

sasrlocke / geocoderlaravel Goto Github PK

View Code? Open in Web Editor NEW

This project forked from geocoder-php/geocoderlaravel

0.0 1.0 0.0 133 KB

Geocoder service provider for Laravel 4 & 5

Home Page: http://geocoder-php.org/GeocoderLaravel/

License: MIT License

PHP 100.00%

geocoderlaravel's Introduction

Geocoder for Lavarel 5

If you still use Lavarel 4, please check out the 0.4.x branch here.

This package allows you to use Geocoder in Laravel 5.

Latest StableVersion Total Downloads Build Status Coverage Status

Installation

It can be found on Packagist. The recommended way is through composer.

Edit composer.json and add:

{
    "require": {
        "toin0u/geocoder-laravel": "@stable"
    }
}

Protip: you should browse the toin0u/geocoder-laravel page to choose a stable version to use, avoid the @stable meta constraint.

And install dependencies:

$ composer update

If you do not have Composer installed, run these two commands:

$ curl -sS https://getcomposer.org/installer | php
$ php composer.phar install

Usage

Find the providers array key in config/app.php and register the Geocoder Service Provider.

'providers' => array(
    // ...

    'Toin0u\Geocoder\GeocoderServiceProvider',
)

Find the aliases array key in config/app.php and register the Geocoder Facade.

'aliases' => array(
    // ...

    'Geocoder' => 'Toin0u\Geocoder\Facade\Geocoder',
)

Configuration

Publish and edit the configuration file

$ php artisan vendor:publish --provider="toin0u/geocoder-laravel"

The service provider creates the following services:

  • geocoder: the Geocoder instance.
  • geocoder.chain: the chain provider used by Geocoder.
  • geocoder.adapter: the HTTP adapter used to get data from remotes APIs.

By default, the geocoder.chain service contains GoogleMapsProvider and FreeGeoIpProvider. The geocoder.adapter service uses the cURL adapter. Override these services to use the adapter/providers you want by editing config/geocoder.php:

return array(
    'providers' => array(
        'Geocoder\Provider\GoogleMapsProvider' => array('my-locale', 'my-region', $ssl = true, 'my-api-key'),
        'Geocoder\Provider\GoogleMapsBusinessProvider' => array(
            'my-client-id', 'my-api-key', 'my-locale', 'my-region', $ssl = true
        ),
        'Geocoder\Provider\CloudMadeProvider'  => array('my-api-key'),
        'Geocoder\Provider\FreeGeoIpProvider'  => null, // or array()
        // ...
    ),
    'adapter'  => 'Geocoder\HttpAdapter\CurlHttpAdapter'
);

NB: As you can see the array value of the provider is the constructor arguments.

See the Geocoder documentation for a list of available adapters and providers.

Example with Facade

<?php

// ...
try {
    $geocode = Geocoder::geocode('10 rue Gambetta, Paris, France');
    // The GoogleMapsProvider will return a result
    var_dump($geocode);
} catch (\Exception $e) {
    // No exception will be thrown here
    echo $e->getMessage();
}

Changelog

See the CHANGELOG file

Support

Please open an issue on GitHub

Contributor Code of Conduct

Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.

License

GeocoderLaravel is released under the MIT License. See the bundled LICENSE file for details.

geocoderlaravel's People

Contributors

toin0u avatar spinegar avatar anaxamaxan avatar willdurand avatar hootlex avatar thewinterwind avatar verkaufer avatar liuggio avatar dwenaus avatar sasrlocke avatar

Watchers

 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.