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