소스 검색

rework to simple string input

Karl Hudgell 6 달 전
부모
커밋
b633706e56
1개의 변경된 파일20개의 추가작업 그리고 14개의 파일을 삭제
  1. 20 14
      main.py

+ 20 - 14
main.py

@@ -23,32 +23,38 @@ create_config(client)
 # Check if any arguments are passed
 if len(sys.argv) > 1:
     # Get the JSON argument from the command line
-    json_str = sys.argv[1]
+    input_str = sys.argv[1]
 
     try:
         # Convert the JSON string into a dictionary
-        disc_data = json.loads(json_str.replace("'",'"'))
-        # Check if disc is the same as last inserted
-        if (disc_data == json.loads(check_current_disc(client))):
-            # If disc is the same, PLAY
-            control_player(client, "PLAY")
-        else:
-            # Pass the parsed data to the update_disc function
-            control_player(client, "PLAY")
-            update_disc(client, disc_data)
+        disc_data = input_str.split(":")
+        if disc_data[0] == "ytmusic":
+            disc_object = {
+                "Name":disc_data[1],
+                "type":disc_data[2],
+                "id":disc_data[3]
+            }
+            # Check if disc is the same as last inserted
+            if (disc_object == json.loads(check_current_disc(client))):
+                # If disc is the same, PLAY
+                control_player(client, "PLAY")
+            else:
+                # Pass the parsed data to the update_disc function
+                control_player(client, "PLAY")
+                update_disc(client, disc_data)
     except json.JSONDecodeError as e:
         try:
-            if json_str == "EJECT":
+            if input_str == "EJECT":
                 # PAUSE the current playing item
                 control_player(client, "PAUSE")
-            elif json_str == "PLAY":
+            elif input_str == "PLAY":
                 # PLAY the current playing item
                 control_player(client, "PLAY")
-            elif json_str == "PAUSE":
+            elif input_str == "PAUSE":
                 # PAUSE the current playing item
                 control_player(client, "PAUSE")                
             else:
-                print(f"Can't process {json_str}")
+                print(f"Can't process {input_str}")
         except Exception:
             print(f"Invalid JSON format: {e}")
 else: