orchestra/memory
最新稳定版本:v6.0.0
Composer 安装命令:
composer require orchestra/memory
包简介
Memory Component for Orchestra Platform
README 文档
README
Memory Component handles runtime configuration either using "in memory" Runtime or database using Cache, Fluent Query Builder or Eloquent ORM. Instead of just allowing static configuration to be used, Memory Component allow those configuration to be persistent in between request by utilising multiple data storage option either through cache or database.
Version Compatibility
| Laravel | Memory |
|---|---|
| 5.5.x | 3.5.x |
| 5.6.x | 3.6.x |
| 5.7.x | 3.7.x |
| 5.8.x | 3.8.x |
| 6.x | 4.x |
| 7.x | 5.x |
| 8.x | 6.x |
Installation
To install through composer, run the following command from terminal:
composer require "orchestra/memory"
Configuration
Next add the service provider in config/app.php.
'providers' => [ // ... Orchestra\Memory\MemoryServiceProvider::class, ],
Aliases
You might want to add Orchestra\Support\Facades\Memory to class aliases in config/app.php:
'aliases' => [ // ... 'Memory' => Orchestra\Support\Facades\Memory::class, ],
Migrations
Before we can start using Memory Component, please run the following:
php artisan migrate
Publish Configuration
Optionally, you can also publish the configuration file if there any requirement to change the default:
php artisan vendor:publish --provider="Orchestra\\Memory\\MemoryServiceProvider"
Usage
Creating Instance
Below are list of possible ways to use Memory Component:
$runtime = Memory::make('runtime'); $fluent = Memory::make('fluent'); $eloquent = Memory::make('eloquent'); $cache = Memory::make('cache');
However, most of the time you wouldn't need to have additional memory instance other than the default which is using orchestra_options table.
$memory = Memory::make();
When using with Orchestra Platform,
Memory::make()would be used throughout the application.
Storing Items
Storing items in the Memory Component is simple. Simply call the put method:
$memory->put('site.author', 'Taylor'); // or you can also use Memory::put('site.author', 'Taylor');
The first parameter is the key to the config item. You will use this key to retrieve the item from the config. The second parameter is the value of the item.
Retrieving Items
Retrieving items from Memory Component is even more simple than storing them. It is done using the get method. Just mention the key of the item you wish to retrieve:
$name = $memory->get('site.author'); // or you can also use $name = Memory::get('site.author');
By default, NULL will be returned if the item does not exist. However, you may pass a different default value as a second parameter to the method:
$name = $memory->get('site.author', 'Fred');
Now, "Fred" will be returned if the "site.author" item does not exist.
Removing Items
Need to get rid of an item? No problem. Just mention the name of the item to the forget method:
$memory->forget('site.author'); // or you can also use Memory::forget('site.author');
Extending Memory
There might be requirement that a different type of storage engine would be use for memory instance, you can extending it by adding your own handler.
<?php use Orchestra\Contracts\Memory\Handler; class AcmeMemoryHandler implements Handler { // Add your implementation } Memory::extend('acme', function ($app, $name) { return new Orchestra\Memory\Provider( new AcmeMemoryHandler($name) ); }); // Now you can use it as $acme = Memory::make('acme.default');
You can also extends
Orchestra\Memory\Handlerwhich add some boilerplate code on your custom handler.
统计信息
- 总下载量: 149.78k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 11
- 点击次数: 1
- 依赖项目数: 11
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2013-04-11