forked from sql-machine-learning/gomaxcompute
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtask.go
81 lines (68 loc) · 2.15 KB
/
task.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
package gomaxcompute
import (
"encoding/xml"
"github.com/twinj/uuid"
)
const anonymousSQLTask = "AnonymousSQLTask"
type odpsTask interface {
GetName() string
GetComment() string
xml.Marshaler
}
type cdata struct {
String string `xml:",cdata"`
}
type odpsSQLTask struct {
// default: AnonymousSQLTask
Name string
Query string
Comment string
// uuid settings
Config map[string]string
}
func (s odpsSQLTask) MarshalXML(e *xml.Encoder, start xml.StartElement) error {
e.EncodeToken(xml.StartElement{Name: xml.Name{Local: "SQL"}})
e.EncodeToken(xml.StartElement{Name: xml.Name{Local: "Name"}})
e.EncodeToken(xml.CharData(anonymousSQLTask))
e.EncodeToken(xml.EndElement{Name: xml.Name{Local: "Name"}})
if s.Comment != "" {
e.EncodeToken(xml.StartElement{Name: xml.Name{Local: "Comment"}})
e.EncodeToken(xml.CharData(s.Comment))
e.EncodeToken(xml.EndElement{Name: xml.Name{Local: "Comment"}})
}
e.EncodeToken(xml.StartElement{Name: xml.Name{Local: "Config"}})
for key, value := range s.Config {
e.EncodeToken(xml.StartElement{Name: xml.Name{Local: "Property"}})
e.EncodeToken(xml.StartElement{Name: xml.Name{Local: "Name"}})
e.EncodeToken(xml.CharData(key))
e.EncodeToken(xml.EndElement{Name: xml.Name{Local: "Name"}})
e.EncodeElement(cdata{value}, xml.StartElement{Name: xml.Name{Local: "Value"}})
e.EncodeToken(xml.EndElement{Name: xml.Name{Local: "Property"}})
}
e.EncodeToken(xml.EndElement{Name: xml.Name{Local: "Config"}})
e.EncodeElement(cdata{s.Query}, xml.StartElement{Name: xml.Name{Local: "Query"}})
e.EncodeToken(xml.EndElement{Name: xml.Name{Local: "SQL"}})
return e.Flush()
}
func (s *odpsSQLTask) GetName() string {
return s.Name
}
func (s *odpsSQLTask) GetComment() string {
return s.Comment
}
func newAnonymousSQLTask(query string, config map[string]string) odpsTask {
return newSQLTask(anonymousSQLTask, query, config)
}
func newSQLTask(name, query string, config map[string]string) odpsTask {
if config == nil {
config = map[string]string{
"uuid": uuid.NewV4().String(),
"settings": `{"odps.sql.udf.strict.mode": "true"}`,
}
}
return &odpsSQLTask{
Name: name,
Query: query,
Config: config,
}
}