summaryrefslogtreecommitdiffstats
path: root/openresty-ext/src/assembly/resources/openresty/nginx/luaext/core/error_handler.lua
blob: f21f10a8aa7e2796371149b05ccb7f4ffecf95e0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
--[[

    Copyright (C) 2016 ZTE, Inc. and others. All rights reserved. (ZTE)

    Licensed under the Apache License, Version 2.0 (the "License");
    you may not use this file except in compliance with the License.
    You may obtain a copy of the License at

            http://www.apache.org/licenses/LICENSE-2.0

    Unless required by applicable law or agreed to in writing, software
    distributed under the License is distributed on an "AS IS" BASIS,
    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    See the License for the specific language governing permissions and
    limitations under the License.

--]]

local _M = {}
_M._VERSION = '1.0.0'
local msbConf   =  require('conf.msbinit')
local enablefullsearch = msbConf.systemConf.enablefullsearch
local ngx_var = ngx.var
local error_page_head = '<html><head><title>502 Bad Gateway</title></head><body bgcolor="white"><center><h1>502 Bad Gateway</h1></center><center>error message:'
local error_page_foot = '</center><hr><center>nginx</center></body></html>'
local upstream_not_found_err = "service info is incorrect:using own upstream flag is on but upstream name is empty"

function _M.svc_not_found(err_info,detail_info)
	ngx.log(ngx.WARN, ngx.var.request_id.." "..(err_info or "").." detail_info:"..(detail_info or ""))
	if enablefullsearch and ngx_var.svc_type ~= "custom" then
		-- test against the custom services after the commonrewrite phase
		--ngx.status = ngx.HTTP_GONE
		return ngx.exec("@commonnotfound");
	else
		ngx.status = ngx.HTTP_BAD_GATEWAY
		ngx.print(error_page_head..err_info..error_page_foot)
	end
	return ngx.exit(ngx.status)
end

function _M.svc_not_allow_access(err_info,detail_info)
	ngx.log(ngx.WARN, ngx.var.request_id.." "..(err_info or "").." detail_info:"..(detail_info or ""))
	ngx.status = ngx.HTTP_FORBIDDEN
	return ngx.exit(ngx.status)
end

function _M.upstream_not_found()
	ngx.log(ngx.WARN, ngx.var.request_id.." "..upstream_not_found_err)
	ngx.status = ngx.HTTP_BAD_GATEWAY
	ngx.print(error_page_head..upstream_not_found_err..error_page_foot)
	return ngx.exit(ngx.status)
end

function _M.no_server_available(err_info,detail_info)
	ngx.log(ngx.WARN, ngx.var.request_id.." "..(err_info or "").." detail_info:"..(detail_info or ""))
	ngx.status = ngx.HTTP_BAD_GATEWAY
	ngx.print(error_page_head..err_info..error_page_foot)
	return ngx.exit(ngx.status)
end

return _M