בקשה ! עזרה בכתיבת קוד לג'ימיל להעברת הודעות מייל
-
@גבאי בשמחה.. זה לא מסובך לי
זה מטפל רק בהודעות עם התווית שתכתוב. ואחרי שמטפל בהודעה הוא מסיר ממנה את התווית (כמובן כדי שלא יבצע בה את הפרוצדורה שוב)function redirect() { let printerEmail = 'hppppppp@mail.com' // מייל של המדפסת let label = GmailApp.getUserLabelByName('label') // שם של התווית let messages = label.getThreads() if (messages.length > 0) { messages.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(label) // מסיר את התווית מהמייל שטופל }) } }
אני מבין שאתה יודע להוסיף טריגרים וכו'
-
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 הנ"ל) תקבל מייד תווית "להעברה" אם היא לא נקראה (זאת על ידי מסנן, לא הסקריפט)
ואז הסקריפט יטפל בכל ההודעות עם תווית "להעברה" - יישלח מהתוכן שלהן הודעה למדפסת + יימחק את התווית "להעברה" וייקצה לה תווית "בטיפול"
כאשר מגיעה הודעה מהמדפסת והיא לא נקראה עדיין - הסקריפט יישלח את התוכן של הההודעה מהמדפסת, כתשובה לכל ההודעות שיש להן תווית "בטיפול", יימחק מהן את התווית "בטיפול" וייקצה תווית "בוצע"
ואת ההודעה של המדפסת הוא ייסמן כנקרא?
משהו כזה?