csx před 4 roky
revize
2d4faf188d

binární
Data_Upload_Api Zobrazit soubor


+ 119 - 0
conf/app.conf Zobrazit soubor

@@ -0,0 +1,119 @@
1
+appname = 血透
2
+httpport = 9550
3
+runmode = dev
4
+
5
+copyrequestbody = true
6
+sessionon = true
7
+sessiongcmaxlifetime = 64800
8
+
9
+tokencookiemaxlifetime = 7200
10
+
11
+enablexsrf = false
12
+xsrfkey = 61oETzKXQAGaYdkL5gEmGeJJFuYh7EQnp2XdTP1o
13
+xsrfexpire = 3600
14
+
15
+qiniu_accesskey = -l_Pcc1YJs0gh3w0YwN2uoaZO_5fY5J9SIYnSjg0
16
+qiniu_secretkey = DmZSp_Bmnp-9aUB7xUvoyViZpzmx1Rs2RL69GvlW
17
+qiniu_domain = https://images.shengws.com/
18
+qiniu_bucket = syhclub-storage
19
+
20
+aes_key = "xuetou-201807319"
21
+
22
+wxtoken = gh_ac6cd0cdde3d
23
+wxoriId = gh_ac6cd0cdde3d
24
+wxappId = wxbb9223f20bc11612
25
+# wxappsecret = a78c793c377268db25dde2eb971a2ebb
26
+# wxEncodingAESKey = 1vRDzqltXYOc9iMqhsQT7AkIRRpUaGl8MZlUcP7x4UK
27
+
28
+sms_appId = dcabb3aa7afd402794046ebbbf652bce
29
+sms_sid = a26cb0ceb3a811ca82143972f4ef38a4
30
+sms_token = ea475ed8d3de6c54c2b3f9d78db76d1e
31
+sms_baseUrl = https://open.ucpaas.com/ol/sms/
32
+ip_max_send_count = 20
33
+moblie_max_send_count = 5
34
+sms_verification_code_templateid = 329532
35
+
36
+
37
+appid = "wx43ad410d9eef426e"
38
+mchid = "1509573721"
39
+key = "e4SHrkiZu0pQEwVoGBapDBTf9N1Q6MxV"
40
+appsecret="61ee2e6268497d5aa9de0b0187c39aea"
41
+
42
+
43
+sz_province = 19
44
+sz_city = 291
45
+
46
+
47
+
48
+[prod]
49
+httpdomain = http://api.szjkhd.com
50
+
51
+
52
+readmysqlhost = shengws1.mysql.rds.aliyuncs.com
53
+readmysqlport = 3306
54
+readmysqluser = syh
55
+readmysqlpass = xhPECP2nFObR8aUK
56
+readmysqlname = sgj_xt
57
+
58
+writemysqlhost = shengws1.mysql.rds.aliyuncs.com
59
+writemysqlport = 3306
60
+writemysqluser = syh
61
+writemysqlpass = xhPECP2nFObR8aUK
62
+writemysqlname = sgj_xt
63
+
64
+
65
+readuserhost = shengws1.mysql.rds.aliyuncs.com
66
+readuserport = 3306
67
+readuseruser = syh
68
+readuserpass = xhPECP2nFObR8aUK
69
+readusername = sgj_users
70
+
71
+writeuserhost = shengws1.mysql.rds.aliyuncs.com
72
+writeuserport = 3306
73
+writeuseruser = syh
74
+writeuserpass = xhPECP2nFObR8aUK
75
+writeusername = sgj_users
76
+
77
+redishost = 349e580b2a524290.redis.rds.aliyuncs.com
78
+redisport = 6379
79
+redispasswrod = TZtBW098WId3i27clkpj3q8dnUaVFP
80
+redisdb = 0
81
+
82
+
83
+
84
+
85
+
86
+[dev]
87
+httpdomain = http://api.szjkhd.com
88
+
89
+
90
+readmysqlhost = rm-wz9rg531npf61q03tro.mysql.rds.aliyuncs.com
91
+readmysqlport = 3306
92
+readmysqluser = root
93
+readmysqlpass = 1Q2W3e4r!@#$
94
+readmysqlname = sgj_xt
95
+
96
+writemysqlhost = rm-wz9rg531npf61q03tro.mysql.rds.aliyuncs.com
97
+writemysqlport = 3306
98
+writemysqluser = root
99
+writemysqlpass = 1Q2W3e4r!@#$
100
+writemysqlname = sgj_xt
101
+
102
+readuserhost = rm-wz9rg531npf61q03tro.mysql.rds.aliyuncs.com
103
+readuserport = 3306
104
+readuseruser = root
105
+readuserpass = 1Q2W3e4r!@#$
106
+readusername = sgj_users
107
+
108
+writeuserhost = rm-wz9rg531npf61q03tro.mysql.rds.aliyuncs.com
109
+writeuserport = 3306
110
+writeuseruser = root
111
+writeuserpass = 1Q2W3e4r!@#$
112
+writeusername = sgj_users
113
+
114
+redishost = 120.77.235.13
115
+redisport = 6379
116
+redispasswrod = syh@#$%123456!
117
+redisdb = 0
118
+
119
+

+ 29 - 0
controllers/admin_api_controllers/admin_api_base_controller.go Zobrazit soubor

@@ -0,0 +1,29 @@
1
+package admin_api_controllers
2
+
3
+import (
4
+	"Data_Upload_Api/controllers"
5
+)
6
+
7
+type AdminBaseAPIController struct {
8
+	controllers.BaseAPIController
9
+}
10
+
11
+func (this *AdminBaseAPIController) ErrorLog(format string, a ...interface{}) {
12
+	//beego.Error(fmt.Sprintf("[管理员后台] %v", fmt.Sprintf(format, a...)))
13
+}
14
+
15
+func (this *AdminBaseAPIController) WarnLog(format string, a ...interface{}) {
16
+	//beego.Warn(fmt.Sprintf("[管理员后台] %v", fmt.Sprintf(format, a...)))
17
+}
18
+
19
+func (this *AdminBaseAPIController) InfoLog(format string, a ...interface{}) {
20
+	//beego.Info(fmt.Sprintf("[管理员后台] %v", fmt.Sprintf(format, a...)))
21
+}
22
+
23
+func (this *AdminBaseAPIController) DebugLog(format string, a ...interface{}) {
24
+	//beego.Debug(fmt.Sprintf("[管理员后台] %v", fmt.Sprintf(format, a...)))
25
+}
26
+
27
+func (this *AdminBaseAPIController) TraceLog(format string, a ...interface{}) {
28
+	//beego.Trace(fmt.Sprintf("[管理员后台] %v", fmt.Sprintf(format, a...)))
29
+}

+ 9 - 0
controllers/admin_api_controllers/api_router_register.go Zobrazit soubor

@@ -0,0 +1,9 @@
1
+package admin_api_controllers
2
+
3
+import "github.com/astaxie/beego"
4
+
5
+// 管理员后台路由,以 /admin/api 为前缀
6
+func AdminAPIControllersRegisterRouters() {
7
+	beego.Router("/data/upload/api/city", &CityDataUploadAPIController{}, "post:UploadCityData")
8
+
9
+}

+ 11 - 0
controllers/admin_api_controllers/city_data_upload_api_controller.go Zobrazit soubor

@@ -0,0 +1,11 @@
1
+package admin_api_controllers
2
+
3
+import "Data_Upload_Api/controllers"
4
+
5
+type CityDataUploadAPIController struct {
6
+	controllers.BaseAPIController
7
+}
8
+
9
+func (this *CityDataUploadAPIController) UploadCityData() {
10
+
11
+}

+ 72 - 0
controllers/base_api_controller.go Zobrazit soubor

@@ -0,0 +1,72 @@
1
+package controllers
2
+
3
+import (
4
+	"Data_Upload_Api/enums"
5
+)
6
+
7
+type BaseAPIController struct {
8
+	BaseController
9
+}
10
+
11
+// func (this *BaseAPIController) Prepare() {
12
+// 	this.BaseController.Prepare()
13
+// 	beego.Trace("============================================================")
14
+// 	beego.Trace("session ID: %v", this.Ctx.Input.Cookie("beegosessionID"))
15
+// 	beego.Trace("session : %v", this.GetSession("info"))
16
+// 	this.SetSession("info", time.Now().Format("2006/01/02 15:04:05"))
17
+// 	beego.Trace("============================================================")
18
+// }
19
+
20
+// 输出数据格式化
21
+/*
22
+	success json:
23
+	{
24
+		"state": 1,
25
+		"code": 0,
26
+		"data": json,
27
+	}
28
+
29
+	fail json:
30
+	{
31
+		"state": 0,
32
+		"code": int,
33
+		"msg": string,
34
+	}
35
+*/
36
+func (this *BaseAPIController) ServeSuccessJSON(data map[string]interface{}) {
37
+	this.Data["json"] = enums.MakeSuccessResponseJSON(data)
38
+	this.ServeJSON()
39
+}
40
+
41
+func (this *BaseAPIController) ServeFailJSONWithSGJErrorCode(code int) {
42
+	this.Data["json"] = enums.MakeFailResponseJSONWithSGJErrorCode(code)
43
+	this.ServeJSON()
44
+}
45
+
46
+func (this *BaseAPIController) ServeFailJSONWithSGJError(err *enums.SGJError) {
47
+	this.Data["json"] = enums.MakeFailResponseJSONWithSGJError(err)
48
+	this.ServeJSON()
49
+}
50
+
51
+func (this *BaseAPIController) ServeFailJsonSend(code int, msg string) {
52
+	this.Data["json"] = enums.MakeFailResponseJSON(msg, code)
53
+	this.ServeJSON()
54
+}
55
+
56
+type BaseAuthAPIController struct {
57
+	BaseAPIController
58
+}
59
+
60
+func (this *BaseAuthAPIController) Prepare() {
61
+	this.BaseAPIController.Prepare()
62
+
63
+}
64
+
65
+type BaseServeAPIController struct {
66
+	BaseAPIController
67
+}
68
+
69
+func (this *BaseServeAPIController) Prepare() {
70
+	this.BaseAPIController.Prepare()
71
+
72
+}

+ 29 - 0
controllers/base_controller.go Zobrazit soubor

@@ -0,0 +1,29 @@
1
+package controllers
2
+
3
+import (
4
+	"github.com/astaxie/beego"
5
+)
6
+
7
+type BaseController struct {
8
+	beego.Controller
9
+}
10
+
11
+func (this *BaseController) ErrorLog(format string, a ...interface{}) {
12
+	//beego.Error(fmt.Sprintf(format, a...))
13
+}
14
+
15
+func (this *BaseController) WarnLog(format string, a ...interface{}) {
16
+	//beego.Warn(fmt.Sprintf(format, a...))
17
+}
18
+
19
+func (this *BaseController) InfoLog(format string, a ...interface{}) {
20
+	//beego.Info(fmt.Sprintf(format, a...))
21
+}
22
+
23
+func (this *BaseController) DebugLog(format string, a ...interface{}) {
24
+	//beego.Debug(fmt.Sprintf(format, a...))
25
+}
26
+
27
+func (this *BaseController) TraceLog(format string, a ...interface{}) {
28
+	//beego.Trace(fmt.Sprintf(format, a...))
29
+}

+ 58 - 0
controllers/base_view_controller.go Zobrazit soubor

@@ -0,0 +1,58 @@
1
+package controllers
2
+
3
+type BaseViewController struct {
4
+	BaseController
5
+}
6
+
7
+// 设置模板
8
+// 第一个参数模板,第二个参数为layout
9
+func (this *BaseViewController) SetTpl(template ...string) {
10
+	var tplName string
11
+	layout := ""
12
+	switch {
13
+	case len(template) == 1:
14
+		tplName = template[0]
15
+	case len(template) == 2:
16
+		tplName = template[0]
17
+		layout = template[1]
18
+	default:
19
+		tplName = "index.tpl"
20
+	}
21
+	this.Layout = layout
22
+	this.TplName = tplName
23
+}
24
+
25
+// 重定向
26
+func (this *BaseViewController) Redirect302(url string) {
27
+	this.Redirect(url, 302)
28
+	this.StopRun()
29
+}
30
+
31
+// 错误页面
32
+func (this *BaseViewController) Abort404() {
33
+	this.Abort("404")
34
+}
35
+
36
+// // 微信错误页面
37
+// func (this *BaseViewController) WxAbort404(title, desc string) {
38
+// 	this.Data["Title"] = title
39
+// 	this.Data["Desc"] = desc
40
+// 	this.SetTpl("view_wx/error/404.html")
41
+// }
42
+
43
+// type BaseAuthViewController struct {
44
+// 	BaseViewController
45
+// }
46
+
47
+// func (this *BaseAuthViewController) Prepare() {
48
+// 	this.BaseController.Prepare()
49
+// 	backUrl := utils.SetThisRequestURI(this.Ctx.Request.RequestURI)
50
+// 	backUrl = base64.URLEncoding.EncodeToString([]byte(backUrl))
51
+// 	if this.GetUserInfo() == nil {
52
+// 		if strings.HasPrefix(this.Ctx.Request.RequestURI, "/web/") {
53
+// 			this.Redirect302(beego.URLFor("WebLoginViewController.Login") + "?backUrl=" + backUrl)
54
+// 		} else {
55
+// 			this.Redirect302(beego.URLFor("WxLoginViewController.Login") + "?backUrl=" + backUrl)
56
+// 		}
57
+// 	}
58
+// }

Diff nebyl zobrazen, protože je příliš veliký
+ 2 - 0
db/xt_drug_dic


+ 21 - 0
db/xt_drugway_dic Zobrazit soubor

@@ -0,0 +1,21 @@
1
+INSERT INTO xt_drugway_dic (code, name, status, created_time, updated_time) VALUES 
2
+("DGCX","导管冲洗",1,1536290447,1536290447),
3
+("PO","口服",1,1536290447,1536290447),
4
+("LNZS","瘤内注射",1,1536290447,1536290447),
5
+("IVPUMP","微泵注射",1,1536290447,1536290447),
6
+("WBZS","微泵注射",1,1536290447,1536290447),
7
+("SXHF","舌下含服",1,1536290447,1536290447),
8
+("JMFG","静脉封管",1,1536290447,1536290447),
9
+("DGNWBZS","导管内微泵注射",1,1536290447,1536290447),
10
+("GLCX","管路冲洗",1,1536290447,1536290447),
11
+("PS","皮试 ",1,1536290447,1536290447),
12
+("JMCX","静脉采血",1,1536290447,1536290447),
13
+("YLGCX","引流管冲洗",1,1536290447,1536290447),
14
+("ID","皮内注射",1,1536290447,1536290447),
15
+("IH","皮下注射",1,1536290447,1536290447),
16
+("IM","肌肉注射",1,1536290447,1536290447),
17
+("IV","静脉注射",1,1536290447,1536290447),
18
+("IVGTT","静脉输液(普通)",1,1536290447,1536290447),
19
+("IVGTT","静脉输液(特殊)",1,1536290447,1536290447),
20
+("JBMZ","局部麻醉",1,1536290447,1536290447),
21
+("DGRS","导管溶栓",1,1536290447,1536290447);

+ 35 - 0
db/xt_ef_dic Zobrazit soubor

@@ -0,0 +1,35 @@
1
+INSERT INTO xt_execution_frequency_dic (code,name,status,created_time,updated_time) VALUES
2
+("AM","上午",1,1536290447,1536290447),
3
+("QW","每周一次",1,1536290447,1536290447),
4
+("SAS","需要时",1,1536290447,1536290447),
5
+("SQ30FZ","术前30分钟",1,1536290447,1536290447),
6
+("ST","立即",1,1536290447,1536290447),
7
+("TID","每日三次",1,1536290447,1536290447),
8
+("QID","每日四次",1,1536290447,1536290447),
9
+("QIW","每周四次",1,1536290447,1536290447),
10
+("TIW","每周三次",1,1536290447,1536290447),
11
+("TXHLJ","透析后立即",1,1536290447,1536290447),
12
+("XJQ","下机前",1,1536290447,1536290447),
13
+("ONCE","临时一次",1,1536290447,1536290447),
14
+("LZYC","两周一次",1,1536290447,1536290447),
15
+("LZSC","两周三次",1,1536290447,1536290447),
16
+("AA","各",1,1536290447,1536290447),
17
+("SZYC","四周一次",1,1536290447,1536290447),
18
+("QOD","隔日一次",1,1536290447,1536290447),
19
+("QN","每晚一次",1,1536290447,1536290447),
20
+("BID","每日二次",1,1536290447,1536290447),
21
+("BIW","每周二次",1,1536290447,1536290447),
22
+("CF","长方",1,1536290447,1536290447),
23
+("CITO!","急速地",1,1536290447,1536290447),
24
+("CXSY","持续使用",1,1536290447,1536290447),
25
+("F","份",1,1536290447,1536290447),
26
+("HS","临睡前",1,1536290447,1536290447),
27
+("LSKY","临时开药",1,1536290447,1536290447),
28
+("MCYC","每晨一次",1,1536290447,1536290447),
29
+("MFZYC","每分钟一次",1,1536290447,1536290447),
30
+("QD","每日一次",1,1536290447,1536290447),
31
+("QEH","每小时",1,1536290447,1536290447),
32
+("QH","每1小时一次",1,1536290447,1536290447),
33
+("QM","每晨一次",1,1536290447,1536290447),
34
+("QN","每晚",1,1536290447,1536290447),
35
+("SJQ","上机前",1,1536290447,1536290447);

binární
db/xtdb.docx Zobrazit soubor


+ 374 - 0
enums/error_code.go Zobrazit soubor

@@ -0,0 +1,374 @@
1
+package enums
2
+
3
+import "Data_Upload_Api/utils"
4
+
5
+const ( // ErrorCode
6
+	// 登录注册错误 6000+
7
+	ErrorCodeLoginTimeout                   = 6001
8
+	ErrorCodeNotLogin                       = 6002
9
+	ErrorCodePermissionDenied               = 6003
10
+	ErrorCodeMobileRegistered               = 6004
11
+	ErrorCodePasswordEmpty                  = 6005
12
+	ErrorCodeVerificationCodeWrong          = 6006
13
+	ErrorCodeRegisterFail                   = 6007
14
+	ErrorCodeInvalidToken                   = 6008
15
+	ErrorCodeAccountOrPasswordWrong         = 6009
16
+	ErrorCodeMissingOrg                     = 6010
17
+	ErrorCodeMissingOrgApp                  = 6011
18
+	ErrorCodeAccountOrVerCodeWrong          = 6012
19
+	ErrorCodeMobileNotExit                  = 6013
20
+	ErrorCodeUserNotExist                   = 6014
21
+	ErrorCodeUserWasForbidden               = 6015
22
+	ErrorCodeNeverCreateTypeApp             = 6016
23
+	ErrorCodeContactSuperAdminCreateTypeApp = 6017
24
+
25
+	// 数据验证错误 7000+
26
+	ErrorCodeMobileFormat     = 7001
27
+	ErrorCodeTelphoneFormat   = 7002
28
+	ErrorCodeParamWrong       = 7003
29
+	ErrorCodeParamFormatWrong = 7004
30
+
31
+	// 数据库操作错误 8000+
32
+	ErrorCodeDBCreate         = 8001
33
+	ErrorCodeDBUpdate         = 8002
34
+	ErrorCodeDBDelete         = 8003
35
+	ErrorCodeDBSelectNoResult = 8004
36
+	ErrorCodeDataException    = 8005
37
+
38
+	// 业务逻辑操作错误 9000+
39
+	ErrorCodeRoleNotExist           = 9001
40
+	ErrorCodeAdminUserNotExist      = 9002
41
+	ErrorCodeMobileDidUsedInApp     = 9003
42
+	ErrorCodeMissingUserName        = 9004
43
+	ErrorCodeOldPasswordWrong       = 9005
44
+	ErrorCodeCannotRemoveRole       = 9006
45
+	ErrorCodeRoleMobileIsSuperAdmin = 9007
46
+
47
+	ErrorCodeGetQiniuUpToken                = 1001
48
+	ErrorCodeCreatePatient                  = 1002
49
+	ErrorCodeDialysisNoExist                = 1003
50
+	ErrorCodeIdCardNoExist                  = 1004
51
+	ErrorCodePatientNoExist                 = 1005
52
+	ErrorCodeUpdatePatient                  = 1006
53
+	ErrorCodeDialysisSolutionExist          = 1007
54
+	ErrorCodeDialysisSolutionCreate         = 1008
55
+	ErrorCodeDialysisSolutionUpdate         = 1009
56
+	ErrorCodeDialysisSolutionNotExist       = 1010
57
+	ErrorCodeParentDialysisSolutionNotExist = 1011
58
+	ErrorCodeAlReadyHadChildSolution        = 1012
59
+	ErrorCodeCanntCreateChildChildSolution  = 1013
60
+	ErrorCodeDialysisSolutionUsed           = 1014
61
+	ErrorCodeCreateDryWeightFail            = 1015
62
+	ErrorCodeCreateDoctorAdviceFail         = 1016
63
+	ErrorCodeDoctorAdviceNotExist           = 1017
64
+	ErrorCodeUpdateDoctorAdviceFail         = 1018
65
+	ErrorCodeLongTimeAdviceNotCanntEdit     = 1019
66
+	ErrorCodeAdviceStoped                   = 1020
67
+	ErrorCodeParentAdviceNotExist           = 1021
68
+	ErrorCodeStopAdviceFail                 = 1022
69
+	ErrorCodeDeleteAdviceFail               = 1023
70
+	ErrorCodeDialysisSolutionDelete         = 1024
71
+	ErrorCodeDeviceNumberNotTheZone         = 1025
72
+	ErrorCodeCreateScheduleFail             = 1026
73
+	ErrorCodeCantSetScheduleAgainOneDay     = 1027
74
+	ErrorCodeCantSetScheduleBeforeNow       = 1028
75
+	ErrorCodeScheduleNotExist               = 1029
76
+	ErrorCodeDeleteScheduleFail             = 1030
77
+	ErrorCodeChangeScheduleFail             = 1031
78
+	ErrorCodePatientPhoneUsed               = 1032
79
+	ErrorCodeAdviceExced                    = 1033
80
+	ErrorCodeAdviceChecked                  = 1034
81
+	ErrorCodePointScheduleExist             = 1035
82
+	ErrorCodeExceAndCheckNotOneUser         = 1036
83
+	ErrorCodeCanotEditOtherAdvice           = 1037
84
+	ErrorCodeEditLapsetoFail                = 1038
85
+	ErrorCodeAdviceCheckBeforeExce          = 1039
86
+	ErrorCodeAdviceExceBeforeStart          = 1040
87
+	ErrorCodeDelScheduleFailByDialysis      = 1041
88
+	ErrorCodeNotSelectLapsetoType           = 1042
89
+	ErrorCodeNotSelectLapsetoTime           = 1043
90
+
91
+	ErrorCodeInspectionDateExit    = 1201
92
+	ErrorCodeInspectionAddFail     = 1202
93
+	ErrorCodeInspectionEditFail    = 1204
94
+	ErrorCodeInspectionDateNotExit = 1203
95
+	ErrorCodeInspectionDeleteFail  = 1205
96
+
97
+	ErrorCodeMonitorCreate                  = 1128
98
+	ErrorCodeMonitorNotExist                = 1129
99
+	ErrorCodeMonitorUpdate                  = 1130
100
+	ErrorDialysisOrderNoStart               = 1132
101
+	ErrorDialysisOrderNoEND                 = 1133
102
+	ErrorDialysisOrderRepeatStart           = 1134
103
+	ErrorCodeDialysisPermissionDeniedModify = 1135
104
+
105
+	ErrorCodeNotSubscibe       = 4003
106
+	ErrorCodeServeNotExist     = 4004
107
+	ErrorCodeInvoiceExist      = 4005
108
+	ErrorCodeApplyInvoiceFail  = 4006
109
+	ErrorCodeHetongHad         = 4007
110
+	ErrorCodeCreateHetongFail  = 4008
111
+	ErrorCodePatientReachLimit = 4009
112
+
113
+	ErrorCodeDeviceZoneNotExist                      = 9021
114
+	ErrorCodeDeviceZoneNameRepeat                    = 9022
115
+	ErrorCodeDeviceGroupNotExist                     = 9023
116
+	ErrorCodeDeviceGroupNameRepeat                   = 9024
117
+	ErrorCodeDeviceNumberNotExist                    = 9025
118
+	ErrorCodeDeviceNumberRepeat                      = 9026
119
+	ErrorCodeDeviceNotExist                          = 9027
120
+	ErrorCodeDeviceZoneCannotDisable                 = 9028
121
+	ErrorCodeDeviceNumberCannotDisableCuzDevice      = 9029
122
+	ErrorCodeDeviceNumberCannotDisableCuzSchedule    = 9030
123
+	ErrorCodeDeviceNumberCannotDisableCuzSchTemplate = 9031
124
+
125
+	ErrorCommitFail = 90000
126
+
127
+	ErrorCodeCreateStockInFail = 20001
128
+
129
+	ErrorCodeScheduleTemplateNotExist = 10001
130
+
131
+	ErrorCodeSystemError  = 6666
132
+	ErrorCodeProductError = 6667
133
+	ErrorCodeFieldExist   = 100001
134
+	ErrorCodeCreateConfig = 100002
135
+	ErrorCodeUpdateConfig = 100003
136
+
137
+	ErrorCodeDoubleCheckWrong     = 200003
138
+	ErrorCodeDoubleCheckUserWrong = 200004
139
+	ErrorCodeGoodNoStockInError   = 200005
140
+	ErrorCodeCancelStockFail      = 200006
141
+	ErrorCodeDeleteGoodTypeFail   = 200007
142
+	ErrorCodeDeleteGoodInfoFail   = 200008
143
+	ErrorCodeDeleteFail           = 200009
144
+
145
+	ErrorCodeKeyFail                 = 200010
146
+	ErrorCodeDeleteStockInRecordFail = 200011
147
+	ErrorCodeNameWrong               = 200012
148
+
149
+	ErrorCodeParamEmptyWrong       = 200013
150
+	ErrorCodeParamAdviceEmptyWrong = 200014
151
+
152
+	ErrorCodeParamTemplateNOEXISTWrong = 200015
153
+
154
+	ErrorCodeDeleteDealerWrong       = 200016
155
+	ErrorCodeDeleteManufacturerWrong = 200017
156
+	ErrorCodeGoodTypeNameExistError  = 200018
157
+	ErrorCodeGoodInfoNameExistError  = 200019
158
+
159
+	ErrorCodePrescriptionPermissionDeniedModify = 200020
160
+
161
+	ErrorCodeAdvicePermissionDeniedModify = 200021
162
+	ErrorCodePrescriptionException        = 200022
163
+
164
+	ErrorCodeNameException = 200023
165
+)
166
+
167
+var ErrCodeMsgs = map[int]string{
168
+	// 登录注册错误
169
+	ErrorCodeLoginTimeout:                   "登录超时",
170
+	ErrorCodeNotLogin:                       "未登录",
171
+	ErrorCodePermissionDenied:               "权限不足",
172
+	ErrorCodeMobileRegistered:               "手机号已被注册",
173
+	ErrorCodePasswordEmpty:                  "密码为空",
174
+	ErrorCodeVerificationCodeWrong:          "验证码错误",
175
+	ErrorCodeRegisterFail:                   "注册失败",
176
+	ErrorCodeInvalidToken:                   "令牌无效",
177
+	ErrorCodeAccountOrPasswordWrong:         "账号或密码错误",
178
+	ErrorCodeMissingOrg:                     "未创建机构",
179
+	ErrorCodeMissingOrgApp:                  "未创建任何应用",
180
+	ErrorCodeAccountOrVerCodeWrong:          "账号或验证码错误",
181
+	ErrorCodeMobileNotExit:                  "手机号不存在",
182
+	ErrorCodeUserNotExist:                   "用户不存在",
183
+	ErrorCodeUserWasForbidden:               "该用户被禁用",
184
+	ErrorCodeNeverCreateTypeApp:             "未创建此种应用",
185
+	ErrorCodeContactSuperAdminCreateTypeApp: "请联系超级管理员开通此种应用",
186
+
187
+	// 数据验证错误
188
+	ErrorCodeMobileFormat:     "手机号格式错误",
189
+	ErrorCodeTelphoneFormat:   "电话格式错误",
190
+	ErrorCodeParamWrong:       "参数错误",
191
+	ErrorCodeParamFormatWrong: "参数格式错误",
192
+
193
+	// 数据库操作错误
194
+	ErrorCodeDBCreate:         "数据库创建出错",
195
+	ErrorCodeDBUpdate:         "数据库更新出错",
196
+	ErrorCodeDBDelete:         "数据库删除出错",
197
+	ErrorCodeDBSelectNoResult: "查询无结果",
198
+	ErrorCodeDataException:    "数据异常",
199
+
200
+	// 业务逻辑操作错误
201
+	ErrorCodeRoleNotExist:           "角色不存在",
202
+	ErrorCodeAdminUserNotExist:      "管理员不存在",
203
+	ErrorCodeMobileDidUsedInApp:     "该手机号已在该应用中被注册为管理员",
204
+	ErrorCodeMissingUserName:        "缺少用户名",
205
+	ErrorCodeOldPasswordWrong:       "原密码不正确",
206
+	ErrorCodeCannotRemoveRole:       "存在该角色的管理员,不能删除该角色",
207
+	ErrorCodeRoleMobileIsSuperAdmin: "该手机号已注册为超级管理员",
208
+
209
+	ErrorCodeGetQiniuUpToken: "获取七牛uptoken失败",
210
+	ErrorCodeCreatePatient:   "创建患者失败",
211
+	ErrorCodeDialysisNoExist: "患者透析号重复!",
212
+	ErrorCodeIdCardNoExist:   "身份证号重复!",
213
+	ErrorCodePatientNoExist:  "患者信息不存在!",
214
+	ErrorCodeUpdatePatient:   "修改患者信息失败",
215
+
216
+	ErrorCodeDialysisSolutionExist:          "该处方已经存在",
217
+	ErrorCodeDialysisSolutionCreate:         "创建处方失败",
218
+	ErrorCodeDialysisSolutionUpdate:         "修改处方失败",
219
+	ErrorCodeDialysisSolutionNotExist:       "该处方不存在",
220
+	ErrorCodeParentDialysisSolutionNotExist: "上级处方不存在",
221
+	ErrorCodeAlReadyHadChildSolution:        "所选处方已经存在子方案",
222
+	ErrorCodeCanntCreateChildChildSolution:  "子方案不能添加子方案",
223
+	ErrorCodeDialysisSolutionUsed:           "处方已被使用,不能删除",
224
+	ErrorCodeCreateDryWeightFail:            "添加干体重失败",
225
+	ErrorCodeCreateDoctorAdviceFail:         "添加医嘱失败",
226
+	ErrorCodeUpdateDoctorAdviceFail:         "修改医嘱信息失败",
227
+	ErrorCodeDoctorAdviceNotExist:           "医嘱不存在",
228
+	ErrorCodeLongTimeAdviceNotCanntEdit:     "长期医嘱不能修改!",
229
+	ErrorCodeAdviceStoped:                   "所选医嘱已停止",
230
+	ErrorCodeParentAdviceNotExist:           "上级医嘱不存在",
231
+	ErrorCodeDeleteAdviceFail:               "删除医嘱失败",
232
+	ErrorCodeStopAdviceFail:                 "停止医嘱失败",
233
+	ErrorCodeDialysisSolutionDelete:         "删除方案失败",
234
+	ErrorCodeDeviceNumberNotTheZone:         "所选机号不在选择分区中",
235
+	ErrorCodeCreateScheduleFail:             "添加排班失败",
236
+	ErrorCodeCantSetScheduleAgainOneDay:     "同一天不可有两次排班",
237
+	ErrorCodeCantSetScheduleBeforeNow:       "不能给今天之前的日期排班",
238
+	ErrorCodeScheduleNotExist:               "排班不存在",
239
+	ErrorCodePointScheduleExist:             "所先位置排班已经存在",
240
+	ErrorCodeDeleteScheduleFail:             "取消排班失败",
241
+	ErrorCodeChangeScheduleFail:             "修改排班失败",
242
+	ErrorCodePatientPhoneUsed:               "手机号已经存在",
243
+	ErrorCodeAdviceExced:                    "医嘱已经执行",
244
+	ErrorCodeAdviceCheckBeforeExce:          "核对医嘱不能在执行医嘱之前",
245
+	ErrorCodeAdviceExceBeforeStart:          "执行医嘱不能在开始之前",
246
+	ErrorCodeAdviceChecked:                  "医嘱已经核对",
247
+	ErrorCodeExceAndCheckNotOneUser:         "核对与执行不能是同一人",
248
+	ErrorCodeCanotEditOtherAdvice:           "不能修改非本人添加的医嘱",
249
+	ErrorCodeEditLapsetoFail:                "转归失败",
250
+	ErrorCodeDelScheduleFailByDialysis:      "已经上机透析,不能取消排班",
251
+	ErrorCodeNotSelectLapsetoType:           "请选择转归状态",
252
+	ErrorCodeNotSelectLapsetoTime:           "请选择转归时间",
253
+
254
+	ErrorCodeInspectionDateExit:    "当天已经存在检验检查记录",
255
+	ErrorCodeInspectionAddFail:     "添加记录失败",
256
+	ErrorCodeInspectionDateNotExit: "当天不存在检验检查记录",
257
+	ErrorCodeInspectionEditFail:    "修改记录失败",
258
+	ErrorCodeInspectionDeleteFail:  "删除记录失败",
259
+
260
+	ErrorCodeDeviceZoneNotExist:                      "设备分区不存在",
261
+	ErrorCodeDeviceZoneNameRepeat:                    "该分区名已存在",
262
+	ErrorCodeDeviceGroupNotExist:                     "设备分组不存在",
263
+	ErrorCodeDeviceGroupNameRepeat:                   "该分组名已存在",
264
+	ErrorCodeDeviceNumberNotExist:                    "机号不存在",
265
+	ErrorCodeDeviceNumberRepeat:                      "该机号已存在",
266
+	ErrorCodeDeviceNotExist:                          "该设备不存在",
267
+	ErrorCodeDeviceZoneCannotDisable:                 "该分区存在床位号,不能删除",
268
+	ErrorCodeDeviceNumberCannotDisableCuzDevice:      "该床位存在设备,不能删除",
269
+	ErrorCodeDeviceNumberCannotDisableCuzSchedule:    "该床位尚有排班安排,不能删除",
270
+	ErrorCodeDeviceNumberCannotDisableCuzSchTemplate: "排班模板在该床位尚有排班安排,不能删除",
271
+
272
+	ErrorCodeNotSubscibe:       "没有订阅服务或服务已过期,请先购买服务!",
273
+	ErrorCodeServeNotExist:     "服务订单不存在!",
274
+	ErrorCodeInvoiceExist:      "已经申请了发票!",
275
+	ErrorCodeApplyInvoiceFail:  "申请发票失败!",
276
+	ErrorCodeHetongHad:         "合同已经存在!",
277
+	ErrorCodeCreateHetongFail:  "合同创建失败",
278
+	ErrorCodePatientReachLimit: "患者数已达到当前服务版本病人数,需要升级到更高的版本",
279
+
280
+	ErrorCodeMonitorCreate:                  "创建监测失败",
281
+	ErrorCodeMonitorNotExist:                "监测记录不存在",
282
+	ErrorCodeMonitorUpdate:                  "修改监测失败",
283
+	ErrorCodeDialysisPermissionDeniedModify: "您没有权限修改其他医护的数据!",
284
+
285
+	ErrorDialysisOrderNoStart:     "尚未上机,无法执行下机操作",
286
+	ErrorDialysisOrderNoEND:       "已处于下机状态",
287
+	ErrorDialysisOrderRepeatStart: "已上机",
288
+	//ErrorCodeScheduleTemplateNotExist: "排班模板不存在",
289
+
290
+	ErrorCodeSystemError:              "系统异常",
291
+	ErrorCodeProductError:             "该服务商品已丢失",
292
+	ErrorCodeScheduleTemplateNotExist: "排班模板不存在",
293
+
294
+	ErrorCodeCreateStockInFail: "入库失败",
295
+	//ErrorCodeSystemError:  "系统异常",
296
+	//ErrorCodeProductError: "该服务商品已丢失",
297
+	ErrorCodeFieldExist:   "配置字段已存在",
298
+	ErrorCodeCreateConfig: "创建配置失败",
299
+	ErrorCodeUpdateConfig: "修改配置失败",
300
+
301
+	ErrorCommitFail:               "提交失败",
302
+	ErrorCodeDoubleCheckWrong:     "核对已完成, 无法再次提交",
303
+	ErrorCodeDoubleCheckUserWrong: "你已完成核对,不能重复核对",
304
+	ErrorCodeGoodNoStockInError:   "该商品尚未入库",
305
+
306
+	ErrorCodeCancelStockFail:    "出库退库失败",
307
+	ErrorCodeDeleteGoodTypeFail: "该类型存在商品信息,无法删除",
308
+	ErrorCodeDeleteGoodInfoFail: "该商品已经入库无法删除",
309
+
310
+	ErrorCodeDeleteFail: "删除失败",
311
+
312
+	ErrorCodeKeyFail:                 "关键字不能为空",
313
+	ErrorCodeDeleteStockInRecordFail: "该记录已经有出库或退货操作,无法删除",
314
+	ErrorCodeNameWrong:               "该模版名字已存在",
315
+	ErrorCodeParamEmptyWrong:         "模版名称不能为空",
316
+	ErrorCodeParamAdviceEmptyWrong:   "医嘱名称不能为空",
317
+
318
+	ErrorCodeDeleteDealerWrong:       "该经销商所属商品已入库无法删除",
319
+	ErrorCodeDeleteManufacturerWrong: "该厂商所属商品已入库无法删除",
320
+	ErrorCodeGoodTypeNameExistError:  "该商品类型名字已存在",
321
+	ErrorCodeGoodInfoNameExistError:  "该规格名称名字已存在",
322
+
323
+	ErrorCodePrescriptionPermissionDeniedModify: "您没有权限修改透析处方数据",
324
+	ErrorCodeAdvicePermissionDeniedModify:       "您没有权限添加医嘱",
325
+	ErrorCodePrescriptionException:              "上机失败,请先开处方",
326
+
327
+	ErrorCodeNameException: "账号已经存在",
328
+}
329
+
330
+type SGJError struct {
331
+	Code int
332
+}
333
+
334
+func (e *SGJError) Error() string {
335
+	value, ok := ErrCodeMsgs[e.Code]
336
+	if ok {
337
+		return value
338
+	} else {
339
+		return "未知错误"
340
+	}
341
+}
342
+
343
+func MakeSuccessResponseJSON(data map[string]interface{}) map[string]interface{} {
344
+	json := make(map[string]interface{})
345
+	if data != nil {
346
+		json["data"] = data
347
+	} else {
348
+		json["data"] = make(map[string]interface{})
349
+	}
350
+	json["state"] = 1
351
+	json["code"] = 0
352
+	return json
353
+}
354
+
355
+func MakeFailResponseJSON(errMsg string, errCode int) map[string]interface{} {
356
+	json := make(map[string]interface{})
357
+	json["msg"] = errMsg
358
+	json["code"] = errCode
359
+	json["state"] = 0
360
+	return json
361
+}
362
+
363
+func MakeFailResponseJSONWithSGJError(err *SGJError) map[string]interface{} {
364
+	if err == nil {
365
+		utils.WarningLog("MakeFailResponseJSONWithSGJError 参数err 不能为空")
366
+		return nil
367
+	}
368
+	return MakeFailResponseJSON(err.Error(), err.Code)
369
+}
370
+
371
+func MakeFailResponseJSONWithSGJErrorCode(code int) map[string]interface{} {
372
+	err := &SGJError{Code: code}
373
+	return MakeFailResponseJSON(err.Error(), err.Code)
374
+}

+ 18 - 0
main.go Zobrazit soubor

@@ -0,0 +1,18 @@
1
+package main
2
+
3
+import (
4
+	_ "Data_Upload_Api/routers"
5
+	"Data_Upload_Api/service"
6
+	"Data_Upload_Api/service/city"
7
+
8
+	"github.com/astaxie/beego"
9
+)
10
+
11
+func init() {
12
+	service.ConnectDB()
13
+}
14
+
15
+func main() {
16
+	city.AutoSZUploadData()
17
+	beego.Run()
18
+}

+ 655 - 0
models/src_data.go Zobrazit soubor

@@ -0,0 +1,655 @@
1
+package models
2
+
3
+type UserOrg struct {
4
+	ID              int64           `gorm:"column:id" json:"id"`
5
+	Creator         int64           `gorm:"column:creator" json:"creator"`
6
+	OrgName         string          `gorm:"column:org_name" json:"org_name"`
7
+	OrgShortName    string          `gorm:"column:org_short_name" json:"org_short_name"`
8
+	OrgLogo         string          `gorm:"column:org_logo" json:"org_logo"`
9
+	OrgIntroduction string          `gorm:"column:org_introduction" json:"org_introduction"`
10
+	Illness         string          `gorm:"column:illness" json:"illness"`
11
+	Province        int64           `gorm:"column:province" json:"province"`
12
+	City            int64           `gorm:"column:city" json:"city"`
13
+	District        int64           `gorm:"column:district" json:"district"`
14
+	Address         string          `gorm:"column:address" json:"address"`
15
+	Longitude       string          `gorm:"column:longitude" json:"longitude"`
16
+	Latitude        string          `gorm:"column:latitude" json:"latitude"`
17
+	OrgType         int64           `gorm:"column:org_type" json:"org_type"`
18
+	Comments        int64           `gorm:"column:comments" json:"comments"`
19
+	Evaluate        float64         `gorm:"column:evaluate" json:"evaluate"`
20
+	Gallery         string          `gorm:"column:gallery" json:"gallery"`
21
+	BusinessWeek    string          `gorm:"column:business_week" json:"business_week"`
22
+	BusinessTime    string          `gorm:"column:business_time" json:"business_time"`
23
+	ContactName     string          `gorm:"column:contact_name" json:"contact_name"`
24
+	Telephone       string          `gorm:"column:telephone" json:"telephone"`
25
+	Claim           int64           `gorm:"column:claim" json:"claim"`
26
+	OperatingState  int64           `gorm:"column:operating_state" json:"operating_state"`
27
+	Status          int64           `gorm:"column:status" json:"status"`
28
+	Ctime           int64           `gorm:"column:ctime" json:"ctime"`
29
+	Mtime           int64           `gorm:"column:mtime" json:"mtime"`
30
+	Source          int64           `gorm:"column:source" json:"source"`
31
+	Ttype           int64           `gorm:"column:ttype" json:"ttype"`
32
+	Ttid            int64           `gorm:"column:ttid" json:"ttid"`
33
+	Tuid            int64           `gorm:"column:tuid" json:"tuid"`
34
+	Reason          string          `gorm:"column:reason" json:"reason"`
35
+	Level           int64           `gorm:"column:level" json:"level"`
36
+	Website         string          `gorm:"column:website" json:"website"`
37
+	Import          int64           `gorm:"column:import" json:"import"`
38
+	Sortno          int64           `gorm:"column:sortno" json:"sortno"`
39
+	DeviceNumber    []*DeviceNumber `gorm:"ForeignKey:OrgId;AssociationForeignKey:ID" json:"device_number"`
40
+}
41
+
42
+func (UserOrg) TableName() string {
43
+	return "sgj_user_org"
44
+}
45
+
46
+type UserAdminRole struct {
47
+	ID          int64  `gorm:"column:id" json:"id"`
48
+	AdminUserId int64  `gorm:"column:admin_user_id" json:"admin_user_id"`
49
+	OrgId       int64  `gorm:"column:org_id" json:"org_id"`
50
+	AppId       int64  `gorm:"column:app_id" json:"app_id"`
51
+	RoleId      int64  `gorm:"column:role_id" json:"role_id"`
52
+	UserName    string `gorm:"column:user_name" json:"user_name"`
53
+	Avatar      string `gorm:"column:avatar" json:"avatar"`
54
+	UserType    int64  `gorm:"column:user_type" json:"user_type"`
55
+	UserTitle   int64  `gorm:"column:user_title" json:"user_title"`
56
+	Intro       string `gorm:"column:intro" json:"intro"`
57
+	Status      int64  `gorm:"column:status" json:"status"`
58
+	Ctime       int64  `gorm:"column:ctime" json:"ctime"`
59
+	Mtime       int64  `gorm:"column:mtime" json:"mtime"`
60
+}
61
+
62
+func (UserAdminRole) TableName() string {
63
+	return "sgj_user_admin_role"
64
+}
65
+
66
+type Patients struct {
67
+	ID                           int64             `gorm:"column:id" json:"id"`
68
+	UserOrgId                    int64             `gorm:"column:user_org_id" json:"user_org_id"`
69
+	UserId                       int64             `gorm:"column:user_id" json:"user_id"`
70
+	Avatar                       string            `gorm:"column:avatar" json:"avatar"`
71
+	PatientType                  int64             `gorm:"column:patient_type" json:"patient_type"`
72
+	DialysisNo                   string            `gorm:"column:dialysis_no" json:"dialysis_no"`
73
+	AdmissionNumber              string            `gorm:"column:admission_number" json:"admission_number"`
74
+	Source                       int64             `gorm:"column:source" json:"source"`
75
+	Lapseto                      int64             `gorm:"column:lapseto" json:"lapseto"`
76
+	PartitionId                  int64             `gorm:"column:partition_id" json:"partition_id"`
77
+	BedId                        int64             `gorm:"column:bed_id" json:"bed_id"`
78
+	Name                         string            `gorm:"column:name" json:"name"`
79
+	Alias                        string            `gorm:"column:alias" json:"alias"`
80
+	Gender                       int64             `gorm:"column:gender" json:"gender"`
81
+	MaritalStatus                int64             `gorm:"column:marital_status" json:"marital_status"`
82
+	IdCardNo                     string            `gorm:"column:id_card_no" json:"id_card_no"`
83
+	Birthday                     int64             `gorm:"column:birthday" json:"birthday"`
84
+	ReimbursementWayId           int64             `gorm:"column:reimbursement_way_id" json:"reimbursement_way_id"`
85
+	HealthCareType               int64             `gorm:"column:health_care_type" json:"health_care_type"`
86
+	HealthCareNo                 string            `gorm:"column:health_care_no" json:"health_care_no"`
87
+	HealthCareDueDate            int64             `gorm:"column:health_care_due_date" json:"health_care_due_date"`
88
+	Height                       int64             `gorm:"column:height" json:"height"`
89
+	BloodType                    int64             `gorm:"column:blood_type" json:"blood_type"`
90
+	Rh                           int64             `gorm:"column:rh" json:"rh"`
91
+	HealthCareDueAlertDate       int64             `gorm:"column:health_care_due_alert_date" json:"health_care_due_alert_date"`
92
+	EducationLevel               int64             `gorm:"column:education_level" json:"education_level"`
93
+	Profession                   int64             `gorm:"column:profession" json:"profession"`
94
+	Phone                        string            `gorm:"column:phone" json:"phone"`
95
+	HomeTelephone                string            `gorm:"column:home_telephone" json:"home_telephone"`
96
+	RelativePhone                string            `gorm:"column:relative_phone" json:"relative_phone"`
97
+	RelativeRelations            string            `gorm:"column:relative_relations" json:"relative_relations"`
98
+	HomeAddress                  string            `gorm:"column:home_address" json:"home_address"`
99
+	WorkUnit                     string            `gorm:"column:work_unit" json:"work_unit"`
100
+	UnitAddress                  string            `gorm:"column:unit_address" json:"unit_address"`
101
+	Children                     int64             `gorm:"column:children" json:"children"`
102
+	ReceivingDate                int64             `gorm:"column:receiving_date" json:"receiving_date"`
103
+	IsHospitalFirstDialysis      int64             `gorm:"column:is_hospital_first_dialysis" json:"is_hospital_first_dialysis"`
104
+	FirstDialysisDate            int64             `gorm:"column:first_dialysis_date" json:"first_dialysis_date"`
105
+	FirstDialysisHospital        string            `gorm:"column:first_dialysis_hospital" json:"first_dialysis_hospital"`
106
+	PredialysisCondition         string            `gorm:"column:predialysis_condition" json:"predialysis_condition"`
107
+	PreHospitalDialysisFrequency string            `gorm:"column:pre_hospital_dialysis_frequency" json:"pre_hospital_dialysis_frequency"`
108
+	PreHospitalDialysisTimes     int64             `gorm:"column:pre_hospital_dialysis_times" json:"pre_hospital_dialysis_times"`
109
+	HospitalFirstDialysisDate    int64             `gorm:"column:hospital_first_dialysis_date" json:"hospital_first_dialysis_date"`
110
+	InductionPeriod              int64             `gorm:"column:induction_period" json:"induction_period"`
111
+	InitialDialysis              int64             `gorm:"column:initial_dialysis" json:"initial_dialysis"`
112
+	TotalDialysis                int64             `gorm:"column:total_dialysis" json:"total_dialysis"`
113
+	AttendingDoctorId            int64             `gorm:"column:attending_doctor_id" json:"attending_doctor_id"`
114
+	HeadNurseId                  int64             `gorm:"column:head_nurse_id" json:"head_nurse_id"`
115
+	Evaluate                     string            `gorm:"column:evaluate" json:"evaluate"`
116
+	Diagnose                     string            `gorm:"column:diagnose" json:"diagnose"`
117
+	Remark                       string            `gorm:"column:remark" json:"remark"`
118
+	RegistrarsId                 int64             `gorm:"column:registrars_id" json:"registrars_id"`
119
+	Registrars                   string            `gorm:"column:registrars" json:"registrars"`
120
+	QrCode                       string            `gorm:"column:qr_code" json:"qr_code"`
121
+	BindingState                 int64             `gorm:"column:binding_state" json:"binding_state"`
122
+	PatientComplains             string            `gorm:"column:patient_complains" json:"patient_complains"`
123
+	PresentHistory               string            `gorm:"column:present_history" json:"present_history"`
124
+	PastHistory                  string            `gorm:"column:past_history" json:"past_history"`
125
+	Temperature                  float64           `gorm:"column:temperature" json:"temperature"`
126
+	Pulse                        int64             `gorm:"column:pulse" json:"pulse"`
127
+	Respiratory                  int64             `gorm:"column:respiratory" json:"respiratory"`
128
+	Sbp                          int64             `gorm:"column:sbp" json:"sbp"`
129
+	Dbp                          int64             `gorm:"column:dbp" json:"dbp"`
130
+	Status                       int64             `gorm:"column:status" json:"status"`
131
+	CreatedTime                  int64             `gorm:"column:created_time" json:"created_time"`
132
+	UpdatedTime                  int64             `gorm:"column:updated_time" json:"updated_time"`
133
+	Nation                       string            `gorm:"column:nation" json:"nation"`
134
+	NativePlace                  string            `gorm:"column:native_place" json:"native_place"`
135
+	Age                          int64             `gorm:"column:age" json:"age"`
136
+	PatientLapseto               []*PatientLapseto `gorm:"ForeignKey:PatientId,LapsetoType;AssociationForeignKey:ID,Lapseto" json:"lapseto"`
137
+}
138
+
139
+func (Patients) TableName() string {
140
+	return "xt_patients"
141
+}
142
+
143
+type Device struct {
144
+	ID             int64  `gorm:"column:id" json:"id"`
145
+	OrgId          int64  `gorm:"column:org_id" json:"org_id"`
146
+	DeviceType     int64  `gorm:"column:device_type" json:"device_type"`
147
+	DmId           int64  `gorm:"column:dm_id" json:"dm_id"`
148
+	WteId          int64  `gorm:"column:wte_id" json:"wte_id"`
149
+	SerialNumber   string `gorm:"column:serial_number" json:"serial_number"`
150
+	Name           string `gorm:"column:name" json:"name"`
151
+	Model          string `gorm:"column:model" json:"model"`
152
+	DeviceNumberId int64  `gorm:"column:device_number_id" json:"device_number_id"`
153
+	DeviceNumber   string `gorm:"column:device_number" json:"device_number"`
154
+	DeviceZoneId   int64  `gorm:"column:device_zone_id" json:"device_zone_id"`
155
+	DeviceGroupId  int64  `gorm:"column:device_group_id" json:"device_group_id"`
156
+	Status         int64  `gorm:"column:status" json:"status"`
157
+	Ctime          int64  `gorm:"column:ctime" json:"ctime"`
158
+	Mtime          int64  `gorm:"column:mtime" json:"mtime"`
159
+}
160
+
161
+func (Device) TableName() string {
162
+	return "xt_device"
163
+}
164
+
165
+type DeviceNumber struct {
166
+	ID      int64  `gorm:"column:id" json:"id"`
167
+	OrgId   int64  `gorm:"column:org_id" json:"org_id"`
168
+	Number  string `gorm:"column:number" json:"number"`
169
+	GroupId int64  `gorm:"column:group_id" json:"group_id"`
170
+	ZoneId  int64  `gorm:"column:zone_id" json:"zone_id"`
171
+	Status  int64  `gorm:"column:status" json:"status"`
172
+	Ctime   int64  `gorm:"column:ctime" json:"ctime"`
173
+	Mtime   int64  `gorm:"column:mtime" json:"mtime"`
174
+}
175
+
176
+func (DeviceNumber) TableName() string {
177
+	return "xt_device_number"
178
+}
179
+
180
+type DeviceZone struct {
181
+	ID     int64  `gorm:"column:id" json:"id"`
182
+	OrgId  int64  `gorm:"column:org_id" json:"org_id"`
183
+	Name   string `gorm:"column:name" json:"name"`
184
+	Type   int64  `gorm:"column:type" json:"type"`
185
+	Status int64  `gorm:"column:status" json:"status"`
186
+	Ctime  int64  `gorm:"column:ctime" json:"ctime"`
187
+	Mtime  int64  `gorm:"column:mtime" json:"mtime"`
188
+}
189
+
190
+func (DeviceZone) TableName() string {
191
+	return "xt_device_zone"
192
+}
193
+
194
+type Schedule struct {
195
+	ID           int64        `gorm:"column:id" json:"id"`
196
+	UserOrgId    int64        `gorm:"column:user_org_id" json:"user_org_id"`
197
+	PartitionId  int64        `gorm:"column:partition_id" json:"partition_id"`
198
+	BedId        int64        `gorm:"column:bed_id" json:"bed_id"`
199
+	PatientId    int64        `gorm:"column:patient_id" json:"patient_id"`
200
+	ScheduleDate int64        `gorm:"column:schedule_date" json:"schedule_date"`
201
+	ScheduleType int64        `gorm:"column:schedule_type" json:"schedule_type"`
202
+	ScheduleWeek int64        `gorm:"column:schedule_week" json:"schedule_week"`
203
+	ModeId       int64        `gorm:"column:mode_id" json:"mode_id"`
204
+	Status       int64        `gorm:"column:status" json:"status"`
205
+	CreatedTime  int64        `gorm:"column:created_time" json:"created_time"`
206
+	UpdatedTime  int64        `gorm:"column:updated_time" json:"updated_time"`
207
+	DeviceNumber DeviceNumber `gorm:"ForeignKey:ID;AssociationForeignKey:BedId" json:"device"`
208
+}
209
+
210
+func (Schedule) TableName() string {
211
+	return "xt_schedule"
212
+}
213
+
214
+type DialysisPrescription struct {
215
+	ID                         int64                    `gorm:"column:id" json:"id"`
216
+	UserOrgId                  int64                    `gorm:"column:user_org_id" json:"user_org_id"`
217
+	PatientId                  int64                    `gorm:"column:patient_id" json:"patient_id"`
218
+	Dialyzer                   int64                    `gorm:"column:dialyzer" json:"dialyzer"`
219
+	MachineType                string                   `gorm:"column:machine_type" json:"machine_type"`
220
+	DewaterAmount              float64                  `gorm:"column:dewater_amount" json:"dewater_amount"`
221
+	DialyzerPerfusionApparatus string                   `gorm:"column:dialyzer_perfusion_apparatus" json:"dialyzer_perfusion_apparatus"`
222
+	PrescriptionDewatering     float64                  `gorm:"column:prescription_dewatering" json:"prescription_dewatering"`
223
+	Anticoagulant              int64                    `gorm:"column:anticoagulant" json:"anticoagulant"`
224
+	AnticoagulantShouji        float64                  `gorm:"column:anticoagulant_shouji" json:"anticoagulant_shouji"`
225
+	AnticoagulantWeichi        float64                  `gorm:"column:anticoagulant_weichi" json:"anticoagulant_weichi"`
226
+	AnticoagulantZongliang     float64                  `gorm:"column:anticoagulant_zongliang" json:"anticoagulant_zongliang"`
227
+	AnticoagulantGaimingcheng  string                   `gorm:"column:anticoagulant_gaimingcheng" json:"anticoagulant_gaimingcheng"`
228
+	AnticoagulantGaijiliang    string                   `gorm:"column:anticoagulant_gaijiliang" json:"anticoagulant_gaijiliang"`
229
+	ModeId                     int64                    `gorm:"column:mode_id" json:"mode_id"`
230
+	DialysisDurationHour       int64                    `gorm:"column:dialysis_duration_hour" json:"dialysis_duration_hour"`
231
+	DialysisDurationMinute     int64                    `gorm:"column:dialysis_duration_minute" json:"dialysis_duration_minute"`
232
+	DialysisDuration           float64                  `gorm:"column:dialysis_duration" json:"dialysis_duration"`
233
+	ReplacementTotal           float64                  `gorm:"column:replacement_total" json:"replacement_total"`
234
+	ReplacementWay             int64                    `gorm:"column:replacement_way" json:"replacement_way"`
235
+	HemodialysisMachine        int64                    `gorm:"column:hemodialysis_machine" json:"hemodialysis_machine"`
236
+	BloodFilter                int64                    `gorm:"column:blood_filter" json:"blood_filter"`
237
+	PerfusionApparatus         int64                    `gorm:"column:perfusion_apparatus" json:"perfusion_apparatus"`
238
+	DryWeight                  float64                  `gorm:"column:dry_weight" json:"dry_weight"`
239
+	VascularAccessMode         int64                    `gorm:"column:vascular_access_mode" json:"vascular_access_mode"`
240
+	VascularAccess             int64                    `gorm:"column:vascular_access" json:"vascular_access"`
241
+	BloodFlowVolume            float64                  `gorm:"column:blood_flow_volume" json:"blood_flow_volume"`
242
+	DialysateFlow              float64                  `gorm:"column:dialysate_flow" json:"dialysate_flow"`
243
+	DisplaceLiqui              float64                  `gorm:"column:displace_liqui" json:"displace_liqui"`
244
+	Kalium                     float64                  `gorm:"column:kalium" json:"kalium"`
245
+	Sodium                     float64                  `gorm:"column:sodium" json:"sodium"`
246
+	Calcium                    float64                  `gorm:"column:calcium" json:"calcium"`
247
+	Bicarbonate                float64                  `gorm:"column:bicarbonate" json:"bicarbonate"`
248
+	Glucose                    float64                  `gorm:"column:glucose" json:"glucose"`
249
+	DialysateTemperature       float64                  `gorm:"column:dialysate_temperature" json:"dialysate_temperature"`
250
+	Conductivity               float64                  `gorm:"column:conductivity" json:"conductivity"`
251
+	PrescriptionDoctor         int64                    `gorm:"column:prescription_doctor" json:"prescription_doctor"`
252
+	Creater                    int64                    `gorm:"column:creater" json:"creater"`
253
+	Modifier                   int64                    `gorm:"column:modifier" json:"modifier"`
254
+	Remark                     string                   `gorm:"column:remark" json:"remark"`
255
+	Status                     int64                    `gorm:"column:status" json:"status"`
256
+	CreatedTime                int64                    `gorm:"column:created_time" json:"created_time"`
257
+	UpdatedTime                int64                    `gorm:"column:updated_time" json:"updated_time"`
258
+	RecordDate                 int64                    `gorm:"column:record_date" json:"record_date"`
259
+	RecordId                   int64                    `gorm:"column:record_id" json:"record_id"`
260
+	TargetUltrafiltration      float64                  `gorm:"column:target_ultrafiltration" json:"target_ultrafiltration"`
261
+	DialysateFormulation       int64                    `gorm:"column:dialysate_formulation" json:"dialysate_formulation"`
262
+	BodyFluid                  int64                    `gorm:"column:body_fluid" json:"body_fluid"`
263
+	SpecialMedicine            int64                    `gorm:"column:special_medicine" json:"special_medicine"`
264
+	SpecialMedicineOther       string                   `gorm:"column:special_medicine_other" json:"special_medicine_other"`
265
+	DisplaceLiquiPart          int64                    `gorm:"column:displace_liqui_part" json:"displace_liqui_part"`
266
+	BloodAccess                int64                    `gorm:"column:blood_access" json:"blood_access"`
267
+	DisplaceLiquiValue         float64                  `gorm:"column:displace_liqui_value" json:"displace_liqui_value"`
268
+	Ultrafiltration            float64                  `gorm:"column:ultrafiltration" json:"ultrafiltration"`
269
+	BodyFluidOther             string                   `gorm:"column:body_fluid_other" json:"body_fluid_other"`
270
+	Niprocart                  int64                    `gorm:"column:niprocart" json:"niprocart"`
271
+	Jms                        int64                    `gorm:"column:jms" json:"jms"`
272
+	FistulaNeedleSet           int64                    `gorm:"column:fistula_needle_set" json:"fistula_needle_set"`
273
+	FistulaNeedleSet16         int64                    `gorm:"column:fistula_needle_set_16" json:"fistula_needle_set_16"`
274
+	Hemoperfusion              int64                    `gorm:"column:hemoperfusion" json:"hemoperfusion"`
275
+	DialyserSterilised         int64                    `gorm:"column:dialyser_sterilised" json:"dialyser_sterilised"`
276
+	Filtryzer                  int64                    `gorm:"column:filtryzer" json:"filtryzer"`
277
+	TargetKtv                  float64                  `gorm:"column:target_ktv" json:"target_ktv"`
278
+	Dialyzers                  int64                    `gorm:"column:dialyzers" json:"dialyzers"`
279
+	Injector                   int64                    `gorm:"column:injector" json:"injector"`
280
+	Bloodlines                 int64                    `gorm:"column:bloodlines" json:"bloodlines"`
281
+	TubingHemodialysis         int64                    `gorm:"column:tubing_hemodialysis" json:"tubing_hemodialysis"`
282
+	Package                    int64                    `gorm:"column:package" json:"package"`
283
+	ALiquid                    int64                    `gorm:"column:a_liquid" json:"a_liquid"`
284
+	AssessmentBeforeDislysis   AssessmentBeforeDislysis `gorm:"ForeignKey:PatientId,AssessmentDate;AssociationForeignKey:PatientId,RecordDate" json:"before"`
285
+	DialysisOrder              DialysisOrder            `gorm:"ForeignKey:PatientId,DialysisDate;AssociationForeignKey:PatientId,RecordDate" json:"order"`
286
+}
287
+
288
+func (DialysisPrescription) TableName() string {
289
+	return "xt_dialysis_prescription"
290
+}
291
+
292
+type DoctorAdvice struct {
293
+	ID                    int64   `gorm:"column:id" json:"id"`
294
+	UserOrgId             int64   `gorm:"column:user_org_id" json:"user_org_id"`
295
+	PatientId             int64   `gorm:"column:patient_id" json:"patient_id"`
296
+	AdviceType            int64   `gorm:"column:advice_type" json:"advice_type"`
297
+	AdviceDate            int64   `gorm:"column:advice_date" json:"advice_date"`
298
+	StartTime             int64   `gorm:"column:start_time" json:"start_time"`
299
+	AdviceName            string  `gorm:"column:advice_name" json:"advice_name"`
300
+	AdviceDesc            string  `gorm:"column:advice_desc" json:"advice_desc"`
301
+	ReminderDate          int64   `gorm:"column:reminder_date" json:"reminder_date"`
302
+	SingleDose            float64 `gorm:"column:single_dose" json:"single_dose"`
303
+	SingleDoseUnit        string  `gorm:"column:single_dose_unit" json:"single_dose_unit"`
304
+	PrescribingNumber     float64 `gorm:"column:prescribing_number" json:"prescribing_number"`
305
+	PrescribingNumberUnit string  `gorm:"column:prescribing_number_unit" json:"prescribing_number_unit"`
306
+	DeliveryWay           string  `gorm:"column:delivery_way" json:"delivery_way"`
307
+	ExecutionFrequency    string  `gorm:"column:execution_frequency" json:"execution_frequency"`
308
+	AdviceDoctor          int64   `gorm:"column:advice_doctor" json:"advice_doctor"`
309
+	Status                int64   `gorm:"column:status" json:"status"`
310
+	CreatedTime           int64   `gorm:"column:created_time" json:"created_time"`
311
+	UpdatedTime           int64   `gorm:"column:updated_time" json:"updated_time"`
312
+	AdviceAffirm          string  `gorm:"column:advice_affirm" json:"advice_affirm"`
313
+	Remark                string  `gorm:"column:remark" json:"remark"`
314
+	StopTime              int64   `gorm:"column:stop_time" json:"stop_time"`
315
+	StopReason            string  `gorm:"column:stop_reason" json:"stop_reason"`
316
+	StopDoctor            int64   `gorm:"column:stop_doctor" json:"stop_doctor"`
317
+	StopState             int64   `gorm:"column:stop_state" json:"stop_state"`
318
+	ParentId              int64   `gorm:"column:parent_id" json:"parent_id"`
319
+	ExecutionTime         int64   `gorm:"column:execution_time" json:"execution_time"`
320
+	ExecutionStaff        int64   `gorm:"column:execution_staff" json:"execution_staff"`
321
+	ExecutionState        int64   `gorm:"column:execution_state" json:"execution_state"`
322
+	Checker               int64   `gorm:"column:checker" json:"checker"`
323
+	RecordDate            int64   `gorm:"column:record_date" json:"record_date"`
324
+	DialysisOrderId       int64   `gorm:"column:dialysis_order_id" json:"dialysis_order_id"`
325
+	CheckTime             int64   `gorm:"column:check_time" json:"check_time"`
326
+	CheckState            int64   `gorm:"column:check_state" json:"check_state"`
327
+	DrugSpec              float64 `gorm:"column:drug_spec" json:"drug_spec"`
328
+	DrugSpecUnit          string  `gorm:"column:drug_spec_unit" json:"drug_spec_unit"`
329
+	Groupno               int64   `gorm:"column:groupno" json:"groupno"`
330
+}
331
+
332
+func (DoctorAdvice) TableName() string {
333
+	return "xt_doctor_advice"
334
+}
335
+
336
+type AssessmentAfterDislysis struct {
337
+	ID                              int64   `gorm:"column:id" json:"id"`
338
+	UserOrgId                       int64   `gorm:"column:user_org_id" json:"user_org_id"`
339
+	PatientId                       int64   `gorm:"column:patient_id" json:"patient_id"`
340
+	AssessmentDate                  int64   `gorm:"column:assessment_date" json:"assessment_date"`
341
+	DialysisOrderId                 int64   `gorm:"column:dialysis_order_id" json:"dialysis_order_id"`
342
+	Temperature                     float64 `gorm:"column:temperature" json:"temperature"`
343
+	PulseFrequency                  float64 `gorm:"column:pulse_frequency" json:"pulse_frequency"`
344
+	BreathingRate                   float64 `gorm:"column:breathing_rate" json:"breathing_rate"`
345
+	SystolicBloodPressure           float64 `gorm:"column:systolic_blood_pressure" json:"systolic_blood_pressure"`
346
+	DiastolicBloodPressure          float64 `gorm:"column:diastolic_blood_pressure" json:"diastolic_blood_pressure"`
347
+	BloodPressureType               int64   `gorm:"column:blood_pressure_type" json:"blood_pressure_type"`
348
+	ActualUltrafiltration           float64 `gorm:"column:actual_ultrafiltration" json:"actual_ultrafiltration"`
349
+	ActualDisplacement              float64 `gorm:"column:actual_displacement" json:"actual_displacement"`
350
+	ActualTreatmentHour             int64   `gorm:"column:actual_treatment_hour" json:"actual_treatment_hour"`
351
+	ActualTreatmentMinute           int64   `gorm:"column:actual_treatment_minute" json:"actual_treatment_minute"`
352
+	WeighingWay                     string  `gorm:"column:weighing_way" json:"weighing_way"`
353
+	WeightAfter                     float64 `gorm:"column:weight_after" json:"weight_after"`
354
+	WeightLoss                      float64 `gorm:"column:weight_loss" json:"weight_loss"`
355
+	Cruor                           string  `gorm:"column:cruor" json:"cruor"`
356
+	SymptomAfterDialysis            string  `gorm:"column:symptom_after_dialysis" json:"symptom_after_dialysis"`
357
+	InternalFistula                 string  `gorm:"column:internal_fistula" json:"internal_fistula"`
358
+	Catheter                        string  `gorm:"column:catheter" json:"catheter"`
359
+	Complication                    string  `gorm:"column:complication" json:"complication"`
360
+	Evaluator                       int64   `gorm:"column:evaluator" json:"evaluator"`
361
+	Remark                          string  `gorm:"column:remark" json:"remark"`
362
+	DialysisIntakes                 int64   `gorm:"column:dialysis_intakes" json:"dialysis_intakes"`
363
+	DialysisIntakesFeed             int64   `gorm:"column:dialysis_intakes_feed" json:"dialysis_intakes_feed"`
364
+	DialysisIntakesTransfusion      int64   `gorm:"column:dialysis_intakes_transfusion" json:"dialysis_intakes_transfusion"`
365
+	DialysisIntakesBloodTransfusion int64   `gorm:"column:dialysis_intakes_blood_transfusion" json:"dialysis_intakes_blood_transfusion"`
366
+	DialysisIntakesWashpipe         int64   `gorm:"column:dialysis_intakes_washpipe" json:"dialysis_intakes_washpipe"`
367
+	Status                          int64   `gorm:"column:status" json:"status"`
368
+	CreatedTime                     int64   `gorm:"column:created_time" json:"created_time"`
369
+	UpdatedTime                     int64   `gorm:"column:updated_time" json:"updated_time"`
370
+	Creater                         int64   `gorm:"column:creater" json:"creater"`
371
+	Modifier                        int64   `gorm:"column:modifier" json:"modifier"`
372
+	BloodAccessPartId               int64   `gorm:"column:blood_access_part_id" json:"blood_access_part_id"`
373
+	BloodAccessPartOperaId          int64   `gorm:"column:blood_access_part_opera_id" json:"blood_access_part_opera_id"`
374
+	PuncturePointOozingBlood        int64   `gorm:"column:puncture_point_oozing_blood" json:"puncture_point_oozing_blood"`
375
+	PuncturePointHaematoma          int64   `gorm:"column:puncture_point_haematoma" json:"puncture_point_haematoma"`
376
+	InternalFistulaTremorAc         int64   `gorm:"column:internal_fistula_tremor_ac" json:"internal_fistula_tremor_ac"`
377
+	PatientGose                     int64   `gorm:"column:patient_gose" json:"patient_gose"`
378
+	InpatientDepartment             string  `gorm:"column:inpatient_department" json:"inpatient_department"`
379
+	ObservationContent              string  `gorm:"column:observation_content" json:"observation_content"`
380
+	ObservationContentOther         string  `gorm:"column:observation_content_other" json:"observation_content_other"`
381
+	DryWeight                       float64 `gorm:"column:dry_weight" json:"dry_weight"`
382
+	DialysisProcess                 int64   `gorm:"column:dialysis_process" json:"dialysis_process"`
383
+	InAdvanceMinute                 float64 `gorm:"column:in_advance_minute" json:"in_advance_minute"`
384
+	InAdvanceReason                 string  `gorm:"column:in_advance_reason" json:"in_advance_reason"`
385
+	HemostasisMinute                int64   `gorm:"column:hemostasis_minute" json:"hemostasis_minute"`
386
+	HemostasisOpera                 int64   `gorm:"column:hemostasis_opera" json:"hemostasis_opera"`
387
+	TremorNoise                     int64   `gorm:"column:tremor_noise" json:"tremor_noise"`
388
+	DisequilibriumSyndrome          int64   `gorm:"column:disequilibrium_syndrome" json:"disequilibrium_syndrome"`
389
+	DisequilibriumSyndromeOption    string  `gorm:"column:disequilibrium_syndrome_option" json:"disequilibrium_syndrome_option"`
390
+	ArterialTube                    int64   `gorm:"column:arterial_tube" json:"arterial_tube"`
391
+	IntravenousTube                 int64   `gorm:"column:intravenous_tube" json:"intravenous_tube"`
392
+	Dialyzer                        int64   `gorm:"column:dialyzer" json:"dialyzer"`
393
+	InAdvanceReasonOther            string  `gorm:"column:in_advance_reason_other" json:"in_advance_reason_other"`
394
+	AssessmentDoctor                int64   `gorm:"column:assessment_doctor" json:"assessment_doctor"`
395
+	AssessmentTime                  int64   `gorm:"column:assessment_time" json:"assessment_time"`
396
+	IsEat                           int64   `gorm:"column:is_eat" json:"is_eat"`
397
+}
398
+
399
+func (AssessmentAfterDislysis) TableName() string {
400
+	return "xt_assessment_after_dislysis"
401
+}
402
+
403
+type AssessmentBeforeDislysis struct {
404
+	ID                             int64   `gorm:"column:id" json:"id"`
405
+	UserOrgId                      int64   `gorm:"column:user_org_id" json:"user_org_id"`
406
+	PatientId                      int64   `gorm:"column:patient_id" json:"patient_id"`
407
+	AssessmentDate                 int64   `gorm:"column:assessment_date" json:"assessment_date"`
408
+	DialysisOrderId                int64   `gorm:"column:dialysis_order_id" json:"dialysis_order_id"`
409
+	Temperature                    float64 `gorm:"column:temperature" json:"temperature"`
410
+	PulseFrequency                 float64 `gorm:"column:pulse_frequency" json:"pulse_frequency"`
411
+	BreathingRate                  float64 `gorm:"column:breathing_rate" json:"breathing_rate"`
412
+	SystolicBloodPressure          float64 `gorm:"column:systolic_blood_pressure" json:"systolic_blood_pressure"`
413
+	DiastolicBloodPressure         float64 `gorm:"column:diastolic_blood_pressure" json:"diastolic_blood_pressure"`
414
+	BloodPressureType              int64   `gorm:"column:blood_pressure_type" json:"blood_pressure_type"`
415
+	DryWeight                      float64 `gorm:"column:dry_weight" json:"dry_weight"`
416
+	WeightAfterLastTransparency    float64 `gorm:"column:weight_after_last_transparency" json:"weight_after_last_transparency"`
417
+	WeighingWay                    string  `gorm:"column:weighing_way" json:"weighing_way"`
418
+	WeighingBefore                 float64 `gorm:"column:weighing_before" json:"weighing_before"`
419
+	AdditionalWeight               float64 `gorm:"column:additional_weight" json:"additional_weight"`
420
+	WeightBefore                   float64 `gorm:"column:weight_before" json:"weight_before"`
421
+	WeightGain                     float64 `gorm:"column:weight_gain" json:"weight_gain"`
422
+	PreloadedDewatering            float64 `gorm:"column:preloaded_dewatering" json:"preloaded_dewatering"`
423
+	UltrafiltrationAmount          float64 `gorm:"column:ultrafiltration_amount" json:"ultrafiltration_amount"`
424
+	DialysisInterphase             string  `gorm:"column:dialysis_interphase" json:"dialysis_interphase"`
425
+	LastPostDialysis               string  `gorm:"column:last_post_dialysis" json:"last_post_dialysis"`
426
+	SymptomBeforeDialysis          string  `gorm:"column:symptom_before_dialysis" json:"symptom_before_dialysis"`
427
+	InternalFistula                string  `gorm:"column:internal_fistula" json:"internal_fistula"`
428
+	InternalFistulaSkin            string  `gorm:"column:internal_fistula_skin" json:"internal_fistula_skin"`
429
+	CatheterBend                   int64   `gorm:"column:catheter_bend" json:"catheter_bend"`
430
+	Catheter                       string  `gorm:"column:catheter" json:"catheter"`
431
+	Complication                   string  `gorm:"column:complication" json:"complication"`
432
+	Evaluator                      int64   `gorm:"column:evaluator" json:"evaluator"`
433
+	Creater                        int64   `gorm:"column:creater" json:"creater"`
434
+	Remark                         string  `gorm:"column:remark" json:"remark"`
435
+	Status                         int64   `gorm:"column:status" json:"status"`
436
+	CreatedTime                    int64   `gorm:"column:created_time" json:"created_time"`
437
+	UpdatedTime                    int64   `gorm:"column:updated_time" json:"updated_time"`
438
+	Modifier                       int64   `gorm:"column:modifier" json:"modifier"`
439
+	BloodAccessPartId              int64   `gorm:"column:blood_access_part_id" json:"blood_access_part_id"`
440
+	BloodAccessPartOperaId         int64   `gorm:"column:blood_access_part_opera_id" json:"blood_access_part_opera_id"`
441
+	IsHemorrhage                   int64   `gorm:"column:is_hemorrhage" json:"is_hemorrhage"`
442
+	Hemorrhage                     string  `gorm:"column:hemorrhage" json:"hemorrhage"`
443
+	HemorrhageOther                string  `gorm:"column:hemorrhage_other" json:"hemorrhage_other"`
444
+	PunctureMethod                 string  `gorm:"column:puncture_method" json:"puncture_method"`
445
+	BloodAccessInternalFistula     string  `gorm:"column:blood_access_internal_fistula" json:"blood_access_internal_fistula"`
446
+	InternalFistulaOther           string  `gorm:"column:internal_fistula_other" json:"internal_fistula_other"`
447
+	BloodAccessNoise               int64   `gorm:"column:blood_access_noise" json:"blood_access_noise"`
448
+	PunctureWay                    int64   `gorm:"column:puncture_way" json:"puncture_way"`
449
+	VenousCatheterization          int64   `gorm:"column:venous_catheterization" json:"venous_catheterization"`
450
+	VenousCatheterizationPart      int64   `gorm:"column:venous_catheterization_part" json:"venous_catheterization_part"`
451
+	VenousCatheterizationPartOther string  `gorm:"column:venous_catheterization_part_other" json:"venous_catheterization_part_other"`
452
+	DuctusArantii                  string  `gorm:"column:ductus_arantii" json:"ductus_arantii"`
453
+	EmergencyTreatment             int64   `gorm:"column:emergency_treatment" json:"emergency_treatment"`
454
+	EmergencyTreatmentOther        string  `gorm:"column:emergency_treatment_other" json:"emergency_treatment_other"`
455
+	DialysisCount                  int64   `gorm:"column:dialysis_count" json:"dialysis_count"`
456
+	AssessmentDoctor               int64   `gorm:"column:assessment_doctor" json:"assessment_doctor"`
457
+	AssessmentTime                 int64   `gorm:"column:assessment_time" json:"assessment_time"`
458
+	MachineType                    string  `gorm:"column:machine_type" json:"machine_type"`
459
+	IsInfect                       int64   `gorm:"column:is_infect" json:"is_infect"`
460
+	Exposed                        float64 `gorm:"column:exposed" json:"exposed"`
461
+	Skin                           int64   `gorm:"column:skin" json:"skin"`
462
+	SkinOther                      string  `gorm:"column:skin_other" json:"skin_other"`
463
+	InfectOther                    string  `gorm:"column:infect_other" json:"infect_other"`
464
+	DuctusArantiiOther             string  `gorm:"column:ductus_arantii_other" json:"ductus_arantii_other"`
465
+}
466
+
467
+func (AssessmentBeforeDislysis) TableName() string {
468
+	return "xt_assessment_before_dislysis"
469
+}
470
+
471
+type MonitoringRecord struct {
472
+	ID                        int64         `gorm:"column:id" json:"id"`
473
+	UserOrgId                 int64         `gorm:"column:user_org_id" json:"user_org_id"`
474
+	PatientId                 int64         `gorm:"column:patient_id" json:"patient_id"`
475
+	DialysisOrderId           int64         `gorm:"column:dialysis_order_id" json:"dialysis_order_id"`
476
+	MonitoringDate            int64         `gorm:"column:monitoring_date" json:"monitoring_date"`
477
+	MonitoringTime            string        `gorm:"column:monitoring_time" json:"monitoring_time"`
478
+	PulseFrequency            float64       `gorm:"column:pulse_frequency" json:"pulse_frequency"`
479
+	BreathingRate             float64       `gorm:"column:breathing_rate" json:"breathing_rate"`
480
+	SystolicBloodPressure     float64       `gorm:"column:systolic_blood_pressure" json:"systolic_blood_pressure"`
481
+	DiastolicBloodPressure    float64       `gorm:"column:diastolic_blood_pressure" json:"diastolic_blood_pressure"`
482
+	BloodPressureType         int64         `gorm:"column:blood_pressure_type" json:"blood_pressure_type"`
483
+	Pic                       string        `gorm:"column:pic" json:"pic"`
484
+	BloodFlowVolume           float64       `gorm:"column:blood_flow_volume" json:"blood_flow_volume"`
485
+	VenousPressure            float64       `gorm:"column:venous_pressure" json:"venous_pressure"`
486
+	VenousPressureUnit        string        `gorm:"column:venous_pressure_unit" json:"venous_pressure_unit"`
487
+	ArterialPressure          float64       `gorm:"column:arterial_pressure" json:"arterial_pressure"`
488
+	TransmembranePressure     float64       `gorm:"column:transmembrane_pressure" json:"transmembrane_pressure"`
489
+	TransmembranePressureUnit string        `gorm:"column:transmembrane_pressure_unit" json:"transmembrane_pressure_unit"`
490
+	UltrafiltrationRate       float64       `gorm:"column:ultrafiltration_rate" json:"ultrafiltration_rate"`
491
+	UltrafiltrationVolume     float64       `gorm:"column:ultrafiltration_volume" json:"ultrafiltration_volume"`
492
+	SodiumConcentration       float64       `gorm:"column:sodium_concentration" json:"sodium_concentration"`
493
+	Temperature               float64       `gorm:"column:temperature" json:"temperature"`
494
+	DialysateTemperature      float64       `gorm:"column:dialysate_temperature" json:"dialysate_temperature"`
495
+	ReplacementRate           float64       `gorm:"column:replacement_rate" json:"replacement_rate"`
496
+	DisplacementQuantity      float64       `gorm:"column:displacement_quantity" json:"displacement_quantity"`
497
+	Ktv                       float64       `gorm:"column:ktv" json:"ktv"`
498
+	Symptom                   string        `gorm:"column:symptom" json:"symptom"`
499
+	Dispose                   string        `gorm:"column:dispose" json:"dispose"`
500
+	Result                    string        `gorm:"column:result" json:"result"`
501
+	MonitoringNurse           int64         `gorm:"column:monitoring_nurse" json:"monitoring_nurse"`
502
+	Status                    int64         `gorm:"column:status" json:"status"`
503
+	CreatedTime               int64         `gorm:"column:created_time" json:"created_time"`
504
+	UpdatedTime               int64         `gorm:"column:updated_time" json:"updated_time"`
505
+	OperateTime               int64         `gorm:"column:operate_time" json:"operate_time"`
506
+	Conductivity              float64       `gorm:"column:conductivity" json:"conductivity"`
507
+	DisplacementFlowQuantity  float64       `gorm:"column:displacement_flow_quantity" json:"displacement_flow_quantity"`
508
+	DialysisOrder             DialysisOrder `gorm:"ForeignKey:PatientId,DialysisDate;AssociationForeignKey:PatientId,MonitoringDate" json:"order"`
509
+}
510
+
511
+func (MonitoringRecord) TableName() string {
512
+	return "xt_monitoring_record"
513
+}
514
+
515
+type PatientLapseto struct {
516
+	ID          int64 `gorm:"column:id" json:"id"`
517
+	PatientId   int64 `gorm:"column:patient_id" json:"patient_id"`
518
+	LapsetoType int64 `gorm:"column:lapseto_type" json:"lapseto_type"`
519
+	LapsetoTime int64 `gorm:"column:lapseto_time" json:"lapseto_time"`
520
+	Status      int64 `gorm:"column:status" json:"status"`
521
+	CreatedTime int64 `gorm:"column:created_time" json:"created_time"`
522
+	UpdatedTime int64 `gorm:"column:updated_time" json:"updated_time"`
523
+}
524
+
525
+func (PatientLapseto) TableName() string {
526
+	return "xt_patient_lapseto"
527
+}
528
+
529
+type DialysisOrder struct {
530
+	ID             int64  `gorm:"column:id" json:"id"`
531
+	DialysisDate   int64  `gorm:"column:dialysis_date" json:"dialysis_date"`
532
+	UserOrgId      int64  `gorm:"column:user_org_id" json:"user_org_id"`
533
+	PatientId      int64  `gorm:"column:patient_id" json:"patient_id"`
534
+	PrescriptionId int64  `gorm:"column:prescription_id" json:"prescription_id"`
535
+	Stage          int64  `gorm:"column:stage" json:"stage"`
536
+	Remark         string `gorm:"column:remark" json:"remark"`
537
+	BedId          int64  `gorm:"column:bed_id" json:"bed_id"`
538
+	StartNurse     int64  `gorm:"column:start_nurse" json:"start_nurse"`
539
+	FinishNurse    int64  `gorm:"column:finish_nurse" json:"finish_nurse"`
540
+	Status         int64  `gorm:"column:status" json:"status"`
541
+	CreatedTime    int64  `gorm:"column:created_time" json:"created_time"`
542
+	UpdatedTime    int64  `gorm:"column:updated_time" json:"updated_time"`
543
+	StartTime      int64  `gorm:"column:start_time" json:"start_time"`
544
+	EndTime        int64  `gorm:"column:end_time" json:"end_time"`
545
+	PunctureNurse  int64  `gorm:"column:puncture_nurse" json:"puncture_nurse"`
546
+	Creator        int64  `gorm:"column:creator" json:"creator"`
547
+	Modifier       int64  `gorm:"column:modifier" json:"modifier"`
548
+	FinishCreator  int64  `gorm:"column:finish_creator" json:"finish_creator"`
549
+	FinishModifier int64  `gorm:"column:finish_modifier" json:"finish_modifier"`
550
+}
551
+
552
+func (DialysisOrder) TableName() string {
553
+	return "xt_dialysis_order"
554
+}
555
+
556
+type VMSchedule struct {
557
+	ID                       int64                    `gorm:"column:id" json:"id"`
558
+	UserOrgId                int64                    `gorm:"column:user_org_id" json:"user_org_id"`
559
+	PartitionId              int64                    `gorm:"column:partition_id" json:"partition_id"`
560
+	BedId                    int64                    `gorm:"column:bed_id" json:"bed_id"`
561
+	PatientId                int64                    `gorm:"column:patient_id" json:"patient_id"`
562
+	ScheduleDate             int64                    `gorm:"column:schedule_date" json:"schedule_date"`
563
+	ScheduleType             int64                    `gorm:"column:schedule_type" json:"schedule_type"`
564
+	ScheduleWeek             int64                    `gorm:"column:schedule_week" json:"schedule_week"`
565
+	ModeId                   int64                    `gorm:"column:mode_id" json:"mode_id"`
566
+	Status                   int64                    `gorm:"column:status" json:"status"`
567
+	CreatedTime              int64                    `gorm:"column:created_time" json:"created_time"`
568
+	UpdatedTime              int64                    `gorm:"column:updated_time" json:"updated_time"`
569
+	DeviceNumber             DeviceNumber             `gorm:"ForeignKey:ID;AssociationForeignKey:BedId" json:"device"`
570
+	VMDialysisPrescription   VMDialysisPrescription   `gorm:"ForeignKey:RecordDate,PatientID;AssociationForeignKey:ScheduleDate,PatientID" json:"prescription"`
571
+	AssessmentBeforeDislysis AssessmentBeforeDislysis `gorm:"ForeignKey:AssessmentDate,PatientID;AssociationForeignKey:ScheduleDate,PatientID" json:"before"`
572
+	AssessmentAfterDislysis  AssessmentAfterDislysis  `gorm:"ForeignKey:AssessmentDate,PatientID;AssociationForeignKey:ScheduleDate,PatientID" json:"after"`
573
+	DialysisOrder            DialysisOrder            `gorm:"ForeignKey:DialysisDate,PatientID;AssociationForeignKey:ScheduleDate,PatientID" json:"order"`
574
+	MonitoringRecord         []MonitoringRecord       `gorm:"ForeignKey:MonitoringDate,PatientID;AssociationForeignKey:ScheduleDate,PatientID" json:"monitor"`
575
+}
576
+
577
+func (VMSchedule) TableName() string {
578
+	return "xt_schedule"
579
+}
580
+
581
+type VMDialysisPrescription struct {
582
+	ID                         int64   `gorm:"column:id" json:"id"`
583
+	UserOrgId                  int64   `gorm:"column:user_org_id" json:"user_org_id"`
584
+	PatientId                  int64   `gorm:"column:patient_id" json:"patient_id"`
585
+	Dialyzer                   int64   `gorm:"column:dialyzer" json:"dialyzer"`
586
+	MachineType                string  `gorm:"column:machine_type" json:"machine_type"`
587
+	DewaterAmount              float64 `gorm:"column:dewater_amount" json:"dewater_amount"`
588
+	DialyzerPerfusionApparatus string  `gorm:"column:dialyzer_perfusion_apparatus" json:"dialyzer_perfusion_apparatus"`
589
+	PrescriptionDewatering     float64 `gorm:"column:prescription_dewatering" json:"prescription_dewatering"`
590
+	Anticoagulant              int64   `gorm:"column:anticoagulant" json:"anticoagulant"`
591
+	AnticoagulantShouji        float64 `gorm:"column:anticoagulant_shouji" json:"anticoagulant_shouji"`
592
+	AnticoagulantWeichi        float64 `gorm:"column:anticoagulant_weichi" json:"anticoagulant_weichi"`
593
+	AnticoagulantZongliang     float64 `gorm:"column:anticoagulant_zongliang" json:"anticoagulant_zongliang"`
594
+	AnticoagulantGaimingcheng  string  `gorm:"column:anticoagulant_gaimingcheng" json:"anticoagulant_gaimingcheng"`
595
+	AnticoagulantGaijiliang    string  `gorm:"column:anticoagulant_gaijiliang" json:"anticoagulant_gaijiliang"`
596
+	ModeId                     int64   `gorm:"column:mode_id" json:"mode_id"`
597
+	DialysisDurationHour       int64   `gorm:"column:dialysis_duration_hour" json:"dialysis_duration_hour"`
598
+	DialysisDurationMinute     int64   `gorm:"column:dialysis_duration_minute" json:"dialysis_duration_minute"`
599
+	DialysisDuration           float64 `gorm:"column:dialysis_duration" json:"dialysis_duration"`
600
+	ReplacementTotal           float64 `gorm:"column:replacement_total" json:"replacement_total"`
601
+	ReplacementWay             int64   `gorm:"column:replacement_way" json:"replacement_way"`
602
+	HemodialysisMachine        int64   `gorm:"column:hemodialysis_machine" json:"hemodialysis_machine"`
603
+	BloodFilter                int64   `gorm:"column:blood_filter" json:"blood_filter"`
604
+	PerfusionApparatus         int64   `gorm:"column:perfusion_apparatus" json:"perfusion_apparatus"`
605
+	DryWeight                  float64 `gorm:"column:dry_weight" json:"dry_weight"`
606
+	VascularAccessMode         int64   `gorm:"column:vascular_access_mode" json:"vascular_access_mode"`
607
+	VascularAccess             int64   `gorm:"column:vascular_access" json:"vascular_access"`
608
+	BloodFlowVolume            float64 `gorm:"column:blood_flow_volume" json:"blood_flow_volume"`
609
+	DialysateFlow              float64 `gorm:"column:dialysate_flow" json:"dialysate_flow"`
610
+	DisplaceLiqui              float64 `gorm:"column:displace_liqui" json:"displace_liqui"`
611
+	Kalium                     float64 `gorm:"column:kalium" json:"kalium"`
612
+	Sodium                     float64 `gorm:"column:sodium" json:"sodium"`
613
+	Calcium                    float64 `gorm:"column:calcium" json:"calcium"`
614
+	Bicarbonate                float64 `gorm:"column:bicarbonate" json:"bicarbonate"`
615
+	Glucose                    float64 `gorm:"column:glucose" json:"glucose"`
616
+	DialysateTemperature       float64 `gorm:"column:dialysate_temperature" json:"dialysate_temperature"`
617
+	Conductivity               float64 `gorm:"column:conductivity" json:"conductivity"`
618
+	PrescriptionDoctor         int64   `gorm:"column:prescription_doctor" json:"prescription_doctor"`
619
+	Creater                    int64   `gorm:"column:creater" json:"creater"`
620
+	Modifier                   int64   `gorm:"column:modifier" json:"modifier"`
621
+	Remark                     string  `gorm:"column:remark" json:"remark"`
622
+	Status                     int64   `gorm:"column:status" json:"status"`
623
+	CreatedTime                int64   `gorm:"column:created_time" json:"created_time"`
624
+	UpdatedTime                int64   `gorm:"column:updated_time" json:"updated_time"`
625
+	RecordDate                 int64   `gorm:"column:record_date" json:"record_date"`
626
+	RecordId                   int64   `gorm:"column:record_id" json:"record_id"`
627
+	TargetUltrafiltration      float64 `gorm:"column:target_ultrafiltration" json:"target_ultrafiltration"`
628
+	DialysateFormulation       int64   `gorm:"column:dialysate_formulation" json:"dialysate_formulation"`
629
+	BodyFluid                  int64   `gorm:"column:body_fluid" json:"body_fluid"`
630
+	SpecialMedicine            int64   `gorm:"column:special_medicine" json:"special_medicine"`
631
+	SpecialMedicineOther       string  `gorm:"column:special_medicine_other" json:"special_medicine_other"`
632
+	DisplaceLiquiPart          int64   `gorm:"column:displace_liqui_part" json:"displace_liqui_part"`
633
+	BloodAccess                int64   `gorm:"column:blood_access" json:"blood_access"`
634
+	DisplaceLiquiValue         float64 `gorm:"column:displace_liqui_value" json:"displace_liqui_value"`
635
+	Ultrafiltration            float64 `gorm:"column:ultrafiltration" json:"ultrafiltration"`
636
+	BodyFluidOther             string  `gorm:"column:body_fluid_other" json:"body_fluid_other"`
637
+	Niprocart                  int64   `gorm:"column:niprocart" json:"niprocart"`
638
+	Jms                        int64   `gorm:"column:jms" json:"jms"`
639
+	FistulaNeedleSet           int64   `gorm:"column:fistula_needle_set" json:"fistula_needle_set"`
640
+	FistulaNeedleSet16         int64   `gorm:"column:fistula_needle_set_16" json:"fistula_needle_set_16"`
641
+	Hemoperfusion              int64   `gorm:"column:hemoperfusion" json:"hemoperfusion"`
642
+	DialyserSterilised         int64   `gorm:"column:dialyser_sterilised" json:"dialyser_sterilised"`
643
+	Filtryzer                  int64   `gorm:"column:filtryzer" json:"filtryzer"`
644
+	TargetKtv                  float64 `gorm:"column:target_ktv" json:"target_ktv"`
645
+	Dialyzers                  int64   `gorm:"column:dialyzers" json:"dialyzers"`
646
+	Injector                   int64   `gorm:"column:injector" json:"injector"`
647
+	Bloodlines                 int64   `gorm:"column:bloodlines" json:"bloodlines"`
648
+	TubingHemodialysis         int64   `gorm:"column:tubing_hemodialysis" json:"tubing_hemodialysis"`
649
+	Package                    int64   `gorm:"column:package" json:"package"`
650
+	ALiquid                    int64   `gorm:"column:a_liquid" json:"a_liquid"`
651
+}
652
+
653
+func (VMDialysisPrescription) TableName() string {
654
+	return "xt_dialysis_prescription"
655
+}

+ 425 - 0
models/sz/target_data.go Zobrazit soubor

@@ -0,0 +1,425 @@
1
+package sz
2
+
3
+import "time"
4
+
5
+type TempHdHospital struct {
6
+	ID             int64     `gorm:"column:id" json:"id"`
7
+	HospitalId     string    `gorm:"column:hospital_id" json:"hospital_id"`
8
+	InstType       string    `gorm:"column:inst_type" json:"inst_type"`
9
+	DepartMentName string    `gorm:"column:depart_ment_name" json:"depart_ment_name"`
10
+	AuthorizedBeds int64     `gorm:"column:authorized_beds" json:"authorized_beds"`
11
+	CreateTime     time.Time `gorm:"column:create_time" json:"create_time"`
12
+	UpdateTime     time.Time `gorm:"column:update_time" json:"update_time"`
13
+	Sjscsj         time.Time `gorm:"column:sjscsj" json:"sjscsj"`
14
+	Mj             string    `gorm:"column:mj" json:"mj"`
15
+	Xgbz           int64     `gorm:"column:xgbz" json:"xgbz"`
16
+	Ylyl1          string    `gorm:"column:ylyl1" json:"ylyl1"`
17
+	Ylyl2          string    `gorm:"column:ylyl2" json:"ylyl2"`
18
+}
19
+
20
+func (TempHdHospital) TableName() string {
21
+	return "temp_hd_hospital"
22
+}
23
+
24
+type TempHdStaff struct {
25
+	ID                           int64     `gorm:"column:id" json:"id"`
26
+	HospitalId                   string    `gorm:"column:hospital_id" json:"hospital_id"`
27
+	StaffId                      string    `gorm:"column:staff_id" json:"staff_id"`
28
+	IdType                       string    `gorm:"column:id_type" json:"id_type"`
29
+	IdNo                         string    `gorm:"column:id_no" json:"id_no"`
30
+	StaffName                    string    `gorm:"column:staff_name" json:"staff_name"`
31
+	Position                     string    `gorm:"column:position" json:"position"`
32
+	TrainingName                 string    `gorm:"column:training_name" json:"training_name"`
33
+	PracticeCertificate          string    `gorm:"column:practice_certificate" json:"practice_certificate"`
34
+	PracticeCertificateNo        string    `gorm:"column:practice_certificate_no" json:"practice_certificate_no"`
35
+	QualificationCertificate     string    `gorm:"column:qualification_certificate" json:"qualification_certificate"`
36
+	QualificationType            string    `gorm:"column:qualification_type" json:"qualification_type"`
37
+	DiplomaFile                  string    `gorm:"column:diploma_file" json:"diploma_file"`
38
+	DegreeCertificateFile        string    `gorm:"column:degree_certificate_file" json:"degree_certificate_file"`
39
+	TrainingCertificateFile      string    `gorm:"column:training_certificate_file" json:"training_certificate_file"`
40
+	PracticeCertificateFile      string    `gorm:"column:practice_certificate_file" json:"practice_certificate_file"`
41
+	QualificationCertificateFile string    `gorm:"column:qualification_certificate_file" json:"qualification_certificate_file"`
42
+	Xgbz                         string    `gorm:"column:xgbz" json:"xgbz"`
43
+	TrainingDate                 time.Time `gorm:"column:training_date" json:"training_date"`
44
+	InDate                       time.Time `gorm:"column:in_date" json:"in_date"`
45
+	OutDate                      time.Time `gorm:"column:out_date" json:"out_date"`
46
+	CreateTime                   time.Time `gorm:"column:create_time" json:"create_time"`
47
+	UpdateTime                   time.Time `gorm:"column:update_time" json:"update_time"`
48
+	Sjscsj                       time.Time `gorm:"column:sjscsj" json:"sjscsj"`
49
+	Mj                           string    `gorm:"column:mj" json:"mj"`
50
+	Ylyl1                        string    `gorm:"column:ylyl1" json:"ylyl1"`
51
+	Ylyl2                        string    `gorm:"column:ylyl2" json:"ylyl2"`
52
+	PermanentType                string    `gorm:"column:permanent_type" json:"permanent_type"`
53
+}
54
+
55
+func (TempHdStaff) TableName() string {
56
+	return "temp_hd_staff"
57
+}
58
+
59
+type TempHdDm struct {
60
+	ID             int64     `gorm:"column:id" json:"id"`
61
+	HospitalId     string    `gorm:"column:hospital_id" json:"hospital_id"`
62
+	EquipmentId    string    `gorm:"column:equipment_id" json:"equipment_id"`
63
+	SickbedNo      string    `gorm:"column:sickbed_no" json:"sickbed_no"`
64
+	EquipmentBrand string    `gorm:"column:equipment_brand" json:"equipment_brand"`
65
+	EnableTime     time.Time `gorm:"column:enable_time" json:"enable_time"`
66
+	DiscardedTime  time.Time `gorm:"column:discarded_time" json:"discarded_time"`
67
+	Status         string    `gorm:"column:status" json:"status"`
68
+	EquipmentType  string    `gorm:"column:equipment_type" json:"equipment_type"`
69
+	Temperature    string    `gorm:"column:temperature" json:"temperature"`
70
+	Pressure       string    `gorm:"column:pressure" json:"pressure"`
71
+	PressureUnit   string    `gorm:"column:pressure_unit" json:"pressure_unit"`
72
+	WorkingVoltage string    `gorm:"column:working_voltage" json:"working_voltage"`
73
+	Xgbz           string    `gorm:"column:xgbz" json:"xgbz"`
74
+	Bbp            string    `gorm:"column:bbp" json:"bbp"`
75
+	CreateTime     time.Time `gorm:"column:create_time" json:"create_time"`
76
+	UpdateTime     time.Time `gorm:"column:update_time" json:"update_time"`
77
+	Sjscsj         time.Time `gorm:"column:sjscsj" json:"sjscsj"`
78
+	Mj             string    `gorm:"column:mj" json:"mj"`
79
+	Ylyl1          string    `gorm:"column:ylyl1" json:"ylyl1"`
80
+	Ylyl2          string    `gorm:"column:ylyl2" json:"ylyl2"`
81
+}
82
+
83
+func (TempHdDm) TableName() string {
84
+	return "temp_hd_dm"
85
+}
86
+
87
+type TempHdPatient struct {
88
+	ID                int64     `gorm:"column:id" json:"id"`
89
+	HospitalId        string    `gorm:"column:hospital_id" json:"hospital_id"`
90
+	PatientNk         string    `gorm:"column:patient_nk" json:"patient_nk"`
91
+	CardNo            string    `gorm:"column:card_no" json:"card_no"`
92
+	CardType          string    `gorm:"column:card_type" json:"card_type"`
93
+	IdNo              string    `gorm:"column:id_no" json:"id_no"`
94
+	IdType            string    `gorm:"column:id_type" json:"id_type"`
95
+	PatientName       string    `gorm:"column:patient_name" json:"patient_name"`
96
+	Gender            string    `gorm:"column:gender" json:"gender"`
97
+	BornDate          time.Time `gorm:"column:born_date" json:"born_date"`
98
+	DiagnosisSummary  string    `gorm:"column:diagnosis_summary" json:"diagnosis_summary"`
99
+	IsCrf             string    `gorm:"column:is_crf" json:"is_crf"`
100
+	AllergyHistory    string    `gorm:"column:allergy_history" json:"allergy_history"`
101
+	PayMethod         string    `gorm:"column:pay_method" json:"pay_method"`
102
+	DialysisStartTime time.Time `gorm:"column:dialysis_start_time" json:"dialysis_start_time"`
103
+	LocalStartTime    time.Time `gorm:"column:local_start_time" json:"local_start_time"`
104
+	Xgbz              string    `gorm:"column:xgbz" json:"xgbz"`
105
+	CreatedTime       time.Time `gorm:"column:created_time" json:"created_time"`
106
+	UpdateTime        time.Time `gorm:"column:update_time" json:"update_time"`
107
+	Sjscsj            time.Time `gorm:"column:sjscsj" json:"sjscsj"`
108
+	Mj                string    `gorm:"column:mj" json:"mj"`
109
+	Ylyl1             string    `gorm:"column:ylyl1" json:"ylyl1"`
110
+	Ylyl2             string    `gorm:"column:ylyl2" json:"ylyl2"`
111
+}
112
+
113
+func (TempHdPatient) TableName() string {
114
+	return "temp_hd_patient"
115
+}
116
+
117
+type TempHdPatientOut struct {
118
+	ID              int64     `gorm:"column:id" json:"id"`
119
+	Sn              string    `gorm:"column:sn" json:"sn"`
120
+	HospitalId      string    `gorm:"column:hospital_id" json:"hospital_id"`
121
+	PatientNk       string    `gorm:"column:patient_nk" json:"patient_nk"`
122
+	SequelaeDate    time.Time `gorm:"column:sequelae_date" json:"sequelae_date"`
123
+	SequelaeType    string    `gorm:"column:sequelae_type" json:"sequelae_type"`
124
+	SequelaeSubType string    `gorm:"column:sequelae_sub_type" json:"sequelae_sub_type"`
125
+	ExtReason       string    `gorm:"column:ext_reason" json:"ext_reason"`
126
+	CreateTime      time.Time `gorm:"column:create_time" json:"create_time"`
127
+	Sjscsj          time.Time `gorm:"column:sjscsj" json:"sjscsj"`
128
+	Mj              string    `gorm:"column:mj" json:"mj"`
129
+	Xgbz            int64     `gorm:"column:xgbz" json:"xgbz"`
130
+	Ylyl1           string    `gorm:"column:ylyl1" json:"ylyl1"`
131
+	Ylyl2           string    `gorm:"column:ylyl2" json:"ylyl2"`
132
+}
133
+
134
+func (TempHdPatientOut) TableName() string {
135
+	return "temp_hd_patient_out"
136
+}
137
+
138
+type TempHdPs struct {
139
+	ID                int64     `gorm:"column:id" json:"id"`
140
+	HospitalId        string    `gorm:"column:hospital_id" json:"hospital_id"`
141
+	PrescribeId       string    `gorm:"column:prescribe_id" json:"prescribe_id"`
142
+	PatientNk         string    `gorm:"column:patient_nk" json:"patient_nk"`
143
+	MedicalId         string    `gorm:"column:medical_id" json:"medical_id"`
144
+	DrId              string    `gorm:"column:dr_id" json:"dr_id"`
145
+	DialysisFrequency int64     `gorm:"column:dialysis_frequency" json:"dialysis_frequency"`
146
+	FrequencyUnit     int64     `gorm:"column:frequency_unit" json:"frequency_unit"`
147
+	DialysisDuration  float64   `gorm:"column:dialysis_duration" json:"dialysis_duration"`
148
+	Hdf               string    `gorm:"column:hdf" json:"hdf"`
149
+	HdfFrequencyUnit  int64     `gorm:"column:hdf_frequency_unit" json:"hdf_frequency_unit"`
150
+	HdfFrequency      int64     `gorm:"column:hdf_frequency" json:"hdf_frequency"`
151
+	HdfDuration       float64   `gorm:"column:hdf_duration" json:"hdf_duration"`
152
+	Hp                string    `gorm:"column:hp" json:"hp"`
153
+	HpFrequency       int64     `gorm:"column:hp_frequency" json:"hp_frequency"`
154
+	HpFrequencyUnit   int64     `gorm:"column:hp_frequency_unit" json:"hp_frequency_unit"`
155
+	HpDuration        float64   `gorm:"column:hp_duration" json:"hp_duration"`
156
+	K                 float64   `gorm:"column:k" json:"k"`
157
+	Ca                float64   `gorm:"column:ca" json:"ca"`
158
+	Na                float64   `gorm:"column:na" json:"na"`
159
+	Glucose           string    `gorm:"column:glucose" json:"glucose"`
160
+	FluxLevel         string    `gorm:"column:flux_level" json:"flux_level"`
161
+	FluxValue         string    `gorm:"column:flux_value" json:"flux_value"`
162
+	UseType           string    `gorm:"column:use_type" json:"use_type"`
163
+	PrescribeTime     time.Time `gorm:"column:prescribe_time" json:"prescribe_time"`
164
+	CreateTime        time.Time `gorm:"column:create_time" json:"create_time"`
165
+	Sjscsj            time.Time `gorm:"column:sjscsj" json:"sjscsj"`
166
+	Mj                string    `gorm:"column:mj" json:"mj"`
167
+	Xgbz              int64     `gorm:"column:xgbz" json:"xgbz"`
168
+	Ylyl1             string    `gorm:"column:ylyl1" json:"ylyl1"`
169
+	Ylyl2             string    `gorm:"column:ylyl2" json:"ylyl2"`
170
+}
171
+
172
+func (TempHdPs) TableName() string {
173
+	return "temp_hd_ps"
174
+}
175
+
176
+type TempHdPsMedicine struct {
177
+	ID             int64     `gorm:"column:id" json:"id"`
178
+	Sn             string    `gorm:"column:sn" json:"sn"`
179
+	PrescribeId    string    `gorm:"column:prescribe_id" json:"prescribe_id"`
180
+	HospitalId     string    `gorm:"column:hospital_id" json:"hospital_id"`
181
+	MedicineTypeId string    `gorm:"column:medicine_type_id" json:"medicine_type_id"`
182
+	MedicineId     string    `gorm:"column:medicine_id" json:"medicine_id"`
183
+	CreatedTime    time.Time `gorm:"column:created_time" json:"created_time"`
184
+	Sjscsj         time.Time `gorm:"column:sjscsj" json:"sjscsj"`
185
+	Mj             string    `gorm:"column:mj" json:"mj"`
186
+	Xgbz           int64     `gorm:"column:xgbz" json:"xgbz"`
187
+	Ylyl1          string    `gorm:"column:ylyl1" json:"ylyl1"`
188
+	Ylyl2          string    `gorm:"column:ylyl2" json:"ylyl2"`
189
+}
190
+
191
+func (TempHdPsMedicine) TableName() string {
192
+	return "temp_hd_ps_medicine"
193
+}
194
+
195
+type TempHdInfection struct {
196
+	ID         int64     `gorm:"column:id" json:"id"`
197
+	HospitalId string    `gorm:"column:hospital_id" json:"hospital_id"`
198
+	PatientNk  string    `gorm:"column:patient_nk" json:"patient_nk"`
199
+	Hbv        string    `gorm:"column:hbv" json:"hbv"`
200
+	Hcv        string    `gorm:"column:hcv" json:"hcv"`
201
+	Rpr        string    `gorm:"column:rpr" json:"rpr"`
202
+	Hiv        string    `gorm:"column:hiv" json:"hiv"`
203
+	Hbsag      string    `gorm:"column:hbsag" json:"hbsag"`
204
+	Hbs        string    `gorm:"column:hbs" json:"hbs"`
205
+	Hbeag      string    `gorm:"column:hbeag" json:"hbeag"`
206
+	Hbe        string    `gorm:"column:hbe" json:"hbe"`
207
+	Hbc        string    `gorm:"column:hbc" json:"hbc"`
208
+	CheckDate  time.Time `gorm:"column:check_date" json:"check_date"`
209
+	CreateTime time.Time `gorm:"column:create_time" json:"create_time"`
210
+	Sjscsj     time.Time `gorm:"column:sjscsj" json:"sjscsj"`
211
+	Mj         string    `gorm:"column:mj" json:"mj"`
212
+	Xgbz       int64     `gorm:"column:xgbz" json:"xgbz"`
213
+	Ylyl1      string    `gorm:"column:ylyl1" json:"ylyl1"`
214
+	Ylyl2      string    `gorm:"column:ylyl2" json:"ylyl2"`
215
+}
216
+
217
+func (TempHdInfection) TableName() string {
218
+	return "temp_hd_infection"
219
+}
220
+
221
+type TempHdInhospital struct {
222
+	ID             int64     `gorm:"column:id" json:"id"`
223
+	HospitalId     string    `gorm:"column:hospital_id" json:"hospital_id"`
224
+	MedicalNo      string    `gorm:"column:medical_no" json:"medical_no"`
225
+	AdmissionTime  time.Time `gorm:"column:admission_time" json:"admission_time"`
226
+	AdmissionCause string    `gorm:"column:admission_cause" json:"admission_cause"`
227
+	CreateTime     time.Time `gorm:"column:create_time" json:"create_time"`
228
+	Sjscsj         time.Time `gorm:"column:sjscsj" json:"sjscsj"`
229
+	Mj             string    `gorm:"column:mj" json:"mj"`
230
+	Xgbz           int64     `gorm:"column:xgbz" json:"xgbz"`
231
+	Ylyl1          string    `gorm:"column:ylyl1" json:"ylyl1"`
232
+	Ylyl2          string    `gorm:"column:ylyl2" json:"ylyl2"`
233
+}
234
+
235
+func (TempHdInhospital) TableName() string {
236
+	return "temp_hd_inhospital"
237
+}
238
+
239
+type TempHdOuthospital struct {
240
+	ID            int64     `gorm:"column:id" json:"id"`
241
+	HospitalId    string    `gorm:"column:hospital_id" json:"hospital_id"`
242
+	MedicalNo     string    `gorm:"column:medical_no" json:"medical_no"`
243
+	DischargeDate time.Time `gorm:"column:discharge_date" json:"discharge_date"`
244
+	CreateTime    time.Time `gorm:"column:create_time" json:"create_time"`
245
+	Sjscsj        time.Time `gorm:"column:sjscsj" json:"sjscsj"`
246
+	Mj            string    `gorm:"column:mj" json:"mj"`
247
+	Xgbz          int64     `gorm:"column:xgbz" json:"xgbz"`
248
+	Ylyl1         string    `gorm:"column:ylyl1" json:"ylyl1"`
249
+	Ylyl2         string    `gorm:"column:ylyl2" json:"ylyl2"`
250
+}
251
+
252
+func (TempHdOuthospital) TableName() string {
253
+	return "temp_hd_outhospital"
254
+}
255
+
256
+type DataUpload struct {
257
+	ID           int64 `gorm:"column:id" json:"id"`
258
+	ModuleType   int64 `gorm:"column:module_type" json:"module_type"`
259
+	OrgId        int64 `gorm:"column:org_id" json:"org_id"`
260
+	UploadDate   int64 `gorm:"column:upload_date" json:"upload_date"`
261
+	UploadStatus int64 `gorm:"column:upload_status" json:"upload_status"`
262
+	ReturnStatus int64 `gorm:"column:return_status" json:"return_status"`
263
+	UploadType   int64 `gorm:"column:upload_type" json:"upload_type"`
264
+}
265
+
266
+func (DataUpload) TableName() string {
267
+	return "data_upload"
268
+}
269
+
270
+type DataUploadConfig struct {
271
+	ID             int64  `gorm:"column:id" json:"id"`
272
+	OrgId          int64  `gorm:"column:org_id" json:"org_id"`
273
+	ProvinceId     int64  `gorm:"column:province_id" json:"province_id"`
274
+	CityId         int64  `gorm:"column:city_id" json:"city_id"`
275
+	GatewayAddress string `gorm:"column:gateway_address" json:"gateway_address"`
276
+	AppId          string `gorm:"column:app_id" json:"app_id"`
277
+	Key            string `gorm:"column:key" json:"key"`
278
+	Status         int64  `gorm:"column:status" json:"status"`
279
+	CreateTime     int64  `gorm:"column:create_time" json:"create_time"`
280
+	ModifyTime     int64  `gorm:"column:modify_time" json:"modify_time"`
281
+	TimeQuantum    int64  `gorm:"column:time_quantum" json:"time_quantum"`
282
+}
283
+
284
+func (DataUploadConfig) TableName() string {
285
+	return "data_upload_config"
286
+}
287
+
288
+type TempHdShift struct {
289
+	ID             int64     `gorm:"column:id" json:"id"`
290
+	PsId           string    `gorm:"column:ps_id" json:"ps_id"`
291
+	HospitalId     string    `gorm:"column:hospital_id" json:"hospital_id"`
292
+	PatientNk      string    `gorm:"column:patient_nk" json:"patient_nk"`
293
+	ScheduleDate   time.Time `gorm:"column:schedule_date" json:"schedule_date"`
294
+	ShiftType      string    `gorm:"column:shift_type" json:"shift_type"`
295
+	SickbedNo      string    `gorm:"column:sickbed_no" json:"sickbed_no"`
296
+	ScheduleStatus string    `gorm:"column:schedule_status" json:"schedule_status"`
297
+	CreateTime     time.Time `gorm:"column:create_time" json:"create_time"`
298
+	Sjscsj         time.Time `gorm:"column:sjscsj" json:"sjscsj"`
299
+	Mj             string    `gorm:"column:mj" json:"mj"`
300
+	Xgbz           int64     `gorm:"column:xgbz" json:"xgbz"`
301
+	Ylyl1          string    `gorm:"column:ylyl1" json:"ylyl1"`
302
+	Ylyl2          string    `gorm:"column:ylyl2" json:"ylyl2"`
303
+}
304
+
305
+func (TempHdShift) TableName() string {
306
+	return "temp_hd_shift"
307
+}
308
+
309
+type TempHdDoctorsAdvice struct {
310
+	ID               int64     `gorm:"column:id" json:"id"`
311
+	MedicalOrDerId   string    `gorm:"column:medical_or_der_id" json:"medical_or_der_id"`
312
+	HospitalId       string    `gorm:"column:hospital_id" json:"hospital_id"`
313
+	DialysisId       string    `gorm:"column:dialysis_id" json:"dialysis_id"`
314
+	OrderType        string    `gorm:"column:order_type" json:"order_type"`
315
+	RrtType          string    `gorm:"column:rrt_type" json:"rrt_type"`
316
+	PatientNk        string    `gorm:"column:patient_nk" json:"patient_nk"`
317
+	DialysisDuration int64     `gorm:"column:dialysis_duration" json:"dialysis_duration"`
318
+	BloodVol         int64     `gorm:"column:blood_vol" json:"blood_vol"`
319
+	DryWeigh         float64   `gorm:"column:dry_weigh" json:"dry_weigh"`
320
+	CreateTime       time.Time `gorm:"column:create_time" json:"create_time"`
321
+	Sjscsj           time.Time `gorm:"column:sjscsj" json:"sjscsj"`
322
+	Mj               string    `gorm:"column:mj" json:"mj"`
323
+	Xgbz             int64     `gorm:"column:xgbz" json:"xgbz"`
324
+	Ylyl1            string    `gorm:"column:ylyl1" json:"ylyl1"`
325
+	Ylyl2            string    `gorm:"column:ylyl2" json:"ylyl2"`
326
+}
327
+
328
+func (TempHdDoctorsAdvice) TableName() string {
329
+	return "temp_hd_doctors_advice"
330
+}
331
+
332
+type TempHdDialysis struct {
333
+	ID                    int64     `gorm:"column:id" json:"id"`
334
+	DialysisId            string    `gorm:"column:dialysis_id" json:"dialysis_id"`
335
+	HospitalId            string    `gorm:"column:hospital_id" json:"hospital_id"`
336
+	PatientNk             string    `gorm:"column:patient_nk" json:"patient_nk"`
337
+	PsId                  string    `gorm:"column:ps_id" json:"ps_id"`
338
+	DialysisDate          time.Time `gorm:"column:dialysis_date" json:"dialysis_date"`
339
+	SickbedNo             string    `gorm:"column:sickbed_no" json:"sickbed_no"`
340
+	DivisionId            string    `gorm:"column:division_id" json:"division_id"`
341
+	EquipmentId           string    `gorm:"column:equipment_id" json:"equipment_id"`
342
+	MixDalysis            string    `gorm:"column:mix_dalysis" json:"mix_dalysis"`
343
+	ActualufMl            int64     `gorm:"column:actualuf_ml" json:"actualuf_ml"`
344
+	Ufv                   int64     `gorm:"column:ufv" json:"ufv"`
345
+	TotalReplace          int64     `gorm:"column:total_replace" json:"total_replace"`
346
+	TotalTreatDuration    int64     `gorm:"column:total_treat_duration" json:"total_treat_duration"`
347
+	IsHospitalozation     string    `gorm:"column:is_hospitalozation" json:"is_hospitalozation"`
348
+	IsEmergency           string    `gorm:"column:is_emergency" json:"is_emergency"`
349
+	EmergencyReason       string    `gorm:"column:emergency_reason" json:"emergency_reason"`
350
+	IsPerioperativePeriod string    `gorm:"column:is_perioperative_period" json:"is_perioperative_period"`
351
+	BeforeSbp             int64     `gorm:"column:before_sbp" json:"before_sbp"`
352
+	BeforeDbp             int64     `gorm:"column:before_dbp" json:"before_dbp"`
353
+	AfterSbp              int64     `gorm:"column:after_sbp" json:"after_sbp"`
354
+	AfterDbp              int64     `gorm:"column:after_dbp" json:"after_dbp"`
355
+	BeforeWeight          float64   `gorm:"column:before_weight" json:"before_weight"`
356
+	AfterWeight           float64   `gorm:"column:after_weight" json:"after_weight"`
357
+	AccessId              string    `gorm:"column:access_id" json:"access_id"`
358
+	DialyzerId            string    `gorm:"column:dialyzer_id" json:"dialyzer_id"`
359
+	Ktv                   float64   `gorm:"column:ktv" json:"ktv"`
360
+	StartTime             time.Time `gorm:"column:start_time" json:"start_time"`
361
+	EndTime               time.Time `gorm:"column:end_time" json:"end_time"`
362
+	CreateTime            time.Time `gorm:"column:create_time" json:"create_time"`
363
+	Sjscsj                time.Time `gorm:"column:sjscsj" json:"sjscsj"`
364
+	Mj                    string    `gorm:"column:mj" json:"mj"`
365
+	Xgbz                  int64     `gorm:"column:xgbz" json:"xgbz"`
366
+	Ylyl1                 string    `gorm:"column:ylyl1" json:"ylyl1"`
367
+	Ylyl2                 string    `gorm:"column:ylyl2" json:"ylyl2"`
368
+}
369
+
370
+func (TempHdDialysis) TableName() string {
371
+	return "temp_hd_dialysis"
372
+}
373
+
374
+type TempHdMiddle struct {
375
+	ID             int64     `gorm:"column:id" json:"id"`
376
+	Sn             string    `gorm:"column:sn" json:"sn"`
377
+	HospitalId     string    `gorm:"column:hospital_id" json:"hospital_id"`
378
+	PatientNk      string    `gorm:"column:patient_nk" json:"patient_nk"`
379
+	DialysisId     string    `gorm:"column:dialysis_id" json:"dialysis_id"`
380
+	MonitorTime    time.Time `gorm:"column:monitor_time" json:"monitor_time"`
381
+	Sbp            int64     `gorm:"column:sbp" json:"sbp"`
382
+	Dbp            int64     `gorm:"column:dbp" json:"dbp"`
383
+	P              int64     `gorm:"column:p" json:"p"`
384
+	Ns             int64     `gorm:"column:ns" json:"ns"`
385
+	Qb             int64     `gorm:"column:qb" json:"qb"`
386
+	Ap             int64     `gorm:"column:ap" json:"ap"`
387
+	Vp             int64     `gorm:"column:vp" json:"vp"`
388
+	Tmp            int64     `gorm:"column:tmp" json:"tmp"`
389
+	Ufr            int64     `gorm:"column:ufr" json:"ufr"`
390
+	Ufv            int64     `gorm:"column:ufv" json:"ufv"`
391
+	OnLine         int64     `gorm:"column:on_line" json:"on_line"`
392
+	Spo2           float64   `gorm:"column:spo2" json:"spo2"`
393
+	R              int64     `gorm:"column:r" json:"r"`
394
+	OtherSituation string    `gorm:"column:other_situation" json:"other_situation"`
395
+	Nurse          string    `gorm:"column:nurse" json:"nurse"`
396
+	CreateTime     time.Time `gorm:"column:create_time" json:"create_time"`
397
+	Sjscsj         time.Time `gorm:"column:sjscsj" json:"sjscsj"`
398
+	Mj             string    `gorm:"column:mj" json:"mj"`
399
+	Xgbz           int64     `gorm:"column:xgbz" json:"xgbz"`
400
+	Ylyl1          string    `gorm:"column:ylyl1" json:"ylyl1"`
401
+	Ylyl2          string    `gorm:"column:ylyl2" json:"ylyl2"`
402
+}
403
+
404
+func (TempHdMiddle) TableName() string {
405
+	return "temp_hd_middle"
406
+}
407
+
408
+type TempHdDivision struct {
409
+	ID           int64     `gorm:"column:id" json:"id"`
410
+	DivisionId   string    `gorm:"column:division_id" json:"division_id"`
411
+	HospitalId   string    `gorm:"column:hospital_id" json:"hospital_id"`
412
+	DevisionName string    `gorm:"column:devision_name" json:"devision_name"`
413
+	UpdateFlag   string    `gorm:"column:update_flag" json:"update_flag"`
414
+	UpdateTime   time.Time `gorm:"column:update_time" json:"update_time"`
415
+	CreateTime   time.Time `gorm:"column:create_time" json:"create_time"`
416
+	Sjscsj       time.Time `gorm:"column:sjscsj" json:"sjscsj"`
417
+	Mj           string    `gorm:"column:mj" json:"mj"`
418
+	Xgbz         int64     `gorm:"column:xgbz" json:"xgbz"`
419
+	Ylyl1        string    `gorm:"column:ylyl1" json:"ylyl1"`
420
+	Ylyl2        string    `gorm:"column:ylyl2" json:"ylyl2"`
421
+}
422
+
423
+func (TempHdDivision) TableName() string {
424
+	return "temp_hd_division"
425
+}

+ 22 - 0
routers/router.go Zobrazit soubor

@@ -0,0 +1,22 @@
1
+package routers
2
+
3
+import (
4
+	admin_api "Data_Upload_Api/controllers/admin_api_controllers"
5
+	"github.com/astaxie/beego"
6
+	"github.com/astaxie/beego/plugins/cors"
7
+)
8
+
9
+func init() {
10
+	beego.InsertFilter("*", beego.BeforeRouter, cors.Allow(&cors.Options{
11
+		// AllowAllOrigins:  true,
12
+		AllowOrigins:     []string{"http://api.szjkhd.com", "http://admin.xt.test.szjkhd.com", "http://admin.xt.szjkhd.com", "http://localhost:9527"},
13
+		AllowMethods:     []string{"GET", "POST", "PUT", "DELETE", "OPTIONS"},
14
+		AllowHeaders:     []string{"Origin", "Authorization", "Access-Control-Allow-Origin", "Access-Control-Allow-Headers", "Content-Type"},
15
+		ExposeHeaders:    []string{"Content-Length", "Access-Control-Allow-Origin", "Access-Control-Allow-Headers", "Content-Type"},
16
+		AllowCredentials: true,
17
+	}))
18
+
19
+	// beego.Router("/", &controllers.MainController{})
20
+
21
+	admin_api.AdminAPIControllersRegisterRouters()
22
+}

Diff nebyl zobrazen, protože je příliš veliký
+ 1253 - 0
service/city/auto_create_week_schedules_service.go


+ 150 - 0
service/city_data_uoload_service.go Zobrazit soubor

@@ -0,0 +1,150 @@
1
+// 统计后台的 service
2
+
3
+package service
4
+
5
+import (
6
+	"Data_Upload_Api/models"
7
+	"Data_Upload_Api/models/sz"
8
+
9
+	"github.com/jinzhu/gorm"
10
+	"strings"
11
+)
12
+
13
+func FindAllDataUploadConfigOrgInfo(province_id int64, city_id int64, config_type int64) (data []*sz.DataUploadConfig, err error) {
14
+
15
+	err = readDb.Model(&sz.DataUploadConfig{}).Where("status = 1 AND province_id = ? AND city_id = ? AND config_type = ?", province_id, city_id, config_type).Find(&data).Error
16
+	return
17
+}
18
+
19
+func FindDataUploadOrgInfo(org_id int64, module_type int64) (data sz.DataUpload, err error) {
20
+	err = readDb.Model(&sz.DataUpload{}).Where(" org_id = ? AND module_type = ?", org_id, module_type).Last(&data).Error
21
+	return
22
+}
23
+
24
+func FindOrgData(org_id int64) (org models.UserOrg, err error) {
25
+	err = readUserDb.Model(&models.UserOrg{}).Where("status = 1 AND id = ?", org_id).Preload("DeviceNumber", func(db *gorm.DB) *gorm.DB {
26
+		return readDb.Where("status = 1")
27
+	}).Find(&org).Error
28
+	return
29
+}
30
+func FindOrgRolesData(org_id int64, lastUploadTime int64, nowTime int64) (role []*models.UserAdminRole, err error) {
31
+	db := readUserDb.Model(&models.UserAdminRole{}).Where("status = 1 AND org_id = ?  ", org_id)
32
+	if lastUploadTime != 0 && nowTime != 0 {
33
+		db.Where("ctime >= ? AND ctime <= ?", lastUploadTime, nowTime)
34
+	}
35
+	err = db.Find(&role).Error
36
+	return
37
+}
38
+func FindOrgPatientData(org_id int64, lastUploadTime int64, nowTime int64) (patient []*models.Patients, err error) {
39
+	db := readDb.Model(&models.Patients{}).Where("status = 1 AND user_org_id = ?", org_id)
40
+	if lastUploadTime != 0 && nowTime != 0 {
41
+		db = db.Where("created_time >= ? AND created_time <= ?", lastUploadTime, nowTime)
42
+	}
43
+	err = db.Find(&patient).Error
44
+
45
+	return
46
+}
47
+
48
+func FindOrgPatientOutData(org_id int64, lastUploadTime int64, nowTime int64) (patient []*models.Patients, err error) {
49
+	db := readDb.Model(&models.Patients{}).Where("status = 1 AND user_org_id = ? AND lapseto = 2 ", org_id).Preload("PatientLapseto", "status = 1")
50
+	if lastUploadTime != 0 && nowTime != 0 {
51
+		db = db.Where("created_time >= ? AND created_time <= ?", lastUploadTime, nowTime)
52
+	}
53
+	err = db.Find(&patient).Error
54
+	return
55
+}
56
+
57
+func FindOrgScheduleData(org_id int64, lastUploadTime int64, nowTime int64) (sch []*models.Schedule, err error) {
58
+	db := readDb.Model(&models.Schedule{}).Where("status = 1 AND user_org_id = ?", org_id).Preload("DeviceNumber", "status = 1")
59
+
60
+	if lastUploadTime != 0 && nowTime != 0 {
61
+		db = db.Where("created_time >= ? AND created_time <= ?", lastUploadTime, nowTime)
62
+	}
63
+	err = db.Find(&sch).Error
64
+	return
65
+}
66
+
67
+func FindOrgDialysisPrescriptionData(org_id int64, lastUploadTime int64, nowTime int64) (ps []*models.DialysisPrescription, err error) {
68
+	db := readDb.Model(&models.DialysisPrescription{}).Where("status = 1 AND user_org_id = ?", org_id).Preload("AssessmentBeforeDislysis", "status = 1").Preload("DialysisOrder", "status = 1")
69
+	if lastUploadTime != 0 && nowTime != 0 {
70
+		db = db.Where("created_time >= ? AND created_time <= ?", lastUploadTime, nowTime)
71
+	}
72
+	err = db.Find(&ps).Error
73
+	return
74
+}
75
+
76
+func FindOrgMonitorRecordData(org_id int64, lastUploadTime int64, nowTime int64) (monitor []*models.MonitoringRecord, err error) {
77
+	db := readDb.Model(&models.MonitoringRecord{}).Where("status = 1 AND user_org_id = ?", org_id)
78
+
79
+	if lastUploadTime != 0 && nowTime != 0 {
80
+		db = db.Where("created_time >= ? AND created_time <= ?", lastUploadTime, nowTime)
81
+	}
82
+	err = db.Find(&monitor).Error
83
+
84
+	return
85
+}
86
+
87
+func CreateOrgRecord(hospital *sz.TempHdHospital) (err error) {
88
+	err = writeDb.Model(&sz.TempHdHospital{}).Create(&hospital).Error
89
+	return
90
+}
91
+
92
+func CreateUploadRecord(upload *sz.DataUpload) (err error) {
93
+	err = writeDb.Model(&sz.DataUpload{}).Create(&upload).Error
94
+	return
95
+}
96
+
97
+func BatchCreateStaffRecord(staffs []*sz.TempHdStaff) (err error) {
98
+	if len(staffs) > 0 {
99
+		utx := writeDb.Begin()
100
+		if len(staffs) > 0 {
101
+			thisSQL := "INSERT INTO temp_hd_staff (hospital_id, staff_id, staff_name, position, permanent_type,create_time,update_time,sjscsj,mj) VALUES "
102
+			insertParams := make([]string, 0)
103
+			insertData := make([]interface{}, 0)
104
+			for _, info := range staffs {
105
+				insertParams = append(insertParams, "(?,?,?,?,?,?,?,?,?)")
106
+				insertData = append(insertData, info.HospitalId)
107
+				insertData = append(insertData, info.StaffId)
108
+				insertData = append(insertData, info.StaffName)
109
+				insertData = append(insertData, info.Position)
110
+				insertData = append(insertData, info.PermanentType)
111
+				insertData = append(insertData, info.CreateTime)
112
+				insertData = append(insertData, info.UpdateTime)
113
+				insertData = append(insertData, info.Sjscsj)
114
+				insertData = append(insertData, info.Xgbz)
115
+			}
116
+			thisSQL += strings.Join(insertParams, ", ")
117
+			err = utx.Exec(thisSQL, insertData...).Error
118
+			if err != nil {
119
+				utx.Rollback()
120
+				return
121
+			}
122
+		}
123
+		utx.Commit()
124
+	}
125
+	return
126
+}
127
+func FindOrgDialysisData(org_id int64, lastUploadTime int64, nowTime int64) (ps []*models.VMSchedule, err error) {
128
+	db := readDb.Model(&models.VMSchedule{}).Where("status = 1 AND user_org_id = ? ", org_id).
129
+		Preload("DeviceNumber", "status = 1").
130
+		Preload("VMDialysisPrescription", "status = 1").
131
+		Preload("AssessmentBeforeDislysis", "status = 1").
132
+		Preload("AssessmentAfterDislysis", "status = 1").
133
+		Preload("DialysisOrder", "status = 1").
134
+		Preload("MonitoringRecord", "status = 1")
135
+
136
+	if lastUploadTime != 0 && nowTime != 0 {
137
+		db = db.Where("created_time >= ? AND created_time <= ?", lastUploadTime, nowTime)
138
+	}
139
+	err = db.Find(&ps).Error
140
+	return
141
+}
142
+func FindOrgDeviceZoneRecordData(org_id int64, lastUploadTime int64, nowTime int64) (zone []*models.DeviceZone, err error) {
143
+	db := readDb.Model(&models.DeviceZone{}).Where("status = 1 AND  org_id = ?", org_id)
144
+	if lastUploadTime != 0 && nowTime != 0 {
145
+		db = db.Where("ctime >= ? AND ctime <= ?", lastUploadTime, nowTime)
146
+	}
147
+	err = db.Find(&zone).Error
148
+
149
+	return
150
+}

+ 119 - 0
service/db.go Zobrazit soubor

@@ -0,0 +1,119 @@
1
+// Pipe - A small and beautiful blogging platform written in golang.
2
+// Copyright (C) 2017-2018, b3log.org
3
+//
4
+// This program is free software: you can redistribute it and/or modify
5
+// it under the terms of the GNU General Public License as published by
6
+// the Free Software Foundation, either version 3 of the License, or
7
+// (at your option) any later version.
8
+//
9
+// This program is distributed in the hope that it will be useful,
10
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
11
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
+// GNU General Public License for more details.
13
+//
14
+// You should have received a copy of the GNU General Public License
15
+// along with this program.  If not, see <http://www.gnu.org/licenses/>.
16
+
17
+package service
18
+
19
+import (
20
+	"fmt"
21
+	"github.com/astaxie/beego"
22
+	"github.com/jinzhu/gorm"
23
+	_ "github.com/jinzhu/gorm/dialects/mysql" // mysql
24
+)
25
+
26
+var readDb *gorm.DB
27
+var writeDb *gorm.DB
28
+var readUserDb *gorm.DB
29
+var writeUserDb *gorm.DB
30
+
31
+var err error
32
+
33
+func ConnectDB() {
34
+	readHost := beego.AppConfig.String("readmysqlhost")
35
+	readPort := beego.AppConfig.String("readmysqlport")
36
+	readUser := beego.AppConfig.String("readmysqluser")
37
+	readPass := beego.AppConfig.String("readmysqlpass")
38
+	readName := beego.AppConfig.String("readmysqlname")
39
+
40
+	writeHost := beego.AppConfig.String("writemysqlhost")
41
+	writePort := beego.AppConfig.String("writemysqlport")
42
+	writeUser := beego.AppConfig.String("writemysqluser")
43
+	writePass := beego.AppConfig.String("writemysqlpass")
44
+	writeName := beego.AppConfig.String("writemysqlname")
45
+
46
+	readUserHost := beego.AppConfig.String("readuserhost")
47
+	readUserPort := beego.AppConfig.String("readuserport")
48
+	readUserUser := beego.AppConfig.String("readuseruser")
49
+	readUserPass := beego.AppConfig.String("readuserpass")
50
+	readUserName := beego.AppConfig.String("readusername")
51
+
52
+	writeUserHost := beego.AppConfig.String("writeuserhost")
53
+	writeUserPort := beego.AppConfig.String("writeuserport")
54
+	writeUserUser := beego.AppConfig.String("writeuseruser")
55
+	writeUserPass := beego.AppConfig.String("writeuserpass")
56
+	writeUserName := beego.AppConfig.String("writeusername")
57
+
58
+	rdsn := fmt.Sprintf("%s:%s@tcp(%s:%s)/%s?charset=utf8mb4&parseTime=true", readUser, readPass, readHost, readPort, readName)
59
+	wdsn := fmt.Sprintf("%s:%s@tcp(%s:%s)/%s?charset=utf8mb4&parseTime=true", writeUser, writePass, writeHost, writePort, writeName)
60
+
61
+	rudsn := fmt.Sprintf("%s:%s@tcp(%s:%s)/%s?charset=utf8mb4&parseTime=true", readUserUser, readUserPass, readUserHost, readUserPort, readUserName)
62
+	wudsn := fmt.Sprintf("%s:%s@tcp(%s:%s)/%s?charset=utf8mb4&parseTime=true", writeUserUser, writeUserPass, writeUserHost, writeUserPort, writeUserName)
63
+
64
+	readDb, err = gorm.Open("mysql", rdsn)
65
+
66
+	//defer readDb.Close()
67
+	if err != nil {
68
+		//beego.Error(err)
69
+	}
70
+	readDb.DB().SetMaxIdleConns(5)
71
+	readDb.DB().SetMaxOpenConns(20)
72
+	readDb.LogMode(true)
73
+
74
+	writeDb, err = gorm.Open("mysql", wdsn)
75
+	if err != nil {
76
+		//beego.Error(err)
77
+	}
78
+
79
+	//defer writeDb.Close()
80
+
81
+	writeDb.DB().SetMaxIdleConns(5)
82
+	writeDb.DB().SetMaxOpenConns(20)
83
+	writeDb.LogMode(true)
84
+
85
+	readUserDb, err = gorm.Open("mysql", rudsn)
86
+	if err != nil {
87
+		//beego.Error(err)
88
+	}
89
+
90
+	//defer readUserDb.Close()
91
+
92
+	readUserDb.DB().SetMaxIdleConns(5)
93
+	readUserDb.DB().SetMaxOpenConns(20)
94
+	readUserDb.LogMode(true)
95
+
96
+	writeUserDb, err = gorm.Open("mysql", wudsn)
97
+	if err != nil {
98
+		//beego.Error(err)
99
+	}
100
+	//defer writeUserDb.Close()
101
+
102
+	writeUserDb.DB().SetMaxIdleConns(5)
103
+	writeUserDb.DB().SetMaxOpenConns(20)
104
+	writeUserDb.LogMode(true)
105
+
106
+}
107
+
108
+func XTReadDB() *gorm.DB {
109
+	return readDb
110
+}
111
+func XTWriteDB() *gorm.DB {
112
+	return writeDb
113
+}
114
+func UserReadDB() *gorm.DB {
115
+	return readUserDb
116
+}
117
+func UserWriteDB() *gorm.DB {
118
+	return writeUserDb
119
+}

binární
static/1.jpg Zobrazit soubor


binární
static/2.jpg Zobrazit soubor


binární
static/5.jpg Zobrazit soubor


+ 1 - 0
static/js/reload.min.js Zobrazit soubor

@@ -0,0 +1 @@
1
+function b(a){var c=new WebSocket(a);c.onclose=function(){setTimeout(function(){b(a)},2E3)};c.onmessage=function(){location.reload()}}try{if(window.WebSocket)try{b("ws://localhost:12450/reload")}catch(a){console.error(a)}else console.log("Your browser does not support WebSockets.")}catch(a){console.error("Exception during connecting to Reload:",a)};

+ 37 - 0
tests/default_test.go Zobrazit soubor

@@ -0,0 +1,37 @@
1
+package test
2
+
3
+import (
4
+	_ "XT/routers"
5
+	"net/http"
6
+	"net/http/httptest"
7
+	"path/filepath"
8
+	"runtime"
9
+	"testing"
10
+
11
+	"github.com/astaxie/beego"
12
+	. "github.com/smartystreets/goconvey/convey"
13
+)
14
+
15
+func init() {
16
+	_, file, _, _ := runtime.Caller(1)
17
+	apppath, _ := filepath.Abs(filepath.Dir(filepath.Join(file, ".."+string(filepath.Separator))))
18
+	beego.TestBeegoInit(apppath)
19
+}
20
+
21
+// TestBeego is a sample to run an endpoint test
22
+func TestBeego(t *testing.T) {
23
+	r, _ := http.NewRequest("GET", "/", nil)
24
+	w := httptest.NewRecorder()
25
+	beego.BeeApp.Handlers.ServeHTTP(w, r)
26
+
27
+	beego.Trace("testing", "TestBeego", "Code[%d]\n%s", w.Code, w.Body.String())
28
+
29
+	Convey("Subject: Test Station Endpoint\n", t, func() {
30
+		Convey("Status Code Should Be 200", func() {
31
+			So(w.Code, ShouldEqual, 200)
32
+		})
33
+		Convey("The Result Should Not Be Empty", func() {
34
+			So(w.Body.Len(), ShouldBeGreaterThan, 0)
35
+		})
36
+	})
37
+}

+ 13 - 0
utils/ip_helper.go Zobrazit soubor

@@ -0,0 +1,13 @@
1
+package utils
2
+
3
+import (
4
+	"net/http"
5
+)
6
+
7
+func GetIP(r *http.Request) string {
8
+	ip := r.Header.Get("X-Forwarded-For")
9
+	if ip == "" {
10
+		ip = r.RemoteAddr
11
+	}
12
+	return ip
13
+}

+ 66 - 0
utils/log.go Zobrazit soubor

@@ -0,0 +1,66 @@
1
+package utils
2
+
3
+import (
4
+	"fmt"
5
+	"time"
6
+)
7
+
8
+const (
9
+	color_red = uint8(iota + 91)
10
+	color_green
11
+	color_yellow
12
+	color_blue
13
+	color_magenta //洋红
14
+
15
+	// info = "[INFO]"
16
+	// trac = "[TRAC]"
17
+	// erro = "[ERRO]"
18
+	// warn = "[WARN]"
19
+	// succ = "[SUCC]"
20
+)
21
+
22
+// 根据 https://github.com/liyu4/chill 修改的
23
+// see complete color rules in document in https://en.wikipedia.org/wiki/ANSI_escape_code#cite_note-ecma48-13
24
+func TraceLog(format string, a ...interface{}) {
25
+	fmt.Println(formatLog(yellow(fmt.Sprintf(format, a...))))
26
+}
27
+
28
+func InfoLog(format string, a ...interface{}) {
29
+	fmt.Println(formatLog(blue(fmt.Sprintf(format, a...))))
30
+}
31
+
32
+func SuccessLog(format string, a ...interface{}) {
33
+	fmt.Println(formatLog(green(fmt.Sprintf(format, a...))))
34
+}
35
+
36
+func WarningLog(format string, a ...interface{}) {
37
+	fmt.Println(formatLog(magenta(fmt.Sprintf(format, a...))))
38
+}
39
+
40
+func ErrorLog(format string, a ...interface{}) {
41
+	fmt.Println(formatLog(red(fmt.Sprintf(format, a...))))
42
+}
43
+
44
+func red(s string) string {
45
+	return fmt.Sprintf("\x1b[%dm%s\x1b[0m", color_red, s)
46
+}
47
+
48
+func green(s string) string {
49
+	return fmt.Sprintf("\x1b[%dm%s\x1b[0m", color_green, s)
50
+}
51
+
52
+func yellow(s string) string {
53
+	return fmt.Sprintf("\x1b[%dm%s\x1b[0m", color_yellow, s)
54
+}
55
+
56
+func blue(s string) string {
57
+	return fmt.Sprintf("\x1b[%dm%s\x1b[0m", color_blue, s)
58
+}
59
+
60
+func magenta(s string) string {
61
+	return fmt.Sprintf("\x1b[%dm%s\x1b[0m", color_magenta, s)
62
+}
63
+
64
+func formatLog(prefix string) string {
65
+	return time.Now().Format("[2006/01/02 15:04:05]") + " " + prefix + " "
66
+}

+ 191 - 0
utils/paginator.go Zobrazit soubor

@@ -0,0 +1,191 @@
1
+// Copyright 2013 wetalk authors
2
+//
3
+// Licensed under the Apache License, Version 2.0 (the "License"): you may
4
+// not use this file except in compliance with the License. You may obtain
5
+// a copy of the License at
6
+//
7
+//     http://www.apache.org/licenses/LICENSE-2.0
8
+//
9
+// Unless required by applicable law or agreed to in writing, software
10
+// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11
+// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12
+// License for the specific language governing permissions and limitations
13
+// under the License.
14
+
15
+package utils
16
+
17
+import (
18
+	"math"
19
+	"net/http"
20
+	"net/url"
21
+	"strconv"
22
+)
23
+
24
+type Paginator struct {
25
+	Request     *http.Request
26
+	PerPageNums int
27
+	MaxPages    int
28
+
29
+	nums      int64
30
+	pageRange []int
31
+	pageNums  int
32
+	page      int
33
+}
34
+
35
+func (p *Paginator) PageNums() int {
36
+	if p.pageNums != 0 {
37
+		return p.pageNums
38
+	}
39
+	pageNums := math.Ceil(float64(p.nums) / float64(p.PerPageNums))
40
+	if p.MaxPages > 0 {
41
+		pageNums = math.Min(pageNums, float64(p.MaxPages))
42
+	}
43
+	p.pageNums = int(pageNums)
44
+	return p.pageNums
45
+}
46
+
47
+func (p *Paginator) Nums() int64 {
48
+	return p.nums
49
+}
50
+
51
+func (p *Paginator) SetNums(nums int64) {
52
+	p.nums = nums
53
+}
54
+
55
+func (p *Paginator) Page() int {
56
+	if p.page != 0 {
57
+		return p.page
58
+	}
59
+	if p.Request.Form == nil {
60
+		p.Request.ParseForm()
61
+	}
62
+	p.page, _ = strconv.Atoi(p.Request.Form.Get("page"))
63
+	if p.page > p.PageNums() {
64
+		p.page = p.PageNums()
65
+	}
66
+	if p.page <= 0 {
67
+		p.page = 1
68
+	}
69
+	return p.page
70
+}
71
+
72
+func (p *Paginator) Pages() []int {
73
+	if p.pageRange == nil && p.nums > 0 {
74
+		var pages []int
75
+		pageNums := p.PageNums()
76
+		page := p.Page()
77
+		switch {
78
+		case page >= pageNums-4 && pageNums > 9:
79
+			start := pageNums - 9 + 1
80
+			pages = make([]int, 9)
81
+			for i, _ := range pages {
82
+				pages[i] = start + i
83
+			}
84
+		case page >= 5 && pageNums > 9:
85
+			start := page - 5 + 1
86
+			pages = make([]int, int(math.Min(9, float64(page+4+1))))
87
+			for i, _ := range pages {
88
+				pages[i] = start + i
89
+			}
90
+		default:
91
+			pages = make([]int, int(math.Min(9, float64(pageNums))))
92
+			for i, _ := range pages {
93
+				pages[i] = i + 1
94
+			}
95
+		}
96
+		p.pageRange = pages
97
+	}
98
+	return p.pageRange
99
+}
100
+
101
+func (p *Paginator) PageLink(page int) string {
102
+	link, _ := url.ParseRequestURI(p.Request.RequestURI)
103
+	values := link.Query()
104
+	if page == 1 {
105
+		values.Del("page")
106
+	} else {
107
+		values.Set("page", strconv.Itoa(page))
108
+	}
109
+	link.RawQuery = values.Encode()
110
+	return link.String()
111
+}
112
+
113
+func (p *Paginator) PageParams() url.Values {
114
+	link, _ := url.ParseRequestURI(p.Request.RequestURI)
115
+	values := link.Query()
116
+	values.Del("page")
117
+	return values
118
+}
119
+
120
+func (p *Paginator) BasePageLink() string {
121
+	link, _ := url.ParseRequestURI(p.Request.RequestURI)
122
+	values := link.Query()
123
+	values.Del("page")
124
+	link.RawQuery = values.Encode()
125
+	return link.String()
126
+}
127
+
128
+func (p *Paginator) PageLinkPrev() (link string) {
129
+	if p.HasPrev() {
130
+		link = p.PageLink(p.Page() - 1)
131
+	}
132
+	return
133
+}
134
+
135
+func (p *Paginator) PageLinkNext() (link string) {
136
+	if p.HasNext() {
137
+		link = p.PageLink(p.Page() + 1)
138
+	}
139
+	return
140
+}
141
+
142
+func (p *Paginator) PageLinkFirst() (link string) {
143
+	return p.PageLink(1)
144
+}
145
+
146
+func (p *Paginator) PageLinkLast() (link string) {
147
+	return p.PageLink(p.PageNums())
148
+}
149
+
150
+func (p *Paginator) HasPrev() bool {
151
+	return p.Page() > 1
152
+}
153
+
154
+func (p *Paginator) HasNext() bool {
155
+	return p.Page() < p.PageNums()
156
+}
157
+
158
+func (p *Paginator) IsActive(page int) bool {
159
+	return p.Page() == page
160
+}
161
+
162
+func (p *Paginator) Offset() int {
163
+	return (p.Page() - 1) * p.PerPageNums
164
+}
165
+
166
+func (p *Paginator) HasPages() bool {
167
+	return p.PageNums() > 1
168
+}
169
+
170
+func (p *Paginator) Total() int {
171
+	return p.PageNums()
172
+}
173
+func (p *Paginator) TotalSubOne() int {
174
+	return p.PageNums() - 1
175
+}
176
+
177
+func NewPaginator(req *http.Request, per int, nums int64) *Paginator {
178
+	p := Paginator{}
179
+	p.Request = req
180
+	if per <= 0 {
181
+		per = 10
182
+	}
183
+	p.PerPageNums = per
184
+	p.SetNums(nums)
185
+	return &p
186
+}
187
+
188
+func FakePaginator(currentPage int, per int, nums int64) *Paginator {
189
+	fakeReq, _ := http.NewRequest("GET", "/?page="+strconv.Itoa(currentPage), nil)
190
+	return NewPaginator(fakeReq, per, nums)
191
+}

+ 75 - 0
utils/regex_helper.go Zobrazit soubor

@@ -0,0 +1,75 @@
1
+package utils
2
+
3
+import (
4
+	"fmt"
5
+	"regexp"
6
+)
7
+
8
+// 正整数正则
9
+func PositiveIntegerRegexp() *regexp.Regexp {
10
+	reg, _ := regexp.Compile("^[1-9][0-9]*$")
11
+	return reg
12
+}
13
+
14
+// 手机号正则 不那么严谨的
15
+func CellPhoneRegexp() *regexp.Regexp {
16
+	reg, _ := regexp.Compile("^1\\d{10}$")
17
+	return reg
18
+}
19
+
20
+// 固话正则
21
+func TelPhoneRegexp() *regexp.Regexp {
22
+	// reg, _ := regexp.Compile("^0\\d{2,3}-?\\d{7,8}$")
23
+	reg, _ := regexp.Compile("^0\\d{2,3}-?\\d{7,8}$")
24
+	return reg
25
+}
26
+
27
+// 手机号或固话正则
28
+func PhoneRegexp() *regexp.Regexp {
29
+	reg, _ := regexp.Compile("^(0\\d{2,3}-?\\d{7,8}$)|(1\\d{10}$)")
30
+	return reg
31
+}
32
+
33
+// tests
34
+func PositiveIntegerRegexpTest() {
35
+	reg := PositiveIntegerRegexp()
36
+	fmt.Println("12 是否匹配:", reg.MatchString("12"))
37
+	fmt.Println("1 是否匹配:", reg.MatchString("1"))
38
+	fmt.Println("980030 是否匹配:", reg.MatchString("980030"))
39
+	fmt.Println("01 是否匹配:", reg.MatchString("01"))
40
+	fmt.Println("asd1asd 是否匹配:", reg.MatchString("asd1asd"))
41
+	fmt.Println("a12 是否匹配:", reg.MatchString("a12"))
42
+	fmt.Println("12a 是否匹配:", reg.MatchString("12a"))
43
+	fmt.Println("-12 是否匹配:", reg.MatchString("-12"))
44
+	fmt.Println("12.1 是否匹配:", reg.MatchString("12.1"))
45
+	fmt.Println("14j2a 是否匹配:", reg.MatchString("14j2a"))
46
+}
47
+
48
+func CellPhoneRegexpTest() {
49
+	reg := CellPhoneRegexp()
50
+	fmt.Println("13632250447 是否匹配:", reg.MatchString("13632250447"))
51
+	fmt.Println("12000000000 是否匹配:", reg.MatchString("12000000000"))
52
+	fmt.Println("30001212325 是否匹配:", reg.MatchString("30001212325"))
53
+	fmt.Println("1233123 是否匹配:", reg.MatchString("1233123"))
54
+	fmt.Println("123312312344 是否匹配:", reg.MatchString("123312312344"))
55
+	fmt.Println("13345678a12 是否匹配:", reg.MatchString("13345678a12"))
56
+	fmt.Println("a13345678a1 是否匹配:", reg.MatchString("a13345678a1"))
57
+	fmt.Println("1334a678a12 是否匹配:", reg.MatchString("1334a678a12"))
58
+	fmt.Println("1345678a12a 是否匹配:", reg.MatchString("1345678a12a"))
59
+	fmt.Println("aqwertyuioo 是否匹配:", reg.MatchString("aqwertyuioo"))
60
+}
61
+
62
+func TelPhoneRegexpTest() {
63
+	reg := TelPhoneRegexp()
64
+	fmt.Println("020-39006917 是否匹配:", reg.MatchString("020-39006917"))
65
+	fmt.Println("02039006917 是否匹配:", reg.MatchString("02039006917"))
66
+	fmt.Println("0754-5916612 是否匹配:", reg.MatchString("0754-5916612"))
67
+	fmt.Println("07545916612 是否匹配:", reg.MatchString("07545916612"))
68
+	fmt.Println("123-39006917 是否匹配:", reg.MatchString("123-39006917"))
69
+	fmt.Println("1754-5916612 是否匹配:", reg.MatchString("1754-5916612"))
70
+	fmt.Println("0a0-39006917 是否匹配:", reg.MatchString("0a0-39006917"))
71
+	fmt.Println("0a039006917 是否匹配:", reg.MatchString("0a039006917"))
72
+	fmt.Println("010-39s06917 是否匹配:", reg.MatchString("010-39s06917"))
73
+	fmt.Println("020-390069171 是否匹配:", reg.MatchString("020-390069171"))
74
+	fmt.Println("020-3900691 是否匹配:", reg.MatchString("020-3900691"))
75
+}

+ 115 - 0
utils/stringtool.go Zobrazit soubor

@@ -0,0 +1,115 @@
1
+package utils
2
+
3
+import (
4
+	"bytes"
5
+	"crypto/aes"
6
+	"crypto/cipher"
7
+	"crypto/md5"
8
+	"encoding/base64"
9
+	"fmt"
10
+	"math/rand"
11
+	"strconv"
12
+	"strings"
13
+	"time"
14
+
15
+	"github.com/astaxie/beego"
16
+)
17
+
18
+// 将字符串加密成 md5
19
+func String2md5(str string) string {
20
+	data := []byte(str)
21
+	has := md5.Sum(data)
22
+	return fmt.Sprintf("%x", has) //将[]byte转成16进制
23
+}
24
+
25
+// RandomString 在数字、大写字母、小写字母范围内生成num位的随机字符串
26
+func RandomString(length int) string {
27
+	// 48 ~ 57 数字
28
+	// 65 ~ 90 A ~ Z
29
+	// 97 ~ 122 a ~ z
30
+	// 一共62个字符,在0~61进行随机,小于10时,在数字范围随机,
31
+	// 小于36在大写范围内随机,其他在小写范围随机
32
+	rand.Seed(time.Now().UnixNano())
33
+	result := make([]string, 0, length)
34
+	for i := 0; i < length; i++ {
35
+		t := rand.Intn(62)
36
+		if t < 10 {
37
+			result = append(result, strconv.Itoa(rand.Intn(10)))
38
+		} else if t < 36 {
39
+			result = append(result, string(rand.Intn(26)+65))
40
+		} else {
41
+			result = append(result, string(rand.Intn(26)+97))
42
+		}
43
+	}
44
+	return strings.Join(result, "")
45
+}
46
+
47
+func RandomNumberString(length int) string {
48
+	var str string
49
+	for i := 0; i < length; i++ {
50
+		rand.Seed(time.Now().UnixNano())
51
+		str += strconv.Itoa(rand.Intn(10))
52
+	}
53
+	return str
54
+}
55
+
56
+// AES加密
57
+func AESEncrypt(origin string) string {
58
+	aes_key := beego.AppConfig.String("aes_key")
59
+	fmt.Println(aes_key)
60
+	xpass, _ := _aesEncrypt([]byte(origin), []byte(aes_key))
61
+	fmt.Println(_aesEncrypt([]byte(origin), []byte(aes_key)))
62
+	fmt.Println(xpass)
63
+	pass64 := base64.StdEncoding.EncodeToString(xpass)
64
+	fmt.Println(pass64)
65
+	return pass64
66
+}
67
+
68
+func AESDecrypt(crypted []byte) string {
69
+	aes_key := beego.AppConfig.String("aes_key")
70
+	origData, err := _aesDecrypt(crypted, []byte(aes_key))
71
+	if err != nil {
72
+		return ""
73
+	}
74
+	return string(origData)
75
+}
76
+
77
+func _PKCS5Padding(ciphertext []byte, blockSize int) []byte {
78
+	padding := blockSize - len(ciphertext)%blockSize
79
+	padtext := bytes.Repeat([]byte{byte(padding)}, padding)
80
+	return append(ciphertext, padtext...)
81
+}
82
+
83
+func _PKCS5UnPadding(origData []byte) []byte {
84
+	length := len(origData)
85
+	unpadding := int(origData[length-1])
86
+	return origData[:(length - unpadding)]
87
+}
88
+
89
+func _aesEncrypt(origData, key []byte) ([]byte, error) {
90
+	block, err := aes.NewCipher(key)
91
+	if err != nil {
92
+		return nil, err
93
+	}
94
+
95
+	blockSize := block.BlockSize()
96
+	origData = _PKCS5Padding(origData, blockSize)
97
+	blockMode := cipher.NewCBCEncrypter(block, key[:blockSize])
98
+	crypted := make([]byte, len(origData))
99
+	blockMode.CryptBlocks(crypted, origData)
100
+	return crypted, nil
101
+}
102
+
103
+func _aesDecrypt(crypted, key []byte) ([]byte, error) {
104
+	block, err := aes.NewCipher(key)
105
+	if err != nil {
106
+		return nil, err
107
+	}
108
+
109
+	blockSize := block.BlockSize()
110
+	blockMode := cipher.NewCBCDecrypter(block, key[:blockSize])
111
+	origData := make([]byte, len(crypted))
112
+	blockMode.CryptBlocks(origData, crypted)
113
+	origData = _PKCS5UnPadding(origData)
114
+	return origData, nil
115
+}

+ 27 - 0
utils/time_helper.go Zobrazit soubor

@@ -0,0 +1,27 @@
1
+package utils
2
+
3
+import (
4
+	"time"
5
+)
6
+
7
+// day 当天凌晨0点
8
+func ZeroHourTimeOfDay(day time.Time) time.Time {
9
+	dayStr := day.Format("2006-01-02")
10
+	zeroHourTime, _ := ParseTimeStringToTime("2006-01-02", dayStr)
11
+	return *zeroHourTime
12
+}
13
+
14
+// day 当月一号凌晨0点
15
+func BeginningOfMonth(day time.Time) time.Time {
16
+	dayStr := day.Format("2006-01")
17
+	monthTime, _ := ParseTimeStringToTime("2006-01", dayStr)
18
+	return *monthTime
19
+}
20
+
21
+// 指定年月的月份的月初凌晨0点和月末23点59分59秒
22
+func MonthBeginningToEnd(year int, month int) (time.Time, time.Time) {
23
+	beginningOfMonth := time.Date(year, time.Month(month), 1, 0, 0, 0, 0, time.Local)
24
+	beginningOfNextMonth := beginningOfMonth.AddDate(0, 1, 0)
25
+	endOfMonth := beginningOfNextMonth.Add(time.Duration(-1))
26
+	return beginningOfMonth, endOfMonth
27
+}

+ 231 - 0
utils/tools.go Zobrazit soubor

@@ -0,0 +1,231 @@
1
+package utils
2
+
3
+import (
4
+	"crypto/sha1"
5
+	"encoding/base64"
6
+	"errors"
7
+	"fmt"
8
+	"io"
9
+	"math/rand"
10
+	"regexp"
11
+	"sort"
12
+	"strconv"
13
+	"strings"
14
+	"time"
15
+
16
+	"github.com/astaxie/beego"
17
+)
18
+
19
+func TimeSub(t1, t2 time.Time) int {
20
+	t1 = time.Date(t1.Year(), t1.Month(), t1.Day(), 0, 0, 0, 0, time.Local)
21
+	t2 = time.Date(t2.Year(), t2.Month(), t2.Day(), 0, 0, 0, 0, time.Local)
22
+
23
+	return int(t1.Sub(t2).Hours() / 24)
24
+}
25
+
26
+func MarkBackUrl(backUrl, defaultUrl string) string {
27
+	if len(backUrl) == 0 {
28
+		backUrl = defaultUrl
29
+	} else {
30
+		backURLByte, err := base64.URLEncoding.DecodeString(backUrl)
31
+		if err != nil {
32
+			backUrl = backUrl
33
+		} else {
34
+			backUrl = string(backURLByte)
35
+		}
36
+	}
37
+	return backUrl
38
+}
39
+
40
+func CheckMobile(mobile string) (match bool) {
41
+
42
+	//过滤手机
43
+	match, _ = regexp.MatchString("^1([358][0-9]|4[579]|66|7[0135678]|9[89])[0-9]{8}$", mobile)
44
+	return
45
+}
46
+
47
+func RandCode(min, max int64) string {
48
+	if min >= max || min == 0 || max == 0 {
49
+		return strconv.FormatInt(max, 10)
50
+	}
51
+	rand.Seed(time.Now().UnixNano())
52
+	randNum := rand.Int63n(max-min) + min
53
+	return strconv.FormatInt(randNum, 10)
54
+}
55
+
56
+func TimeAgo(timeUnix int64) string {
57
+	timeUnixS := time.Unix(timeUnix, 0)
58
+	timeNow := time.Now()
59
+	timeSub := timeNow.Sub(timeUnixS)
60
+
61
+	if timeSub < time.Minute*1 {
62
+		return "刚刚"
63
+	} else if timeSub < time.Hour*1 {
64
+		return strconv.Itoa(int(timeSub.Minutes())) + "分钟前"
65
+	} else if timeSub < time.Hour*24 {
66
+		return strconv.Itoa(int(timeSub.Hours())) + "小时前"
67
+	} else if timeSub < time.Hour*24*7 {
68
+		return strconv.Itoa(int(timeSub.Hours()/24)) + "天前"
69
+	} else {
70
+		return timeUnixS.Format("2006-01-02 15:04")
71
+	}
72
+	return ""
73
+}
74
+
75
+//Signature sha1签名
76
+func Signature(params ...string) string {
77
+	sort.Strings(params)
78
+	h := sha1.New()
79
+	for _, s := range params {
80
+		io.WriteString(h, s)
81
+	}
82
+	return fmt.Sprintf("%x", h.Sum(nil))
83
+}
84
+
85
+//RandomStr 随机生成字符串
86
+func RandomStr(length int) string {
87
+	str := "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
88
+	bytes := []byte(str)
89
+	result := []byte{}
90
+	r := rand.New(rand.NewSource(time.Now().UnixNano()))
91
+	for i := 0; i < length; i++ {
92
+		result = append(result, bytes[r.Intn(len(bytes))])
93
+	}
94
+	return string(result)
95
+}
96
+
97
+//GetCurrTs return current timestamps
98
+func GetCurrTs() int64 {
99
+	return time.Now().Unix()
100
+}
101
+
102
+func SetThisRequestURI(uri string) string {
103
+	return fmt.Sprintf("%v%v", beego.AppConfig.String("httpdomain"), uri)
104
+}
105
+
106
+func SetThisBasr64RequestURI(uri string) string {
107
+	backUrl := fmt.Sprintf("%v%v", beego.AppConfig.String("httpdomain"), uri)
108
+	backUrl = base64.URLEncoding.EncodeToString([]byte(backUrl))
109
+
110
+	return backUrl
111
+}
112
+
113
+func TransNum2Str(read int64) (transRead string) {
114
+	if read < 0 {
115
+		transRead = "0"
116
+	} else if read < 10000 {
117
+		transRead = fmt.Sprintf("%v", read)
118
+	} else {
119
+		var c float64 = 10000
120
+		var rc float64 = float64(read)
121
+		transRead = fmt.Sprintf("%.2f万", rc/c)
122
+	}
123
+
124
+	return
125
+}
126
+
127
+func GenMobileToken(mobile string) (token string) {
128
+	st := strings.Split(mobile, "")
129
+
130
+	s := fmt.Sprintf("%s%v%v%v%v%v%v", mobile, st[0], st[1], st[3], st[7], st[6], st[9])
131
+
132
+	h := sha1.New()
133
+	h.Write([]byte(s))
134
+	bs := h.Sum(nil)
135
+
136
+	token = fmt.Sprintf("%x", bs)
137
+
138
+	return
139
+}
140
+
141
+func CheckMobileToken(mobile, token string) bool {
142
+	o := GenMobileToken(mobile)
143
+	if token == o {
144
+		return true
145
+	}
146
+
147
+	return false
148
+}
149
+
150
+type jSapiConfig struct {
151
+	AppID     string `json:"app_id"`
152
+	Timestamp int64  `json:"timestamp"`
153
+	NonceStr  string `json:"nonce_str"`
154
+	Signature string `json:"signature"`
155
+}
156
+
157
+//GetAJTConfig jsapi_ticket config
158
+func GetAJTConfig(jsapiTicket, uri string) (jSapiConfig, error) {
159
+	var config jSapiConfig
160
+	nonceStr := RandomStr(16)
161
+	timestamp := GetCurrTs()
162
+	str := fmt.Sprintf("jsapi_ticket=%s&noncestr=%s&timestamp=%d&url=%s", jsapiTicket, nonceStr, timestamp, uri)
163
+	sigStr := Signature(str)
164
+
165
+	config.AppID = beego.AppConfig.String("wxappId")
166
+	config.NonceStr = nonceStr
167
+	config.Timestamp = timestamp
168
+	config.Signature = sigStr
169
+	return config, nil
170
+}
171
+
172
+func TrimHtml(src string) string {
173
+	//将HTML标签全转换成小写
174
+	re, _ := regexp.Compile("\\<[\\S\\s]+?\\>")
175
+	src = re.ReplaceAllStringFunc(src, strings.ToLower)
176
+	//去除STYLE
177
+	re, _ = regexp.Compile("\\<style[\\S\\s]+?\\</style\\>")
178
+	src = re.ReplaceAllString(src, "")
179
+	//去除SCRIPT
180
+	re, _ = regexp.Compile("\\<script[\\S\\s]+?\\</script\\>")
181
+	src = re.ReplaceAllString(src, "")
182
+	//去除所有尖括号内的HTML代码,并换成换行符
183
+	re, _ = regexp.Compile("\\<[\\S\\s]+?\\>")
184
+	src = re.ReplaceAllString(src, "\n")
185
+	//去除连续的换行符
186
+	re, _ = regexp.Compile("\\s{2,}")
187
+	src = re.ReplaceAllString(src, "\n")
188
+	return strings.TrimSpace(src)
189
+}
190
+
191
+func SubString(str string, begin, length int) string {
192
+	rs := []rune(str)
193
+	lth := len(rs)
194
+	if begin < 0 {
195
+		begin = 0
196
+	}
197
+	if begin >= lth {
198
+		begin = lth
199
+	}
200
+	end := begin + length
201
+
202
+	if end > lth {
203
+		end = lth
204
+	}
205
+	return string(rs[begin:end])
206
+}
207
+
208
+func ParseTimeStringToTime(layout string, timeStr string) (*time.Time, error) {
209
+	if len(layout) == 0 || len(timeStr) == 0 {
210
+		return nil, errors.New("layout 或 日期字符串 为空,无法解析")
211
+	}
212
+	loc, _ := time.LoadLocation("Local")
213
+	date, parseDateErr := time.ParseInLocation(layout, timeStr, loc)
214
+	return &date, parseDateErr
215
+}
216
+
217
+// 获取 date 所在周的周一和周日,以周一0点为一周的开始,周日24点为一周的结束
218
+func GetMondayAndSundayOfWeekDate(date *time.Time) (time.Time, time.Time) {
219
+	if date == nil {
220
+		now := time.Now()
221
+		date = &now
222
+	}
223
+	weekday := int(date.Weekday())
224
+	if weekday == 0 {
225
+		weekday = 7
226
+	}
227
+	loc, _ := time.LoadLocation("Local")
228
+	monday, _ := time.ParseInLocation("2006-01-02 15:04:05", date.AddDate(0, 0, 1-weekday).Format("2006-01-02")+" 00:00:00", loc)
229
+	sunday, _ := time.ParseInLocation("2006-01-02 15:04:05", date.AddDate(0, 0, 7-weekday).Format("2006-01-02")+" 23:59:59", loc)
230
+	return monday, sunday
231
+}

Diff nebyl zobrazen, protože je příliš veliký
+ 95 - 0
views/index.tpl