Um DbContext pode impor uma política de filtr

Gostaria de passar um valor para o ctor de um DbContext e fazer com que esse valor imponha "filtragem" nos DbSets relacionados. Isso é possível ... ou existe uma abordagem melhor?

Code pode ficar assim:

class Contact {
  int ContactId { get; set; }
  int CompanyId { get; set; }
  string Name { get; set; }
}

class ContactContext : DbContext {
  public ContactContext(int companyId) {...}
  public DbSet<Contact> Contacts { get; set; }
}

using (var cc = new ContactContext(123)) {
  // Would only return contacts where CompanyId = 123
  var all = (from i in cc.Contacts select i);

  // Would automatically set the CompanyId to 123
  var contact = new Contact { Name = "Doug" };
  cc.Contacts.Add(contact);
  cc.SaveChanges();

  // Would throw custom exception
  contact.CompanyId = 456;
  cc.SaveChanges;
}

questionAnswers(2)

yourAnswerToTheQuestion