Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/hi-folks/milk-sdk-php

Milk SDK PHP is a (fluent) open-source PHP library that makes it easy to integrate your PHP application with location services like Geocode, Route, Isoline, Search Places and Address, location data ...
https://github.com/hi-folks/milk-sdk-php

geocoder-api geolocation hacktoberfest hacktoberfest2021 location-data location-services php

Last synced: 30 days ago
JSON representation

Milk SDK PHP is a (fluent) open-source PHP library that makes it easy to integrate your PHP application with location services like Geocode, Route, Isoline, Search Places and Address, location data ...

Awesome Lists containing this project

README

        

# Milk SDK PHP

[![Actions Status](https://github.com/hi-folks/milk-sdk-php/workflows/PHP%20check%20test/badge.svg)](https://github.com/hi-folks/milk-sdk-php/actions)
[![GitHub license](https://img.shields.io/github/license/hi-folks/milk-sdk-php)](https://github.com/hi-folks/milk-sdk-php/blob/master/LICENSE.md)

![Milk SDK PHP](milk-sdk-php.png "Milk SDK PHP")

Milk SDK PHP is a (fluent) open-source PHP library that makes it easy to integrate your PHP application with location services like:
- [HERE **Routing** API **V8**](#routing-api-v8) and [**V7**](#routing-api-v7): for calculate routes from a starting point to destination;
- [HERE **Weather** Destination API](#weather-api): for getting weather forecasts;
- [HERE **Geocoding** API](#geocoding-api): for converting addresses into geographic coordinates;
- [HERE **Reverse Geocoding** API](#reverse-geocoding-api): for converting coordinates into addresses;
- [HERE **Isoline** API](#isoline-api): for calculating the area that a driver (or a biker or a walker) can reach within a given time or distance;
- [HERE **Discover** API](#discover-api): for searching addresses, places and locations;
- [HERE **Map Image** API](#map-image-api): for creating static image of a map;
- [HERE **Data Hub** API](#use-here-data-hub);
- ... other coming soon ...

## Getting Started

### Install the SDK

In your PHP project install package via Composer:

```sh
composer require hi-folks/milk-sdk-php
```
## Obtain HERE API Key
To use HERE Location Services you will need an API key. The API key is a unique identifier that is used to authenticate API requests associated with your project.
There is a official tutorial for retrieving the API Key:
https://developer.here.com/tutorials/getting-here-credentials/

## Weather API

With Weather API class you can get weather forecasts, observation, or alerts for a specific location.

You can call the following methods to get the corresponding weather information:

- *productObservation()*: Get current weather conditions from the eight closest locations to the specified location.
- *productAlerts()*: Get forecasted weather alerts for the next 24 hours.
- *productForecast7days()*: Get morning, afternoon, evening and night weather forecasts for the next seven days.
- *productForecast7daysSimple()*: Get daily weather forecasts for the next seven days.
- *productForecastAstronomy()*: Get information on when the sun and moon rise and set, and on the phase of the moon for the next seven days.
- *productForecastHourly()*: Get hourly weather forecasts for the next seven days.
- *productNwsAlerts()*: Get all active watches and warnings for the US and Canada.

For example, to retrieve weather forecasts in Berlin:

```php
$jsonWeather = Weather::instance()
->setAppIdAppCode($hereAppId, $hereAppCode)
->productForecast7days()
->name("Berlin")
->get();
var_dump($jsonWeather->getData());
var_dump($jsonWeather->isError());
var_dump($jsonWeather->getErrorMessage());
var_dump($jsonWeather->getDataAsJsonString());
```

## Routing API (v7)
To retrieve the fastest route by foot

```php
$r = (new RoutingV7())
->setApiKey($hereApiKey)
->byFoot()
->typeFastest()
->startingPoint(52.5160, 13.3779)
->destination(52.5185, 13.4283)
->get();
var_dump($r->getData());
var_dump($r->isError());
var_dump($r->getErrorMessage());
var_dump($r->getDataAsJsonString());
```

Instead of using get(), you could use _getManeuverInstructions()_ method:

```php
$r = (new RoutingV7())
->setApiKey($hereApiKey)
->byFoot()
->typeFastest()
->startingPoint(52.5160, 13.3779)
->destination(52.5185, 13.4283)
->getManeuverInstructions();

var_dump($r);
```

## Routing API (v8)
To retrieve the fastest route by car

```php
$routingActions = RoutingV8::instance()
->setApiKey($hereApiKey)
->byCar()
->routingModeFast()
->startingPoint(52.5160, 13.3779)
->destination(52.5185, 13.4283)
->returnInstructions()
->langIta()
->getDefaultActions();

foreach ($routingActions as $key => $action) {
echo " - ".$action->instruction . PHP_EOL;
}
```

## Geocoding API
In order to retrieve geo-coordinates (latitude, longitude) of a known address or place.

```php
use HiFolks\Milk\Here\RestApi\Geocode;
$hereApiKey = "Your API KEY";
$r = Geocode::instance()
->setApiKey($hereApiKey)
->country("Italia")
->q("Colosseo")
->langIta()
->get();
var_dump($r->getData());
var_dump($r->isError());
var_dump($r->getErrorMessage());
var_dump($r->getDataAsJsonString());
```

## Reverse Geocoding API
In order to find the nearest address to specific geo-coordinates:

```php
use HiFolks\Milk\Here\RestApi\ReverseGeocode;
$hereApiKey = "Your API KEY";
$r = ReverseGeocode::instance()
->setApiKey($hereApiKey)
->at(41.88946,12.49239)
->limit(5)
->lang("en_US")
->get();
var_dump($r->getData());
var_dump($r->isError());
var_dump($r->getErrorMessage());
var_dump($r->getDataAsJsonString());

if ($r->isError()) {
echo "Error: ". $r->getErrorMessage();
} else {
$items = $r->getData()->items;
foreach ($items as $key => $item) {
echo " - " .$item->title.
" : ( ".$item->position->lat . "," . $item->position->lng .
" ) , distance:" . $item->distance . " , type: " . $item->resultType . PHP_EOL;
}
}
```

## Isoline API
```php
use HiFolks\Milk\Here\RestApi\Isoline;
$hereApiKey = "yourapikey";
$isoline = Isoline::instance()
->setApiKey($hereApiKey)
->originPoint(41.890251, 12.492373)
->byFoot()
->rangeByTime(600) // 10 minutes
->get();

```
## Map Image Api
With MapImage class you can create static image of a map.
For the map you can define:
- *center()*: the center of the map;
- *addPoi()*: add a point in the map;
- *zoom()*: set the zoom level;
- *height()*: set the height of image (in pixel);
- *width()*: set the width of the image (in pixel).
```php
use Hifolks\milk\here\RestApi\MapImage;
$hereApiKey = "yourapikey";
$imageUrl = MapImage::instance($hereApiKey)
->center(45.548, 11.54947)
->addPoi(45, 12, "ff0000")
->addPoi(45.1, 12.1, "00ff00")
->addPoi(45.2, 12.2, "0000ff", "", "12", "Test 3")
->zoom(12)
->height(2048)
->width(2048 / 1.4)
->getUrl();
```

You can use also the Geocoding functionality with *centerAddress()* method.
```php
$image = MapImage::instance($hereApiKey)
->centerAddress("Venezia")
->zoom(12)
->height(2048)
->width(intval(2048 / 1.4));
$imageUrl = $image->getUrl();
```

## Discover API
If you need to search an address or a place and you need to validate it and obtain some other information about the location, you can use *Discover API* endpoint via Discover class.
```php
$address = "Basilica San Marco, venezia";
// instance the class
$discover = Discover::instance($hereApiKey)
// define the address
->q($address)
// define a center point (for example Rome)
->at(41.902782, 12.496366)
// define where to limit the search, in this case ITA is the country code for Italy
->inCountry("ITA")
->get();
```

If you need to search an address in Italy, you can use inItaly() method:
```php
$address = "Basilica San Marco, venezia";
$discover = Discover::instance($hereApiKey)
->q($address)
->inItaly()
->get();
```

## Use HERE Data Hub
### Configuring XYZ HUB

With this SDK you can consume DataHub (XYZ) API.
You have 2 options:
- use your own instance of XYZ HUB
or
- use Data Hub Cloud https://developer.here.com/documentation/studio/map_customization_suite_hlp/dev_guide/index.html

#### Configure SDK with your own instance of XYZ HUB

Running your own instance of XYZ HUB means that you already have your instance of https://github.com/heremaps/xyz-hub.
A tutorial about how to set up XYZ Hub locally (on localhost): https://dev.to/robertobutti/restful-web-service-for-geospatial-data-12ii

Create a _.env_ file.
Fill it with:

```
XYZ_ACCESS_TOKEN=""
XYZ_API_HOSTNAME="http://localhost:8080"
```

#### Configure SDK with XYZ HUB Cloud service

Using XYZ HUB Cloud Service means that you are using this host https://xyz.api.here.com.

To use this service you need to sign in as developer on https://developer.here.com/ and create your plan (for example Freemium) and obtain your Access Token.

Once you have your access token, create a _.env_ file. You can start from a sample file (_.env.dist_):

```sh
cp .env.dist .env
```

Then, you need to fill your XYZ_ACCESS_TOKEN in .env file with your access token.

## Quick Examples

In order to use the Milk SDK, you need to:

- create a PHP file
- include the autoload.php file
- declare all imports via _use_
- load environment configuration (via _Dotenv_)
- get your token
- get your XYZ Spaces
- display your result

```php
get();
// display your result
var_dump($s->getData());
```

### Retrieve your XYZ Spaces

To get your XYZ Spaces:

```php
$s = XyzSpace::instance($xyzToken)->get();
```

To get XYZ Spaces by everybody (not only your own XYZ Spaces):

```php
$s = XyzSpace::instance($xyzToken)->ownerAll()->get();
```

### Delete Space

To delete a XYZ Space:

```php
$xyzSpaceDeleted = XyzSpace::instance($xyzToken)->delete($spaceId);
```

### Create Space

To create a new XYZ Space:

```php
$xyzSpaceCreated = XyzSpace::instance($xyzToken)->create("My Space", "Description");
```

### Update Space

To update the XYZ Space with space id == \$spaceId:

```php
$obj = new \stdClass;
$obj->title = "Edited Title";
$obj->description = "Edited Description";
$retVal = $space->update($spaceId, $obj);
```

### Statistics

The get statistics from XYZ Space:

```php
$statistics = XyzSpaceStatistics::instance($xyzToken)->spaceId($spaceId)->get();
```

### Features

Iterate features

```php
/** XyzSpaceFeature $xyzSpaceFeature */
$xyzSpaceFeature = new XyzSpaceFeature::instance($xyzToken);
$result = $xyzSpaceFeature->iterate($spaceId)->get();
```

### Retrieve 1 Feature

You need to use feature() method with $featureId and $spaceId

```php
$xyzSpaceFeature = XyzSpaceFeature::instance($xyzToken);
$result = $xyzSpaceFeature->feature($featureId, $spaceId)->get();
```

### Create or Edit 1 Feature

To create or edit a Feature you can use saveOne() method.

```php
$spaceId = "yourspaceid";
$featureId = "yourfeatureid";
$geoJson = new GeoJson();
$properties = [
"name" => "Berlin",
"op" => "Put"
];
$geoJson->addPoint(52.5165, 13.37809, $properties, $featureId);
$feature = XyzSpaceFeatureEditor::instance($xyzToken);
$result = $feature->feature($geoJson->get())->saveOne($spaceId, $featureId);
$feature->debug();
```

### Create multiple features from a geojson file

If you have a Geojson File, you can upload it into a space.

```php
$spaceId = "yourspaceid";
$file = "https://data.cityofnewyork.us/api/geospatial/arq3-7z49?method=export&format=GeoJSON";
$response = XyzSpaceFeatureEditor::instance($xyzToken)
->addTags(["file"])
->geojson($file)
->create($spaceId);
```

### Search features by property

To search features by properties you can use *addSearchParams* to add serach params, in the example below, you are searching features with *name* property equals "Colosseo".

```php
$spaceId = "yourspaceid";
$xyzSpaceFeature = XyzSpaceFeature::instance($xyzToken)->addSearchParams("p.name", "Colosseo");
$result = $xyzSpaceFeature->search($spaceId)->get();
```
### Search features by proximity

To search feature close to latitude=41.890251 and longitude=12.492373 with a radius less than 1000 meters (close to Colosseum):

```php
$spaceId = "yourspaceid";
$result = XyzSpaceFeature::instance($xyzToken)->spatial($spaceId, 41.890251, 12.492373, 1000)->get();
```

## Useful reference

### Data Hub API

- ReDoc API documentation: https://xyz.api.here.com/hub/static/redoc/
- Open API documentation: https://xyz.api.here.com/hub/static/swagger/

### HERE Destination Weather API

- Overview: https://developer.here.com/documentation/destination-weather/dev_guide/topics/overview.html
- API Reference: https://developer.here.com/documentation/destination-weather/dev_guide/topics/api-reference.html

### HERE Rest Routing V8 API

- Overview: https://developer.here.com/documentation/routing-api/8.9.1/dev_guide/topics/use-cases/calculate-route.html
- API Reference: https://developer.here.com/documentation/routing-api/8.9.1/api-reference-swagger.html

### HERE Rest Geocoding API

- Overview: https://developer.here.com/documentation/geocoding-search-api/dev_guide/topics/endpoint-geocode-brief.html

### HERE Rest Reverse Geocoding API

- Overview: https://developer.here.com/documentation/geocoding-search-api/dev_guide/topics/endpoint-reverse-geocode-brief.html

### HERE Rest Isoline API

- Overview: https://developer.here.com/documentation/isoline-routing-api/dev_guide/index.html