• הרשמה
    • התחברות
    • חיפוש
    • דף הבית
    • אינדקס קישורים
    • פוסטים אחרונים
    • קבלת התראות מהדפדפן
    • משתמשים
    • חיפוש בהגדרות המתקדמות
    • חיפוש גוגל בפורום
    • ניהול המערכת
    • ניהול המערכת - שרת private

    בדיקת קוד פייתון

    עזרה הדדית למשתמשים מתקדמים
    5
    19
    78
    טוען פוסטים נוספים
    • מהישן לחדש
    • מהחדש לישן
    • הכי הרבה הצבעות
    תגובה
    • הגיבו כנושא
    התחברו בכדי לפרסם תגובה
    נושא זה נמחק. רק משתמשים עם הרשאות מתאימות יוכלו לצפות בו.
    • ה
      האדם החושב נערך לאחרונה על ידי

      @ישראללוי לא יעבוד, אתה מעלה למערכת את נתיב הקובץ, הפרמטרים להעלאה לא נכונים, נראה שאתה מנסה לשלוח לימות url של קובץ מרוחק, מה שאתה צריך לעשות זה להוריד אותו אצלך מקומית ולהעלות את תוכן הקובץ לימות.

      תגובה 1 תגובה אחרונה תגובה ציטוט 0
      • י
        ישראללוי @צדיק תמים נערך לאחרונה על ידי ישראללוי

        @צדיק-תמים כתב בבדיקת קוד פייתון:

        @ישראללוי אם זה סקריפט חד פעמי אתה יכול לוותר על הלוגין ולוגאאוט ופשוט לשלוח בפרמטר טוקן את המשתמש והסיסמה עם נקודותיים ביניהם
        לא עברתי על שאר הקוד

        תקנתי כעצתך תודה רבה

        @האדם-החושב כתב בבדיקת קוד פייתון:

        @ישראללוי לא יעבוד, אתה מעלה למערכת את נתיב הקובץ, הפרמטרים להעלאה לא נכונים, נראה שאתה מנסה לשלוח לימות url של קובץ מרוחק, מה שאתה צריך לעשות זה להוריד אותו אצלך מקומית ולהעלות את תוכן הקובץ לימות.

        קוד מתוקן

        import os
        import shutil
        import requests
        import json  # <-- ייבוא חיוני לפיענוח תגובות API
        from dotenv import load_dotenv
        
        # --- טעינת משתני סביבה מקובץ .env ---
        load_dotenv()
        
        # הגדרת תיקיית הורדות
        # DOWNLOAD_FOLDER = 'downloads'
        # os.makedirs(DOWNLOAD_FOLDER, exist_ok=True)
        
        # --- משתנים גלובליים עבור ה-API ---
        YEMOT_API_USERNAME = os.getenv("YEMOT_USERNAME")
        YEMOT_API_PASSWORD = os.getenv("YEMOT_PASSWORD")
        YEMOT_API_URL = "https://www.call2all.co.il/ym/api"
        
        # -------------------------------------------------------------------
        # בדיקת תלות - האם FFmpeg מותקן?
        # -------------------------------------------------------------------
        if not shutil.which('ffmpeg'):
            print("--------------------------------------------------")
            print("אזהרה: FFmpeg לא נמצא במערכת שלך.")
            print("המרת קבצים ל-WAV לא תעבוד ללא FFmpeg.")
            print("אנא התקן אותו והוסף אותו ל-PATH של המערכת.")
            print("--------------------------------------------------")
        
        # -------------------------------------------------------------------
        # חלק 1: פונקציית עזר מתוקנת לתקשורת עם ימות המשיח
        # -------------------------------------------------------------------
        
        def process_yemot_api(local_wav_path, remote_filename):
            """
            Handles the entire Yemot API process: Login, Upload, and Logout.
            Uses JSON parsing for modern API responses and robust error handling.
            """
            if not YEMOT_API_USERNAME or not YEMOT_API_PASSWORD:
                print("שגיאה: שם משתמש או סיסמה של ימות המשיח לא הוגדרו בקובץ .env")
                return False
        
            session = requests.Session()
            print(f"שלב 1: מעלה את הקובץ '{local_wav_path}' אל '{remote_filename}.wav'...")
            
            # הנתיב צריך להיות רק התיקייה, שם הקובץ מועבר בנפרד
            target_path_folder = "IVR2/8"
            
            upload_params = {
                "token": f"{YEMOT_API_USERNAME}:{YEMOT_API_PASSWORD}",  # שימוש בטוקן הנכון שחולץ מה-JSON
                "what": "ivr_sync",
                "path": target_path_folder,
            }
            
            try:
                with open(local_wav_path, 'rb') as f:
                    # שם הקובץ בהעלאה צריך להיות עם סיומת .wav
                    files = {'file': (f'{remote_filename}.wav', f, 'audio/wav')}
                    response = session.post(f"{YEMOT_API_URL}/UploadFile", params=upload_params, files=files, timeout=90) # Timeout ארוך יותר להעלאה
                    response.raise_for_status()
        
                data = response.json()
                if data.get("responseStatus") == "OK":
                    print(f"העלאת הקובץ '{remote_filename}.wav' לשלוחה 8 הצליחה!")
                    return True
                else:
                    error_message = data.get("message", "שגיאה לא ידועה מה-API")
                    print(f"שגיאת העלאת קובץ: {error_message}")
                    return False
        
            except requests.exceptions.RequestException as e:
                print(f"שגיאת רשת בעת העלאת קובץ: {e}")
                return False
            except FileNotFoundError:
                print(f"שגיאה קריטית: לא נמצא קובץ מקומי להעלאה בנתיב {local_wav_path}")
                return False
            except json.JSONDecodeError:
                print(f"שגיאה בפענוח תגובת ה-API בעת העלאה. תגובה גולמית: {response.text}")
                return False
        
        if __name__ == "__main__":
            print("\n--- מתחיל הרצת בדיקה מקומית ---")
            
            # ודא שיש לך קובץ בשם 'a.wav' באותה תיקייה
            local_file = "a.wav"
            remote_name = "aaa_test" # שם הקובץ כפי שיופיע במערכת
            
            if os.path.exists(local_file):
                success = process_yemot_api(local_file, remote_name)
                if success:
                    print(f"\nהתהליך הושלם בהצלחה. הקובץ '{remote_name}.wav' אמור להיות בשלוחה 8.")
                else:
                    print("\nהתהליך נכשל. בדוק את הודעות השגיאה למעלה.")
            else:
                print(f"שגיאת בדיקה: הקובץ '{local_file}' לא נמצא. צור קובץ זה כדי להריץ את הבדיקה.")
            
            print("--- סיום הרצת בדיקה ---\n")
        

        מה לא נכון? תודה רבה

        תגובה 1 תגובה אחרונה תגובה ציטוט 0
        • פ
          פיסטוק פרווה מומחה נערך לאחרונה על ידי

          @ישראללוי כתב בבדיקת קוד פייתון:

          target_path_folder = "IVR2/8"

          יש לך כמה שגיאות קודם כל בשורה 46:

          target_path_folder = "IVR2/8"
          

          תשנה ל:

          target_path_folder = "ivr/8/"
          

          תוסיף בפרמס: autoNumbering: true
          כדי שזה יעלה במספור אוטומטי או שתשנה את הנתיב שיהיה את שם הקובץ + סיומת
          לדוגמא

          target_path_folder = "ivr/8/000.wav"
          
          י 2 תגובות תגובה אחרונה תגובה ציטוט 0
          • י
            ישראללוי @פיסטוק פרווה נערך לאחרונה על ידי

            פוסט זה נמחק!
            תגובה 1 תגובה אחרונה תגובה ציטוט 0
            • י
              ישראללוי @פיסטוק פרווה נערך לאחרונה על ידי ישראללוי

              @פיסטוק-פרווה זה הקריאה המועדכנת
              זה תקין?

                          response = session.post(f"{YEMOT_API_URL}/UploadFile", headers={
                              "token": f"{YEMOT_API_USERNAME}:{YEMOT_API_PASSWORD}",
                              "path": "IVR2/8/a.wav"
                              }, files={'file': (f'{remote_filename}.wav', f, 'audio/wav')}
                          , timeout=90) # Timeout ארוך יותר להעלאה
                          response.raise_for_status()
              

              זה תקין?

                              "token": f"{YEMOT_API_USERNAME}:{YEMOT_API_PASSWORD}",
              
              

              זה מחזיר שגיאה
              שגיאת העלאת קובץ: IllegalStateException(session token is required)

              פ תגובה 1 תגובה אחרונה תגובה ציטוט 0
              • פ
                פיסטוק פרווה מומחה @ישראללוי נערך לאחרונה על ידי

                @ישראללוי
                זה לא קורא טוב את הערכים מה .env
                איך רשמת ב ENV. (בלי סיסמה)

                י תגובה 1 תגובה אחרונה תגובה ציטוט 0
                • י
                  ישראללוי @פיסטוק פרווה נערך לאחרונה על ידי ישראללוי

                  @פיסטוק-פרווה
                  YEMOT_USERNAME=************
                  YEMOT_PASSWORD=*********
                  הטוקן והנתיב צריכים להיות בעדר או בפרמס?

                  פ תגובה 1 תגובה אחרונה תגובה ציטוט 0
                  • פ
                    פיסטוק פרווה מומחה @ישראללוי נערך לאחרונה על ידי

                    @ישראללוי
                    נראה לי שאפשר גם וגם אבל עדיף בפרמס

                    י תגובה 1 תגובה אחרונה תגובה ציטוט 0
                    • פ
                      פיסטוק פרווה מומחה נערך לאחרונה על ידי

                      @ישראללוי כתב בבדיקת קוד פייתון:

                      YEMOT_API_USERNAME

                      תוסיף פרינט של היוזר והסיסמה בהפעלת הקוד אחרי שזה נמשך מה env

                      י תגובה 1 תגובה אחרונה תגובה ציטוט 0
                      • י
                        ישראללוי @פיסטוק פרווה נערך לאחרונה על ידי

                        @פיסטוק-פרווה כתב בבדיקת קוד פייתון:

                        @ישראללוי כתב בבדיקת קוד פייתון:

                        YEMOT_API_USERNAME

                        תוסיף פרינט של היוזר והסיסמה בהפעלת הקוד אחרי שזה נמשך מה env

                        הדפסתי והערכים תקינים

                        תגובה 1 תגובה אחרונה תגובה ציטוט 0
                        • C
                          CUBASE נערך לאחרונה על ידי CUBASE

                          לא הבנתי למה צריך ffmpeg?, המערכת ממירה לבד את הקובץ

                          תגובה 1 תגובה אחרונה תגובה ציטוט 0
                          • י
                            ישראללוי @פיסטוק פרווה נערך לאחרונה על ידי

                            @פיסטוק-פרווה כתב בבדיקת קוד פייתון:

                            @ישראללוי
                            נראה לי שאפשר גם וגם אבל עדיף בפרמס

                            זה המעודכן

                                    with open(local_wav_path, 'rb') as f:
                                        # שם הקובץ בהעלאה צריך להיות עם סיומת .wav
                                        response = session.post(f"{YEMOT_API_URL}/UploadFile",
                                            params={
                                                "token": f"{YEMOT_API_USERNAME}:{YEMOT_API_PASSWORD}",
                                                "path":"IVR2/8/a.wav"
                                            },
                                            headers={
                                                "files": files
                                            }
                                        , timeout=90)
                            
                            

                            תקין?

                            C תגובה 1 תגובה אחרונה תגובה ציטוט 0
                            • C
                              CUBASE @ישראללוי נערך לאחרונה על ידי

                              @ישראללוי ה-path שוב לא תקין, תחליף ל-ivr/8/a.wav

                              י תגובה 1 תגובה אחרונה תגובה ציטוט 0
                              • י
                                ישראללוי @CUBASE נערך לאחרונה על ידי ישראללוי

                                @CUBASE כתב בבדיקת קוד פייתון:

                                @ישראללוי ה-path שוב לא תקין, תחליף ל-ivr/8/a.wav

                                זה המעודכן

                                        with open(local_wav_path, 'rb') as f:
                                            # שם הקובץ בהעלאה צריך להיות עם סיומת .wav
                                            files = {'file': (f'{remote_filename}.wav', f, 'audio/wav')}
                                            response = session.post(f"{YEMOT_API_URL}/UploadFile",
                                                params={
                                                    "token": f"{YEMOT_API_USERNAME}:{YEMOT_API_PASSWORD}",
                                                    "path":"ivr/8/a.wav"
                                                },
                                                headers={
                                                    "files": files
                                                }
                                            , timeout=90)
                                
                                

                                תקין?

                                עריכה זה המעודכן

                                        with open(local_wav_path, 'rb') as f:
                                            # שם הקובץ בהעלאה צריך להיות עם סיומת .wav
                                            files = {'file': (f'{remote_filename}.wav', f, 'audio/wav')}
                                            response = session.post(f"{YEMOT_API_URL}/UploadFile",
                                                params={
                                                    "token": f"{YEMOT_API_USERNAME}:{YEMOT_API_PASSWORD}",
                                                    "path":"ivr/8/a.wav"
                                                },
                                                files=files,
                                                headers={
                                                    "Content-Type": "multipart/form-data"
                                                },
                                                timeout=90
                                            )
                                
                                
                                י תגובה 1 תגובה אחרונה תגובה ציטוט 0
                                • י
                                  ישראללוי @ישראללוי נערך לאחרונה על ידי

                                  @ישראללוי כתב בבדיקת קוד פייתון:

                                  @CUBASE כתב בבדיקת קוד פייתון:

                                  @ישראללוי ה-path שוב לא תקין, תחליף ל-ivr/8/a.wav

                                  זה המעודכן

                                          with open(local_wav_path, 'rb') as f:
                                              # שם הקובץ בהעלאה צריך להיות עם סיומת .wav
                                              files = {'file': (f'{remote_filename}.wav', f, 'audio/wav')}
                                              response = session.post(f"{YEMOT_API_URL}/UploadFile",
                                                  params={
                                                      "token": f"{YEMOT_API_USERNAME}:{YEMOT_API_PASSWORD}",
                                                      "path":"ivr/8/a.wav"
                                                  },
                                                  headers={
                                                      "files": files
                                                  }
                                              , timeout=90)
                                  
                                  

                                  תקין?

                                  עריכה זה המעודכן

                                          with open(local_wav_path, 'rb') as f:
                                              # שם הקובץ בהעלאה צריך להיות עם סיומת .wav
                                              files = {'file': (f'{remote_filename}.wav', f, 'audio/wav')}
                                              response = session.post(f"{YEMOT_API_URL}/UploadFile",
                                                  params={
                                                      "token": f"{YEMOT_API_USERNAME}:{YEMOT_API_PASSWORD}",
                                                      "path":"ivr/8/a.wav"
                                                  },
                                                  files=files,
                                                  headers={
                                                      "Content-Type": "multipart/form-data"
                                                  },
                                                  timeout=90
                                              )
                                  
                                  

                                  זה תקין?

                                  ה תגובה 1 תגובה אחרונה תגובה ציטוט 0
                                  • ה
                                    האדם החושב @ישראללוי נערך לאחרונה על ידי האדם החושב

                                    @ישראללוי

                                    from uuid import uuid4
                                    
                                    import requests    
                                    
                                    class Yemot:
                                        BASE_URL = "https://www.call2all.co.il/ym/api/"
                                    
                                        def __init__(
                                                self,
                                                user_name: str,
                                                password: str | int,
                                        ) -> None:
                                            self.token = f"{user_name}:{password}"
                                            self.params = {
                                                "token": self.token
                                            }
                                    
                                        def upload_file(self, path: str, blob: bytes, file_name: str, base_path: str = "ivr2:/") -> bool:
                                            total_size = len(blob)
                                            chunk_size = 49 * 1024 * 1024
                                            chunks = [blob[offset:offset + chunk_size] for offset in range(0, total_size, chunk_size)]
                                            if len(chunks) == 1:
                                                return self._upload_small_file(path, blob, file_name, base_path)
                                            else:
                                                return self._upload_large_file(path, chunks, file_name, total_size, base_path)
                                    
                                        def _upload_small_file(self, path: str, blob: bytes, file_name: str, base_path: str) -> bool:
                                            data = {
                                                "path": f"{base_path}{path}",
                                                "convertAudio": "1",
                                                "autoNumbering": "true",
                                            }
                                            data.update(self.params)
                                            files = {"file": (file_name, blob)}
                                            url = f"{self.BASE_URL}UploadFile"
                                            response = requests.post(url, files=files, data=data).json()
                                            return response["responseStatus"] == "OK"
                                    
                                        def _upload_large_file(self, path: str, chunks: list[bytes], file_name: str, content_size: int, base_path: str) -> bool:
                                            qquuid = str(uuid4())
                                            offset = 0
                                            for index, chunk in enumerate(chunks):
                                                data = {
                                                    "path": f"{base_path}{path}",
                                                    "qquuid": qquuid,
                                                    "convertAudio": "1",
                                                    "autoNumbering": "true",
                                                    "uploader": "yemot-admin",
                                                    "qqfilename": file_name,
                                                    "qqtotalfilesize": content_size,
                                                    "qqtotalparts": len(chunks),
                                                    "qqchunksize": len(chunk),
                                                    "qqpartbyteoffset": offset,
                                                    "qqpartindex": index,
                                                }
                                                data.update(self.params)
                                                files = {
                                                    "qqfile": chunk,
                                                }
                                                url = f"{self.BASE_URL}UploadFile"
                                                response = requests.post(url, data=data, files=files).json()
                                                if not response["success"]:
                                                    print(f"Error uploading chunk {index}: {response}")
                                                    return False
                                                offset += len(chunk)
                                    
                                            data = {
                                                "path": f"{base_path}{path}",
                                                "uploader": "yemot-admin",
                                                "convertAudio": "1",
                                                "autoNumbering": "true",
                                                "qquuid": qquuid,
                                                "qqfilename": file_name,
                                                "qqtotalfilesize": content_size,
                                                "qqtotalparts": len(chunks),
                                            }
                                            data.update(self.params)
                                            response = requests.post(f"{self.BASE_URL}UploadFile?done", data=data).json()
                                            return response["responseStatus"] == "OK"
                                    
                                    
                                    תגובה 1 תגובה אחרונה תגובה ציטוט 0
                                    • פוסט ראשון
                                      פוסט אחרון