# (c) cavaliba.com  - data/api - role.py



import app_data.api.helper as helper
from app_home.log import DEBUG, log
from app_user.aaa_api import start_api
from app_user.role import role_get_by_id, role_get_by_name, role_listdict_format, role_search
from django.views.decorators.csrf import csrf_exempt

# permission: p_role_read

#  ----------------------------------------------------------------------------
# /api/roles/
# /api/roles/<id>/
# /api/roles/<key>/
#  ----------------------------------------------------------------------------
@csrf_exempt
def role(request, id=None, key=None):

    aaa_api = start_api(request, permission="p_role_read")
    if not aaa_api["is_allowed"]:
        return helper.send_denied()

    log(DEBUG, aaa=aaa_api, app="api", view="role", action="GET", status="OK", data="")


    # single by id
    if id:
        r = role_get_by_id(id)
        if r:
            reply = role_listdict_format([r])
            return helper.send_response(request, reply, 200)
        else:
            return helper.send_not_found()

    # single by keyname/name
    if key:
        r = role_get_by_name(key)
        if r:
            reply = role_listdict_format([r])
            return helper.send_response(request, reply, 200)
        else:
            return helper.send_not_found()


    # multi list
    search = request.GET.get('search', '')
    page = helper.get_page(request)
    size = helper.get_size(request)
    roles = role_search(query=search, page=page, size=size)

    reply = role_listdict_format(roles)

    if len(reply) == 0:
        return helper.send_not_found()
    else:
        return helper.send_response(request, reply, 200)
