feat(download):增加虎标档案模板的下载,并在Docker镜像中加入下载支持。
This commit is contained in:
parent
5fac9a7da4
commit
17e1964bcd
@ -10,11 +10,20 @@ ADD . /app
|
|||||||
RUN CGO_ENABLED=0 GOOS=linux go build -tags=jsoniter -v -o server .
|
RUN CGO_ENABLED=0 GOOS=linux go build -tags=jsoniter -v -o server .
|
||||||
|
|
||||||
FROM alpine:latest AS production
|
FROM alpine:latest AS production
|
||||||
|
RUN echo "https://mirror.tuna.tsinghua.edu.cn/alpine/v3.4/main/" > /etc/apk/repositories
|
||||||
RUN apk add --no-cache tzdata
|
RUN apk add --no-cache tzdata
|
||||||
|
RUN apk update \
|
||||||
|
&& apk upgrade \
|
||||||
|
&& apk add --no-cache bash \
|
||||||
|
bash-doc \
|
||||||
|
bash-completion \
|
||||||
|
&& rm -rf /var/cache/apk/* \
|
||||||
ENV TZ=Asia/Shanghai
|
ENV TZ=Asia/Shanghai
|
||||||
RUN mkdir /app
|
RUN mkdir /app
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
COPY --from=builder /app/server .
|
COPY --from=builder /app/server .
|
||||||
COPY settings.yaml .
|
COPY settings.yaml .
|
||||||
COPY regions.csv .
|
COPY regions.csv .
|
||||||
|
RUN mkdir /app/assets
|
||||||
|
COPY ./assets/* /app/assets
|
||||||
CMD ["./server"]
|
CMD ["./server"]
|
BIN
assets/meter_04kv_template.xlsx
Normal file
BIN
assets/meter_04kv_template.xlsx
Normal file
Binary file not shown.
53
controller/meter04kv.go
Normal file
53
controller/meter04kv.go
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
package controller
|
||||||
|
|
||||||
|
import (
|
||||||
|
"electricity_bill_calc/response"
|
||||||
|
"electricity_bill_calc/security"
|
||||||
|
"electricity_bill_calc/service"
|
||||||
|
"fmt"
|
||||||
|
"net/http"
|
||||||
|
|
||||||
|
"github.com/gin-gonic/gin"
|
||||||
|
)
|
||||||
|
|
||||||
|
type _Meter04kVController struct {
|
||||||
|
Router *gin.Engine
|
||||||
|
}
|
||||||
|
|
||||||
|
var Meter04kVController *_Meter04kVController
|
||||||
|
|
||||||
|
func InitializeMeter04kVController(router *gin.Engine) {
|
||||||
|
Meter04kVController = &_Meter04kVController{
|
||||||
|
Router: router,
|
||||||
|
}
|
||||||
|
|
||||||
|
Meter04kVController.Router.GET("/park/:pid/meter/template", security.EnterpriseAuthorize, download04kvMeterArchiveTemplate)
|
||||||
|
}
|
||||||
|
|
||||||
|
func download04kvMeterArchiveTemplate(c *gin.Context) {
|
||||||
|
result := response.NewResult(c)
|
||||||
|
requestParkId := c.Param("pid")
|
||||||
|
userSession, err := _retreiveSession(c)
|
||||||
|
if err != nil {
|
||||||
|
result.Unauthorized(err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
sure, err := service.ParkService.EnsurePark(userSession.Uid, requestParkId)
|
||||||
|
if err != nil {
|
||||||
|
result.Error(http.StatusInternalServerError, err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if !sure {
|
||||||
|
result.Unauthorized("不能访问不属于自己的园区。")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
parkDetail, err := service.ParkService.FetchParkDetail(requestParkId)
|
||||||
|
if err != nil {
|
||||||
|
result.NotFound("未找到指定的园区信息。")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
c.Status(http.StatusOK)
|
||||||
|
c.Header("Content-Type", "application/octet-stream")
|
||||||
|
c.Header("Content-Transfer-Encoding", "binary")
|
||||||
|
c.FileAttachment("./assets/meter_04kv_template.xlsx", fmt.Sprintf("%s-户表档案.xlsx", parkDetail.Name))
|
||||||
|
}
|
@ -20,6 +20,7 @@ func Router() *gin.Engine {
|
|||||||
controller.InitializeChargesController(router)
|
controller.InitializeChargesController(router)
|
||||||
controller.InitializeParkController(router)
|
controller.InitializeParkController(router)
|
||||||
controller.InitializeMaintenanceFeeController(router)
|
controller.InitializeMaintenanceFeeController(router)
|
||||||
|
controller.InitializeMeter04kVController(router)
|
||||||
|
|
||||||
return router
|
return router
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user