בקשה ! עזרה בכתיבת קוד לג'ימיל להעברת הודעות מייל
-
https://h30434.www3.hp.com/t5/Mobile-Printing-Cloud-Printing/Eprint-history/td-p/7175190
עדכון :
לפי מה שכתוב כאן סגרו את השירות הזה ,
סליחה .
https://h30434.www3.hp.com/t5/Mobile-Printing-Cloud-Printing/hp-connected-eprint-history-discontinued/td-p/6195088/page/2 -
-
@chv יש לי עוד אתגר /בעיה קטנה.
כששולחים מיל למדפסת מקבלים מיל תשובה עם אישור שזה נעשה. אני מעונין שמי ששולח מייל להדפסה לכתובת הג'ימיל ג"כ יקבל את הודעת האישור. מה שעשיתי כרגע זה שמקבלים תשובה אוטומטית עם אישור (רק שהסתבכתי קצת שגם המדפסת תקבל את התשובה אוטומטית. ולא מצאתי צורה פשוטה לעשות תשובה אוטומטית לפי סינון מסוים. רק ע"י סקריפט כפי שהבאתי בפוטס הראשון)
רק שהחיסרון הוא שאם מתקבלת מהמדפסת הודעת שגיאה זה לא יעביר את זה חזרה למי ששלח את ההודעה אלא הוא יקבל ג"כ הודעת אישור.
חשבתי על כיון לפיתרון אולי אפשר לעשות שכל מי ששולח הודעה יקבל תווית מסוימת. ולעשות פקודה שכל מיל שמגיע מהמדפסת נשלח חזרה למילים שיש בהם את התויות הנ"ל (ומחיקת התוית)
האם זה אפשרי? או שאולי יש לך רעיון יותר טוב? (ברעיון שלי יש חיסרון קטן שאם שלחו 2 בתוך דקה שניהם יקבלו את אותה התשובה) -
@גבאי זה כבר מעניין..
השאלה שלך כאן היא בעצם איך לזהות את השולח המקורי של ההודעה שמגיעה כתשובה מהמדפסת (שהרי מי ששלח אותה בפועל זה אנחנו ולא הוא)
בא נחשוב.. יש לכל שרשור במייל מזהה מיוחד (ID) (יש גם לכל הודעה ID אבל זה פחות חשוב)
אם אנחנו מאחסנים את ה-ID של ההודעה המקורית - במייל שאנחנו שולחים למדפסת (ומקבלים תשובה ממנה עליו) נוכל לפענח אותו מהתשובה וכך נדע לאן להעביר את התשובה (להכניס אותה כתשובה לשרשור המקורי, על פי ה-ID)
אני חושב שאפשר לעבוד ממש ידני, להכניס את ה-ID לתוך הנושא של ההודעה שנשלחת למדפסת מהסקריפט. וכך אפשר אחר כך לחלץ אותו מתוך הנושא כדי לדעת לאן להעביר את ההודעה שהתקבלה ממנה.
ככה בערך?function redirect() { let printerEmail = 'hppppppp@mail.com' // מייל של המדפסת let forwardlabel = GmailApp.getUserLabelByName('forward') // שם של תווית - העברה למדפסת let workinglabel = GmailApp.getUserLabelByName('working') // שם של תווית - עובד על זה let fromprinter = GmailApp.getUserLabelByName('fromprinter') // שם של תווית - מהמדפסת, להעברה לשולח המקורי let donelabel = GmailApp.getUserLabelByName('done') // שם של תווית - בוצע let forwardmessages = forwardlabel.getThreads() if (forwardmessages.length > 0) { forwardmessages.forEach(function (m) { let id = m.getId() // מקבלים את המזהה של השרשור כדי להוסיף אותו לנושא של ההודעה שתישלח למדפסת let message = m.getMessages()[0] let subject = message.getSubject() let body = message.getBody() let attachments = message.getAttachments() MailApp.sendEmail(printerEmail, subject + ' ' + id, '', { htmlBody: body, attachments: attachments }) m.removeLabel(forwardlabel) // מסיר את תווית העברה m.addLabel(workinglabel) // מוסיף תווית עובד על זה }) } let printermessages = fromprinter.getThreads() if (printermessages.length > 0) { printermessages.forEach(function (m) { let message = m.getMessages() let lastmessage = message[message.length -1] let subject = message.getSubject() let id = subject.split(' ').splice(-1)[0] // מקבלים את המזהה של השרשור המקורי על ידי ניתוח הנושא של ההודעה מהמדפסת let body = lastmessage.getBody() let attachments = lastmessage.getAttachments() let originalthread = GmailApp.getThreadById(id) // מקבלים את השרשור המקורי על ידי המזהה originalthread.reply(body, { attachments: attachments }) m.removeLabel(fromprinter) // מוחקים את התווית של העברה לשולח מקורי מהשרשור של המדפסת originalthread.removeLabel(workinglabel) // מוחקים מהשרשור המקורי את התווית עובד על זה originalthread.addLabel(donelabel) // מוסיפים לשרשור המקורי את תווית בוצע }) } }
אתה צריך להגדיר מסנן שיחיל את התווית 'להעברה למדפסת' על הודעות מהשולחים שלך.
וגם להגדיר מסנן שיחיל תווית 'מהמדפסת, להעברה לשולח מקורי' על כל ההודעות החוזרות מהמדפסת.
תוויות שבתכלס יהיו אצלך:- להעברה למדפסת
- עובד על זה (מחכה לתשובה מהמדפסת)
- להעברה לשולח מקורי (תשובות מהמדפסת)
- בוצע
-
@chv וואו ......... כל הכבוד.
עדיין לא נסיתי לעשות את זה בפועל.
אבל יש בעיה אחת לפי מה שאני מבין הרעיון בנוי על כך שבהודעת תשובה שמתקבלת מהמדפסת מופיע הנושא ששלחתי אליה! (כמו "השב" בכל פעם)
אבל האמת היא שהמדפסת לא שולחת הודעת תשובה אלא הודעה חדשה ואין בה שום איזכור לאיזה הודעה היא משיבה. (הנתון היחיד זה הכתובת שממנה נשלח כל השאר זהה לחלוטין)
כך נראית ההודעה
-
@chv אבל זה יעבוד לי כרגע? לפחות על האחרון או האחרונים? או שבגלל שאין מזהה הקוד ישתבש?
אני מתעצל לבדוק לפני שאני שואל אותך
ועוד משהו שאני מסתבך איתו
לא מצאתי אפשרות לעשות מסנן שיחול על כל ההודעות מלבד הודעות שיגיעו מהמדפסת (ולכן האפשרות הראשונה שלך לעשות את הפקודה על כל ההודעות שלא נקראו היתה יותר טובה כי עשיתי מסנן על ההודעות שמגיעות מהמדפסת שיסומן כנקרא וידלג על דואר נכנס וכך זה אמור לעקוף אותו)
יש לך רעיון איך לעשות את זה? -
@גבאי תנאי "לא" בפילטרים של ג'ימייל עושים עם סימן מינוס (-) כלומר זה ככה בחיפוש:
from:(-email@gmail.com)
זה מביא את כל המיילים שלא מהכתובת הזו
(אז כנראה בממשק של בניית הפילטרים דרך ההגדרות של ג'ימייל פשוט מכניסים בשורה "מאת" - ככה:(email@gmail.com-)
אני משער)אז רק תסביר לי מה הולך להיות ההרכב של ההודעות כדי שאני יבין איך אמור להיראות הסקריפט.
הולך להיות כך שכל הודעה (לא מהכתובת של HP הנ"ל) תקבל מייד תווית "להעברה" אם היא לא נקראה (זאת על ידי מסנן, לא הסקריפט)
ואז הסקריפט יטפל בכל ההודעות עם תווית "להעברה" - יישלח מהתוכן שלהן הודעה למדפסת + יימחק את התווית "להעברה" וייקצה לה תווית "בטיפול"
כאשר מגיעה הודעה מהמדפסת והיא לא נקראה עדיין - הסקריפט יישלח את התוכן של הההודעה מהמדפסת, כתשובה לכל ההודעות שיש להן תווית "בטיפול", יימחק מהן את התווית "בטיפול" וייקצה תווית "בוצע"
ואת ההודעה של המדפסת הוא ייסמן כנקרא?
משהו כזה? -
משהו כזה:
function redirect() { let printerEmail = 'hppppppp@mail.com' // מייל של המדפסת let forwardlabel = GmailApp.getUserLabelByName('forward') // שם של תווית - העברה למדפסת let workinglabel = GmailApp.getUserLabelByName('working') // שם של תווית - עובד על זה let donelabel = GmailApp.getUserLabelByName('done') // שם של תווית - בוצע let forwardmessages = forwardlabel.getThreads() if (forwardmessages.length > 0) { forwardmessages.forEach(function (m) { let message = m.getMessages()[0] let subject = message.getSubject() let body = message.getBody() let attachments = message.getAttachments() MailApp.sendEmail(printerEmail, subject, '', { htmlBody: body, attachments: attachments }) m.removeLabel(forwardlabel) // מסיר את תווית העברה m.addLabel(workinglabel) // מוסיף תווית עובד על זה }) } let printermessages = GmailApp.search(`from:${printerEmail} is:unread`) if (printermessages.length > 0) { printermessages.forEach(function (m) { let message = m.getMessages() let lastmessage = message[message.length -1] let body = lastmessage.getBody() let attachments = lastmessage.getAttachments() let workingthreads = workinglabel.getThreads() if (workingthreads.length > 0) { workingthreads.forEach(function (m) { m.reply(body, { attachments: attachments }) m.removeLabel(workinglabel) m.addLabel(donelabel) }) } m.markRead() }) } }
כמו שכתבת - זה יכול גם בטעות להחזיר את אותה תשובת מדפסת לכמה מיילים
אפשרי לעשות את זה כך שישיב על ראשון-ראשון - אולי לא במדויק אבל לפחות שישיב לכל הודעה בהודעה אחת.
אין לי כוח עכשיו (אולי @מוטי-אורן ירצה?) -
@גבאי אתה מתכוין השלב של קבלת כל ההודעות מהמדפסת - שעוד לא טופלו - לסקריפט
זה קורה בשורה 21
אין עניין בעבודה מול תווית. מקבלים אותם בצורה של חיפוש בגימייל על פי הכלל של מאת:המייל של המדפסת, ורק הודעות שלא נקראו
לאחר הטיפול (כלומר השליחה של תוכן ההודעה כתשובה להודעות המקוריות) ההודעה מהמדפסת מסומנת כנקראה כך שלא תטופל בריצה הבאה של הסקריפט -
@chv לא נעים לי כבר להטריד
אבל משהו לא עובד לי
ההודעה מקבלת תווית "להדפסה" נשלחת למייל של המדפסת ומקבלת במקום זה תווית "עובד על זה" ומשם ואילך הוא חוזר ושולח את ההודעה של המדפסת שוב ושוב למדפסת במקום להחזיר לשולח. וגם לא מקבל תווית בוצע ולא מסמן אותה כ"נקרא".