|
| 1 | +#!/usr/bin/env python3 |
| 2 | + |
| 3 | +print("****************") |
| 4 | +print("TimeTracker CLI") |
| 5 | +print("****************") |
| 6 | + |
| 7 | +import os |
| 8 | + |
| 9 | +from flask import json |
| 10 | +from flask_script import Manager |
| 11 | + |
| 12 | +from time_tracker_api import create_app |
| 13 | +from time_tracker_api.api import api |
| 14 | + |
| 15 | +app = create_app() |
| 16 | +cli_manager = Manager(app) |
| 17 | + |
| 18 | + |
| 19 | +@cli_manager.command |
| 20 | +@cli_manager.option('-f', '--filename', |
| 21 | + dest='filename', |
| 22 | + help='Path of the swagger file. By default swagger.json') |
| 23 | +def gen_swagger_json(filename='swagger.json'): |
| 24 | + """ Exports swagger specifications in json format """ |
| 25 | + schema_json_data = json.dumps(api.__schema__) |
| 26 | + save_data(schema_json_data, filename) |
| 27 | + |
| 28 | + |
| 29 | +@cli_manager.command |
| 30 | +@cli_manager.option('-f', '--filename', |
| 31 | + dest='filename', |
| 32 | + help='Path of the postman collection file.' |
| 33 | + 'By default it is timetracker-api-postman-collection.json') |
| 34 | +@cli_manager.option('-b', '--base-url-placeholder', |
| 35 | + dest='base_url_placeholder', |
| 36 | + help='Text used as placeholder. E.g. {{timetracker_api_host}}.' |
| 37 | + 'By default the base url will be http://localhost') |
| 38 | +def gen_postman_collection(filename='timetracker-api-postman-collection.json', |
| 39 | + base_url_placeholder=None): |
| 40 | + """ Generates a Postman collection for the API """ |
| 41 | + data = api.as_postman(urlvars=False, swagger=True) |
| 42 | + postman_collection_json_data = json.dumps(data) |
| 43 | + if base_url_placeholder is not None: |
| 44 | + parsed_json = postman_collection_json_data.replace("http://localhost", base_url_placeholder) |
| 45 | + else: |
| 46 | + parsed_json = postman_collection_json_data |
| 47 | + |
| 48 | + save_data(parsed_json, filename) |
| 49 | + |
| 50 | + |
| 51 | +def save_data(data: str, filename: str) -> None: |
| 52 | + """ Save text content to a file """ |
| 53 | + if filename: |
| 54 | + try: |
| 55 | + real_path = os.path.expanduser(filename) |
| 56 | + with open(real_path, "w") as f: |
| 57 | + f.write(data) |
| 58 | + print("%s was generated successfully" % real_path) |
| 59 | + except OSError as err: |
| 60 | + print("Error while generating '%s': %s" % filename, err) |
| 61 | + else: |
| 62 | + print(data) |
| 63 | + |
| 64 | + |
| 65 | +if __name__ == "__main__": |
| 66 | + cli_manager.run() |
0 commit comments