GeoSot/Laravel-EnvEditor

View on GitHub
README.md

Summary

Maintainability
Test Coverage
[![Latest Version on Packagist](https://img.shields.io/packagist/v/geo-sot/laravel-env-editor.svg?style=flat-square)](https://packagist.org/packages/geo-sot/laravel-env-editor)
[![Total Downloads](https://img.shields.io/packagist/dt/geo-sot/laravel-env-editor.svg?style=flat-square)](https://packagist.org/packages/geo-sot/laravel-env-editor)
[![Coverage Status](https://coveralls.io/repos/github/GeoSot/Laravel-EnvEditor/badge.svg)](https://coveralls.io/github/GeoSot/Laravel-EnvEditor)
[![Codacy Badge](https://api.codacy.com/project/badge/Grade/bdb3a7b58b5d4efc9dbf07be99ae84df)](https://www.codacy.com/manual/geo.sotis/Laravel-EnvEditor?utm_source=github.com&utm_medium=referral&utm_content=GeoSot/Laravel-EnvEditor&utm_campaign=Badge_Grade)
[![Maintainability](https://api.codeclimate.com/v1/badges/f494c7292af300b0c7fc/maintainability)](https://codeclimate.com/github/GeoSot/Laravel-EnvEditor/maintainability)
[![License](https://poser.pugx.org/geo-sot/laravel-env-editor/license)](https://packagist.org/packages/geo-sot/laravel-env-editor)
# Laravel .env Editor (plus GUI) 
This Package allows to manage Laravel .env file values on the Fly (add, edit, delete keys), upload another .env or create backups
<br/>
Management can be done through the user interface, or programmatically by using the `EnvEditor` Facade, without breaking the files structure. 
<br/>
The inspiration for this package was, [Brotzka/laravel-dotenv-editor](https://github.com/Brotzka/laravel-dotenv-editor).

*   [Installation](#installation)
*   [Available Methods](#available_methods)
*   [User Interface](#user_interface)

## <a name="installation">Installation:</a>

1. Install package
    ```bash
    composer require geo-sot/laravel-env-editor
    ```
2. Publish assets 
     ```bash
     php artisan vendor:publish --provider=GeoSot\EnvEditor\ServiceProvider     
      ```      
      This will publish all files:
    * config -> env-editor.php
    * views -> resources/views/vendor/env-editor/..
    * lang -> resources/lang/vendor/env-editor.php
      
     Or publish specific tags

    ```bash
     //Publish specific tag
     php artisan vendor:publish --tag=config
     php artisan vendor:publish --tag=translations
     php artisan vendor:publish --tag=views
     
     //Publish specific Tag from this Vendor
     php artisan vendor:publish --provider=GeoSot\EnvEditor\ServiceProvider --tag=config  
 
     ```
     
## <a name="available_methods">Available Methods:</a>

>* getEnvFileContent
>* keyExists
>* getKey
>* addKey
>* editKey
>* deleteKey
>* getAllBackUps
>* upload
>* backUpCurrent
>* getFilePath
>* deleteBackup
>* restoreBackUp

<Details>
<Summary>Example</Summary>

   ```php
     
    EnvEditor::getEnvFileContent($fileName='') 
    // Return The .env Data as Collection.
    // If FileName Is provided it searches inside backups Directory and returns these results
 
    EnvEditor::keyExists($key)
    // Search key existance in .env
    
    EnvEditor::getKey(string $key, $default = null)    
    // Get key value from .env,
 
     EnvEditor::addKey($key, $value, array $options = [])
     // Adds new Key in .env file
     // As options can pass ['index'=>'someNumericIndex'] in order to place the new key after an other and not in the end,
     // or ['group'=>'MAIL/APP etc'] to place the new key oat the end of the group 
 
     EnvEditor::editKey($key, $value)
     // Edits existing key value
 
     EnvEditor::deleteKey($key)    
 
     EnvEditor::getAllBackUps()
     // Returns all Backup files as collection with some info like, created_date, content etc.
 
     EnvEditor::upload(UploadedFile $uploadedFile, $replaceCurrentEnv)
     // Gets an UploadedFile and stores it as backup or as current .env
 
     EnvEditor::backUpCurrent()
     // Backups current .env
 
     EnvEditor::getFilePath($fileName = '')
     // Returns the full path of a backup file. 
     // If $fileName is empty returns the full path of the .env file
 
     EnvEditor::deleteBackup($fileName)
     
 
     EnvEditor::restoreBackUp()
     


 ```
</Details>
 <br/>
 

## <a name="user_interface">User Interface</a>

**Note:** user interface is disabled be default. You can enable it by changing the configuration option `env-editor.route.enable`

User Interface Contains three Tabs 

 -  [Current .env](#current_env)
    * [Add new Key](#add_key)
    * [Edit Key](#edit_key)
    * [Delete new Key](#delete_key)
 - [Backups](#backups)
   * [Backups Index](#backups_index)
   * [Backup file details](#backup_file_details)
 - [Upload](#upload)
 
 <br/>
 
### <a name="current_env">Current .env </a>
![Overview](https://user-images.githubusercontent.com/22406063/73443980-60500600-4360-11ea-9d60-7ddf335cfa11.png)
<br/>
<br/>
#### <a name="add_key">Add new key</a>
![AddKey](https://user-images.githubusercontent.com/22406063/73443992-65ad5080-4360-11ea-9311-7ad53a207298.png)
<br/>
<br/>
#### <a name="edit_key">Edit key</a>
![EditKey](https://user-images.githubusercontent.com/22406063/73443996-66de7d80-4360-11ea-879c-365d87b08610.png)
<br/>
<br/>
#### <a name="delete_key">Delete key</a>
![DeleteKey](https://user-images.githubusercontent.com/22406063/73443999-68a84100-4360-11ea-8955-371fcfc0c1b5.png)
<br/>
<br/>
### <a name="backups">Backups</a>
#### <a name="backups_index">Backups Index</a>
![Overview](https://user-images.githubusercontent.com/22406063/73444004-6a720480-4360-11ea-9260-2f3978b828ca.png)
<br/>
<br/>
#### <a name="backup_file_details">Backup file details</a>
![Overview](https://user-images.githubusercontent.com/22406063/73444009-6c3bc800-4360-11ea-9f36-5d50571a84aa.png)
<br/>
<br/>
### Upload
![Overview](https://user-images.githubusercontent.com/22406063/73444015-6e058b80-4360-11ea-80b0-c60f837392ba.png)