Проверка уникального ключа, показывающая ошибку при обновлении данных в laravel

0

Привет Я создаю приложение, использующее laravel, и у меня есть модель, где поле asset_number уникально, и правила проверки являются следующими

МОДЕЛЬ

protected $rules = array
        (

            'asset_number'              => 'required|alpha_dash|min:2|max:12|unique:asset_details,asset_number,{id}',
            'asset_name'                => 'alpha_space',
            'asset_type_id'             => 'required',
            'shift'                     => 'required',

        );

Вот мой код контроллера для создания и редактирования

КОНТРОЛЛЕР

public function postCreate()
    {

        // get the POST data
        $new = Input::all();

        // create a new Assetdetail instance
        $assetdetail = new Assetdetail();

        // attempt validation
        if ($assetdetail->validate($new))
        {

            // Save the location data
            $assetdetail ->asset_number             = e(Input::get('asset_number'));
            $assetdetail ->asset_name               = e(Input::get('asset_name'));
            $assetdetail ->asset_type_id            = e(Input::get('asset_type_id'));
            $assetdetail ->shift                    = e(Input::get('shift'));

            // Was the asset created?
            if($assetdetail ->save())
            {
                // Redirect to the new location  page
                return Redirect::to("admin/settings/assetdetails")->with('success', Lang::get('admin/assetdetails/message.create.success'));
            }
        }
        else
        {
            // failure
            $errors = $assetdetail->errors();
            return Redirect::back()->withInput()->withErrors($errors);
        }

        // Redirect to the location create page
        return Redirect::to('admin/settings/assetdetails/create')->with('error', Lang::get('admin/assetdetails/message.create.error'));

    }


    public function getEdit($assetdetailId = null)
    {
        // Check if the location exists
        if (is_null($assetdetail = Assetdetail::find($assetdetailId)))
        {
            // Redirect to the blogs management page
            return Redirect::to('admin/settings/assetdetails')->with('error', Lang::get('admin/assetdetails/message.does_not_exist'));
        }

        //$assetlife = DB::table('asset_details')->where('id', '=', $assetdetailId)->lists('asset_life');
        $location_list = array('' => '') + Location::lists('name', 'id');
        $assettype_list = array('' => '') + Assettype::lists('asset_type', 'id');
        $assignTo_list = array('' => 'Select a User') + User::select(DB::raw('CONCAT(first_name, " ", last_name) AS full_name'), 'id') ->lists('full_name', 'id');

        $assetdetail_options = array('' => 'Top Level') + DB::table('asset_details')->where('id', '!=', $assetdetailId)->lists('asset_number', 'id');

        return View::make('backend/assetdetails/edit', compact('assetdetail'))->with('assetdetail_options',$assetdetail_options)->with('location_list',$location_list)->with('assettype_list',$assettype_list)->with('assignTo_list',$assignTo_list);

    }


    public function postEdit($assetdetailId = null)
    {
        // Check if the location exists
        if (is_null($assetdetail = Assetdetail::find($assetdetailId)))
        {
            // Redirect to the blogs management page
            return Redirect::to('admin/settings/assetdetails')->with('error', Lang::get('admin/assetdetails/message.does_not_exist'));
        }

        $new = Input::all();

        /*if ($assetdetail ->asset_number   == Input::old('asset_number') && 
        {
          $assetdetail ->asset_number = e(Input::get('asset_number'));
        }*/

        if ($assetdetail->validate($new))
        {

            // Update the asset data
            $assetdetail ->asset_number             = e(Input::get('asset_number'));
            $assetdetail ->asset_name               = e(Input::get('asset_name'));
            $assetdetail ->asset_type_id            = e(Input::get('asset_type_id'));
            $assetdetail ->shift                    = e(Input::get('shift'));


            // Was the asset created?
            if($assetdetail->save())
            {
                // Redirect to the saved location page
                return Redirect::to("admin/settings/assetdetails/$assetdetailId/edit")->with('success', Lang::get('admin/assetdetails/message.update.success'));
            }
        }

            else
            {
            // failure
            $errors = $assetdetail->errors();
            return Redirect::back()->withInput()->withErrors($errors);
            }


        // Redirect to the asset management page with error
        return Redirect::to("admin/settings/assetdetails/$assetdetailId/edit")->with('error', Lang::get('admin/assetdetails/message.update.error'));

    }

Мой Route.php

Route::post('create', array('as' => 'savenew/assetdetail','uses' => 'Controllers\Admin\AssetdetailsController@postCreate'));
            Route::get('{assetdetailId}/edit', array('as' => 'update/assetdetail', 'uses' => 'Controllers\Admin\AssetdetailsController@getEdit'));
            Route::post('{assetdetailId}/edit', 'Controllers\Admin\AssetdetailsController@postEdit');

Теперь проблема в том, что когда я пытаюсь обновить свою форму, поле asset_number выдает ошибку: значение_объекта уже выполнено. Как передать идентификатор в моем контроллере при обновлении моей формы, чтобы он выдавал ошибку, только если уже существующее имя_общества а не при редактировании формы с текущим номером ресурса.

Я попробовал следующее без везения

Модель

'asset_number' => 'mobileNumber' => 'required|min:5|numeric|unique:asset_details,asset_number,' . $id

контроллер

Assetdetail::$rules['mobileNumber'] = 'required|min:5|numeric|unique:asset_details,asset_number,' . $id
Теги:
validation
laravel-4
laravel-routing

1 ответ

0
Лучший ответ

Привет, я наконец нашел рабочее решение, я вот что я сделал, пожалуйста, взгляните

контроллер

class AssetdetailsController extends AdminController 
 {

     protected $validationRules = array
        (   
            'asset_number'              => 'required|alpha_dash|min:2|max:12|unique:asset_details,asset_number',
            'asset_name'                => 'alpha_space',
            'asset_type_id'             => 'required',
            'shift'                     => 'required',
        );

    public function postCreate()
    {

        $validator = Validator::make(Input::all(), $this->validationRules);

        // If validation fails, we'll exit the operation now.
        if ($validator->fails())
        {
            // Ooops.. something went wrong
            return Redirect::back()->withInput()->withErrors($validator);
        }

        // attempt validation
        else
        {

            $assetdetail ->asset_number             = e(Input::get('asset_number'));
            $assetdetail ->asset_name               = e(Input::get('asset_name'));
            $assetdetail ->asset_type_id            = e(Input::get('asset_type_id'));
            $assetdetail ->shift                    = e(Input::get('shift'));

            // Was the asset created?
            if($assetdetail ->save())
            {
                // Redirect to the new location  page
                return Redirect::to("admin/settings/assetdetails")->with('success', Lang::get('admin/assetdetails/message.create.success'));
            }
        }


        // Redirect to the location create page
        return Redirect::to('admin/settings/assetdetails/create')->with('error', Lang::get('admin/assetdetails/message.create.error'));

    }

    public function postEdit($assetdetailId = null)
    {
        // Check if the location exists
        if (is_null($assetdetail = Assetdetail::find($assetdetailId)))
        {
            // Redirect to the blogs management page
            return Redirect::to('admin/settings/assetdetails')->with('error', Lang::get('admin/assetdetails/message.assetdetail_not_exist'));
        }

        $this->validationRules['asset_number'] = "required|alpha_dash|min:2|max:12|unique:asset_details,asset_number,{$assetdetail->asset_number},asset_number";

        $validator = Validator::make(Input::all(), $this->validationRules);


        // If validation fails, we'll exit the operation now.
        if ($validator->fails())
        {
            // Ooops.. something went wrong
            return Redirect::back()->withInput()->withErrors($validator);
        }

        else
        {
            $assetdetail ->asset_number             = e(Input::get('asset_number'));
            $assetdetail ->asset_name               = e(Input::get('asset_name'));
            $assetdetail ->asset_type_id            = e(Input::get('asset_type_id'));
            $assetdetail ->shift                    = e(Input::get('shift'));

            if($assetdetail->save())
            {
                // Redirect to the saved location page
                return Redirect::to("admin/settings/assetdetails/$assetdetailId/edit")->with('success', Lang::get('admin/assetdetails/message.update.success'));
            }
        }

        // Redirect to the asset management page with error
        return Redirect::to("admin/settings/assetdetails/$assetdetailId/edit")->with('error', Lang::get('admin/assetdetails/message.update.error'));

    }
}

Ещё вопросы

Сообщество Overcoder
Наверх
Меню