-
Notifications
You must be signed in to change notification settings - Fork 0
/
SpitFire.php
121 lines (106 loc) · 3.16 KB
/
SpitFire.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
<?php namespace spitfire;
/*
*
* Copyright (C) 2023-2023 César de la Cal Bretschneider <[email protected]>.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
* MA 02110-13 01 USA
*
*/
use spitfire\contracts\core\LocationsInterface;
use spitfire\core\Locations;
use spitfire\exceptions\ApplicationException;
use spitfire\provider\Container;
/**
* Dispatcher class of Spitfire. Calls all the required classes for Spitfire to run.
*
* @author César de la Cal <[email protected]>
*/
class SpitFire
{
/**
*
* @var Container
*/
private $provider;
/**
* Provides quick access to different locations that the system will commonly
* use. This object is read only.
*
* @var Locations
*/
private $locations;
public function __construct()
{
$this->locations = new Locations(defined('BASEDIR')? rtrim(BASEDIR, '\/') : __DIR__);
/*
* Initialize the service container, which will manage all the services that
* the framework provides to the application.
*/
$this->provider = new Container();
$this->provider()->set(Locations::class, $this->locations);
$this->provider()->set(LocationsInterface::class, $this->locations);
}
/**
* @throws ApplicationException
*/
public static function baseUrl() : string
{
/**
* If the application has a url defined as the base url for the application,
* we use that.
*/
if (config('app.url') !== null) {
/**
* The app.url must obviously be a string.
*/
assert(is_string(config('app.url')));
return config('app.url');
}
/**
* CLI applications must have a base url defined, since otherwise the application
* could be generating bad URLs without our knowledge. This is usually a very bad
* experience for the user who receives a URL they cannot access.
*/
if (cli()) {
throw new ApplicationException('CLI applications require the app.url config to be defined', 2104191131);
}
assert(is_string($_SERVER['PHP_SELF']));
/**
* Poorly configured applications can always fall back to guessing the base url.
* This is by no means a good way of handling this.
*/
$public = explode('/public/index.php', $_SERVER['PHP_SELF'], 2)[0];
return dirname($public);
}
/**
*
* @return Locations
*/
public function locations()
{
return $this->locations;
}
/**
* Return the dependency container for this Spitfire instance. This container
* allows the application to inject behaviors into the
*
* @return Container
*/
public function provider()
{
return $this->provider;
}
}