swp / updater-bundle
Provides integration for ahilles107/updater which gives an easy way to update your application.
Installs: 2 342
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 3
Forks: 3
Open Issues: 2
Type:symfony-bundle
Requires
- php: >=5.4
- ahilles107/updater: 1.0.x-dev
- friendsofsymfony/rest-bundle: >=1.7.1
- jms/serializer-bundle: ^1.0
- nelmio/api-doc-bundle: @stable
- symfony/framework-bundle: ~2.0
- vierbergenlars/php-semver: ^3.0
- willdurand/hateoas-bundle: ^1.0
Requires (Dev)
- akeneo/phpspec-skip-example-extension: ^1.2@dev
- phpspec/phpspec: ~2.0
- phpunit/php-code-coverage: @stable
- phpunit/phpunit: ~4.5@stable
Suggests
- guzzlehttp/guzzle: Allows to send more advanced HTTP requests (requires PHP >= 5.5.0)
This package is auto-updated.
Last update: 2020-01-26 16:25:47 UTC
README
Provides integration for updater which gives an easy way to update your application.
Installation
Installation is a 8 step process:
- Download SWPUpdaterBundle
- Enable the bundle and its dependencies
- Create your own
Version
class or use existing one - Import SWPUpdaterBundle routing file
- Configure the FOSRestBundle
- Configure the SensioFrameworkExtraBundle
- Configure the Symfony FrameworkBundle
- Configure the SWPUpdaterBundle
Step 1: Install SWPUpdaterBundle with Composer
Run the following composer require command:
$ php composer.phar require swp/updater-bundle
Step 2: Enable the bundle and its dependencies
Enable the bundle in AppKernel.php
and its all dependencies (FOSRestBundle, JMSSerializerBundle, NelmioApiDocBundle)
<?php // app/AppKernel.php public function registerBundles() { $bundles = array( // ... new SWP\UpdaterBundle\SWPUpdaterBundle(), new FOS\RestBundle\FOSRestBundle(), new JMS\SerializerBundle\JMSSerializerBundle(), new Nelmio\ApiDocBundle\NelmioApiDocBundle(), ); }
Step 3: Create your own Version
class or use existing one
This bundle requires your own Version
class to read the current application's version and apply available updates based on that.
You must create your own Version
class for your application which must implement SWP\UdaterBundle\Version\VersionInterface
interface which is provided by this bundle. See the example below.
<?php namespace Acme\DemoBundle\Version; use SWP\UpdaterBundle\Version\VersionInterface; final class Version implements VersionInterface { private $version = '0.0.1'; public function getVersion() { return $this->version; } public function setVersion($version) { $this->version = $version; return $this; } }
Step 4: Import SWPUpdaterBundle routing file
You have to import SWPUpdaterBundle routing file. You can use YAML or XML format.
YAML:
# app/config/routing.yml swp_updater: resource: "@SWPUpdaterBundle/Resources/config/routing.yml" prefix: /
XML:
<!-- app/config/routing.xml --> <import resource="@SWPUpdaterBundle/Resources/config/routing.xml" prefix="/" />
Step 5: Configure the FOSRestBundle
FOSRestBundle will be installed automatically for you. You just have to configure it. SWPUpdaterBundle provides an API endpoints to get and post appropiate data. To make use of the API provided by SWPUpdaterBundle you have to configure FOSRestBundle properly.
FOSRestBundle provides various tools to rapidly develop RESTful API's with Symfony2. Below example provides ready to be used YAML configuration.
Thanks to NelmioApiDocBundle, the SWPUpdaterBundle API documentation can be available under the url: http://example.com/api/doc
For more informations about the configuration of the FOSRestBundle, please see documentation
# app/config/config.yml fos_rest: routing_loader: default_format: json view: formats: json: true view_response_listener: 'force' format_listener: rules: - { path: '^/api', priorities: ['json'], fallback_format: json, prefer_extension: true } - { path: '^/', stop: true } exception: codes: 'Symfony\Component\Routing\Exception\ResourceNotFoundException': 404 messages: 'Symfony\Component\Routing\Exception\ResourceNotFoundException': true
Step 6: Configure the SensioFrameworkExtraBundle
Symfony FrameworkBundle will be installed automatically for you. You just have to configure it.
# app/config/config.yml sensio_framework_extra: view: { annotations: false }
Step 7: Configure the Symfony FrameworkBundle
Symfony FrameworkBundle will be installed automatically for you. You just have to configure it.
# app/config/config.yml framework: templating: engines: ['twig']
Step 8: Configure the SWPUpdaterBundle
Now that you have your own Version
class, it's time to configure the bundle for your needs.
Add the following parameter to your parameters.yml
file.
# app/config/parameters.yml parameters: swp_updater.version.class: "Acme\DemoBundle\Version\Version"
Add the following configuration to your config.yml
file.
# app/config/config.yml swp_updater: version_class: %swp_updater.version.class% client: base_uri: http://example.com
At this stage, the bundle is ready to be used by your application.
Adding custom http client options:
SWPUpdaterBundle uses Guzzle to fetch data from the external server which provides informations about the update packages. You can add custom Guzzle options / headers for your http client by simply adding an array of options as a parameter. The example below shows how to add custom curl options.
# app/config/parameters.yml parameters: swp_updater.client.options: curl: # http://guzzle.readthedocs.org/en/latest/faq.html#how-can-i-add-custom-curl-options 10203: # integer value of CURLOPT_RESOLVE - "example.com:localhost" # This will resolve the host example.com to your localhost
For more details see Guzzle documentation.
Changing default directories:
There are two types of directories used by the Http client:
- temporary directory - specifies where the update packages will be downlaoded and extacted, defaults to
app/cache/<env>
where<env>
can bedev
,test
orprod
. - target directory - directory which should be updated, defaults to the current application directory.
Those directories can be changed by setting temp_dir
and target_dir
options in your config.yml file.
# app/config/config.yml swp_updater: temp_dir: "/some/temp/dir" target_dir: "/some/target/dir"
Enabling Monolog channel for SWPUpdaterBundle:
It is possible to enable a separate Monolog channel to which all logs will be forwarded. You will have then a separate log file for the SWPUpdaterBundle which will be saved under the directory app/logs/
and will be named updater_<env>-<current_date>.log
.
By default, separate channel is disabled. You can enable it by setting monolog_channel
option to true
and configuring Monolog.
# app/config/config.yml swp_updater: monolog_channel: true monolog: channels: ["updater"] handlers: updater: type: rotating_file # creates a new file every day (http://symfony.com/doc/current/cookbook/logging/monolog.html#how-to-rotate-your-log-files) path: %kernel.logs_dir%/updater_%kernel.environment%.log level: debug max_files: 10 channels: ["updater"]
For more details see the Monolog documentation.
Changing a client's type:
SWPUpdaterBundle supports two clients to download the update packages from the update server:
- PHP (file_get_contents)
- Guzzle
It is possible to change between these two clients, by simply defining the client's type
in bundle configuration. Available types are:
- guzzle
- default
When type
is not defined, PHP (default) client will be used by default.
# app/config/config.yml swp_updater: version_class: %swp_updater.version.class% client: base_uri: http://example.com type: guzzle # or default