1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
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
|
# Copyright 2009 Canonical Ltd. This software is licensed under the
# GNU Affero General Public License version 3 (see the file LICENSE).
# pylint: disable-msg=E0611,W0212
__metaclass__ = type
__all__ = [
'BinaryPackageFile',
'BinaryPackageFileSet',
'SourceFileMixin',
'SourcePackageReleaseFile',
]
from sqlobject import ForeignKey
from zope.interface import implements
from canonical.database.enumcol import EnumCol
from canonical.database.sqlbase import (
SQLBase,
sqlvalues,
)
from lp.registry.interfaces.sourcepackage import SourcePackageFileType
from lp.services.database.bulk import load_related
from lp.services.librarian.model import (
LibraryFileAlias,
LibraryFileContent,
)
from lp.soyuz.enums import BinaryPackageFileType
from lp.soyuz.interfaces.files import (
IBinaryPackageFile,
IBinaryPackageFileSet,
ISourcePackageReleaseFile,
ISourcePackageReleaseFileSet,
)
class BinaryPackageFile(SQLBase):
"""See IBinaryPackageFile """
implements(IBinaryPackageFile)
_table = 'BinaryPackageFile'
binarypackagerelease = ForeignKey(dbName='binarypackagerelease',
foreignKey='BinaryPackageRelease',
notNull=True)
libraryfile = ForeignKey(dbName='libraryfile',
foreignKey='LibraryFileAlias', notNull=True)
filetype = EnumCol(dbName='filetype',
schema=BinaryPackageFileType)
class BinaryPackageFileSet:
"""See `IBinaryPackageFileSet`."""
implements(IBinaryPackageFileSet)
def getByPackageUploadIDs(self, package_upload_ids):
"""See `IBinaryPackageFileSet`."""
if package_upload_ids is None or len(package_upload_ids) == 0:
return []
return BinaryPackageFile.select("""
PackageUploadBuild.packageupload = PackageUpload.id AND
PackageUpload.id IN %s AND
BinaryPackageBuild.id = PackageUploadBuild.build AND
BinaryPackageRelease.build = BinaryPackageBuild.id AND
BinaryPackageFile.binarypackagerelease = BinaryPackageRelease.id
""" % sqlvalues(package_upload_ids),
clauseTables=["PackageUpload", "PackageUploadBuild",
"BinaryPackageBuild", "BinaryPackageRelease"],
prejoins=["binarypackagerelease", "binarypackagerelease.build",
"binarypackagerelease.binarypackagename"])
def loadLibraryFiles(self, binary_files):
"""See `IBinaryPackageFileSet`."""
lfas = load_related(LibraryFileAlias, binary_files, ['libraryfileID'])
load_related(LibraryFileContent, lfas, ['contentID'])
return lfas
class SourceFileMixin:
"""Mix-in class for common functionality between source file classes."""
@property
def is_orig(self):
return self.filetype in (
SourcePackageFileType.ORIG_TARBALL,
SourcePackageFileType.COMPONENT_ORIG_TARBALL
)
class SourcePackageReleaseFile(SourceFileMixin, SQLBase):
"""See ISourcePackageFile"""
implements(ISourcePackageReleaseFile)
sourcepackagerelease = ForeignKey(foreignKey='SourcePackageRelease',
dbName='sourcepackagerelease')
libraryfile = ForeignKey(foreignKey='LibraryFileAlias',
dbName='libraryfile')
filetype = EnumCol(schema=SourcePackageFileType)
class SourcePackageReleaseFileSet:
"""See `ISourcePackageReleaseFileSet`."""
implements(ISourcePackageReleaseFileSet)
def getByPackageUploadIDs(self, package_upload_ids):
"""See `ISourcePackageReleaseFileSet`."""
if package_upload_ids is None or len(package_upload_ids) == 0:
return []
return SourcePackageReleaseFile.select("""
PackageUploadSource.packageupload = PackageUpload.id AND
PackageUpload.id IN %s AND
SourcePackageReleaseFile.sourcepackagerelease =
PackageUploadSource.sourcepackagerelease
""" % sqlvalues(package_upload_ids),
clauseTables=["PackageUpload", "PackageUploadSource"],
prejoins=["libraryfile", "libraryfile.content",
"sourcepackagerelease",
"sourcepackagerelease.sourcepackagename"])
|