]>
git.ipfire.org Git - pbs.git/blob - src/buildservice/__init__.py
12 from . import bugtracker
13 from . import builders
16 from . import database
17 from . import distribution
18 from . import jobqueue
22 from . import messages
24 from . import packages
25 from . import repository
26 from . import settings
27 from . import sessions
33 log
= logging
.getLogger("backend")
37 from .__version
__ import VERSION
as __version__
39 from .decorators
import *
40 from .constants
import *
42 class Backend(object):
45 def __init__(self
, config_file
=None):
46 # Read configuration file.
47 self
.config
= self
.read_config(config_file
)
49 # Global pakfire settings (from database).
50 self
.settings
= settings
.Settings(self
)
52 self
.arches
= arches
.Arches(self
)
53 self
.aws
= aws
.AWS(self
)
54 self
.builds
= builds
.Builds(self
)
55 self
.cache
= cache
.Cache(self
)
56 self
.jobs
= jobs
.Jobs(self
)
57 self
.builders
= builders
.Builders(self
)
58 self
.distros
= distribution
.Distributions(self
)
59 self
.jobqueue
= jobqueue
.JobQueue(self
)
60 self
.keys
= keys
.Keys(self
)
61 self
.messages
= messages
.Messages(self
)
62 self
.mirrors
= mirrors
.Mirrors(self
)
63 self
.packages
= packages
.Packages(self
)
64 self
.repos
= repository
.Repositories(self
)
65 self
.sessions
= sessions
.Sessions(self
)
66 self
.sources
= sources
.Sources(self
)
67 self
.updates
= updates
.Updates(self
)
68 self
.uploads
= uploads
.Uploads(self
)
69 self
.users
= users
.Users(self
)
71 # Open a connection to bugzilla.
72 self
.bugzilla
= bugtracker
.Bugzilla(self
)
75 def _environment_configuration(self
):
78 # Get database configuration
80 "name" : os
.environ
.get("PBS_DATABASE_NAME"),
81 "hostname" : os
.environ
.get("PBS_DATABASE_HOSTNAME"),
82 "user" : os
.environ
.get("PBS_DATABASE_USER"),
83 "password" : os
.environ
.get("PBS_DATABASE_PASSWORD"),
88 def read_config(self
, path
):
89 c
= configparser
.SafeConfigParser()
91 # Import configuration from environment
92 for section
in self
._environment
_configuration
:
93 c
.add_section(section
)
95 for k
in self
._environment
_configuration
[section
]:
96 c
.set(section
, k
, self
._environment
_configuration
[section
][k
] or "")
98 # Load default configuration file first
100 os
.path
.join(CONFIGSDIR
, "pbs.conf"),
106 # Load all configuration files
108 if os
.path
.exists(path
):
109 log
.debug("Loading configuration from %s" % path
)
112 log
.error("No such file %s" % path
)
119 name
= self
.config
.get("database", "name")
120 hostname
= self
.config
.get("database", "hostname")
121 user
= self
.config
.get("database", "user")
122 password
= self
.config
.get("database", "password")
123 except configparser
.Error
as e
:
124 log
.error("Error parsing the config: %s" % e
.message
)
126 log
.debug("Connecting to database %s @ %s" % (name
, hostname
))
128 return database
.Connection(hostname
, name
, user
=user
, password
=password
)
130 def delete_file(self
, path
, not_before
=None):
131 self
.db
.execute("INSERT INTO queue_delete(path, not_before) \
132 VALUES(%s, %s)", path
, not_before
)
134 def cleanup_files(self
):
135 query
= self
.db
.query("SELECT * FROM queue_delete \
136 WHERE (not_before IS NULL OR not_before <= NOW())")
144 if not path
or not path
.startswith("%s/" % PAKFIRE_DIR
):
145 log
.warning("Cannot delete file outside of the tree")
149 logging
.debug("Removing %s..." % path
)
152 logging
.error("Could not remove %s: %s" % (path
, e
))
155 path
= os
.path
.dirname(path
)
157 # Stop if we are running outside of the tree.
158 if not path
.startswith(PAKFIRE_DIR
):
161 # If the directory is not empty, we cannot remove it.
162 if os
.path
.exists(path
) and os
.listdir(path
):
166 logging
.debug("Removing %s..." % path
)
169 logging
.error("Could not remove %s: %s" % (path
, e
))
172 self
.db
.execute("DELETE FROM queue_delete WHERE id = %s", row
.id)