Metadata-Version: 2.1
Name: jenkins-backup-restore-cli
Version: 1.1.2
Summary: A Jenkins backup and restore python cli tool with arguments.
Home-page: https://github.com/venkatalolla/jenkins-backup-restore.git
Author: Surya Lolla
Author-email: suryasaicharan93@gmail.com
License: MIT
Description: # Python Jenkins Backup Restore Module
        
        [![PyPI - Downloads](https://img.shields.io/pypi/dm/jenkins-backup-restore-cli?style=plastic)](https://pypi.org/project/jenkins-backup-restore-cli/)
        [![PyPI - Version](https://img.shields.io/pypi/v/jenkins-backup-restore-cli?style=plasticl&logo=pypi)](https://pypi.org/project/jenkins-backup-restore-cli/)
        
        jenkins-backup-restore-cli module takes a backup of the jenkins home directory and restores it as required.
        
        ```
              _            _    _             ____             _
             | |          | |  (_)           |  _ \           | |
             | | ___ _ __ | | ___ _ __  ___  | |_) | __ _  ___| | ___   _ _ __
         _   | |/ _ \ '_ \| |/ / | '_ \/ __| |  _ < / _` |/ __| |/ / | | | '_ \
        | |__| |  __/ | | |   <| | | | \__ \ | |_) | (_| | (__|   <| |_| | |_) |
         \____/ \___|_| |_|_|\_\_|_| |_|___/ |____/ \__,_|\___|_|\_\\__,_| .__/
                                                                         | |
                                                                         |_|
         _____           _                    _____ _ _
        |  __ \         | |                  / ____| (_)
        | |__) |___  ___| |_ ___  _ __ ___  | |    | |_
        |  _  // _ \/ __| __/ _ \| '__/ _ \ | |    | | |
        | | \ \  __/\__ \ || (_) | | |  __/ | |____| | |
        |_|  \_\___||___/\__\___/|_|  \___|  \_____|_|_|
        
        
        ``` 
        
        ## Prerequisites
        - python2.7 or higher
        - pip or pip3 
        
        ## Installation
        Run the following command to install the jenkins-backup-restore-cli,
        ```
        pip3 install jenkins-backup-restore-cli
        ```
        
        ## What does it do?
        The jenkins-backup-restore-cli tool will backup the jenkins_home directory as well as restores it.
        
        #### Backup
        * The backup module will look for a jenkins-home directory
        * Tar it into a temporary directory.
        * Copy the tarfile to an user specified location or to a AWS s3 bucket.
        * Delete the temporary directory (can be persisted with `--persist-tmp-archive`)
        
        #### Restore
        * The restore module will look for a jenkins-home directory that needs to be restored
        * create a tmp directory and copy the tarfile or download the tarfile from an s3 bucket to it.
        * Untar the tarfile in that temporary directory
        * Make a copy of existing jenkins_home directory
        * Replace the old jenkins_home with the untarred jenkins_home
        * Delete the temporary directory (can be persisted with `--persist-tmp-archive`)
        
        ## Backup and restore
        jenkins-backup-restore-cli common options for both backup and restore,
        
        ### Common Options
        
        ##### `--version`
        Shows version number of the package
        ```
        jenkins-backup-restore-cli --version
        ```
        
        ##### `--custom-archive-name`
        To create a backup tarfile with the custom name, 
        ```
        jenkins-backup-restore-cli --custom-archive-name my-backup
        ```
        > Note: If not provided, it will backup with the default name (default: jenkins_backup.tar.gz)
        
        
        ##### `--jenkins-home-dir`
        * user should provide a `--jenkins-home-dir`. 
        * If the user specified directory does not exists, tool looks for a default location (default: `/var/jenkins_home`)
        * If the default location does not exists, the tool will look for an `JENKINS_HOME` environment variable.
        ```
        jenkins-backup-restore-cli --jenkins-home-dir /var/lib/jenkins
        ```
        
        > Note:  In above each step the tool will throw a warning and throws an error if environment variable does not exists or 
        > the path set in the value does not exists. 
        
        ### Commands
        
        #### Backup Commands
        
        To backup jenkins_home, either one of the following commands with arguments can be used,
        
        * `backup-local` - Take a backup in the local machine (same machine where jenkins is running)
        
          * `--backup-destination-path`, local path to store the backup
         
        ```
        jenkins-backup-restore-cli --jenkins-home-dir <jenkins_home> backup-local --backup-destination-path <local-path>
        ```
        
        * `backup-s3` - Take a backup and push it to an s3 bucket
        
          * `--backup-bucket-name`, s3 bucket name to store the backup.
          * `--persist-tmp-archive`, persists(True) or delete(False) the archive, in the temporary path once the archive pushed to s3 bucket (default: `False`)
        
        ```
        jenkins-backup-restore-cli --jenkins-home-dir <jenkins_home> backup-s3 --backup-bucket-name <bucket-name> --persist-tmp-archive True
        ```
        
        #### Restore Commands
        
        To restore jenkins_home, either one of the following commands with arguments can be used,
        
        * `restore-local` - Restore from a local jenkins backup tarfile
        
          * `--restore-archive-path`, local path to the backup tarfile
          * `--persist-tmp-archive`, persists(True) or delete(False) the archive in the temporary path once the archive is extracted to jenkins_home (default: `False`)
          
        ```
        jenkins-backup-restore-cli --jenkins-home-dir <jenkins_home> restore-local --restore-archive-path <path-to-backup-tarfile> --persist-tmp-archive True
        ```
        
        * `restore-s3` - Restore from a s3 bucket
        
          * `--restore-bucket-name`, bucket name to download the archive from
          * `--restore-archive-download-path`, local path to download the archive from s3 bucket
          * `--persist-tmp-archive`, persists(True) or delete(False) the archive in the temporary path once the archive is extracted to jenkins_home (default: `False`)
        
        ```
        jenkins-backup-restore-cli --jenkins-home-dir <jenkins_home> restore-s3 --restore-bucket-path <bucket-name> --restore-archive-download-path <local-path-to-download-tarfile> --persist-tmp-archive True
        ```
         
        > ##### Note: For any help, use `--help` flag. 
        
        ## Dockerfile
        A [Dockerfile](Dockerfile) that has the jenkins-backup-restore-cli latest package installed on it.
        
        
        ## Helm Chart
        A Helm chart for the jenkins-backup-restore-cli tool to perform backup and restore on Jenkins pod running in a Kubernetes cluster, find a README.md [here](jenkins-backup-restore-cli/README.md). 
Keywords: Jenkins backup and restore cli
Platform: UNKNOWN
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: End Users/Desktop
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: System Administrators
Classifier: Topic :: System :: Systems Administration
Classifier: Topic :: System :: Recovery Tools
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Operating System :: MacOS :: MacOS X
Classifier: Operating System :: POSIX
Description-Content-Type: text/markdown
