fetch-issues.py 6.16 KB
Newer Older
Anders Franz Terkelsen's avatar
Anders Franz Terkelsen committed
1
2
3
4
5
6
7
8
9
#!/usr/bin/env python3


from collections import namedtuple
import os.path
import csv
import io
import json
import requests
10
import time
Anders Franz Terkelsen's avatar
Anders Franz Terkelsen committed
11
12
13
14
15
16
17
18
19
20
21
22
23
24

USER_HOME = os.path.expanduser("~")
SECRETS_FILE = os.path.join(USER_HOME, "fetch-issues.json")


def get_secret(key):
    with open(SECRETS_FILE) as f:
        return json.load(f)[key]


Issue = namedtuple("Issue", ["created", "title", "url"])


def github_parser(json_string, ticket_base_url):
25
    return (
Anders Franz Terkelsen's avatar
Anders Franz Terkelsen committed
26
27
28
29
30
31
        Issue(
            created=issue["created_at"].split("T")[0],
            title=issue["title"],
            url="/".join([ticket_base_url, str(issue["number"])]),
        )
        for issue in json.loads(json_string)
32
    )
Anders Franz Terkelsen's avatar
Anders Franz Terkelsen committed
33
34
35


def redmine_parser(json_string, ticket_base_url):
36
    return (
Anders Franz Terkelsen's avatar
Anders Franz Terkelsen committed
37
38
39
40
41
42
        Issue(
            created=issue["start_date"],
            title=issue["subject"],
            url="/".join([ticket_base_url, str(issue["id"])]),
        )
        for issue in json.loads(json_string)["issues"]
43
    )
Anders Franz Terkelsen's avatar
Anders Franz Terkelsen committed
44
45
46


def trac_parser(csv_string, ticket_base_url):
47
    return (
Anders Franz Terkelsen's avatar
Anders Franz Terkelsen committed
48
49
50
51
52
53
        Issue(
            created=issue["time"].split(" ")[0],
            title=issue["summary"],
            url="/".join([ticket_base_url, issue["\ufeffid"]]),
        )
        for issue in csv.DictReader(io.StringIO(csv_string))
54
    )
Anders Franz Terkelsen's avatar
Anders Franz Terkelsen committed
55
56
57


def mantis_parser(csv_string, ticket_base_url):
58
    return (
Anders Franz Terkelsen's avatar
Anders Franz Terkelsen committed
59
60
61
62
63
64
        Issue(
            created=issue["Date Submitted"],
            title=issue["Summary"],
            url="{}{}".format(ticket_base_url, issue["Id"]),
        )
        for issue in csv.DictReader(io.StringIO(csv_string))
65
    )
Anders Franz Terkelsen's avatar
Anders Franz Terkelsen committed
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


IssueTracker = namedtuple(
    "IssueTracker",
    ["parser", "project", "url", "headers", "ticket_base_url"],
)


issue_trackers = [
    IssueTracker(
        parser=trac_parser,
        project="OpenModelica",
        url="https://trac.openmodelica.org/OpenModelica/query?status=accepted&status=assigned&status=new&status=reopened&summary=~into-cps&or&status=accepted&status=assigned&status=new&status=reopened&description=~into-cps&format=csv&col=id&col=summary&col=time&order=priority",  # noqa
        headers=None,
        ticket_base_url="https://trac.openmodelica.org/OpenModelica/ticket",
    ),
    IssueTracker(
        parser=redmine_parser,
        project="Modelio",
        url="http://forge.modelio.org/projects/intocps/issues.json",
        headers=None,
        ticket_base_url="http://forge.modelio.org/issues",
    ),
    IssueTracker(
        parser=github_parser,
        project="INTO-CPS Application",
        url="https://api.github.com/repos/into-cps/INTO-CPS_Application/issues?state=open",  # noqa
        headers=None,
        ticket_base_url="https://github.com/into-cps/INTO-CPS_Application/issues",  # noqa
    ),
    IssueTracker(
        parser=github_parser,
        project="Overture",
        url="https://api.github.com/repos/overturetool/overture/issues?state=open&labels=into-cps",  # noqa
        headers=None,
        ticket_base_url="https://github.com/overturetool/overture/issues",
    ),
    IssueTracker(
        parser=github_parser,
        project="Overture-FMU",
        url="https://api.github.com/repos/overturetool/overture-fmu/issues?state=open",  # noqa
        headers=None,
        ticket_base_url="https://github.com/overturetool/overture-fmu/issues",  # noqa
    ),
    IssueTracker(
        parser=github_parser,
        project="20-sim FMU Export",
        url="https://api.github.com/repos/controllab/fmi-export-20sim/issues?state=open",  # noqa
        headers=None,
        ticket_base_url="https://github.com/controllab/fmi-export-20sim/issues",  # noqa
    ),

    IssueTracker(
        parser=github_parser,
        project="INTO-CPS DSE",
        url="https://api.github.com/repos/CarlGamble/INTO-CPS-DSE/issues?state=open",  # noqa
        headers=None,
        ticket_base_url="https://github.com/CarlGamble/INTO-CPS-DSE/issues",
    ),
125
126
127
128
129
130
131
    IssueTracker(
        parser=github_parser,
        project="INTO-CPS UI",
        url="https://api.github.com/repos/into-cps/intocps-ui/issues?state=open",  # noqa
        headers=None,
        ticket_base_url="https://github.com/into-cps/intocps-ui/issues",
    ),
132
133
134
135
136
137
138
#    IssueTracker(
#        parser=mantis_parser,
#        project="RT-Tester",
#        url="https://software.verified.de/mantis/csv_export.php",
#        headers=get_secret("rtt_headers"),
#        ticket_base_url="https://software.verified.de/mantis/view.php?id=",
#    ),
Anders Franz Terkelsen's avatar
Anders Franz Terkelsen committed
139
140
141
142
]


def main():
143
    
144
    timestr = time.strftime("%Y-W%W")#"%Y-%m-%d")
145
    print (timestr)
146
147
148
149
150
151
152
153
154
155
    week = time.strftime("%W")
    year = time.strftime("%Y")
    name = '{}-W{}'.format(year,week)
    fileName = name+'.md'
    
    fc = open('fetch-out','w')
    fc.write(fileName)
    fc.close()
    
    f = open(fileName,'w')
156
157
    f.write('---\n')
    f.write('layout: default\n')
158
    f.write('title: Week {} {}, Weekly Issues Digest\n'.format(week,year))
159
160
    f.write('---\n\n')

161
    f.write('# Week {} {}, Weekly Issues Digest for INTO-CPS\n\n'.format(week,year))
162
163
164

    f.write('## Currently Open Issues\n\n')
    
Anders Franz Terkelsen's avatar
Anders Franz Terkelsen committed
165
    for tracker in sorted(issue_trackers, key=lambda tracker: tracker.project):
166
        print("### {}".format(tracker.project))
Anders Franz Terkelsen's avatar
Anders Franz Terkelsen committed
167
168
169
170
        for issue in tracker.parser(
            requests.get(tracker.url, headers=tracker.headers).text,
            tracker.ticket_base_url,
        ):
171
            line = "* [{} - ({})]({})".format(
Anders Franz Terkelsen's avatar
Anders Franz Terkelsen committed
172
                    issue.title,
173
                    issue.created,
Anders Franz Terkelsen's avatar
Anders Franz Terkelsen committed
174
175
                    issue.url,
                )
176
177
            f.write(line+'\n')
            print(line)
178
179
180
    f.write("\n\n#History of Weekly Digests\n\n")
    f.write("Below you will find a list of weekly digests giving a historical overview of all known issues across all the tools that are part of INTO-CPS.\n")
    
Anders Franz Terkelsen's avatar
Anders Franz Terkelsen committed
181

182
    with open('issue-history.txt','rw') as fc:
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
        my_lines = fc.readlines()
        fc.close()

        for s in my_lines:
            f.write("* [{}]({}.html)".format(s,s))

        
        if any(name in s for s in my_lines):
            print("already there\n")
        else:
            lines = [name]+ my_lines
       
            with open('issue-history.txt','w') as fh:
                fh.writelines(["%s\n" % item  for item in lines])
                fh.close()
        
    f.close()
                
Anders Franz Terkelsen's avatar
Anders Franz Terkelsen committed
201
202
if __name__ == "__main__":
    main()