import { ServerRoute } from '@hapi/hapi'
import Joi from '@hapi/joi'
import { RoleHandler } from '../handlers/role.handler'
import { options } from "../validators/global.validator.schema"
import { Common } from "../../utils/common"
import {
    roleResponse,
    roleRequest,
    roleIdentifier,
    roleStringIdentifier,
    roleListRequest,
    roleListResponse,
    roleListAllRequest,
    roleListAllResponse,
    roleSortOrderRequest,
    roleStatusRequest
} from "../validators/role.validator"
const roleHandler = new RoleHandler();
import { I18N } from '../../utils/i18n';
import { error400, error401, error403, error404, error500, confirmationOnly } from "../validators/global.validator.schema"
const routes: ServerRoute[] = [
    {
        method: 'POST',
        path: '/role',
        handler: roleHandler.create,
        options: {
            tags: ['api', 'Role'],
            description: I18N.t('CREATE_ROLE_DESCRIPTION'),
            notes: I18N.t('CREATE_ROLE_NOTE'),
            auth: { strategies: ['jwt'], scope: ['admin', 'manageRoles'] },
            plugins: { 'hapi-swagger': { order: 1 } },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                payload: roleRequest,
            },
            response: {
                status: {
                    201: roleResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }

            }
        },
    },
    {
        method: 'GET',
        path: '/role/{id}',
        handler: roleHandler.getById,
        options: {
            tags: ['api', 'Role'],
            description: I18N.t('GET_ROLE_BY_ID_DESCRIPTION'),
            notes: I18N.t('GET_ROLE_BY_ID_NOTE'),
            plugins: { 'hapi-swagger': { order: 2 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'manageRoles'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                params: roleIdentifier
            },
            response: {
                status: {
                    200: roleResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }

            }
        },
    },
    {
        method: 'GET',
        path: '/role/{code}/byCode',
        handler: roleHandler.getByCode,
        options: {
            tags: ['api', 'Role'],
            description: I18N.t('GET_ROLE_BY_CODE_DESCRIPTION'),
            notes: I18N.t('GET_ROLE_BY_CODE_NOTE'),
            plugins: { 'hapi-swagger': { order: 3 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'manageRoles'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                params: roleStringIdentifier
            },
            response: {
                status: {
                    200: roleResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }

            }
        },
    },
    {
        method: 'PATCH',
        path: '/role/{id}',
        handler: roleHandler.update,
        options: {
            tags: ['api', 'Role'],
            description: I18N.t('UPDATE_ROLE_DESCRIPTION'),
            notes: I18N.t('UPDATE_ROLE_NOTE'),
            plugins: { 'hapi-swagger': { order: 4 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'manageRoles'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                payload: roleRequest,
                params: roleIdentifier
            },
            response: {
                status: {
                    200: roleResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }

            }
        },
    },
    {
        method: 'DELETE',
        path: '/role/{id}',
        handler: roleHandler.delete,
        options: {
            tags: ['api', 'Role'],
            description: I18N.t('DELETE_ROLE_DESCRIPTION'),
            notes: I18N.t('DELETE_ROLE_NOTE'),
            plugins: { 'hapi-swagger': { order: 5 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'manageRoles'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                params: roleIdentifier
            },
            response: {
                status: {
                    200: roleResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }

            }
        },
    },
    {
        method: 'GET',
        path: '/role/list',
        handler: roleHandler.list,
        options: {
            tags: ['api', 'Role'],
            description: I18N.t('LIST_ROLE_DESCRIPTION'),
            notes: I18N.t('LIST_ROLE_NOTE'),
            plugins: { 'hapi-swagger': { order: 6 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'manageRoles','manageLiveStreams'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                query: roleListRequest
            },
            response: {
                status: {
                    200: roleListResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }

            }
        },
    },
    {
        method: 'GET',
        path: '/role/listAll',
        handler: roleHandler.listAll,
        options: {
            tags: ['api', 'Role'],
            description: I18N.t('LIST_ALL_ROLE_DESCRIPTION'),
            notes: I18N.t('LIST_ALL_ROLE_NOTE'),
            plugins: { 'hapi-swagger': { order: 7 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'manageRoles','manageLiveStreams'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                query: roleListAllRequest
            },
            response: {
                status: {
                    200: roleListAllResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }

            }
        },
    },
    {
        method: 'GET',
        path: '/role/{id}/listRevisions',
        handler: roleHandler.listRevisions,
        options: {
            tags: ['api', 'Role'],
            description: I18N.t('LIST_ROLE_REVISIONS_DESCRIPTION'),
            notes: I18N.t('LIST_ROLE_REVISIONS_NOTE'),
            plugins: { 'hapi-swagger': { order: 8 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'manageRoles'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                params: roleIdentifier,
                query: roleListRequest
            },
            response: {
                status: {
                    200: roleListResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }

            }
        },
    },
    {
        method: 'POST',
        path: '/role/{id}/restoreRevision',
        handler: roleHandler.restoreRevision,
        options: {
            tags: ['api', 'Role'],
            description: I18N.t('RESTORE_ROLE_REVISION'),
            notes: I18N.t('RESTORE_ROLE_REVISION_NOTE'),
            plugins: { 'hapi-swagger': { order: 9 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'manageRoles'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                params: roleIdentifier
            },
            response: {
                status: {
                    200: roleResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }

            }
        },

    },
    {
        method: 'PATCH',
        path: '/role/{id}/sortOrder',
        handler: roleHandler.setSortOrder,
        options: {
            tags: ['api', 'Role'],
            description: I18N.t('ROLE_SORT_ORDER_DESCRIPTION'),
            notes: I18N.t('ROLE_SORT_ORDER_NOTE'),
            plugins: { 'hapi-swagger': { order: 10 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'manageQuotes'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                params: roleIdentifier,
                payload: roleSortOrderRequest
            },
            response: {
                status: {
                    200: confirmationOnly,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }

            }
        },
    },
    {
        method: 'PATCH',
        path: '/role/{id}/status',
        handler: roleHandler.updateStatus,
        options: {
            tags: ['api', 'Role'],
            description: I18N.t('ROLE_STATUS_UPDATE_DESCRIPTION'),
            notes: I18N.t('ROLE_STATUS_UPDATE_NOTE'),
            plugins: { 'hapi-swagger': { order: 11 } },
            auth: { strategies: ['jwt'], scope: ['admin', 'manageQuotes'] },
            validate: {
                headers: Common.routeHeaders("authorized"),
                options: options,
                failAction: Common.failover,
                params: roleIdentifier,
                payload: roleStatusRequest
            },
            response: {
                status: {
                    200: roleResponse,
                    400: error400,
                    401: error401,
                    403: error403,
                    404: error404,
                    500: error500
                }

            }
        },
    }

]
export default routes