]> git.pld-linux.org Git - projects/pld-ftp-admin.git/blame - modules/ftptree.py
- all scripts use ftpiod for locking and logging
[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()
098f4a50 106 if loadall:
d9b3388c
MM
107 for pkgname in self.pkgnames:
108 self.loadedpkgs[pkgname]=Pkg(pkgname, self)
109
098f4a50
MM
110 def __getitem__(self, key):
111 if self.loadedpkgs.has_key(key):
112 return self.loadedpkgs[key]
113 elif key in self.pkgnames:
114 pkg=Pkg(key, self)
115 self.loadedpkgs[key]=pkg
116 return pkg
117 else:
118 raise KeyError, key
119 def has_key(self, key):
120 if key in self.pkgnames:
121 return True
122 else:
123 return False
1610d209
MM
124 def keys(self):
125 return self.pkgnames
098f4a50 126
9b00920e
MM
127 def testmove(self, dsttree):
128 self.__checkbuild()
129 self.__checkarchs(dsttree)
130
098f4a50
MM
131 def movepkgs(self, dsttree):
132 self.__checkbuild()
133 bailoutonerror()
134 self.__checkarchs(dsttree)
135 bailoutonerror()
136 self.__rmolderfromsrc()
137 self.__rmotherfromdst(dsttree)
138
14085d11 139 for pkg in self.marked4moving:
098f4a50
MM
140 pkg.move(dsttree)
141
14085d11
MM
142 def removepkgs(self):
143 for pkg in self.marked4removal:
144 pkg.remove()
145
146 def mark4removal(self, wannabepkgs):
147 self.__mark4something(wannabepkgs, Pkg.mark4removal)
148
149 def mark4moving(self, wannabepkgs):
150 self.__mark4something(wannabepkgs, Pkg.mark4moving)
151
152
153 # Internal functions below
154
d9b3388c
MM
155 def __loadpkgnames(self):
156 def checkfiletype(name):
157 if name[-13:]=='.src.rpm.info':
158 return True
159 else:
160 return False
161 list=filter(checkfiletype, os.listdir(self.basedir+'/SRPMS/.metadata'))
162 self.pkgnames=map((lambda x: x[:-13]), list)
163
14085d11 164 def __mark4something(self, wannabepkgs, markfunction):
098f4a50
MM
165 def chopoffextension(pkg):
166 found=pkg.find('.src.rpm')
167 if found==-1:
168 return pkg
169 else:
170 return pkg[:found]
171 for wannabepkg in wannabepkgs:
172 pkgname=chopoffextension(wannabepkg)
173 if pkgname in self.pkgnames:
174 if not pkgname in self.loadedpkgs.keys():
175 self.loadedpkgs[pkgname]=Pkg(pkgname, self)
14085d11 176 markfunction(self.loadedpkgs[pkgname])
098f4a50
MM
177 else:
178 perror(pkgname+" was not found in source tree")
179 bailoutonerror()
14085d11 180
098f4a50 181 def __checkbuild(self):
200470c5
MM
182 f=urllib.urlopen('http://ep09.pld-linux.org/~builderth/queue.txt')
183 #f=open('queue.txt')
098f4a50
MM
184 requests={}
185 reid=re.compile(r'^.*id=(.*) pri.*$')
186 regb=re.compile(r'^group:.*$|builders:.*$', re.M)
187 for i in re.findall(regb, f.read()):
188 if i[0]=='g':
189 id=reid.sub(r'\1', i)
190 requests[id]=""
191 elif i[0]=='b':
192 requests[id]=requests[id]+i
193 f.close()
14085d11 194 for pkg in self.marked4moving:
098f4a50
MM
195 for bid in pkg.build.keys():
196 if requests.has_key(bid) and not requests[bid].find('?') == -1:
197 perror("Building of package %s (buildid %s) not finished" % (pkg,bid))
198
199 def __checkarchs(self, dsttree):
14085d11 200 for pkg in self.marked4moving:
d9b3388c 201 otherpkgnames=self.__find_other_pkgs(pkg, dsttree)
098f4a50
MM
202 curarchs=[]
203 missingarchs=[]
204 for somepkg in otherpkgnames:
151d31cc 205 curarchs.extend(Pkg(somepkg, dsttree).files.keys())
098f4a50 206 for arch in curarchs:
151d31cc 207 if arch not in pkg.files.keys():
098f4a50
MM
208 missingarchs.append(arch)
209 if missingarchs:
9b00920e 210 perror('Moving %s would remove archs: %s' % (pkg, missingarchs))
098f4a50
MM
211
212 def __rmolderfromsrc(self):
14085d11 213 for pkg in self.marked4moving:
d9b3388c 214 olderpkgnames=self.__find_older_pkgs(pkg)
098f4a50
MM
215 for i in olderpkgnames:
216 Pkg(i, self).remove()
217
218 def __rmotherfromdst(self, dsttree):
14085d11 219 for pkg in self.marked4moving:
d9b3388c 220 pkgnames=self.__find_other_pkgs(pkg, dsttree)
098f4a50
MM
221 for i in pkgnames:
222 Pkg(i, dsttree).remove()
223
d9b3388c
MM
224 # Used more than once filter functions
225
226 def __find_other_pkgs(self, pkg, tree):
227 ziewre=re.compile(string.join(pkg.name.split('-')[:-2], '-')+'-[^-]*-[^-]*$')
228 def filter_other_pkgs(x):
229 if ziewre.match(x) and not x == pkg.name:
230 return True
231 else:
232 return False
233 return filter(filter_other_pkgs, tree.pkgnames)
234
235 def __find_older_pkgs(self, pkg):
236 def filter_older_pkgs(x):
237 checking=x.split('-')
238 curpkg=pkg.name.split('-')
239 if checking[-2]<curpkg[-2]:
240 return True
241 elif checking[-2]==curpkg[-2]:
242 if checking[-1]<curpkg[-1]:
243 return True
244 else:
245 return False
246 else:
247 return False
248 return filter(filter_older_pkgs, self.__find_other_pkgs(pkg, self))
249
098f4a50 250
This page took 0.079404 seconds and 4 git commands to generate.