Elocuente: Calling Where en una relación

Tengo la siguiente consulta ORM elocuente.

$products2 = Product::with('metal', 'metal.fixes', 'metal.fixes.currency')
    ->where('metal_id', '=', 1)
    ->get()->toArray();

El resultado de esta consulta es el siguiente:

http://pastebin.com/JnDi7swv

Deseo restringir aún más mi consulta para mostrar solo productos dondefixes.currency_id = 1.

$products2 = Product::with('metal', 'metal.fixes', 'metal.fixes.currency')
    ->where('metal_id', '=', 1)
    ->where('metal.fixes.currency_id', '=', 1)
    ->get()->toArray();

¿Podría alguien ayudarme con este segundo donde por favor? Estoy recibiendo el siguiente error:

SQLSTATE[42S22]: Column not found: 1054 Unknown column 'metal.fixes.currency_id' 
in 'where clause' (SQL: select * from `products` where `metal_id` = ? 
and `metal`.`fixes`.`currency_id` = ?) (Bindings: array ( 0 => 1, 1 => 1, ))

Resuelto con la ayuda de Rob Gordijn:

$products2 = Product::with(array(
    'metal', 
    'metal.fixes.currency', 
    'metal.fixes' => function($query){
        $query->where('currency_id', '=', 1);
     }))
        ->where('common', '=', 1)
        ->where('metal_id', '=', 1)
        ->get()->toArray();

Respuestas a la pregunta(1)

Su respuesta a la pregunta