-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcli.py
More file actions
92 lines (79 loc) · 2.92 KB
/
cli.py
File metadata and controls
92 lines (79 loc) · 2.92 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
from __future__ import annotations
import argparse
import sys
from pathlib import Path
from openapi_python.generator import GenerationRequest, try_generate_client
def _build_parser() -> argparse.ArgumentParser:
parser = argparse.ArgumentParser(prog="openapi-python")
subcommands = parser.add_subparsers(dest="command", required=True)
generate = subcommands.add_parser(
"generate", help="Generate a typed client from an OpenAPI spec"
)
spec_input = generate.add_mutually_exclusive_group(required=True)
spec_input.add_argument("--spec", help="Path or URL to OpenAPI source")
spec_input.add_argument("--spec-json", help="OpenAPI source as a JSON string")
generate.add_argument("--out", required=True, help="Output directory")
generate.add_argument(
"--package", default="my_client", help="Generated package name"
)
generate.add_argument(
"--overwrite", action="store_true", help="Overwrite existing generated files"
)
generate.add_argument(
"--no-ssl",
action="store_true",
help="Disable SSL certificate verification for URL specs",
)
generate.add_argument(
"--protocol-only",
action="store_true",
help="Require supplied transports instead of generating built-in httpx transports",
)
generate.add_argument(
"--routes",
action=argparse.BooleanOptionalAction,
default=True,
help="Generate route literal types and route-specific client overloads (DEFAULT: True)",
)
generate.add_argument(
"--requests",
action=argparse.BooleanOptionalAction,
default=True,
help="Generate typed params, query, header, and body protocol arguments (DEFAULT: True)",
)
generate.add_argument(
"--responses",
action=argparse.BooleanOptionalAction,
default=True,
help="Generate typed protocol response values (DEFAULT: True)",
)
return parser
def main(argv: list[str] | None = None) -> int:
parser = _build_parser()
args = parser.parse_args(argv)
if args.command != "generate":
parser.print_help()
return 2
request = GenerationRequest(
output_dir=Path(args.out),
spec_source=args.spec,
spec_json=args.spec_json,
package_name=args.package,
overwrite=args.overwrite,
verify_ssl=not args.no_ssl,
protocol_only=args.protocol_only,
generate_routes=args.routes,
generate_requests=args.requests,
generate_responses=args.responses,
)
result = try_generate_client(request)
if not result.success:
print(result.diagnostics[0], file=sys.stderr)
return 2
print(
f"Generated {len(result.written_files)} files for package '{args.package}' "
f"({result.operations} operations, {result.type_definitions} type definitions)."
)
return 0
if __name__ == "__main__":
raise SystemExit(main())