问题描述
我正在建立一个博客样式文档站点。创建子页面时,我正在使用作者的用户输入字段。我发现Wagtail在页面模型中拥有所有者。为了不重复数据,我删除了author字段,以便可以使用默认的wagtail字段。但是,我已经设置了用于身份验证的LDAP模块,因此所有者作为雇员ID(而不是用户名)存放。该员工ID确实映射为全名,我可以通过owner.get_full_name在模板上访问它。
问题是,执行搜索时,如何设置默认搜索以检查所有者的全名?如何将其纳入搜索索引?我对Wagtail还是有点陌生,所以这可能是创建带有外键映射回用户表的author字段的情况,还是应该修改搜索视图以包括遍历用户表的情况?
def search(request):
search_query = request.GET.get('query',None)
page = request.GET.get('page',1)
# Search
if search_query:
search_results = Page.objects.live().search(search_query)
query = Query.get(search_query)
# Record hit
query.add_hit()
else:
search_results = Page.objects.none()
# Pagination
paginator = Paginator(search_results,10)
try:
search_results = paginator.page(page)
except PageNotAnInteger:
search_results = paginator.page(1)
except EmptyPage:
search_results = paginator.page(paginator.num_pages)
return TemplateResponse(request,'search/search.html',{
'search_query': search_query,'search_results': search_results,})
解决方法
如果您查看Wagtail搜索文档,它描述了为可调用项和附加属性编制索引的过程:
所以我要做的是:
- 在页面类中创建一个get_owner_full_name()方法
- 将index.SearchField('get_owner_full_name')添加到search_fields
不过请注意,这仅在使用PostgreSQL后端或Elasticsearch后端时才有效。默认的数据库后端不支持额外字段的索引。