# (c) cavaliba.com - IAM - ajax.py

import json
import re

from app_home.configuration import get_configuration
from app_user.aaa import start_ajax
from app_user.models import SireneUser
from django.db.models import Q
from django.http import HttpResponse
from django.views.decorators.csrf import csrf_protect


# Security: authenticated (oauth2), GET / read-only
@csrf_protect
def ajax_user(request):

    # GET /user/private/ajax/?q=query
    # respdata = """
    # {
    #   "results": [
    #     { "id": "ajax1", "text": "ajax1"},
    #     { "id": "ajax2", "text": "ajax2"}
    #   ]
    # }
    # """
    response = HttpResponse("{}", content_type='text/json')

    context = start_ajax(request)
    if not context:
        return response

    m = re.compile(r'[a-zA-Z0-9()_/.-]*$')
    query = request.GET.get("q", "")
    if not m.match(query):
        return response

    bigset_size = int(get_configuration("data","DATA_BIGSET_SIZE"))

    # 3.21
    #users = SireneUser.objects.filter(is_enabled=True, login__icontains=query)[0:bigset_size]
    users = SireneUser.objects\
                .filter( Q(displayname__icontains=query)\
                | Q(login__icontains=query)\
                | Q(email__icontains=query)\
                | Q(firstname__icontains=query)\
                | Q(lastname__icontains=query)\
                )[0:bigset_size]

    data = {}
    data['results'] = []

    dsp = "---"
    data['results'].append({'id':'---', 'text':dsp})

    for item in users:
        dsp = f"{item.login} ({item.displayname})"
        data['results'].append({'id':item.login, 'text':dsp})


    respdata = json.dumps(data, indent=4, ensure_ascii = False).encode('utf8')
    return HttpResponse(respdata, content_type='text/json')


