Hot-keys on this page
r m x p toggle line displays
j k next/prev highlighted chunk
0 (zero) top of page
1 (one) first highlighted chunk
#!/usr/bin/env python3 # vim: set fileencoding=utf-8
# Copyright © 2021 Pavel Tisnovsky # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License.
# Schema for metadata sub-node Required("cluster_id"): uuidValidator, Required("external_organization"): posIntInStringValidator })
# Schema for metadata sub-node in report sub-node Required("feature_id"): str, # TODO: more strict checking possible? Required("component"): str, # TODO: more strict checking possible? })
# Schema for all schema fields Required("name"): str, # TODO: more strict checking possible? Required("type"): str, # TODO: more strict checking possible? })
# Schema for schema sub-node Required("version"): posFloatInStringValidator, Required("fields"): [schemaFieldValidator], })
# Schema for data items Required("cluster_id"): uuidValidator, Optional("value"): Any(int, float, str), Optional("last_transition_time"): timestampValidatorNoZ, Optional("path"): pathToCephValidator, }, extra=ALLOW_EXTRA)
# Schema for report sub-nodes Required("metadata"): reportMetadataSchema, Required("schema"): schemaSchema, Required("data"): [dataSchema], })
# Schema for messages consumed from ccx-XXX-insights-operator-archive-features Kafka topic Required("path"): pathToCephValidator, Required("metadata"): metadataSchema, Required("report"): [reportSchema], })
"""Entry point to this script.""" # Parse all CLI arguments. verbose = args.verbose multiple = args.multiple input_file = args.input
if multiple: # process multiple messages stored in one input file report = validate_multiple_messages(schema, input_file, verbose) else: # process single message stored in one input file report = validate_single_message(schema, input_file, verbose)
# print report from schema validation print_report(report, args.nocolors)
main() |