|
@@ -3,13 +3,13 @@ package contrab |
|
@@ -3,13 +3,13 @@ package contrab |
|
3
|
import (
|
3
|
import (
|
|
4
|
"fmt"
|
4
|
"fmt"
|
|
5
|
"github.com/aliyun/alibaba-cloud-sdk-go/services/vod"
|
5
|
"github.com/aliyun/alibaba-cloud-sdk-go/services/vod"
|
|
|
|
6
|
+ "github.com/aliyun/aliyun-oss-go-sdk/oss"
|
|
6
|
"github.com/astaxie/beego/orm"
|
7
|
"github.com/astaxie/beego/orm"
|
|
7
|
"gitlab.fjmaimaimai.com/mmm-go/gocomm/pkg/log"
|
8
|
"gitlab.fjmaimaimai.com/mmm-go/gocomm/pkg/log"
|
|
8
|
"opp/internal/aliyun"
|
9
|
"opp/internal/aliyun"
|
|
9
|
"opp/internal/utils"
|
10
|
"opp/internal/utils"
|
|
10
|
"opp/models"
|
11
|
"opp/models"
|
|
11
|
"opp/protocol"
|
12
|
"opp/protocol"
|
|
12
|
- "path/filepath"
|
|
|
|
13
|
)
|
13
|
)
|
|
14
|
|
14
|
|
|
15
|
const LoopSize = 1
|
15
|
const LoopSize = 1
|
|
@@ -51,8 +51,9 @@ func MigrateChanceDataToAliYun() { |
|
@@ -51,8 +51,9 @@ func MigrateChanceDataToAliYun() { |
|
51
|
//上传图片
|
51
|
//上传图片
|
|
52
|
data.Images = utils.JsonMarsh(uploadImages(data, data.Images))
|
52
|
data.Images = utils.JsonMarsh(uploadImages(data, data.Images))
|
|
53
|
//上传视频
|
53
|
//上传视频
|
|
|
|
54
|
+ data.Videos = utils.JsonMarsh(uploadVideos(data, data.Videos))
|
|
54
|
//上传音频
|
55
|
//上传音频
|
|
55
|
-
|
56
|
+ data.Speechs = utils.JsonMarsh(uploadVoice(data, data.Speechs))
|
|
56
|
//更新数据
|
57
|
//更新数据
|
|
57
|
o.Update(data)
|
58
|
o.Update(data)
|
|
58
|
}
|
59
|
}
|
|
@@ -61,6 +62,69 @@ func MigrateChanceDataToAliYun() { |
|
@@ -61,6 +62,69 @@ func MigrateChanceDataToAliYun() { |
|
61
|
}
|
62
|
}
|
|
62
|
}
|
63
|
}
|
|
63
|
|
64
|
|
|
|
|
65
|
+func uploadVideos(d *models.ChanceData, video string) (rsp []protocol.Video) {
|
|
|
|
66
|
+ utils.JsonUnmarshal(video, &rsp)
|
|
|
|
67
|
+ if len(rsp) == 0 {
|
|
|
|
68
|
+ rsp = make([]protocol.Video, 0)
|
|
|
|
69
|
+ return
|
|
|
|
70
|
+ }
|
|
|
|
71
|
+ for i := range rsp {
|
|
|
|
72
|
+ p := rsp[i]
|
|
|
|
73
|
+ if len(p.VideoId) > 0 {
|
|
|
|
74
|
+ printInfo(d, p.Path, Uploaded)
|
|
|
|
75
|
+ continue
|
|
|
|
76
|
+ }
|
|
|
|
77
|
+ var (
|
|
|
|
78
|
+ err error
|
|
|
|
79
|
+ auth *aliyun.CreateUploadVideoResponse
|
|
|
|
80
|
+ authImage *aliyun.CreateUploadImageResponse
|
|
|
|
81
|
+ vodc *vod.Client
|
|
|
|
82
|
+ )
|
|
|
|
83
|
+ vodc, err = aliyun.DefaultVodClient()
|
|
|
|
84
|
+ if err != nil {
|
|
|
|
85
|
+ goto ERR
|
|
|
|
86
|
+ }
|
|
|
|
87
|
+ //上传视频
|
|
|
|
88
|
+ auth, err = aliyun.CreateUploadVideo(vodc, &aliyun.CreateUploadVideoRequest{FileName: p.Path})
|
|
|
|
89
|
+ if err != nil {
|
|
|
|
90
|
+ goto ERR
|
|
|
|
91
|
+ }
|
|
|
|
92
|
+ err = upload(p.Path, auth.UploadAddress, auth.UploadAuth)
|
|
|
|
93
|
+ if err != nil {
|
|
|
|
94
|
+ goto ERR
|
|
|
|
95
|
+ }
|
|
|
|
96
|
+
|
|
|
|
97
|
+ //备份路径
|
|
|
|
98
|
+ rsp[i].PathBak = p.Path
|
|
|
|
99
|
+ rsp[i].VideoId = auth.VideoId
|
|
|
|
100
|
+ rsp[i].Path = auth.FileURL
|
|
|
|
101
|
+ printInfo(d, fmt.Sprintf("%v -> %v", p.Path, auth.FileURL), UploadSuccess)
|
|
|
|
102
|
+
|
|
|
|
103
|
+ //上传封面
|
|
|
|
104
|
+ if len(p.Cover.Path) > 0 {
|
|
|
|
105
|
+ authImage, err = aliyun.CreateUploadImage(vodc, &aliyun.CreateUploadImageRequest{FileName: p.Cover.Path})
|
|
|
|
106
|
+ if err != nil {
|
|
|
|
107
|
+ goto ERR
|
|
|
|
108
|
+ }
|
|
|
|
109
|
+ err = upload(p.Cover.Path, authImage.UploadAddress, authImage.UploadAuth)
|
|
|
|
110
|
+ if err != nil {
|
|
|
|
111
|
+ goto ERR
|
|
|
|
112
|
+ }
|
|
|
|
113
|
+ printInfo(d, fmt.Sprintf("cover %v -> %v", p.Cover.Path, authImage.ImageURL), UploadSuccess)
|
|
|
|
114
|
+ rsp[i].Cover.Path = authImage.ImageURL
|
|
|
|
115
|
+ rsp[i].Cover.ImageId = authImage.ImageId
|
|
|
|
116
|
+ }
|
|
|
|
117
|
+ continue
|
|
|
|
118
|
+ ERR:
|
|
|
|
119
|
+ {
|
|
|
|
120
|
+ log.Error("ali vod error:", err)
|
|
|
|
121
|
+ printInfo(d, p.Path, UploadFail)
|
|
|
|
122
|
+ continue
|
|
|
|
123
|
+ }
|
|
|
|
124
|
+ }
|
|
|
|
125
|
+ return
|
|
|
|
126
|
+}
|
|
|
|
127
|
+
|
|
64
|
//上传图片
|
128
|
//上传图片
|
|
65
|
func uploadImages(d *models.ChanceData, img string) (rsp []protocol.Picture) {
|
129
|
func uploadImages(d *models.ChanceData, img string) (rsp []protocol.Picture) {
|
|
66
|
utils.JsonUnmarshal(img, &rsp)
|
130
|
utils.JsonUnmarshal(img, &rsp)
|
|
@@ -74,40 +138,92 @@ func uploadImages(d *models.ChanceData, img string) (rsp []protocol.Picture) { |
|
@@ -74,40 +138,92 @@ func uploadImages(d *models.ChanceData, img string) (rsp []protocol.Picture) { |
|
74
|
printInfo(d, p.Path, Uploaded)
|
138
|
printInfo(d, p.Path, Uploaded)
|
|
75
|
continue
|
139
|
continue
|
|
76
|
}
|
140
|
}
|
|
77
|
-
|
|
|
|
78
|
var (
|
141
|
var (
|
|
79
|
err error
|
142
|
err error
|
|
|
|
143
|
+ auth *aliyun.CreateUploadImageResponse
|
|
80
|
vodc *vod.Client
|
144
|
vodc *vod.Client
|
|
81
|
- imageRsp *aliyun.CreateUploadImageResponse
|
|
|
|
82
|
- client *aliyun.OSSClient
|
|
|
|
83
|
)
|
145
|
)
|
|
84
|
- vodc, _ = aliyun.DefaultVodClient()
|
|
|
|
85
|
- list := filepath.SplitList(p.Path)
|
|
|
|
86
|
- if len(list) == 0 {
|
|
|
|
87
|
- err = fmt.Errorf("路径无效:%v", p.Path)
|
146
|
+ vodc, err = aliyun.DefaultVodClient()
|
|
|
|
147
|
+ if err != nil {
|
|
|
|
148
|
+ goto ERR
|
|
|
|
149
|
+ }
|
|
|
|
150
|
+ auth, err = aliyun.CreateUploadImage(vodc, &aliyun.CreateUploadImageRequest{FileName: p.Path})
|
|
|
|
151
|
+ if err != nil {
|
|
88
|
goto ERR
|
152
|
goto ERR
|
|
89
|
}
|
153
|
}
|
|
|
|
154
|
+ err = upload(p.Path, auth.UploadAddress, auth.UploadAuth)
|
|
90
|
if err != nil {
|
155
|
if err != nil {
|
|
91
|
goto ERR
|
156
|
goto ERR
|
|
92
|
}
|
157
|
}
|
|
93
|
- imageRsp, err = aliyun.CreateUploadImage(vodc, &aliyun.CreateUploadImageRequest{FileName: list[len(list)-1]})
|
158
|
+
|
|
|
|
159
|
+ //备份路径
|
|
|
|
160
|
+ rsp[i].PathBak = p.Path
|
|
|
|
161
|
+ rsp[i].ImageId = auth.ImageId
|
|
|
|
162
|
+ rsp[i].Path = auth.ImageURL
|
|
|
|
163
|
+ printInfo(d, fmt.Sprintf("%v -> %v", p.Path, auth.ImageURL), UploadSuccess)
|
|
|
|
164
|
+ continue
|
|
|
|
165
|
+ ERR:
|
|
|
|
166
|
+ {
|
|
|
|
167
|
+ log.Error("ali vod error:", err)
|
|
|
|
168
|
+ printInfo(d, p.Path, UploadFail)
|
|
|
|
169
|
+ continue
|
|
|
|
170
|
+ }
|
|
|
|
171
|
+ }
|
|
|
|
172
|
+ return
|
|
|
|
173
|
+}
|
|
|
|
174
|
+
|
|
|
|
175
|
+//上传文件
|
|
|
|
176
|
+func upload(path string, upAddress, upAuth string, options ...oss.Option) (err error) {
|
|
|
|
177
|
+ var (
|
|
|
|
178
|
+ client *aliyun.OSSClient
|
|
|
|
179
|
+ )
|
|
|
|
180
|
+ client, err = aliyun.NewStsOSSClient(upAddress, upAuth)
|
|
|
|
181
|
+ if err != nil {
|
|
|
|
182
|
+ return
|
|
|
|
183
|
+ }
|
|
|
|
184
|
+ err = client.PutObjectByUrlDefault(path, options...)
|
|
|
|
185
|
+ if err != nil {
|
|
|
|
186
|
+ return
|
|
|
|
187
|
+ }
|
|
|
|
188
|
+ return
|
|
|
|
189
|
+}
|
|
|
|
190
|
+
|
|
|
|
191
|
+//上班媒体数据
|
|
|
|
192
|
+func uploadVoice(d *models.ChanceData, data string) (rsp []protocol.Speech) {
|
|
|
|
193
|
+ utils.JsonUnmarshal(data, &rsp)
|
|
|
|
194
|
+ if len(rsp) == 0 {
|
|
|
|
195
|
+ rsp = make([]protocol.Speech, 0)
|
|
|
|
196
|
+ return
|
|
|
|
197
|
+ }
|
|
|
|
198
|
+ for i := range rsp {
|
|
|
|
199
|
+ p := rsp[i]
|
|
|
|
200
|
+ if len(p.VideoId) > 0 {
|
|
|
|
201
|
+ printInfo(d, p.Path, Uploaded)
|
|
|
|
202
|
+ continue
|
|
|
|
203
|
+ }
|
|
|
|
204
|
+ var (
|
|
|
|
205
|
+ err error
|
|
|
|
206
|
+ auth *aliyun.CreateUploadVideoResponse
|
|
|
|
207
|
+ vodc *vod.Client
|
|
|
|
208
|
+ )
|
|
|
|
209
|
+ vodc, err = aliyun.DefaultVodClient()
|
|
94
|
if err != nil {
|
210
|
if err != nil {
|
|
95
|
goto ERR
|
211
|
goto ERR
|
|
96
|
}
|
212
|
}
|
|
97
|
- client, err = aliyun.NewStsOSSClient(imageRsp.UploadAddress, imageRsp.UploadAuth)
|
213
|
+ auth, err = aliyun.CreateUploadVideo(vodc, &aliyun.CreateUploadVideoRequest{FileName: p.Path})
|
|
98
|
if err != nil {
|
214
|
if err != nil {
|
|
99
|
goto ERR
|
215
|
goto ERR
|
|
100
|
}
|
216
|
}
|
|
101
|
- err = client.PutObjectByUrlDefault(p.Path)
|
217
|
+ err = upload(p.Path, auth.UploadAddress, auth.UploadAuth, oss.ContentType("audio/mpeg"))
|
|
102
|
if err != nil {
|
218
|
if err != nil {
|
|
103
|
goto ERR
|
219
|
goto ERR
|
|
104
|
}
|
220
|
}
|
|
105
|
|
221
|
|
|
106
|
//备份路径
|
222
|
//备份路径
|
|
107
|
rsp[i].PathBak = p.Path
|
223
|
rsp[i].PathBak = p.Path
|
|
108
|
- rsp[i].ImageId = imageRsp.ImageId
|
|
|
|
109
|
- rsp[i].Path = imageRsp.ImageURL
|
|
|
|
110
|
- printInfo(d, p.Path, UploadSuccess)
|
224
|
+ rsp[i].VideoId = auth.VideoId
|
|
|
|
225
|
+ rsp[i].Path = auth.FileURL
|
|
|
|
226
|
+ printInfo(d, fmt.Sprintf("%v -> %v", p.Path, auth.FileURL), UploadSuccess)
|
|
111
|
continue
|
227
|
continue
|
|
112
|
ERR:
|
228
|
ERR:
|
|
113
|
{
|
229
|
{
|
|
@@ -119,12 +235,6 @@ func uploadImages(d *models.ChanceData, img string) (rsp []protocol.Picture) { |
|
@@ -119,12 +235,6 @@ func uploadImages(d *models.ChanceData, img string) (rsp []protocol.Picture) { |
|
119
|
return
|
235
|
return
|
|
120
|
}
|
236
|
}
|
|
121
|
|
237
|
|
|
122
|
-//上班媒体数据
|
|
|
|
123
|
-func uploadVoice(d *models.ChanceData, url string) (rp []protocol.Speech) {
|
|
|
|
124
|
- //
|
|
|
|
125
|
- return nil
|
|
|
|
126
|
-}
|
|
|
|
127
|
-
|
|
|
|
128
|
type ChanceDataExtend struct {
|
238
|
type ChanceDataExtend struct {
|
|
129
|
Id int64 `json:"id"`
|
239
|
Id int64 `json:"id"`
|
|
130
|
ChanceId int64 `json:"chance_id"`
|
240
|
ChanceId int64 `json:"chance_id"`
|