X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=modules%2Fprivate%2Fbuildbot%2Fprojects%2FimmaeEu%2F__init__.py;h=bb880e5329d5e31cdf5f12630ab32104dbc22aba;hb=251c0a135a4153453030dc0e2c132e57934c0095;hp=f29eb149d1cd69a04d5b022bbba3a79dc5c7981b;hpb=0012da0ff3d45df9f68412b90be4f7c24d46a777;p=perso%2FImmae%2FConfig%2FNix.git diff --git a/modules/private/buildbot/projects/immaeEu/__init__.py b/modules/private/buildbot/projects/immaeEu/__init__.py index f29eb14..bb880e5 100644 --- a/modules/private/buildbot/projects/immaeEu/__init__.py +++ b/modules/private/buildbot/projects/immaeEu/__init__.py @@ -15,15 +15,21 @@ class E(): SSH_HOST_KEY = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIIFbhFTl2A2RJn5L51yxJM4XfCS2ZaiSX/jo9jFSdghF" XMPP_RECIPIENTS = os.environ["BUILDBOT_XMPP_RECIPIENTS"].split(" ") + BIP39_GIT_URL = "https://git.immae.eu/perso/Immae/Projets/Cryptomonnaies/BIP39.git" IMMAE_EU_GIT_URL = "gitolite@git.immae.eu:perso/Immae/Sites/Blog" + RECETTES_GIT_URL = "gitolite@git.immae.eu:perso/Immae/Sites/Recettes" COURS_GIT_URL = "gitolite@git.immae.eu:perso/Immae/Sites/Cours" NORMALESUP_GIT_URL = "gitolite@git.immae.eu:perso/Immae/Projets/Sites/Normalesup" COURS_RELEASE_PATH = "/var/lib/buildbot/outputs/cours" COURS_TARBALL_PATH = "/var/lib/ftp/release.immae.eu/cours" COURS_TARBALL_URL = "https://release.immae.eu/cours" + BIP39_RELEASE_PATH = "/var/lib/buildbot/outputs/bip39" IMMAE_EU_RELEASE_PATH = "/var/lib/buildbot/outputs/immaeEu" + RECETTES_RELEASE_PATH = "/var/lib/buildbot/outputs/recettes" NORMALESUP_RELEASE_PATH = "/var/lib/buildbot/outputs/recherche" + GSMCELLS_RELEASE_PATH = "/var/lib/ftp/release.immae.eu/gsm_cells" + GSMCELLS_RELEASE_URL = "https://release.immae.eu/gsm_cells" # master.cfg SECRETS_FILE = os.getcwd() + "/secrets" @@ -61,22 +67,89 @@ def configure(c): c['schedulers'].append(hook_scheduler("ImmaeEu", timer=1)) c['schedulers'].append(hook_scheduler("Normalesup", timer=1)) c['schedulers'].append(hook_scheduler("Cours", timer=1)) - c['schedulers'].append(force_scheduler("force_immae_eu", ["ImmaeEu_build", "Normalesup_build", "Cours_build"])) + c['schedulers'].append(hook_scheduler("Recettes", timer=1)) + c['schedulers'].append(hook_scheduler("BIP39", timer=1)) + c['schedulers'].append(schedulers.Nightly(name="GSMCells-weekly", + builderNames=["GSMCells_build"], dayOfWeek=6, hour=3)) + c['schedulers'].append(force_scheduler("force_immae_eu", [ + "ImmaeEu_build", "Normalesup_build", "Cours_build", + "Recettes_build", "BIP39_build" + ])) + c['schedulers'].append(schedulers.ForceScheduler( + name="GSMCells-force", label="Force build", + buttonName="Force build", + reason=util.StringParameter(name="reason", label="Reason", default="Force build"), + codebases=[ + util.CodebaseParameter("", + branch=util.FixedParameter(name="branch", default=""), + revision=util.FixedParameter(name="revision", default=""), + repository=util.FixedParameter(name="repository", default=""), + project=util.FixedParameter(name="project", default=""), + ), + ], + username=util.FixedParameter(name="username", default="Web button"), + builderNames=["GSMCells_build"] + )) c['builders'].append(immae_eu_factory()) c['builders'].append(normalesup_factory()) c['builders'].append(cours_factory()) + c['builders'].append(gsm_cells_factory()) + c['builders'].append(recettes_factory()) + c['builders'].append(bip39_factory()) c['services'].append(SlackStatusPush( name="slack_status_immae_eu_project", - builders=["ImmaeEu_build", "Normalesup_build", "Cours_build"], + builders=[ + "ImmaeEu_build", "Normalesup_build", "Cours_build", + "GSMCells_build", "Recettes_build", "BIP39_build" + ], serverUrl=open(E.SECRETS_FILE + "/slack_webhook", "r").read().rstrip())) c['services'].append(XMPPStatusPush( name="xmpp_status_immae_eu_project", - builders=["ImmaeEu_build", "Normalesup_build", "Cours_build"], + builders=[ + "ImmaeEu_build", "Normalesup_build", "Cours_build", + "GSMCells_build", "Recettes_build", "BIP39_build" + ], recipients=E.XMPP_RECIPIENTS, password=open(E.SECRETS_FILE + "/notify_xmpp_password", "r").read().rstrip())) +def recettes_factory(): + path_env = { + "PATH": os.environ["BUILDBOT_PATH_Recettes"] + ":${PATH}" + } + factory = util.BuildFactory() + factory.addStep(steps.Git(logEnviron=False, repourl=E.RECETTES_GIT_URL, + submodules=True, sshPrivateKey=open(E.SSH_KEY_PATH).read().rstrip(), + sshHostKey=E.SSH_HOST_KEY, mode="full", method="copy")) + factory.addStep(steps.ShellCommand(name="build website", + logEnviron=False, haltOnFailure=True, workdir="source", + env=path_env, command=["jekyll", "build", "--baseurl", "/recettes"])) + factory.addStep(steps.MasterShellCommand(command="rm -rf {}".format(E.RECETTES_RELEASE_PATH))) + factory.addStep(steps.DirectoryUpload(workersrc="../source/_site", + masterdest=E.RECETTES_RELEASE_PATH, + url="https://www.immae.eu/recettes")) + factory.addStep(steps.MasterShellCommand(command="chmod -R a+rX {}".format(E.RECETTES_RELEASE_PATH))) + + return util.BuilderConfig(name="Recettes_build", workernames=["generic-worker-immae-eu"], factory=factory) + +def bip39_factory(): + path_env = { + "PATH": os.environ["BUILDBOT_PATH_BIP39"] + ":${PATH}" + } + factory = util.BuildFactory() + factory.addStep(steps.Git(logEnviron=False, repourl=E.BIP39_GIT_URL, + submodules=True, mode="full", method="copy")) + factory.addStep(steps.ShellCommand(name="build file", + logEnviron=False, haltOnFailure=True, workdir="source", + env=path_env, command=["python", "compile.py"])) + factory.addStep(steps.FileUpload(name="upload file", workersrc="bip39-standalone.html", + workdir="source", masterdest=E.BIP39_RELEASE_PATH + "/index.html", + url="https://tools.immae.eu/BIP39", mode=0o644)) + factory.addStep(steps.MasterShellCommand(command="chmod -R a+rX {}".format(E.BIP39_RELEASE_PATH))) + + return util.BuilderConfig(name="BIP39_build", workernames=["generic-worker-immae-eu"], factory=factory) + def immae_eu_factory(): path_env = { "PATH": os.environ["BUILDBOT_PATH_ImmaeEu"] + ":${PATH}" @@ -98,7 +171,8 @@ def immae_eu_factory(): def cours_factory(): path_env = { - "PATH": os.environ["BUILDBOT_PATH_Cours"] + ":${PATH}" + "PATH": os.environ["BUILDBOT_PATH_Cours"] + ":${PATH}", + "CI": "yes" } factory = util.BuildFactory() factory.addStep(steps.Git(logEnviron=False, repourl=E.COURS_GIT_URL, @@ -158,3 +232,35 @@ def normalesup_factory(): factory.addStep(steps.MasterShellCommand(command="chmod -R a+rX {}".format(E.NORMALESUP_RELEASE_PATH))) return util.BuilderConfig(name="Normalesup_build", workernames=["generic-worker-immae-eu"], factory=factory) + +def gsm_cells_factory(): + path_env = { + "PATH": os.environ["BUILDBOT_PATH_GSMCells"] + ":${PATH}", + "IN_BUILDBOT": "yes", + } + master_env = { + "HTACCESS": ''' + Options +FollowSymLinks + IndexIgnore * + ''' + } + for k, v in os.environ.items(): + if k.startswith("BUILDBOT_GSM_CELLS_"): + path_env[k[len("BUILDBOT_GSM_CELLS_"):]] = v + + script = os.environ["BUILDBOT_PROJECT_DIR"] + "/scripts/lacells_download" + factory = util.BuildFactory() + factory.addStep(steps.ShellCommand(name="download files", + logEnviron=False, haltOnFailure=True, command=[script], env=path_env)) + factory.addStep(steps.ShellCommand(name="give read access to all files", + logEnviron=False, haltOnFailure=True, + command="chmod a+r lacells.db", env=path_env)) + factory.addStep(steps.FileUpload(workersrc="lacells.db", + masterdest=(E.GSMCELLS_RELEASE_PATH+"/lacells.db"), url=(E.GSMCELLS_RELEASE_URL+"/lacells.db"))) + factory.addStep(steps.MasterShellCommand(command="touch {}/.duplicity-ignore".format(E.GSMCELLS_RELEASE_PATH))) + factory.addStep(steps.MasterShellCommand(command='echo "$HTACCESS" > {}/.htaccess'.format(E.GSMCELLS_RELEASE_PATH), + env=master_env)) + factory.addStep(steps.MasterShellCommand(command="ln -sf lacells.db {}/lacells.db.new".format(E.GSMCELLS_RELEASE_PATH))) + factory.addStep(steps.MasterShellCommand(command="chmod -R a+rX {}".format(E.GSMCELLS_RELEASE_PATH))) + + return util.BuilderConfig(name="GSMCells_build", workernames=["generic-worker-immae-eu"], factory=factory)