2016-10-15 00:22:23 +00:00
< ? php
/**
* Pterodactyl - Panel
* Copyright ( c ) 2015 - 2016 Dane Everitt < dane @ daneeveritt . com >
2016-12-07 22:46:38 +00:00
* Some Modifications ( c ) 2015 Dylan Seidt < dylan . seidt @ gmail . com >.
2016-10-15 00:22:23 +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 :
*
* 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 .
*/
2016-12-07 22:46:38 +00:00
2016-10-15 00:22:23 +00:00
namespace Pterodactyl\Http\Controllers\Base ;
2016-10-20 22:20:58 +00:00
use Log ;
2016-12-07 22:46:38 +00:00
use Alert ;
2016-10-15 00:22:23 +00:00
use Pterodactyl\Models ;
2016-12-07 22:46:38 +00:00
use Illuminate\Http\Request ;
2016-10-20 22:20:58 +00:00
use Pterodactyl\Repositories\APIRepository ;
2016-10-15 00:22:23 +00:00
use Pterodactyl\Exceptions\DisplayException ;
use Pterodactyl\Http\Controllers\Controller ;
2016-12-07 22:46:38 +00:00
use Pterodactyl\Exceptions\DisplayValidationException ;
2016-10-15 00:22:23 +00:00
class APIController extends Controller
{
public function index ( Request $request )
{
$keys = Models\APIKey :: where ( 'user' , $request -> user () -> id ) -> get ();
2016-12-07 22:46:38 +00:00
foreach ( $keys as & $key ) {
2016-10-15 00:22:23 +00:00
$key -> permissions = Models\APIPermission :: where ( 'key_id' , $key -> id ) -> get ();
}
return view ( 'base.api.index' , [
2016-12-07 22:46:38 +00:00
'keys' => $keys ,
2016-10-15 00:22:23 +00:00
]);
}
2016-12-12 19:30:57 +00:00
public function create ( Request $request )
2016-10-15 00:22:23 +00:00
{
return view ( 'base.api.new' );
}
public function save ( Request $request )
{
2016-10-20 22:20:58 +00:00
try {
$repo = new APIRepository ( $request -> user ());
2016-12-12 19:30:57 +00:00
$secret = $repo -> create ( $request -> except ([ '_token' ]));
2016-10-20 22:20:58 +00:00
Alert :: success ( '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 /><code>' . $secret . '</code>' ) -> flash ();
2016-12-07 22:46:38 +00:00
2016-10-20 22:20:58 +00:00
return redirect () -> route ( 'account.api' );
} catch ( DisplayValidationException $ex ) {
return redirect () -> route ( 'account.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 ();
}
2016-12-07 22:46:38 +00:00
2016-10-20 22:20:58 +00:00
return redirect () -> route ( 'account.api.new' ) -> withInput ();
}
2016-10-15 00:22:23 +00:00
2016-10-20 22:20:58 +00:00
public function revoke ( Request $request , $key )
{
try {
$repo = new APIRepository ( $request -> user ());
$repo -> revoke ( $key );
2016-12-07 22:46:38 +00:00
2016-10-20 22:20:58 +00:00
return response ( '' , 204 );
} catch ( \Exception $ex ) {
return response () -> json ([
2016-12-07 22:46:38 +00:00
'error' => 'An error occured while attempting to remove this key.' ,
2016-10-20 22:20:58 +00:00
], 503 );
}
2016-10-15 00:22:23 +00:00
}
}