]> git.pld-linux.org Git - projects/pld-ftp-admin.git/blame - modules/ftptree.py
- minor internal reorganization finished
[projects/pld-ftp-admin.git] / modules / ftptree.py
CommitLineData
098f4a50
MM
1# vi: encoding=utf-8 ts=8 sts=4 sw=4 et
2
0a108b7f 3import os, config, string, urllib, re
81e9387d 4from common import fileexists, noarchcachedir
151d31cc 5from baseftptree import BasePkg, BaseFtpTree
098f4a50
MM
6errnum=0
7
0a108b7f 8SomeError="Oh no"
85f3481a 9quietmode=False
0a108b7f 10
098f4a50
MM
11def bailoutonerror():
12 if not errnum == 0:
13 print "%d error(s) encountered... aborting" % errnum
0a108b7f 14 raise SomeError
098f4a50 15
d9b3388c 16def pinfo(msg):
0767aa5e 17 print 'INFO: ' + msg
d9b3388c 18
098f4a50
MM
19def perror(msg):
20 global errnum
21 errnum=errnum+1
492b6398 22 print 'ERR: ' + msg
098f4a50 23
796b7867 24def pwarning(msg):
492b6398 25 print 'WARN: ' + msg
796b7867 26
098f4a50 27def rm(file):
18c8e935
MM
28 os.remove(file)
29 #print 'rm: '+file
098f4a50
MM
30
31def mv(src, dst):
18c8e935
MM
32 os.rename(src, dst+'/'+src.split('/')[-1])
33 #print "mv: %s %s" % (src, dst+'/'+src.split('/')[-1])
098f4a50 34
151d31cc 35class Pkg(BasePkg):
85f3481a
MM
36 def __init__(self, nvr, tree):
37 BasePkg.__init__(self, nvr, tree)
38 self.name=string.join(nvr.split('-')[:-2], '-')
39 self.version=nvr.split('-')[-2]
40 self.release=nvr.split('-')[-1]
14085d11 41 self.marked4removal=False
d9b3388c 42 self.marked4moving=False
67b5bf38
MM
43 self.errors=[]
44 self.warnings=[]
098f4a50 45
14085d11
MM
46 def mark4moving(self):
47 if not self.marked4moving:
48 self.tree.marked4moving.append(self)
49 self.marked4moving=True
50
51 def mark4removal(self):
52 if not self.marked4removal:
53 self.tree.marked4removal.append(self)
54 self.marked4removal=True
098f4a50 55
85f3481a
MM
56 def error(self, msg):
57 self.errors.append(msg)
58 if not quietmode:
59 perror('%s %s' % (self.nvr, msg))
60
61 def warning(self, msg):
62 self.warnings.append(msg)
63 if not quietmode:
64 pwarning('%s %s' % (self.nvr, msg))
65
bb2cb325
MM
66 def load(self, content=None):
67 BasePkg.load(self, content)
098f4a50 68 if self.info.has_key('move'):
14085d11 69 self.mark4moving()
098f4a50
MM
70
71 def writeinfo(self):
85f3481a 72 f=open(self.tree.basedir+'/SRPMS/.metadata/'+self.nvr+'.src.rpm.info', 'w')
098f4a50
MM
73 for bid in self.build.keys():
74 f.write("info:build:%s:requester:%s\ninfo:build:%s:requester_email:%s\n" % (bid, self.build[bid].requester, bid, self.build[bid].requester_email))
75 for key in self.info.keys():
76 f.write("info:%s:%s\n" % (key, string.join(self.info[key], ':')))
151d31cc
MM
77 for arch in self.files.keys():
78 for rpm in self.files[arch]:
098f4a50
MM
79 f.write("file:%s:%s\n" % (arch, rpm))
80
81 def remove(self):
151d31cc
MM
82 for arch in self.files.keys():
83 for rpm in self.files[arch]:
098f4a50 84 rm(self.tree.basedir+'/'+arch+'/RPMS/'+rpm)
81e9387d
MM
85 if arch=='noarch':
86 if fileexists(noarchcachedir+rpm+'.filelist'):
87 rm(noarchcachedir+rpm+'.filelist')
88 if fileexists(noarchcachedir+rpm+'.reqlist'):
89 rm(noarchcachedir+rpm+'.reqlist')
85f3481a 90 rm(self.tree.basedir+'/SRPMS/.metadata/'+self.nvr+'.src.rpm.info')
098f4a50
MM
91
92 def move(self, dsttree):
85f3481a 93 if dsttree.has_key(self.nvr):
098f4a50 94 movedany=False
151d31cc 95 for arch in self.files.keys():
85f3481a
MM
96 if arch in dsttree[self.nvr].files.keys():
97 pinfo("Arch %s for %s is already present in dest tree; removing from srctree" % (arch, self.nvr))
151d31cc 98 for rpm in self.files[arch]:
098f4a50
MM
99 rm(self.tree.basedir+'/'+arch+'/RPMS/'+rpm)
100 else:
101 movedany=True
85f3481a 102 dsttree[self.nvr].files[arch]=self.files[arch]
151d31cc 103 for rpm in self.files[arch]:
098f4a50
MM
104 mv(self.tree.basedir+'/'+arch+'/RPMS/'+rpm, dsttree.basedir+'/'+arch+'/RPMS/')
105 if movedany:
106 for bid in self.build.keys():
85f3481a
MM
107 dsttree[self.nvr].build[bid]=self.build[bid]
108 dsttree[self.nvr].writeinfo()
109 rm(self.tree.basedir+'/SRPMS/.metadata/'+self.nvr+'.src.rpm.info')
098f4a50 110 else:
151d31cc
MM
111 for arch in self.files.keys():
112 for rpm in self.files[arch]:
098f4a50 113 mv(self.tree.basedir+'/'+arch+'/RPMS/'+rpm, dsttree.basedir+'/'+arch+'/RPMS/')
85f3481a 114 mv(self.tree.basedir+'/SRPMS/.metadata/'+self.nvr+'.src.rpm.info', dsttree.basedir+'/SRPMS/.metadata/')
098f4a50
MM
115
116
151d31cc 117class FtpTree(BaseFtpTree):
098f4a50 118 def __init__(self, tree, loadall=False):
151d31cc 119 BaseFtpTree.__init__(self, tree)
098f4a50 120 self.loadedpkgs={}
14085d11
MM
121 self.marked4removal=[]
122 self.marked4moving=[]
d9b3388c
MM
123 self.pkgnames=[]
124 self.__loadpkgnames()
098f4a50 125 if loadall:
d9b3388c
MM
126 for pkgname in self.pkgnames:
127 self.loadedpkgs[pkgname]=Pkg(pkgname, self)
796b7867
MM
128 # Tests:
129 self.do_checkbuild=True
d9b3388c 130
098f4a50
MM
131 def __getitem__(self, key):
132 if self.loadedpkgs.has_key(key):
133 return self.loadedpkgs[key]
134 elif key in self.pkgnames:
135 pkg=Pkg(key, self)
136 self.loadedpkgs[key]=pkg
137 return pkg
138 else:
139 raise KeyError, key
796b7867 140
098f4a50
MM
141 def has_key(self, key):
142 if key in self.pkgnames:
143 return True
144 else:
145 return False
796b7867 146
1610d209
MM
147 def keys(self):
148 return self.pkgnames
098f4a50 149
67b5bf38 150 def checktree(self, dsttree):
85f3481a
MM
151 self.__checkbuild(self.loadedpkgs.values())
152 self.__checkarchs(dsttree, self.loadedpkgs.values())
0767aa5e 153
9b00920e 154 def testmove(self, dsttree):
67b5bf38
MM
155 self.__checkbuild(self.marked4moving)
156 self.__checkarchs(dsttree, self.marked4moving)
9b00920e 157
098f4a50 158 def movepkgs(self, dsttree):
f053c9e6 159 if self.do_checkbuild:
67b5bf38 160 self.__checkbuild(self.marked4moving)
098f4a50 161 bailoutonerror()
67b5bf38 162 self.__checkarchs(dsttree, self.marked4moving)
098f4a50
MM
163 bailoutonerror()
164 self.__rmolderfromsrc()
165 self.__rmotherfromdst(dsttree)
166
14085d11 167 for pkg in self.marked4moving:
098f4a50
MM
168 pkg.move(dsttree)
169
14085d11 170 def removepkgs(self):
6bc6286e 171 if self.do_checkbuild:
67b5bf38 172 self.__checkbuild(self.marked4removal)
6bc6286e 173 bailoutonerror()
14085d11
MM
174 for pkg in self.marked4removal:
175 pkg.remove()
176
177 def mark4removal(self, wannabepkgs):
178 self.__mark4something(wannabepkgs, Pkg.mark4removal)
179
180 def mark4moving(self, wannabepkgs):
181 self.__mark4something(wannabepkgs, Pkg.mark4moving)
182
183
184 # Internal functions below
185
d9b3388c
MM
186 def __loadpkgnames(self):
187 def checkfiletype(name):
188 if name[-13:]=='.src.rpm.info':
189 return True
190 else:
191 return False
192 list=filter(checkfiletype, os.listdir(self.basedir+'/SRPMS/.metadata'))
193 self.pkgnames=map((lambda x: x[:-13]), list)
194
14085d11 195 def __mark4something(self, wannabepkgs, markfunction):
098f4a50
MM
196 def chopoffextension(pkg):
197 found=pkg.find('.src.rpm')
198 if found==-1:
199 return pkg
200 else:
201 return pkg[:found]
202 for wannabepkg in wannabepkgs:
203 pkgname=chopoffextension(wannabepkg)
204 if pkgname in self.pkgnames:
205 if not pkgname in self.loadedpkgs.keys():
206 self.loadedpkgs[pkgname]=Pkg(pkgname, self)
14085d11 207 markfunction(self.loadedpkgs[pkgname])
098f4a50 208 else:
492b6398 209 perror('%s not found in source tree' % pkgname)
098f4a50 210 bailoutonerror()
14085d11 211
67b5bf38 212 def __checkbuild(self, marked):
0767aa5e 213 f=urllib.urlopen(config.builderqueue)
200470c5 214 #f=open('queue.txt')
098f4a50
MM
215 requests={}
216 reid=re.compile(r'^.*id=(.*) pri.*$')
217 regb=re.compile(r'^group:.*$|builders:.*$', re.M)
218 for i in re.findall(regb, f.read()):
219 if i[0]=='g':
220 id=reid.sub(r'\1', i)
221 requests[id]=""
222 elif i[0]=='b':
223 requests[id]=requests[id]+i
224 f.close()
6bc6286e 225 for pkg in marked:
098f4a50
MM
226 for bid in pkg.build.keys():
227 if requests.has_key(bid) and not requests[bid].find('?') == -1:
85f3481a 228 pkg.error("(buildid %s) building not finished" % bid)
098f4a50 229
67b5bf38
MM
230 def __checkarchs(self, dsttree, marked):
231 for pkg in marked:
4802753d 232 if len(pkg.files.keys()) <= 1:
85f3481a 233 pkg.error('has only src.rpm built')
4802753d 234 continue
d9b3388c 235 otherpkgnames=self.__find_other_pkgs(pkg, dsttree)
796b7867
MM
236 if otherpkgnames: # check if we're not removing some archs
237 curarchs=[]
238 missingarchs=[]
239 for somepkg in otherpkgnames:
240 curarchs.extend(Pkg(somepkg, dsttree).files.keys())
241 for arch in curarchs:
242 if arch not in pkg.files.keys():
243 missingarchs.append(arch)
244 if missingarchs:
85f3481a 245 pkg.error('moving would remove archs: %s' % missingarchs)
796b7867 246 else: # warn if a package isn't built for all archs
492b6398
MM
247 if (config.separate_noarch and 'noarch' in pkg.files.keys() and
248 len(pkg.files.keys())==2):
249 continue
5efbaf69 250 elif len(pkg.files.keys()) != len(config.ftp_archs)+1:
492b6398
MM
251 missingarchs=[]
252 for arch in config.ftp_archs:
253 if arch not in pkg.files.keys():
254 missingarchs.append(arch)
85f3481a 255 pkg.warning('not built for archs: %s' % missingarchs)
098f4a50
MM
256
257 def __rmolderfromsrc(self):
14085d11 258 for pkg in self.marked4moving:
d9b3388c 259 olderpkgnames=self.__find_older_pkgs(pkg)
098f4a50
MM
260 for i in olderpkgnames:
261 Pkg(i, self).remove()
262
263 def __rmotherfromdst(self, dsttree):
14085d11 264 for pkg in self.marked4moving:
d9b3388c 265 pkgnames=self.__find_other_pkgs(pkg, dsttree)
098f4a50
MM
266 for i in pkgnames:
267 Pkg(i, dsttree).remove()
268
d9b3388c
MM
269 # Used more than once filter functions
270
271 def __find_other_pkgs(self, pkg, tree):
85f3481a 272 escapedpkgname=pkg.name.replace('.', '\.').replace('+', '\+')
ef83f940 273 ziewre=re.compile(escapedpkgname+'-[^-]*-[^-]*$')
d9b3388c 274 def filter_other_pkgs(x):
85f3481a 275 if ziewre.match(x) and not x == pkg.nvr:
d9b3388c
MM
276 return True
277 else:
278 return False
279 return filter(filter_other_pkgs, tree.pkgnames)
280
281 def __find_older_pkgs(self, pkg):
282 def filter_older_pkgs(x):
283 checking=x.split('-')
85f3481a 284 if checking[-2]<pkg.version:
d9b3388c 285 return True
85f3481a
MM
286 elif checking[-2]==pkg.version:
287 if checking[-1]<pkg.release:
d9b3388c
MM
288 return True
289 else:
290 return False
291 else:
292 return False
293 return filter(filter_older_pkgs, self.__find_other_pkgs(pkg, self))
294
098f4a50 295
This page took 0.102024 seconds and 4 git commands to generate.