Matteo Scandolo | 431781c | 2017-09-06 15:33:07 -0700 | [diff] [blame] | 1 | # Copyright 2017-present Open Networking Foundation |
| 2 | # |
| 3 | # Licensed under the Apache License, Version 2.0 (the "License"); |
| 4 | # you may not use this file except in compliance with the License. |
| 5 | # You may obtain a copy of the License at |
| 6 | # |
| 7 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 8 | # |
| 9 | # Unless required by applicable law or agreed to in writing, software |
| 10 | # distributed under the License is distributed on an "AS IS" BASIS, |
| 11 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 12 | # See the License for the specific language governing permissions and |
| 13 | # limitations under the License. |
| 14 | |
| 15 | import os |
Zack Williams | 6714216 | 2019-03-06 14:01:32 -0700 | [diff] [blame] | 16 | import traceback |
Scott Baker | de2f7ff | 2018-12-19 16:00:09 -0800 | [diff] [blame] | 17 | from xosgenx.generator import XOSProcessor, XOSProcessorArgs |
Matteo Scandolo | 431781c | 2017-09-06 15:33:07 -0700 | [diff] [blame] | 18 | |
| 19 | CWD = OUTPUT_DIR = os.path.abspath(os.path.dirname(os.path.realpath(__file__))) |
| 20 | SWAGGER_DOCS_DIR = os.path.abspath(CWD + '/../swagger/specs') |
Matteo Scandolo | 6451409 | 2019-02-20 10:47:48 -0800 | [diff] [blame] | 21 | REPO_DIR = os.path.abspath(CWD + "/../../../") |
Matteo Scandolo | 431781c | 2017-09-06 15:33:07 -0700 | [diff] [blame] | 22 | |
| 23 | class Args: |
| 24 | pass |
| 25 | |
| 26 | def generate_swagger_docs(xproto): |
| 27 | |
| 28 | # if not os.path.isfile(xproto): |
| 29 | # print "ERROR: Couldn't find xproto file for %s at: %s" % (service, xproto) |
| 30 | # return |
| 31 | |
| 32 | print "Generating swagger docs for %s" % (xproto) |
Scott Baker | de2f7ff | 2018-12-19 16:00:09 -0800 | [diff] [blame] | 33 | args = XOSProcessorArgs() |
Matteo Scandolo | 431781c | 2017-09-06 15:33:07 -0700 | [diff] [blame] | 34 | args.files = xproto |
| 35 | args.target = 'swagger.xtarget' |
| 36 | args.output = SWAGGER_DOCS_DIR |
| 37 | args.write_to_file = "single" |
| 38 | args.dest_file = "swagger.yaml" |
| 39 | args.quiet = False |
| 40 | try: |
Sapan Bhatia | bfb233a | 2018-02-09 14:53:09 -0800 | [diff] [blame] | 41 | XOSProcessor.process(args) |
Zack Williams | 6714216 | 2019-03-06 14:01:32 -0700 | [diff] [blame] | 42 | except Exception: |
Matteo Scandolo | 431781c | 2017-09-06 15:33:07 -0700 | [diff] [blame] | 43 | print "ERROR: Couldn't generate swagger specs" |
Zack Williams | 6714216 | 2019-03-06 14:01:32 -0700 | [diff] [blame] | 44 | traceback.print_exc() |
Matteo Scandolo | 431781c | 2017-09-06 15:33:07 -0700 | [diff] [blame] | 45 | |
Matteo Scandolo | b8a4b12 | 2018-01-19 13:36:22 -0800 | [diff] [blame] | 46 | def get_xproto_recursively(root): |
| 47 | files = [] |
| 48 | items = os.listdir(root) |
| 49 | # iterate over the content of the folder excluding hidden items |
| 50 | for item in [i for i in items if i[0] is not "."]: |
Scott Baker | 73cb2c6 | 2019-06-04 15:40:16 -0700 | [diff] [blame] | 51 | if ("venv" in item) or ("virtualenv" in item): |
| 52 | # avoid recursing through virtual env directories |
| 53 | continue |
| 54 | if "xos-genx-tests" in item: |
| 55 | # don't generate docs for xosgenx's unit tests |
| 56 | continue |
Scott Baker | 0b04606 | 2019-06-04 18:01:18 -0700 | [diff] [blame] | 57 | if "xos-tosca" in item: |
| 58 | # don't generate docs for xos-tosca's unit tests |
| 59 | continue |
Matteo Scandolo | b8a4b12 | 2018-01-19 13:36:22 -0800 | [diff] [blame] | 60 | item_abs_path = os.path.abspath(root + "/" + item) |
| 61 | if os.path.isdir(item_abs_path): |
| 62 | files = files + get_xproto_recursively(item_abs_path) |
Matteo Scandolo | 6451409 | 2019-02-20 10:47:48 -0800 | [diff] [blame] | 63 | elif os.path.isfile(item_abs_path) and ".xproto" in item_abs_path: |
Matteo Scandolo | b8a4b12 | 2018-01-19 13:36:22 -0800 | [diff] [blame] | 64 | files.append(item_abs_path) |
| 65 | |
Scott Baker | f755532 | 2019-06-05 10:03:03 -0700 | [diff] [blame^] | 66 | protos = [f for f in files if "xproto" in f] |
| 67 | |
| 68 | protos = sorted(protos) |
| 69 | |
| 70 | # remove the core xproto... |
| 71 | core_proto = None |
| 72 | for proto in protos[:]: |
| 73 | if "core.xproto" in proto: |
| 74 | protos.remove(proto) |
| 75 | core_proto = proto |
| 76 | |
| 77 | # ... and put it at the front of the list |
| 78 | if core_proto: |
| 79 | protos = [core_proto] + protos |
| 80 | |
| 81 | return protos |
Matteo Scandolo | b8a4b12 | 2018-01-19 13:36:22 -0800 | [diff] [blame] | 82 | |
| 83 | |
Matteo Scandolo | 431781c | 2017-09-06 15:33:07 -0700 | [diff] [blame] | 84 | def main(): |
| 85 | |
Matteo Scandolo | 6451409 | 2019-02-20 10:47:48 -0800 | [diff] [blame] | 86 | protos = get_xproto_recursively(REPO_DIR) |
Matteo Scandolo | 431781c | 2017-09-06 15:33:07 -0700 | [diff] [blame] | 87 | |
Matteo Scandolo | 6451409 | 2019-02-20 10:47:48 -0800 | [diff] [blame] | 88 | generate_swagger_docs(protos) |
Matteo Scandolo | 431781c | 2017-09-06 15:33:07 -0700 | [diff] [blame] | 89 | |
| 90 | |
| 91 | if __name__ == '__main__': |
Sapan Bhatia | bfb233a | 2018-02-09 14:53:09 -0800 | [diff] [blame] | 92 | main() |