2017-01-12 19:40:20 -08:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Http\Controllers\Api;
|
|
|
|
|
|
|
|
use App\Http\Controllers\Controller;
|
2019-03-13 20:12:03 -07:00
|
|
|
use App\Http\Transformers\LoginAttemptsTransformer;
|
2017-10-16 07:07:21 -07:00
|
|
|
use App\Models\Setting;
|
2018-03-02 18:01:20 -08:00
|
|
|
use App\Notifications\MailTest;
|
2018-12-06 14:05:43 -08:00
|
|
|
use App\Notifications\SlackTest;
|
2019-03-13 20:12:03 -07:00
|
|
|
use App\Services\LdapAd;
|
2018-12-06 14:05:43 -08:00
|
|
|
use Illuminate\Http\JsonResponse;
|
2019-03-13 20:12:03 -07:00
|
|
|
use Illuminate\Http\Request;
|
|
|
|
use Illuminate\Support\Facades\DB;
|
2018-12-06 14:05:43 -08:00
|
|
|
use Illuminate\Support\Facades\Log;
|
2019-03-13 20:12:03 -07:00
|
|
|
use Illuminate\Support\Facades\Notification;
|
2017-01-12 19:40:20 -08:00
|
|
|
|
|
|
|
class SettingsController extends Controller
|
|
|
|
{
|
|
|
|
|
2018-12-06 14:05:43 -08:00
|
|
|
/**
|
|
|
|
* Test the ldap settings
|
|
|
|
*
|
|
|
|
* @author Wes Hulette <jwhulette@gmail.com>
|
|
|
|
*
|
|
|
|
* @since 5.0.0
|
|
|
|
*
|
|
|
|
* @param App\Models\LdapAd $ldap
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Http\JsonResponse
|
|
|
|
*/
|
|
|
|
public function ldapAdSettingsTest(LdapAd $ldap): JsonResponse
|
2017-07-07 23:44:48 -07:00
|
|
|
{
|
2019-01-10 13:20:43 -08:00
|
|
|
if(!$ldap->init()) {
|
2018-12-06 14:05:43 -08:00
|
|
|
Log::info('LDAP is not enabled cannot test.');
|
2017-10-16 07:07:21 -07:00
|
|
|
return response()->json(['message' => 'LDAP is not enabled, cannot test.'], 400);
|
|
|
|
}
|
|
|
|
|
2018-12-06 14:05:43 -08:00
|
|
|
// The connect, bind and resulting users message
|
|
|
|
$message = [];
|
2017-07-07 23:44:48 -07:00
|
|
|
|
2018-12-06 14:05:43 -08:00
|
|
|
Log::info('Preparing to test LDAP user login');
|
|
|
|
// Test user can connect to the LDAP server
|
2017-07-07 23:44:48 -07:00
|
|
|
try {
|
2018-12-06 14:05:43 -08:00
|
|
|
$ldap->testLdapAdUserConnection();
|
|
|
|
$message['login'] = [
|
|
|
|
'message' => 'Successfully connected to LDAP server.'
|
|
|
|
];
|
|
|
|
} catch (\Exception $ex) {
|
|
|
|
return response()->json([
|
|
|
|
'message' => 'Error logging into LDAP server, error: ' . $ex->getMessage() . ' - Verify your that your username and password are correct'
|
2017-07-07 23:44:48 -07:00
|
|
|
}
|
|
|
|
} catch (\Exception $e) {
|
2019-07-15 14:10:57 -07:00
|
|
|
\Log::debug('Connection failed but we cannot debug it any further on our end.');
|
2018-12-06 14:05:43 -08:00
|
|
|
], 400);
|
2017-07-07 23:44:48 -07:00
|
|
|
}
|
|
|
|
|
2018-12-06 14:05:43 -08:00
|
|
|
Log::info('Preparing to test LDAP bind connection');
|
|
|
|
// Test user can bind to the LDAP server
|
|
|
|
try {
|
|
|
|
$ldap->testLdapAdBindConnection();
|
|
|
|
$message['bind'] = [
|
|
|
|
'message' => 'Successfully binded to LDAP server.'
|
|
|
|
];
|
|
|
|
} catch (\Exception $ex) {
|
|
|
|
return response()->json([
|
|
|
|
'message' => 'Error binding to LDAP server, error: ' . $ex->getMessage()
|
|
|
|
], 400);
|
2017-10-16 07:07:21 -07:00
|
|
|
}
|
|
|
|
|
2018-12-06 14:05:43 -08:00
|
|
|
Log::info('Preparing to get sample user set from LDAP directory');
|
|
|
|
// Get a sample of 10 users so user can verify the data is correct
|
2017-10-16 06:34:04 -07:00
|
|
|
try {
|
2018-12-06 14:05:43 -08:00
|
|
|
$users = $ldap->testUserImportSync();
|
|
|
|
$message['user_sync'] = [
|
|
|
|
'users' => $users
|
|
|
|
];
|
|
|
|
} catch (\Exception $ex) {
|
|
|
|
$message['user_sync'] = [
|
|
|
|
'message' => 'Error getting users from LDAP directory, error: ' . $ex->getMessage()
|
|
|
|
];
|
|
|
|
return response()->json($message, 400);
|
2017-10-16 06:34:04 -07:00
|
|
|
}
|
|
|
|
|
2018-12-06 14:05:43 -08:00
|
|
|
return response()->json($message, 200);
|
2017-10-16 06:34:04 -07:00
|
|
|
}
|
|
|
|
|
2018-02-22 16:35:34 -08:00
|
|
|
public function slacktest()
|
|
|
|
{
|
|
|
|
|
|
|
|
if ($settings = Setting::getSettings()->slack_channel=='') {
|
|
|
|
\Log::debug('Slack is not enabled. Cannot test.');
|
|
|
|
return response()->json(['message' => 'Slack is not enabled, cannot test.'], 400);
|
|
|
|
}
|
|
|
|
|
|
|
|
\Log::debug('Preparing to test slack connection');
|
|
|
|
|
|
|
|
try {
|
|
|
|
Notification::send($settings = Setting::getSettings(), new SlackTest());
|
|
|
|
return response()->json(['message' => 'Success'], 200);
|
|
|
|
} catch (\Exception $e) {
|
|
|
|
\Log::debug('Slack connection failed');
|
|
|
|
return response()->json(['message' => $e->getMessage()], 400);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-10-19 08:18:56 -07:00
|
|
|
/**
|
|
|
|
* Test the email configuration
|
|
|
|
*
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
|
|
|
* @since [v3.0]
|
|
|
|
* @return Redirect
|
|
|
|
*/
|
|
|
|
public function ajaxTestEmail()
|
|
|
|
{
|
2017-10-19 08:33:46 -07:00
|
|
|
if (!config('app.lock_passwords')) {
|
|
|
|
try {
|
2018-03-02 18:01:20 -08:00
|
|
|
Notification::send(Setting::first(), new MailTest());
|
2017-11-03 14:58:49 -07:00
|
|
|
return response()->json(['message' => 'Mail sent to '.config('mail.reply_to.address')], 200);
|
2017-10-19 08:33:46 -07:00
|
|
|
} catch (Exception $e) {
|
|
|
|
return response()->json(['message' => $e->getMessage()], 500);
|
|
|
|
}
|
2017-10-19 08:18:56 -07:00
|
|
|
}
|
2017-10-19 08:33:46 -07:00
|
|
|
return response()->json(['message' => 'Mail would have been sent, but this application is in demo mode! '], 200);
|
2017-10-19 08:18:56 -07:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2018-08-01 03:51:59 -07:00
|
|
|
/**
|
|
|
|
* Get a list of login attempts
|
|
|
|
*
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
|
|
|
* @since [v5.0.0]
|
|
|
|
* @param \Illuminate\Http\Request $request
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function showLoginAttempts(Request $request)
|
|
|
|
{
|
|
|
|
$allowed_columns = ['id', 'username', 'remote_ip', 'user_agent','successful','created_at'];
|
|
|
|
|
|
|
|
$login_attempts = DB::table('login_attempts');
|
|
|
|
$order = $request->input('order') === 'asc' ? 'asc' : 'desc';
|
|
|
|
$sort = in_array($request->get('sort'), $allowed_columns) ? $request->get('sort') : 'created_at';
|
|
|
|
|
|
|
|
$total = $login_attempts->count();
|
|
|
|
$login_attempts->orderBy($sort, $order);
|
|
|
|
$login_attempt_results = $login_attempts->skip(request('offset', 0))->take(request('limit', 20))->get();
|
|
|
|
|
|
|
|
return (new LoginAttemptsTransformer)->transformLoginAttempts($login_attempt_results, $total);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2017-10-19 08:18:56 -07:00
|
|
|
|
|
|
|
|
2017-01-12 19:40:20 -08:00
|
|
|
}
|