123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186 |
- #!/usr/bin/env python
- import click
- import click_log
- import json
- import logging
- import os
- import sys
- from lakesuperior.api import admin as admin_api
- from lakesuperior.config_parser import config
- from lakesuperior.env import env
- from lakesuperior.store.ldp_rs.lmdb_store import TxnManager
- logger = logging.getLogger(__name__)
- click_log.basic_config(logger)
- @click.group()
- def admin():
- pass
- @click.command()
- def bootstrap():
- '''
- Bootstrap binary and graph stores.
- This script will parse configuration files and initialize a filesystem and
- triplestore with an empty FCREPO repository.
- It is used in test suites and on a first run.
- Additional scaffolding files may be parsed to create initial contents.
- '''
- rdfly = env.app_globals.rdfly
- nonrdfly = env.app_globals.nonrdfly
- click.echo(
- click.style(
- 'WARNING: This operation will WIPE ALL YOUR DATA.\n',
- bold=True, fg='red')
- + 'Are you sure? (Please type `yes` to continue) > ', nl=False)
- choice = input().lower()
- if choice != 'yes':
- click.echo('Aborting.')
- sys.exit(1)
- import lakesuperior.env_setup
- click.echo('Initializing graph store at {}'.format(rdfly.store.path))
- with TxnManager(env.app_globals.rdf_store, write=True) as txn:
- rdfly.bootstrap()
- rdfly.store.close()
- click.echo('Graph store initialized.')
- click.echo('Initializing binary store at {}'.format(nonrdfly.root))
- nonrdfly.bootstrap()
- click.echo('Binary store initialized.')
- click.echo('Repository successfully set up. Go to town.')
- @click.command()
- @click.option(
- '--human', '-h', is_flag=True, flag_value=True,
- help='Print a human-readable string. By default, JSON is printed.')
- def stats(human=False):
- '''
- Print repository statistics.
- @param human (bool) Whether to output the data in human-readable
- format.
- '''
- stat_data = admin_api.stats()
- if human:
- click.echo(
- 'This option is not supported yet. Sorry.\nUse the `/admin/stats`'
- ' endpoint in the web UI for a pretty printout.')
- else:
- click.echo(json.dumps(stat_data))
- @click.command()
- def check_fixity(uid):
- '''
- [STUB] Check fixity of a resource.
- '''
- pass
- @click.command()
- def check_refint():
- '''
- [STUB] Check referential integrity.
- This command scans the graph store to verify that all references to
- resources within the repository are effectively pointing to existing
- resources. For repositories set up with the `referencial_integrity` option
- (the default), this is a pre-condition for a consistent data set.
- '''
- pass
- @click.command()
- def cleanup():
- '''
- [STUB] Clean up orphan database items.
- '''
- pass
- @click.command()
- def copy():
- '''
- [STUB] Copy (backup) repository data.
- This s a low-level copy, which backs up the data directories containing
- graph and binary data. It may not even be a necessary command since to
- back up the repository one just needs to copy the binary and metadata
- folders.
- '''
- pass
- @click.command()
- @click.argument('src')
- @click.argument('dest')
- @click.option(
- '--start', '-s', default='/', show_default=True,
- help='Starting point for looking for resources in the repository.\n'
- 'The default `/` value starts at the root, i.e. migrates the whole '
- 'repository.')
- @click.option(
- '--zero-binaries', '-z', is_flag=True,
- help='If set, binaries are created as zero-byte files in the proper '
- 'folder structure rather than having their full content copied.')
- @click_log.simple_verbosity_option(logger)
- def migrate(src, dest, start, zero_binaries):
- '''
- Migrate an LDP repository to LAKEsuperior.
- This utility creates a fully functional LAKEshore repository from an
- existing repository. The source repo can be LAKEsuperior or
- another LDP-compatible implementation.
- A folder will be created in the location indicated by ``dest``. If the
- folder exists already, it will be deleted and recreated. The folder will be
- populated with the RDF and binary data directories and a default
- configuration directory. The new repository can be immediately started
- from this location.
- '''
- logger.info('Migrating {} into a new repository on {}.'.format(
- src, dest))
- entries = admin_api.migrate(
- src, dest, start=start, zero_binaries=zero_binaries)
- logger.info('Migrated {} resources.'.format(entries))
- logger.info('''Migration complete. To start the new repository, from the
- directory you launched this script run:
- FCREPO_CONFIG_DIR="{}/etc" ./fcrepo
- Make sure that the default port is not being used by another repository.
- '''.format(dest))
- @click.command()
- @click.argument('src')
- @click.argument('dest')
- def load(src, dest):
- '''
- [STUB] Load serialized repository data.
- Load serialized data from a filesystem location into a Fedora repository.
- The Fedora repo can be LAKEsuperior or another compatible implementation.
- '''
- pass
- admin.add_command(bootstrap)
- admin.add_command(check_fixity)
- admin.add_command(check_refint)
- admin.add_command(cleanup)
- admin.add_command(copy)
- admin.add_command(load)
- admin.add_command(migrate)
- admin.add_command(stats)
- if __name__ == '__main__':
- admin()
|