import { ServerRoute } from '@hapi/hapi'
import Joi from '@hapi/joi'
import { PermissionHandler } from '../handlers/permission.handler'
import { options } from "../validators/global.validator.schema"
import { Common } from "../../utils/common"
import {
    permissionResponse,
    permissionRequest,
    permissionIdentifier,
    permissionStringIdentifier,
    permissionListRequest,
    permissionListResponse,
    permissionListAllRequest,
    permissionListAllResponse,
    permissionStatusRequest,
    permissionSortOrderRequest,
} from "../validators/permission.validator"
import { I18N } from '../../utils/i18n';
const permissionHandler = new PermissionHandler();
import { error400, error401, error403, error404, error500, confirmationOnly } from "../validators/global.validator.schema"
const routes: ServerRoute[] = [
    {
        method: 'POST',
        path: '/permission',
        handler: permissionHandler.create,
        options: {
            tags: ['api', 'Permission'],
            description: I18N.t('CREATE_PERMISSION_DESCRIPTION'),
            notes: I18N.t('CREATE_PERMISSION_NOTE'),
            auth: { strategies: ['jwt'], scope: ['admin', 'managePermissions'] },
            plugins: { 'hapi-swagger': { order: 1 } },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                payload: permissionRequest,
            },
            response: {
                status: {
                    201: permissionResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }
            }
        },
    },
    {
        method: 'GET',
        path: '/permission/{id}',
        handler: permissionHandler.getById,
        options: {
            tags: ['api', 'Permission'],
            description: I18N.t('GET_PERMISSION_BY_ID_DESCRIPTION'),
            notes: I18N.t('GET_PERMISSION_BY_ID_NOTE'),
            plugins: { 'hapi-swagger': { order: 2 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'managePermissions'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                params: permissionIdentifier
            },
            response: {
                status: {
                    200: permissionResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }
            }
        },
    },
    {
        method: 'GET',
        path: '/permission/{code}/byCode',
        handler: permissionHandler.getByCode,
        options: {
            tags: ['api', 'Permission'],
            description: I18N.t('GET_PERMISSION_BY_CODE_DESCRIPTION'),
            notes: I18N.t('GET_PERMISSION_BY_CODE_NOTE'),
            plugins: { 'hapi-swagger': { order: 3 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'managePermissions'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                params: permissionStringIdentifier
            },
            response: {
                status: {
                    200: permissionResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }
            }
        },
    },
    {
        method: 'PATCH',
        path: '/permission/{id}',
        handler: permissionHandler.update,
        options: {
            tags: ['api', 'Permission'],
            description: I18N.t('UPDATE_PERMISSION_DESCRIPTION'),
            notes: I18N.t('UPDATE_PERMISSION_NOTE'),
            plugins: { 'hapi-swagger': { order: 4 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'managePermissions'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                payload: permissionRequest,
                params: permissionIdentifier
            },
            response: {
                status: {
                    200: permissionResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }
            }
        },
    },
    {
        method: 'DELETE',
        path: '/permission/{id}',
        handler: permissionHandler.delete,
        options: {
            tags: ['api', 'Permission'],
            description: I18N.t('DELETE_PERMISSION_DESCRIPTION'),
            notes: I18N.t('DELETE_PERMISSION_NOTE'),
            plugins: { 'hapi-swagger': { order: 5 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'managePermissions'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                params: permissionIdentifier
            },
            response: {
                status: {
                    200: permissionResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }
            }
        },
    },
    {
        method: 'GET',
        path: '/permission/list',
        handler: permissionHandler.list,
        options: {
            tags: ['api', 'Permission'],
            description: I18N.t('LIST_PERMISSION_DESCRIPTION'),
            notes: I18N.t('LIST_PERMISSION_NOTE'),
            plugins: { 'hapi-swagger': { order: 6 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'managePermissions'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                query: permissionListRequest
            },
            response: {
                status: {
                    200: permissionListResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }
            }
        },
    },
    {
        method: 'GET',
        path: '/permission/listAll',
        handler: permissionHandler.listAll,
        options: {
            tags: ['api', 'Permission'],
            description: I18N.t('LIST_ALL_PERMISSION_DESCRIPTION'),
            notes: I18N.t('LIST_ALL_PERMISSION_NOTE'),
            plugins: { 'hapi-swagger': { order: 7 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'managePermissions'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                query: permissionListAllRequest
            },
            response: {
                status: {
                    200: permissionListAllResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }
            }
        },
    },
    {
        method: 'GET',
        path: '/permission/{id}/listRevisions',
        handler: permissionHandler.listRevisions,
        options: {
            tags: ['api', 'Permission'],
            description: I18N.t('LIST_PERMISSION_REVISIONS_DESCRIPTION'),
            notes: I18N.t('LIST_PERMISSION_REVISIONS_NOTE'),
            plugins: { 'hapi-swagger': { order: 8 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'managePermissions'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                params: permissionIdentifier,
                query: permissionListRequest
            },
            response: {
                status: {
                    200: permissionListResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }
            }
        },
    },
    {
        method: 'POST',
        path: '/permission/{id}/restoreRevision',
        handler: permissionHandler.restoreRevision,
        options: {
            tags: ['api', 'Permission'],
            description: I18N.t('RESTORE_PERMISSION_REVISION'),
            notes: I18N.t('RESTORE_PERMISSION_REVISION_NOTE'),
            plugins: { 'hapi-swagger': { order: 9 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'managePermissions'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                params: permissionIdentifier
            },
            response: {
                status: {
                    200: permissionResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }
            }
        },
    },
    {
        method: 'GET',
        path: '/permission/tree',
        handler: permissionHandler.permissionTree,
        options: {
            tags: ['api', 'Permission'],
            description: I18N.t('RESTORE_PERMISSION_REVISION'),
            notes: I18N.t('RESTORE_PERMISSION_REVISION_NOTE'),
            plugins: { 'hapi-swagger': { order: 9 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'managePermissions'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover
            },
            response: {
                status: {
                    //200: permissionResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }
            }
        },
    },
    {
        method: 'PATCH',
        path: '/permission/{id}/sortOrder',
        handler: permissionHandler.setSortOrder,
        options: {
            tags: ['api', 'Permission'],
            description: I18N.t('PERMISSION_SORT_ORDER_DESCRIPTION'),
            notes: I18N.t('PERMISSION_SORT_ORDER_NOTE'),
            plugins: { 'hapi-swagger': { order: 10 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'manageCategories'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                params: permissionIdentifier,
                payload: permissionSortOrderRequest
            },
            response: {
                status: {
                    200: confirmationOnly,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }
            }
        },
    },
    {
        method: 'PATCH',
        path: '/permission/{id}/status',
        handler: permissionHandler.updateStatus,
        options: {
            tags: ['api', 'Permission'],
            description: I18N.t('PERMISSION_STATUS_UPDATE_DESCRIPTION'),
            notes: I18N.t('PERMISSION_STATUS_UPDATE_NOTE'),
            plugins: { 'hapi-swagger': { order: 11 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'manageCategories'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                params: permissionIdentifier,
                payload: permissionStatusRequest
            },
            response: {
                status: {
                    200: permissionResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }
            }
        },
    }
]
export default routes