/**
  * Show the form for creating a new resource.
  *
  * @return Response
  */
 public function roulette()
 {
     if (ACL::checkUserPermission('bet.roulette') == false) {
         return Redirect::action('dashboard');
     }
     if (Auth::user()->isPlayer()) {
         $player_operator = Playeroperators::with('tabledetails')->where('player_id', Auth::user()->id)->get()->first();
         $gamedetails = Gamechannel::with('tabledetails.operator', 'tabledetails.gamedetails')->openchannel()->where('table_id', $player_operator->tabledetails->id)->take(1)->get()->first();
         $playerdetails = User::with('wallet')->where('id', Auth::user()->id)->get()->first();
         if (!empty($gamedetails)) {
             $title = Lang::get('Bet Roulette');
             $form_open = Form::open(array('method' => 'post', 'class' => 'smart-form', 'route' => array('bet.place')));
             $data = array('title' => $title, 'playerdetails' => $playerdetails, 'gamedetails' => $gamedetails, 'formOpen' => $form_open);
             return View::make('bet/roulette', $data);
         } else {
             return App::abort(404, 'Operator haven\'t start the roulette game.');
         }
     } else {
         return App::abort(404, 'Your account is not a player account.');
     }
 }
 public function start()
 {
     if (ACL::checkUserPermission('roulette.start') == false) {
         return Redirect::action('dashboard');
     }
     if (Auth::user()->isOperator()) {
         $game = Games::where('game_name', 'Roulette')->take(1)->get()->first();
         $table = Gametables::where('operator_id', $this->operator_id)->take(1)->get()->first();
         $players = Playeroperators::with('playerdetails', 'credits')->where('operator_id', $this->operator_id)->get();
         if (!empty($table)) {
             $create_channel = array('channel_id' => Utils::generateRandomString(), 'table_id' => $table->id);
             $channel_id = '';
             $channel = Gamechannel::openchannel()->where('table_id', $table->id)->take(1)->get()->first();
             if (!empty($channel)) {
                 $channel_id = $channel->id;
             } else {
                 $channel_create = Gamechannel::create($create_channel);
                 $channel_id = $channel_create->id;
             }
             $gamedetails = Gamechannel::with('tabledetails.gamedetails', 'tabledetails.operator', 'bets', 'bets.playerdetails')->find($channel_id);
             $totalbets = 0;
             $totalplayers = 0;
             if ($gamedetails->bets != null) {
                 foreach ($gamedetails->bets as $gamebets) {
                     $totalbets += $gamebets->bet_amount;
                     $totalplayers++;
                 }
             }
             $title = Lang::get('Start Game');
             $data = array('title' => $title, 'totalbets' => $totalbets, 'totalplayers' => $totalplayers, 'gamedetails' => $gamedetails, 'players' => $players);
             return View::make('operator/create', $data);
         } else {
             return App::abort(401, 'No Roulette table has been assigned to your account.');
         }
     } else {
         return App::abort(401, 'You are not a operator.');
     }
 }
 public function winnings()
 {
     //retrieve POST value
     $param = Input::only('gameid', 'winning_number');
     $rules = array('gameid' => 'required|exists:game_channel,id', 'winning_number' => 'required|integer|between:0,36');
     //custom error messaging
     $messages = array('gameid.exists' => 'Game doesn\'t exist');
     $validator = Validator::make($param, $rules, $messages);
     if ($validator->passes()) {
         $gamewinnings = array('game_id' => 1, 'channel_id' => $param['gameid'], 'winning_number' => $param['winning_number']);
         $winnings = Gamewinnings::create($gamewinnings);
         Gamechannel::where('id', $param['gameid'])->update(array('channel_status' => 0));
         $bets = Gamebets::with('channel', 'payout')->where('channel_id', $param['gameid'])->get();
         $bet_win = array();
         foreach ($bets as $row) {
             $win = false;
             switch ($row->payout->name) {
                 case "straight":
                     if ($row->bet_number == $param['winning_number']) {
                         $win = true;
                     }
                     break;
                 case "split":
                     $numbers = explode(",", $row->bet_number);
                     if (in_array($param['winning_number'], $numbers)) {
                         $win = true;
                     }
                     break;
                 case "line":
                     $numbers = explode(",", $row->bet_number);
                     if (in_array($param['winning_number'], $numbers)) {
                         $win = true;
                     }
                     break;
                 case "square":
                     $numbers = explode(",", $row->bet_number);
                     if (in_array($param['winning_number'], $numbers)) {
                         $win = true;
                     }
                     break;
                 case "basket":
                     $numbers = explode(",", $row->bet_number);
                     if (in_array($param['winning_number'], $numbers)) {
                         $win = true;
                     }
                     break;
                 case "1stcolumn":
                     $numbers_covered = explode(',', $row->payout->numbers_covered);
                     if (in_array($param['winning_number'], $numbers_covered)) {
                         $win = true;
                     }
                     break;
                 case "2ndcolumn":
                     $numbers_covered = explode(',', $row->payout->numbers_covered);
                     if (in_array($param['winning_number'], $numbers_covered)) {
                         $win = true;
                     }
                     break;
                 case "3rdcolumn":
                     $numbers_covered = explode(',', $row->payout->numbers_covered);
                     if (in_array($param['winning_number'], $numbers_covered)) {
                         $win = true;
                     }
                     break;
                 case "1dozen":
                     $numbers_covered = explode(',', $row->payout->numbers_covered);
                     if (in_array($param['winning_number'], $numbers_covered)) {
                         $win = true;
                     }
                     break;
                 case "2dozen":
                     $numbers_covered = explode(',', $row->payout->numbers_covered);
                     if (in_array($param['winning_number'], $numbers_covered)) {
                         $win = true;
                     }
                     break;
                 case "3dozen":
                     $numbers_covered = explode(',', $row->payout->numbers_covered);
                     if (in_array($param['winning_number'], $numbers_covered)) {
                         $win = true;
                     }
                     break;
                 case "even":
                     if ($param['winning_number'] % 2 == 0) {
                         $win = true;
                     }
                     break;
                 case "odd":
                     if ($param['winning_number'] % 2 != 0) {
                         $win = true;
                     }
                     break;
                 default:
                     $numbers_covered = explode(',', $row->payout->numbers_covered);
                     if (in_array($param['winning_number'], $numbers_covered)) {
                         $win = true;
                     }
             }
             if ($win == true) {
                 $update = array('bet_result' => 'win', 'bet_status' => 0);
                 Gamebets::where('id', $row->id)->update($update);
                 $this->player_winnings($row->payout->payout, $row->player_id, $row->bet_amount, $row->channel->channel_id);
                 $bet_win[] = $row->id;
             } elseif ($win == false) {
                 $update = array('bet_result' => 'loss', 'bet_status' => 0);
                 Gamebets::where('id', $row->id)->update($update);
             }
         }
         if (count($bet_win) > 0) {
             $player_winnings = Gamebets::with('payout', 'playerdetails')->whereIn('id', $bet_win)->get();
             if (!empty($player_winnings->first())) {
                 $response = array('betwin' => true, 'message' => 'List of players who won.', 'data' => $player_winnings->toArray());
             }
         } else {
             $response = array('betwin' => false, 'message' => 'No player has won this game.');
         }
     } else {
         //All error message in validation
         $messages = $validator->messages();
         //response if merchant doesnt have list of products.
         $response = array('betwin' => 404, 'error' => 'not_found', 'error_message' => $messages->all());
     }
     echo json_encode($response);
 }