This repository has been archived by the owner on Aug 23, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathredfishProfileSimulator.py
125 lines (101 loc) · 5.08 KB
/
redfishProfileSimulator.py
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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
# Copyright Notice:
# Copyright 2016 Distributed Management Task Force, Inc. All rights reserved.
# License: BSD 3-Clause License. For full text see link: https://github.com/DMTF/Redfish-Profile-Simulator/blob/main/LICENSE.md
# This program is dependent on the following Python packages that should be installed separately with pip:
# pip install Flask
#
# standard python packages
import sys
import getopt
import os
rfVersion = "0.9.6"
rfProgram1 = "redfishProfileSimulator"
rfProgram2 = " "
rfUsage1 = "[-Vh] [--Version][--help]"
rfUsage2 = "[-H<hostIP>] [-P<port>] [-p<profile_path>]"
rfUsage3 = "[--Host=<hostIP>] [--Port=<port>] [--profile_path=<profile_path>]"
def rf_usage():
print("Usage:")
print(" ", rfProgram1, " ", rfUsage1)
print(" ", rfProgram1, " ", rfUsage2)
print(" ", rfProgram2, " ", rfUsage3)
def rf_help():
print(rfProgram1,"implements a simulation of a redfish service for the \"Simple OCP Server V1\" Mockup.")
print(" The simulation includes an http server, RestEngine, and dynamic Redfish datamodel.")
print(" You can GET, PATHCH,... to the service just like a real Redfish service.")
print(" Both Basic and Redfish Session/Token authentication is supported (for a single user/passwd and token")
print(" the user/passwd is: root/password123456. The authToken is: 123456SESSIONauthcode")
print(" these can be changed by editing the redfishURIs.py file. will make dynamic later.")
print(" The http service and Rest engine is built on Flask, and all code is Python 3.4+")
print(" The data model resources are \"initialized\" from the SPMF \"SimpleOcpServerV1\" Mockup.")
print(" and stored as python dictionaries--then the dictionaries are updated with patches, posts, deletes.")
print(" The program can be extended to support other mockup \"profiles\".")
print("")
print(" By default, the simulation runs on localhost (127.0.0.1), on port 5000.")
print(" These can be changed with CLI options: -P<port> -H <hostIP> | --port=<port> --host=<hostIp>")
print("")
print("Version: ", rfVersion)
rf_usage()
print("")
print(" -V, --Version, --- the program version")
print(" -h, --help, --- help")
print(" -H<hostIP>, --Host=<hostIp> --- host IP address. dflt=127.0.0.1")
print(" -P<port>, --Port=<port> --- the port to use. dflt=5000")
print(" -p<profile_path>, --profile=<profile_path> --- the path to the Redfish profile to use. "
"dflt=\"./MockupData/SimpleOcpServerV1\" ")
def main(argv):
# set default option args
rf_profile_path = os.path.abspath("./MockupData/SimpleOcpServerV1")
rf_host = "127.0.0.1"
rf_port = 5000
try:
opts, args = getopt.getopt(argv[1:], "VhH:P:p:",
["Version", "help", "Host=", "Port=", "profile="])
except getopt.GetoptError:
print(rfProgram1, ": Error parsing options")
rf_usage()
sys.exit(2)
for opt, arg in opts:
if opt in ("-h", "--help"):
rf_help()
sys.exit(0)
elif opt in ("-V", "--Version"):
print("Version:", rfVersion)
sys.exit(0)
elif opt in ("-p", "--profile"):
rf_profile_path = arg
elif opt in "--Host=":
rf_host = arg
elif opt in "--Port=":
rf_port=int(arg)
else:
print(" ", rfProgram1, ": Error: unsupported option")
rf_usage()
sys.exit(2)
print("{} Version: {}".format(rfProgram1,rfVersion))
print(" Starting redfishProfileSimulator at: hostIP={}, port={}".format(rf_host, rf_port))
print(" Using Profile at {}".format(rf_profile_path))
if os.path.isdir(rf_profile_path):
# import the classes and code we run from main.
from v1sim.serviceVersions import RfServiceVersions
from v1sim.serviceRoot import RfServiceRoot
# rfApi_SimpleServer is a function in ./RedfishProfileSim/redfishURIs.py.
# It loads the flask APIs (URIs), and starts the flask service
from v1sim.redfishURIs import rfApi_SimpleServer
# create the root service resource
root_path = os.path.normpath("redfish/v1")
# create the version resource for GET /redfish
versions = RfServiceVersions(rf_profile_path, "redfish")
root = RfServiceRoot(rf_profile_path, root_path)
# start the flask REST API service
rfApi_SimpleServer(root, versions, host=rf_host, port=rf_port)
else:
print("invalid profile path")
if __name__ == "__main__":
main(sys.argv)
#http://127.0.0.1:5000/
#app.run(host="0.0.0.0") # run on all IPs
#run(host=None, port=None, debug=None, **options)
# host=0.0.0.0 server avail externally -- all IPs
# host=127.0.0.1 is default
# port=5000 default, or port defined in SERVER_NAME config var