我使用的是elasticsearch_dsl,它工作得很好。
但是,我希望结果根据发送的用户令牌进行过滤。
我尝试使用rest_frameworks的过滤器,但没有成功。
实现这一目标的正确方法是什么?
访问结果的URL
http://localhost:9200/_searchModels.py
class Task(models.Model):
title = models.CharField("Title", max_length=10000, blank=True)
owner = models.ForeignKey('auth.User', blank=True, null=True)Search.py
from rest_framework import filters
connections.create_connection()
class TaskIndex(DocType):
title = String()
class Meta:
index = 'task-index'
def filter_queryset(self, request, queryset, view):
return queryset.filter(owner=request.user)
def bulk_indexing():
TaskIndex.init()
es = Elasticsearch()
bulk(client=es, actions=(b.indexing() for b in models.Task.objects.all().iterator()))
def _search(title):
s = Search().filter('term', title=title.text)
response = s.execute()
return response发布于 2017-03-02 10:18:43
只需将_search函数修改为也按用户过滤即可。我不知道在ES中存储用户的格式是什么,但应该是这样的:
from elasticsearch_dsl.query import Q
def _search(title, user):
s = Search().query('bool', must=[
Q('term', title=title.text),
Q('match', owner=user.pk),
])
return s.execute()https://stackoverflow.com/questions/42545037
复制相似问题