SUSE SLED11 / SLES11 Security Update : postgresql94 (SUSE-SU-2016:0482-1)

2016-02-18T00:00:00
ID SUSE_SU-2016-0482-1.NASL
Type nessus
Reporter This script is Copyright (C) 2016-2021 and is owned by Tenable, Inc. or an Affiliate thereof.
Modified 2016-02-18T00:00:00

Description

This update of postgresql94 to 9.4.5 fixes the following issues :

  • CVE-2015-5289: json or jsonb input values constructed from arbitrary user input could have crashed the PostgreSQL server and caused a denial of service (bsc#949670)

  • CVE-2015-5288: crypt() (pgCrypto extension) couldi potentially be exploited to read a few additional bytes of memory (bsc#949669)

Also contains all changes and bugfixes in the upstream 9.4.5 release: http://www.postgresql.org/docs/current/static/release-9-4-5.html

Note that Tenable Network Security has extracted the preceding description block directly from the SUSE security advisory. Tenable has attempted to automatically clean and format it as much as possible without introducing additional issues.

                                        
                                            #%NASL_MIN_LEVEL 70300
#
# (C) Tenable Network Security, Inc.
#
# The descriptive text and package checks in this plugin were
# extracted from SUSE update advisory SUSE-SU-2016:0482-1.
# The text itself is copyright (C) SUSE.
#

include('deprecated_nasl_level.inc');
include('compat.inc');

if (description)
{
  script_id(88835);
  script_version("2.10");
  script_set_attribute(attribute:"plugin_modification_date", value:"2021/01/06");

  script_cve_id("CVE-2015-5288", "CVE-2015-5289");

  script_name(english:"SUSE SLED11 / SLES11 Security Update : postgresql94 (SUSE-SU-2016:0482-1)");
  script_summary(english:"Checks rpm output for the updated packages.");

  script_set_attribute(
    attribute:"synopsis", 
    value:"The remote SUSE host is missing one or more security updates."
  );
  script_set_attribute(
    attribute:"description", 
    value:
"This update of postgresql94 to 9.4.5 fixes the following issues :

  - CVE-2015-5289: json or jsonb input values constructed
    from arbitrary user input could have crashed the
    PostgreSQL server and caused a denial of service
    (bsc#949670)

  - CVE-2015-5288: crypt() (pgCrypto extension) couldi
    potentially be exploited to read a few additional bytes
    of memory (bsc#949669)

Also contains all changes and bugfixes in the upstream 9.4.5 release:
http://www.postgresql.org/docs/current/static/release-9-4-5.html

Note that Tenable Network Security has extracted the preceding
description block directly from the SUSE security advisory. Tenable
has attempted to automatically clean and format it as much as possible
without introducing additional issues."
  );
  # http://www.postgresql.org/docs/current/static/release-9-4-5.html
  script_set_attribute(
    attribute:"see_also",
    value:"https://www.postgresql.org/docs/current/release-9-4-5.html"
  );
  script_set_attribute(
    attribute:"see_also",
    value:"https://bugzilla.suse.com/show_bug.cgi?id=949669"
  );
  script_set_attribute(
    attribute:"see_also",
    value:"https://bugzilla.suse.com/show_bug.cgi?id=949670"
  );
  script_set_attribute(
    attribute:"see_also",
    value:"https://www.suse.com/security/cve/CVE-2015-5288/"
  );
  script_set_attribute(
    attribute:"see_also",
    value:"https://www.suse.com/security/cve/CVE-2015-5289/"
  );
  # https://www.suse.com/support/update/announcement/2016/suse-su-20160482-1/
  script_set_attribute(
    attribute:"see_also",
    value:"http://www.nessus.org/u?4c59478d"
  );
  script_set_attribute(
    attribute:"solution", 
    value:
"To install this SUSE Security Update use YaST online_update.
Alternatively you can run the command listed for your product :

SUSE Manager 2.1 :

zypper in -t patch sleman21-postgreqsql94-20160120-12409=1

SUSE Linux Enterprise Software Development Kit 11-SP4 :

zypper in -t patch sdksp4-postgreqsql94-20160120-12409=1

SUSE Linux Enterprise Software Development Kit 11-SP3 :

zypper in -t patch sdksp3-postgreqsql94-20160120-12409=1

SUSE Linux Enterprise Server for VMWare 11-SP3 :

zypper in -t patch slessp3-postgreqsql94-20160120-12409=1

SUSE Linux Enterprise Server 11-SP4 :

zypper in -t patch slessp4-postgreqsql94-20160120-12409=1

SUSE Linux Enterprise Server 11-SP3 :

zypper in -t patch slessp3-postgreqsql94-20160120-12409=1

SUSE Linux Enterprise Desktop 11-SP4 :

zypper in -t patch sledsp4-postgreqsql94-20160120-12409=1

SUSE Linux Enterprise Desktop 11-SP3 :

zypper in -t patch sledsp3-postgreqsql94-20160120-12409=1

SUSE Linux Enterprise Debuginfo 11-SP4 :

zypper in -t patch dbgsp4-postgreqsql94-20160120-12409=1

SUSE Linux Enterprise Debuginfo 11-SP3 :

zypper in -t patch dbgsp3-postgreqsql94-20160120-12409=1

To bring your system up-to-date, use 'zypper patch'."
  );
  script_set_cvss_base_vector("CVSS2#AV:N/AC:L/Au:N/C:P/I:N/A:P");
  script_set_cvss_temporal_vector("CVSS2#E:U/RL:OF/RC:C");
  script_set_attribute(attribute:"exploitability_ease", value:"No known exploits are available");
  script_set_attribute(attribute:"exploit_available", value:"false");

  script_set_attribute(attribute:"plugin_type", value:"local");
  script_set_attribute(attribute:"cpe", value:"p-cpe:/a:novell:suse_linux:libecpg6");
  script_set_attribute(attribute:"cpe", value:"p-cpe:/a:novell:suse_linux:libpq5");
  script_set_attribute(attribute:"cpe", value:"p-cpe:/a:novell:suse_linux:postgresql94");
  script_set_attribute(attribute:"cpe", value:"p-cpe:/a:novell:suse_linux:postgresql94-contrib");
  script_set_attribute(attribute:"cpe", value:"p-cpe:/a:novell:suse_linux:postgresql94-docs");
  script_set_attribute(attribute:"cpe", value:"p-cpe:/a:novell:suse_linux:postgresql94-server");
  script_set_attribute(attribute:"cpe", value:"cpe:/o:novell:suse_linux:11");

  script_set_attribute(attribute:"vuln_publication_date", value:"2015/10/26");
  script_set_attribute(attribute:"patch_publication_date", value:"2016/02/16");
  script_set_attribute(attribute:"plugin_publication_date", value:"2016/02/18");
  script_set_attribute(attribute:"generated_plugin", value:"current");
  script_end_attributes();

  script_category(ACT_GATHER_INFO);
  script_copyright(english:"This script is Copyright (C) 2016-2021 and is owned by Tenable, Inc. or an Affiliate thereof.");
  script_family(english:"SuSE Local Security Checks");

  script_dependencies("ssh_get_info.nasl");
  script_require_keys("Host/local_checks_enabled", "Host/cpu", "Host/SuSE/release", "Host/SuSE/rpm-list");

  exit(0);
}


include("audit.inc");
include("global_settings.inc");
include("rpm.inc");


if (!get_kb_item("Host/local_checks_enabled")) audit(AUDIT_LOCAL_CHECKS_NOT_ENABLED);
release = get_kb_item("Host/SuSE/release");
if (isnull(release) || release !~ "^(SLED|SLES)") audit(AUDIT_OS_NOT, "SUSE");
os_ver = pregmatch(pattern: "^(SLE(S|D)\d+)", string:release);
if (isnull(os_ver)) audit(AUDIT_UNKNOWN_APP_VER, "SUSE");
os_ver = os_ver[1];
if (! preg(pattern:"^(SLED11|SLES11)$", string:os_ver)) audit(AUDIT_OS_NOT, "SUSE SLED11 / SLES11", "SUSE " + os_ver);

if (!get_kb_item("Host/SuSE/rpm-list")) audit(AUDIT_PACKAGE_LIST_MISSING);

cpu = get_kb_item("Host/cpu");
if (isnull(cpu)) audit(AUDIT_UNKNOWN_ARCH);
if (cpu !~ "^i[3-6]86$" && "x86_64" >!< cpu && "s390x" >!< cpu) audit(AUDIT_LOCAL_CHECKS_NOT_IMPLEMENTED, "SUSE " + os_ver, cpu);

sp = get_kb_item("Host/SuSE/patchlevel");
if (isnull(sp)) sp = "0";
if (os_ver == "SLES11" && (! preg(pattern:"^(3|4)$", string:sp))) audit(AUDIT_OS_NOT, "SLES11 SP3/4", os_ver + " SP" + sp);
if (os_ver == "SLED11" && (! preg(pattern:"^(3|4)$", string:sp))) audit(AUDIT_OS_NOT, "SLED11 SP3/4", os_ver + " SP" + sp);


flag = 0;
if (rpm_check(release:"SLES11", sp:"4", cpu:"x86_64", reference:"libpq5-32bit-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLES11", sp:"4", cpu:"s390x", reference:"libpq5-32bit-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLES11", sp:"4", reference:"libecpg6-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLES11", sp:"4", reference:"libpq5-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLES11", sp:"4", reference:"postgresql94-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLES11", sp:"4", reference:"postgresql94-contrib-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLES11", sp:"4", reference:"postgresql94-docs-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLES11", sp:"4", reference:"postgresql94-server-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLES11", sp:"3", cpu:"x86_64", reference:"libpq5-32bit-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLES11", sp:"3", cpu:"s390x", reference:"libpq5-32bit-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLES11", sp:"3", reference:"libecpg6-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLES11", sp:"3", reference:"libpq5-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLES11", sp:"3", reference:"postgresql94-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLES11", sp:"3", reference:"postgresql94-contrib-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLES11", sp:"3", reference:"postgresql94-docs-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLES11", sp:"3", reference:"postgresql94-server-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"4", cpu:"x86_64", reference:"libecpg6-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"4", cpu:"x86_64", reference:"libpq5-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"4", cpu:"x86_64", reference:"postgresql94-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"4", cpu:"x86_64", reference:"postgresql94-docs-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"4", cpu:"x86_64", reference:"libpq5-32bit-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"4", cpu:"i586", reference:"libecpg6-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"4", cpu:"i586", reference:"libpq5-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"4", cpu:"i586", reference:"postgresql94-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"4", cpu:"i586", reference:"postgresql94-docs-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"3", cpu:"x86_64", reference:"libecpg6-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"3", cpu:"x86_64", reference:"libpq5-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"3", cpu:"x86_64", reference:"postgresql94-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"3", cpu:"x86_64", reference:"postgresql94-docs-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"3", cpu:"x86_64", reference:"libpq5-32bit-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"3", cpu:"i586", reference:"libecpg6-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"3", cpu:"i586", reference:"libpq5-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"3", cpu:"i586", reference:"postgresql94-9.4.5-0.8.3")) flag++;
if (rpm_check(release:"SLED11", sp:"3", cpu:"i586", reference:"postgresql94-docs-9.4.5-0.8.3")) flag++;


if (flag)
{
  if (report_verbosity > 0) security_warning(port:0, extra:rpm_report_get());
  else security_warning(0);
  exit(0);
}
else
{
  tested = pkg_tests_get();
  if (tested) audit(AUDIT_PACKAGE_NOT_AFFECTED, tested);
  else audit(AUDIT_PACKAGE_NOT_INSTALLED, "postgresql94");
}