Download the PHP package mstaack/laravel-postgis without Composer
On this page you can find all versions of the php package mstaack/laravel-postgis. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download mstaack/laravel-postgis
More information about mstaack/laravel-postgis
Files in mstaack/laravel-postgis
Package laravel-postgis
Short Description Postgis extensions for laravel. Aims to make it easy to work with geometries from laravel models
License MIT
Informations about the package laravel-postgis
Laravel Wrapper for PostgreSQL's Geo-Extension Postgis
DEPRECATED
Consider using: https://github.com/clickbar/laravel-magellan
Features
- Work with geometry classes instead of arrays.
- Adds helpers in migrations.
Warning
This Package has been moved to a new owner and aims for Laravel 6/7/8/9 and PHP 7 support only soon!
Replace all your references to the new namespace:
Thanks to :
Fluent in Laravel Packages and Postgres/Postgis? Consider contributing! We are looking for anyone that wants to help out!
Installation
-
Use 3.* for Laravel 5
- Use 5.* for Laravel 6/7/8/9
For laravel >=5.5 that's all. This package supports Laravel new Package Discovery.
If you are using Laravel < 5.5, you also need to add the DatabaseServiceProvider to your config/app.php
file.
Usage
To start, ensure you have PostGIS enabled in your database - you can do this in a Laravel migration or manually via SQL.
Enable PostGIS via a Laravel migration
You need to publish the migration to easily enable PostGIS:
And then you run the migrations:
These methods are safe to use and will only enable / disable the PostGIS extension if relevant - they won't cause an error if PostGIS is / isn't already enabled.
If you prefer, you can use the enablePostgis()
method which will throw an error if PostGIS is already enabled, and the disablePostgis()
method twhich will throw an error if PostGIS isn't enabled.
Enable PostGIS manually
Use an SQL client to connect to your database and run the following command:
CREATE EXTENSION postgis;
To verify that PostGIS is enabled you can run:
SELECT postgis_full_version();
Migrations
Now create a model with a migration by running
php artisan make:model Location
If you don't want a model and just a migration run
php artisan make:migration create_locations_table
Open the created migrations with your editor.
Available blueprint geometries:
- point
- multipoint
- linestring
- multilinestring
- polygon
- multipolygon
- geometrycollection
other methods:
- enablePostgis
- disablePostgis
Models
All models which are to be PostGis enabled must use the PostgisTrait.
You must also define an array called $postgisFields
which defines
what attributes/columns on your model are to be considered geometry objects. By default, all attributes are of type geography
. If you want to use geometry
with a custom SRID, you have to define an array called $postgisTypes
. The keys of this assoc array must match the entries in $postgisFields
(all missing keys default to geography
), the values are assoc arrays, too. They must have two keys: geomtype
which is either geography
or geometry
and srid
which is the desired SRID. Note: Custom SRID is only supported for geometry
, not geography
.
Available geometry classes:
- Point
- MultiPoint
- LineString
- MultiLineString
- Polygon
- MultiPolygon
- GeometryCollection
Publishing config
A configuration file exists for overriding default values. To add to your project, run:
Coordinate precision
The precision of stored/displayed coordinated can be customised in the config.
See http://wiki.gis.com/wiki/index.php/Decimal_degrees#Accuracy for more information
All versions of laravel-postgis with dependencies
illuminate/database Version ^6.0|^7.0|^8.0|^9.0|^10.0
geo-io/wkb-parser Version ^1.0
jmikola/geojson Version ^1.0
bosnadev/database Version ^0.21|dev-master