namespace BookStack\Providers;
-use Illuminate\Support\Facades\Blade;
-use BookStack\Auth\Access\LoginService;
+use BookStack\Actions\ActivityLogger;
use BookStack\Auth\Access\SocialAuthService;
-use BookStack\Entities\BreadcrumbsViewComposer;
use BookStack\Entities\Models\Book;
use BookStack\Entities\Models\Bookshelf;
use BookStack\Entities\Models\Chapter;
use BookStack\Entities\Models\Page;
-use BookStack\Settings\Setting;
+use BookStack\Exceptions\WhoopsBookStackPrettyHandler;
use BookStack\Settings\SettingService;
use BookStack\Util\CspService;
-use Illuminate\Contracts\Cache\Repository;
+use GuzzleHttp\Client;
use Illuminate\Database\Eloquent\Relations\Relation;
-use Illuminate\Support\Facades\View;
-use Illuminate\Support\ServiceProvider;
-use Laravel\Socialite\Contracts\Factory as SocialiteFactory;
use Illuminate\Support\Facades\Schema;
use Illuminate\Support\Facades\URL;
+use Illuminate\Support\ServiceProvider;
+use Psr\Http\Client\ClientInterface as HttpClientInterface;
+use Whoops\Handler\HandlerInterface;
class AppServiceProvider extends ServiceProvider
{
+ /**
+ * Custom container bindings to register.
+ * @var string[]
+ */
+ public $bindings = [
+ HandlerInterface::class => WhoopsBookStackPrettyHandler::class,
+ ];
+
+ /**
+ * Custom singleton bindings to register.
+ * @var string[]
+ */
+ public $singletons = [
+ 'activity' => ActivityLogger::class,
+ SettingService::class => SettingService::class,
+ SocialAuthService::class => SocialAuthService::class,
+ CspService::class => CspService::class,
+ ];
+
/**
* Bootstrap any application services.
*
URL::forceScheme($isHttps ? 'https' : 'http');
}
- // Custom blade view directives
- Blade::directive('icon', function ($expression) {
- return "<?php echo icon($expression); ?>";
- });
-
// Allow longer string lengths after upgrade to utf8mb4
Schema::defaultStringLength(191);
- // Set morph-map due to namespace changes
- Relation::morphMap([
- 'BookStack\\Bookshelf' => Bookshelf::class,
- 'BookStack\\Book' => Book::class,
- 'BookStack\\Chapter' => Chapter::class,
- 'BookStack\\Page' => Page::class,
+ // Set morph-map for our relations to friendlier aliases
+ Relation::enforceMorphMap([
+ 'bookshelf' => Bookshelf::class,
+ 'book' => Book::class,
+ 'chapter' => Chapter::class,
+ 'page' => Page::class,
]);
-
- // View Composers
- View::composer('entities.breadcrumbs', BreadcrumbsViewComposer::class);
}
/**
*/
public function register()
{
- $this->app->singleton(SettingService::class, function ($app) {
- return new SettingService($app->make(Setting::class), $app->make(Repository::class));
- });
-
- $this->app->singleton(SocialAuthService::class, function ($app) {
- return new SocialAuthService($app->make(SocialiteFactory::class), $app->make(LoginService::class));
- });
-
- $this->app->singleton(CspService::class, function ($app) {
- return new CspService();
+ $this->app->bind(HttpClientInterface::class, function ($app) {
+ return new Client([
+ 'timeout' => 3,
+ ]);
});
}
}