Merge "Allow update to provide plugin_info via yaml"
This commit is contained in:
commit
5be08a5be6
@ -313,6 +313,22 @@ To delete jobs/views that only have 'foo' in their name::
|
|||||||
|
|
||||||
jenkins-jobs delete --path ./myjobs \*foo\*
|
jenkins-jobs delete --path ./myjobs \*foo\*
|
||||||
|
|
||||||
|
Providing Plugins Info
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
With Jenkins LTS 1.651.1+ retrieving plugins info became a secure feature and
|
||||||
|
now requires Administrator rights to use [#f2]. This causes JJB to no longer be
|
||||||
|
able to work in situations where a user wants to publish jobs to Jenkins but is
|
||||||
|
not able to receive the Administrator permissions. In this case we can provide
|
||||||
|
a plugins_info.yaml file containing the plugin versions data needed by JJB to
|
||||||
|
parse the job templates.
|
||||||
|
|
||||||
|
To generate a plugins info, using an account with Administrator rights:
|
||||||
|
|
||||||
|
jenkins-jobs get-plugins-info -o plugins_info.yaml
|
||||||
|
|
||||||
|
To run JJB update using the plugins_info.yaml:
|
||||||
|
|
||||||
|
jenkins-jobs update -p plugins_info.yaml ./myjobs
|
||||||
|
|
||||||
.. _command-reference:
|
.. _command-reference:
|
||||||
|
|
||||||
@ -323,8 +339,11 @@ Command Reference
|
|||||||
.. program-output:: jenkins-jobs update --help
|
.. program-output:: jenkins-jobs update --help
|
||||||
.. program-output:: jenkins-jobs delete-all --help
|
.. program-output:: jenkins-jobs delete-all --help
|
||||||
.. program-output:: jenkins-jobs delete --help
|
.. program-output:: jenkins-jobs delete --help
|
||||||
|
.. program-output:: jenkins-jobs get-plugins-info --help
|
||||||
|
|
||||||
.. rubric:: Footnotes
|
.. rubric:: Footnotes
|
||||||
.. [#f1] The cache default location is at ``~/.cache/jenkins_jobs``, which
|
.. [#f1] The cache default location is at ``~/.cache/jenkins_jobs``, which
|
||||||
can be overridden by setting the ``XDG_CACHE_HOME`` environment
|
can be overridden by setting the ``XDG_CACHE_HOME`` environment
|
||||||
variable.
|
variable.
|
||||||
|
.. [#f2] Jenkins Security Advisory affecting plugins info retrieval
|
||||||
|
https://wiki.jenkins-ci.org/display/SECURITY/Jenkins+Security+Advisory+2016-05-11
|
||||||
|
@ -80,6 +80,18 @@ To delete a job::
|
|||||||
|
|
||||||
The above command deletes the job `simple` from the Jenkins master.
|
The above command deletes the job `simple` from the Jenkins master.
|
||||||
|
|
||||||
|
.. _use-case-5:
|
||||||
|
|
||||||
|
Use Case 5: Providing plugins info
|
||||||
|
----------------------------------
|
||||||
|
|
||||||
|
To generate a plugins info, using an account with Administrator rights:
|
||||||
|
|
||||||
|
jenkins-jobs get-plugins-info -o plugins_info.yaml
|
||||||
|
|
||||||
|
To run JJB update using the plugins_info.yaml:
|
||||||
|
|
||||||
|
jenkins-jobs update -p plugins_info.yaml ./myjobs
|
||||||
|
|
||||||
|
|
||||||
Please refer to the jenkins-jobs :ref:`command-reference` and the
|
Please refer to the jenkins-jobs :ref:`command-reference` and the
|
||||||
|
57
jenkins_jobs/cli/subcommand/get_plugins_info.py
Normal file
57
jenkins_jobs/cli/subcommand/get_plugins_info.py
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
# Copyright (C) 2017 Thanh Ha
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
|
||||||
|
import logging
|
||||||
|
|
||||||
|
import yaml
|
||||||
|
|
||||||
|
from jenkins_jobs.builder import JenkinsManager
|
||||||
|
import jenkins_jobs.cli.subcommand.base as base
|
||||||
|
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
class GetPluginsInfoSubCommand(base.BaseSubCommand):
|
||||||
|
|
||||||
|
def parse_args(self, subparser):
|
||||||
|
plugins_info = subparser.add_parser(
|
||||||
|
'get-plugins-info',
|
||||||
|
help='get plugins info yaml by querying Jenkins server.')
|
||||||
|
|
||||||
|
plugins_info.add_argument(
|
||||||
|
'-o', '--output-file',
|
||||||
|
default='plugins_info.yaml',
|
||||||
|
dest='plugins_info_file',
|
||||||
|
help='file to save output to.')
|
||||||
|
|
||||||
|
def execute(self, options, jjb_config):
|
||||||
|
builder = JenkinsManager(jjb_config)
|
||||||
|
plugin_data = builder.jenkins.get_plugins_info()
|
||||||
|
plugins_info = []
|
||||||
|
for plugin in plugin_data:
|
||||||
|
info = {
|
||||||
|
'longName': str(plugin['longName']),
|
||||||
|
'shortName': str(plugin['shortName']),
|
||||||
|
'version': str(plugin['version']),
|
||||||
|
}
|
||||||
|
plugins_info.append(info)
|
||||||
|
|
||||||
|
if options.plugins_info_file:
|
||||||
|
with open(options.plugins_info_file, 'w') as outfile:
|
||||||
|
outfile.write(yaml.dump(plugins_info))
|
||||||
|
logger.info("Generated {} file".format(options.plugins_info_file))
|
||||||
|
else:
|
||||||
|
print(yaml.dump(plugins_info))
|
@ -39,7 +39,7 @@ class TestSubCommand(update.UpdateSubCommand):
|
|||||||
default=False,
|
default=False,
|
||||||
help='use alternative output file layout using config.xml files')
|
help='use alternative output file layout using config.xml files')
|
||||||
test.add_argument(
|
test.add_argument(
|
||||||
'-p',
|
'-p', '--plugin-info',
|
||||||
dest='plugins_info_path',
|
dest='plugins_info_path',
|
||||||
default=None,
|
default=None,
|
||||||
help='path to plugin info YAML file')
|
help='path to plugin info YAML file')
|
||||||
|
@ -58,6 +58,13 @@ class UpdateSubCommand(base.BaseSubCommand):
|
|||||||
dest='delete_old',
|
dest='delete_old',
|
||||||
default=False,
|
default=False,
|
||||||
help='delete obsolete jobs')
|
help='delete obsolete jobs')
|
||||||
|
update.add_argument(
|
||||||
|
'-p', '--plugin-info',
|
||||||
|
dest='plugins_info_path',
|
||||||
|
default=None,
|
||||||
|
help='path to plugin info YAML file. Can be used to provide '
|
||||||
|
'previously retrieved plugins info when connecting credentials '
|
||||||
|
'don\'t have permissions to query.')
|
||||||
update.add_argument(
|
update.add_argument(
|
||||||
'--workers',
|
'--workers',
|
||||||
type=int,
|
type=int,
|
||||||
|
@ -40,6 +40,7 @@ jjb.cli.subcommands =
|
|||||||
test=jenkins_jobs.cli.subcommand.test:TestSubCommand
|
test=jenkins_jobs.cli.subcommand.test:TestSubCommand
|
||||||
delete=jenkins_jobs.cli.subcommand.delete:DeleteSubCommand
|
delete=jenkins_jobs.cli.subcommand.delete:DeleteSubCommand
|
||||||
delete-all=jenkins_jobs.cli.subcommand.delete_all:DeleteAllSubCommand
|
delete-all=jenkins_jobs.cli.subcommand.delete_all:DeleteAllSubCommand
|
||||||
|
get-plugins-info=jenkins_jobs.cli.subcommand.get_plugins_info:GetPluginsInfoSubCommand
|
||||||
jenkins_jobs.projects =
|
jenkins_jobs.projects =
|
||||||
externaljob=jenkins_jobs.modules.project_externaljob:ExternalJob
|
externaljob=jenkins_jobs.modules.project_externaljob:ExternalJob
|
||||||
flow=jenkins_jobs.modules.project_flow:Flow
|
flow=jenkins_jobs.modules.project_flow:Flow
|
||||||
|
Loading…
Reference in New Issue
Block a user