Compare commits
	
		
			58 Commits
		
	
	
		
			4f56854e36
			...
			15e313f053
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 15e313f053 | |||
| 6552868292 | |||
| 7f28aeb349 | |||
| 7fbb5e59b7 | |||
| c880ef997e | |||
| 53d67eef82 | |||
| 4e79ab7a28 | |||
| 34d4dc8d84 | |||
| b8dadc0ee0 | |||
| 10bcbae03e | |||
| 9d71c9a6ea | |||
| 4cdb1508a8 | |||
| 2238689f11 | |||
| 1886eadf91 | |||
| 5fe886a487 | |||
| 822d2d696b | |||
| 01399daa30 | |||
| 539d725a14 | |||
| 74d03c57b4 | |||
| 3cf6a506a8 | |||
| 4006092dba | |||
| 26bbfc173f | |||
| 3b1c1c3016 | |||
| 581d005eff | |||
| ff39e5a67a | |||
| a473804e5f | |||
| 651dbfb6a3 | |||
| b5ff394b27 | |||
| a619c45aa7 | |||
| e2c67151a0 | |||
| 8694d6b52d | |||
| 87b8d516a8 | |||
| bb35c56cbb | |||
| 4e718554b8 | |||
| c190c4c7c3 | |||
| b8461a302c | |||
| 06b13d0f16 | |||
| 37b057fbc1 | |||
| 6c57bb8e02 | |||
| fa6d5bd4c3 | |||
| 46bb16ad7e | |||
| be192ce95d | |||
| af14bcf74b | |||
| bd35319780 | |||
| 082cee499a | |||
| f67223ce46 | |||
| 6f1a46fa07 | |||
| 84ca17620d | |||
| 18d4e6e826 | |||
| 43c264e512 | |||
| 4fcf8dede9 | |||
| a8ecf9a2ca | |||
| 7fe281fdd6 | |||
| 9c64f3bc6d | |||
| 7210111abf | |||
| 7c15c18f81 | |||
| 359dbede04 | |||
| 21f3dac99a | 
							
								
								
									
										14
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								go.mod
									
									
									
									
									
								
							| @ -8,6 +8,7 @@ require ( | |||||||
| 	github.com/bwmarrin/snowflake v0.3.0 | 	github.com/bwmarrin/snowflake v0.3.0 | ||||||
| 	github.com/dubbogo/grpc-go v1.42.9 | 	github.com/dubbogo/grpc-go v1.42.9 | ||||||
| 	github.com/dubbogo/triple v1.1.8 | 	github.com/dubbogo/triple v1.1.8 | ||||||
|  | 	github.com/duke-git/lancet/v2 v2.3.6 | ||||||
| 	github.com/getsentry/sentry-go v0.28.1 | 	github.com/getsentry/sentry-go v0.28.1 | ||||||
| 	github.com/gin-gonic/gin v1.9.0 | 	github.com/gin-gonic/gin v1.9.0 | ||||||
| 	github.com/go-redis/redis v6.15.9+incompatible | 	github.com/go-redis/redis v6.15.9+incompatible | ||||||
| @ -18,12 +19,15 @@ require ( | |||||||
| 	github.com/natefinch/lumberjack v2.0.0+incompatible | 	github.com/natefinch/lumberjack v2.0.0+incompatible | ||||||
| 	github.com/opentracing/opentracing-go v1.2.0 | 	github.com/opentracing/opentracing-go v1.2.0 | ||||||
| 	github.com/samber/lo v1.51.0 | 	github.com/samber/lo v1.51.0 | ||||||
|  | 	github.com/shopspring/decimal v1.4.0 | ||||||
| 	github.com/spf13/viper v1.7.1 | 	github.com/spf13/viper v1.7.1 | ||||||
| 	github.com/streadway/amqp v0.0.0-20190827072141-edfb9018d271 | 	github.com/streadway/amqp v0.0.0-20190827072141-edfb9018d271 | ||||||
| 	github.com/uber/jaeger-client-go v2.30.0+incompatible | 	github.com/uber/jaeger-client-go v2.30.0+incompatible | ||||||
| 	go.uber.org/zap v1.24.0 | 	go.uber.org/zap v1.24.0 | ||||||
|  | 	google.golang.org/grpc v1.54.0 | ||||||
| 	google.golang.org/protobuf v1.29.1 | 	google.golang.org/protobuf v1.29.1 | ||||||
| 	gorm.io/driver/mysql v1.4.7 | 	gorm.io/datatypes v1.2.5 | ||||||
|  | 	gorm.io/driver/mysql v1.5.6 | ||||||
| 	gorm.io/gorm v1.25.12 | 	gorm.io/gorm v1.25.12 | ||||||
| 	gorm.io/plugin/soft_delete v1.2.1 | 	gorm.io/plugin/soft_delete v1.2.1 | ||||||
| ) | ) | ||||||
| @ -32,6 +36,7 @@ require ( | |||||||
| 	cloud.google.com/go/compute v1.15.1 // indirect | 	cloud.google.com/go/compute v1.15.1 // indirect | ||||||
| 	cloud.google.com/go/compute/metadata v0.2.3 // indirect | 	cloud.google.com/go/compute/metadata v0.2.3 // indirect | ||||||
| 	contrib.go.opencensus.io/exporter/prometheus v0.4.1 // indirect | 	contrib.go.opencensus.io/exporter/prometheus v0.4.1 // indirect | ||||||
|  | 	filippo.io/edwards25519 v1.1.0 // indirect | ||||||
| 	github.com/RoaringBitmap/roaring v1.2.3 // indirect | 	github.com/RoaringBitmap/roaring v1.2.3 // indirect | ||||||
| 	github.com/Workiva/go-datastructures v1.0.52 // indirect | 	github.com/Workiva/go-datastructures v1.0.52 // indirect | ||||||
| 	github.com/afex/hystrix-go v0.0.0-20180502004556-fa1af6a1f4f5 // indirect | 	github.com/afex/hystrix-go v0.0.0-20180502004556-fa1af6a1f4f5 // indirect | ||||||
| @ -70,7 +75,7 @@ require ( | |||||||
| 	github.com/go-playground/universal-translator v0.18.1 // indirect | 	github.com/go-playground/universal-translator v0.18.1 // indirect | ||||||
| 	github.com/go-playground/validator/v10 v10.11.2 // indirect | 	github.com/go-playground/validator/v10 v10.11.2 // indirect | ||||||
| 	github.com/go-resty/resty/v2 v2.7.0 // indirect | 	github.com/go-resty/resty/v2 v2.7.0 // indirect | ||||||
| 	github.com/go-sql-driver/mysql v1.7.0 // indirect | 	github.com/go-sql-driver/mysql v1.8.1 // indirect | ||||||
| 	github.com/goccy/go-json v0.10.0 // indirect | 	github.com/goccy/go-json v0.10.0 // indirect | ||||||
| 	github.com/gogo/protobuf v1.3.2 // indirect | 	github.com/gogo/protobuf v1.3.2 // indirect | ||||||
| 	github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect | 	github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect | ||||||
| @ -141,15 +146,14 @@ require ( | |||||||
| 	go.uber.org/atomic v1.9.0 // indirect | 	go.uber.org/atomic v1.9.0 // indirect | ||||||
| 	go.uber.org/multierr v1.8.0 // indirect | 	go.uber.org/multierr v1.8.0 // indirect | ||||||
| 	golang.org/x/arch v0.0.0-20210923205945-b76863e36670 // indirect | 	golang.org/x/arch v0.0.0-20210923205945-b76863e36670 // indirect | ||||||
| 	golang.org/x/crypto v0.19.0 // indirect | 	golang.org/x/crypto v0.22.0 // indirect | ||||||
| 	golang.org/x/net v0.21.0 // indirect | 	golang.org/x/net v0.21.0 // indirect | ||||||
| 	golang.org/x/oauth2 v0.4.0 // indirect | 	golang.org/x/oauth2 v0.4.0 // indirect | ||||||
| 	golang.org/x/sync v0.11.0 // indirect | 	golang.org/x/sync v0.11.0 // indirect | ||||||
| 	golang.org/x/sys v0.18.0 // indirect | 	golang.org/x/sys v0.19.0 // indirect | ||||||
| 	golang.org/x/text v0.22.0 // indirect | 	golang.org/x/text v0.22.0 // indirect | ||||||
| 	google.golang.org/appengine v1.6.7 // indirect | 	google.golang.org/appengine v1.6.7 // indirect | ||||||
| 	google.golang.org/genproto v0.0.0-20230110181048-76db0878b65f // indirect | 	google.golang.org/genproto v0.0.0-20230110181048-76db0878b65f // indirect | ||||||
| 	google.golang.org/grpc v1.54.0 // indirect |  | ||||||
| 	gopkg.in/ini.v1 v1.67.0 // indirect | 	gopkg.in/ini.v1 v1.67.0 // indirect | ||||||
| 	gopkg.in/natefinch/lumberjack.v2 v2.2.1 // indirect | 	gopkg.in/natefinch/lumberjack.v2 v2.2.1 // indirect | ||||||
| 	gopkg.in/yaml.v2 v2.4.0 // indirect | 	gopkg.in/yaml.v2 v2.4.0 // indirect | ||||||
|  | |||||||
							
								
								
									
										38
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								go.sum
									
									
									
									
									
								
							| @ -45,6 +45,8 @@ contrib.go.opencensus.io/exporter/prometheus v0.4.1/go.mod h1:t9wvfitlUjGXG2IXAZ | |||||||
| dmitri.shuralyov.com/gpu/mtl v0.0.0-20190408044501-666a987793e9/go.mod h1:H6x//7gZCb22OMCxBHrMx7a5I7Hp++hsVxbQ4BYO7hU= | dmitri.shuralyov.com/gpu/mtl v0.0.0-20190408044501-666a987793e9/go.mod h1:H6x//7gZCb22OMCxBHrMx7a5I7Hp++hsVxbQ4BYO7hU= | ||||||
| dubbo.apache.org/dubbo-go/v3 v3.0.2 h1:+WuMFN6RSjXHT41QS1Xi5tFfaPuczIVoeQuKq7pISYI= | dubbo.apache.org/dubbo-go/v3 v3.0.2 h1:+WuMFN6RSjXHT41QS1Xi5tFfaPuczIVoeQuKq7pISYI= | ||||||
| dubbo.apache.org/dubbo-go/v3 v3.0.2/go.mod h1:bODgByAf72kzG/5YIfZIODXx81pY3gaAdIQ8B4mN/Yk= | dubbo.apache.org/dubbo-go/v3 v3.0.2/go.mod h1:bODgByAf72kzG/5YIfZIODXx81pY3gaAdIQ8B4mN/Yk= | ||||||
|  | filippo.io/edwards25519 v1.1.0 h1:FNf4tywRC1HmFuKW5xopWpigGjJKiJSV0Cqo0cJWDaA= | ||||||
|  | filippo.io/edwards25519 v1.1.0/go.mod h1:BxyFTGdWcka3PhytdK4V28tE5sGfRvvvRV7EaN4VDT4= | ||||||
| github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= | github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= | ||||||
| github.com/BurntSushi/toml v1.2.1 h1:9F2/+DoOYIOksmaJFPw1tGFy1eDnIJXg+UHjuD8lTak= | github.com/BurntSushi/toml v1.2.1 h1:9F2/+DoOYIOksmaJFPw1tGFy1eDnIJXg+UHjuD8lTak= | ||||||
| github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802/go.mod h1:IVnqGOEym/WlBOVXweHU+Q+/VP0lqqI8lqeDx9IjBqo= | github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802/go.mod h1:IVnqGOEym/WlBOVXweHU+Q+/VP0lqqI8lqeDx9IjBqo= | ||||||
| @ -208,6 +210,8 @@ github.com/dubbogo/net v0.0.4/go.mod h1:1CGOnM7X3he+qgGNqjeADuE5vKZQx/eMSeUkpU3u | |||||||
| github.com/dubbogo/triple v1.0.9/go.mod h1:1t9me4j4CTvNDcsMZy6/OGarbRyAUSY0tFXGXHCp7Iw= | github.com/dubbogo/triple v1.0.9/go.mod h1:1t9me4j4CTvNDcsMZy6/OGarbRyAUSY0tFXGXHCp7Iw= | ||||||
| github.com/dubbogo/triple v1.1.8 h1:yE+J3W1NTZCEPa1FoX+VWZH6UF1c0+A2MGfERlU2zbI= | github.com/dubbogo/triple v1.1.8 h1:yE+J3W1NTZCEPa1FoX+VWZH6UF1c0+A2MGfERlU2zbI= | ||||||
| github.com/dubbogo/triple v1.1.8/go.mod h1:9pgEahtmsY/avYJp3dzUQE8CMMVe1NtGBmUhfICKLJk= | github.com/dubbogo/triple v1.1.8/go.mod h1:9pgEahtmsY/avYJp3dzUQE8CMMVe1NtGBmUhfICKLJk= | ||||||
|  | github.com/duke-git/lancet/v2 v2.3.6 h1:NKxSSh+dlgp37funvxLCf3xLBeUYa7VW1thYQP6j3Y8= | ||||||
|  | github.com/duke-git/lancet/v2 v2.3.6/go.mod h1:zGa2R4xswg6EG9I6WnyubDbFO/+A/RROxIbXcwryTsc= | ||||||
| github.com/dustin/go-humanize v0.0.0-20171111073723-bb3d318650d4/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk= | github.com/dustin/go-humanize v0.0.0-20171111073723-bb3d318650d4/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk= | ||||||
| github.com/dustin/go-humanize v1.0.0 h1:VSnTsYCnlFHaM2/igO1h6X3HA71jcobQuxemgkq4zYo= | github.com/dustin/go-humanize v1.0.0 h1:VSnTsYCnlFHaM2/igO1h6X3HA71jcobQuxemgkq4zYo= | ||||||
| github.com/dustin/go-humanize v1.0.0/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk= | github.com/dustin/go-humanize v1.0.0/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk= | ||||||
| @ -304,8 +308,9 @@ github.com/go-redis/redis v6.15.9+incompatible/go.mod h1:NAIEuMOZ/fxfXJIrKDQDz8w | |||||||
| github.com/go-resty/resty/v2 v2.7.0 h1:me+K9p3uhSmXtrBZ4k9jcEAfJmuC8IivWHwaLZwPrFY= | github.com/go-resty/resty/v2 v2.7.0 h1:me+K9p3uhSmXtrBZ4k9jcEAfJmuC8IivWHwaLZwPrFY= | ||||||
| github.com/go-resty/resty/v2 v2.7.0/go.mod h1:9PWDzw47qPphMRFfhsyk0NnSgvluHcljSMVIq3w7q0I= | github.com/go-resty/resty/v2 v2.7.0/go.mod h1:9PWDzw47qPphMRFfhsyk0NnSgvluHcljSMVIq3w7q0I= | ||||||
| github.com/go-sql-driver/mysql v1.4.0/go.mod h1:zAC/RDZ24gD3HViQzih4MyKcchzm+sOG5ZlKdlhCg5w= | github.com/go-sql-driver/mysql v1.4.0/go.mod h1:zAC/RDZ24gD3HViQzih4MyKcchzm+sOG5ZlKdlhCg5w= | ||||||
| github.com/go-sql-driver/mysql v1.7.0 h1:ueSltNNllEqE3qcWBTD0iQd3IpL/6U+mJxLkazJ7YPc= |  | ||||||
| github.com/go-sql-driver/mysql v1.7.0/go.mod h1:OXbVy3sEdcQ2Doequ6Z5BW6fXNQTmx+9S1MCJN5yJMI= | github.com/go-sql-driver/mysql v1.7.0/go.mod h1:OXbVy3sEdcQ2Doequ6Z5BW6fXNQTmx+9S1MCJN5yJMI= | ||||||
|  | github.com/go-sql-driver/mysql v1.8.1 h1:LedoTUt/eveggdHS9qUFC1EFSa8bU2+1pZjSRpvNJ1Y= | ||||||
|  | github.com/go-sql-driver/mysql v1.8.1/go.mod h1:wEBSXgmK//2ZFJyE+qWnIsVGmvmEKlqwuVSjsCm7DZg= | ||||||
| github.com/go-stack/stack v1.8.0 h1:5SgMzNM5HxrEjV0ww2lTmX6E2Izsfxas4+YHWRs3Lsk= | github.com/go-stack/stack v1.8.0 h1:5SgMzNM5HxrEjV0ww2lTmX6E2Izsfxas4+YHWRs3Lsk= | ||||||
| github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY= | github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY= | ||||||
| github.com/go-test/deep v1.0.2-0.20181118220953-042da051cf31/go.mod h1:wGDj63lr65AM2AQyKZd/NYHGb0R+1RLqB8NKt3aSFNA= | github.com/go-test/deep v1.0.2-0.20181118220953-042da051cf31/go.mod h1:wGDj63lr65AM2AQyKZd/NYHGb0R+1RLqB8NKt3aSFNA= | ||||||
| @ -323,6 +328,8 @@ github.com/gogo/protobuf v1.3.1/go.mod h1:SlYgWuQ5SjCEi6WLHjHCa1yvBfUnHcTbrrZtXP | |||||||
| github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q= | github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q= | ||||||
| github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q= | github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q= | ||||||
| github.com/goji/httpauth v0.0.0-20160601135302-2da839ab0f4d/go.mod h1:nnjvkQ9ptGaCkuDUx6wNykzzlUixGxvkme+H/lnzb+A= | github.com/goji/httpauth v0.0.0-20160601135302-2da839ab0f4d/go.mod h1:nnjvkQ9ptGaCkuDUx6wNykzzlUixGxvkme+H/lnzb+A= | ||||||
|  | github.com/golang-sql/civil v0.0.0-20220223132316-b832511892a9 h1:au07oEsX2xN0ktxqI+Sida1w446QrXBRJ0nee3SNZlA= | ||||||
|  | github.com/golang-sql/sqlexp v0.1.0 h1:ZCD6MBpcuOVfGVqsEmY5/4FtYiKz6tSyUv9LPEDei6A= | ||||||
| github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0/go.mod h1:E/TSTwGwJL78qG/PmXZO1EjYhfJinVAhrmmHX6Z8B9k= | github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0/go.mod h1:E/TSTwGwJL78qG/PmXZO1EjYhfJinVAhrmmHX6Z8B9k= | ||||||
| github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q= | github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q= | ||||||
| github.com/golang/glog v1.0.0/go.mod h1:EWib/APOK0SL3dFbYqvxE3UYd8E6s1ouQ7iEp/0LWV4= | github.com/golang/glog v1.0.0/go.mod h1:EWib/APOK0SL3dFbYqvxE3UYd8E6s1ouQ7iEp/0LWV4= | ||||||
| @ -514,6 +521,10 @@ github.com/ianlancetaylor/demangle v0.0.0-20181102032728-5e5cf60278f6/go.mod h1: | |||||||
| github.com/ianlancetaylor/demangle v0.0.0-20200824232613-28f6c0f3b639/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc= | github.com/ianlancetaylor/demangle v0.0.0-20200824232613-28f6c0f3b639/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc= | ||||||
| github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8= | github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8= | ||||||
| github.com/influxdata/influxdb1-client v0.0.0-20191209144304-8bf82d3c094d/go.mod h1:qj24IKcXYK6Iy9ceXlo3Tc+vtHo9lIhSX5JddghvEPo= | github.com/influxdata/influxdb1-client v0.0.0-20191209144304-8bf82d3c094d/go.mod h1:qj24IKcXYK6Iy9ceXlo3Tc+vtHo9lIhSX5JddghvEPo= | ||||||
|  | github.com/jackc/pgpassfile v1.0.0 h1:/6Hmqy13Ss2zCq62VdNG8tM1wchn8zjSGOBJ6icpsIM= | ||||||
|  | github.com/jackc/pgservicefile v0.0.0-20231201235250-de7065d80cb9 h1:L0QtFUgDarD7Fpv9jeVMgy/+Ec0mtnmYuImjTz6dtDA= | ||||||
|  | github.com/jackc/pgx/v5 v5.5.5 h1:amBjrZVmksIdNjxGW/IiIMzxMKZFelXbUoPNb+8sjQw= | ||||||
|  | github.com/jackc/puddle/v2 v2.2.1 h1:RhxXJtFG022u4ibrCSMSiu5aOq1i77R3OHKNJj77OAk= | ||||||
| github.com/jehiah/go-strftime v0.0.0-20171201141054-1d33003b3869/go.mod h1:cJ6Cj7dQo+O6GJNiMx+Pa94qKj+TG8ONdKHgMNIyyag= | github.com/jehiah/go-strftime v0.0.0-20171201141054-1d33003b3869/go.mod h1:cJ6Cj7dQo+O6GJNiMx+Pa94qKj+TG8ONdKHgMNIyyag= | ||||||
| github.com/jessevdk/go-flags v1.4.0/go.mod h1:4FA24M0QyGHXBuZZK/XkWh8h0e1EYbRYJSGM75WSRxI= | github.com/jessevdk/go-flags v1.4.0/go.mod h1:4FA24M0QyGHXBuZZK/XkWh8h0e1EYbRYJSGM75WSRxI= | ||||||
| github.com/jhump/protoreflect v1.6.0/go.mod h1:eaTn3RZAmMBcV0fifFvlm6VHNz3wSkYyXYWUh7ymB74= | github.com/jhump/protoreflect v1.6.0/go.mod h1:eaTn3RZAmMBcV0fifFvlm6VHNz3wSkYyXYWUh7ymB74= | ||||||
| @ -612,11 +623,12 @@ github.com/mattn/go-isatty v0.0.16/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/ | |||||||
| github.com/mattn/go-isatty v0.0.20 h1:xfD0iDuEKnDkl03q4limB+vH+GxLEtL/jb4xVJSWWEY= | github.com/mattn/go-isatty v0.0.20 h1:xfD0iDuEKnDkl03q4limB+vH+GxLEtL/jb4xVJSWWEY= | ||||||
| github.com/mattn/go-isatty v0.0.20/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= | github.com/mattn/go-isatty v0.0.20/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= | ||||||
| github.com/mattn/go-runewidth v0.0.2/go.mod h1:LwmH8dsx7+W8Uxz3IHJYH5QSwggIsqBzpuz5H//U1FU= | github.com/mattn/go-runewidth v0.0.2/go.mod h1:LwmH8dsx7+W8Uxz3IHJYH5QSwggIsqBzpuz5H//U1FU= | ||||||
| github.com/mattn/go-sqlite3 v1.14.3 h1:j7a/xn1U6TKA/PHHxqZuzh64CdtRc7rU9M+AvkOl5bA= |  | ||||||
| github.com/mattn/go-sqlite3 v1.14.3/go.mod h1:WVKg1VTActs4Qso6iwGbiFih2UIHo0ENGwNd0Lj+XmI= | github.com/mattn/go-sqlite3 v1.14.3/go.mod h1:WVKg1VTActs4Qso6iwGbiFih2UIHo0ENGwNd0Lj+XmI= | ||||||
|  | github.com/mattn/go-sqlite3 v1.14.15 h1:vfoHhTN1af61xCRSWzFIWzx2YskyMTwHLrExkBOjvxI= | ||||||
| github.com/matttproud/golang_protobuf_extensions v1.0.1/go.mod h1:D8He9yQNgCq6Z5Ld7szi9bcBfOoFv/3dc6xSMkL2PC0= | github.com/matttproud/golang_protobuf_extensions v1.0.1/go.mod h1:D8He9yQNgCq6Z5Ld7szi9bcBfOoFv/3dc6xSMkL2PC0= | ||||||
| github.com/matttproud/golang_protobuf_extensions v1.0.4 h1:mmDVorXM7PCGKw94cs5zkfA9PSy5pEvNWRP0ET0TIVo= | github.com/matttproud/golang_protobuf_extensions v1.0.4 h1:mmDVorXM7PCGKw94cs5zkfA9PSy5pEvNWRP0ET0TIVo= | ||||||
| github.com/matttproud/golang_protobuf_extensions v1.0.4/go.mod h1:BSXmuO+STAnVfrANrmjBb36TMTDstsz7MSK+HVaYKv4= | github.com/matttproud/golang_protobuf_extensions v1.0.4/go.mod h1:BSXmuO+STAnVfrANrmjBb36TMTDstsz7MSK+HVaYKv4= | ||||||
|  | github.com/microsoft/go-mssqldb v1.7.2 h1:CHkFJiObW7ItKTJfHo1QX7QBBD1iV+mn1eOyRP3b/PA= | ||||||
| github.com/miekg/dns v1.0.14/go.mod h1:W1PPwlIAgtquWBMBEV9nkV9Cazfe8ScdGz/Lj7v3Nrg= | github.com/miekg/dns v1.0.14/go.mod h1:W1PPwlIAgtquWBMBEV9nkV9Cazfe8ScdGz/Lj7v3Nrg= | ||||||
| github.com/miekg/dns v1.1.26/go.mod h1:bPDLeHnStXmXAq1m/Ch/hvfNHr14JKNPMBo3VZKjuso= | github.com/miekg/dns v1.1.26/go.mod h1:bPDLeHnStXmXAq1m/Ch/hvfNHr14JKNPMBo3VZKjuso= | ||||||
| github.com/miekg/dns v1.1.41/go.mod h1:p6aan82bvRIyn+zDIv9xYNUpwa73JcSh9BKwknJysuI= | github.com/miekg/dns v1.1.41/go.mod h1:p6aan82bvRIyn+zDIv9xYNUpwa73JcSh9BKwknJysuI= | ||||||
| @ -793,6 +805,8 @@ github.com/shirou/gopsutil v3.20.11+incompatible/go.mod h1:5b4v6he4MtMOwMlS0TUMT | |||||||
| github.com/shirou/gopsutil/v3 v3.21.6/go.mod h1:JfVbDpIBLVzT8oKbvMg9P3wEIMDDpVn+LwHTKj0ST88= | github.com/shirou/gopsutil/v3 v3.21.6/go.mod h1:JfVbDpIBLVzT8oKbvMg9P3wEIMDDpVn+LwHTKj0ST88= | ||||||
| github.com/shirou/gopsutil/v3 v3.22.2 h1:wCrArWFkHYIdDxx/FSfF5RB4dpJYW6t7rcp3+zL8uks= | github.com/shirou/gopsutil/v3 v3.22.2 h1:wCrArWFkHYIdDxx/FSfF5RB4dpJYW6t7rcp3+zL8uks= | ||||||
| github.com/shirou/gopsutil/v3 v3.22.2/go.mod h1:WapW1AOOPlHyXr+yOyw3uYx36enocrtSoSBy0L5vUHY= | github.com/shirou/gopsutil/v3 v3.22.2/go.mod h1:WapW1AOOPlHyXr+yOyw3uYx36enocrtSoSBy0L5vUHY= | ||||||
|  | github.com/shopspring/decimal v1.4.0 h1:bxl37RwXBklmTi0C79JfXCEBD1cqqHt0bbgBAGFp81k= | ||||||
|  | github.com/shopspring/decimal v1.4.0/go.mod h1:gawqmDU56v4yIKSwfBSFip1HdCCXN8/+DMd9qYNcwME= | ||||||
| github.com/shurcooL/sanitized_anchor_name v1.0.0/go.mod h1:1NzhyTcUVG4SuEtjjoZeVRXNmyL/1OwPU0+IJeTBvfc= | github.com/shurcooL/sanitized_anchor_name v1.0.0/go.mod h1:1NzhyTcUVG4SuEtjjoZeVRXNmyL/1OwPU0+IJeTBvfc= | ||||||
| github.com/sirupsen/logrus v1.2.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo= | github.com/sirupsen/logrus v1.2.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo= | ||||||
| github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6MwdIuYE2rE= | github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6MwdIuYE2rE= | ||||||
| @ -980,8 +994,8 @@ golang.org/x/crypto v0.0.0-20211108221036-ceb1ce70b4fa/go.mod h1:GvvjBRRGRdwPK5y | |||||||
| golang.org/x/crypto v0.0.0-20211215153901-e495a2d5b3d3/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4= | golang.org/x/crypto v0.0.0-20211215153901-e495a2d5b3d3/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4= | ||||||
| golang.org/x/crypto v0.13.0/go.mod h1:y6Z2r+Rw4iayiXXAIxJIDAJ1zMW4yaTpebo8fPOliYc= | golang.org/x/crypto v0.13.0/go.mod h1:y6Z2r+Rw4iayiXXAIxJIDAJ1zMW4yaTpebo8fPOliYc= | ||||||
| golang.org/x/crypto v0.18.0/go.mod h1:R0j02AL6hcrfOiy9T4ZYp/rcWeMxM3L6QYxlOuEG1mg= | golang.org/x/crypto v0.18.0/go.mod h1:R0j02AL6hcrfOiy9T4ZYp/rcWeMxM3L6QYxlOuEG1mg= | ||||||
| golang.org/x/crypto v0.19.0 h1:ENy+Az/9Y1vSrlrvBSyna3PITt4tiZLf7sgCjZBX7Wo= | golang.org/x/crypto v0.22.0 h1:g1v0xeRhjcugydODzvb3mEM9SQ0HGp9s/nh3COQ/C30= | ||||||
| golang.org/x/crypto v0.19.0/go.mod h1:Iy9bg/ha4yyC70EfRS8jz+B6ybOBKMaSxLj6P6oBDfU= | golang.org/x/crypto v0.22.0/go.mod h1:vr6Su+7cTlO45qkww3VDJlzDn0ctJvRgYbC2NvXHt+M= | ||||||
| golang.org/x/exp v0.0.0-20180321215751-8460e604b9de/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= | golang.org/x/exp v0.0.0-20180321215751-8460e604b9de/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= | ||||||
| golang.org/x/exp v0.0.0-20180807140117-3d87b88a115f/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= | golang.org/x/exp v0.0.0-20180807140117-3d87b88a115f/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= | ||||||
| golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= | golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= | ||||||
| @ -1206,8 +1220,8 @@ golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | |||||||
| golang.org/x/sys v0.8.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | golang.org/x/sys v0.8.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||||
| golang.org/x/sys v0.12.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | golang.org/x/sys v0.12.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||||
| golang.org/x/sys v0.16.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= | golang.org/x/sys v0.16.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= | ||||||
| golang.org/x/sys v0.18.0 h1:DBdB3niSjOA/O0blCZBqDefyWNYveAYMNF1Wum0DYQ4= | golang.org/x/sys v0.19.0 h1:q5f1RH2jigJ1MoAWp2KTp3gm5zAGFUTarQZ5U386+4o= | ||||||
| golang.org/x/sys v0.18.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= | golang.org/x/sys v0.19.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= | ||||||
| golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= | golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= | ||||||
| golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= | golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= | ||||||
| golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k= | golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k= | ||||||
| @ -1484,13 +1498,17 @@ gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C | |||||||
| gopkg.in/yaml.v3 v3.0.0-20210107192922-496545a6307b/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= | gopkg.in/yaml.v3 v3.0.0-20210107192922-496545a6307b/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= | ||||||
| gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= | gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= | ||||||
| gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= | gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= | ||||||
| gorm.io/driver/mysql v1.4.7 h1:rY46lkCspzGHn7+IYsNpSfEv9tA+SU4SkkB+GFX125Y= | gorm.io/datatypes v1.2.5 h1:9UogU3jkydFVW1bIVVeoYsTpLRgwDVW3rHfJG6/Ek9I= | ||||||
| gorm.io/driver/mysql v1.4.7/go.mod h1:SxzItlnT1cb6e1e4ZRpgJN2VYtcqJgqnHxWr4wsP8oc= | gorm.io/datatypes v1.2.5/go.mod h1:I5FUdlKpLb5PMqeMQhm30CQ6jXP8Rj89xkTeCSAaAD4= | ||||||
| gorm.io/driver/sqlite v1.1.3 h1:BYfdVuZB5He/u9dt4qDpZqiqDJ6KhPqs5QUqsr/Eeuc= | gorm.io/driver/mysql v1.5.6 h1:Ld4mkIickM+EliaQZQx3uOJDJHtrd70MxAUqWqlx3Y8= | ||||||
|  | gorm.io/driver/mysql v1.5.6/go.mod h1:sEtPWMiqiN1N1cMXoXmBbd8C6/l+TESwriotuRRpkDM= | ||||||
|  | gorm.io/driver/postgres v1.5.0 h1:u2FXTy14l45qc3UeCJ7QaAXZmZfDDv0YrthvmRq1l0U= | ||||||
| gorm.io/driver/sqlite v1.1.3/go.mod h1:AKDgRWk8lcSQSw+9kxCJnX/yySj8G3rdwYlU57cB45c= | gorm.io/driver/sqlite v1.1.3/go.mod h1:AKDgRWk8lcSQSw+9kxCJnX/yySj8G3rdwYlU57cB45c= | ||||||
|  | gorm.io/driver/sqlite v1.4.3 h1:HBBcZSDnWi5BW3B3rwvVTc510KGkBkexlOg0QrmLUuU= | ||||||
|  | gorm.io/driver/sqlserver v1.5.4 h1:xA+Y1KDNspv79q43bPyjDMUgHoYHLhXYmdFcYPobg8g= | ||||||
| gorm.io/gorm v1.20.1/go.mod h1:0HFTzE/SqkGTzK6TlDPPQbAYCluiVvhzoA1+aVyzenw= | gorm.io/gorm v1.20.1/go.mod h1:0HFTzE/SqkGTzK6TlDPPQbAYCluiVvhzoA1+aVyzenw= | ||||||
| gorm.io/gorm v1.23.0/go.mod h1:l2lP/RyAtc1ynaTjFksBde/O8v9oOGIApu2/xRitmZk= | gorm.io/gorm v1.23.0/go.mod h1:l2lP/RyAtc1ynaTjFksBde/O8v9oOGIApu2/xRitmZk= | ||||||
| gorm.io/gorm v1.23.8/go.mod h1:l2lP/RyAtc1ynaTjFksBde/O8v9oOGIApu2/xRitmZk= | gorm.io/gorm v1.25.7/go.mod h1:hbnx/Oo0ChWMn1BIhpy1oYozzpM15i4YPuHDmfYtwg8= | ||||||
| gorm.io/gorm v1.25.12 h1:I0u8i2hWQItBq1WfE0o2+WuL9+8L21K9e2HHSTE/0f8= | gorm.io/gorm v1.25.12 h1:I0u8i2hWQItBq1WfE0o2+WuL9+8L21K9e2HHSTE/0f8= | ||||||
| gorm.io/gorm v1.25.12/go.mod h1:xh7N7RHfYlNc5EmcI/El95gXusucDrQnHXe0+CgWcLQ= | gorm.io/gorm v1.25.12/go.mod h1:xh7N7RHfYlNc5EmcI/El95gXusucDrQnHXe0+CgWcLQ= | ||||||
| gorm.io/plugin/soft_delete v1.2.1 h1:qx9D/c4Xu6w5KT8LviX8DgLcB9hkKl6JC9f44Tj7cGU= | gorm.io/plugin/soft_delete v1.2.1 h1:qx9D/c4Xu6w5KT8LviX8DgLcB9hkKl6JC9f44Tj7cGU= | ||||||
|  | |||||||
| @ -34,7 +34,7 @@ func (b *BundleProvider) BundleDetail(_ context.Context, req *bundle.BundleDetai | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // 订单相关
 | // 订单相关
 | ||||||
| func (b *BundleProvider) CreateOrderRecord(_ context.Context, req *bundle.OrderRecord) (res *bundle.CommonResponse, err error) { | func (b *BundleProvider) CreateOrderRecord(_ context.Context, req *bundle.OrderCreateRecord) (res *bundle.CommonResponse, err error) { | ||||||
| 	return logic.CreateOrderRecord(req) | 	return logic.CreateOrderRecord(req) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -77,3 +77,14 @@ func (b *BundleProvider) ValueAddBundleDetail(_ context.Context, req *bundle.Val | |||||||
| func (b *BundleProvider) UpdateFinancialConfirmationStatus(_ context.Context, req *bundle.FinancialConfirmationRequest) (res *bundle.CommonResponse, err error) { | func (b *BundleProvider) UpdateFinancialConfirmationStatus(_ context.Context, req *bundle.FinancialConfirmationRequest) (res *bundle.CommonResponse, err error) { | ||||||
| 	return logic.UpdateFinancialConfirmationStatus(req) | 	return logic.UpdateFinancialConfirmationStatus(req) | ||||||
| } | } | ||||||
|  | func (b *BundleProvider) PackagePriceAndTime(_ context.Context, req *bundle.OrderRecord) (res *bundle.PackagePriceAndTimeResponse, err error) { | ||||||
|  | 	return logic.PackagePriceAndTime(req) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 创建增值服务订单
 | ||||||
|  | func (b *BundleProvider) CreateOrderAddRecord(_ context.Context, req *bundle.OrderAddRecord) (res *bundle.CommonResponse, err error) { | ||||||
|  | 	return logic.CreateOrderAddRecord(req) | ||||||
|  | } | ||||||
|  | func (b *BundleProvider) OrderRecordsListV2(_ context.Context, req *bundle.OrderRecordsRequestV2) (res *bundle.OrderRecordsResponseV2, err error) { | ||||||
|  | 	return logic.OrderRecordsListV2(req) | ||||||
|  | } | ||||||
|  | |||||||
| @ -4,6 +4,9 @@ import ( | |||||||
| 	"context" | 	"context" | ||||||
| 	"micro-bundle/internal/logic" | 	"micro-bundle/internal/logic" | ||||||
| 	"micro-bundle/pb/bundle" | 	"micro-bundle/pb/bundle" | ||||||
|  | 
 | ||||||
|  | 	"google.golang.org/grpc/codes" | ||||||
|  | 	"google.golang.org/grpc/status" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func (b *BundleProvider) BundleExtend(_ context.Context, req *bundle.BundleExtendRequest) (*bundle.BundleExtendResponse, error) { | func (b *BundleProvider) BundleExtend(_ context.Context, req *bundle.BundleExtendRequest) (*bundle.BundleExtendResponse, error) { | ||||||
| @ -33,6 +36,11 @@ func (b *BundleProvider) GetUsedRecordList(_ context.Context, req *bundle.GetUse | |||||||
| func (b *BundleProvider) GetImageWorkDetail(_ context.Context, req *bundle.GetImageWorkDetailReq) (*bundle.GetImageWorkDetailResp, error) { | func (b *BundleProvider) GetImageWorkDetail(_ context.Context, req *bundle.GetImageWorkDetailReq) (*bundle.GetImageWorkDetailResp, error) { | ||||||
| 	return logic.GetImageWorkDetail(req) | 	return logic.GetImageWorkDetail(req) | ||||||
| } | } | ||||||
|  | 
 | ||||||
| func (b *BundleProvider) GetVedioWorkDetail(_ context.Context, req *bundle.GetVedioWorkDetailReq) (*bundle.GetVedioeWorkDetailResp, error) { | func (b *BundleProvider) GetVedioWorkDetail(_ context.Context, req *bundle.GetVedioWorkDetailReq) (*bundle.GetVedioeWorkDetailResp, error) { | ||||||
| 	return logic.GetVedioWorkDetail(req) | 	return logic.GetVedioWorkDetail(req) | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | func (b *BundleProvider) ToBeComfirmedWorks(_ context.Context, req *bundle.ToBeComfirmedWorksReq) (*bundle.ToBeComfirmedWorksResp, error) { | ||||||
|  | 	return nil, status.Errorf(codes.Unimplemented, "method ToBeComfirmedWorks not implemented") | ||||||
|  | } | ||||||
|  | |||||||
| @ -13,7 +13,7 @@ func (b *BundleProvider) SaveBundle(_ context.Context, req *bundle.BundleProfile | |||||||
| // 上下架状态更新
 | // 上下架状态更新
 | ||||||
| func (b *BundleProvider) HandShelf(_ context.Context, req *bundle.HandShelfRequest) (res *bundle.CommonResponse, err error) { | func (b *BundleProvider) HandShelf(_ context.Context, req *bundle.HandShelfRequest) (res *bundle.CommonResponse, err error) { | ||||||
| 	// shelfStatus: 1-上架,2-下架
 | 	// shelfStatus: 1-上架,2-下架
 | ||||||
| 	return logic.HandShelf(req) | 	return logic.HandleShelf(req) | ||||||
| } | } | ||||||
| func (b *BundleProvider) BundleListV2(_ context.Context, req *bundle.BundleListRequest) (res *bundle.BundleListResponse, err error) { | func (b *BundleProvider) BundleListV2(_ context.Context, req *bundle.BundleListRequest) (res *bundle.BundleListResponse, err error) { | ||||||
| 	return logic.BundleListV2(req) | 	return logic.BundleListV2(req) | ||||||
| @ -33,3 +33,9 @@ func (b *BundleProvider) ValueAddServiceList(_ context.Context, req *bundle.Valu | |||||||
| func (b *BundleProvider) ValueAddServiceDetail(_ context.Context, req *bundle.ValueAddServiceDetailRequest) (res *bundle.ValueAddServiceDetailResponse, err error) { | func (b *BundleProvider) ValueAddServiceDetail(_ context.Context, req *bundle.ValueAddServiceDetailRequest) (res *bundle.ValueAddServiceDetailResponse, err error) { | ||||||
| 	return logic.ValueAddServiceDetail(req) | 	return logic.ValueAddServiceDetail(req) | ||||||
| } | } | ||||||
|  | func (b *BundleProvider) ValueAddServiceLangByUuidAndLanguage(_ context.Context, req *bundle.ValueAddServiceDetailRequest) (res *bundle.ValueAddServiceLang, err error) { | ||||||
|  | 	return logic.ValueAddServiceDetailByUuidAndLanguage(req) | ||||||
|  | } | ||||||
|  | func (b *BundleProvider) CalculatePrice(ctx context.Context, req *bundle.CalculatePriceRequest) (res *bundle.CalculatePriceResponse, err error) { | ||||||
|  | 	return logic.CalculatePrice(req) | ||||||
|  | } | ||||||
|  | |||||||
| @ -1,8 +1,6 @@ | |||||||
| package dao | package dao | ||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"errors" |  | ||||||
| 	"fmt" |  | ||||||
| 	"micro-bundle/internal/model" | 	"micro-bundle/internal/model" | ||||||
| 	"micro-bundle/pb/bundle" | 	"micro-bundle/pb/bundle" | ||||||
| 	"micro-bundle/pkg/app" | 	"micro-bundle/pkg/app" | ||||||
| @ -160,24 +158,17 @@ func BundleListV2(req *bundle.BundleListRequest) (res *bundle.BundleListResponse | |||||||
| 		query = query.Limit(int(req.PageSize)).Offset(int(req.Page-1) * int(req.PageSize)) | 		query = query.Limit(int(req.PageSize)).Offset(int(req.Page-1) * int(req.PageSize)) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if err = query.Find(&bundles).Error; err != nil { | 	if err = query.Preload("BundleToValueAddService").Find(&bundles).Error; err != nil { | ||||||
| 		return res, commonErr.ReturnError(err, msg.ErrorGetBundleList, "获取套餐列表失败: ") | 		return res, commonErr.ReturnError(err, msg.ErrorGetBundleList, "获取套餐列表失败: ") | ||||||
| 	} | 	} | ||||||
| 	if bundles != nil && len(bundles) > 0 { | 	if bundles != nil && len(bundles) > 0 { | ||||||
| 		for _, bundleProfile := range bundles { | 		for _, bundleProfile := range bundles { | ||||||
| 			selectValueAddService := make([]*bundle.SelectValueAddService, 0) | 			selectValueAddService := make([]*bundle.SelectValueAddService, 0) | ||||||
| 			// 通过中间表拼接增值服务数据
 | 			if bundleProfile.BundleToValueAddService != nil { | ||||||
| 			if bundleProfile.UUID != "" { | 				for _, v := range bundleProfile.BundleToValueAddService { | ||||||
| 				bundleToValueAddServices, err := GetBundleToValueAddServiceByBundleUuid(bundleProfile.UUID) |  | ||||||
| 				if err != nil { |  | ||||||
| 					return res, commonErr.ReturnError(err, msg.ErrorGetBundleInfo, "获取增值服务信息失败: ") |  | ||||||
| 				} |  | ||||||
| 				for _, v := range bundleToValueAddServices { |  | ||||||
| 					valueAddDetail, _ := ValueAddServiceDetail(v.ValueUid, "") |  | ||||||
| 					selectValueAddService = append(selectValueAddService, &bundle.SelectValueAddService{ | 					selectValueAddService = append(selectValueAddService, &bundle.SelectValueAddService{ | ||||||
| 						ValueAddUuid: v.ValueUid, | 						ValueAddUuid: v.ValueUid, | ||||||
| 						IsDisplay:    v.IsDisplay, | 						IsDisplay:    v.IsDisplay, | ||||||
| 						ServiceName:  valueAddDetail.ServiceName, |  | ||||||
| 					}) | 					}) | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| @ -210,6 +201,7 @@ func BundleListV2(req *bundle.BundleListRequest) (res *bundle.BundleListResponse | |||||||
| 				CompanySign:           bundleProfile.CompanySign, | 				CompanySign:           bundleProfile.CompanySign, | ||||||
| 				ContractDuration:      int64(bundleProfile.ContractDuration), | 				ContractDuration:      int64(bundleProfile.ContractDuration), | ||||||
| 				Sort:                  bundleProfile.Sort, | 				Sort:                  bundleProfile.Sort, | ||||||
|  | 				ImgOption:             int32(bundleProfile.ImgOption), | ||||||
| 				BgImg1:                bundleProfile.BgImg1, | 				BgImg1:                bundleProfile.BgImg1, | ||||||
| 				BgImg2:                bundleProfile.BgImg2, | 				BgImg2:                bundleProfile.BgImg2, | ||||||
| 				SelectValueAddService: selectValueAddService, | 				SelectValueAddService: selectValueAddService, | ||||||
| @ -229,79 +221,16 @@ func BundleListV2(req *bundle.BundleListRequest) (res *bundle.BundleListResponse | |||||||
| 
 | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func BundleDetailV2(req *bundle.BundleDetailRequest) (res *bundle.BundleDetailResponseV2, err error) { | func BundleDetailV2(req *bundle.BundleDetailRequest) (res *model.BundleProfile, err error) { | ||||||
| 	if req.Uuid == "" { | 	var data model.BundleProfile | ||||||
| 		return res, errors.New("uuid不能为空") | 	err = app.ModuleClients.BundleDB.Model(&model.BundleProfile{}).Where("uuid = ?", req.Uuid). | ||||||
| 	} | 		Preload("BundleProfileLang"). | ||||||
| 	if req.Language == "" { | 		Preload("BundleToValueAddService"). | ||||||
| 		return res, errors.New("language不能为空") | 		First(&data).Error | ||||||
| 	} |  | ||||||
| 	res = new(bundle.BundleDetailResponseV2) |  | ||||||
| 	bundleProfile := new(model.BundleProfile) |  | ||||||
| 	err = app.ModuleClients.BundleDB.Model(&model.BundleProfile{}).Where("uuid = ?", req.Uuid).Preload("BundleProfileLang").First(&bundleProfile).Error |  | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return res, commonErr.ReturnError(err, msg.ErrorGetBundleInfo, "获取套餐信息失败: ") | 		return res, commonErr.ReturnError(err, msg.ErrorGetBundleInfo, "获取套餐信息失败: ") | ||||||
| 	} | 	} | ||||||
| 	bundleProfileLang := &bundle.BundleProfileLang{ | 	return &data, nil | ||||||
| 		BgImg1: bundleProfile.BgImg1, |  | ||||||
| 		BgImg2: bundleProfile.BgImg2, |  | ||||||
| 		Sort:   bundleProfile.Sort, |  | ||||||
| 	} |  | ||||||
| 	if bundleProfile != nil && bundleProfile.BundleProfileLang != nil && len(bundleProfile.BundleProfileLang) > 0 { |  | ||||||
| 		for _, lang := range bundleProfile.BundleProfileLang { |  | ||||||
| 			if lang.Language == req.Language { |  | ||||||
| 				bundleProfileLang = &bundle.BundleProfileLang{ |  | ||||||
| 					Uuid:      lang.UUID, |  | ||||||
| 					Name:      lang.Name, |  | ||||||
| 					Price:     lang.Price, |  | ||||||
| 					PriceType: lang.PriceType, |  | ||||||
| 					Content:   lang.Content, |  | ||||||
| 					Language:  lang.Language, |  | ||||||
| 					CreatedAt: time.Unix(lang.CreatedAt, 0).Format("2006-01-02 15:04:05"), |  | ||||||
| 					UpdatedAt: time.Unix(int64(lang.UpdatedAt), 0).Format("2006-01-02 15:04:05"), |  | ||||||
| 				} |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	selectValueAddService := make([]*bundle.SelectValueAddService, 0) //已选增值服务
 |  | ||||||
| 	// 通过中间表拼接增值服务数据
 |  | ||||||
| 	if bundleProfile.UUID != "" { |  | ||||||
| 		bundleToValueAddServices, err := GetBundleToValueAddServiceByBundleUuid(bundleProfile.UUID) |  | ||||||
| 		if err != nil { |  | ||||||
| 			return res, commonErr.ReturnError(err, msg.ErrorGetBundleInfo, "获取增值服务信息失败: ") |  | ||||||
| 		} |  | ||||||
| 		for _, valueAddService := range bundleToValueAddServices { |  | ||||||
| 			valueAddDeatilData, err := ValueAddServiceDetailByUuidAndLanguage(valueAddService.ValueUid, req.Language) |  | ||||||
| 			if err != nil { |  | ||||||
| 				return res, commonErr.ReturnError(err, msg.ErrorGetBundleInfo, "获取增值服务信息失败: ") |  | ||||||
| 			} |  | ||||||
| 			ValueAddServiceLang := &bundle.ValueAddServiceLang{ |  | ||||||
| 				Uuid:          valueAddDeatilData.UUID, |  | ||||||
| 				ServiceName:   valueAddDeatilData.ServiceName, |  | ||||||
| 				ServiceType:   int32(valueAddDeatilData.ServiceType), |  | ||||||
| 				PriceMode:     int32(valueAddDeatilData.PriceMode), |  | ||||||
| 				PriceType:     int64(valueAddDeatilData.PriceType), |  | ||||||
| 				OriginalPrice: fmt.Sprintf("%.2f", float32(valueAddDeatilData.OriginalPrice)), |  | ||||||
| 				Unit:          string(valueAddDeatilData.Unit), |  | ||||||
| 				Language:      valueAddDeatilData.Language, |  | ||||||
| 				CreatedAt:     time.Unix(valueAddDeatilData.CreatedAt, 0).Format("2006-01-02 15:04:05"), |  | ||||||
| 				UpdatedAt:     time.Unix(valueAddDeatilData.UpdatedAt, 0).Format("2006-01-02 15:04:05"), |  | ||||||
| 			} |  | ||||||
| 			bundleProfileLang.ValueAddServiceLang = append(bundleProfileLang.ValueAddServiceLang, ValueAddServiceLang) |  | ||||||
| 			selectValueAddService = append(selectValueAddService, &bundle.SelectValueAddService{ |  | ||||||
| 				ValueAddUuid: valueAddService.ValueUid, |  | ||||||
| 				ServiceName:  valueAddDeatilData.ServiceName, |  | ||||||
| 				IsDisplay:    valueAddService.IsDisplay, |  | ||||||
| 			}) |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	if selectValueAddService != nil && len(selectValueAddService) > 0 { |  | ||||||
| 		res.SelectValueAddService = selectValueAddService |  | ||||||
| 	} |  | ||||||
| 	res.Bundle = bundleProfileLang |  | ||||||
| 	return |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // 套餐上下架
 | // 套餐上下架
 | ||||||
| @ -385,3 +314,15 @@ func GetBundleLangsByUuid(uuid string) ([]*model.BundleProfileLang, error) { | |||||||
| 		Find(&result).Error | 		Find(&result).Error | ||||||
| 	return result, err | 	return result, err | ||||||
| } | } | ||||||
|  | func GetBundleDetailByUuid(uuid string) (*model.BundleProfile, error) { | ||||||
|  | 	result := &model.BundleProfile{} | ||||||
|  | 	err := app.ModuleClients.BundleDB.Model(&model.BundleProfile{}). | ||||||
|  | 		Preload("BundleToValueAddService", "deleted_at = 0"). | ||||||
|  | 		Preload("BundleProfileLang", "deleted_at = 0"). | ||||||
|  | 		Where("uuid =?", uuid). | ||||||
|  | 		First(&result).Error | ||||||
|  | 	return result, err | ||||||
|  | } | ||||||
|  | func CreateBunldeHistory(tx *gorm.DB, req *model.BundleProfileHistory) error { | ||||||
|  | 	return tx.Model(&model.BundleProfileHistory{}).Create(req).Error | ||||||
|  | } | ||||||
|  | |||||||
| @ -6,13 +6,45 @@ import ( | |||||||
| 	"micro-bundle/pb/bundle" | 	"micro-bundle/pb/bundle" | ||||||
| 	"micro-bundle/pkg/app" | 	"micro-bundle/pkg/app" | ||||||
| 	"micro-bundle/pkg/utils" | 	"micro-bundle/pkg/utils" | ||||||
|  | 	"strconv" | ||||||
| 	"time" | 	"time" | ||||||
| 
 | 
 | ||||||
|  | 	"github.com/duke-git/lancet/v2/datetime" | ||||||
|  | 
 | ||||||
| 	"gorm.io/gorm" | 	"gorm.io/gorm" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func AddBundleExtendRecord(data model.BundleExtensionRecords) error { | func AddBundleExtendRecord(data model.BundleExtensionRecords) error { | ||||||
| 	return app.ModuleClients.BundleDB.Create(&data).Error | 	return app.ModuleClients.BundleDB.Transaction(func(tx *gorm.DB) error { | ||||||
|  | 		if err := tx.Create(&data).Error; err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 		if data.AvailableDurationAdditional != 0 && data.TimeUnit != 0 { | ||||||
|  | 			record := model.BundleOrderRecords{} | ||||||
|  | 			if err := tx.Model(&model.BundleOrderRecords{}).Where(&model.BundleOrderRecords{CustomerID: strconv.Itoa(data.UserId)}).First(&record).Error; err != nil { | ||||||
|  | 				return err | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			expireTime, err := time.Parse(time.DateOnly, record.ExpirationTime) | ||||||
|  | 			if err != nil { | ||||||
|  | 				return err | ||||||
|  | 			} | ||||||
|  | 			switch data.TimeUnit { | ||||||
|  | 			case 1: | ||||||
|  | 				expireTime = datetime.AddDay(expireTime, int64(data.AvailableDurationAdditional)) | ||||||
|  | 			case 2: | ||||||
|  | 				expireTime = datetime.AddMonth(expireTime, int64(data.AvailableDurationAdditional)) | ||||||
|  | 			case 3: | ||||||
|  | 				expireTime = datetime.AddYear(expireTime, int64(data.AvailableDurationAdditional)) | ||||||
|  | 			default: | ||||||
|  | 				return errors.New("时间单位有误") | ||||||
|  | 			} | ||||||
|  | 			record.ExpirationTime = expireTime.Format(time.DateOnly) | ||||||
|  | 			err = tx.Model(&model.BundleOrderRecords{}).Where(&model.BundleOrderRecords{UUID: record.UUID}).Updates(&record).Error | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 		return nil | ||||||
|  | 	}) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func GetBundleExtendRecordList(req *bundle.BundleExtendRecordsListRequest) (data []model.BundleExtendRecordItemPo, total int64, err error) { | func GetBundleExtendRecordList(req *bundle.BundleExtendRecordsListRequest) (data []model.BundleExtendRecordItemPo, total int64, err error) { | ||||||
| @ -179,3 +211,9 @@ func GetVedioWorkDetail(req *bundle.GetVedioWorkDetailReq) (data model.CastWorkV | |||||||
| 	err = app.ModuleClients.BundleDB.Where(&model.CastWorkVideo{WorkUuid: req.WorkId}).First(&data).Error | 	err = app.ModuleClients.BundleDB.Where(&model.CastWorkVideo{WorkUuid: req.WorkId}).First(&data).Error | ||||||
| 	return | 	return | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | // func ToBeComfirmedWorks(req *bundle.ToBeComfirmedWorksReq) (data []model.CastWork, err error) {
 | ||||||
|  | // 	// app.ModuleClients.BundleDB.Where(&model.CastWork{
 | ||||||
|  | // 	// 	ArtistUuid: req.ArtistUuid,
 | ||||||
|  | // 	// })
 | ||||||
|  | // }
 | ||||||
|  | |||||||
| @ -8,90 +8,35 @@ import ( | |||||||
| 	commonErr "micro-bundle/pkg/err" | 	commonErr "micro-bundle/pkg/err" | ||||||
| 	"micro-bundle/pkg/msg" | 	"micro-bundle/pkg/msg" | ||||||
| 	"micro-bundle/pkg/utils" | 	"micro-bundle/pkg/utils" | ||||||
|  | 	"strconv" | ||||||
|  | 	"time" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func CreateOrderRecord(orderRecord *model.BundleOrderRecords, req *bundle.OrderRecord) (res *bundle.CommonResponse, err error) { | func CreateOrderRecord(orderRecord *model.BundleOrderRecords) (res *bundle.CommonResponse, err error) { | ||||||
| 	res = new(bundle.CommonResponse) | 	res = new(bundle.CommonResponse) | ||||||
| 	bundleInfo := new(model.BundleProfile) | 	var bundleInfo model.BundleProfile | ||||||
| 
 |  | ||||||
| 	// 生成UUID和订单号
 |  | ||||||
| 	orderRecord.UUID = app.ModuleClients.SfNode.Generate().Base64() |  | ||||||
| 	orderRecord.OrderNo = utils.GetOrderNo() |  | ||||||
| 
 |  | ||||||
| 	// 开启事务
 |  | ||||||
| 	tx := app.ModuleClients.BundleDB.Begin() |  | ||||||
| 	defer func() { |  | ||||||
| 		if r := recover(); r != nil { |  | ||||||
| 			tx.Rollback() |  | ||||||
| 		} |  | ||||||
| 	}() |  | ||||||
| 
 |  | ||||||
| 	// 查询套餐主表并预加载
 | 	// 查询套餐主表并预加载
 | ||||||
| 	err = tx.Model(&model.BundleProfile{}). | 	err = app.ModuleClients.BundleDB.Model(&model.BundleProfile{}). | ||||||
| 		Where("uuid = ?", orderRecord.BundleUUID). | 		Where("uuid = ?", orderRecord.BundleUUID). | ||||||
| 		Preload("BundleToValueAddService"). | 		Preload("BundleToValueAddService"). | ||||||
| 		Preload("BundleProfileLang", "language = ?", req.Language). | 		Preload("BundleProfileLang", "language = ?", orderRecord.Language). | ||||||
| 		First(&bundleInfo).Error | 		First(&bundleInfo).Error | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		tx.Rollback() |  | ||||||
| 		res.Msg = msg.ErrorBundleNotFound | 		res.Msg = msg.ErrorBundleNotFound | ||||||
| 		return res, commonErr.ReturnError(err, msg.ErrorBundleNotFound, "查询Bundle信息失败: ") | 		return res, commonErr.ReturnError(err, msg.ErrorBundleNotFound, "查询Bundle信息失败: ") | ||||||
| 	} | 	} | ||||||
| 
 |  | ||||||
| 	// 填充BundleCommonJson字段
 | 	// 填充BundleCommonJson字段
 | ||||||
| 	if bundleJson, e := json.Marshal(bundleInfo); e == nil { | 	if bundleJson, e := json.Marshal(bundleInfo); e == nil { | ||||||
| 		orderRecord.BundleCommonJson = string(bundleJson) | 		orderRecord.BundleCommonJson = bundleJson | ||||||
| 	} else { | 	} else { | ||||||
| 		tx.Rollback() |  | ||||||
| 		res.Msg = msg.ErrorDataConvert | 		res.Msg = msg.ErrorDataConvert | ||||||
| 		return res, commonErr.ReturnError(e, msg.ErrorDataConvert, "Bundle信息转换失败: ") | 		return res, commonErr.ReturnError(e, msg.ErrorDataConvert, "Bundle信息转换失败: ") | ||||||
| 	} | 	} | ||||||
| 
 | 	err = app.ModuleClients.BundleDB.Model(&model.BundleOrderRecords{}).Create(orderRecord).Error | ||||||
| 	// 创建主订单
 | 	if err != nil { | ||||||
| 	if err = tx.Model(&model.BundleOrderRecords{}).Create(orderRecord).Error; err != nil { |  | ||||||
| 		tx.Rollback() |  | ||||||
| 		res.Msg = msg.ErrorCreateOrderInfo | 		res.Msg = msg.ErrorCreateOrderInfo | ||||||
| 		return res, commonErr.ReturnError(err, msg.ErrorCreateOrderInfo, "创建订单信息失败: ") | 		return res, commonErr.ReturnError(err, msg.ErrorCreateOrderInfo, "创建订单信息失败: ") | ||||||
| 	} | 	} | ||||||
| 
 |  | ||||||
| 	// 创建子订单
 |  | ||||||
| 	for _, service := range bundleInfo.BundleToValueAddService { |  | ||||||
| 		amount, PriceType, serviceType, e := calculateAmount(service.ValueUid, req, req.Language) |  | ||||||
| 		if e != nil { |  | ||||||
| 			tx.Rollback() |  | ||||||
| 			res.Msg = msg.ErrorDataConvert |  | ||||||
| 			return res, commonErr.ReturnError(e, msg.ErrorDataConvert, "子订单金额计算失败: ") |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		childOrder := &model.BundleOrderValueAdd{ |  | ||||||
| 			UUID:          app.ModuleClients.SfNode.Generate().Base64(), |  | ||||||
| 			OrderUUID:     orderRecord.UUID, // 修正: 这里应使用主订单UUID
 |  | ||||||
| 			CustomerID:    orderRecord.CustomerID, |  | ||||||
| 			CustomerNum:   orderRecord.CustomerNum, |  | ||||||
| 			CustomerName:  orderRecord.CustomerName, |  | ||||||
| 			ServiceType:   serviceType, |  | ||||||
| 			CurrencyType:  PriceType, |  | ||||||
| 			Amount:        amount, |  | ||||||
| 			Num:           0, |  | ||||||
| 			Unit:          0, |  | ||||||
| 			ValueAddUUID:  service.ValueUid, |  | ||||||
| 			Source:        1, |  | ||||||
| 			PaymentStatus: 1, |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		if err = tx.Model(&model.BundleOrderValueAdd{}).Create(childOrder).Error; err != nil { |  | ||||||
| 			tx.Rollback() |  | ||||||
| 			res.Msg = msg.ErrorCreateOrderInfo |  | ||||||
| 			return res, commonErr.ReturnError(err, msg.ErrorCreateOrderInfo, "创建子订单信息失败: ") |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	// 提交事务
 |  | ||||||
| 	if err = tx.Commit().Error; err != nil { |  | ||||||
| 		res.Msg = msg.ErrorCommitTransaction |  | ||||||
| 		return res, commonErr.ReturnError(err, msg.ErrorCommitTransaction, "提交事务失败: ") |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	res.Uuid = orderRecord.UUID | 	res.Uuid = orderRecord.UUID | ||||||
| 	res.OrderNo = orderRecord.OrderNo | 	res.OrderNo = orderRecord.OrderNo | ||||||
| 	res.Msg = msg.SuccessCreateOrderInfo | 	res.Msg = msg.SuccessCreateOrderInfo | ||||||
| @ -99,28 +44,46 @@ func CreateOrderRecord(orderRecord *model.BundleOrderRecords, req *bundle.OrderR | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // calculateAmount 计算子订单金额
 | // calculateAmount 计算子订单金额
 | ||||||
| func calculateAmount(valueUid string, req *bundle.OrderRecord, language string) (float64, int64, int32, error) { | func calculateAmount(valueUid string, req *bundle.OrderRecord) (amount float64, valueAddServiceLang *model.ValueAddServiceLang, num int32, expirationDay string, err error) { | ||||||
| 	var valueAddServiceLang *model.ValueAddServiceLang | 	err = app.ModuleClients.BundleDB. | ||||||
| 	err := app.ModuleClients.BundleDB. | 		Where("uuid = ? AND language = ?", valueUid, req.Language). | ||||||
| 		Where("uuid = ? AND language = ?", valueUid, language). |  | ||||||
| 		First(&valueAddServiceLang).Error | 		First(&valueAddServiceLang).Error | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return 0, valueAddServiceLang.PriceType, valueAddServiceLang.ServiceType, err | 		return | ||||||
| 	} | 	} | ||||||
| 
 |  | ||||||
| 	var amount float64 |  | ||||||
| 	for _, opt := range valueAddServiceLang.Options { | 	for _, opt := range valueAddServiceLang.Options { | ||||||
| 		if valueAddServiceLang.PriceMode == 1 { |  | ||||||
| 		for _, p := range req.PriceOptionsInfo { | 		for _, p := range req.PriceOptionsInfo { | ||||||
| 			if p.ValueUid == valueUid && opt.Id == p.Id { | 			if p.ValueUid == valueUid && opt.Id == p.Id { | ||||||
|  | 				num = opt.Num | ||||||
|  | 				if valueAddServiceLang.PriceMode == 1 { | ||||||
| 					amount = float64(float32(opt.Num) * opt.Price) | 					amount = float64(float32(opt.Num) * opt.Price) | ||||||
| 				} |  | ||||||
| 			} |  | ||||||
| 				} else if valueAddServiceLang.PriceMode == 2 { | 				} else if valueAddServiceLang.PriceMode == 2 { | ||||||
| 					amount = float64(opt.Price) | 					amount = float64(opt.Price) | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| 	return amount, valueAddServiceLang.PriceType, valueAddServiceLang.ServiceType, nil | 		} | ||||||
|  | 
 | ||||||
|  | 		// 计算过期时间
 | ||||||
|  | 		if valueAddServiceLang.ServiceType == 5 { | ||||||
|  | 			expirationDay = calculateExpirationDay(opt.Num, valueAddServiceLang.Unit) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // calculateExpirationDay 计算到期日
 | ||||||
|  | func calculateExpirationDay(num int32, unit string) string { | ||||||
|  | 	now := time.Now() | ||||||
|  | 	switch unit { | ||||||
|  | 	case "天": | ||||||
|  | 		return now.AddDate(0, 0, int(num)).Format("2006-01-02") | ||||||
|  | 	case "月": | ||||||
|  | 		return now.AddDate(0, int(num), 0).Format("2006-01-02") | ||||||
|  | 	case "年": | ||||||
|  | 		return now.AddDate(int(num), 0, 0).Format("2006-01-02") | ||||||
|  | 	default: | ||||||
|  | 		return "" | ||||||
|  | 	} | ||||||
| } | } | ||||||
| func UpdateOrderRecord(orderRecord *model.BundleOrderRecords) (res *bundle.CommonResponse, err error) { | func UpdateOrderRecord(orderRecord *model.BundleOrderRecords) (res *bundle.CommonResponse, err error) { | ||||||
| 	res = new(bundle.CommonResponse) | 	res = new(bundle.CommonResponse) | ||||||
| @ -136,24 +99,26 @@ func UpdateOrderRecord(orderRecord *model.BundleOrderRecords) (res *bundle.Commo | |||||||
| 
 | 
 | ||||||
| func UpdateOrderRecordByOrderNO(orderRecord *model.BundleOrderRecords) (res *bundle.CommonResponse, err error) { | func UpdateOrderRecordByOrderNO(orderRecord *model.BundleOrderRecords) (res *bundle.CommonResponse, err error) { | ||||||
| 	res = new(bundle.CommonResponse) | 	res = new(bundle.CommonResponse) | ||||||
| 	err = app.ModuleClients.BundleDB.Model(&model.BundleOrderRecords{}).Where("order_no = ?", orderRecord.OrderNo).Updates(orderRecord).Error | 	// Step 1: 先更新子订单(增值服务)的支付状态
 | ||||||
| 	if err != nil { |  | ||||||
| 		res.Msg = msg.ErrorUpdateOrderInfo |  | ||||||
| 		return res, commonErr.ReturnError(err, msg.ErrorUpdateOrderInfo, "更新订单信息失败: ") |  | ||||||
| 	} |  | ||||||
| 	valueAdd := &model.BundleOrderValueAdd{ | 	valueAdd := &model.BundleOrderValueAdd{ | ||||||
| 		PaymentStatus: int(orderRecord.Status), | 		PaymentStatus: int(orderRecord.Status), | ||||||
| 		PaymentTime:   orderRecord.PayTime, | 		PaymentTime:   orderRecord.PayTime, | ||||||
| 	} | 	} | ||||||
| 	//更新子订单支付状态
 | 	err = app.ModuleClients.BundleDB.Model(&model.BundleOrderValueAdd{}). | ||||||
| 	err = app.ModuleClients.BundleDB.Model(&model.BundleOrderValueAdd{}).Where("order_uuid = ?", orderRecord.UUID).Updates(valueAdd).Error | 		Where("order_no = ?", orderRecord.OrderNo). | ||||||
|  | 		Updates(valueAdd).Error | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		res.Msg = msg.ErrorUpdateOrderInfo | 		res.Msg = msg.ErrorUpdateOrderInfo | ||||||
| 		return res, commonErr.ReturnError(err, msg.ErrorUpdateOrderInfo, "更新订单信息失败: ") | 		return res, commonErr.ReturnError(err, msg.ErrorUpdateOrderInfo, "更新增值服务支付状态失败: ") | ||||||
| 	} | 	} | ||||||
|  | 	// Step 2: 再更新主订单信息(如果存在)
 | ||||||
|  | 	err = app.ModuleClients.BundleDB.Model(&model.BundleOrderRecords{}). | ||||||
|  | 		Where("order_no = ?", orderRecord.OrderNo). | ||||||
|  | 		Updates(orderRecord).Error | ||||||
|  | 	// Step 3: 返回结果(即使主订单更新失败,也视为成功)
 | ||||||
| 	res.Uuid = orderRecord.UUID | 	res.Uuid = orderRecord.UUID | ||||||
| 	res.Msg = msg.SuccessUpdateOrderInfo | 	res.Msg = msg.SuccessUpdateOrderInfo | ||||||
| 	return | 	return res, nil | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func OrderRecordsList(req *bundle.OrderRecordsRequest) (res *bundle.OrderRecordsResponse, err error) { | func OrderRecordsList(req *bundle.OrderRecordsRequest) (res *bundle.OrderRecordsResponse, err error) { | ||||||
| @ -267,6 +232,7 @@ func OrderRecordsList(req *bundle.OrderRecordsRequest) (res *bundle.OrderRecords | |||||||
| 			BundleCommonUid:       record.BundleCommonUid, | 			BundleCommonUid:       record.BundleCommonUid, | ||||||
| 			AddBundleCommonUid:    record.AddBundleCommonUid, | 			AddBundleCommonUid:    record.AddBundleCommonUid, | ||||||
| 			FinancialConfirmation: record.FinancialConfirmation, | 			FinancialConfirmation: record.FinancialConfirmation, | ||||||
|  | 			ExpirationTime:        record.ExpirationTime, | ||||||
| 		}) | 		}) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| @ -296,8 +262,10 @@ func OrderRecordDetail(req *bundle.OrderRecordsDetailRequest) (res *bundle.Order | |||||||
| 	if req.CustomerID != "" { | 	if req.CustomerID != "" { | ||||||
| 		query = query.Where("customer_id = ?", req.CustomerID) | 		query = query.Where("customer_id = ?", req.CustomerID) | ||||||
| 	} | 	} | ||||||
| 
 | 	if req.BundleUUID != "" { | ||||||
| 	err = query.First(&orderRecord).Error | 		query = query.Where("bundle_uuid = ?", req.BundleUUID) | ||||||
|  | 	} | ||||||
|  | 	err = query.Order("expiration_time desc").First(&orderRecord).Error | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return res, commonErr.ReturnError(err, msg.ErrorGetOrderInfo, "获取订单信息失败: ") | 		return res, commonErr.ReturnError(err, msg.ErrorGetOrderInfo, "获取订单信息失败: ") | ||||||
| 	} | 	} | ||||||
| @ -325,6 +293,198 @@ func OrderRecordDetail(req *bundle.OrderRecordsDetailRequest) (res *bundle.Order | |||||||
| 		ValueAddBundleUuid:   orderRecord.ValueAddBundleUUID, | 		ValueAddBundleUuid:   orderRecord.ValueAddBundleUUID, | ||||||
| 		ValueAddBundleAmount: orderRecord.ValueAddBundleAmount, | 		ValueAddBundleAmount: orderRecord.ValueAddBundleAmount, | ||||||
| 		TotalAmount:          orderRecord.TotalAmount, | 		TotalAmount:          orderRecord.TotalAmount, | ||||||
|  | 		ExpirationTime:       orderRecord.ExpirationTime, | ||||||
| 	} | 	} | ||||||
| 	return | 	return | ||||||
| } | } | ||||||
|  | func PackagePriceAndTime(orderRecord *bundle.OrderRecord) (res *bundle.PackagePriceAndTimeResponse, err error) { | ||||||
|  | 	res = new(bundle.PackagePriceAndTimeResponse) | ||||||
|  | 	bundleInfo := new(model.BundleProfile) | ||||||
|  | 	// 查询套餐主表并预加载
 | ||||||
|  | 	err = app.ModuleClients.BundleDB.Model(&model.BundleProfile{}). | ||||||
|  | 		Where("uuid = ?", orderRecord.BundleUuid). | ||||||
|  | 		Preload("BundleToValueAddService"). | ||||||
|  | 		Preload("BundleProfileLang", "language = ?", orderRecord.Language). | ||||||
|  | 		First(&bundleInfo).Error | ||||||
|  | 	if err != nil { | ||||||
|  | 		return res, commonErr.ReturnError(err, msg.ErrorBundleNotFound, "查询Bundle信息失败: ") | ||||||
|  | 	} | ||||||
|  | 	var ( | ||||||
|  | 		valueAddAmount float64 | ||||||
|  | 		expirationTime = "9999-12-31" | ||||||
|  | 	) | ||||||
|  | 	for _, service := range bundleInfo.BundleToValueAddService { | ||||||
|  | 		amount, _, _, day, e := calculateAmount(service.ValueUid, orderRecord) | ||||||
|  | 		if e != nil { | ||||||
|  | 			return res, commonErr.ReturnError(e, msg.ErrorDataConvert, "子订单金额计算失败: ") | ||||||
|  | 		} | ||||||
|  | 		if day != "" { | ||||||
|  | 			expirationTime = day | ||||||
|  | 		} | ||||||
|  | 		valueAddAmount = valueAddAmount + amount | ||||||
|  | 	} | ||||||
|  | 	res = &bundle.PackagePriceAndTimeResponse{ | ||||||
|  | 		Price: float32(valueAddAmount), | ||||||
|  | 		Time:  expirationTime, | ||||||
|  | 	} | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  | func CreateOrderAddRecord(req *bundle.OrderAddRecord) (res *bundle.CommonResponse, err error) { | ||||||
|  | 	tx := app.ModuleClients.BundleDB.Begin() | ||||||
|  | 	defer func() { | ||||||
|  | 		if r := recover(); r != nil { | ||||||
|  | 			tx.Rollback() | ||||||
|  | 		} | ||||||
|  | 	}() | ||||||
|  | 	orderNo := utils.GetOrderNo() | ||||||
|  | 	var childOrders []*model.BundleOrderValueAdd | ||||||
|  | 	for _, i := range req.AddPriceOptionsList { | ||||||
|  | 		childOrder := &model.BundleOrderValueAdd{ | ||||||
|  | 			UUID:          app.ModuleClients.SfNode.Generate().Base64(), | ||||||
|  | 			OrderUUID:     req.OrderUUID, // 修正: 这里应使用主订单UUID
 | ||||||
|  | 			CustomerID:    req.CustomerID, | ||||||
|  | 			CustomerNum:   req.CustomerNum, | ||||||
|  | 			CustomerName:  req.CustomerName, | ||||||
|  | 			ServiceType:   i.ServiceType, | ||||||
|  | 			CurrencyType:  i.CurrencyType, | ||||||
|  | 			Amount:        float64(i.Amount), | ||||||
|  | 			OrderNo:       orderNo, | ||||||
|  | 			Num:           i.Num, | ||||||
|  | 			Unit:          i.Unit, | ||||||
|  | 			ValueAddUUID:  i.ValueUid, | ||||||
|  | 			Source:        2, | ||||||
|  | 			PaymentStatus: 1, | ||||||
|  | 			SignContract:  req.SignContract, | ||||||
|  | 			Signature:     req.Signature, | ||||||
|  | 			SignedTime:    req.SignedTime, | ||||||
|  | 			Snapshot:      req.Snapshot, | ||||||
|  | 		} | ||||||
|  | 		childOrders = append(childOrders, childOrder) | ||||||
|  | 
 | ||||||
|  | 		// 如果是类型5服务,更新主订单的过期时间
 | ||||||
|  | 		if i.ServiceType == 5 && req.ExpirationDate != "" { | ||||||
|  | 			if err := tx.Model(&model.BundleOrderRecords{}). | ||||||
|  | 				Where("uuid = ?", req.BundleUuid). | ||||||
|  | 				Update("expiration_time", req.ExpirationDate).Error; err != nil { | ||||||
|  | 				tx.Rollback() | ||||||
|  | 				return nil, commonErr.ReturnError(err, msg.ErrorCreateOrderInfo, "更新主订单过期时间失败: ") | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	// 批量创建子订单(提高性能)
 | ||||||
|  | 	if err = tx.Model(&model.BundleOrderValueAdd{}).Create(childOrders).Error; err != nil { | ||||||
|  | 		tx.Rollback() | ||||||
|  | 		return res, commonErr.ReturnError(err, msg.ErrorCreateOrderInfo, "批量创建子订单失败") | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	// 提交事务
 | ||||||
|  | 	if err := tx.Commit().Error; err != nil { | ||||||
|  | 		tx.Rollback() | ||||||
|  | 		return nil, commonErr.ReturnError(err, msg.ErrorCreateOrderInfo, "提交事务失败: ") | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	return &bundle.CommonResponse{ | ||||||
|  | 		Uuid:    req.BundleUuid, | ||||||
|  | 		OrderNo: orderNo, | ||||||
|  | 		Msg:     msg.SuccessCreateOrderInfo, | ||||||
|  | 	}, nil | ||||||
|  | } | ||||||
|  | func OrderRecordsListV2(req *bundle.OrderRecordsRequestV2) (res *bundle.OrderRecordsResponseV2, err error) { | ||||||
|  | 	res = new(bundle.OrderRecordsResponseV2) | ||||||
|  | 	var count int64 | ||||||
|  | 	modelObj := app.ModuleClients.BundleDB.Model(&model.BundleOrderRecords{}). | ||||||
|  | 		Select("bundle_order_records.*,a.name as bundle_name"). | ||||||
|  | 		Preload("BundleOrderValueAdd"). | ||||||
|  | 		Joins("left join bundle_profile a on bundle_order_records.bundle_uuid = a.uuid") | ||||||
|  | 	//Joins("left join bundle_order_value_add on bundle_order_records.uuid = bundle_order_value_add.order_uuid")
 | ||||||
|  | 	if len(req.UserIds) != 0 { | ||||||
|  | 		modelObj = modelObj.Where("bundle_order_records.customer_id in ?", req.UserIds) | ||||||
|  | 	} | ||||||
|  | 	if req.BundleName != "" { | ||||||
|  | 		modelObj = modelObj.Where("a.name like ?", "%"+req.BundleName+"%") | ||||||
|  | 	} | ||||||
|  | 	if req.PayStatus != 0 { | ||||||
|  | 		modelObj = modelObj.Where("bundle_order_records.status = ?", req.PayStatus) | ||||||
|  | 	} | ||||||
|  | 	if req.AddPayStatus != 0 { | ||||||
|  | 		modelObj = modelObj.Where("exists (select 1 from bundle_order_value_add where bundle_order_value_add.order_no = bundle_order_records.order_no and bundle_order_value_add.payment_status = ?)", req.AddPayStatus) | ||||||
|  | 	} | ||||||
|  | 	if req.OrderNo != "" { | ||||||
|  | 		modelObj = modelObj.Where("bundle_order_records.order_no = ?", req.OrderNo) | ||||||
|  | 	} | ||||||
|  | 	if req.OrderAddNo != "" { | ||||||
|  | 		modelObj = modelObj.Where("exists (select 1 from bundle_order_value_add where bundle_order_value_add.order_no = bundle_order_records.order_no and bundle_order_value_add.order_no = ?)", req.OrderAddNo) | ||||||
|  | 	} | ||||||
|  | 	if req.BundleCreateAtStart != "" && req.BundleCreateAtEnd != "" { | ||||||
|  | 		modelObj = modelObj.Where("bundle_order_records.created_at between ? and ?", req.BundleCreateAtStart, req.BundleCreateAtEnd) | ||||||
|  | 	} | ||||||
|  | 	if req.OrderAddCreateAtStart != "" && req.OrderAddCreateAtEnd != "" { | ||||||
|  | 		modelObj = modelObj.Where("bundle_order_records.created_at between ? and ?", req.OrderAddCreateAtStart, req.OrderAddCreateAtEnd) | ||||||
|  | 	} | ||||||
|  | 	err = modelObj.Count(&count).Error | ||||||
|  | 	if req.PageSize != 0 && req.Page != 0 { | ||||||
|  | 		modelObj = modelObj.Limit(int(req.PageSize)).Offset(int(req.Page-1) * int(req.PageSize)) | ||||||
|  | 	} | ||||||
|  | 	type OrderRecords struct { | ||||||
|  | 		model.BundleOrderRecords | ||||||
|  | 		BundleName string `json:"bundleName"` | ||||||
|  | 	} | ||||||
|  | 	var records []OrderRecords | ||||||
|  | 	err = modelObj.Order("bundle_order_records.created_at desc").Find(&records).Error | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 	for _, record := range records { | ||||||
|  | 		customerID, _ := strconv.ParseInt(record.CustomerID, 10, 64) | ||||||
|  | 		orderItem := &bundle.OrderBundleRecordInfo{ | ||||||
|  | 			OrderNo:        record.OrderNo, | ||||||
|  | 			BundleName:     record.BundleName, | ||||||
|  | 			PayStatus:      int32(record.Status), | ||||||
|  | 			TelNum:         "", | ||||||
|  | 			CustomerName:   record.CustomerName, | ||||||
|  | 			BundleCreateAt: record.CreatedAt.Format("2006-01-02 15:04:05"), | ||||||
|  | 			Amount:         record.Amount, | ||||||
|  | 			CustomerId:     customerID, | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		// 构建子订单 map,按 orderAddNo 聚合
 | ||||||
|  | 		addMap := make(map[string]*bundle.OrderAddBundleRecordInfo) | ||||||
|  | 		for _, sub := range record.BundleOrderValueAdd { | ||||||
|  | 			orderAddNo := sub.OrderNo | ||||||
|  | 
 | ||||||
|  | 			// SettlementAmount 规则
 | ||||||
|  | 			settlementAmount := float32(sub.Amount) | ||||||
|  | 			if sub.OrderNo == record.OrderNo { | ||||||
|  | 				settlementAmount = record.TotalAmount | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			if existing, ok := addMap[orderAddNo]; ok { | ||||||
|  | 				existing.Amount += float32(sub.Amount) | ||||||
|  | 				existing.SettlementAmount += settlementAmount | ||||||
|  | 			} else { | ||||||
|  | 				addMap[orderAddNo] = &bundle.OrderAddBundleRecordInfo{ | ||||||
|  | 					OrderAddNo:       orderAddNo, | ||||||
|  | 					Amount:           float32(sub.Amount), | ||||||
|  | 					SettlementAmount: settlementAmount, | ||||||
|  | 					CurrencyType:     int32(sub.CurrencyType), | ||||||
|  | 					//HandlingFee:      float32(sub.HandlingFee),
 | ||||||
|  | 					//ExchangeRate:     float32(sub.ExchangeRate),
 | ||||||
|  | 					OrderAddCreateAt: sub.CreatedAt.Format("2006-01-02 15:04:05"), | ||||||
|  | 					AddPayStatus:     int32(sub.PaymentStatus), | ||||||
|  | 					Contract:         sub.SignContract, | ||||||
|  | 					Snapshot:         sub.Snapshot, | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		// 将聚合后的子订单添加到主订单返回结构中
 | ||||||
|  | 		for _, v := range addMap { | ||||||
|  | 			orderItem.AddBundleInfo = append(orderItem.AddBundleInfo, v) | ||||||
|  | 		} | ||||||
|  | 		res.BundleInfo = append(res.BundleInfo, orderItem) | ||||||
|  | 	} | ||||||
|  | 	res.Total = int32(count) | ||||||
|  | 	res.Page = req.Page | ||||||
|  | 	res.PageSize = req.PageSize | ||||||
|  | 	return res, nil | ||||||
|  | } | ||||||
|  | |||||||
| @ -1,6 +1,7 @@ | |||||||
| package dao | package dao | ||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
|  | 	"fmt" | ||||||
| 	"micro-bundle/internal/model" | 	"micro-bundle/internal/model" | ||||||
| 	"micro-bundle/pb/bundle" | 	"micro-bundle/pb/bundle" | ||||||
| 	"micro-bundle/pkg/app" | 	"micro-bundle/pkg/app" | ||||||
| @ -113,10 +114,10 @@ func UpdateValueAddServiceLang(tx *gorm.DB, columns map[string]interface{}) (err | |||||||
| 
 | 
 | ||||||
| // 增值套餐列表
 | // 增值套餐列表
 | ||||||
| func ValueAddServiceList(req *bundle.ValueAddServiceListRequest) (res []*model.ValueAddService, total int64, err error) { | func ValueAddServiceList(req *bundle.ValueAddServiceListRequest) (res []*model.ValueAddService, total int64, err error) { | ||||||
| 	query := app.ModuleClients.BundleDB.Model(&model.ValueAddService{}).Preload("ValueAddServiceLang") | 	query := app.ModuleClients.BundleDB.Model(&model.ValueAddService{}). | ||||||
| 	// Preload("ValueAddServiceLang", func(db *gorm.DB) *gorm.DB {
 | 		Preload("ValueAddServiceLang", func(db *gorm.DB) *gorm.DB { | ||||||
| 	// 	return db.Select("uuid,service_name,service_type,price_mode,original_price,unit,language,price_type.options,created_at,updated_at")
 | 			return db.Select("uuid,service_name,service_type,price_mode,original_price,unit,language,price_type,options,created_at,updated_at") | ||||||
| 	// })
 | 		}) | ||||||
| 
 | 
 | ||||||
| 	count := *query | 	count := *query | ||||||
| 	if req.PageSize != 0 && req.Page != 0 { | 	if req.PageSize != 0 && req.Page != 0 { | ||||||
| @ -131,7 +132,7 @@ func ValueAddServiceList(req *bundle.ValueAddServiceListRequest) (res []*model.V | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // 增值套餐详情
 | // 增值套餐详情
 | ||||||
| func ValueAddServiceDetail(uuid string, language string) (valueAddServiceDetail *model.ValueAddService, err error) { | func ValueAddServiceDetail(uuid string) (valueAddServiceDetail *model.ValueAddService, err error) { | ||||||
| 	var data model.ValueAddService | 	var data model.ValueAddService | ||||||
| 	err = app.ModuleClients.BundleDB.Where("uuid = ?", uuid).Preload("ValueAddServiceLang").First(&data).Error | 	err = app.ModuleClients.BundleDB.Where("uuid = ?", uuid).Preload("ValueAddServiceLang").First(&data).Error | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| @ -157,3 +158,32 @@ func GetBundleToValueAddServiceByValueUid(valueUid string) ([]model.BundleToValu | |||||||
| 		Find(&rels).Error | 		Find(&rels).Error | ||||||
| 	return rels, err | 	return rels, err | ||||||
| } | } | ||||||
|  | func GetValueAddServiceDetailByUuid(tx *gorm.DB, uuid string) (*model.ValueAddService, error) { | ||||||
|  | 	result := &model.ValueAddService{} | ||||||
|  | 	err := tx.Model(&model.ValueAddService{}). | ||||||
|  | 		Preload("ValueAddServiceLang", "deleted_at = 0"). | ||||||
|  | 		Where("uuid =? and deleted_at=0", uuid). | ||||||
|  | 		First(&result).Error | ||||||
|  | 	return result, err | ||||||
|  | } | ||||||
|  | func CreateValueAddServiceHistory(tx *gorm.DB, req *model.ValueAddServiceHistory) error { | ||||||
|  | 	return tx.Model(&model.ValueAddServiceHistory{}).Create(req).Error | ||||||
|  | } | ||||||
|  | func BatchValueAddServiceDetailTx(tx *gorm.DB, uids []string) (map[string]*model.ValueAddService, error) { | ||||||
|  | 	if len(uids) == 0 { | ||||||
|  | 		return map[string]*model.ValueAddService{}, nil // 返回空 map,避免 nil panic
 | ||||||
|  | 	} | ||||||
|  | 	var results []*model.ValueAddService | ||||||
|  | 	err := tx.Model(&model.ValueAddService{}). | ||||||
|  | 		Where("uuid IN ? AND deleted_at = 0", uids). | ||||||
|  | 		Preload("ValueAddServiceLang", "deleted_at = 0"). | ||||||
|  | 		Find(&results).Error | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, fmt.Errorf("批量查询增值服务失败: %w", err) | ||||||
|  | 	} | ||||||
|  | 	resultMap := make(map[string]*model.ValueAddService, len(results)) | ||||||
|  | 	for _, detail := range results { | ||||||
|  | 		resultMap[detail.UUID] = detail | ||||||
|  | 	} | ||||||
|  | 	return resultMap, nil | ||||||
|  | } | ||||||
|  | |||||||
| @ -110,3 +110,8 @@ func GetVedioWorkDetail(req *bundle.GetVedioWorkDetailReq) (*bundle.GetVedioeWor | |||||||
| 	err = copier.Copy(result, &data) | 	err = copier.Copy(result, &data) | ||||||
| 	return result, err | 	return result, err | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | func ToBeComfirmedWorks(req *bundle.ToBeComfirmedWorksReq) (*bundle.ToBeComfirmedWorksResp, error) { | ||||||
|  | 	// data, err := dao.ToBeComfirmedWorks(req)
 | ||||||
|  | 	return nil, nil | ||||||
|  | } | ||||||
|  | |||||||
| @ -1,17 +1,20 @@ | |||||||
| package logic | package logic | ||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
|  | 	"encoding/json" | ||||||
| 	"errors" | 	"errors" | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"micro-bundle/internal/dao" | 	"micro-bundle/internal/dao" | ||||||
| 	"micro-bundle/pkg/app" | 	"micro-bundle/pkg/app" | ||||||
| 	"micro-bundle/pkg/msg" | 	"micro-bundle/pkg/msg" | ||||||
|  | 	"time" | ||||||
| 
 | 
 | ||||||
| 	"micro-bundle/internal/model" | 	"micro-bundle/internal/model" | ||||||
| 	"micro-bundle/pb/bundle" | 	"micro-bundle/pb/bundle" | ||||||
| 
 | 
 | ||||||
| 	"github.com/aliyun/alibaba-cloud-sdk-go/sdk/utils" | 	"github.com/aliyun/alibaba-cloud-sdk-go/sdk/utils" | ||||||
| 	"github.com/jinzhu/copier" | 	"github.com/jinzhu/copier" | ||||||
|  | 	"gorm.io/datatypes" | ||||||
| 	"gorm.io/gorm" | 	"gorm.io/gorm" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| @ -68,6 +71,8 @@ func SaveBundle(req *bundle.BundleProfile) (res *bundle.SaveResponse, err error) | |||||||
| 		Content:     req.Content, | 		Content:     req.Content, | ||||||
| 		Price:       req.Price, | 		Price:       req.Price, | ||||||
| 		PriceType:   req.PriceType, | 		PriceType:   req.PriceType, | ||||||
|  | 		Contract:    "https://e-cdn.fontree.cn/fonchain-main/prod/file/saas/contract/template-25032801.pdf", | ||||||
|  | 		ImgOption:   int8(req.ImgOption), | ||||||
| 		BgImg1:      req.BgImg1, | 		BgImg1:      req.BgImg1, | ||||||
| 		BgImg2:      req.BgImg2, | 		BgImg2:      req.BgImg2, | ||||||
| 		ShelfStatus: 2, //默认初始状态为2-下架
 | 		ShelfStatus: 2, //默认初始状态为2-下架
 | ||||||
| @ -96,6 +101,7 @@ func SaveBundle(req *bundle.BundleProfile) (res *bundle.SaveResponse, err error) | |||||||
| 	} | 	} | ||||||
| 	var cancelValueAddService = make(map[string]string) | 	var cancelValueAddService = make(map[string]string) | ||||||
| 	selectService := make([]*model.BundleToValueAddService, 0) | 	selectService := make([]*model.BundleToValueAddService, 0) | ||||||
|  | 	var selectValueAddServiceCount = make(map[int]struct{}) | ||||||
| 	if req.Language == msg.ZH_CN && req.SelectValueAddService != nil && len(req.SelectValueAddService) > 0 { | 	if req.Language == msg.ZH_CN && req.SelectValueAddService != nil && len(req.SelectValueAddService) > 0 { | ||||||
| 		for _, v := range req.SelectValueAddService { | 		for _, v := range req.SelectValueAddService { | ||||||
| 			detail, checkErr := dao.ValueAddServiceDetailByUuidAndLanguage(v.ValueAddUuid, req.Language) | 			detail, checkErr := dao.ValueAddServiceDetailByUuidAndLanguage(v.ValueAddUuid, req.Language) | ||||||
| @ -123,6 +129,10 @@ func SaveBundle(req *bundle.BundleProfile) (res *bundle.SaveResponse, err error) | |||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
|  | 			if _, exists := selectValueAddServiceCount[int(detail.ServiceType)]; exists { | ||||||
|  | 				return res, errors.New(fmt.Sprintf("所选增值服务[%s]类型存在多个", detail.ServiceName)) | ||||||
|  | 			} | ||||||
|  | 			selectValueAddServiceCount[int(detail.ServiceType)] = struct{}{} | ||||||
| 			selectService = append(selectService, &model.BundleToValueAddService{ | 			selectService = append(selectService, &model.BundleToValueAddService{ | ||||||
| 				ValueUid:  v.ValueAddUuid, | 				ValueUid:  v.ValueAddUuid, | ||||||
| 				IsDisplay: v.IsDisplay, | 				IsDisplay: v.IsDisplay, | ||||||
| @ -140,6 +150,9 @@ func SaveBundle(req *bundle.BundleProfile) (res *bundle.SaveResponse, err error) | |||||||
| 	_, err = dao.BundleDetailByUuidAndLanguage(req.Uuid, req.Language) | 	_, err = dao.BundleDetailByUuidAndLanguage(req.Uuid, req.Language) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		if err == gorm.ErrRecordNotFound { | 		if err == gorm.ErrRecordNotFound { | ||||||
|  | 			// if req.Uuid != "" {
 | ||||||
|  | 			// 	return res, errors.New("套餐不存在")
 | ||||||
|  | 			// }
 | ||||||
| 			if req.Language != msg.ZH_CN { | 			if req.Language != msg.ZH_CN { | ||||||
| 				_, err = dao.BundleDetailByUuidAndLanguage(req.Uuid, msg.ZH_CN) | 				_, err = dao.BundleDetailByUuidAndLanguage(req.Uuid, msg.ZH_CN) | ||||||
| 				if err != nil { | 				if err != nil { | ||||||
| @ -203,9 +216,9 @@ func SaveBundle(req *bundle.BundleProfile) (res *bundle.SaveResponse, err error) | |||||||
| 	} else { // 已存在,进行更新
 | 	} else { // 已存在,进行更新
 | ||||||
| 
 | 
 | ||||||
| 		// 更新前保存历史记录
 | 		// 更新前保存历史记录
 | ||||||
| 		// if err = dao.CreateBundleProfileHistory(tx,req.Uuid); err != nil {
 | 		if saveErr := saveBundleHistory(tx, req.Uuid, "", 0); saveErr != nil { | ||||||
| 		// 	return res, errors.New("保存套餐历史记录失败: " + err.Error())
 | 			return res, saveErr | ||||||
| 		// }
 | 		} | ||||||
| 
 | 
 | ||||||
| 		if req.Language == msg.ZH_CN { | 		if req.Language == msg.ZH_CN { | ||||||
| 			if len(cancelValueAddService) > 0 { | 			if len(cancelValueAddService) > 0 { | ||||||
| @ -226,6 +239,7 @@ func SaveBundle(req *bundle.BundleProfile) (res *bundle.SaveResponse, err error) | |||||||
| 				"content":    req.Content, | 				"content":    req.Content, | ||||||
| 				"price":      req.Price, | 				"price":      req.Price, | ||||||
| 				"price_type": req.PriceType, | 				"price_type": req.PriceType, | ||||||
|  | 				"img_option": req.ImgOption, | ||||||
| 				"bg_img1":    req.BgImg1, | 				"bg_img1":    req.BgImg1, | ||||||
| 				"bg_img2":    req.BgImg2, | 				"bg_img2":    req.BgImg2, | ||||||
| 			} | 			} | ||||||
| @ -296,30 +310,112 @@ func BundleListV2(req *bundle.BundleListRequest) (res *bundle.BundleListResponse | |||||||
| } | } | ||||||
| func BundleDetailV2(req *bundle.BundleDetailRequest) (res *bundle.BundleDetailResponseV2, err error) { | func BundleDetailV2(req *bundle.BundleDetailRequest) (res *bundle.BundleDetailResponseV2, err error) { | ||||||
| 	res = new(bundle.BundleDetailResponseV2) | 	res = new(bundle.BundleDetailResponseV2) | ||||||
|  | 	bundleProfile := &bundle.BundleProfile{} | ||||||
|  | 	bundleProfileLangs := make([]*bundle.BundleProfileLang, 0) | ||||||
|  | 	selectValueAddServices := make([]*bundle.SelectValueAddService, 0) //已选增值服务
 | ||||||
| 	if req.Uuid == "" { | 	if req.Uuid == "" { | ||||||
| 		res.Msg = "" |  | ||||||
| 		return res, errors.New("uuid不能为空") | 		return res, errors.New("uuid不能为空") | ||||||
| 	} | 	} | ||||||
| 	if req.Language == "" { | 	// if req.Language == "" {
 | ||||||
| 		res.Msg = "" | 	// 	return res, errors.New("language不能为空")
 | ||||||
| 		return res, errors.New("language不能为空") | 	// }
 | ||||||
| 	} | 	detail, err := dao.BundleDetailV2(req) | ||||||
| 	res, err = dao.BundleDetailV2(req) |  | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		res.Msg = err.Error() | 		res.Msg = err.Error() | ||||||
| 	} | 	} | ||||||
| 	return | 	if detail != nil { | ||||||
|  | 		bundleProfile.Uuid = detail.UUID | ||||||
|  | 		bundleProfile.Name = detail.Name | ||||||
|  | 		bundleProfile.Content = detail.Content | ||||||
|  | 		bundleProfile.Price = detail.Price | ||||||
|  | 		bundleProfile.PriceType = detail.PriceType | ||||||
|  | 		bundleProfile.ImgOption = int32(detail.ImgOption) | ||||||
|  | 		bundleProfile.BgImg1 = detail.BgImg1 | ||||||
|  | 		bundleProfile.BgImg2 = detail.BgImg2 | ||||||
|  | 		bundleProfile.Sort = detail.Sort | ||||||
|  | 		bundleProfile.ShelfStatus = detail.ShelfStatus | ||||||
|  | 		bundleProfile.CreatedAt = detail.CreatedAt.Format("2006-01-02 15:04:05") | ||||||
|  | 		bundleProfile.UpdatedAt = detail.UpdatedAt.Format("2006-01-02 15:04:05") | ||||||
|  | 		bundleProfile.Contract = detail.Contract | ||||||
|  | 		if detail.BundleToValueAddService != nil && len(detail.BundleToValueAddService) > 0 { | ||||||
|  | 			for _, valueAddService := range detail.BundleToValueAddService { | ||||||
|  | 				selectValueAddService := &bundle.SelectValueAddService{ | ||||||
|  | 					ValueAddUuid: valueAddService.ValueUid, | ||||||
|  | 					IsDisplay:    valueAddService.IsDisplay, | ||||||
|  | 				} | ||||||
|  | 				selectValueAddServices = append(selectValueAddServices, selectValueAddService) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 		if detail.BundleProfileLang != nil && len(detail.BundleProfileLang) > 0 { | ||||||
|  | 			for _, lang := range detail.BundleProfileLang { | ||||||
|  | 				bundleProfileLang := &bundle.BundleProfileLang{ | ||||||
|  | 					Uuid:      lang.UUID, | ||||||
|  | 					Name:      lang.Name, | ||||||
|  | 					Price:     lang.Price, | ||||||
|  | 					PriceType: lang.PriceType, | ||||||
|  | 					Content:   lang.Content, | ||||||
|  | 					Language:  lang.Language, | ||||||
|  | 					CreatedAt: time.Unix(lang.CreatedAt, 0).Format("2006-01-02 15:04:05"), | ||||||
|  | 					UpdatedAt: time.Unix(int64(lang.UpdatedAt), 0).Format("2006-01-02 15:04:05"), | ||||||
|  | 				} | ||||||
|  | 				// 通过中间表拼接增值服务数据
 | ||||||
|  | 				// if detail.BundleToValueAddService != nil && len(detail.BundleToValueAddService) > 0 {
 | ||||||
|  | 				// 	for _, valueAddService := range detail.BundleToValueAddService {
 | ||||||
|  | 				// 		valueAddDeatilData, err := dao.ValueAddServiceDetailByUuidAndLanguage(valueAddService.ValueUid, bundleProfileLang.Language)
 | ||||||
|  | 				// 		if err != nil {
 | ||||||
|  | 				// 			return res, err
 | ||||||
|  | 				// 		}
 | ||||||
|  | 				//if valueAddService.IsDisplay{}
 | ||||||
|  | 				// ValueAddServiceLang := &bundle.ValueAddServiceLang{
 | ||||||
|  | 				// 	Uuid:          valueAddDeatilData.UUID,
 | ||||||
|  | 				// 	ServiceName:   valueAddDeatilData.ServiceName,
 | ||||||
|  | 				// 	ServiceType:   int32(valueAddDeatilData.ServiceType),
 | ||||||
|  | 				// 	PriceMode:     int32(valueAddDeatilData.PriceMode),
 | ||||||
|  | 				// 	PriceType:     int64(valueAddDeatilData.PriceType),
 | ||||||
|  | 				// 	OriginalPrice: fmt.Sprintf("%.2f", float32(valueAddDeatilData.OriginalPrice)),
 | ||||||
|  | 				// 	Unit:          string(valueAddDeatilData.Unit),
 | ||||||
|  | 				// 	Language:      valueAddDeatilData.Language,
 | ||||||
|  | 				// 	CreatedAt:     time.Unix(valueAddDeatilData.CreatedAt, 0).Format("2006-01-02 15:04:05"),
 | ||||||
|  | 				// 	UpdatedAt:     time.Unix(valueAddDeatilData.UpdatedAt, 0).Format("2006-01-02 15:04:05"),
 | ||||||
|  | 				// }
 | ||||||
|  | 				//bundleProfileLang.ValueAddServiceLang = append(bundleProfileLang.ValueAddServiceLang, ValueAddServiceLang)
 | ||||||
|  | 				// 		selectValueAddService = append(selectValueAddService, &bundle.SelectValueAddService{
 | ||||||
|  | 				// 			ValueAddUuid: valueAddService.ValueUid,
 | ||||||
|  | 				// 			ServiceName:  valueAddDeatilData.ServiceName,
 | ||||||
|  | 				// 			IsDisplay:    valueAddService.IsDisplay,
 | ||||||
|  | 				// 		})
 | ||||||
|  | 				// 	}
 | ||||||
|  | 				// }
 | ||||||
|  | 				bundleProfileLangs = append(bundleProfileLangs, bundleProfileLang) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| func HandShelf(req *bundle.HandShelfRequest) (res *bundle.CommonResponse, err error) { | 	if selectValueAddServices != nil && len(selectValueAddServices) > 0 { | ||||||
| 	res = new(bundle.CommonResponse) | 		bundleProfile.SelectValueAddService = selectValueAddServices | ||||||
| 	if req.ShelfStatus != 1 && req.ShelfStatus != 2 { |  | ||||||
| 		res.Msg = "" |  | ||||||
| 		return res, errors.New("无效的上下架状态") |  | ||||||
| 	} | 	} | ||||||
| 	res, err = dao.HandShelf(req.Uuid, req.ShelfStatus) | 	bundleProfile.BundleProfileLang = bundleProfileLangs | ||||||
|  | 	res.Bundle = bundleProfile | ||||||
| 	return | 	return | ||||||
| } | } | ||||||
|  | func HandleShelf(req *bundle.HandShelfRequest) (res *bundle.CommonResponse, err error) { | ||||||
|  | 	res = new(bundle.CommonResponse) | ||||||
|  | 	if req.Uuid == "" { | ||||||
|  | 		return res, errors.New("uuid不能为空") | ||||||
|  | 	} | ||||||
|  | 	if req.ShelfStatus != 1 && req.ShelfStatus != 2 { | ||||||
|  | 		return res, errors.New("Invalid shelf status") | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	res, err = dao.HandShelf(req.Uuid, req.ShelfStatus) | ||||||
|  | 	if err != nil { | ||||||
|  | 		res.Msg = err.Error() | ||||||
|  | 		return res, err | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	res.Msg = "Operation success" | ||||||
|  | 	return res, nil | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| // 差异更新套餐与增值服务中间表
 | // 差异更新套餐与增值服务中间表
 | ||||||
| func diffUpdateBundleToValueAddService(tx *gorm.DB, bundleUuid string, selectService []*model.BundleToValueAddService) error { | func diffUpdateBundleToValueAddService(tx *gorm.DB, bundleUuid string, selectService []*model.BundleToValueAddService) error { | ||||||
| @ -362,3 +458,41 @@ func diffUpdateBundleToValueAddService(tx *gorm.DB, bundleUuid string, selectSer | |||||||
| 	} | 	} | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  | func saveBundleHistory(tx *gorm.DB, bundleUuid string, operator string, operatorId uint64) error { | ||||||
|  | 	// 保存历史记录
 | ||||||
|  | 	data, err := dao.GetBundleDetailByUuid(bundleUuid) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return errors.New("查询套餐详情失败: " + err.Error()) | ||||||
|  | 	} | ||||||
|  | 	bundleToValueAddService := data.BundleToValueAddService | ||||||
|  | 	data.BundleToValueAddService = nil | ||||||
|  | 	var valueUuid []string | ||||||
|  | 	if bundleToValueAddService != nil && len(bundleToValueAddService) > 0 { | ||||||
|  | 		for _, v := range bundleToValueAddService { | ||||||
|  | 			valueUuid = append(valueUuid, v.ValueUid) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	valueData, err := dao.BatchValueAddServiceDetailTx(tx, valueUuid) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return errors.New("查询增值服务详情失败: " + err.Error()) | ||||||
|  | 	} | ||||||
|  | 	j, err := json.Marshal(data) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return errors.New("套餐json转换失败: " + err.Error()) | ||||||
|  | 	} | ||||||
|  | 	vJ, err := json.Marshal(valueData) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return errors.New("增值服务json转换失败: " + err.Error()) | ||||||
|  | 	} | ||||||
|  | 	history := &model.BundleProfileHistory{ | ||||||
|  | 		Uuid:            bundleUuid, | ||||||
|  | 		BundleProfile:   datatypes.JSON(j), | ||||||
|  | 		ValueAddService: datatypes.JSON(vJ), | ||||||
|  | 		Operator:        operator, | ||||||
|  | 		OperatorId:      operatorId, | ||||||
|  | 	} | ||||||
|  | 	if err := tx.Create(history).Error; err != nil { | ||||||
|  | 		return errors.New("保存套餐历史记录失败: " + err.Error()) | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  | |||||||
| @ -1,26 +1,66 @@ | |||||||
| package logic | package logic | ||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
|  | 	"github.com/jinzhu/copier" | ||||||
| 	"micro-bundle/internal/dao" | 	"micro-bundle/internal/dao" | ||||||
| 	"micro-bundle/internal/model" | 	"micro-bundle/internal/model" | ||||||
| 	"micro-bundle/pb/bundle" | 	"micro-bundle/pb/bundle" | ||||||
| 	"micro-bundle/pkg/app" | 	"micro-bundle/pkg/app" | ||||||
| 	"micro-bundle/pkg/utils" | 	"micro-bundle/pkg/utils" | ||||||
| 
 |  | ||||||
| 	"github.com/jinzhu/copier" |  | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func CreateOrderRecord(req *bundle.OrderRecord) (res *bundle.CommonResponse, err error) { | func CreateOrderRecord(req *bundle.OrderCreateRecord) (res *bundle.CommonResponse, err error) { | ||||||
| 	res = new(bundle.CommonResponse) | 	res = new(bundle.CommonResponse) | ||||||
| 	orderRecord := new(model.BundleOrderRecords) | 	orderUUID := app.ModuleClients.SfNode.Generate().Base64() | ||||||
| 	_ = copier.CopyWithOption(&orderRecord, req, copier.Option{DeepCopy: true}) | 	orderNo := utils.GetOrderNo() | ||||||
| 	orderRecord.UUID = app.ModuleClients.SfNode.Generate().Base64() | 	var addRecords []model.BundleOrderValueAdd | ||||||
| 	orderRecord.OrderNo = utils.GetOrderNo() | 	for _, i := range req.AddRecords { | ||||||
| 	orderRecord.BundleUUID = req.BundleUuid | 		addRecords = append(addRecords, model.BundleOrderValueAdd{ | ||||||
| 	orderRecord.ValueAddBundleUUID = req.ValueAddBundleUuid | 			UUID:          app.ModuleClients.SfNode.Generate().Base64(), | ||||||
| 	orderRecord.FinancialConfirmation = model.ConfirmationNotConfirmed | 			OrderNo:       orderNo, | ||||||
| 	orderRecord.Language = req.Language | 			OrderUUID:     orderUUID, | ||||||
| 	res, err = dao.CreateOrderRecord(orderRecord, req) | 			CustomerID:    req.CustomerID, | ||||||
|  | 			CustomerNum:   req.CustomerNum, | ||||||
|  | 			CustomerName:  req.CustomerName, | ||||||
|  | 			ServiceType:   i.ServiceType, | ||||||
|  | 			CurrencyType:  i.CurrencyType, | ||||||
|  | 			Amount:        float64(i.Amount), | ||||||
|  | 			Num:           i.Num, | ||||||
|  | 			Unit:          i.Unit, | ||||||
|  | 			ValueAddUUID:  i.ValueUid, | ||||||
|  | 			Source:        int(i.Source), | ||||||
|  | 			PaymentStatus: int(i.PaymentStatus), | ||||||
|  | 			SignContract:  req.SignContract, | ||||||
|  | 			Signature:     req.Signature, | ||||||
|  | 			SignedTime:    req.SignedTime, | ||||||
|  | 			Snapshot:      req.Snapshot, | ||||||
|  | 		}) | ||||||
|  | 	} | ||||||
|  | 	orderRecord := &model.BundleOrderRecords{ | ||||||
|  | 		UUID:                  orderUUID, | ||||||
|  | 		OrderNo:               orderNo, | ||||||
|  | 		BundleUUID:            req.BundleUuid, | ||||||
|  | 		BundleName:            req.BundleName, | ||||||
|  | 		CustomerID:            req.CustomerID, | ||||||
|  | 		CustomerNum:           req.CustomerNum, | ||||||
|  | 		CustomerName:          req.CustomerName, | ||||||
|  | 		Amount:                req.Amount, | ||||||
|  | 		AmountType:            req.AmountType, | ||||||
|  | 		TotalAmount:           req.TotalAmount, | ||||||
|  | 		SignContract:          req.SignContract, | ||||||
|  | 		Signature:             req.Signature, | ||||||
|  | 		SignedTime:            req.SignedTime, | ||||||
|  | 		PayType:               int64(req.PayType), | ||||||
|  | 		PayTime:               req.PayTime, | ||||||
|  | 		Status:                req.Status, | ||||||
|  | 		ContractNo:            req.ContractNo, | ||||||
|  | 		BundleCommonUid:       req.BundleCommonUid, | ||||||
|  | 		FinancialConfirmation: model.ConfirmationNotConfirmed, | ||||||
|  | 		ExpirationTime:        req.ExpirationTime, | ||||||
|  | 		Language:              req.Language, | ||||||
|  | 		BundleOrderValueAdd:   addRecords, | ||||||
|  | 	} | ||||||
|  | 	res, err = dao.CreateOrderRecord(orderRecord) | ||||||
| 	return | 	return | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -70,3 +110,19 @@ func UpdateFinancialConfirmationStatus(req *bundle.FinancialConfirmationRequest) | |||||||
| 	res.Msg = "更新财务确认状态成功" | 	res.Msg = "更新财务确认状态成功" | ||||||
| 	return | 	return | ||||||
| } | } | ||||||
|  | func PackagePriceAndTime(req *bundle.OrderRecord) (res *bundle.PackagePriceAndTimeResponse, err error) { | ||||||
|  | 	res = new(bundle.PackagePriceAndTimeResponse) | ||||||
|  | 	res, err = dao.PackagePriceAndTime(req) | ||||||
|  | 	return | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | func CreateOrderAddRecord(req *bundle.OrderAddRecord) (res *bundle.CommonResponse, err error) { | ||||||
|  | 	res = new(bundle.CommonResponse) | ||||||
|  | 	res, err = dao.CreateOrderAddRecord(req) | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  | func OrderRecordsListV2(req *bundle.OrderRecordsRequestV2) (res *bundle.OrderRecordsResponseV2, err error) { | ||||||
|  | 	res = new(bundle.OrderRecordsResponseV2) | ||||||
|  | 	res, err = dao.OrderRecordsListV2(req) | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  | |||||||
| @ -1,6 +1,7 @@ | |||||||
| package logic | package logic | ||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
|  | 	"encoding/json" | ||||||
| 	"errors" | 	"errors" | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"micro-bundle/internal/dao" | 	"micro-bundle/internal/dao" | ||||||
| @ -12,6 +13,8 @@ import ( | |||||||
| 	"time" | 	"time" | ||||||
| 
 | 
 | ||||||
| 	"github.com/aliyun/alibaba-cloud-sdk-go/sdk/utils" | 	"github.com/aliyun/alibaba-cloud-sdk-go/sdk/utils" | ||||||
|  | 	"github.com/shopspring/decimal" | ||||||
|  | 	"gorm.io/datatypes" | ||||||
| 	"gorm.io/gorm" | 	"gorm.io/gorm" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| @ -147,17 +150,19 @@ func SaveValueAddService(in *bundle.ValueAddServiceLang) (res *bundle.SaveRespon | |||||||
| 		return res, errors.New("语言参数不能为空") | 		return res, errors.New("语言参数不能为空") | ||||||
| 	} | 	} | ||||||
| 	var options model.PriceOptions | 	var options model.PriceOptions | ||||||
|  | 	index := 1 | ||||||
| 	for _, option := range in.Options { | 	for _, option := range in.Options { | ||||||
| 		price, parseErr := strconv.ParseFloat(option.Price, 32) | 		price, parseErr := strconv.ParseFloat(option.Price, 32) | ||||||
| 		if parseErr != nil { | 		if parseErr != nil { | ||||||
| 			return res, parseErr | 			return res, parseErr | ||||||
| 		} | 		} | ||||||
| 		options = append(options, &model.PriceOption{ | 		options = append(options, &model.PriceOption{ | ||||||
| 			Id:     int32(option.Id), | 			Id:     int32(index), | ||||||
| 			Num:    option.Num, | 			Num:    option.Num, | ||||||
| 			Symbol: option.Symbol, | 			Symbol: option.Symbol, | ||||||
| 			Price:  float32(price), | 			Price:  float32(price), | ||||||
| 		}) | 		}) | ||||||
|  | 		index++ | ||||||
| 	} | 	} | ||||||
| 	ok, err := model.ValidateOptions(options) | 	ok, err := model.ValidateOptions(options) | ||||||
| 	if !ok { | 	if !ok { | ||||||
| @ -230,7 +235,18 @@ func SaveValueAddService(in *bundle.ValueAddServiceLang) (res *bundle.SaveRespon | |||||||
| 			} | 			} | ||||||
| 			langList := []string{msg.ZH_TW, msg.EN, msg.DE_DE, msg.JS_JP} | 			langList := []string{msg.ZH_TW, msg.EN, msg.DE_DE, msg.JS_JP} | ||||||
| 			for _, lang := range langList { | 			for _, lang := range langList { | ||||||
| 				otherLang := *valueAddServiceLang | 				otherLang := model.ValueAddServiceLang{ | ||||||
|  | 					UUID:          valueAddServiceLang.UUID, | ||||||
|  | 					ServiceName:   valueAddServiceLang.ServiceName, | ||||||
|  | 					ServiceType:   valueAddServiceLang.ServiceType, | ||||||
|  | 					PriceMode:     valueAddServiceLang.PriceMode, | ||||||
|  | 					OriginalPrice: valueAddServiceLang.OriginalPrice, | ||||||
|  | 					TotalPrice:    valueAddServiceLang.TotalPrice, | ||||||
|  | 					Unit:          valueAddServiceLang.Unit, | ||||||
|  | 					Language:      lang, | ||||||
|  | 					PriceType:     valueAddServiceLang.PriceType, | ||||||
|  | 					Options:       valueAddServiceLang.Options, | ||||||
|  | 				} | ||||||
| 				otherLang.Language = lang | 				otherLang.Language = lang | ||||||
| 				if err = dao.CreateValueAddServiceLang(tx, &otherLang); err != nil { | 				if err = dao.CreateValueAddServiceLang(tx, &otherLang); err != nil { | ||||||
| 					return res, errors.New(fmt.Sprintf("保存%s语言套餐失败: ", lang) + err.Error()) | 					return res, errors.New(fmt.Sprintf("保存%s语言套餐失败: ", lang) + err.Error()) | ||||||
| @ -243,6 +259,9 @@ func SaveValueAddService(in *bundle.ValueAddServiceLang) (res *bundle.SaveRespon | |||||||
| 		} | 		} | ||||||
| 	} else { | 	} else { | ||||||
| 		// 已存在,进行更新
 | 		// 已存在,进行更新
 | ||||||
|  | 		if err := saveValueAddServiceHistory(tx, in.Uuid); err != nil { | ||||||
|  | 			return res, err | ||||||
|  | 		} | ||||||
| 		//中文状态下,更新主表和语言表
 | 		//中文状态下,更新主表和语言表
 | ||||||
| 		if in.Language == msg.ZH_CN { | 		if in.Language == msg.ZH_CN { | ||||||
| 			updateService := map[string]interface{}{ | 			updateService := map[string]interface{}{ | ||||||
| @ -276,7 +295,7 @@ func SaveValueAddService(in *bundle.ValueAddServiceLang) (res *bundle.SaveRespon | |||||||
| 			"options":        options, | 			"options":        options, | ||||||
| 			"language":       in.Language, | 			"language":       in.Language, | ||||||
| 		} | 		} | ||||||
| 		if err = dao.UpdateValueAddServiceLang(tx, updateLangService); err != nil { | 		if err := dao.UpdateValueAddServiceLang(tx, updateLangService); err != nil { | ||||||
| 			return res, err | 			return res, err | ||||||
| 		} | 		} | ||||||
| 		res.Uuid = in.Uuid | 		res.Uuid = in.Uuid | ||||||
| @ -316,11 +335,23 @@ func ValueAddServiceList(req *bundle.ValueAddServiceListRequest) (res *bundle.Va | |||||||
| 			if serviceLang.Options != nil && len(serviceLang.Options) > 0 { | 			if serviceLang.Options != nil && len(serviceLang.Options) > 0 { | ||||||
| 				var options []*bundle.ValueAddPriceOptions | 				var options []*bundle.ValueAddPriceOptions | ||||||
| 				for _, option := range serviceLang.Options { | 				for _, option := range serviceLang.Options { | ||||||
|  | 					var saveAmount decimal.Decimal | ||||||
|  | 					if serviceLang.PriceMode == 1 { | ||||||
|  | 						original := decimal.NewFromFloat(float64(serviceLang.OriginalPrice)) | ||||||
|  | 						price := decimal.NewFromFloat(float64(option.Price)) | ||||||
|  | 						num := decimal.NewFromInt(int64(option.Num)) | ||||||
|  | 						saveAmount = original.Sub(price).Mul(num) | ||||||
|  | 					} else if serviceLang.PriceMode == 2 { | ||||||
|  | 						original := decimal.NewFromFloat(float64(serviceLang.OriginalPrice)) | ||||||
|  | 						price := decimal.NewFromFloat(float64(option.Price)) | ||||||
|  | 						saveAmount = original.Sub(price) | ||||||
|  | 					} | ||||||
| 					options = append(options, &bundle.ValueAddPriceOptions{ | 					options = append(options, &bundle.ValueAddPriceOptions{ | ||||||
| 						Id:         int64(option.Id), | 						Id:         int64(option.Id), | ||||||
| 						Num:        option.Num, | 						Num:        option.Num, | ||||||
| 						Symbol:     option.Symbol, | 						Symbol:     option.Symbol, | ||||||
| 						Price:      fmt.Sprintf("%.2f", option.Price), | 						Price:      fmt.Sprintf("%.2f", option.Price), | ||||||
|  | 						SaveAmount: saveAmount.StringFixed(2), | ||||||
| 					}) | 					}) | ||||||
| 				} | 				} | ||||||
| 				serviceLangInfo.Options = options | 				serviceLangInfo.Options = options | ||||||
| @ -338,19 +369,108 @@ func ValueAddServiceList(req *bundle.ValueAddServiceListRequest) (res *bundle.Va | |||||||
| // 增值套餐详情
 | // 增值套餐详情
 | ||||||
| func ValueAddServiceDetail(req *bundle.ValueAddServiceDetailRequest) (res *bundle.ValueAddServiceDetailResponse, err error) { | func ValueAddServiceDetail(req *bundle.ValueAddServiceDetailRequest) (res *bundle.ValueAddServiceDetailResponse, err error) { | ||||||
| 	res = &bundle.ValueAddServiceDetailResponse{} | 	res = &bundle.ValueAddServiceDetailResponse{} | ||||||
|  | 	valueAddService := &bundle.ValueAddService{} | ||||||
|  | 	serviceLangs := []*bundle.ValueAddServiceLang{} | ||||||
| 	if req.Uuid == "" { | 	if req.Uuid == "" { | ||||||
| 		res.Msg = msg.ErrorValueAddServiceInfo | 		res.Msg = msg.ErrorValueAddServiceInfo | ||||||
| 		return res, errors.New("uuid不能为空") | 		return res, errors.New("uuid不能为空") | ||||||
| 	} | 	} | ||||||
| 	if req.Language == "" { | 	// if req.Language == "" {
 | ||||||
|  | 	// 	res.Msg = msg.ErrorValueAddServiceInfo
 | ||||||
|  | 	// 	return res, errors.New("语言选项不能为空")
 | ||||||
|  | 	// }
 | ||||||
|  | 	detail, err := dao.ValueAddServiceDetail(req.Uuid) | ||||||
|  | 	if err != nil { | ||||||
| 		res.Msg = msg.ErrorValueAddServiceInfo | 		res.Msg = msg.ErrorValueAddServiceInfo | ||||||
|  | 		return res, err | ||||||
|  | 	} | ||||||
|  | 	if detail != nil && len(detail.ValueAddServiceLang) > 0 { | ||||||
|  | 		valueAddService.Uuid = detail.UUID | ||||||
|  | 		valueAddService.ServiceName = detail.ServiceName | ||||||
|  | 		valueAddService.ServiceType = detail.ServiceType | ||||||
|  | 		for _, serviceLang := range detail.ValueAddServiceLang { | ||||||
|  | 			langOptions := []*bundle.ValueAddPriceOptions{} | ||||||
|  | 			if serviceLang.Options != nil && len(serviceLang.Options) > 0 { | ||||||
|  | 				for _, opt := range serviceLang.Options { | ||||||
|  | 					var saveAmount decimal.Decimal | ||||||
|  | 					if serviceLang.PriceMode == 1 { | ||||||
|  | 						original := decimal.NewFromFloat(float64(serviceLang.OriginalPrice)) | ||||||
|  | 						price := decimal.NewFromFloat(float64(opt.Price)) | ||||||
|  | 						num := decimal.NewFromInt(int64(opt.Num)) | ||||||
|  | 						saveAmount = original.Sub(price).Mul(num) | ||||||
|  | 					} else if serviceLang.PriceMode == 2 { | ||||||
|  | 						original := decimal.NewFromFloat(float64(serviceLang.OriginalPrice)) | ||||||
|  | 						price := decimal.NewFromFloat(float64(opt.Price)) | ||||||
|  | 						saveAmount = original.Sub(price) | ||||||
|  | 					} | ||||||
|  | 					langOptions = append(langOptions, &bundle.ValueAddPriceOptions{ | ||||||
|  | 						Id:         int64(opt.Id), | ||||||
|  | 						Num:        opt.Num, | ||||||
|  | 						Symbol:     opt.Symbol, | ||||||
|  | 						Price:      fmt.Sprintf("%.2f", opt.Price), | ||||||
|  | 						SaveAmount: saveAmount.StringFixed(2), | ||||||
|  | 					}) | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 			serviceLangInfo := &bundle.ValueAddServiceLang{ | ||||||
|  | 				Uuid:          serviceLang.UUID, | ||||||
|  | 				ServiceName:   serviceLang.ServiceName, | ||||||
|  | 				ServiceType:   serviceLang.ServiceType, | ||||||
|  | 				Language:      serviceLang.Language, | ||||||
|  | 				PriceMode:     serviceLang.PriceMode, | ||||||
|  | 				OriginalPrice: fmt.Sprintf("%.2f", serviceLang.OriginalPrice), | ||||||
|  | 				Unit:          serviceLang.Unit, | ||||||
|  | 				PriceType:     int64(serviceLang.PriceType), | ||||||
|  | 				Options:       langOptions, | ||||||
|  | 				CreatedAt:     time.Unix(serviceLang.CreatedAt, 0).Format("2006-01-02 15:04:05"), | ||||||
|  | 				UpdatedAt:     time.Unix(serviceLang.UpdatedAt, 0).Format("2006-01-02 15:04:05"), | ||||||
|  | 			} | ||||||
|  | 			serviceLangs = append(serviceLangs, serviceLangInfo) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	valueAddService.ServiceLang = serviceLangs | ||||||
|  | 
 | ||||||
|  | 	res.ValueAddService = valueAddService | ||||||
|  | 	res.Msg = msg.SuccessValueAddServiceInfo | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func saveValueAddServiceHistory(tx *gorm.DB, uuid string) (err error) { | ||||||
|  | 	// 保存历史记录
 | ||||||
|  | 	data, err := dao.GetValueAddServiceDetailByUuid(tx, uuid) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return errors.New("查询增值服务详情失败: " + err.Error()) | ||||||
|  | 	} | ||||||
|  | 	j, err := json.Marshal(data) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return errors.New("json转换失败: " + err.Error()) | ||||||
|  | 	} | ||||||
|  | 	history := &model.ValueAddServiceHistory{ | ||||||
|  | 		Uuid:            uuid, | ||||||
|  | 		ValueAddService: datatypes.JSON(j), | ||||||
|  | 		//Operator:      operator,
 | ||||||
|  | 		//OperatorId:    operatorId,
 | ||||||
|  | 	} | ||||||
|  | 	if err := tx.Create(history).Error; err != nil { | ||||||
|  | 		return errors.New("保存增值服务历史记录失败: " + err.Error()) | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  | func ValueAddServiceDetailByUuidAndLanguage(req *bundle.ValueAddServiceDetailRequest) (res *bundle.ValueAddServiceLang, err error) { | ||||||
|  | 	res = &bundle.ValueAddServiceLang{} | ||||||
|  | 	if req.Uuid == "" { | ||||||
|  | 		return res, errors.New("uuid不能为空") | ||||||
|  | 	} | ||||||
|  | 	if req.Language == "" { | ||||||
| 		return res, errors.New("语言选项不能为空") | 		return res, errors.New("语言选项不能为空") | ||||||
| 	} | 	} | ||||||
| 	detail, err := dao.ValueAddServiceDetailByUuidAndLanguage(req.Uuid, req.Language) | 	detail, err := dao.ValueAddServiceDetailByUuidAndLanguage(req.Uuid, req.Language) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		res.Msg = msg.ErrorValueAddServiceInfo |  | ||||||
| 		return res, err | 		return res, err | ||||||
| 	} | 	} | ||||||
|  | 	if detail == nil { | ||||||
|  | 		return res, errors.New("增值服务不存在") | ||||||
|  | 	} | ||||||
| 	langOptions := []*bundle.ValueAddPriceOptions{} | 	langOptions := []*bundle.ValueAddPriceOptions{} | ||||||
| 	if detail.Options != nil && len(detail.Options) > 0 { | 	if detail.Options != nil && len(detail.Options) > 0 { | ||||||
| 		for _, opt := range detail.Options { | 		for _, opt := range detail.Options { | ||||||
| @ -362,8 +482,7 @@ func ValueAddServiceDetail(req *bundle.ValueAddServiceDetailRequest) (res *bundl | |||||||
| 			}) | 			}) | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 	res = &bundle.ValueAddServiceLang{ | ||||||
| 	serviceLang := &bundle.ValueAddServiceLang{ |  | ||||||
| 		Uuid:          detail.UUID, | 		Uuid:          detail.UUID, | ||||||
| 		ServiceName:   detail.ServiceName, | 		ServiceName:   detail.ServiceName, | ||||||
| 		ServiceType:   detail.ServiceType, | 		ServiceType:   detail.ServiceType, | ||||||
| @ -373,11 +492,39 @@ func ValueAddServiceDetail(req *bundle.ValueAddServiceDetailRequest) (res *bundl | |||||||
| 		Unit:          detail.Unit, | 		Unit:          detail.Unit, | ||||||
| 		PriceType:     int64(detail.PriceType), | 		PriceType:     int64(detail.PriceType), | ||||||
| 		Options:       langOptions, | 		Options:       langOptions, | ||||||
| 		CreatedAt:     time.Unix(detail.CreatedAt, 0).Format("2006-01-02 15:04:05"), |  | ||||||
| 		UpdatedAt:     time.Unix(detail.UpdatedAt, 0).Format("2006-01-02 15:04:05"), |  | ||||||
| 	} | 	} | ||||||
| 
 | 	return | ||||||
| 	res.ValueAddServiceLang = serviceLang | } | ||||||
| 	res.Msg = msg.SuccessValueAddServiceInfo | func CalculatePrice(req *bundle.CalculatePriceRequest) (res *bundle.CalculatePriceResponse, err error) { | ||||||
|  | 	res = &bundle.CalculatePriceResponse{} | ||||||
|  | 	if req.Uuid == "" { | ||||||
|  | 		return res, errors.New("uuid不能为空") | ||||||
|  | 	} | ||||||
|  | 	if req.Language == "" { | ||||||
|  | 		return res, errors.New("语言选项不能为空") | ||||||
|  | 	} | ||||||
|  | 	detail, err := dao.ValueAddServiceDetailByUuidAndLanguage(req.Uuid, req.Language) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return res, err | ||||||
|  | 	} | ||||||
|  | 	if detail == nil { | ||||||
|  | 		return res, errors.New("增值服务不存在") | ||||||
|  | 	} | ||||||
|  | 	// langOptions := []*bundle.ValueAddPriceOptions{}
 | ||||||
|  | 	// if detail.Options != nil && len(detail.Options) > 0 {
 | ||||||
|  | 	// 	for _, opt := range detail.Options {
 | ||||||
|  | 	// 		langOptions = append(langOptions, &bundle.ValueAddPriceOptions{
 | ||||||
|  | 	// 			Id:     int64(opt.Id),
 | ||||||
|  | 	// 			Num:    opt.Num,
 | ||||||
|  | 	// 			Symbol: opt.Symbol,
 | ||||||
|  | 	// 			Price:  fmt.Sprintf("%.2f", opt.Price),
 | ||||||
|  | 	// 		})
 | ||||||
|  | 	// 	}
 | ||||||
|  | 	// }
 | ||||||
|  | 	price, err := detail.Options.CalculatePrice(detail.PriceMode, req.Num) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return res, err | ||||||
|  | 	} | ||||||
|  | 	res.Price = price | ||||||
| 	return | 	return | ||||||
| } | } | ||||||
|  | |||||||
| @ -3,6 +3,7 @@ package model | |||||||
| import ( | import ( | ||||||
| 	"time" | 	"time" | ||||||
| 
 | 
 | ||||||
|  | 	"gorm.io/datatypes" | ||||||
| 	"gorm.io/gorm" | 	"gorm.io/gorm" | ||||||
| 	"gorm.io/plugin/soft_delete" | 	"gorm.io/plugin/soft_delete" | ||||||
| ) | ) | ||||||
| @ -22,6 +23,7 @@ type BundleProfile struct { | |||||||
| 
 | 
 | ||||||
| 	Sort                    int64                     `json:"sort" gorm:"column:sort;type:int;comment:套餐排序"` //数字越小越靠前,同大小后创建优先
 | 	Sort                    int64                     `json:"sort" gorm:"column:sort;type:int;comment:套餐排序"` //数字越小越靠前,同大小后创建优先
 | ||||||
| 	ShelfStatus             int64                     `json:"shelfStatus" gorm:"column:shelf_status;type:int;default:2;comment:上架状态  1:上架 2:下架"` | 	ShelfStatus             int64                     `json:"shelfStatus" gorm:"column:shelf_status;type:int;default:2;comment:上架状态  1:上架 2:下架"` | ||||||
|  | 	ImgOption               int8                      `json:"imgOption" gorm:"column:img_option;type:int;default:1;comment:图片选择 1:背景图1 2 3"` | ||||||
| 	BgImg1                  string                    `json:"bgImg1" gorm:"column:bg_img1;type:varchar(1024);comment:背景图-首页"` | 	BgImg1                  string                    `json:"bgImg1" gorm:"column:bg_img1;type:varchar(1024);comment:背景图-首页"` | ||||||
| 	BgImg2                  string                    `json:"bgImg2" gorm:"column:bg_img2;type:varchar(1024);comment:背景图-我的"` | 	BgImg2                  string                    `json:"bgImg2" gorm:"column:bg_img2;type:varchar(1024);comment:背景图-我的"` | ||||||
| 	BundleToValueAddService []BundleToValueAddService `gorm:"foreignKey:BundleUuid;references:UUID" json:"bundleToValueAddService"` | 	BundleToValueAddService []BundleToValueAddService `gorm:"foreignKey:BundleUuid;references:UUID" json:"bundleToValueAddService"` | ||||||
| @ -55,7 +57,10 @@ type BundleToValueAddService struct { | |||||||
| type BundleProfileHistory struct { | type BundleProfileHistory struct { | ||||||
| 	Id              int32          `gorm:"column:id;type:int(11);primary_key;AUTO_INCREMENT" json:"id"` | 	Id              int32          `gorm:"column:id;type:int(11);primary_key;AUTO_INCREMENT" json:"id"` | ||||||
| 	Uuid            string         `json:"uuid" gorm:"column:uuid;type:varchar(1024);comment:UUID"` | 	Uuid            string         `json:"uuid" gorm:"column:uuid;type:varchar(1024);comment:UUID"` | ||||||
| 	BundleProfile BundleProfile `gorm:"foreignKey:Uuid;references:UUID" json:"bundleProfile"` | 	BundleProfile   datatypes.JSON `json:"bundleProfile" gorm:"column:bundle_profile;type:json;comment:套餐信息"` | ||||||
|  | 	ValueAddService datatypes.JSON `json:"valueAddService" gorm:"column:value_add_service;type:json;comment:增值服务信息"` | ||||||
|  | 	Operator        string         `json:"operator" gorm:"column:operator;type:varchar(1024);comment:操作人"` | ||||||
|  | 	OperatorId      uint64         `json:"operatorId" gorm:"column:operator_id;type:int;comment:操作人ID"` | ||||||
| 	CreatedAt       int64          `gorm:"column:created_at;autoCreateTime"` | 	CreatedAt       int64          `gorm:"column:created_at;autoCreateTime"` | ||||||
| 	UpdatedAt       int64          `gorm:"column:updated_at;autoCreateTime"` | 	UpdatedAt       int64          `gorm:"column:updated_at;autoCreateTime"` | ||||||
| 	DeletedAt       soft_delete.DeletedAt | 	DeletedAt       soft_delete.DeletedAt | ||||||
| @ -83,6 +88,7 @@ type BundleExtensionRecords struct { | |||||||
| 	ImagesAdditional            uint   `gorm:"column:images_additional;type:int(11) unsigned;comment:图文额外增加" json:"images_additional"` | 	ImagesAdditional            uint   `gorm:"column:images_additional;type:int(11) unsigned;comment:图文额外增加" json:"images_additional"` | ||||||
| 	DataAdditional              uint   `gorm:"column:data_additional;type:int(11) unsigned;comment:数据额外增加" json:"data_additional"` | 	DataAdditional              uint   `gorm:"column:data_additional;type:int(11) unsigned;comment:数据额外增加" json:"data_additional"` | ||||||
| 	AvailableDurationAdditional uint   `gorm:"column:available_duration_additional;type:int(11) unsigned;comment:可用时长增加" json:"available_duration_additional"` | 	AvailableDurationAdditional uint   `gorm:"column:available_duration_additional;type:int(11) unsigned;comment:可用时长增加" json:"available_duration_additional"` | ||||||
|  | 	TimeUnit                    uint   `gorm:"column:time_unit;type:int(11) unsigned;comment:时间单位" json:"timeUnit"` | ||||||
| 	Type                        int    `gorm:"column:type;type:tinyint(4);comment:类型 0:手动操作" json:"type"` | 	Type                        int    `gorm:"column:type;type:tinyint(4);comment:类型 0:手动操作" json:"type"` | ||||||
| 	Remark                      string `gorm:"column:remark;type:text;comment:备注" json:"remark"` | 	Remark                      string `gorm:"column:remark;type:text;comment:备注" json:"remark"` | ||||||
| 	OperatorId                  int    `gorm:"column:operator_id;type:int(11);comment:操作人id" json:"operator_id"` | 	OperatorId                  int    `gorm:"column:operator_id;type:int(11);comment:操作人id" json:"operator_id"` | ||||||
|  | |||||||
| @ -1,6 +1,9 @@ | |||||||
| package model | package model | ||||||
| 
 | 
 | ||||||
| import "gorm.io/gorm" | import ( | ||||||
|  | 	"encoding/json" | ||||||
|  | 	"gorm.io/gorm" | ||||||
|  | ) | ||||||
| 
 | 
 | ||||||
| // BundleOrderRecords struct
 | // BundleOrderRecords struct
 | ||||||
| type BundleOrderRecords struct { | type BundleOrderRecords struct { | ||||||
| @ -34,12 +37,14 @@ type BundleOrderRecords struct { | |||||||
| 	AddBundleCommonUid    string                `json:"addBundleCommonUid" gorm:"column:add_bundle_common_uid;type:text;comment:附加套餐公共ID"` | 	AddBundleCommonUid    string                `json:"addBundleCommonUid" gorm:"column:add_bundle_common_uid;type:text;comment:附加套餐公共ID"` | ||||||
| 	FinancialConfirmation int32                 `json:"financialConfirmation" gorm:"column:financial_confirmation;type:int;comment:财务确认 1:未确认 2:已确认"` | 	FinancialConfirmation int32                 `json:"financialConfirmation" gorm:"column:financial_confirmation;type:int;comment:财务确认 1:未确认 2:已确认"` | ||||||
| 	ExpirationTime        string                `json:"expirationTime" gorm:"column:expiration_time;comment:套餐过期时间"` | 	ExpirationTime        string                `json:"expirationTime" gorm:"column:expiration_time;comment:套餐过期时间"` | ||||||
| 	BundleCommonJson      string  `json:"bundle_common_json" gorm:"column:bundle_common_json;type:json;serializer:json;comment:套餐信息"` | 	BundleCommonJson      json.RawMessage       `json:"bundle_common_json" gorm:"column:bundle_common_json;type:json;serializer:json;comment:套餐信息"` | ||||||
| 	Language              string                `gorm:"column:language;comment:语言" json:"language"` | 	Language              string                `gorm:"column:language;comment:语言" json:"language"` | ||||||
|  | 	BundleOrderValueAdd   []BundleOrderValueAdd `gorm:"foreignKey:OrderUUID;references:UUID" json:"bundleOrderValueAdd"` | ||||||
| } | } | ||||||
| type BundleOrderValueAdd struct { | type BundleOrderValueAdd struct { | ||||||
| 	gorm.Model | 	gorm.Model | ||||||
| 	UUID          string  `json:"uuid" gorm:"column:uuid;type:varchar(1024);comment:UUID"` | 	UUID          string  `json:"uuid" gorm:"column:uuid;type:varchar(1024);comment:UUID"` | ||||||
|  | 	OrderNo       string  `json:"orderNo" gorm:"column:order_no;type:varchar(1024);comment:交易编号"` | ||||||
| 	OrderUUID     string  `json:"orderUUID" gorm:"column:order_uuid;type:varchar(1024);comment:套餐UUID"` | 	OrderUUID     string  `json:"orderUUID" gorm:"column:order_uuid;type:varchar(1024);comment:套餐UUID"` | ||||||
| 	CustomerID    string  `json:"customerID" gorm:"column:customer_id;type:varchar(1024);comment:客户ID"` | 	CustomerID    string  `json:"customerID" gorm:"column:customer_id;type:varchar(1024);comment:客户ID"` | ||||||
| 	CustomerNum   string  `json:"customerNum" gorm:"column:customer_num;type:varchar(1024);comment:客户编号"` | 	CustomerNum   string  `json:"customerNum" gorm:"column:customer_num;type:varchar(1024);comment:客户编号"` | ||||||
| @ -48,12 +53,16 @@ type BundleOrderValueAdd struct { | |||||||
| 	CurrencyType  int64   `json:"currencyType" gorm:"column:currency_type;type:int;comment:货币类型"` | 	CurrencyType  int64   `json:"currencyType" gorm:"column:currency_type;type:int;comment:货币类型"` | ||||||
| 	Amount        float64 `json:"amount" gorm:"column:amount;type:decimal(12,2);comment:金额"` | 	Amount        float64 `json:"amount" gorm:"column:amount;type:decimal(12,2);comment:金额"` | ||||||
| 	Num           int32   `json:"num" gorm:"column:num;type:int;comment:数量"` | 	Num           int32   `json:"num" gorm:"column:num;type:int;comment:数量"` | ||||||
| 	Unit          int32   `json:"unit" gorm:"column:unit;type:varchar(1024);comment:单位 1个 2条 3天 4月 5年"` | 	Unit          string  `json:"unit" gorm:"column:unit;type:varchar(1024);comment:单位 1个 2条 3天 4月 5年"` | ||||||
| 	ValueAddUUID  string  `json:"valueAddUUID" gorm:"column:value_add_uuid;type:varchar(1024);comment:增值服务UUID"` | 	ValueAddUUID  string  `json:"valueAddUUID" gorm:"column:value_add_uuid;type:varchar(1024);comment:增值服务UUID"` | ||||||
| 	Source        int     `json:"source" gorm:"column:source;comment:增加方式 1套餐 2单独购买 3拓展"` | 	Source        int     `json:"source" gorm:"column:source;comment:增加方式 1套餐 2单独购买 3拓展"` | ||||||
| 	Remark        string  `json:"remark" gorm:"column:remark;comment:备注"` | 	Remark        string  `json:"remark" gorm:"column:remark;comment:备注"` | ||||||
| 	PaymentStatus int     `json:"paymentStatus" gorm:"column:payment_status;comment:支付状态 1未支付 2已支付"` | 	PaymentStatus int     `json:"paymentStatus" gorm:"column:payment_status;comment:支付状态 1未支付 2已支付"` | ||||||
| 	PaymentTime   string  `gorm:"column:payment_time;comment:支付时间" json:"paymentTime"` | 	PaymentTime   string  `gorm:"column:payment_time;comment:支付时间" json:"paymentTime"` | ||||||
|  | 	SignContract  string  `json:"signContract" gorm:"column:sign_contract;type:varchar(1024);comment:签约合同"` | ||||||
|  | 	Signature     string  `json:"signature" gorm:"column:signature;type:text;comment:签字"` | ||||||
|  | 	SignedTime    string  `json:"signedTime" gorm:"column:signed_time;type:varchar(1024);comment:签约时间(北京时间)"` | ||||||
|  | 	Snapshot      string  `gorm:"column:snapshot;comment:快照" json:"snapshot"` //订单快照
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // 财务确认状态
 | // 财务确认状态
 | ||||||
|  | |||||||
| @ -57,3 +57,31 @@ type CastWorkVideo struct { | |||||||
| func (*CastWorkVideo) TableName() string { | func (*CastWorkVideo) TableName() string { | ||||||
| 	return "cast_work_video" | 	return "cast_work_video" | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | // CastWork undefined
 | ||||||
|  | type CastWork struct { | ||||||
|  | 	Uuid             string `json:"uuid" gorm:"uuid"` | ||||||
|  | 	ArtistUuid       string `json:"artist_uuid" gorm:"artist_uuid"`               // 艺人ID
 | ||||||
|  | 	MediaAccUserIds  string `json:"media_acc_user_ids" gorm:"media_acc_user_ids"` // 自媒体账号user_ids集合
 | ||||||
|  | 	MediaNames       string `json:"media_names" gorm:"media_names"`               // 自媒体账号名称集合
 | ||||||
|  | 	ArtistName       string `json:"artist_name" gorm:"artist_name"`               // 艺人名称
 | ||||||
|  | 	ArtistPhone      string `json:"artist_phone" gorm:"artist_phone"`             // 艺人手机号
 | ||||||
|  | 	WorkCategory     int8   `json:"work_category" gorm:"work_category"`           //  1 图文 2 视频
 | ||||||
|  | 	SubmitTime       string `json:"submit_time" gorm:"submit_time"`               // 提交时间
 | ||||||
|  | 	StatusUpdateTime string `json:"status_update_time" gorm:"status_update_time"` // 状态更新时间
 | ||||||
|  | 	Status           int8   `json:"status" gorm:"status"`                         //  1 待提交 2 审核中 3 审核失败 4 待艺人确认 5 艺人驳回 6 发布成功 7 发布失败
 | ||||||
|  | 	Title            string `json:"title" gorm:"title"` | ||||||
|  | 	Content          string `json:"content" gorm:"content"` | ||||||
|  | 	PublishConfig    string `json:"publish_config" gorm:"publish_config"` // 发布配置
 | ||||||
|  | 	CreatedAt        int64  `json:"created_at" gorm:"created_at"` | ||||||
|  | 	UpdatedAt        int64  `json:"updated_at" gorm:"updated_at"` | ||||||
|  | 	DeletedAt        int64  `json:"deleted_at" gorm:"deleted_at"` | ||||||
|  | 	Cost             int8   `json:"cost" gorm:"cost"`                     //  1 消耗 2 未消耗
 | ||||||
|  | 	ConfirmRemark    string `json:"confirm_remark" gorm:"confirm_remark"` // 艺人确认备注
 | ||||||
|  | 	ApprovalId       string `json:"approval_id" gorm:"approval_id"`       // 审批ID
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // TableName 表名称
 | ||||||
|  | func (*CastWork) TableName() string { | ||||||
|  | 	return "cast_work" | ||||||
|  | } | ||||||
|  | |||||||
| @ -4,7 +4,9 @@ import ( | |||||||
| 	"database/sql/driver" | 	"database/sql/driver" | ||||||
| 	"encoding/json" | 	"encoding/json" | ||||||
| 	"errors" | 	"errors" | ||||||
|  | 	"fmt" | ||||||
| 
 | 
 | ||||||
|  | 	"gorm.io/datatypes" | ||||||
| 	"gorm.io/plugin/soft_delete" | 	"gorm.io/plugin/soft_delete" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| @ -58,6 +60,18 @@ type ValueAddServiceLang struct { | |||||||
| 	UpdatedAt     int64        `gorm:"column:updated_at;autoCreateTime"` | 	UpdatedAt     int64        `gorm:"column:updated_at;autoCreateTime"` | ||||||
| 	DeletedAt     soft_delete.DeletedAt | 	DeletedAt     soft_delete.DeletedAt | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | type ValueAddServiceHistory struct { | ||||||
|  | 	Id              int32          `gorm:"column:id;type:int(11);primary_key;AUTO_INCREMENT" json:"id"` | ||||||
|  | 	Uuid            string         `json:"uuid" gorm:"column:uuid;type:varchar(1024);comment:UUID"` | ||||||
|  | 	ValueAddService datatypes.JSON `json:"valueAddService" gorm:"column:value_add_service;type:json;comment:增值服务"` | ||||||
|  | 	Operator        string         `json:"operator" gorm:"column:operator;type:varchar(1024);comment:操作人"` | ||||||
|  | 	OperatorId      uint64         `json:"operatorId" gorm:"column:operator_id;type:int;comment:操作人ID"` | ||||||
|  | 	CreatedAt       int64          `gorm:"column:created_at;autoCreateTime"` | ||||||
|  | 	UpdatedAt       int64          `gorm:"column:updated_at;autoCreateTime"` | ||||||
|  | 	DeletedAt       soft_delete.DeletedAt | ||||||
|  | } | ||||||
|  | 
 | ||||||
| type PriceOptions []*PriceOption | type PriceOptions []*PriceOption | ||||||
| type PriceOption struct { | type PriceOption struct { | ||||||
| 	Id     int32   `json:"id"` | 	Id     int32   `json:"id"` | ||||||
| @ -130,3 +144,38 @@ func (m *ValueAddService) TableName() string { | |||||||
| func (m *ValueAddServiceLang) TableName() string { | func (m *ValueAddServiceLang) TableName() string { | ||||||
| 	return "value_add_service_lang" | 	return "value_add_service_lang" | ||||||
| } | } | ||||||
|  | func (m *ValueAddServiceHistory) TableName() string { | ||||||
|  | 	return "value_add_service_history" | ||||||
|  | } | ||||||
|  | func (options PriceOptions) CalculatePrice(priceMode, target int32) (float32, error) { | ||||||
|  | 	for _, opt := range options { | ||||||
|  | 		match := false | ||||||
|  | 		switch opt.Symbol { | ||||||
|  | 		case "=": | ||||||
|  | 			match = target == opt.Num | ||||||
|  | 		case ">": | ||||||
|  | 			match = target > opt.Num | ||||||
|  | 		case ">=": | ||||||
|  | 			match = target >= opt.Num | ||||||
|  | 		case "<": | ||||||
|  | 			match = target < opt.Num | ||||||
|  | 		case "<=": | ||||||
|  | 			match = target <= opt.Num | ||||||
|  | 		default: | ||||||
|  | 			return 0, fmt.Errorf("不支持的符号: %s", opt.Symbol) | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		if match { | ||||||
|  | 			switch priceMode { | ||||||
|  | 			case 1: | ||||||
|  | 				return float32(target) * opt.Price, nil | ||||||
|  | 			case 2: | ||||||
|  | 				return opt.Price, nil | ||||||
|  | 			default: | ||||||
|  | 				return 0, fmt.Errorf("未知价格模式: %d", priceMode) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	return 0, fmt.Errorf("未找到匹配规则") | ||||||
|  | } | ||||||
|  | |||||||
							
								
								
									
										195
									
								
								pb/bundle.proto
									
									
									
									
									
								
							
							
						
						
									
										195
									
								
								pb/bundle.proto
									
									
									
									
									
								
							| @ -22,12 +22,15 @@ service Bundle { | |||||||
|   rpc BundleList(BundleListRequest) returns (BundleListResponse) {} |   rpc BundleList(BundleListRequest) returns (BundleListResponse) {} | ||||||
|   rpc BundleDetail(BundleDetailRequest) returns (BundleDetailResponse) {} |   rpc BundleDetail(BundleDetailRequest) returns (BundleDetailResponse) {} | ||||||
| 
 | 
 | ||||||
|   rpc  CreateOrderRecord(OrderRecord) returns (CommonResponse) {} |   rpc  CreateOrderRecord(OrderCreateRecord) returns (CommonResponse) {} | ||||||
|   rpc  UpdateOrderRecord(OrderRecord) returns (CommonResponse) {} |   rpc  UpdateOrderRecord(OrderRecord) returns (CommonResponse) {} | ||||||
|   rpc  UpdateOrderRecordByOrderNo(OrderRecord) returns (CommonResponse) {} |   rpc  UpdateOrderRecordByOrderNo(OrderRecord) returns (CommonResponse) {} | ||||||
|   rpc  OrderRecordsList(OrderRecordsRequest) returns (OrderRecordsResponse) {} |   rpc  OrderRecordsList(OrderRecordsRequest) returns (OrderRecordsResponse) {} | ||||||
|   rpc  OrderRecordsDetail(OrderRecordsDetailRequest) returns (OrderRecordsDetailResponse) {} |   rpc  OrderRecordsDetail(OrderRecordsDetailRequest) returns (OrderRecordsDetailResponse) {} | ||||||
|   rpc  UpdateFinancialConfirmationStatus(FinancialConfirmationRequest) returns (CommonResponse) {} |   rpc  UpdateFinancialConfirmationStatus(FinancialConfirmationRequest) returns (CommonResponse) {} | ||||||
|  |   rpc  CreateOrderAddRecord(OrderAddRecord) returns (CommonResponse) {} | ||||||
|  |   rpc  PackagePriceAndTime(OrderRecord) returns (PackagePriceAndTimeResponse) {}//计算套餐价格和有效时间 | ||||||
|  |   rpc  OrderRecordsListV2(OrderRecordsRequestV2) returns (OrderRecordsResponseV2) {} | ||||||
| 
 | 
 | ||||||
|   //增值套餐  |   //增值套餐  | ||||||
|   rpc CreateValueAddBundle(CreateValueAddBundleRequest) returns (CreateValueAddBundleResponse) {} |   rpc CreateValueAddBundle(CreateValueAddBundleRequest) returns (CreateValueAddBundleResponse) {} | ||||||
| @ -38,6 +41,10 @@ service Bundle { | |||||||
|   rpc SaveValueAddService(ValueAddServiceLang) returns (SaveResponse) {} |   rpc SaveValueAddService(ValueAddServiceLang) returns (SaveResponse) {} | ||||||
|   rpc ValueAddServiceList(ValueAddServiceListRequest) returns (ValueAddServiceListResponse) {} |   rpc ValueAddServiceList(ValueAddServiceListRequest) returns (ValueAddServiceListResponse) {} | ||||||
|   rpc ValueAddServiceDetail(ValueAddServiceDetailRequest) returns (ValueAddServiceDetailResponse) {}  |   rpc ValueAddServiceDetail(ValueAddServiceDetailRequest) returns (ValueAddServiceDetailResponse) {}  | ||||||
|  |   rpc ValueAddServiceLangByUuidAndLanguage(ValueAddServiceDetailRequest)returns (ValueAddServiceLang) {} | ||||||
|  |   rpc CalculatePrice(CalculatePriceRequest) returns (CalculatePriceResponse) {} | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
|   // 余量管理 |   // 余量管理 | ||||||
|   rpc BundleExtend(BundleExtendRequest) returns (BundleExtendResponse) {} // 套餐扩展 |   rpc BundleExtend(BundleExtendRequest) returns (BundleExtendResponse) {} // 套餐扩展 | ||||||
| @ -50,6 +57,91 @@ service Bundle { | |||||||
|   rpc GetUsedRecordList(GetUsedRecordListReq) returns (GetUsedRecordListResp) {} // 获取套餐使用记录列表 |   rpc GetUsedRecordList(GetUsedRecordListReq) returns (GetUsedRecordListResp) {} // 获取套餐使用记录列表 | ||||||
|   rpc GetImageWorkDetail(GetImageWorkDetailReq) returns (GetImageWorkDetailResp) {} // 获取图文作品详情 |   rpc GetImageWorkDetail(GetImageWorkDetailReq) returns (GetImageWorkDetailResp) {} // 获取图文作品详情 | ||||||
|   rpc GetVedioWorkDetail(GetVedioWorkDetailReq) returns (GetVedioeWorkDetailResp) {} // 获取视频作品详情 |   rpc GetVedioWorkDetail(GetVedioWorkDetailReq) returns (GetVedioeWorkDetailResp) {} // 获取视频作品详情 | ||||||
|  | 
 | ||||||
|  |   rpc ToBeComfirmedWorks(ToBeComfirmedWorksReq) returns (ToBeComfirmedWorksResp) {} // 待确认作品列表 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | message OrderCreateRecord{ | ||||||
|  |   string bundleUuid = 1 [json_name = "bundleUuid"]; | ||||||
|  |   string language = 2 [json_name = "language"]; | ||||||
|  |   string expirationTime = 3 [json_name = "expirationTime"]; | ||||||
|  |   string bundleName = 4 [json_name = "bundleName"]; | ||||||
|  |   string customerID = 5 [json_name = "customerID"]; | ||||||
|  |   string customerNum = 6 [json_name = "customerNum"]; | ||||||
|  |   string customerName = 7 [json_name = "customerName"]; | ||||||
|  |   float  amount = 8 [json_name = "amount"]; | ||||||
|  |   int64  amountType = 9 [json_name = "amountType"]; | ||||||
|  |   string signContract = 10 [json_name = "signContract"]; | ||||||
|  |   string signature = 11 [json_name = "signature"]; | ||||||
|  |   string signedTime = 12 [json_name = "signedTime"]; | ||||||
|  |   int64 status = 13 [json_name = "status"]; | ||||||
|  |   string payTime = 14 [json_name = "payTime"]; | ||||||
|  |   string contractNo = 15 [json_name = "contractNo"]; | ||||||
|  |   float totalAmount = 16 [json_name = "totalAmount"]; //总金额 | ||||||
|  |   string bundleCommonUid = 17 [json_name = "bundleCommonUid"]; | ||||||
|  |   string snapshot = 18 [json_name = "snapshot"]; | ||||||
|  |   int32 payType = 19 [json_name = "payType"]; | ||||||
|  |   repeated OrderCreateAddRecord addRecords = 20 [json_name = "addRecords"]; //增值服务 | ||||||
|  | } | ||||||
|  | message OrderCreateAddRecord{ | ||||||
|  |   int32 serviceType = 1 [json_name = "serviceType"]; | ||||||
|  |   string valueUid = 2 [json_name = "valueUid"]; | ||||||
|  |   int64 currencyType = 3 [json_name = "currencyType"]; | ||||||
|  |   float amount = 4 [json_name = "amount"]; | ||||||
|  |   int32 num = 5 [json_name = "num"]; | ||||||
|  |   string unit = 6 [json_name = "unit"]; | ||||||
|  |   int32 source = 7 [json_name = "source"]; | ||||||
|  |   int32 paymentStatus = 8 [json_name = "paymentStatus"]; | ||||||
|  | } | ||||||
|  | message OrderRecordsRequestV2{ | ||||||
|  |   string customerName = 1; | ||||||
|  |   string telNum = 2; | ||||||
|  |   string bundleName = 3; | ||||||
|  |   int32 payStatus = 4; | ||||||
|  |   int32 addPayStatus = 5; | ||||||
|  |   string orderNo = 6; | ||||||
|  |   string orderAddNo = 7; | ||||||
|  |   string bundleCreateAtStart = 8; | ||||||
|  |   string bundleCreateAtEnd = 9; | ||||||
|  |   string orderAddCreateAtStart = 10; | ||||||
|  |   string orderAddCreateAtEnd = 11; | ||||||
|  |   int32 page = 12; | ||||||
|  |   int32 pageSize = 13; | ||||||
|  |   repeated int64 userIds = 14; | ||||||
|  | } | ||||||
|  | message OrderRecordsResponseV2{ | ||||||
|  |   repeated OrderBundleRecordInfo bundleInfo = 1; | ||||||
|  |   int32 page = 2; | ||||||
|  |   int32 pageSize = 3; | ||||||
|  |   int32 total = 4; | ||||||
|  | } | ||||||
|  | message OrderBundleRecordInfo{ | ||||||
|  |   string orderNo = 1; | ||||||
|  |   string bundleName = 2; | ||||||
|  |   int32 payStatus = 3; | ||||||
|  |   string telNum = 4; | ||||||
|  |   string customerName = 5; | ||||||
|  |   string bundleCreateAt = 6; | ||||||
|  |   float amount = 7; | ||||||
|  |   repeated OrderAddBundleRecordInfo addBundleInfo = 8; | ||||||
|  |   int64 customerId = 9; | ||||||
|  | } | ||||||
|  | message OrderAddBundleRecordInfo{ | ||||||
|  |   string orderAddNo = 1; | ||||||
|  |   float amount = 2; | ||||||
|  |   float settlementAmount = 3; | ||||||
|  |   int32 currencyType = 4; | ||||||
|  |   float handlingFee = 5; | ||||||
|  |   float exchangeRate = 6; | ||||||
|  |   string orderAddCreateAt = 7; | ||||||
|  |   int32 addPayStatus = 8; | ||||||
|  |   string contract = 9; | ||||||
|  |   string snapshot = 10; | ||||||
|  | } | ||||||
|  | message PackagePriceAndTimeResponse{ | ||||||
|  |   float price = 1 [json_name = "price"]; | ||||||
|  |   string time = 2 [json_name = "time"]; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| message CommonResponse { | message CommonResponse { | ||||||
| @ -77,6 +169,7 @@ message BundleProfile { | |||||||
|   int64 shelfStatus = 16 [json_name = "shelfStatus"]; // 1 上架 2 下架 |   int64 shelfStatus = 16 [json_name = "shelfStatus"]; // 1 上架 2 下架 | ||||||
|   repeated SelectValueAddService selectValueAddService = 17 [json_name = "SelectValueAddService"]; |   repeated SelectValueAddService selectValueAddService = 17 [json_name = "SelectValueAddService"]; | ||||||
|   repeated BundleProfileLang bundleProfileLang = 18 [json_name = "bundleProfileLang"]; |   repeated BundleProfileLang bundleProfileLang = 18 [json_name = "bundleProfileLang"]; | ||||||
|  |   int32 imgOption = 19 [json_name = "imgOption"]; | ||||||
| } | } | ||||||
| message BundleProfileLang { | message BundleProfileLang { | ||||||
|   string uuid = 1 [json_name = "uuid"]; |   string uuid = 1 [json_name = "uuid"]; | ||||||
| @ -87,10 +180,10 @@ message BundleProfileLang { | |||||||
|   string language = 6 [json_name = "language"]; |   string language = 6 [json_name = "language"]; | ||||||
|   string createdAt = 7 [json_name = "createdAt"]; |   string createdAt = 7 [json_name = "createdAt"]; | ||||||
|   string updatedAt = 8 [json_name = "updatedAt"]; |   string updatedAt = 8 [json_name = "updatedAt"]; | ||||||
|   string bgImg1 = 9 [json_name = "bgImg1"]; |   //string bgImg1 = 9 [json_name = "bgImg1"]; | ||||||
|   string bgImg2 = 10 [json_name = "bgImg2"]; |   //string bgImg2 = 10 [json_name = "bgImg2"]; | ||||||
|   int64 sort = 11 [json_name = "sort"]; |  // int64 sort = 11 [json_name = "sort"]; | ||||||
|   repeated ValueAddServiceLang valueAddServiceLang = 12 [json_name = "ValueAddServiceLang"]; |   //repeated ValueAddServiceLang valueAddServiceLang = 12 [json_name = "ValueAddServiceLang"]; | ||||||
| } | } | ||||||
| message SaveResponse { | message SaveResponse { | ||||||
|   string msg = 1 [json_name = "msg"]; |   string msg = 1 [json_name = "msg"]; | ||||||
| @ -132,9 +225,8 @@ message BundleDetailResponse { | |||||||
|   string msg = 2 [json_name = "msg"]; |   string msg = 2 [json_name = "msg"]; | ||||||
| } | } | ||||||
| message BundleDetailResponseV2{ | message BundleDetailResponseV2{ | ||||||
|   BundleProfileLang bundle = 1 [json_name = "bundle"]; |   BundleProfile bundle = 1 [json_name = "bundle"]; | ||||||
|   repeated SelectValueAddService selectValueAddService = 2 [json_name = "SelectValueAddService"]; |   string msg =2 [json_name = "msg"]; | ||||||
|   string msg =3 [json_name = "msg"]; |  | ||||||
| } | } | ||||||
| message OrderRecord { | message OrderRecord { | ||||||
|   string uuid = 1 [json_name = "uuid"]; |   string uuid = 1 [json_name = "uuid"]; | ||||||
| @ -173,10 +265,38 @@ message OrderRecord { | |||||||
|   string telNum = 34 [json_name = "telNum"]; |   string telNum = 34 [json_name = "telNum"]; | ||||||
|   string language = 35 [json_name = "language"]; |   string language = 35 [json_name = "language"]; | ||||||
|   repeated PriceOptionsInfo priceOptionsInfo = 36 [json_name = "priceOptionsInfo"]; |   repeated PriceOptionsInfo priceOptionsInfo = 36 [json_name = "priceOptionsInfo"]; | ||||||
|  |   string expirationTime = 37 [json_name = "expirationTime"]; | ||||||
|  |   string snapshot = 38 [json_name = "snapshot"]; | ||||||
|  | } | ||||||
|  | message OrderAddRecord{ | ||||||
|  |   string bundleUuid = 1 [json_name = "bundleUuid"]; | ||||||
|  |   repeated AddPriceOptionsInfo addPriceOptionsList = 2 [json_name = "addPriceOptionsList"]; | ||||||
|  |   string language = 3 [json_name = "language"]; | ||||||
|  |   string customerID = 4 [json_name = "customerID"]; | ||||||
|  |   string customerNum = 5 [json_name = "customerNum"]; | ||||||
|  |   string customerName = 6 [json_name = "customerName"]; | ||||||
|  | //  string valueAddUUID = 12 [json_name = "valueAddUUID"]; | ||||||
|  |   int32 source = 7 [json_name = "source"]; | ||||||
|  |   string signContract = 8 [json_name = "signContract"]; | ||||||
|  |   string signature = 9 [json_name = "signature"]; | ||||||
|  |   string signedTime = 10 [json_name = "signedTime"]; | ||||||
|  |   string expirationDate = 11 [json_name = "expirationDate"]; | ||||||
|  |   string snapshot = 38 [json_name = "snapshot"]; | ||||||
|  |   string orderUUID = 39 [json_name = "orderUUID"]; | ||||||
|  | } | ||||||
|  | message AddPriceOptionsInfo { | ||||||
|  |   int32 id = 1 [json_name = "id"]; | ||||||
|  |   string valueUid = 2 [json_name = "valueUid"]; | ||||||
|  |   int32 serviceType = 3 [json_name = "serviceType"]; | ||||||
|  |   int64 currencyType = 4 [json_name = "currencyType"]; | ||||||
|  |   float amount = 5 [json_name = "amount"]; | ||||||
|  |   int32 num = 6 [json_name = "num"]; | ||||||
|  |   string unit = 7 [json_name = "unit"]; | ||||||
| } | } | ||||||
| message PriceOptionsInfo { | message PriceOptionsInfo { | ||||||
|   int32 id = 1 [json_name = "id"]; |   int32 id = 1 [json_name = "id"]; | ||||||
|   string valueUid = 2 [json_name = "valueUid"]; |   string valueUid = 2 [json_name = "valueUid"]; | ||||||
|  |   int32 num = 3 [json_name = "num"]; | ||||||
| } | } | ||||||
| message OrderRecordsRequest { | message OrderRecordsRequest { | ||||||
|   int32 page = 1 [json_name = "page"]; |   int32 page = 1 [json_name = "page"]; | ||||||
| @ -206,6 +326,7 @@ message OrderRecordsDetailRequest { | |||||||
|   string uuid = 1 [json_name = "uuid"]; |   string uuid = 1 [json_name = "uuid"]; | ||||||
|   string orderNo = 2 [json_name = "orderNo"]; |   string orderNo = 2 [json_name = "orderNo"]; | ||||||
|   string customerID = 3 [json_name = "customerID"]; |   string customerID = 3 [json_name = "customerID"]; | ||||||
|  |   string bundleUUID = 4 [json_name = "bundleUUID"]; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| message OrderRecordsDetailResponse { | message OrderRecordsDetailResponse { | ||||||
| @ -299,6 +420,8 @@ message ValueAddPriceOptions { | |||||||
|  int32 num = 2 [json_name = "num"]; |  int32 num = 2 [json_name = "num"]; | ||||||
|  string symbol = 3 [json_name = "symbol"]; |  string symbol = 3 [json_name = "symbol"]; | ||||||
|  string price = 4 [json_name = "price"]; |  string price = 4 [json_name = "price"]; | ||||||
|  |  string saveAmount = 5 [json_name = "saveAmount"]; | ||||||
|  | 
 | ||||||
| } | } | ||||||
| //增值服务列表 | //增值服务列表 | ||||||
| message ValueAddServiceListRequest { | message ValueAddServiceListRequest { | ||||||
| @ -319,11 +442,19 @@ message ValueAddServiceDetailRequest { | |||||||
| } | } | ||||||
| message ValueAddServiceDetailResponse { | message ValueAddServiceDetailResponse { | ||||||
|   string msg = 1 [json_name = "msg"]; |   string msg = 1 [json_name = "msg"]; | ||||||
|   ValueAddServiceLang valueAddServiceLang = 2 [json_name = "valueAddServiceLang"]; |   ValueAddService valueAddService = 2 [json_name = "valueAddService"]; | ||||||
|  | } | ||||||
|  | message CalculatePriceRequest{ | ||||||
|  |   string uuid = 1; | ||||||
|  |   int32 num = 2; | ||||||
|  |   string language = 3; | ||||||
|  | } | ||||||
|  | message CalculatePriceResponse{ | ||||||
|  |   string msg = 1; | ||||||
|  |   float price = 2; | ||||||
| } | } | ||||||
| //*********************************新增值服务-over****************************************** | //*********************************新增值服务-over****************************************** | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| message BundleExtendRequest{ | message BundleExtendRequest{ | ||||||
|   int64 userId = 1; |   int64 userId = 1; | ||||||
|   uint32 accountAdditional = 2;  |   uint32 accountAdditional = 2;  | ||||||
| @ -331,10 +462,11 @@ message BundleExtendRequest{ | |||||||
|   uint32 imagesAdditional = 4;  |   uint32 imagesAdditional = 4;  | ||||||
|   uint32 dataAdditional = 5; |   uint32 dataAdditional = 5; | ||||||
|   uint32 availableDurationAdditional = 6;  |   uint32 availableDurationAdditional = 6;  | ||||||
|   string remark = 7;  |   uint32 timeUnit = 7; // 1 日 2 月 3年 | ||||||
|   string associatedorderNumber = 8;  |   string remark = 8;  | ||||||
|   string operatorName = 9;  |   string associatedorderNumber = 9;  | ||||||
|   string operatorPhoneNumber = 10;  |   string operatorName = 10;  | ||||||
|  |   string operatorPhoneNumber = 11;  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| message BundleExtendResponse{ | message BundleExtendResponse{ | ||||||
| @ -382,6 +514,16 @@ message GetBundleBalanceListReq{ | |||||||
|   int32 pageSize = 7; |   int32 pageSize = 7; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | message GetBundleBalanceReq{ | ||||||
|  |   string userName = 1; | ||||||
|  |   int32 status = 2; | ||||||
|  |   string bundleName = 3; | ||||||
|  |   int64 expiredTimeStart = 4; | ||||||
|  |   int64 expiredTimeEnd = 5; | ||||||
|  |   int32 page = 6; | ||||||
|  |   int32 pageSize = 7; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| message BundleBalanceItem{ | message BundleBalanceItem{ | ||||||
|   int32 userId = 1; |   int32 userId = 1; | ||||||
|   string userName = 2; |   string userName = 2; | ||||||
| @ -399,7 +541,10 @@ message BundleBalanceItem{ | |||||||
|   int32 dataAnalysisConsumptionNumber = 14; |   int32 dataAnalysisConsumptionNumber = 14; | ||||||
|   int32 expansionPacksNumber = 15; |   int32 expansionPacksNumber = 15; | ||||||
| } | } | ||||||
| 
 | message GetBundleBalanceResp{ | ||||||
|  |   int64 total = 1; | ||||||
|  |   repeated BundleBalanceItem data = 2; | ||||||
|  | } | ||||||
| message GetBundleBalanceListResp{ | message GetBundleBalanceListResp{ | ||||||
|   int64 total = 1; |   int64 total = 1; | ||||||
|   repeated BundleBalanceItem data = 2; |   repeated BundleBalanceItem data = 2; | ||||||
| @ -498,3 +643,23 @@ message  GetVedioeWorkDetailResp{ | |||||||
|   repeated string imageUrls = 2; |   repeated string imageUrls = 2; | ||||||
|   int64 createdAt = 3; |   int64 createdAt = 3; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | message ToBeComfirmedWorksReq{ | ||||||
|  |   string artistUuid = 1; | ||||||
|  |   int32 page = 2; | ||||||
|  |   int32 pageSize =3; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | message ToBeComfirmedWorksResp{ | ||||||
|  |   string uuid = 1;       // 作品uuid | ||||||
|  |   uint32 workCategory = 2;   // 1 图文 2 视频 | ||||||
|  |   string platformIDs = 3;    // 发布平台ID集合 (json 格式字符串) | ||||||
|  |   string mediaNames = 4;     // 自媒体账号名称集合 | ||||||
|  |   string mediaAccIDs = 5;   // 自媒体账号ID集合 | ||||||
|  |   string title = 6;     // 作品标题 | ||||||
|  |   string content = 7;     // 作品标题 | ||||||
|  |   string submitTime = 8;    // 提交时间 | ||||||
|  |   string operatorName = 9;  // 操作人名称 | ||||||
|  |   string operatorPhone = 10; // 操作人手机号 | ||||||
|  |   uint32 status = 11;        // 1 待提交 2 审核中 3 审核失败 4 待艺人确认 5 艺人驳回 6 发布成功 7 发布失败 | ||||||
|  | } | ||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -17,6 +17,48 @@ var _ = proto.Marshal | |||||||
| var _ = fmt.Errorf | var _ = fmt.Errorf | ||||||
| var _ = math.Inf | var _ = math.Inf | ||||||
| 
 | 
 | ||||||
|  | func (this *OrderCreateRecord) Validate() error { | ||||||
|  | 	for _, item := range this.AddRecords { | ||||||
|  | 		if item != nil { | ||||||
|  | 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||||
|  | 				return github_com_mwitkow_go_proto_validators.FieldError("AddRecords", err) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  | func (this *OrderCreateAddRecord) Validate() error { | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  | func (this *OrderRecordsRequestV2) Validate() error { | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  | func (this *OrderRecordsResponseV2) Validate() error { | ||||||
|  | 	for _, item := range this.BundleInfo { | ||||||
|  | 		if item != nil { | ||||||
|  | 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||||
|  | 				return github_com_mwitkow_go_proto_validators.FieldError("BundleInfo", err) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  | func (this *OrderBundleRecordInfo) Validate() error { | ||||||
|  | 	for _, item := range this.AddBundleInfo { | ||||||
|  | 		if item != nil { | ||||||
|  | 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||||
|  | 				return github_com_mwitkow_go_proto_validators.FieldError("AddBundleInfo", err) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  | func (this *OrderAddBundleRecordInfo) Validate() error { | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  | func (this *PackagePriceAndTimeResponse) Validate() error { | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
| func (this *CommonResponse) Validate() error { | func (this *CommonResponse) Validate() error { | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
| @ -38,13 +80,6 @@ func (this *BundleProfile) Validate() error { | |||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
| func (this *BundleProfileLang) Validate() error { | func (this *BundleProfileLang) Validate() error { | ||||||
| 	for _, item := range this.ValueAddServiceLang { |  | ||||||
| 		if item != nil { |  | ||||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { |  | ||||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("ValueAddServiceLang", err) |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
| func (this *SaveResponse) Validate() error { | func (this *SaveResponse) Validate() error { | ||||||
| @ -89,13 +124,6 @@ func (this *BundleDetailResponseV2) Validate() error { | |||||||
| 			return github_com_mwitkow_go_proto_validators.FieldError("Bundle", err) | 			return github_com_mwitkow_go_proto_validators.FieldError("Bundle", err) | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	for _, item := range this.SelectValueAddService { |  | ||||||
| 		if item != nil { |  | ||||||
| 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { |  | ||||||
| 				return github_com_mwitkow_go_proto_validators.FieldError("SelectValueAddService", err) |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
| func (this *OrderRecord) Validate() error { | func (this *OrderRecord) Validate() error { | ||||||
| @ -108,6 +136,19 @@ func (this *OrderRecord) Validate() error { | |||||||
| 	} | 	} | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  | func (this *OrderAddRecord) Validate() error { | ||||||
|  | 	for _, item := range this.AddPriceOptionsList { | ||||||
|  | 		if item != nil { | ||||||
|  | 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||||
|  | 				return github_com_mwitkow_go_proto_validators.FieldError("AddPriceOptionsList", err) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  | func (this *AddPriceOptionsInfo) Validate() error { | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
| func (this *PriceOptionsInfo) Validate() error { | func (this *PriceOptionsInfo) Validate() error { | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
| @ -217,13 +258,19 @@ func (this *ValueAddServiceDetailRequest) Validate() error { | |||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
| func (this *ValueAddServiceDetailResponse) Validate() error { | func (this *ValueAddServiceDetailResponse) Validate() error { | ||||||
| 	if this.ValueAddServiceLang != nil { | 	if this.ValueAddService != nil { | ||||||
| 		if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(this.ValueAddServiceLang); err != nil { | 		if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(this.ValueAddService); err != nil { | ||||||
| 			return github_com_mwitkow_go_proto_validators.FieldError("ValueAddServiceLang", err) | 			return github_com_mwitkow_go_proto_validators.FieldError("ValueAddService", err) | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  | func (this *CalculatePriceRequest) Validate() error { | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  | func (this *CalculatePriceResponse) Validate() error { | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
| func (this *BundleExtendRequest) Validate() error { | func (this *BundleExtendRequest) Validate() error { | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
| @ -249,9 +296,22 @@ func (this *BundleExtendRecordItem) Validate() error { | |||||||
| func (this *GetBundleBalanceListReq) Validate() error { | func (this *GetBundleBalanceListReq) Validate() error { | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  | func (this *GetBundleBalanceReq) Validate() error { | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
| func (this *BundleBalanceItem) Validate() error { | func (this *BundleBalanceItem) Validate() error { | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  | func (this *GetBundleBalanceResp) Validate() error { | ||||||
|  | 	for _, item := range this.Data { | ||||||
|  | 		if item != nil { | ||||||
|  | 			if err := github_com_mwitkow_go_proto_validators.CallValidatorIfExists(item); err != nil { | ||||||
|  | 				return github_com_mwitkow_go_proto_validators.FieldError("Data", err) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
| func (this *GetBundleBalanceListResp) Validate() error { | func (this *GetBundleBalanceListResp) Validate() error { | ||||||
| 	for _, item := range this.Data { | 	for _, item := range this.Data { | ||||||
| 		if item != nil { | 		if item != nil { | ||||||
| @ -302,3 +362,9 @@ func (this *GetImageWorkDetailResp) Validate() error { | |||||||
| func (this *GetVedioeWorkDetailResp) Validate() error { | func (this *GetVedioeWorkDetailResp) Validate() error { | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  | func (this *ToBeComfirmedWorksReq) Validate() error { | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  | func (this *ToBeComfirmedWorksResp) Validate() error { | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  | |||||||
| @ -37,12 +37,15 @@ type BundleClient interface { | |||||||
| 	BundleDetailV2(ctx context.Context, in *BundleDetailRequest, opts ...grpc_go.CallOption) (*BundleDetailResponseV2, common.ErrorWithAttachment) | 	BundleDetailV2(ctx context.Context, in *BundleDetailRequest, opts ...grpc_go.CallOption) (*BundleDetailResponseV2, common.ErrorWithAttachment) | ||||||
| 	BundleList(ctx context.Context, in *BundleListRequest, opts ...grpc_go.CallOption) (*BundleListResponse, common.ErrorWithAttachment) | 	BundleList(ctx context.Context, in *BundleListRequest, opts ...grpc_go.CallOption) (*BundleListResponse, common.ErrorWithAttachment) | ||||||
| 	BundleDetail(ctx context.Context, in *BundleDetailRequest, opts ...grpc_go.CallOption) (*BundleDetailResponse, common.ErrorWithAttachment) | 	BundleDetail(ctx context.Context, in *BundleDetailRequest, opts ...grpc_go.CallOption) (*BundleDetailResponse, common.ErrorWithAttachment) | ||||||
| 	CreateOrderRecord(ctx context.Context, in *OrderRecord, opts ...grpc_go.CallOption) (*CommonResponse, common.ErrorWithAttachment) | 	CreateOrderRecord(ctx context.Context, in *OrderCreateRecord, opts ...grpc_go.CallOption) (*CommonResponse, common.ErrorWithAttachment) | ||||||
| 	UpdateOrderRecord(ctx context.Context, in *OrderRecord, opts ...grpc_go.CallOption) (*CommonResponse, common.ErrorWithAttachment) | 	UpdateOrderRecord(ctx context.Context, in *OrderRecord, opts ...grpc_go.CallOption) (*CommonResponse, common.ErrorWithAttachment) | ||||||
| 	UpdateOrderRecordByOrderNo(ctx context.Context, in *OrderRecord, opts ...grpc_go.CallOption) (*CommonResponse, common.ErrorWithAttachment) | 	UpdateOrderRecordByOrderNo(ctx context.Context, in *OrderRecord, opts ...grpc_go.CallOption) (*CommonResponse, common.ErrorWithAttachment) | ||||||
| 	OrderRecordsList(ctx context.Context, in *OrderRecordsRequest, opts ...grpc_go.CallOption) (*OrderRecordsResponse, common.ErrorWithAttachment) | 	OrderRecordsList(ctx context.Context, in *OrderRecordsRequest, opts ...grpc_go.CallOption) (*OrderRecordsResponse, common.ErrorWithAttachment) | ||||||
| 	OrderRecordsDetail(ctx context.Context, in *OrderRecordsDetailRequest, opts ...grpc_go.CallOption) (*OrderRecordsDetailResponse, common.ErrorWithAttachment) | 	OrderRecordsDetail(ctx context.Context, in *OrderRecordsDetailRequest, opts ...grpc_go.CallOption) (*OrderRecordsDetailResponse, common.ErrorWithAttachment) | ||||||
| 	UpdateFinancialConfirmationStatus(ctx context.Context, in *FinancialConfirmationRequest, opts ...grpc_go.CallOption) (*CommonResponse, common.ErrorWithAttachment) | 	UpdateFinancialConfirmationStatus(ctx context.Context, in *FinancialConfirmationRequest, opts ...grpc_go.CallOption) (*CommonResponse, common.ErrorWithAttachment) | ||||||
|  | 	CreateOrderAddRecord(ctx context.Context, in *OrderAddRecord, opts ...grpc_go.CallOption) (*CommonResponse, common.ErrorWithAttachment) | ||||||
|  | 	PackagePriceAndTime(ctx context.Context, in *OrderRecord, opts ...grpc_go.CallOption) (*PackagePriceAndTimeResponse, common.ErrorWithAttachment) | ||||||
|  | 	OrderRecordsListV2(ctx context.Context, in *OrderRecordsRequestV2, opts ...grpc_go.CallOption) (*OrderRecordsResponseV2, common.ErrorWithAttachment) | ||||||
| 	// 增值套餐
 | 	// 增值套餐
 | ||||||
| 	CreateValueAddBundle(ctx context.Context, in *CreateValueAddBundleRequest, opts ...grpc_go.CallOption) (*CreateValueAddBundleResponse, common.ErrorWithAttachment) | 	CreateValueAddBundle(ctx context.Context, in *CreateValueAddBundleRequest, opts ...grpc_go.CallOption) (*CreateValueAddBundleResponse, common.ErrorWithAttachment) | ||||||
| 	ValueAddBundleList(ctx context.Context, in *ValueAddBundleListRequest, opts ...grpc_go.CallOption) (*ValueAddBundleListResponse, common.ErrorWithAttachment) | 	ValueAddBundleList(ctx context.Context, in *ValueAddBundleListRequest, opts ...grpc_go.CallOption) (*ValueAddBundleListResponse, common.ErrorWithAttachment) | ||||||
| @ -51,6 +54,8 @@ type BundleClient interface { | |||||||
| 	SaveValueAddService(ctx context.Context, in *ValueAddServiceLang, opts ...grpc_go.CallOption) (*SaveResponse, common.ErrorWithAttachment) | 	SaveValueAddService(ctx context.Context, in *ValueAddServiceLang, opts ...grpc_go.CallOption) (*SaveResponse, common.ErrorWithAttachment) | ||||||
| 	ValueAddServiceList(ctx context.Context, in *ValueAddServiceListRequest, opts ...grpc_go.CallOption) (*ValueAddServiceListResponse, common.ErrorWithAttachment) | 	ValueAddServiceList(ctx context.Context, in *ValueAddServiceListRequest, opts ...grpc_go.CallOption) (*ValueAddServiceListResponse, common.ErrorWithAttachment) | ||||||
| 	ValueAddServiceDetail(ctx context.Context, in *ValueAddServiceDetailRequest, opts ...grpc_go.CallOption) (*ValueAddServiceDetailResponse, common.ErrorWithAttachment) | 	ValueAddServiceDetail(ctx context.Context, in *ValueAddServiceDetailRequest, opts ...grpc_go.CallOption) (*ValueAddServiceDetailResponse, common.ErrorWithAttachment) | ||||||
|  | 	ValueAddServiceLangByUuidAndLanguage(ctx context.Context, in *ValueAddServiceDetailRequest, opts ...grpc_go.CallOption) (*ValueAddServiceLang, common.ErrorWithAttachment) | ||||||
|  | 	CalculatePrice(ctx context.Context, in *CalculatePriceRequest, opts ...grpc_go.CallOption) (*CalculatePriceResponse, common.ErrorWithAttachment) | ||||||
| 	// 余量管理
 | 	// 余量管理
 | ||||||
| 	BundleExtend(ctx context.Context, in *BundleExtendRequest, opts ...grpc_go.CallOption) (*BundleExtendResponse, common.ErrorWithAttachment) | 	BundleExtend(ctx context.Context, in *BundleExtendRequest, opts ...grpc_go.CallOption) (*BundleExtendResponse, common.ErrorWithAttachment) | ||||||
| 	BundleExtendRecordsList(ctx context.Context, in *BundleExtendRecordsListRequest, opts ...grpc_go.CallOption) (*BundleExtendRecordsListResponse, common.ErrorWithAttachment) | 	BundleExtendRecordsList(ctx context.Context, in *BundleExtendRecordsListRequest, opts ...grpc_go.CallOption) (*BundleExtendRecordsListResponse, common.ErrorWithAttachment) | ||||||
| @ -61,6 +66,7 @@ type BundleClient interface { | |||||||
| 	GetUsedRecordList(ctx context.Context, in *GetUsedRecordListReq, opts ...grpc_go.CallOption) (*GetUsedRecordListResp, common.ErrorWithAttachment) | 	GetUsedRecordList(ctx context.Context, in *GetUsedRecordListReq, opts ...grpc_go.CallOption) (*GetUsedRecordListResp, common.ErrorWithAttachment) | ||||||
| 	GetImageWorkDetail(ctx context.Context, in *GetImageWorkDetailReq, opts ...grpc_go.CallOption) (*GetImageWorkDetailResp, common.ErrorWithAttachment) | 	GetImageWorkDetail(ctx context.Context, in *GetImageWorkDetailReq, opts ...grpc_go.CallOption) (*GetImageWorkDetailResp, common.ErrorWithAttachment) | ||||||
| 	GetVedioWorkDetail(ctx context.Context, in *GetVedioWorkDetailReq, opts ...grpc_go.CallOption) (*GetVedioeWorkDetailResp, common.ErrorWithAttachment) | 	GetVedioWorkDetail(ctx context.Context, in *GetVedioWorkDetailReq, opts ...grpc_go.CallOption) (*GetVedioeWorkDetailResp, common.ErrorWithAttachment) | ||||||
|  | 	ToBeComfirmedWorks(ctx context.Context, in *ToBeComfirmedWorksReq, opts ...grpc_go.CallOption) (*ToBeComfirmedWorksResp, common.ErrorWithAttachment) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| type bundleClient struct { | type bundleClient struct { | ||||||
| @ -77,18 +83,23 @@ type BundleClientImpl struct { | |||||||
| 	BundleDetailV2                       func(ctx context.Context, in *BundleDetailRequest) (*BundleDetailResponseV2, error) | 	BundleDetailV2                       func(ctx context.Context, in *BundleDetailRequest) (*BundleDetailResponseV2, error) | ||||||
| 	BundleList                           func(ctx context.Context, in *BundleListRequest) (*BundleListResponse, error) | 	BundleList                           func(ctx context.Context, in *BundleListRequest) (*BundleListResponse, error) | ||||||
| 	BundleDetail                         func(ctx context.Context, in *BundleDetailRequest) (*BundleDetailResponse, error) | 	BundleDetail                         func(ctx context.Context, in *BundleDetailRequest) (*BundleDetailResponse, error) | ||||||
| 	CreateOrderRecord                 func(ctx context.Context, in *OrderRecord) (*CommonResponse, error) | 	CreateOrderRecord                    func(ctx context.Context, in *OrderCreateRecord) (*CommonResponse, error) | ||||||
| 	UpdateOrderRecord                    func(ctx context.Context, in *OrderRecord) (*CommonResponse, error) | 	UpdateOrderRecord                    func(ctx context.Context, in *OrderRecord) (*CommonResponse, error) | ||||||
| 	UpdateOrderRecordByOrderNo           func(ctx context.Context, in *OrderRecord) (*CommonResponse, error) | 	UpdateOrderRecordByOrderNo           func(ctx context.Context, in *OrderRecord) (*CommonResponse, error) | ||||||
| 	OrderRecordsList                     func(ctx context.Context, in *OrderRecordsRequest) (*OrderRecordsResponse, error) | 	OrderRecordsList                     func(ctx context.Context, in *OrderRecordsRequest) (*OrderRecordsResponse, error) | ||||||
| 	OrderRecordsDetail                   func(ctx context.Context, in *OrderRecordsDetailRequest) (*OrderRecordsDetailResponse, error) | 	OrderRecordsDetail                   func(ctx context.Context, in *OrderRecordsDetailRequest) (*OrderRecordsDetailResponse, error) | ||||||
| 	UpdateFinancialConfirmationStatus    func(ctx context.Context, in *FinancialConfirmationRequest) (*CommonResponse, error) | 	UpdateFinancialConfirmationStatus    func(ctx context.Context, in *FinancialConfirmationRequest) (*CommonResponse, error) | ||||||
|  | 	CreateOrderAddRecord                 func(ctx context.Context, in *OrderAddRecord) (*CommonResponse, error) | ||||||
|  | 	PackagePriceAndTime                  func(ctx context.Context, in *OrderRecord) (*PackagePriceAndTimeResponse, error) | ||||||
|  | 	OrderRecordsListV2                   func(ctx context.Context, in *OrderRecordsRequestV2) (*OrderRecordsResponseV2, error) | ||||||
| 	CreateValueAddBundle                 func(ctx context.Context, in *CreateValueAddBundleRequest) (*CreateValueAddBundleResponse, error) | 	CreateValueAddBundle                 func(ctx context.Context, in *CreateValueAddBundleRequest) (*CreateValueAddBundleResponse, error) | ||||||
| 	ValueAddBundleList                   func(ctx context.Context, in *ValueAddBundleListRequest) (*ValueAddBundleListResponse, error) | 	ValueAddBundleList                   func(ctx context.Context, in *ValueAddBundleListRequest) (*ValueAddBundleListResponse, error) | ||||||
| 	ValueAddBundleDetail                 func(ctx context.Context, in *ValueAddBundleDetailRequest) (*ValueAddBundleDetailResponse, error) | 	ValueAddBundleDetail                 func(ctx context.Context, in *ValueAddBundleDetailRequest) (*ValueAddBundleDetailResponse, error) | ||||||
| 	SaveValueAddService                  func(ctx context.Context, in *ValueAddServiceLang) (*SaveResponse, error) | 	SaveValueAddService                  func(ctx context.Context, in *ValueAddServiceLang) (*SaveResponse, error) | ||||||
| 	ValueAddServiceList                  func(ctx context.Context, in *ValueAddServiceListRequest) (*ValueAddServiceListResponse, error) | 	ValueAddServiceList                  func(ctx context.Context, in *ValueAddServiceListRequest) (*ValueAddServiceListResponse, error) | ||||||
| 	ValueAddServiceDetail                func(ctx context.Context, in *ValueAddServiceDetailRequest) (*ValueAddServiceDetailResponse, error) | 	ValueAddServiceDetail                func(ctx context.Context, in *ValueAddServiceDetailRequest) (*ValueAddServiceDetailResponse, error) | ||||||
|  | 	ValueAddServiceLangByUuidAndLanguage func(ctx context.Context, in *ValueAddServiceDetailRequest) (*ValueAddServiceLang, error) | ||||||
|  | 	CalculatePrice                       func(ctx context.Context, in *CalculatePriceRequest) (*CalculatePriceResponse, error) | ||||||
| 	BundleExtend                         func(ctx context.Context, in *BundleExtendRequest) (*BundleExtendResponse, error) | 	BundleExtend                         func(ctx context.Context, in *BundleExtendRequest) (*BundleExtendResponse, error) | ||||||
| 	BundleExtendRecordsList              func(ctx context.Context, in *BundleExtendRecordsListRequest) (*BundleExtendRecordsListResponse, error) | 	BundleExtendRecordsList              func(ctx context.Context, in *BundleExtendRecordsListRequest) (*BundleExtendRecordsListResponse, error) | ||||||
| 	GetBundleBalanceList                 func(ctx context.Context, in *GetBundleBalanceListReq) (*GetBundleBalanceListResp, error) | 	GetBundleBalanceList                 func(ctx context.Context, in *GetBundleBalanceListReq) (*GetBundleBalanceListResp, error) | ||||||
| @ -97,6 +108,7 @@ type BundleClientImpl struct { | |||||||
| 	GetUsedRecordList                    func(ctx context.Context, in *GetUsedRecordListReq) (*GetUsedRecordListResp, error) | 	GetUsedRecordList                    func(ctx context.Context, in *GetUsedRecordListReq) (*GetUsedRecordListResp, error) | ||||||
| 	GetImageWorkDetail                   func(ctx context.Context, in *GetImageWorkDetailReq) (*GetImageWorkDetailResp, error) | 	GetImageWorkDetail                   func(ctx context.Context, in *GetImageWorkDetailReq) (*GetImageWorkDetailResp, error) | ||||||
| 	GetVedioWorkDetail                   func(ctx context.Context, in *GetVedioWorkDetailReq) (*GetVedioeWorkDetailResp, error) | 	GetVedioWorkDetail                   func(ctx context.Context, in *GetVedioWorkDetailReq) (*GetVedioeWorkDetailResp, error) | ||||||
|  | 	ToBeComfirmedWorks                   func(ctx context.Context, in *ToBeComfirmedWorksReq) (*ToBeComfirmedWorksResp, error) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (c *BundleClientImpl) GetDubboStub(cc *triple.TripleConn) BundleClient { | func (c *BundleClientImpl) GetDubboStub(cc *triple.TripleConn) BundleClient { | ||||||
| @ -165,7 +177,7 @@ func (c *bundleClient) BundleDetail(ctx context.Context, in *BundleDetailRequest | |||||||
| 	return out, c.cc.Invoke(ctx, "/"+interfaceKey+"/BundleDetail", in, out) | 	return out, c.cc.Invoke(ctx, "/"+interfaceKey+"/BundleDetail", in, out) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (c *bundleClient) CreateOrderRecord(ctx context.Context, in *OrderRecord, opts ...grpc_go.CallOption) (*CommonResponse, common.ErrorWithAttachment) { | func (c *bundleClient) CreateOrderRecord(ctx context.Context, in *OrderCreateRecord, opts ...grpc_go.CallOption) (*CommonResponse, common.ErrorWithAttachment) { | ||||||
| 	out := new(CommonResponse) | 	out := new(CommonResponse) | ||||||
| 	interfaceKey := ctx.Value(constant.InterfaceKey).(string) | 	interfaceKey := ctx.Value(constant.InterfaceKey).(string) | ||||||
| 	return out, c.cc.Invoke(ctx, "/"+interfaceKey+"/CreateOrderRecord", in, out) | 	return out, c.cc.Invoke(ctx, "/"+interfaceKey+"/CreateOrderRecord", in, out) | ||||||
| @ -201,6 +213,24 @@ func (c *bundleClient) UpdateFinancialConfirmationStatus(ctx context.Context, in | |||||||
| 	return out, c.cc.Invoke(ctx, "/"+interfaceKey+"/UpdateFinancialConfirmationStatus", in, out) | 	return out, c.cc.Invoke(ctx, "/"+interfaceKey+"/UpdateFinancialConfirmationStatus", in, out) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func (c *bundleClient) CreateOrderAddRecord(ctx context.Context, in *OrderAddRecord, opts ...grpc_go.CallOption) (*CommonResponse, common.ErrorWithAttachment) { | ||||||
|  | 	out := new(CommonResponse) | ||||||
|  | 	interfaceKey := ctx.Value(constant.InterfaceKey).(string) | ||||||
|  | 	return out, c.cc.Invoke(ctx, "/"+interfaceKey+"/CreateOrderAddRecord", in, out) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (c *bundleClient) PackagePriceAndTime(ctx context.Context, in *OrderRecord, opts ...grpc_go.CallOption) (*PackagePriceAndTimeResponse, common.ErrorWithAttachment) { | ||||||
|  | 	out := new(PackagePriceAndTimeResponse) | ||||||
|  | 	interfaceKey := ctx.Value(constant.InterfaceKey).(string) | ||||||
|  | 	return out, c.cc.Invoke(ctx, "/"+interfaceKey+"/PackagePriceAndTime", in, out) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (c *bundleClient) OrderRecordsListV2(ctx context.Context, in *OrderRecordsRequestV2, opts ...grpc_go.CallOption) (*OrderRecordsResponseV2, common.ErrorWithAttachment) { | ||||||
|  | 	out := new(OrderRecordsResponseV2) | ||||||
|  | 	interfaceKey := ctx.Value(constant.InterfaceKey).(string) | ||||||
|  | 	return out, c.cc.Invoke(ctx, "/"+interfaceKey+"/OrderRecordsListV2", in, out) | ||||||
|  | } | ||||||
|  | 
 | ||||||
| func (c *bundleClient) CreateValueAddBundle(ctx context.Context, in *CreateValueAddBundleRequest, opts ...grpc_go.CallOption) (*CreateValueAddBundleResponse, common.ErrorWithAttachment) { | func (c *bundleClient) CreateValueAddBundle(ctx context.Context, in *CreateValueAddBundleRequest, opts ...grpc_go.CallOption) (*CreateValueAddBundleResponse, common.ErrorWithAttachment) { | ||||||
| 	out := new(CreateValueAddBundleResponse) | 	out := new(CreateValueAddBundleResponse) | ||||||
| 	interfaceKey := ctx.Value(constant.InterfaceKey).(string) | 	interfaceKey := ctx.Value(constant.InterfaceKey).(string) | ||||||
| @ -237,6 +267,18 @@ func (c *bundleClient) ValueAddServiceDetail(ctx context.Context, in *ValueAddSe | |||||||
| 	return out, c.cc.Invoke(ctx, "/"+interfaceKey+"/ValueAddServiceDetail", in, out) | 	return out, c.cc.Invoke(ctx, "/"+interfaceKey+"/ValueAddServiceDetail", in, out) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func (c *bundleClient) ValueAddServiceLangByUuidAndLanguage(ctx context.Context, in *ValueAddServiceDetailRequest, opts ...grpc_go.CallOption) (*ValueAddServiceLang, common.ErrorWithAttachment) { | ||||||
|  | 	out := new(ValueAddServiceLang) | ||||||
|  | 	interfaceKey := ctx.Value(constant.InterfaceKey).(string) | ||||||
|  | 	return out, c.cc.Invoke(ctx, "/"+interfaceKey+"/ValueAddServiceLangByUuidAndLanguage", in, out) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (c *bundleClient) CalculatePrice(ctx context.Context, in *CalculatePriceRequest, opts ...grpc_go.CallOption) (*CalculatePriceResponse, common.ErrorWithAttachment) { | ||||||
|  | 	out := new(CalculatePriceResponse) | ||||||
|  | 	interfaceKey := ctx.Value(constant.InterfaceKey).(string) | ||||||
|  | 	return out, c.cc.Invoke(ctx, "/"+interfaceKey+"/CalculatePrice", in, out) | ||||||
|  | } | ||||||
|  | 
 | ||||||
| func (c *bundleClient) BundleExtend(ctx context.Context, in *BundleExtendRequest, opts ...grpc_go.CallOption) (*BundleExtendResponse, common.ErrorWithAttachment) { | func (c *bundleClient) BundleExtend(ctx context.Context, in *BundleExtendRequest, opts ...grpc_go.CallOption) (*BundleExtendResponse, common.ErrorWithAttachment) { | ||||||
| 	out := new(BundleExtendResponse) | 	out := new(BundleExtendResponse) | ||||||
| 	interfaceKey := ctx.Value(constant.InterfaceKey).(string) | 	interfaceKey := ctx.Value(constant.InterfaceKey).(string) | ||||||
| @ -285,6 +327,12 @@ func (c *bundleClient) GetVedioWorkDetail(ctx context.Context, in *GetVedioWorkD | |||||||
| 	return out, c.cc.Invoke(ctx, "/"+interfaceKey+"/GetVedioWorkDetail", in, out) | 	return out, c.cc.Invoke(ctx, "/"+interfaceKey+"/GetVedioWorkDetail", in, out) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func (c *bundleClient) ToBeComfirmedWorks(ctx context.Context, in *ToBeComfirmedWorksReq, opts ...grpc_go.CallOption) (*ToBeComfirmedWorksResp, common.ErrorWithAttachment) { | ||||||
|  | 	out := new(ToBeComfirmedWorksResp) | ||||||
|  | 	interfaceKey := ctx.Value(constant.InterfaceKey).(string) | ||||||
|  | 	return out, c.cc.Invoke(ctx, "/"+interfaceKey+"/ToBeComfirmedWorks", in, out) | ||||||
|  | } | ||||||
|  | 
 | ||||||
| // BundleServer is the server API for Bundle service.
 | // BundleServer is the server API for Bundle service.
 | ||||||
| // All implementations must embed UnimplementedBundleServer
 | // All implementations must embed UnimplementedBundleServer
 | ||||||
| // for forward compatibility
 | // for forward compatibility
 | ||||||
| @ -298,12 +346,15 @@ type BundleServer interface { | |||||||
| 	BundleDetailV2(context.Context, *BundleDetailRequest) (*BundleDetailResponseV2, error) | 	BundleDetailV2(context.Context, *BundleDetailRequest) (*BundleDetailResponseV2, error) | ||||||
| 	BundleList(context.Context, *BundleListRequest) (*BundleListResponse, error) | 	BundleList(context.Context, *BundleListRequest) (*BundleListResponse, error) | ||||||
| 	BundleDetail(context.Context, *BundleDetailRequest) (*BundleDetailResponse, error) | 	BundleDetail(context.Context, *BundleDetailRequest) (*BundleDetailResponse, error) | ||||||
| 	CreateOrderRecord(context.Context, *OrderRecord) (*CommonResponse, error) | 	CreateOrderRecord(context.Context, *OrderCreateRecord) (*CommonResponse, error) | ||||||
| 	UpdateOrderRecord(context.Context, *OrderRecord) (*CommonResponse, error) | 	UpdateOrderRecord(context.Context, *OrderRecord) (*CommonResponse, error) | ||||||
| 	UpdateOrderRecordByOrderNo(context.Context, *OrderRecord) (*CommonResponse, error) | 	UpdateOrderRecordByOrderNo(context.Context, *OrderRecord) (*CommonResponse, error) | ||||||
| 	OrderRecordsList(context.Context, *OrderRecordsRequest) (*OrderRecordsResponse, error) | 	OrderRecordsList(context.Context, *OrderRecordsRequest) (*OrderRecordsResponse, error) | ||||||
| 	OrderRecordsDetail(context.Context, *OrderRecordsDetailRequest) (*OrderRecordsDetailResponse, error) | 	OrderRecordsDetail(context.Context, *OrderRecordsDetailRequest) (*OrderRecordsDetailResponse, error) | ||||||
| 	UpdateFinancialConfirmationStatus(context.Context, *FinancialConfirmationRequest) (*CommonResponse, error) | 	UpdateFinancialConfirmationStatus(context.Context, *FinancialConfirmationRequest) (*CommonResponse, error) | ||||||
|  | 	CreateOrderAddRecord(context.Context, *OrderAddRecord) (*CommonResponse, error) | ||||||
|  | 	PackagePriceAndTime(context.Context, *OrderRecord) (*PackagePriceAndTimeResponse, error) | ||||||
|  | 	OrderRecordsListV2(context.Context, *OrderRecordsRequestV2) (*OrderRecordsResponseV2, error) | ||||||
| 	// 增值套餐
 | 	// 增值套餐
 | ||||||
| 	CreateValueAddBundle(context.Context, *CreateValueAddBundleRequest) (*CreateValueAddBundleResponse, error) | 	CreateValueAddBundle(context.Context, *CreateValueAddBundleRequest) (*CreateValueAddBundleResponse, error) | ||||||
| 	ValueAddBundleList(context.Context, *ValueAddBundleListRequest) (*ValueAddBundleListResponse, error) | 	ValueAddBundleList(context.Context, *ValueAddBundleListRequest) (*ValueAddBundleListResponse, error) | ||||||
| @ -312,6 +363,8 @@ type BundleServer interface { | |||||||
| 	SaveValueAddService(context.Context, *ValueAddServiceLang) (*SaveResponse, error) | 	SaveValueAddService(context.Context, *ValueAddServiceLang) (*SaveResponse, error) | ||||||
| 	ValueAddServiceList(context.Context, *ValueAddServiceListRequest) (*ValueAddServiceListResponse, error) | 	ValueAddServiceList(context.Context, *ValueAddServiceListRequest) (*ValueAddServiceListResponse, error) | ||||||
| 	ValueAddServiceDetail(context.Context, *ValueAddServiceDetailRequest) (*ValueAddServiceDetailResponse, error) | 	ValueAddServiceDetail(context.Context, *ValueAddServiceDetailRequest) (*ValueAddServiceDetailResponse, error) | ||||||
|  | 	ValueAddServiceLangByUuidAndLanguage(context.Context, *ValueAddServiceDetailRequest) (*ValueAddServiceLang, error) | ||||||
|  | 	CalculatePrice(context.Context, *CalculatePriceRequest) (*CalculatePriceResponse, error) | ||||||
| 	// 余量管理
 | 	// 余量管理
 | ||||||
| 	BundleExtend(context.Context, *BundleExtendRequest) (*BundleExtendResponse, error) | 	BundleExtend(context.Context, *BundleExtendRequest) (*BundleExtendResponse, error) | ||||||
| 	BundleExtendRecordsList(context.Context, *BundleExtendRecordsListRequest) (*BundleExtendRecordsListResponse, error) | 	BundleExtendRecordsList(context.Context, *BundleExtendRecordsListRequest) (*BundleExtendRecordsListResponse, error) | ||||||
| @ -322,6 +375,7 @@ type BundleServer interface { | |||||||
| 	GetUsedRecordList(context.Context, *GetUsedRecordListReq) (*GetUsedRecordListResp, error) | 	GetUsedRecordList(context.Context, *GetUsedRecordListReq) (*GetUsedRecordListResp, error) | ||||||
| 	GetImageWorkDetail(context.Context, *GetImageWorkDetailReq) (*GetImageWorkDetailResp, error) | 	GetImageWorkDetail(context.Context, *GetImageWorkDetailReq) (*GetImageWorkDetailResp, error) | ||||||
| 	GetVedioWorkDetail(context.Context, *GetVedioWorkDetailReq) (*GetVedioeWorkDetailResp, error) | 	GetVedioWorkDetail(context.Context, *GetVedioWorkDetailReq) (*GetVedioeWorkDetailResp, error) | ||||||
|  | 	ToBeComfirmedWorks(context.Context, *ToBeComfirmedWorksReq) (*ToBeComfirmedWorksResp, error) | ||||||
| 	mustEmbedUnimplementedBundleServer() | 	mustEmbedUnimplementedBundleServer() | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -357,7 +411,7 @@ func (UnimplementedBundleServer) BundleList(context.Context, *BundleListRequest) | |||||||
| func (UnimplementedBundleServer) BundleDetail(context.Context, *BundleDetailRequest) (*BundleDetailResponse, error) { | func (UnimplementedBundleServer) BundleDetail(context.Context, *BundleDetailRequest) (*BundleDetailResponse, error) { | ||||||
| 	return nil, status.Errorf(codes.Unimplemented, "method BundleDetail not implemented") | 	return nil, status.Errorf(codes.Unimplemented, "method BundleDetail not implemented") | ||||||
| } | } | ||||||
| func (UnimplementedBundleServer) CreateOrderRecord(context.Context, *OrderRecord) (*CommonResponse, error) { | func (UnimplementedBundleServer) CreateOrderRecord(context.Context, *OrderCreateRecord) (*CommonResponse, error) { | ||||||
| 	return nil, status.Errorf(codes.Unimplemented, "method CreateOrderRecord not implemented") | 	return nil, status.Errorf(codes.Unimplemented, "method CreateOrderRecord not implemented") | ||||||
| } | } | ||||||
| func (UnimplementedBundleServer) UpdateOrderRecord(context.Context, *OrderRecord) (*CommonResponse, error) { | func (UnimplementedBundleServer) UpdateOrderRecord(context.Context, *OrderRecord) (*CommonResponse, error) { | ||||||
| @ -375,6 +429,15 @@ func (UnimplementedBundleServer) OrderRecordsDetail(context.Context, *OrderRecor | |||||||
| func (UnimplementedBundleServer) UpdateFinancialConfirmationStatus(context.Context, *FinancialConfirmationRequest) (*CommonResponse, error) { | func (UnimplementedBundleServer) UpdateFinancialConfirmationStatus(context.Context, *FinancialConfirmationRequest) (*CommonResponse, error) { | ||||||
| 	return nil, status.Errorf(codes.Unimplemented, "method UpdateFinancialConfirmationStatus not implemented") | 	return nil, status.Errorf(codes.Unimplemented, "method UpdateFinancialConfirmationStatus not implemented") | ||||||
| } | } | ||||||
|  | func (UnimplementedBundleServer) CreateOrderAddRecord(context.Context, *OrderAddRecord) (*CommonResponse, error) { | ||||||
|  | 	return nil, status.Errorf(codes.Unimplemented, "method CreateOrderAddRecord not implemented") | ||||||
|  | } | ||||||
|  | func (UnimplementedBundleServer) PackagePriceAndTime(context.Context, *OrderRecord) (*PackagePriceAndTimeResponse, error) { | ||||||
|  | 	return nil, status.Errorf(codes.Unimplemented, "method PackagePriceAndTime not implemented") | ||||||
|  | } | ||||||
|  | func (UnimplementedBundleServer) OrderRecordsListV2(context.Context, *OrderRecordsRequestV2) (*OrderRecordsResponseV2, error) { | ||||||
|  | 	return nil, status.Errorf(codes.Unimplemented, "method OrderRecordsListV2 not implemented") | ||||||
|  | } | ||||||
| func (UnimplementedBundleServer) CreateValueAddBundle(context.Context, *CreateValueAddBundleRequest) (*CreateValueAddBundleResponse, error) { | func (UnimplementedBundleServer) CreateValueAddBundle(context.Context, *CreateValueAddBundleRequest) (*CreateValueAddBundleResponse, error) { | ||||||
| 	return nil, status.Errorf(codes.Unimplemented, "method CreateValueAddBundle not implemented") | 	return nil, status.Errorf(codes.Unimplemented, "method CreateValueAddBundle not implemented") | ||||||
| } | } | ||||||
| @ -393,6 +456,12 @@ func (UnimplementedBundleServer) ValueAddServiceList(context.Context, *ValueAddS | |||||||
| func (UnimplementedBundleServer) ValueAddServiceDetail(context.Context, *ValueAddServiceDetailRequest) (*ValueAddServiceDetailResponse, error) { | func (UnimplementedBundleServer) ValueAddServiceDetail(context.Context, *ValueAddServiceDetailRequest) (*ValueAddServiceDetailResponse, error) { | ||||||
| 	return nil, status.Errorf(codes.Unimplemented, "method ValueAddServiceDetail not implemented") | 	return nil, status.Errorf(codes.Unimplemented, "method ValueAddServiceDetail not implemented") | ||||||
| } | } | ||||||
|  | func (UnimplementedBundleServer) ValueAddServiceLangByUuidAndLanguage(context.Context, *ValueAddServiceDetailRequest) (*ValueAddServiceLang, error) { | ||||||
|  | 	return nil, status.Errorf(codes.Unimplemented, "method ValueAddServiceLangByUuidAndLanguage not implemented") | ||||||
|  | } | ||||||
|  | func (UnimplementedBundleServer) CalculatePrice(context.Context, *CalculatePriceRequest) (*CalculatePriceResponse, error) { | ||||||
|  | 	return nil, status.Errorf(codes.Unimplemented, "method CalculatePrice not implemented") | ||||||
|  | } | ||||||
| func (UnimplementedBundleServer) BundleExtend(context.Context, *BundleExtendRequest) (*BundleExtendResponse, error) { | func (UnimplementedBundleServer) BundleExtend(context.Context, *BundleExtendRequest) (*BundleExtendResponse, error) { | ||||||
| 	return nil, status.Errorf(codes.Unimplemented, "method BundleExtend not implemented") | 	return nil, status.Errorf(codes.Unimplemented, "method BundleExtend not implemented") | ||||||
| } | } | ||||||
| @ -417,6 +486,9 @@ func (UnimplementedBundleServer) GetImageWorkDetail(context.Context, *GetImageWo | |||||||
| func (UnimplementedBundleServer) GetVedioWorkDetail(context.Context, *GetVedioWorkDetailReq) (*GetVedioeWorkDetailResp, error) { | func (UnimplementedBundleServer) GetVedioWorkDetail(context.Context, *GetVedioWorkDetailReq) (*GetVedioeWorkDetailResp, error) { | ||||||
| 	return nil, status.Errorf(codes.Unimplemented, "method GetVedioWorkDetail not implemented") | 	return nil, status.Errorf(codes.Unimplemented, "method GetVedioWorkDetail not implemented") | ||||||
| } | } | ||||||
|  | func (UnimplementedBundleServer) ToBeComfirmedWorks(context.Context, *ToBeComfirmedWorksReq) (*ToBeComfirmedWorksResp, error) { | ||||||
|  | 	return nil, status.Errorf(codes.Unimplemented, "method ToBeComfirmedWorks not implemented") | ||||||
|  | } | ||||||
| func (s *UnimplementedBundleServer) XXX_SetProxyImpl(impl protocol.Invoker) { | func (s *UnimplementedBundleServer) XXX_SetProxyImpl(impl protocol.Invoker) { | ||||||
| 	s.proxyImpl = impl | 	s.proxyImpl = impl | ||||||
| } | } | ||||||
| @ -707,7 +779,7 @@ func _Bundle_BundleDetail_Handler(srv interface{}, ctx context.Context, dec func | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func _Bundle_CreateOrderRecord_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc_go.UnaryServerInterceptor) (interface{}, error) { | func _Bundle_CreateOrderRecord_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc_go.UnaryServerInterceptor) (interface{}, error) { | ||||||
| 	in := new(OrderRecord) | 	in := new(OrderCreateRecord) | ||||||
| 	if err := dec(in); err != nil { | 	if err := dec(in); err != nil { | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @ -880,6 +952,93 @@ func _Bundle_UpdateFinancialConfirmationStatus_Handler(srv interface{}, ctx cont | |||||||
| 	return interceptor(ctx, in, info, handler) | 	return interceptor(ctx, in, info, handler) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func _Bundle_CreateOrderAddRecord_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc_go.UnaryServerInterceptor) (interface{}, error) { | ||||||
|  | 	in := new(OrderAddRecord) | ||||||
|  | 	if err := dec(in); err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 	base := srv.(dubbo3.Dubbo3GrpcService) | ||||||
|  | 	args := []interface{}{} | ||||||
|  | 	args = append(args, in) | ||||||
|  | 	md, _ := metadata.FromIncomingContext(ctx) | ||||||
|  | 	invAttachment := make(map[string]interface{}, len(md)) | ||||||
|  | 	for k, v := range md { | ||||||
|  | 		invAttachment[k] = v | ||||||
|  | 	} | ||||||
|  | 	invo := invocation.NewRPCInvocation("CreateOrderAddRecord", args, invAttachment) | ||||||
|  | 	if interceptor == nil { | ||||||
|  | 		result := base.XXX_GetProxyImpl().Invoke(ctx, invo) | ||||||
|  | 		return result, result.Error() | ||||||
|  | 	} | ||||||
|  | 	info := &grpc_go.UnaryServerInfo{ | ||||||
|  | 		Server:     srv, | ||||||
|  | 		FullMethod: ctx.Value("XXX_TRIPLE_GO_INTERFACE_NAME").(string), | ||||||
|  | 	} | ||||||
|  | 	handler := func(ctx context.Context, req interface{}) (interface{}, error) { | ||||||
|  | 		result := base.XXX_GetProxyImpl().Invoke(ctx, invo) | ||||||
|  | 		return result, result.Error() | ||||||
|  | 	} | ||||||
|  | 	return interceptor(ctx, in, info, handler) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func _Bundle_PackagePriceAndTime_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc_go.UnaryServerInterceptor) (interface{}, error) { | ||||||
|  | 	in := new(OrderRecord) | ||||||
|  | 	if err := dec(in); err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 	base := srv.(dubbo3.Dubbo3GrpcService) | ||||||
|  | 	args := []interface{}{} | ||||||
|  | 	args = append(args, in) | ||||||
|  | 	md, _ := metadata.FromIncomingContext(ctx) | ||||||
|  | 	invAttachment := make(map[string]interface{}, len(md)) | ||||||
|  | 	for k, v := range md { | ||||||
|  | 		invAttachment[k] = v | ||||||
|  | 	} | ||||||
|  | 	invo := invocation.NewRPCInvocation("PackagePriceAndTime", args, invAttachment) | ||||||
|  | 	if interceptor == nil { | ||||||
|  | 		result := base.XXX_GetProxyImpl().Invoke(ctx, invo) | ||||||
|  | 		return result, result.Error() | ||||||
|  | 	} | ||||||
|  | 	info := &grpc_go.UnaryServerInfo{ | ||||||
|  | 		Server:     srv, | ||||||
|  | 		FullMethod: ctx.Value("XXX_TRIPLE_GO_INTERFACE_NAME").(string), | ||||||
|  | 	} | ||||||
|  | 	handler := func(ctx context.Context, req interface{}) (interface{}, error) { | ||||||
|  | 		result := base.XXX_GetProxyImpl().Invoke(ctx, invo) | ||||||
|  | 		return result, result.Error() | ||||||
|  | 	} | ||||||
|  | 	return interceptor(ctx, in, info, handler) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func _Bundle_OrderRecordsListV2_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc_go.UnaryServerInterceptor) (interface{}, error) { | ||||||
|  | 	in := new(OrderRecordsRequestV2) | ||||||
|  | 	if err := dec(in); err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 	base := srv.(dubbo3.Dubbo3GrpcService) | ||||||
|  | 	args := []interface{}{} | ||||||
|  | 	args = append(args, in) | ||||||
|  | 	md, _ := metadata.FromIncomingContext(ctx) | ||||||
|  | 	invAttachment := make(map[string]interface{}, len(md)) | ||||||
|  | 	for k, v := range md { | ||||||
|  | 		invAttachment[k] = v | ||||||
|  | 	} | ||||||
|  | 	invo := invocation.NewRPCInvocation("OrderRecordsListV2", args, invAttachment) | ||||||
|  | 	if interceptor == nil { | ||||||
|  | 		result := base.XXX_GetProxyImpl().Invoke(ctx, invo) | ||||||
|  | 		return result, result.Error() | ||||||
|  | 	} | ||||||
|  | 	info := &grpc_go.UnaryServerInfo{ | ||||||
|  | 		Server:     srv, | ||||||
|  | 		FullMethod: ctx.Value("XXX_TRIPLE_GO_INTERFACE_NAME").(string), | ||||||
|  | 	} | ||||||
|  | 	handler := func(ctx context.Context, req interface{}) (interface{}, error) { | ||||||
|  | 		result := base.XXX_GetProxyImpl().Invoke(ctx, invo) | ||||||
|  | 		return result, result.Error() | ||||||
|  | 	} | ||||||
|  | 	return interceptor(ctx, in, info, handler) | ||||||
|  | } | ||||||
|  | 
 | ||||||
| func _Bundle_CreateValueAddBundle_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc_go.UnaryServerInterceptor) (interface{}, error) { | func _Bundle_CreateValueAddBundle_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc_go.UnaryServerInterceptor) (interface{}, error) { | ||||||
| 	in := new(CreateValueAddBundleRequest) | 	in := new(CreateValueAddBundleRequest) | ||||||
| 	if err := dec(in); err != nil { | 	if err := dec(in); err != nil { | ||||||
| @ -1054,6 +1213,64 @@ func _Bundle_ValueAddServiceDetail_Handler(srv interface{}, ctx context.Context, | |||||||
| 	return interceptor(ctx, in, info, handler) | 	return interceptor(ctx, in, info, handler) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func _Bundle_ValueAddServiceLangByUuidAndLanguage_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc_go.UnaryServerInterceptor) (interface{}, error) { | ||||||
|  | 	in := new(ValueAddServiceDetailRequest) | ||||||
|  | 	if err := dec(in); err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 	base := srv.(dubbo3.Dubbo3GrpcService) | ||||||
|  | 	args := []interface{}{} | ||||||
|  | 	args = append(args, in) | ||||||
|  | 	md, _ := metadata.FromIncomingContext(ctx) | ||||||
|  | 	invAttachment := make(map[string]interface{}, len(md)) | ||||||
|  | 	for k, v := range md { | ||||||
|  | 		invAttachment[k] = v | ||||||
|  | 	} | ||||||
|  | 	invo := invocation.NewRPCInvocation("ValueAddServiceLangByUuidAndLanguage", args, invAttachment) | ||||||
|  | 	if interceptor == nil { | ||||||
|  | 		result := base.XXX_GetProxyImpl().Invoke(ctx, invo) | ||||||
|  | 		return result, result.Error() | ||||||
|  | 	} | ||||||
|  | 	info := &grpc_go.UnaryServerInfo{ | ||||||
|  | 		Server:     srv, | ||||||
|  | 		FullMethod: ctx.Value("XXX_TRIPLE_GO_INTERFACE_NAME").(string), | ||||||
|  | 	} | ||||||
|  | 	handler := func(ctx context.Context, req interface{}) (interface{}, error) { | ||||||
|  | 		result := base.XXX_GetProxyImpl().Invoke(ctx, invo) | ||||||
|  | 		return result, result.Error() | ||||||
|  | 	} | ||||||
|  | 	return interceptor(ctx, in, info, handler) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func _Bundle_CalculatePrice_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc_go.UnaryServerInterceptor) (interface{}, error) { | ||||||
|  | 	in := new(CalculatePriceRequest) | ||||||
|  | 	if err := dec(in); err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 	base := srv.(dubbo3.Dubbo3GrpcService) | ||||||
|  | 	args := []interface{}{} | ||||||
|  | 	args = append(args, in) | ||||||
|  | 	md, _ := metadata.FromIncomingContext(ctx) | ||||||
|  | 	invAttachment := make(map[string]interface{}, len(md)) | ||||||
|  | 	for k, v := range md { | ||||||
|  | 		invAttachment[k] = v | ||||||
|  | 	} | ||||||
|  | 	invo := invocation.NewRPCInvocation("CalculatePrice", args, invAttachment) | ||||||
|  | 	if interceptor == nil { | ||||||
|  | 		result := base.XXX_GetProxyImpl().Invoke(ctx, invo) | ||||||
|  | 		return result, result.Error() | ||||||
|  | 	} | ||||||
|  | 	info := &grpc_go.UnaryServerInfo{ | ||||||
|  | 		Server:     srv, | ||||||
|  | 		FullMethod: ctx.Value("XXX_TRIPLE_GO_INTERFACE_NAME").(string), | ||||||
|  | 	} | ||||||
|  | 	handler := func(ctx context.Context, req interface{}) (interface{}, error) { | ||||||
|  | 		result := base.XXX_GetProxyImpl().Invoke(ctx, invo) | ||||||
|  | 		return result, result.Error() | ||||||
|  | 	} | ||||||
|  | 	return interceptor(ctx, in, info, handler) | ||||||
|  | } | ||||||
|  | 
 | ||||||
| func _Bundle_BundleExtend_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc_go.UnaryServerInterceptor) (interface{}, error) { | func _Bundle_BundleExtend_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc_go.UnaryServerInterceptor) (interface{}, error) { | ||||||
| 	in := new(BundleExtendRequest) | 	in := new(BundleExtendRequest) | ||||||
| 	if err := dec(in); err != nil { | 	if err := dec(in); err != nil { | ||||||
| @ -1286,6 +1503,35 @@ func _Bundle_GetVedioWorkDetail_Handler(srv interface{}, ctx context.Context, de | |||||||
| 	return interceptor(ctx, in, info, handler) | 	return interceptor(ctx, in, info, handler) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func _Bundle_ToBeComfirmedWorks_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc_go.UnaryServerInterceptor) (interface{}, error) { | ||||||
|  | 	in := new(ToBeComfirmedWorksReq) | ||||||
|  | 	if err := dec(in); err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 	base := srv.(dubbo3.Dubbo3GrpcService) | ||||||
|  | 	args := []interface{}{} | ||||||
|  | 	args = append(args, in) | ||||||
|  | 	md, _ := metadata.FromIncomingContext(ctx) | ||||||
|  | 	invAttachment := make(map[string]interface{}, len(md)) | ||||||
|  | 	for k, v := range md { | ||||||
|  | 		invAttachment[k] = v | ||||||
|  | 	} | ||||||
|  | 	invo := invocation.NewRPCInvocation("ToBeComfirmedWorks", args, invAttachment) | ||||||
|  | 	if interceptor == nil { | ||||||
|  | 		result := base.XXX_GetProxyImpl().Invoke(ctx, invo) | ||||||
|  | 		return result, result.Error() | ||||||
|  | 	} | ||||||
|  | 	info := &grpc_go.UnaryServerInfo{ | ||||||
|  | 		Server:     srv, | ||||||
|  | 		FullMethod: ctx.Value("XXX_TRIPLE_GO_INTERFACE_NAME").(string), | ||||||
|  | 	} | ||||||
|  | 	handler := func(ctx context.Context, req interface{}) (interface{}, error) { | ||||||
|  | 		result := base.XXX_GetProxyImpl().Invoke(ctx, invo) | ||||||
|  | 		return result, result.Error() | ||||||
|  | 	} | ||||||
|  | 	return interceptor(ctx, in, info, handler) | ||||||
|  | } | ||||||
|  | 
 | ||||||
| // Bundle_ServiceDesc is the grpc_go.ServiceDesc for Bundle service.
 | // Bundle_ServiceDesc is the grpc_go.ServiceDesc for Bundle service.
 | ||||||
| // It's only intended for direct use with grpc_go.RegisterService,
 | // It's only intended for direct use with grpc_go.RegisterService,
 | ||||||
| // and not to be introspected or modified (even as a copy)
 | // and not to be introspected or modified (even as a copy)
 | ||||||
| @ -1353,6 +1599,18 @@ var Bundle_ServiceDesc = grpc_go.ServiceDesc{ | |||||||
| 			MethodName: "UpdateFinancialConfirmationStatus", | 			MethodName: "UpdateFinancialConfirmationStatus", | ||||||
| 			Handler:    _Bundle_UpdateFinancialConfirmationStatus_Handler, | 			Handler:    _Bundle_UpdateFinancialConfirmationStatus_Handler, | ||||||
| 		}, | 		}, | ||||||
|  | 		{ | ||||||
|  | 			MethodName: "CreateOrderAddRecord", | ||||||
|  | 			Handler:    _Bundle_CreateOrderAddRecord_Handler, | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			MethodName: "PackagePriceAndTime", | ||||||
|  | 			Handler:    _Bundle_PackagePriceAndTime_Handler, | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			MethodName: "OrderRecordsListV2", | ||||||
|  | 			Handler:    _Bundle_OrderRecordsListV2_Handler, | ||||||
|  | 		}, | ||||||
| 		{ | 		{ | ||||||
| 			MethodName: "CreateValueAddBundle", | 			MethodName: "CreateValueAddBundle", | ||||||
| 			Handler:    _Bundle_CreateValueAddBundle_Handler, | 			Handler:    _Bundle_CreateValueAddBundle_Handler, | ||||||
| @ -1377,6 +1635,14 @@ var Bundle_ServiceDesc = grpc_go.ServiceDesc{ | |||||||
| 			MethodName: "ValueAddServiceDetail", | 			MethodName: "ValueAddServiceDetail", | ||||||
| 			Handler:    _Bundle_ValueAddServiceDetail_Handler, | 			Handler:    _Bundle_ValueAddServiceDetail_Handler, | ||||||
| 		}, | 		}, | ||||||
|  | 		{ | ||||||
|  | 			MethodName: "ValueAddServiceLangByUuidAndLanguage", | ||||||
|  | 			Handler:    _Bundle_ValueAddServiceLangByUuidAndLanguage_Handler, | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			MethodName: "CalculatePrice", | ||||||
|  | 			Handler:    _Bundle_CalculatePrice_Handler, | ||||||
|  | 		}, | ||||||
| 		{ | 		{ | ||||||
| 			MethodName: "BundleExtend", | 			MethodName: "BundleExtend", | ||||||
| 			Handler:    _Bundle_BundleExtend_Handler, | 			Handler:    _Bundle_BundleExtend_Handler, | ||||||
| @ -1409,6 +1675,10 @@ var Bundle_ServiceDesc = grpc_go.ServiceDesc{ | |||||||
| 			MethodName: "GetVedioWorkDetail", | 			MethodName: "GetVedioWorkDetail", | ||||||
| 			Handler:    _Bundle_GetVedioWorkDetail_Handler, | 			Handler:    _Bundle_GetVedioWorkDetail_Handler, | ||||||
| 		}, | 		}, | ||||||
|  | 		{ | ||||||
|  | 			MethodName: "ToBeComfirmedWorks", | ||||||
|  | 			Handler:    _Bundle_ToBeComfirmedWorks_Handler, | ||||||
|  | 		}, | ||||||
| 	}, | 	}, | ||||||
| 	Streams:  []grpc_go.StreamDesc{}, | 	Streams:  []grpc_go.StreamDesc{}, | ||||||
| 	Metadata: "pb/bundle.proto", | 	Metadata: "pb/bundle.proto", | ||||||
|  | |||||||
| @ -13,7 +13,7 @@ var Provider = wire.NewSet(NewBundleDB) | |||||||
| func NewBundleDB() *gorm.DB { | func NewBundleDB() *gorm.DB { | ||||||
| 	connBundleDB := strings.Join([]string{bundleConfig.Data.BundleDB.User, ":", bundleConfig.Data.BundleDB.Password, | 	connBundleDB := strings.Join([]string{bundleConfig.Data.BundleDB.User, ":", bundleConfig.Data.BundleDB.Password, | ||||||
| 		"@tcp(", bundleConfig.Data.BundleDB.Host, ":", bundleConfig.Data.BundleDB.Port, ")/", | 		"@tcp(", bundleConfig.Data.BundleDB.Host, ":", bundleConfig.Data.BundleDB.Port, ")/", | ||||||
| 		bundleConfig.Data.BundleDB.DbName, "?charset=utf8mb4&parseTime=true"}, "") | 		bundleConfig.Data.BundleDB.DbName, "?charset=utf8mb4&parseTime=true&loc=Local"}, "") | ||||||
| 	DciDB := loadMysqlConn(connBundleDB) | 	DciDB := loadMysqlConn(connBundleDB) | ||||||
| 	return DciDB | 	return DciDB | ||||||
| } | } | ||||||
|  | |||||||
| @ -49,6 +49,8 @@ func loadMysqlConn(conn string) *gorm.DB { | |||||||
| 		&model.ValueAddService{}, | 		&model.ValueAddService{}, | ||||||
| 		&model.ValueAddServiceLang{}, | 		&model.ValueAddServiceLang{}, | ||||||
| 		&model.BundleToValueAddService{}, | 		&model.BundleToValueAddService{}, | ||||||
|  | 		&model.BundleProfileHistory{}, | ||||||
|  | 		&model.ValueAddServiceHistory{}, | ||||||
| 		&model.BundleOrderValueAdd{}, | 		&model.BundleOrderValueAdd{}, | ||||||
| 		&model.BundleExtensionRecords{}, | 		&model.BundleExtensionRecords{}, | ||||||
| 		&model.BundleBalance{}, | 		&model.BundleBalance{}, | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user