##// END OF EJS Templates
merged dev into stable
merged dev into stable

File last commit:

r3896:8dae2a28 beta
r3969:351ad34d merge rhodecode-0.0.1.7.0 default
Show More
rhodecode_api.py
121 lines | 4.1 KiB | text/x-python | PythonLexer
created rhodecode-api binary script for working with api via cli...
r2379 # -*- coding: utf-8 -*-
"""
api: decouple some parts from api CLI script...
r3833 rhodecode.bin.api
~~~~~~~~~~~~~~~~~
created rhodecode-api binary script for working with api via cli...
r2379
Api CLI client for RhodeCode
:created_on: Jun 3, 2012
:author: marcink
:copyright: (C) 2010-2012 Marcin Kuzminski <marcin@python-works.com>
:license: GPLv3, see COPYING for more details.
"""
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# 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/>.
from __future__ import with_statement
import sys
import argparse
Added --format into gist CLI...
r3875 from rhodecode.bin.base import json, api_call, RcConf, FORMAT_JSON, FORMAT_PRETTY
created rhodecode-api binary script for working with api via cli...
r2379
def argparser(argv):
added --config option into rhodecode-api script for optional path for...
r2571 usage = (
api: decouple some parts from api CLI script...
r3833 "rhodecode-api [-h] [--format=FORMAT] [--apikey=APIKEY] [--apihost=APIHOST] "
"[--config=CONFIG] [--save-config] "
"METHOD <key:val> <key2:val> ...\n"
"Create config file: rhodecode-gist --apikey=<key> --apihost=http://rhodecode.server --save-config"
added --config option into rhodecode-api script for optional path for...
r2571 )
created rhodecode-api binary script for working with api via cli...
r2379
parser = argparse.ArgumentParser(description='RhodeCode API cli',
usage=usage)
## config
group = parser.add_argument_group('config')
group.add_argument('--apikey', help='api access key')
group.add_argument('--apihost', help='api host')
added --config option into rhodecode-api script for optional path for...
r2571 group.add_argument('--config', help='config file')
api: decouple some parts from api CLI script...
r3833 group.add_argument('--save-config', action='store_true', help='save the given config into a file')
created rhodecode-api binary script for working with api via cli...
r2379
group = parser.add_argument_group('API')
api: decouple some parts from api CLI script...
r3833 group.add_argument('method', metavar='METHOD', nargs='?', type=str, default=None,
created rhodecode-api binary script for working with api via cli...
r2379 help='API method name to call followed by key:value attributes',
)
Added optional --format=json into api cli. That will return pure JSON data from server
r2381 group.add_argument('--format', dest='format', type=str,
Added --format into gist CLI...
r3875 help='output format default: `%s` can '
'be also `%s`' % (FORMAT_PRETTY, FORMAT_JSON),
Added optional --format=json into api cli. That will return pure JSON data from server
r2381 default=FORMAT_PRETTY
)
created rhodecode-api binary script for working with api via cli...
r2379 args, other = parser.parse_known_args()
return parser, args, other
def main(argv=None):
"""
Main execution function for cli
:param argv:
"""
if argv is None:
argv = sys.argv
conf = None
parser, args, other = argparser(argv)
api_credentials_given = (args.apikey and args.apihost)
api: decouple some parts from api CLI script...
r3833 if args.save_config:
created rhodecode-api binary script for working with api via cli...
r2379 if not api_credentials_given:
api: decouple some parts from api CLI script...
r3833 raise parser.error('--save-config requires --apikey and --apihost')
added --config option into rhodecode-api script for optional path for...
r2571 conf = RcConf(config_location=args.config,
autocreate=True, config={'apikey': args.apikey,
created rhodecode-api binary script for working with api via cli...
r2379 'apihost': args.apihost})
api: decouple some parts from api CLI script...
r3833 sys.exit()
created rhodecode-api binary script for working with api via cli...
r2379
if not conf:
added --config option into rhodecode-api script for optional path for...
r2571 conf = RcConf(config_location=args.config, autoload=True)
created rhodecode-api binary script for working with api via cli...
r2379 if not conf:
if not api_credentials_given:
parser.error('Could not find config file and missing '
'--apikey or --apihost in params')
apikey = args.apikey or conf['apikey']
Added --format into gist CLI...
r3875 apihost = args.apihost or conf['apihost']
created rhodecode-api binary script for working with api via cli...
r2379 method = args.method
Show proper error on argument parse when using api-cli
r2509
Added --format into gist CLI...
r3875 # if we don't have method here it's an error
if not method:
parser.error('Please specify method name')
Show proper error on argument parse when using api-cli
r2509 try:
margs = dict(map(lambda s: s.split(':', 1), other))
Don't catch all exceptions
r3631 except Exception:
Show proper error on argument parse when using api-cli
r2509 sys.stderr.write('Error parsing arguments \n')
sys.exit()
Added --format into gist CLI...
r3875 if args.format == FORMAT_PRETTY:
print 'Calling method %s => %s' % (method, apihost)
created rhodecode-api binary script for working with api via cli...
r2379
API cli should prefer to display errors instead of responses
r3896 json_resp = api_call(apikey, apihost, method, **margs)
if json_resp['error']:
json_data = json_resp['error']
else:
json_data = json_resp['result']
Added --format into gist CLI...
r3875 if args.format == FORMAT_JSON:
print json.dumps(json_data)
elif args.format == FORMAT_PRETTY:
print 'Server response \n%s' % (
json.dumps(json_data, indent=4, sort_keys=True))
created rhodecode-api binary script for working with api via cli...
r2379 return 0
if __name__ == '__main__':
sys.exit(main(sys.argv))