-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathrubygems.go
88 lines (69 loc) · 1.95 KB
/
rubygems.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
package ingestors
import (
"io"
"time"
log "github.com/sirupsen/logrus"
"github.com/buger/jsonparser"
"github.com/librariesio/depper/data"
)
const rubyGemsSchedule = "*/5 * * * *"
const rubyGemsJustUpdatedURL = "https://rubygems.org/api/v1/activity/just_updated.json"
const rubyGemsLatestURL = "https://rubygems.org/api/v1/activity/latest.json"
type RubyGems struct {
LatestRun time.Time
}
func NewRubyGems() *RubyGems {
return &RubyGems{}
}
func (ingestor *RubyGems) Name() string {
return "rubygems"
}
func (ingestor *RubyGems) Schedule() string {
return rubyGemsSchedule
}
func (ingestor *RubyGems) Ingest() []data.PackageVersion {
results := append(
ingestor.ingestURL(rubyGemsJustUpdatedURL),
ingestor.ingestURL(rubyGemsLatestURL)...,
)
ingestor.LatestRun = time.Now()
return results
}
func (ingestor *RubyGems) ingestURL(url string) []data.PackageVersion {
var results []data.PackageVersion
response, err := depperGetUrl(url)
if err != nil {
log.WithFields(log.Fields{"ingestor": ingestor.Name(), "error": err}).Error()
return results
}
defer response.Body.Close()
body, _ := io.ReadAll(response.Body)
_, _ = jsonparser.ArrayEach(body, func(value []byte, dataType jsonparser.ValueType, offset int, err error) {
if err != nil {
log.WithFields(
log.Fields{
"ingestor": ingestor.Name(),
"error": err,
"value": string(value),
"dataType": dataType.String(),
"offset": offset,
},
).Error()
return
}
name, _ := jsonparser.GetString(value, "name")
version, _ := jsonparser.GetString(value, "version")
createdAt, _ := jsonparser.GetString(value, "version_created_at")
createdAtTime, _ := time.Parse(time.RFC3339, createdAt)
discoveryLag := time.Since(createdAtTime)
results = append(results,
data.PackageVersion{
Platform: "rubygems",
Name: name,
Version: version,
CreatedAt: createdAtTime,
DiscoveryLag: discoveryLag,
})
})
return results
}