Hello community,

here is the log from the commit of package cloud-init for openSUSE:Factory 
checked in at 2016-11-18 22:01:48
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/cloud-init (Old)
 and      /work/SRC/openSUSE:Factory/.cloud-init.new (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Package is "cloud-init"

Changes:
--------
--- /work/SRC/openSUSE:Factory/cloud-init/cloud-init.changes    2016-11-12 
13:02:33.000000000 +0100
+++ /work/SRC/openSUSE:Factory/.cloud-init.new/cloud-init.changes       
2016-11-18 22:01:49.000000000 +0100
@@ -1,0 +2,5 @@
+Sun Nov 13 13:33:41 CET 2016 - ku...@suse.de
+
+- Add zypp_add_repos.diff to support repos for zypper [FATE#322038]
+
+-------------------------------------------------------------------

New:
----
  zypp_add_repos.diff

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Other differences:
------------------
++++++ cloud-init.spec ++++++
--- /var/tmp/diff_new_pack.vgqFpX/_old  2016-11-18 22:01:50.000000000 +0100
+++ /var/tmp/diff_new_pack.vgqFpX/_new  2016-11-18 22:01:50.000000000 +0100
@@ -50,6 +50,7 @@
 Patch25:        cloud-init-digital-ocean-datasource.patch
 Patch26:        cloud-init-digital-ocean-datasource-enable-by-default.patch
 Patch27:        cloud-init-sysconfig-netpathfix.patch
+Patch28:       zypp_add_repos.diff
 BuildRequires:  fdupes
 BuildRequires:  filesystem
 BuildRequires:  python-devel
@@ -176,6 +177,7 @@
 %patch25 -p1
 %patch26 -p1
 %patch27
+%patch28 -p0
 
 %if 0%{?suse_version} <= 1130
 # disable ecdsa for SLE 11 (not available)

++++++ cloud.cfg.suse ++++++
--- /var/tmp/diff_new_pack.vgqFpX/_old  2016-11-18 22:01:50.000000000 +0100
+++ /var/tmp/diff_new_pack.vgqFpX/_new  2016-11-18 22:01:50.000000000 +0100
@@ -29,6 +29,7 @@
  - ssh-import-id
  - locale
  - set-passwords
+ - zypp_add_repo
  - package-update-upgrade-install
  - timezone
  - puppet

++++++ zypp_add_repos.diff ++++++
--- cloudinit/config/cc_zypp_add_repo.py
+++ cloudinit/config/cc_zypp_add_repo.py        2016/11/13 16:56:21
@@ -0,0 +1,106 @@
+# vi: ts=4 expandtab
+#
+#    This file is based on cc_yum_add_repo.py:
+#
+#    Copyright (C) 2012 Yahoo! Inc.
+#
+#    Author: Joshua Harlow <harlo...@yahoo-inc.com>
+#
+#    This program is free software: you can redistribute it and/or modify
+#    it under the terms of the GNU General Public License version 3, as
+#    published by the Free Software Foundation.
+#
+#    This program 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 General Public License for more details.
+#
+#    You should have received a copy of the GNU General Public License
+#    along with this program.  If not, see <http://www.gnu.org/licenses/>.
+
+import os
+
+import configobj
+import six
+
+from cloudinit import util
+
+distros = ['opensuse', 'sles']
+
+
+def _canonicalize_id(repo_id):
+    repo_id = repo_id.replace(" ", "_")
+    return repo_id
+
+
+def _format_repo_value(val):
+    if isinstance(val, (bool)):
+        # zypp prefers 1/0
+        return str(int(val))
+    if isinstance(val, (list, tuple)):
+        return "\n    ".join([_format_repo_value(v) for v in val])
+    if not isinstance(val, six.string_types):
+        return str(val)
+    return val
+
+
+def _format_repository_config(repo_id, repo_config):
+    to_be = configobj.ConfigObj()
+    to_be[repo_id] = {}
+    # Do basic translation of the items -> values
+    for (k, v) in repo_config.items():
+        # For now assume that people using this know the format
+        # of zypper repos  and don't verify keys/values further
+        to_be[repo_id][k] = _format_repo_value(v)
+    lines = to_be.write()
+    lines.insert(0, "# Created by cloud-init on %s" % (util.time_rfc2822()))
+    return "\n".join(lines)
+
+
+def handle(name, cfg, _cloud, log, _args):
+    repos = cfg.get('zypp_repos')
+    if not repos:
+        log.debug(("Skipping module named %s,"
+                   " no 'zypp_repos' configuration found"), name)
+        return
+    repo_base_path = util.get_cfg_option_str(cfg, 'zypp_repo_dir',
+                                             '/etc/zypp/repos.d/')
+    repo_locations = {}
+    repo_configs = {}
+    for (repo_id, repo_config) in repos.items():
+        canon_repo_id = _canonicalize_id(repo_id)
+        repo_fn_pth = os.path.join(repo_base_path, "%s.repo" % (canon_repo_id))
+        if os.path.exists(repo_fn_pth):
+            log.info("Skipping repo %s, file %s already exists!",
+                     repo_id, repo_fn_pth)
+            continue
+        elif canon_repo_id in repo_locations:
+            log.info("Skipping repo %s, file %s already pending!",
+                     repo_id, repo_fn_pth)
+            continue
+        if not repo_config:
+            repo_config = {}
+        # Do some basic sanity checks/cleaning
+        n_repo_config = {}
+        for (k, v) in repo_config.items():
+            k = k.lower().strip().replace("-", "_")
+            if k:
+                n_repo_config[k] = v
+        repo_config = n_repo_config
+        missing_required = 0
+        for req_field in ['baseurl']:
+            if req_field not in repo_config:
+                log.warn(("Repository %s does not contain a %s"
+                          " configuration 'required' entry"),
+                         repo_id, req_field)
+                missing_required += 1
+        if not missing_required:
+            repo_configs[canon_repo_id] = repo_config
+            repo_locations[canon_repo_id] = repo_fn_pth
+        else:
+            log.warn("Repository %s is missing %s required fields, skipping!",
+                     repo_id, missing_required)
+    for (c_repo_id, path) in repo_locations.items():
+        repo_blob = _format_repository_config(c_repo_id,
+                                              repo_configs.get(c_repo_id))
+        util.write_file(path, repo_blob)
--- doc/examples/cloud-config-zypp-repo.txt
+++ doc/examples/cloud-config-zypp-repo.txt     2016/11/13 17:04:12
@@ -0,0 +1,18 @@
+#cloud-config
+# vim: syntax=yaml
+#
+# Add zypper repository configuration to the system
+#
+# The following example adds the file /etc/zypp/repos.d/EPEL_TESTING.repo
+# which can then subsequently be used by zypper for later operations.
+zypp_repos:
+    # The name of the repository
+    EPEL_Testing:
+        # Any repository configuration options
+        name: Extra Packages for Testing
+        enabled: true
+        autorefresh: true
+        keeppackages: false
+        baseurl: http://download.example.com/ibs/EPEL/1.0/standard/
+        gpgcheck: true
+        gpgkey: 
http://download.example.com/ibs/EPEL/1.0/standard/repodata/repomd.xml.key

Reply via email to