217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
|
# File 'lib/engine2/action/list.rb', line 217
def list_context query, handler
handler.permit parent = handler.params[:parent_id]
model = assets[:model]
assoc = assets[:assoc]
parent_keys = split_keys(parent)
case assoc[:type]
when :one_to_many
keys = assoc[:keys]
condition = parent_keys.all?(&:empty?) ? false : Hash[keys.map{|k| model.table_name.q(k)}.zip(parent_keys)]
if handler.params[:negate]
query = query.exclude(condition)
query = query.or(Hash[keys.zip([nil])]) if keys.all?{|k|model.db_schema[k][:allow_null] == true}
query
else
query.where(condition)
end
when :many_to_many
q_pk = model.primary_keys_qualified
j_table = assoc[:join_table]
l_keys = assoc[:left_keys].map{|k| j_table.q(k)}
r_keys = assoc[:right_keys].map{|k| j_table.q(k)}
r_keys_vals = Hash[r_keys.zip(q_pk)]
l_keys_vals = parent_keys.all?(&:empty?) ? false : Hash[l_keys.zip(parent_keys)]
if handler.params[:negate]
query.exclude(model.db[j_table].select(nil).where(r_keys_vals & l_keys_vals).exists)
else
if joins = query.opts[:join] and joins.find{|j|j.table == j_table}
query
else
query.qualify.left_join(j_table, r_keys_vals)
end.filter(l_keys_vals)
end
else unsupported_association
end
end
|