בקשה ! עזרה בכתיבת קוד לג'ימיל להעברת הודעות מייל
-
@גבאי בדקתי את הסקריפט בפועל (עד עכשיו כתבתי בעל פה בלי לנסות בפועל, כלומר בלי לבדוק שזה עובד)
ממה שראיתי - צורת העבודה של שילוב בין מסננים שמקצים תוויות, ואז הסקריפט מחפש את התוויות - זה מתכון לכאב ראש. המסננים האלו מקצים עוד פעם ועוד פעם את התוויות (אפילו שכבר טופל) וגורמים לסקריפט לרוץ שוב, אני לא יודע עד כמה זה טעות שלי בהגדרת המסננים (לא חושב שזה טעות שלי)
החלטתי לעבוד בלי מסננים.-
הסקריפט עצמו מחפש בהתחלה את כל המיילים - שלא מכתובת המדפסת ו-שללא תווית 'עובד' או 'בוצע'
אותם הוא מעביר (מנתח ובונה הודעה וכו') למדפסת.
ומקצה להן תווית 'עובד'. -
בנוסף הסקריפט מחפש את כל ההודעות שלא נקראו וש-מהמייל של המדפסת
אותם הוא מעביר (ראשון ראשון) להודעות שעם תווית 'עובד'
ומסיר מהן את תווית 'עובד'. ומסמן הודעת המדפסת כנקרא.
עשית בדיקות בפועל וזה עבד לי ללא שגיאות.
שים לב לכאורה אם אתה רוצה להפעיל את זה על אותו מייל שעד עכשיו ניסת איתו - תעבוד לפני כן למחוק את כל ההודעות הקודמות שיש להן תוויות 'עובד' או 'בוצע' או אני יודע מה, או תמחק את התוויות האלה - בכל אופן תבדוק שלא יהיה תוויות שיבלבלו את הסקריפט (זה יכול לבבלבל אותו גם אם זה נמצא אפילו ב'אשפה' . נראה לי)
וכמובן תמחק את המסנן שמוסיף את התווית 'להעברה'זה הקוד:
function redirect() { let printerEmail = 'printer@hp.com' // מייל של המדפסת let workinglabel = GmailApp.getUserLabelByName('working') // שם של תווית - עובד על זה let donelabel = GmailApp.getUserLabelByName('performed') // שם של תווית - בוצע let forwardmessages = GmailApp.search(`-from:${printerEmail} AND -label:working AND -label:performed`) if (forwardmessages.length > 0) { for (let formessage of forwardmessages) { let message = formessage.getMessages()[0] let subject = message.getSubject() let body = message.getBody() let attachments = message.getAttachments() MailApp.sendEmail(printerEmail, subject, '', { htmlBody: body, attachments: attachments }) formessage.addLabel(workinglabel) // מוסיף תווית עובד על זה } } let printermessages = GmailApp.search(`from:${printerEmail} is:unread`) if (printermessages.length > 0) { for (let printmessage of printermessages) { let message = printmessage.getMessages()[0] let body = message.getBody() let attachments = message.getAttachments() let lastworkingthread = workinglabel.getThreads()[0] lastworkingthread.reply('', { htmlBody: body, attachments: attachments }) lastworkingthread.removeLabel(workinglabel) lastworkingthread.addLabel(donelabel) printmessage.markRead() } } }
כמו שאתה רואה - תווית 'להעברה' עברה לעולם שכולו טוב.
כמו כן שינתי את צורת הלולאה מ-forEach
ל-for (let ... of ...)
. אני לא חושב שהיה בעיה עם הקודם - לא הגיוני - אבל עשיתי, שיהיה.דיווחים יתקבלו..
נ.ב. אם השאלה שלך בנוגע ל-webhost הייתה מיועדת אליי - אני לא יודע
-
-
@chv כל הכבוד לך על המאמצים ועל העזרה אין לך מושג איזה תועלת זה בשבילי.
אבל כרגע יש בעיה וכנראה שאני יודע מה הסיבה. הוא שולח שוב ושוב את ההודעה שמתקבלת מהמדפסת
הסיבה לכך לפי מה שאני מבין שהגדרת שהכתובת של המדפסת ששולחת את ההודעה זה אותה כתובת שמקבלת את ההודעה (הרי אין לך כזו מדפסת אז איך יכלת להגדיר את הכתובת, כנראה שעשית לפי הכתובת שאליה נשלחות ההודעות) והאמת היא שהודעות תשובה מתקבלות מכתובת כללית של כל המדפסות וזה הכתובתdonotreply@hpeprint.com
צריך להגדיר את הפילטר שלא מקבל תווית עובד על זה וכן את המילים שאותם צריך לשלוח חזרה בקוד לפי הכתובת הזו ולא לפי הכתובת של המדפסת
-
@chv אין לך מושג באיזה עוצמה אני מרגיש את ה"נהמא דכיסופא" מעולם לא הרגשתי כ"כ הכרת הטוב לבנ"א שכ"כ טורח ומתאמץ ומתמסר לשני בלי להכיר ובלי שהשני יוכל להכיר אותו/ להוקיר לו טובה
אני כל הזמן מסתובב בהרגשה...... איך אני עושה לההוא @chv טובה בחזרה? איך אני מודה לו? הקושי שלי הוא עצום! היום התחלתי להבין מה זה "נהמא דכיסופא"
בקיצור אין לי מילים...... ואם יש דרך להכיר לך טובה תעדכן אותי -
@גבאי נכון, לא חשבתי על זה..
זה אמור לסדר את זה:function redirect() { let printerEmail = 'printer@hp.com' // מייל של המדפסת let printerResponsesEmail = 'dontreply@hp.com'// מייל תשובות מהמדפסת let workinglabel = GmailApp.getUserLabelByName('working') // שם של תווית - עובד על זה let donelabel = GmailApp.getUserLabelByName('performed') // שם של תווית - בוצע let forwardmessages = GmailApp.search(`-from:${printerResponsesEmail} AND -label:working AND -label:performed`) // לשים לב לשמות התוויות if (forwardmessages.length > 0) { for (let formessage of forwardmessages) { let message = formessage.getMessages()[0] let subject = message.getSubject() let body = message.getBody() let attachments = message.getAttachments() // בשורה הבאה - שולח מייל למדפסת מתוכן ההודעה שהתקבלה MailApp.sendEmail(printerEmail, subject, '', { htmlBody: body, attachments: attachments }) formessage.addLabel(workinglabel) // מוסיף תווית 'עובד על זה' להודעה } } let printermessages = GmailApp.search(`from:${printerResponsesEmail} is:unread`) if (printermessages.length > 0) { for (let printmessage of printermessages) { let message = printmessage.getMessages()[0] let body = message.getBody() let attachments = message.getAttachments() let lastworkingthread = workinglabel.getThreads()[0] lastworkingthread.reply('', { htmlBody: body, attachments: attachments }) lastworkingthread.removeLabel(workinglabel) // מוחק תווית 'עובד על זה' מהודעה שקיבלה תשובה lastworkingthread.addLabel(donelabel) // מקצה תווית 'בוצע' להודעה שקיבלה תשובה printmessage.markRead() // סימון הודעת המדפסת כנקרא } } }
@גבאי אמר בבקשה ! עזרה בכתיבת קוד לג'ימיל להעברת הודעות מייל:
@chv אין לך מושג באיזה עוצמה אני מרגיש את ה"נהמא דכיסופא" מעולם לא הרגשתי כ"כ הכרת הטוב לבנ"א שכ"כ טורח ומתאמץ ומתמסר לשני בלי להכיר ובלי שהשני יוכל להכיר אותו/ להוקיר לו טובה
אני כל הזמן מסתובב בהרגשה...... איך אני עושה לההוא @chv טובה בחזרה? איך אני מודה לו? הקושי שלי הוא עצום! היום התחלתי להבין מה זה "נהמא דכיסופא"
בקיצור אין לי מילים...... ואם יש דרך להכיר לך טובה תעדכן אותיתודה על הפרגונים.. אבל אל תגזים, אני בעיקר נהנה מהאתגרים האלה וזה לא הכל חסד
-
@chv התקדמנו שלב.......... אבל עדין לא לגמרי
א. הוא שולח שוב ושוב למדפסת את ההודעה (כנראה בגלל שההודעה שנמצאת בדואר יוצא ג"כ מופעלת עליה הפרוצדורה של הסקריפט, כמו הפשלה שהיתה לי בסינון שצריך לעשות רק מה שנשלח אלי.)
ב. הוא אמנם נותן תווית בוצע אבל לא שולח אלי בחזרה..... -
@chv בדיקה נוספת
א. הוא שולח מייד בהפעלה הראשונה 3 פעמים את ההודעה
ב. הוא נותן תווית בוצע על ההודעה שהתקבלה מהמדפסת ועל ההודעות (3, כנ"ל) שנשלחו למדפסת במקום על ההודעה שהתקבלה למייל, וכך נשאר התווית "עובד על זה" בהודעה שהתקבלה והיא נשלחת שוב.
וכנראה שמהסיבה הזו אני לא מקבל את התשובה למייל השולח כי התשובה באה אלי חזרה...... -
אוחחח... יכול להיות שזה חלק מהבאג - (או כולו) - שהפעולת חיפוש מחפשת גם הודעות בדואר יוצא.
תוסיף את זה לשורות החיפוש (שורה 6 ושורה 20. בתוך הגרשיים המוזרים)is:inbox
זה פשוט מחפש רק בדואר נכנס
יכול להיות שהסתדר?
ואגב שים לב שאתה חייב למחוק גם את המסננים שהיו לפני וגם את ההודעות עם תוויות - שלא יבלבלו אותו עכשיו
נ.ב. אני יסביר לך, אני תכלס מוגבל בצורת הטסטים שאני עושה (אם זה היה בעבודה או משהו הייתי חייב לעשות טסטים נורמלי אבל זה פורום אז..) אין לי כוח לקחת עכשיו תיבת מייל שלי ולהחיל את זה עליה בצורה מוחלטת אז עבדתי בצורה דומה, סיננתי ממיילים מסוימים וכו' יכול להיות שבגלל זה כל הפשלות
-
@chv ככה?
let printermessages = GmailApp.search(`from:${printerResponsesEmail} is:unread is:inbox`) let forwardmessages = GmailApp.search(`-from:${printerResponsesEmail} AND -label:working AND -label:performed is:inbox`) // לשים לב לשמות התוויות
זה באמת שולח לי חזרה את ההודעה וגם מסמן בתווית בוצע
אבל עדין יש משהו שחוזר על עצמו שוב ושוב
זה נראה שלא מסנן את כל מה שמגיע מהמדפסת אלא שולח לה שוב, גם מה שמגיע מהמדפסת מקבל תווית "עובד על זה" -
@גבאי הוא לא אמור להפעיל את הפרוצדורה על מה שבתווית מסוימת בכלל. לא מה שעם תווית בוצע ולא מה שבתווית working.
אני אומר לך שוב - שים לב כשאתה מעדכן את הסקריפט, שלא יהיו שאריות שמבלבלות אותו. ייתכן מאוד שזה מה שקורה.
פשוט או שתמחק את כל ההודעות הקודמות, או שתשים להם תווית מיוחדת שממנה הסקריפט יתעלם - מה שאתה חושב -
@chv מה שאני רואה כרגע זה שהמיל שלי שולח לעצמו גם כן את ההודעה של המדפסת ולא רק למייל שממנו נשלחה ההודעה המקורית וממילא זה חוזר על עצמו שוב שוב כי הוא מקבל הודעה בדואר נכנס ושולח אותה למדפסת וכן הלאה
אולי תצליח לחשבן אותו למה זה קורה?
אולי זה נובע מכך שהוא שולח גם איזה שהיא הודעה מדואר יוצא ולכן הוא מוגדר כמייל ששלח הודעה למדפסת. ? -
@chv הוספתי בקוד סינון שלא יפעל על הודעות שמגיעות מהמיל שלי
האם כך צריך לכתוב את זה?
שורה 6let forwardmessages = GmailApp.search(`-from:${printerResponsesEmail} AND -label:working AND -label:performed is:inbox from:(-12345676@gmail.com)`) // לשים לב לשמות התוויות