public inbox for devel@edk2.groups.io
 help / color / mirror / Atom feed
From: "Jayaprakash, N" <n.jayaprakash@intel.com>
To: "devel@edk2.groups.io" <devel@edk2.groups.io>,
	"Jayaprakash, N" <n.jayaprakash@intel.com>
Cc: Rebecca Cran <rebecca@bsdio.com>,
	"Kinney, Michael D" <michael.d.kinney@intel.com>
Subject: Re: [edk2-devel] [edk2-libc Patch 1/1] ek2-libc: Sample python scripts for socket client capabilities on UEFI shell
Date: Fri, 10 Nov 2023 15:41:51 +0000	[thread overview]
Message-ID: <PH7PR11MB594317B17D4B0E2F598C479DEEAEA@PH7PR11MB5943.namprd11.prod.outlook.com> (raw)
In-Reply-To: <179203AC4BBFEE91.3183@groups.io>

These are simple Python apps to demonstrate the usage of socket communication using the HTTP library. 
Reviewed-by : Jayaprakash N <n.jayaprakash@intel.com>

Regards,
JP
-----Original Message-----
From: devel@edk2.groups.io <devel@edk2.groups.io> On Behalf Of Jayaprakash, N
Sent: Friday, October 27, 2023 9:57 PM
To: devel@edk2.groups.io
Cc: Jayaprakash, N <n.jayaprakash@intel.com>; Rebecca Cran <rebecca@bsdio.com>; Kinney, Michael D <michael.d.kinney@intel.com>
Subject: [edk2-devel] [edk2-libc Patch 1/1] ek2-libc: Sample python scripts for socket client capabilities on UEFI shell

REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4580

This BZ has been created to provide the sample python scripts to demonstrate the socket client capabilities using http library on UEFI shell with the help of Python UEFI interpreter.
The http_echo_client.py and http_echo_server.py scripts are provided as sample scripts to exercise the python http library from UEFI shell.

Cc: Rebecca Cran <rebecca@bsdio.com>
Cc: Michael D Kinney <michael.d.kinney@intel.com>
Cc: Jayaprakash N <n.jayaprakash@intel.com>
Signed-off-by: Jayaprakash Nevara <n.jayaprakash@intel.com>
---
 .../PyMod-3.6.8/Lib/http_echo_client.py       | 81 +++++++++++++++++++
 .../PyMod-3.6.8/Lib/http_echo_server.py       | 61 ++++++++++++++
 2 files changed, 142 insertions(+)
 create mode 100644 AppPkg/Applications/Python/Python-3.6.8/PyMod-3.6.8/Lib/http_echo_client.py
 create mode 100644 AppPkg/Applications/Python/Python-3.6.8/PyMod-3.6.8/Lib/http_echo_server.py

diff --git a/AppPkg/Applications/Python/Python-3.6.8/PyMod-3.6.8/Lib/http_echo_client.py b/AppPkg/Applications/Python/Python-3.6.8/PyMod-3.6.8/Lib/http_echo_client.py
new file mode 100644
index 0000000..ea0368d
--- /dev/null
+++ b/AppPkg/Applications/Python/Python-3.6.8/PyMod-3.6.8/Lib/http_echo_
+++ client.py
@@ -0,0 +1,81 @@
+"""
+This is a sample HTTP echo client sends data to the server and gets 
+echoed data from the server in response body and prints the same to the 
+console.
+
+Note: This application needs to be run from UEFI shell using the Python 
+UEFI interpreter.
+"""
+
+import sys
+import time
+from http import client
+from http.client import HTTPException
+import traceback
+
+_max_retries = 10
+_retry_count = 0
+
+
+def _print_usage():
+    print("Sample http echo client application")
+    print("Usage:")
+    print("python.efi http_echo_client.py <ServerIPAddress>")
+
+
+if len(sys.argv) != 2:
+    _print_usage()
+    sys.exit(0)
+
+if sys.argv[1] == "-h":
+    _print_usage()
+    sys.exit(0)
+
+http_server = sys.argv[1]
+while True:
+    try:
+        name = input("Enter the parameter name:")
+        value = input("Enter parameter value:")
+        print("Connecting to server to send a get request with following parameter")
+        print("{}={}".format(name, value))
+        # replace space with %20
+        value = value.replace(" ", "%20")
+        conn = client.HTTPConnection(http_server)
+        # Send GET request with some data
+        conn.request("GET", "/echo?{}={}".format(name, value))
+        rsp = conn.getresponse()
+        if rsp.status == 204:
+            print("No content")
+            break
+        elif rsp.status == 200:
+            data_received = rsp.read()
+            # replace %20 with space character before displaying to console
+            data_received = data_received.replace(b"%20", b" ")
+            print("from server:{}".format(data_received))
+            conn.close()
+            print("Closing the connection")
+            break
+        else:
+            print("Invalid response code {}".format(rsp.status))
+            conn.close()
+            print("Closing the connection")
+            break
+    except HTTPException as exp:
+        print("Got exception while connecting to server : {}".format(exp))
+        traceback.print_exc()
+        break
+    except ConnectionRefusedError as exp:
+        print("Got exception while connecting to server : {}".format(exp))
+        print("Check & start the server, if it is not started")
+        print(
+            "Retrying connection after 10 seconds, retry count = {}".format(
+                _retry_count + 1
+            )
+        )
+        if _retry_count == _max_retries:
+            print(
+                "Exceeded max retries {} exiting the application".format(_max_retries)
+            )
+            break
+        time.sleep(10)
+        _retry_count += 1
diff --git a/AppPkg/Applications/Python/Python-3.6.8/PyMod-3.6.8/Lib/http_echo_server.py b/AppPkg/Applications/Python/Python-3.6.8/PyMod-3.6.8/Lib/http_echo_server.py
new file mode 100644
index 0000000..eebdf33
--- /dev/null
+++ b/AppPkg/Applications/Python/Python-3.6.8/PyMod-3.6.8/Lib/http_echo_
+++ server.py
@@ -0,0 +1,61 @@
+"""
+This is a sample HTTP echo server that echos the command / data coming 
+from the client.
+Here the data is received from client through GET request in the form 
+of parameter of GET request.
+The parameter is extracted and sent back to the client in the response 
+body.
+
+Note that this server sample application needs to be run on a system 
+booted to OS.
+"""
+
+import os
+import socket
+import sys
+from http.server import BaseHTTPRequestHandler, HTTPServer from 
+http.client import parse_headers
+
+
+class MyHTTPRequestHandler(BaseHTTPRequestHandler):
+    """HTTP request handler class"""
+
+    # Handle GET command
+    def do_GET(self):
+        print("path {}".format(self.path))
+        path = self.path.split("?")[0]
+        param_name = self.path.split("?")[1].split("=")[0]
+        param_value = self.path.split("?")[1].split("=")[1]
+        print("param name {} value = {}".format(param_name, param_value))
+        if path == "/echo":
+            self.send_response(200)
+            self.send_header("Content-type", "text/plain")
+            self.end_headers()
+            self.wfile.write(
+                bytes("{}={}".format(param_name, param_value), encoding="utf-8")
+            )
+        else:
+            print("invalid request")
+            self.send_response(204)
+
+
+def run():
+    try:
+        print("Starting the server...")
+        server_address = (socket.gethostbyname(socket.gethostname()), 80)
+        print("Server address :", server_address)
+        httpd = HTTPServer(server_address, MyHTTPRequestHandler)
+        print("\n\n\nPress CTRL+C to exit server application")
+        httpd.serve_forever()
+    except KeyboardInterrupt as exp:
+        print("KeyboardInterrupt")
+        sys.exit(0)
+    except Exception as exp:
+        print(str(exp))
+
+
+if __name__ == "__main__":
+    if os.name == "edk2":
+        print("HTTP echo server not supported on EDk2")
+        sys.exit(0)
+    run()
--
2.40.0.windows.1








-=-=-=-=-=-=-=-=-=-=-=-
Groups.io Links: You receive all messages sent to this group.
View/Reply Online (#111039): https://edk2.groups.io/g/devel/message/111039
Mute This Topic: https://groups.io/mt/102508927/7686176
Group Owner: devel+owner@edk2.groups.io
Unsubscribe: https://edk2.groups.io/g/devel/unsub [rebecca@openfw.io]
-=-=-=-=-=-=-=-=-=-=-=-



      parent reply	other threads:[~2023-11-10 15:41 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-10-27 16:27 [edk2-devel] [edk2-libc Patch 0/1] AppPkg/Python - Sample scripts to exercise socket functionality Jayaprakash, N
2023-10-27 16:27 ` [edk2-devel] [edk2-libc Patch 1/1] ek2-libc: Sample python scripts for socket client capabilities on UEFI shell Jayaprakash, N
2023-10-28 10:25   ` Laszlo Ersek
     [not found] ` <179203AC4BBFEE91.3183@groups.io>
2023-11-10 15:41   ` Jayaprakash, N [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-list from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=PH7PR11MB594317B17D4B0E2F598C479DEEAEA@PH7PR11MB5943.namprd11.prod.outlook.com \
    --to=devel@edk2.groups.io \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox