This file is indexed.

/usr/share/dirsrv/updates/70upgradefromldif.pl is in 389-ds-base 1.3.7.10-1ubuntu1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  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
use Mozilla::LDAP::Conn;
use Mozilla::LDAP::Entry;
use Mozilla::LDAP::Utils qw(normalizeDN);
use Mozilla::LDAP::API qw(:constant ldap_url_parse ldap_explode_dn);
use File::Basename;
use File::Copy;
use DSUtil qw(debug serverIsRunning);

# Used to upgrade from an older version whose database might not be
# compatible - also for an upgrade from a machine of a different
# architecture
# For each backend instance, the ldif directory should contain
# a file called BACKEND.ldif e.g. userRoot.ldif NetscapeRoot.ldif etc.
# each file will be imported
# if the import is successful, the file will be renamed so that if
# upgrade is run again, it will not attempt to import it again, but
# it will be left around as a backup
sub runinst {
    my ($inf, $inst, $dseldif, $conn) = @_;

    my @errs;

    my $config = "cn=config";
    my $config_entry = $conn->search($config, "base", "(cn=*)");
    if (!$config_entry) {
        return ("error_no_configuration_entry", $!);
    }
    my $ldifdir = $config_entry->getValues('nsslapd-ldifdir');
    if (!$ldifdir) {
        debug(1, "No such attribute nsslapd-ldifdir in cn=config in $inst\n");
        return (); # nothing to do
    }
    my $rundir = $config_entry->getValues('nsslapd-rundir');
    my $instdir = $config_entry->getValues('nsslapd-instancedir');
    # Check if the server is up or not
    my $isrunning = serverIsRunning($rundir, $inst);

    for my $file (glob("$ldifdir/*.upgrade.ldif")) {
        # assumes file name is backendname.upgrade.ldif
        my $dbinst = basename($file, ".upgrade.ldif");
        @errs = importLDIF($conn, $file, $dbinst, $isrunning, $instdir);
        if (@errs) {
            return @errs;
        }
        # else ok - rename file so we don't try to import again
        my $newfile = $file . ".importok";
        rename($file, $newfile);
    }

    return ();
}

sub startTaskAndWait {
    my ($conn, $entry) = @_;

    my $dn = $entry->getDN();
    # start the task
    $conn->add($entry);
    my $rc;
    if ($rc = $conn->getErrorCode()) {
        debug(0, "Couldn't add entry $dn: " . $conn->getErrorString());
        return $rc;
    }

    # wait for task completion - task is complete when the nsTaskExitCode attr is set
    my @attrlist = qw(nsTaskLog nsTaskStatus nsTaskExitCode nsTaskCurrentItem nsTaskTotalItems);
    my $done = 0;
    my $exitCode = 0;
    while (! $done) {
        sleep 1;
        $entry = $conn->search($dn, "base", "(objectclass=*)", 0, @attrlist);
        if ($entry->exists('nsTaskExitCode')) {
            $exitCode = $entry->getValues('nsTaskExitCode');
            $done = 1;
        } else {
            debug(1, $entry->getValues('nsTaskLog') . "\n");
        }
    }

    return $exitCode;
}

sub importLDIF {
  my ($conn, $file, $be, $isrunning, $instdir, $rc) = @_;

  if ($isrunning) {
      my $cn = "import" . time;
      my $dn = "cn=$cn,cn=import,cn=tasks,cn=config";
      my $entry = new Mozilla::LDAP::Entry();
      $entry->setDN($dn);
      $entry->setValues('objectclass', 'top', 'extensibleObject');
      $entry->setValues('cn', $cn);
      $entry->setValues('nsFilename', $file);
      $entry->setValues('nsInstance', $be);
      $rc = startTaskAndWait($conn, $entry);
      if ($rc) {
          return ('error_import_check_log', $file, $be, $rc . ":" . $conn->getErrorString());
      }
  } else { # server down - use ldif2db
      $? = 0; # clear
      if ($rc = system("$instdir/ldif2db -n $be -i $file > /dev/null 2>&1")) {
          debug(0, "Could not import $file to database $be - check errors log\n");
          return ('error_import_check_log', $file, $be, $?);
      }
  }

  return ();
}