[PATCH 07 of 17 v3] cli: convert 'gearbox repo-scan' into 'kallithea-cli repo-scan'

Thomas De Schampheleire patrickdepinguin at gmail.com
Thu Oct 18 20:49:30 UTC 2018


# HG changeset patch
# User Thomas De Schampheleire <thomas.de_schampheleire at nokia.com>
# Date 1539024021 -7200
#      Mon Oct 08 20:40:21 2018 +0200
# Node ID 14d028cae3da185a91fa9025df498632913ff056
# Parent  949f164c58c8cccd17b76f9720e21783c8f391ec
cli: convert 'gearbox repo-scan' into 'kallithea-cli repo-scan'

diff --git a/docs/dev/dbmigrations.rst b/docs/dev/dbmigrations.rst
--- a/docs/dev/dbmigrations.rst
+++ b/docs/dev/dbmigrations.rst
@@ -31,7 +31,7 @@ 4. After every database schema change, r
 
     rm temp.db
     gearbox setup-db -c temp.ini --repos=/var/repos --user=doe --email doe at example.com --password=123456 --no-public-access --force-yes
-    gearbox repo-scan -c temp.ini
+    kallithea-cli repo-scan temp.ini
 
 5. Once satisfied with the schema changes, auto-generate a draft Alembic
    script using the development database that has *not* been upgraded.
diff --git a/kallithea/bin/kallithea_cli.py b/kallithea/bin/kallithea_cli.py
--- a/kallithea/bin/kallithea_cli.py
+++ b/kallithea/bin/kallithea_cli.py
@@ -20,3 +20,4 @@ import kallithea.bin.kallithea_cli_cache
 import kallithea.bin.kallithea_cli_celery
 import kallithea.bin.kallithea_cli_config
 import kallithea.bin.kallithea_cli_ishell
+import kallithea.bin.kallithea_cli_repo
diff --git a/kallithea/lib/paster_commands/repo_scan.py b/kallithea/bin/kallithea_cli_repo.py
rename from kallithea/lib/paster_commands/repo_scan.py
rename to kallithea/bin/kallithea_cli_repo.py
--- a/kallithea/lib/paster_commands/repo_scan.py
+++ b/kallithea/bin/kallithea_cli_repo.py
@@ -12,53 +12,39 @@
 # You should have received a copy of the GNU General Public License
 # along with this program.  If not, see <http://www.gnu.org/licenses/>.
 """
-kallithea.lib.paster_commands.repo_scan
-~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-
-repo-scan gearbox command for Kallithea
-
-This file was forked by the Kallithea project in July 2014.
+This file was forked by the Kallithea project in July 2014 and later moved.
 Original author and date, and relevant copyright and licensing information is below:
 :created_on: Feb 9, 2013
 :author: marcink
 :copyright: (c) 2013 RhodeCode GmbH, and others.
 :license: GPLv3, see LICENSE.md for more details.
 """
-
-
+import click
+from kallithea.bin.kallithea_cli_base import cli
+import kallithea.bin.kallithea_cli_util as cli_util
 
+from kallithea.lib.utils import repo2db_mapper
 from kallithea.model.scm import ScmModel
-from kallithea.lib.paster_commands.common import BasePasterCommand
-from kallithea.lib.utils import repo2db_mapper
 
-
-class Command(BasePasterCommand):
-    """Kallithea: Scan file system for repositories
-
-    Search under the repository root configured in the database,
-    all new repositories, and report missing ones with an option of removing them.
-    """
+ at cli.command()
+ at cli_util.auto_setup_app()
+ at click.option('--remove-missing', is_flag=True,
+        help='Remove missing repositories from the Kallithea database.')
+def repo_scan(config_file, remove_missing):
+    """Scan filesystem for repositories.
 
-    def take_action(self, args):
-        rm_obsolete = args.delete_obsolete
-        print 'Now scanning root location for new repos ...'
-        added, removed = repo2db_mapper(ScmModel().repo_scan(),
-                                        remove_obsolete=rm_obsolete)
-        print 'Scan completed.'
-        if added:
-            print 'Added: %s' % ', '.join(added)
-        if removed:
-            print '%s: %s' % ('Removed' if rm_obsolete else 'Missing',
-                              ', '.join(removed))
-
-    def get_parser(self, prog_name):
-        parser = super(Command, self).get_parser(prog_name)
-
-        parser.add_argument(
-            '--delete-obsolete',
-            action='store_true',
-            help="Use this flag do delete repositories that are "
-                 "present in Kallithea database but not on the filesystem",
-        )
-
-        return parser
+    Search the configured repository root for new repositories and add them
+    into Kallithea.
+    Additionally, report repositories that were previously known to Kallithea
+    but are no longer present on the filesystem. If option --remove-missing is
+    given, remove the missing repositories from the Kallithea database.
+    """
+    click.echo('Now scanning root location for new repos ...')
+    added, removed = repo2db_mapper(ScmModel().repo_scan(),
+                                    remove_obsolete=remove_missing)
+    click.echo('Scan completed.')
+    if added:
+        click.echo('Added: %s' % ', '.join(added))
+    if removed:
+        click.echo('%s: %s' % ('Removed' if remove_missing else 'Missing',
+                          ', '.join(removed)))
diff --git a/setup.py b/setup.py
--- a/setup.py
+++ b/setup.py
@@ -162,7 +162,6 @@ setuptools.setup(
     install-iis=kallithea.lib.paster_commands.install_iis:Command
     make-index=kallithea.lib.paster_commands.make_index:Command
     make-rcext=kallithea.lib.paster_commands.make_rcextensions:Command
-    repo-scan=kallithea.lib.paster_commands.repo_scan:Command
     setup-db=kallithea.lib.paster_commands.setup_db:Command
     update-repoinfo=kallithea.lib.paster_commands.update_repoinfo:Command
     upgrade-db=kallithea.lib.dbmigrate:UpgradeDb


More information about the kallithea-general mailing list