google-maps-plugin/Plugin.php
2019-03-11 18:25:18 +03:00

170 lines
5.2 KiB
PHP

<?php
/*
* This file is a part of Mibew Google Maps Plugin.
*
* Copyright 2014 Dmitriy Simushev <simushevds@gmail.com>.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* @file The main file of Mibew:GoogleMaps plugin.
*/
namespace Mibew\Mibew\Plugin\GoogleMaps;
use Mibew\Asset\AssetManagerInterface;
use Mibew\EventDispatcher\EventDispatcher;
use Mibew\EventDispatcher\Events;
use Mibew\Plugin\PluginManager;
/**
* Provides an ability to view visitors at Google Maps.
*/
class Plugin extends \Mibew\Plugin\AbstractPlugin implements \Mibew\Plugin\PluginInterface
{
/**
* Class constructor.
*
* @param array $config List of the plugin config. The following options are
* supported:
* - 'api_key': string, Google Maps API key that should be used to render
* maps.
*/
public function __construct($config)
{
if (empty($config['api_key'])) {
trigger_error('Google API key cannot be empty', E_USER_WARNING);
return;
}
parent::__construct($config);
$this->initialized = true;
}
/**
* Defines necessary event listeners.
*/
public function run()
{
$dispatcher = EventDispatcher::getInstance();
$dispatcher->attachListener(Events::USERS_FUNCTION_CALL, $this, 'usersFunctionCallHandler');
$dispatcher->attachListener(Events::PAGE_ADD_JS, $this, 'pageAddJsHandler');
$dispatcher->attachListener(Events::PAGE_ADD_CSS, $this, 'pageAddCssHandler');
}
/**
* A handler for {@link \Mibew\EventDispatcher\Events::USERS_FUNCTION_CALL}.
*
* Provides an ability to use "googleMapsGetInfo" function at the client
* side.
*
* @see \Mibew\EventDispatcher\Events::USERS_FUNCTION_CALL
*/
public function usersFunctionCallHandler(&$function)
{
if ($function['function'] == 'googleMapsGetInfo') {
// An IP string can contain more than one IP address. For example it
// can be something like this: "x.x.x.x (x.x.x.x)". We need to
// use only first one.
$ips = explode(' ', $function['arguments']['ip'], 2);
$ip = filter_var($ips[0], FILTER_VALIDATE_IP);
if (!$ip) {
// There is no valid IP in the string. An error should be returned.
$function['results'] = array(
'errorCode' => 1,
'errorMessage' => 'The specified IP is invalid!',
);
return;
}
$info = PluginManager::getInstance()
->getPlugin('Mibew:GeoIp')
->getGeoInfo($ip, get_current_locale());
$function['results'] = array(
'country' => $info['country_name'] ?: '',
'city' => $info['city'] ?: '',
'latitude' => $info['latitude'],
'longitude' => $info['longitude'],
);
}
}
/**
* Adds custom JS files to the page.
*
* @see \Mibew\EventDispatcher\Events::PAGE_ADD_JS
*/
public function pageAddJsHandler(&$args)
{
if ($args['request']->attributes->get('_route') == 'users') {
$filepath = str_replace(DIRECTORY_SEPARATOR, '/', $this->getFilesPath());
$args['js'][] = $filepath . '/vendor/jquery-colorbox/jquery.colorbox-min.js';
$args['js'][] = array(
'content' => $this->getApiUrl(),
'type' => AssetManagerInterface::ABSOLUTE_URL,
);
$args['js'][] = $filepath . '/js/plugin.js';
}
}
/**
* Adds custom CSS files to the page.
*
* @see \Mibew\EventDispatcher\Events::PAGE_ADD_CSS
*/
public function pageAddCssHandler(&$args)
{
if ($args['request']->attributes->get('_route') == 'users') {
$filepath = str_replace(DIRECTORY_SEPARATOR, '/', $this->getFilesPath());
$args['css'][] = $filepath . '/vendor/jquery-colorbox/example3/colorbox.css';
$args['css'][] = $filepath . '/css/styles.css';
}
}
/**
* {@inheritdoc}
*/
public static function getVersion()
{
return '1.1.1';
}
/**
* {@inheritdoc}
*/
public static function getDependencies()
{
return array('Mibew:GeoIp' => '1.*');
}
/**
* Builds URL for Google Maps API.
*
* @return string API URL
* @throws \RuntimeException if API key was not set correctly.
*/
protected function getApiUrl()
{
if (empty($this->config['api_key'])) {
throw new \RuntimeException('Google API key cannot be empty');
}
return '//maps.googleapis.com/maps/api/js?key='
. $this->config['api_key']
. '&sensor=false';
}
}