2016-01-16 06:20:27 +00:00
< ? php
2016-01-20 00:10:39 +00:00
/**
* Copyright ( c ) 2015 - 2016 Dane Everitt < dane @ daneeveritt . com >
*
2016-01-20 20:56:40 +00:00
* 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 :
2016-01-20 00:10:39 +00:00
*
2016-01-20 20:56:40 +00:00
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software .
2016-01-20 00:10:39 +00:00
*
2016-01-20 20:56:40 +00:00
* 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 .
2016-01-20 00:10:39 +00:00
*/
2016-01-16 06:20:27 +00:00
namespace Pterodactyl\Http\Controllers\Admin ;
use Alert ;
use Log ;
2016-01-17 00:56:48 +00:00
use Pterodactyl\Models ;
use Pterodactyl\Repositories\APIRepository ;
2016-01-16 06:20:27 +00:00
use Pterodactyl\Http\Controllers\Controller ;
2016-01-17 00:56:48 +00:00
use Pterodactyl\Exceptions\DisplayValidationException ;
use Pterodactyl\Exceptions\DisplayException ;
2016-01-16 06:20:27 +00:00
use Illuminate\Http\Request ;
class APIController extends Controller
{
public function __construct ()
{
//
}
public function getIndex ( Request $request )
{
$keys = Models\APIKey :: all ();
foreach ( $keys as & $key ) {
$key -> permissions = Models\APIPermission :: where ( 'key_id' , $key -> id ) -> get ();
}
return view ( 'admin.api.index' , [
'keys' => $keys
]);
}
2016-01-17 00:56:48 +00:00
public function getNew ( Request $request )
{
return view ( 'admin.api.new' );
}
public function postNew ( Request $request )
{
try {
$api = new APIRepository ;
$secret = $api -> new ( $request -> except ([ '_token' ]));
Alert :: info ( 'An API Keypair has successfully been generated. The API secret for this public key is shown below and will not be shown again.<br /><br />Secret: <code>' . $secret . '</code>' ) -> flash ();
return redirect () -> route ( 'admin.api' );
} catch ( DisplayValidationException $ex ) {
return redirect () -> route ( 'admin.api.new' ) -> withErrors ( json_decode ( $ex -> getMessage ())) -> withInput ();
} catch ( DisplayException $ex ) {
Alert :: danger ( $ex -> getMessage ()) -> flash ();
} catch ( \Exception $ex ) {
Log :: error ( $ex );
Alert :: danger ( 'An unhandled exception occured while attempting to add this API key.' ) -> flash ();
}
return redirect () -> route ( 'admin.api.new' ) -> withInput ();
}
public function deleteRevokeKey ( Request $request , $key )
{
try {
$api = new APIRepository ;
$api -> revoke ( $key );
return response ( '' , 204 );
} catch ( \Exception $ex ) {
return response () -> json ([
'error' => 'An error occured while attempting to remove this key.'
], 503 );
}
}
2016-01-16 06:20:27 +00:00
}