Como filtrar uma tabela dinâmica usando o Eloquent?
Estou usando uma tabela dinâmica no projeto com o qual estou trabalhando para obter trabalhos de usuários.
Por exemplo:User::find(1)->works
me dá os trabalhos do usuário com ID de 1.
O problema é que eu quero filtrar esses resultados com dados Pivot extras.
Algo como:
User::find(1)->works->pivot->where('active',1)->get();
Em que o ativo é a coluna que eu configurei na tabela dinâmica de user_works.
Esta é minha parte relacionada do meu modelo User.php:
<?php
class User extends Cartalyst\Sentry\Users\Eloquent\User {
public function works() {
return $this->belongsToMany('Work','user_works')->withPivot('active')->withTimestamps();
}
}
Esta é minha parte relacionada do meu modelo Work.php:
<?php
class Work extends Eloquent {
public function users() {
return $this->belongsToMany('User','user_works')->withPivot('active')->withTimestamps();
}
}
Este é o meu esquema de tabela dinâmica:
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
class CreateUserWorksTable extends Migration {
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('user_works', function(Blueprint $table) {
$table->increments('id');
$table->integer('user_id')->unsigned()->default(0);
$table->integer('work_id')->unsigned()->default(0);
$table->enum('active',array('0','1'))->default(1);
$table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');
$table->foreign('work_id')->references('id')->on('works')->onDelete('cascade');
$table->timestamps();
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::drop('user_works');
}
}
Existe alguma maneira de obter os dados sem criar um novo modelo para a tabela dinâmica?
Desde já, obrigado,
Editar: Eu posso filtrar assim:
return User::find(1)->works()->where('user_works.active','=','1')->get();
Eu tive que digitar o nome da tabela raw. Mas existe uma maneira melhor de obter isso sem usá-lo?