forked from joefitzgerald/forecast
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathassignment.go
139 lines (125 loc) · 3.53 KB
/
assignment.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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
package forecast
import (
"encoding/csv"
"fmt"
"io"
"net/url"
"strconv"
"time"
)
type assignmentsContainer struct {
Assignments Assignments `json:"assignments"`
}
// Assignments is a list of assignments
type Assignments []Assignment
// Assignment is a Forecast assignment
type Assignment struct {
ID int `json:"id"`
StartDate string `json:"start_date"`
EndDate string `json:"end_date"`
Allocation int `json:"allocation"`
Notes string `json:"notes"`
UpdatedAt time.Time `json:"updated_at"`
UpdatedByID int `json:"updated_by_id"`
ProjectID int `json:"project_id"`
PersonID int `json:"person_id"`
PlaceholderID int `json:"placeholder_id"`
RepeatedAssignmentSetID int `json:"repeated_assignment_set_id"`
}
// Weekdays returns the number of working days between the start date and end date
// of the assignment
func (a *Assignment) Weekdays() int {
start, err := time.Parse("2006-01-02", a.StartDate)
if err != nil {
return 0
}
finish, err := time.Parse("2006-01-02", a.EndDate)
if err != nil {
return 0
}
next := start
result := 0
for {
if finish.Sub(next).Seconds() < 0 {
break
}
switch next.Weekday() {
case time.Monday:
result = result + 1
case time.Tuesday:
result = result + 1
case time.Wednesday:
result = result + 1
case time.Thursday:
result = result + 1
case time.Friday:
result = result + 1
}
next = next.Add(time.Hour * 24)
}
return result
}
// Assignments retrieves all assignments for the Forecast account
func (api *API) Assignments() (Assignments, error) {
var container assignmentsContainer
err := api.do("assignments", &container)
if err != nil {
return nil, err
}
return container.Assignments, nil
}
// AssignmentsWithParams returns all assignments for the Forecast account that are filtered using options
func (api *API) AssignmentsWithParams(options map[string]string) (Assignments, error) {
params := url.Values{}
for key, value := range options {
params.Add(key, value)
}
var container assignmentsContainer
err := api.do(fmt.Sprintf("assignments?%s", params.Encode()), &container)
if err != nil {
return nil, err
}
return container.Assignments, nil
}
// ToCSV writes the projects to the supplied writer in CSV
// format
func (assignments Assignments) ToCSV(w io.Writer) error {
writer := csv.NewWriter(w)
header := []string{
"id",
"start_date",
"end_date",
"allocation",
"notes",
"updated_at",
"updated_by_id",
"project_id",
"person_id",
"placeholder_id",
"repeated_assignment_set_id",
}
err := writer.Write(header)
if err != nil {
return err
}
for _, assignment := range assignments {
var record []string
record = append(record, strconv.Itoa(assignment.ID))
record = append(record, assignment.StartDate)
record = append(record, assignment.EndDate)
record = append(record, strconv.Itoa(assignment.Allocation))
record = append(record, assignment.Notes)
record = append(record, assignment.UpdatedAt.UTC().Format(time.RFC822Z))
record = append(record, strconv.Itoa(assignment.UpdatedByID))
record = append(record, strconv.Itoa(assignment.ProjectID))
record = append(record, strconv.Itoa(assignment.PersonID))
record = append(record, strconv.Itoa(assignment.PlaceholderID))
record = append(record, strconv.Itoa(assignment.RepeatedAssignmentSetID))
err := writer.Write(record)
if err != nil {
return err
}
}
writer.Flush()
return nil
}