-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
12 changed files
with
359 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -5,3 +5,4 @@ | |
.env | ||
/node_modules | ||
/vendor | ||
composer.lock |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
# Release Notes for Flare | ||
|
||
## 4.0.0 | ||
- Initial release |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
The MIT License (MIT) | ||
|
||
Copyright (c) Pixel & Tonic, Inc. | ||
|
||
Permission is hereby granted, free of charge, to any person obtaining a copy | ||
of this software and associated documentation files (the "Software"), to deal | ||
in the Software without restriction, including without limitation the rights | ||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
copies of the Software, and to permit persons to whom the Software is | ||
furnished to do so, subject to the following conditions: | ||
|
||
The above copyright notice and this permission notice shall be included in all | ||
copies or substantial portions of the Software. | ||
|
||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||
SOFTWARE. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
# Flare | ||
|
||
Flareapp.io integration for Craft CMS | ||
|
||
## Requirements | ||
|
||
This plugin requires Craft CMS 4.12.0 or later, and PHP 8.1 or later - <br>and an account at [flareapp.io](https://flareapp.io/?via=studioespresso) *(Affiliate link, you're supporting further maintenance of this plugin by signing up through that link - thanks!)* | ||
|
||
## Installation | ||
|
||
You can install this plugin from the Plugin Store or with Composer. | ||
|
||
#### From the Plugin Store | ||
|
||
Go to the Plugin Store in your project’s Control Panel and search for “Flare”. Then press “Install”. | ||
|
||
#### With Composer | ||
|
||
Open your terminal and run the following commands: | ||
|
||
```shell | ||
cd /path/to/my-project.test | ||
(ddev/php) composer require studioespresso/craft-flare | ||
(ddev/php) craft plugin/install flare | ||
``` | ||
|
||
## Configuration | ||
Create a project in your Flare account, copy the API key and add it in the plugin settings. | ||
|
||
Alternatively, you can use the ``flare.php`` configuration file to manage this. This file is environment-aware, like any other Craft CMS configuration. You can find an example below. | ||
|
||
````php | ||
<?php | ||
|
||
return [ | ||
'*' => [ | ||
'enabled' => false, | ||
'apiKey' => \craft\helpers\App::env('FLARE_API_KEY'), | ||
'excludedExceptions' => [ | ||
ErrorException::class, | ||
] | ||
], | ||
'production' => [ | ||
'enabled' => true, | ||
] | ||
]; | ||
```` | ||
|
||
## Testing | ||
Once you've added the API key for your Flare project, you can use a built-in console command to send a test exception to Flare: | ||
|
||
````shell | ||
(ddev/php) craft flare/test/index | ||
# That should result on the following message: | ||
Exception reported to flareapp.io, check your project there to see if it shows up | ||
```` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,88 @@ | ||
<?php | ||
|
||
namespace studioespresso\flare; | ||
|
||
use Craft; | ||
use craft\base\Model; | ||
use craft\base\Plugin; | ||
use craft\console\Application as ConsoleApplication; | ||
use craft\events\ExceptionEvent; | ||
use craft\web\ErrorHandler; | ||
use Spatie\FlareClient\Flare as FlareClient; | ||
use studioespresso\flare\models\Settings; | ||
use studioespressp\flare\services\FlareService; | ||
use yii\base\Event; | ||
|
||
/** | ||
* Flare plugin | ||
* | ||
* @method static Flare getInstance() | ||
* @method Settings getSettings() | ||
* @method FlareService flare | ||
* @author Studio Espresso <support@studioespresso.co> | ||
* @copyright Studio Espresso | ||
* @license MIT | ||
*/ | ||
class Flare extends Plugin | ||
{ | ||
public string $schemaVersion = '1.0.0'; | ||
public bool $hasCpSettings = true; | ||
/** | ||
* @var mixed|object|null | ||
*/ | ||
|
||
public static function config(): array | ||
{ | ||
return [ | ||
'components' => [ | ||
'flare' => FlareService::class, | ||
], | ||
]; | ||
} | ||
|
||
public function init(): void | ||
{ | ||
parent::init(); | ||
|
||
if (Craft::$app instanceof ConsoleApplication) { | ||
$this->controllerNamespace = 'studioespresso\flare\console\controllers'; | ||
} | ||
|
||
$this->attachEventHandlers(); | ||
|
||
// Any code that creates an element query or loads Twig should be deferred until | ||
// after Craft is fully initialized, to avoid conflicts with other plugins/modules | ||
Craft::$app->onInit(function() { | ||
if ($this->getSettings()->enabled) { | ||
// $client = FlareClient::make($this->getSettings()->apiKey)->registerFlareHandlers(); | ||
Event::on( | ||
ErrorHandler::className(), | ||
ErrorHandler::EVENT_BEFORE_HANDLE_EXCEPTION, | ||
function(ExceptionEvent $event) { | ||
// $client->report($event->exception); | ||
$this->flare->reportException($event->exception); | ||
} | ||
); | ||
} | ||
}); | ||
} | ||
|
||
protected function createSettingsModel(): ?Model | ||
{ | ||
return Craft::createObject(Settings::class); | ||
} | ||
|
||
protected function settingsHtml(): ?string | ||
{ | ||
return Craft::$app->view->renderTemplate('flare/_settings.twig', [ | ||
'plugin' => $this, | ||
'settings' => $this->getSettings(), | ||
]); | ||
} | ||
|
||
private function attachEventHandlers(): void | ||
{ | ||
// Register event handlers here ... | ||
// (see https://craftcms.com/docs/4.x/extend/events.html to get started) | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
<?php | ||
|
||
/** | ||
* @author studioespresso | ||
* @package craft-flare | ||
* @since 1.0.0 | ||
*/ | ||
|
||
/** | ||
* Flare config.php | ||
* | ||
* This file exists only as a template for the Flare settings. | ||
* It does nothing on its own. | ||
* | ||
* Don't edit this file, instead copy it to 'craft/config' as 'flare.php' | ||
* and make your changes there to override default settings. | ||
* | ||
* Once copied to 'craft/config', this file will be multi-environment aware as | ||
* well, so you can have different settings groups for each environment, just as | ||
* you do for 'general.php' | ||
*/ | ||
|
||
return [ | ||
'enabled' => true, | ||
'apiKey' => '', | ||
'excludedExceptions' => [], | ||
]; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
<?php | ||
|
||
namespace studioespresso\flare\console\controllers; | ||
|
||
use craft\console\Controller; | ||
use craft\helpers\Console; | ||
use studioespresso\flare\Flare; | ||
use yii\base\Exception; | ||
|
||
/** | ||
* Testing your Flare integration | ||
*/ | ||
class TestController extends Controller | ||
{ | ||
/** | ||
* Once you have the Flare plugin installed & configured, use this function to throw an simulated exception to test if it shows on in Flare. | ||
*/ | ||
public function actionIndex(): void | ||
{ | ||
if (!Flare::getInstance()->getSettings()->enabled) { | ||
Console::stdout("Flare is not enabled on this environment." . PHP_EOL . "Check your settings or run this command where Flare is enabled." . PHP_EOL, Console::FG_YELLOW); | ||
return; | ||
} | ||
if (!Flare::getInstance()->getSettings()->apiKey) { | ||
Console::stdout("Flare API key missing." . PHP_EOL . "Check your settings or run this command where Flare is correctly configured" . PHP_EOL, Console::FG_RED); | ||
return; | ||
} | ||
try { | ||
throw new Exception("This is an exception throws while testing the Flare plugin for Craft CMS", 418); | ||
} catch (\Throwable $e) { | ||
Flare::getInstance()->flare->reportException($e); | ||
Console::stdout("Exception reported to flareapp.io, check your project there to see if it shows up" . PHP_EOL); | ||
} | ||
} | ||
} |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
<?php | ||
|
||
namespace studioespresso\flare\models; | ||
|
||
use craft\base\Model; | ||
|
||
/** | ||
* Flare settings | ||
*/ | ||
class Settings extends Model | ||
{ | ||
public bool $enabled = true; | ||
|
||
public ?string $apiKey = null; | ||
|
||
public array $excludedExceptions = []; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
<?php | ||
|
||
namespace studioespressp\flare\services; | ||
|
||
use Craft; | ||
use craft\base\Component; | ||
use Spatie\FlareClient\Flare as FlareClient; | ||
use studioespresso\flare\Flare; | ||
|
||
class FlareService extends Component | ||
{ | ||
public ?FlareClient $client = null; | ||
|
||
public function init(): void | ||
{ | ||
if ( | ||
Flare::getInstance()->getSettings()->apiKey && | ||
Flare::getInstance()->getSettings()->enabled | ||
) { | ||
$this->client = FlareClient::make(Flare::getInstance()->getSettings()->apiKey)->registerFlareHandlers(); | ||
} | ||
parent::init(); | ||
} | ||
|
||
public function reportException(\Throwable $exception) | ||
{ | ||
$settings = Flare::getInstance()->getSettings(); | ||
if (in_array(get_class($exception), $settings->excludedExceptions)) { | ||
Craft::info('Exception class excluded from being reported to Flare.', Flare::getInstance()->handle); | ||
return; | ||
} | ||
|
||
if ($this->client) { | ||
$this->client->context('CMS', 'Craft CMS'); | ||
$this->client->context('System name', Craft::$app->getSystemName()); | ||
$this->client->context('Craft version', Craft::$app->getInfo()->version); | ||
$this->client->context('Yii version', Craft::$app->getYiiVersion()); | ||
$this->client->report($exception); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
{# @var plugin \studioespresso\flare\Flare #} | ||
{# @var settings \studioespresso\flare\models\Settings #} | ||
|
||
{% import '_includes/forms.twig' as forms %} | ||
{% import _self as self %} | ||
|
||
|
||
{{ forms.autosuggestfield({ | ||
label: 'API key'|t('flare'), | ||
id: 'apiKey', | ||
name: 'apiKey', | ||
suggestEnvVars: true, | ||
value: settings['apiKey'], | ||
warning: self.configWarning('apiKey', 'flare') | ||
}) }} | ||
|
||
{{ forms.lightswitchField({ | ||
label: "Enabled"|t, | ||
id: 'enabled', | ||
name: 'enabled', | ||
on: settings['enabled'], | ||
warning: self.configWarning('enabled', 'flare') | ||
}) }} | ||
|
||
|
||
|
||
{% macro configWarning(setting, file) -%} | ||
{%- set configArray = craft.app.config.getConfigFromFile(file) -%} | ||
{%- if configArray[setting] is defined -%} | ||
{{ "This is being overridden by the `{setting}` config setting."|raw|t('flare', { | ||
setting: setting | ||
}) }} | ||
{%- else -%} | ||
{{ false }} | ||
{%- endif -%} | ||
{%- endmacro %} |