137 lines
4.5 KiB
Diff
137 lines
4.5 KiB
Diff
|
From 24aef5baa9725e26efd37fa78b83f98629d77eba Mon Sep 17 00:00:00 2001
|
||
|
From: Pino Toscano <ptoscano@redhat.com>
|
||
|
Date: Wed, 21 Feb 2018 17:33:28 +0100
|
||
|
Subject: [PATCH] New API: inspect_get_osinfo
|
||
|
|
||
|
Try to guess the possible osinfo-db short ID for the specified OS.
|
||
|
|
||
|
Related to: https://bugzilla.redhat.com/show_bug.cgi?id=1544842
|
||
|
|
||
|
(cherry picked from commit 286b88891c2288fb7f64c9538296599ece04bcb1)
|
||
|
---
|
||
|
generator/actions_inspection.ml | 14 ++++++
|
||
|
lib/Makefile.am | 1 +
|
||
|
lib/inspect-osinfo.c | 75 +++++++++++++++++++++++++++++++++
|
||
|
3 files changed, 90 insertions(+)
|
||
|
create mode 100644 lib/inspect-osinfo.c
|
||
|
|
||
|
diff --git a/generator/actions_inspection.ml b/generator/actions_inspection.ml
|
||
|
index 0ac282435..ff5083114 100644
|
||
|
--- a/generator/actions_inspection.ml
|
||
|
+++ b/generator/actions_inspection.ml
|
||
|
@@ -770,4 +770,18 @@ advice before using trademarks in applications.
|
||
|
|
||
|
=back" };
|
||
|
|
||
|
+ { defaults with
|
||
|
+ name = "inspect_get_osinfo"; added = (1, 39, 1);
|
||
|
+ style = RString (RPlainString, "id"), [String (Mountable, "root")], [];
|
||
|
+ shortdesc = "get a possible osinfo short ID corresponding to this operating system";
|
||
|
+ longdesc = "\
|
||
|
+This function returns a possible short ID for libosinfo corresponding
|
||
|
+to the guest.
|
||
|
+
|
||
|
+I<Note:> The returned ID is only a guess by libguestfs, and nothing
|
||
|
+ensures that it actually exists in osinfo-db.
|
||
|
+
|
||
|
+If no ID could not be determined, then the string C<unknown> is
|
||
|
+returned." };
|
||
|
+
|
||
|
]
|
||
|
diff --git a/lib/Makefile.am b/lib/Makefile.am
|
||
|
index d075174d9..742b182cc 100644
|
||
|
--- a/lib/Makefile.am
|
||
|
+++ b/lib/Makefile.am
|
||
|
@@ -95,6 +95,7 @@ libguestfs_la_SOURCES = \
|
||
|
info.c \
|
||
|
inspect-apps.c \
|
||
|
inspect-icon.c \
|
||
|
+ inspect-osinfo.c \
|
||
|
journal.c \
|
||
|
launch.c \
|
||
|
launch-direct.c \
|
||
|
diff --git a/lib/inspect-osinfo.c b/lib/inspect-osinfo.c
|
||
|
new file mode 100644
|
||
|
index 000000000..816d317f1
|
||
|
--- /dev/null
|
||
|
+++ b/lib/inspect-osinfo.c
|
||
|
@@ -0,0 +1,75 @@
|
||
|
+/* libguestfs
|
||
|
+ * Copyright (C) 2018 Red Hat Inc.
|
||
|
+ *
|
||
|
+ * This library is free software; you can redistribute it and/or
|
||
|
+ * modify it under the terms of the GNU Lesser General Public
|
||
|
+ * License as published by the Free Software Foundation; either
|
||
|
+ * version 2 of the License, or (at your option) any later version.
|
||
|
+ *
|
||
|
+ * This library is distributed in the hope that it will be useful,
|
||
|
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||
|
+ * Lesser General Public License for more details.
|
||
|
+ *
|
||
|
+ * You should have received a copy of the GNU Lesser General Public
|
||
|
+ * License along with this library; if not, write to the Free Software
|
||
|
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||
|
+ */
|
||
|
+
|
||
|
+#include <config.h>
|
||
|
+
|
||
|
+#include "guestfs.h"
|
||
|
+#include "guestfs-internal.h"
|
||
|
+#include "guestfs-internal-actions.h"
|
||
|
+
|
||
|
+char *
|
||
|
+guestfs_impl_inspect_get_osinfo (guestfs_h *g, const char *root)
|
||
|
+{
|
||
|
+ CLEANUP_FREE char *type = NULL;
|
||
|
+ CLEANUP_FREE char *distro = NULL;
|
||
|
+ int major, minor;
|
||
|
+
|
||
|
+ type = guestfs_inspect_get_type (g, root);
|
||
|
+ if (!type)
|
||
|
+ return NULL;
|
||
|
+ distro = guestfs_inspect_get_distro (g, root);
|
||
|
+ if (!distro)
|
||
|
+ return NULL;
|
||
|
+ major = guestfs_inspect_get_major_version (g, root);
|
||
|
+ minor = guestfs_inspect_get_minor_version (g, root);
|
||
|
+
|
||
|
+ if (STREQ (type, "linux")) {
|
||
|
+ if (STREQ (distro, "centos")) {
|
||
|
+ if (major >= 7)
|
||
|
+ return safe_asprintf (g, "%s%d.0", distro, major);
|
||
|
+ else if (major == 6)
|
||
|
+ return safe_asprintf (g, "%s%d.%d", distro, major, minor);
|
||
|
+ }
|
||
|
+ else if (STREQ (distro, "debian")) {
|
||
|
+ if (major >= 4)
|
||
|
+ return safe_asprintf (g, "%s%d", distro, major);
|
||
|
+ }
|
||
|
+ else if (STREQ (distro, "fedora") || STREQ (distro, "mageia"))
|
||
|
+ return safe_asprintf (g, "%s%d", distro, major);
|
||
|
+ else if (STREQ (distro, "sles")) {
|
||
|
+ if (minor == 0)
|
||
|
+ return safe_asprintf (g, "%s%d", distro, major);
|
||
|
+ else
|
||
|
+ return safe_asprintf (g, "%s%dsp%d", distro, major, minor);
|
||
|
+ }
|
||
|
+ else if (STREQ (distro, "ubuntu"))
|
||
|
+ return safe_asprintf (g, "%s%d.%02d", distro, major, minor);
|
||
|
+
|
||
|
+ if (major > 0 || minor > 0)
|
||
|
+ return safe_asprintf (g, "%s%d.%d", distro, major, minor);
|
||
|
+ }
|
||
|
+ else if (STREQ (type, "freebsd") || STREQ (type, "netbsd") || STREQ (type, "openbsd"))
|
||
|
+ return safe_asprintf (g, "%s%d.%d", distro, major, minor);
|
||
|
+ else if (STREQ (type, "dos")) {
|
||
|
+ if (STREQ (distro, "msdos"))
|
||
|
+ return safe_strdup (g, "msdos6.22");
|
||
|
+ }
|
||
|
+
|
||
|
+ /* No ID could be guessed, return "unknown". */
|
||
|
+ return safe_strdup (g, "unknown");
|
||
|
+}
|
||
|
--
|
||
|
2.21.0
|
||
|
|