Codebase list dupload / HEAD dupload.conf
HEAD

Tree @HEAD (Download .tar.gz)

dupload.conf @HEADraw · history · blame

# This is the configuration for dupload.
# It is intended to be read and evaluated from Perl.
#
### PLEASE READ THE dupload.conf(5) MANUAL PAGE
#
# Reading the dupload(1) manual page is also advisable.

package config;

use strict;
use warnings;

use Dpkg::Vendor qw(get_current_vendor);

# ----------------
# Global variables
# ----------------

# The host to use if no --to option is used.
our $default_host;

my $vendor = get_current_vendor();
if ($vendor eq 'Debian') {
    $default_host = 'debian-ssh';
} elsif ($vendor eq 'Ubuntu') {
    $default_host = 'ubuntu';
}

# Boolean, as its name says.
our $no_parentheses_to_fullname;

# Pathname to a sendmail compatible MTA.
our $mta;

# ------------
# Global hooks
# ------------

our %preupload = (
    # Check changes file for valid signatures.
    changes => [
        '/usr/share/dupload/openpgp-check %1',
    ],
    sourcepackage => [] ,
    file => [],
    # Lintian check of packages.
    #deb => 'lintian -v -i %1',
    deb => [],
    package => [],
);

our %postupload = (
    changes => [],
    sourcepackage => [],
    file => [],
    deb => [],
    package => [],
);

# Note: hooks can also be defined in a per-host basis, this
# overrides globally defined hooks.

# -------------------
# Hosts configuration
# -------------------

our %cfg;

# Per-host variables:
# fqdn          - full hostname
# method        - ftp, scp, scpb or rsync
#                 (defaults to ftp)
# login         - user name to use on the remote host
#                 (defaults to 'anonymous' for FTP and local username for SSH methods)
#                 use "user\@remote" for firewall logins
# password      - password for anonymous FTP logins
# filemode      - destination files mode (undef disables, defaults to 0644)
# incoming      - directory where to upload first
# queuedir      - directory where to move if upload succeeded
# distallowlist - regex of the distributions allowed for this host
# distblocklist - regex of the distributions blocked for this host
# mail          - an array with 'to' and 'cc' addresses for announcement and
#                 distribution 'match' keys
# fullname      - the full name to use in the announcement email
#                 (defaults to what your local MTA uses)
# visibleuser   - the username to use in the announcement email
#                 (defaults to local username)
# visiblename   - the domainname to use in the announcement email
#                 (defaults to what your local MTA uses)

# -----------------
# Pre-defined hosts
# -----------------

my $preupload_debian = [
    '/usr/share/dupload/openpgp-check %1',
    '/usr/share/dupload/debian-source-only %1',
];
my $preupload_debian_security = [
    '/usr/share/dupload/openpgp-check %1',
    '/usr/share/dupload/debian-security-auth %1',
    '/usr/share/dupload/debian-source-only %1',
];

$cfg{'debian-ssh'} = {
    fqdn => 'ssh.upload.debian.org',
    method => 'scpb',
    incoming => '/srv/upload.debian.org/UploadQueue/',
    distblocklist => qr/^(?:UNRELEASED|.*-security$)/,
    # Files pass on to dinstall on ftp-master which sends emails itself.
    dinstall_runs => 1,
    preupload => {
        changes => $preupload_debian,
    },
};
$cfg{'debian-ftp'} = {
    fqdn => 'ftp.upload.debian.org',
    method => 'ftp',
    passive => 1,
    incoming => '/pub/UploadQueue/',
    distblocklist => qr/^(?:UNRELEASED|.*-security$)/,
    # Files pass on to dinstall on ftp-master which sends emails itself.
    dinstall_runs => 1,
    preupload => {
        changes => $preupload_debian,
    },
};
# See <https://lists.debian.org/debian-project/2009/05/msg00036.html>.
$cfg{'debian-ftp-eu'} = {
    fqdn => 'ftp.eu.upload.debian.org',
    method => 'ftp',
    passive => 1,
    incoming => '/pub/UploadQueue/',
    distblocklist => qr/^(?:UNRELEASED|.*-security$)/,
    # Files pass on to dinstall on ftp-master which sends emails itself.
    dinstall_runs => 1,
    preupload => {
        changes => $preupload_debian,
    },
};

# See <https://backports.debian.org/Contribute/> for more information.
$cfg{'debian-backports'} = {
    fqdn => 'backports-master.debian.org',
    method => 'ftp',
    passive => 1,
    incoming => '/pub/UploadQueue/',
    distblocklist => qr/^(?:UNRELEASED|.*-security$)/,
    distallowlist => qr/^.*-backports(?:-sloppy)?$/,
    dinstall_runs => 1,
};

# For Delayed uploads use this. You can use 0-day, which is uploaded
# one hour before dinstall runs.
my $delay = (defined($ENV{DEBDELAY}) ? $ENV{DEBDELAY} : 7);
$cfg{'debian-ftp-delayed'} = {
    fqdn => 'ftp.upload.debian.org',
    method => 'ftp',
    passive => 1,
    incoming => "/pub/UploadQueue/DELAYED/$delay-day/",
    distblocklist => qr/^UNRELEASED/,
    # Files pass on to dinstall on ftp-master which sends emails itself.
    dinstall_runs => 1,
    preupload => {
        changes => $preupload_debian,
    },
};

# Debian Ports upload queue, for more information see
# <https://www.ports.debian.org/archive>.
$cfg{'debian-ports'} = {
    fqdn => 'ports-master.debian.org',
    method => 'ftp',
    passive => 1,
    incoming => '/incoming/',
    distblocklist => qr/^UNRELEASED/,
    dinstall_runs => 1,
};

# Mentors upload queue, for more information see
# <https://mentors.debian.net/cgi-bin/maintainer-intro>.
$cfg{'debian-mentors'} = {
    fqdn => 'mentors.debian.net',
    method => 'ftp',
    passive => 1,
    incoming => '/pub/UploadQueue/',
    dinstall_runs => 1,
};

# NOTE: Do _NOT_ upload a package to the security upload queue
# (oldstable-security, stable-security, etc.) without prior authorization
# from the Debian security team. Please see
# <https://www.debian.org/doc/developers-reference/pkgs.html#bug-security>.

# See <https://lists.debian.org/debian-devel-announce/2017/10/msg00000.html>
$cfg{'debian-ssh-security'} = {
    fqdn => 'ssh.security.upload.debian.org',
    method => 'scpb',
    incoming => '/srv/security.upload.debian.org/SecurityUploadQueue',
    filemode => undef,
    distblocklist => qr/^UNRELEASED/,
    distallowlist => qr/^.*-security$/,
    # Files pass on to dinstall on security which sends emails itself.
    dinstall_runs => 1,
    preupload => {
        changes => $preupload_debian_security,
    },
};
$cfg{'debian-ftp-security'} = {
    fqdn => 'ftp.security.upload.debian.org',
    method => 'ftp',
    passive => 1,
    incoming => '/pub/SecurityUploadQueue',
    filemode => undef,
    distblocklist => qr/^UNRELEASED/,
    distallowlist => qr/^.*-security$/,
    # Files pass on to dinstall on security which sends emails itself.
    dinstall_runs => 1,
    preupload => {
        changes => $preupload_debian_security,
    },
};
$cfg{'debian-ssh-security-unembargoed'} = {
    fqdn => 'ssh.security.upload.debian.org',
    method => 'scpb',
    incoming => '/srv/security.upload.debian.org/OpenSecurityUploadQueue',
    distblocklist => qr/^UNRELEASED/,
    distallowlist => qr/^.*-security$/,
    # Files pass on to dinstall on security which sends emails itself.
    dinstall_runs => 1,
    preupload => {
        changes => $preupload_debian_security,
    },
};
$cfg{'debian-ftp-security-unembargoed'} = {
    fqdn => 'ftp.security.upload.debian.org',
    method => 'ftp',
    passive => 1,
    incoming => '/pub/OpenSecurityUploadQueue',
    distblocklist => qr/^UNRELEASED/,
    distallowlist => qr/^.*-security$/,
    # Files pass on to dinstall on security which sends emails itself.
    dinstall_runs => 1,
    preupload => {
        changes => $preupload_debian_security,
    },
};

$cfg{'ubuntu'} = {
    fqdn => 'upload.ubuntu.com',
    method => 'ftp',
    passive => 1,
    incoming => '/ubuntu',
    distblocklist => qr/^UNRELEASED/,
    dinstall_runs => 1,
};

# Compatibility aliases.
$cfg{'ftp-master'} = $cfg{'debian-ssh'};
$cfg{'anonymous-ftp-master'} = $cfg{'debian-ftp'};
$cfg{'anonymous-ftp-eu'} = $cfg{'debian-ftp-eu'};
$cfg{'delayed'} = $cfg{'debian-ftp-delayed'};
$cfg{'bpo'} = $cfg{'debian-backports'};
$cfg{'mentors'} = $cfg{'debian-mentors'};
$cfg{'security'} = $cfg{'debian-ssh-security'};
$cfg{'anonymous-security'} = $cfg{'debian-ftp-security'};
$cfg{'anonymous-security-unembargoed'} = $cfg{'debian-ftp-security-unembargoed'};

# Do not remove the following line. Perl needs it.
1;

## vim: ft=perl
## Local Variables: ##
## mode:perl ##
## End: ##