commit b87b6b2a96de870f1782b00cfe3f393cc79b7d3b Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Mon Dec 18 14:05:11 2017 +0000 Even more tests for this micropub refactor commit 2d967f33c3abeea8fc89f91e1764e970681dc58f Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sat Dec 16 22:19:53 2017 +0000 Fill out token endpoint tests commit 440dcbe3e53f058060c918429bea75911ddafdc1 Merge: 02a25b0 f60164f Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Fri Dec 15 14:32:50 2017 +0000 Merge pull request #77 from jonnybarnes/analysis-8KABW6 Apply fixes from StyleCI commit f60164fe81dbcc1d2343704145d26c6d6412579a Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Fri Dec 15 14:27:40 2017 +0000 Apply fixes from StyleCI commit 02a25b083a0305f73d715feb3f9d34f9de8f67d4 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Fri Dec 15 14:17:43 2017 +0000 phpcs fix commit 144998de0866bf11f235847d7edc076235294545 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Fri Dec 15 14:16:59 2017 +0000 Don’t pass the request object to service files, pass request()->all() commit dd5e52010c51a359665efa349ff8c13d4d6dbf57 Merge: 97b270a 23b145e Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sun Dec 10 20:01:03 2017 +0000 Merge pull request #76 from jonnybarnes/analysis-86AVg6 Apply fixes from StyleCI commit 23b145e7bf67a358b3cb894ea0793984b65ecab5 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sun Dec 10 19:50:53 2017 +0000 Apply fixes from StyleCI commit 97b270a89abe92e167e0d363029ae0b86608bbc9 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sun Dec 10 19:43:38 2017 +0000 Improve test coverage of the refactor commit 244102264559e4fb0b0614d1738c0283703a71dc Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Fri Dec 8 13:31:13 2017 +0000 Refactor the note creation code commit 22b4786cbd7ae508b51a47f0c8cf9a15535edbb1 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Thu Dec 7 17:39:41 2017 +0000 Remove ununsed importsed classes in the controller
163 lines
3.6 KiB
PHP
163 lines
3.6 KiB
PHP
<?php
|
|
|
|
namespace App;
|
|
|
|
use Illuminate\Support\Facades\DB;
|
|
use Illuminate\Database\Eloquent\Model;
|
|
use Illuminate\Database\Eloquent\Builder;
|
|
use Cviebrock\EloquentSluggable\Sluggable;
|
|
use Phaza\LaravelPostgis\Geometries\Point;
|
|
use Phaza\LaravelPostgis\Eloquent\PostgisTrait;
|
|
|
|
class Place extends Model
|
|
{
|
|
use Sluggable;
|
|
use PostgisTrait;
|
|
|
|
/**
|
|
* The attributes that are mass assignable.
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $fillable = ['name', 'slug'];
|
|
|
|
/**
|
|
* The attributes that are Postgis geometry objects.
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $postgisFields = [
|
|
'location',
|
|
'polygon',
|
|
];
|
|
|
|
/**
|
|
* Return the sluggable configuration array for this model.
|
|
*
|
|
* @return array
|
|
*/
|
|
public function sluggable()
|
|
{
|
|
return [
|
|
'slug' => [
|
|
'source' => 'name',
|
|
'onUpdate' => true,
|
|
],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Define the relationship with Notes.
|
|
*
|
|
* @var array
|
|
*/
|
|
public function notes()
|
|
{
|
|
return $this->hasMany('App\Note');
|
|
}
|
|
|
|
/**
|
|
* Select places near a given location.
|
|
*
|
|
* @param \Illuminate\Database\Eloquent\Builder $query
|
|
* @param Point $point
|
|
* @param int Distance
|
|
* @return \Illuminate\Database\Eloquent\Builder
|
|
*/
|
|
public function scopeNear(Builder $query, Point $point, $distance = 1000)
|
|
{
|
|
$field = DB::raw(
|
|
sprintf(
|
|
"ST_Distance(%s.location, ST_GeogFromText('%s'))",
|
|
$this->getTable(),
|
|
$point->toWKT()
|
|
)
|
|
);
|
|
|
|
return $query->where($field, '<=', $distance)->orderBy($field);
|
|
}
|
|
|
|
public function scopeWhereExternalURL(Builder $query, string $url)
|
|
{
|
|
return $query->where('external_urls', '@>', json_encode([
|
|
$this->getType($url) => $url,
|
|
]));
|
|
}
|
|
|
|
/**
|
|
* Get the latitude from the `location` property.
|
|
*
|
|
* @return string latitude
|
|
*/
|
|
public function getLatitudeAttribute()
|
|
{
|
|
return explode(' ', $this->location)[1];
|
|
}
|
|
|
|
/**
|
|
* Get the longitude from the `location` property.
|
|
*
|
|
* @return string longitude
|
|
*/
|
|
public function getLongitudeAttribute()
|
|
{
|
|
return explode(' ', $this->location)[0];
|
|
}
|
|
|
|
/**
|
|
* The Long URL for a place.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getLongurlAttribute()
|
|
{
|
|
return config('app.url') . '/places/' . $this->slug;
|
|
}
|
|
|
|
/**
|
|
* The Short URL for a place.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getShorturlAttribute()
|
|
{
|
|
return config('app.shorturl') . '/places/' . $this->slug;
|
|
}
|
|
|
|
/**
|
|
* This method is an alternative for `longurl`.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getUriAttribute()
|
|
{
|
|
return $this->longurl;
|
|
}
|
|
|
|
public function setExternalUrlsAttribute($url)
|
|
{
|
|
if ($url === null) {
|
|
return;
|
|
}
|
|
$type = $this->getType($url);
|
|
$already = [];
|
|
if (array_key_exists('external_urls', $this->attributes)) {
|
|
$already = json_decode($this->attributes['external_urls'], true);
|
|
}
|
|
$already[$type] = $url;
|
|
$this->attributes['external_urls'] = json_encode($already);
|
|
}
|
|
|
|
private function getType(string $url): ?string
|
|
{
|
|
$host = parse_url($url, PHP_URL_HOST);
|
|
if (ends_with($host, 'foursquare.com') === true) {
|
|
return 'foursquare';
|
|
}
|
|
if (ends_with($host, 'openstreetmap.org') === true) {
|
|
return 'osm';
|
|
}
|
|
|
|
return 'default';
|
|
}
|
|
}
|