|
4 | 4 | #import models |
5 | 5 | import datetime |
6 | 6 | import os |
| 7 | +import re |
| 8 | +import tarfile |
7 | 9 |
|
8 | 10 | from django.shortcuts import render_to_response, get_object_or_404 |
9 | 11 | from ietf.idtracker.models import IETFWG, IRTF, Area |
|
17 | 19 | from django.utils.decorators import decorator_from_middleware |
18 | 20 | from django.middleware.gzip import GZipMiddleware |
19 | 21 | from django.db.models import Count |
| 22 | +from ietf.idtracker.models import InternetDraft |
| 23 | +from ietf.idrfc.idrfc_wrapper import IdWrapper |
20 | 24 |
|
21 | 25 | from ietf.proceedings.models import Meeting, MeetingTime, WgMeetingSession, MeetingVenue, IESGHistory, Proceeding, Switches, WgProceedingsActivities |
22 | 26 |
|
@@ -148,3 +152,107 @@ def session_agenda(request, num, session, ext=None): |
148 | 152 | raise Http404("No %s agenda for the %s session of IETF %s is available" % (ext, session, num)) |
149 | 153 | else: |
150 | 154 | raise Http404("No agenda for the %s session of IETF %s is available" % (session, num)) |
| 155 | + |
| 156 | +def convert_to_pdf(doc_name): |
| 157 | + from tempfile import mkstemp |
| 158 | + from ietf.utils.pipe import pipe |
| 159 | + import subprocess |
| 160 | + inpath = os.path.join(settings.INTERNET_DRAFT_PATH, doc_name + ".txt") |
| 161 | + outpath = os.path.join(settings.INTERNET_DRAFT_PDF_PATH, doc_name + ".pdf") |
| 162 | + |
| 163 | + try: |
| 164 | + infile = open(inpath, "r") |
| 165 | + except Exception, e: |
| 166 | + return |
| 167 | + |
| 168 | + t,tempname = mkstemp() |
| 169 | + tempfile = open(tempname, "w") |
| 170 | + |
| 171 | + pageend = 0; |
| 172 | + newpage = 0; |
| 173 | + formfeed = 0; |
| 174 | + for line in infile: |
| 175 | + line = re.sub("\r","",line) |
| 176 | + line = re.sub("[ \t]+$","",line) |
| 177 | + if re.search("\[?[Pp]age [0-9ivx]+\]?[ \t]*$",line): |
| 178 | + pageend=1 |
| 179 | + tempfile.write(line) |
| 180 | + continue |
| 181 | + if re.search("^[ \t]*\f",line): |
| 182 | + formfeed=1 |
| 183 | + tempfile.write(line) |
| 184 | + continue |
| 185 | + if re.search("^ *INTERNET.DRAFT.+[0-9]+ *$",line) or re.search("^ *Internet.Draft.+[0-9]+ *$",line) or re.search("^draft-[-a-z0-9_.]+.*[0-9][0-9][0-9][0-9]$",line) or re.search("^RFC.+[0-9]+$",line): |
| 186 | + newpage=1 |
| 187 | + if re.search("^[ \t]*$",line) and pageend and not newpage: |
| 188 | + continue |
| 189 | + if pageend and newpage and not formfeed: |
| 190 | + tempfile.write("\f") |
| 191 | + pageend=0 |
| 192 | + formfeed=0 |
| 193 | + newpage=0 |
| 194 | + tempfile.write(line) |
| 195 | + |
| 196 | + infile.close() |
| 197 | + tempfile.close() |
| 198 | + t,psname = mkstemp() |
| 199 | + pipe("enscript --margins 76::76: -B -q -p "+psname + " " +tempname) |
| 200 | + os.unlink(tempname) |
| 201 | + pipe("ps2pdf "+psname+" "+outpath) |
| 202 | + os.unlink(psname) |
| 203 | + |
| 204 | + |
| 205 | +def session_draft_tarfile(request, num, session): |
| 206 | + from tempfile import mkstemp |
| 207 | + extensions = ["html", "htm", "txt", "HTML", "HTM", "TXT", ] |
| 208 | + found = False |
| 209 | + for wg in [session, session.upper(), session.lower()]: |
| 210 | + for e in extensions: |
| 211 | + path = settings.AGENDA_PATH_PATTERN % {"meeting":num, "wg":wg, "ext":e} |
| 212 | + if os.path.exists(path): |
| 213 | + file = open(path) |
| 214 | + agenda = file.read() |
| 215 | + file.close() |
| 216 | + found = True |
| 217 | + break |
| 218 | + if found: |
| 219 | + break |
| 220 | + else: |
| 221 | + raise Http404("No agenda for the %s session of IETF %s is available" % (session, num)) |
| 222 | + |
| 223 | + drafts = set(re.findall('(draft-[-a-z0-9]*)',agenda)) |
| 224 | + |
| 225 | + response = HttpResponse(mimetype='application/octet-stream') |
| 226 | + response['Content-Disposition'] = 'attachment; filename=%s-drafts.tgz'%(session) |
| 227 | + tarstream = tarfile.open('','w:gz',response) |
| 228 | + mfh, mfn = mkstemp() |
| 229 | + manifest = open(mfn, "w") |
| 230 | + |
| 231 | + for draft in drafts: |
| 232 | + if (re.search('-[0-9]{2}$',draft)): |
| 233 | + doc_name = draft |
| 234 | + else: |
| 235 | + id = get_object_or_404(InternetDraft, filename=draft) |
| 236 | + doc = IdWrapper(id) |
| 237 | + doc_name = draft + "-" + id.revision |
| 238 | + |
| 239 | + txt_path = os.path.join(settings.INTERNET_DRAFT_PATH, doc_name + ".txt") |
| 240 | + pdf_path = os.path.join(settings.INTERNET_DRAFT_PDF_PATH, doc_name + ".pdf") |
| 241 | + |
| 242 | + if (not os.path.exists(pdf_path)): |
| 243 | + convert_to_pdf(doc_name) |
| 244 | + |
| 245 | + if os.path.exists(pdf_path): |
| 246 | + try: |
| 247 | + tarstream.add(pdf_path, str(doc_name + ".pdf")) |
| 248 | + manifest.write("Included: "+pdf_path+"\n") |
| 249 | + except Exception, e: |
| 250 | + manifest.write(("Failed (%s): "%e)+pdf_path+"\n") |
| 251 | + else: |
| 252 | + manifest.write("Not found: "+pdf_path+"\n") |
| 253 | + |
| 254 | + manifest.close() |
| 255 | + tarstream.add(mfn, "manifest.txt") |
| 256 | + tarstream.close() |
| 257 | + os.unlink(mfn) |
| 258 | + return response |
0 commit comments