Предполагая, что существует связь ForeingKey между моделью администратора и моделью пользователя, вы можете настроить фильтр на то, что видит пользователь. Например:
class UserCreatesAndViewsSomething(LoginRequiredMixin, CreateView):
model = UserLog (or something like that)
template_name = 'some template you have'
fields = ('field you want to display',)
# This function will submit the form to the database
def form_valid(self, form):
# this will help you determine what the current administrator is
administrator = AdministratorModel.objects.get(user=self.request.user, administrator=self.kwargs['administrator'])
form.instance.user = self.request.user
# This will autopopulate administrator input to the current user administrator
form.instance.administrator = administrator
return super(UserCreatesAndViewsSomething, self).form_valid(form)
# get_context_data will help you determine what the user can see.
def get_context_data(self, **kwargs):
administrator = AdministratorModel.objects.get(user=self.request.user, administrator=self.kwargs['administrator'])
context = super(UserCreatesAndViewsSomething, self).get_context_data(**kwargs)
context['something'] = to_journal_entry.objects.filter(user=self.request.user, administrator=administrator)
return context
Я знаю, что это много, но если вы вообще знакомы с Джанго, вы, безусловно, можете это сделать. Вам придется пройти через метод проб и ошибок, но этот подход я использовал для своего проекта.
Примечание для финала: предполагается, что все ваши пользователи и пользовательские входы находятся в одной базе данных, а код помогает вам получитьтолько соответствующая информация. Если вы имеете дело с клиентами высокой важности или с какой-либо конфиденциальной информацией, вам, вероятно, следует обратиться к мультитенантности, которая создаст другую схему или другую базу данных для каждого из ваших клиентов. Это приведет к другой структуре кода.
Надеюсь, это поможет.