मैं एक NAGIOS प्रणाली के साथ एक समस्या में चल रहा हूं, जो एक लोकप्रिय ईमेल-टू-एसएमएस सेवा को ईमेल भेज रहा है। ईमेल-टू-एसएमएस सेवा Subject:
लाइन में पाठ के साथ ईमेल लेती है , और उन्हें To:
क्षेत्र में एन्कोड किए गए मोबाइल नंबर पर भेजती है । अब तक सब ठीक है। दुःख की बात है sendmail (और यह पहले पोस्टफ़िक्स) (जरूरी लंबे) में एक नि: शुल्क CRLF डालने लगते Subject:
लाइन, और मेरे एसएमएस संदेश CRLF पर कटा हुआ पैदा कर रहा है कि यदि और केवल यदिSubject:
लाइन एक या अधिक कोलोन शामिल अतीत नि: शुल्क CRLF।
मुझे पूरा विश्वास है कि संदेश सही तरीके से बनाए जा रहे हैं, लेकिन सिर्फ यह सुनिश्चित करने के लिए, यहाँ मुझे एक लंबी Subject:
लाइन के साथ, अपने आप को एक पूरी तरह से परीक्षण परीक्षा संदेश तैयार करना है :
echo "foo" | mail -s "1234567 101234567 201234567 301234567 401234567 501234567 601234567 701234567 801234567 90123456789" reaper@teaparty.net
ध्यान दें कि इस Subject:
पंक्ति में कोई अतिरिक्त कोलन नहीं है ; मैं यहाँ सब कर रहा हूँ दिखा रहा है कि तार पर एक अतिरिक्त CRLF डाला गया है। यहाँ का परिणाम है sudo ngrep -x port 25
:
44 61 74 65 3a 20 46 72 69 2c 20 33 31 20 4d 61 Date: Fri, 31 Ma
79 20 32 30 31 33 20 31 30 3a 34 33 3a 35 35 20 y 2013 10:43:55
2b 30 31 30 30 0d 0a 54 6f 3a 20 72 65 61 70 65 +0100..To: reape
72 40 74 65 61 70 61 72 74 79 2e 6e 65 74 0d 0a r@teaparty.net..
53 75 62 6a 65 63 74 3a 20 31 32 33 34 35 36 37 Subject: 1234567
20 31 30 31 32 33 34 35 36 37 20 32 30 31 32 33 101234567 20123
34 35 36 37 20 33 30 31 32 33 34 35 36 37 20 34 4567 301234567 4
30 31 32 33 34 35 36 37 20 35 30 31 32 33 34 35 01234567 5012345
36 37 0d 0a 20 36 30 31 32 33 34 35 36 37 20 37 67.. 601234567 7
30 31 32 33 34 35 36 37 20 38 30 31 32 33 34 35 01234567 8012345
36 37 20 39 30 31 32 33 34 35 36 37 38 39 0d 0a 67 90123456789..
55 73 65 72 2d 41 67 65 6e 74 3a 20 48 65 69 72 User-Agent: Heir
6c 6f 6f 6d 20 6d 61 69 6c 78 20 31 32 2e 34 20 loom mailx 12.4
37 2f 32 39 2f 30 38 0d 0a 4d 49 4d 45 2d 56 65 7/29/08..MIME-Ve
72 73 69 6f 6e 3a 20 31 2e 30 0d 0a 43 6f 6e 74 rsion: 1.0..Cont
65 6e 74 2d 54 79 70 65 3a 20 74 65 78 74 2f 70 ent-Type: text/p
6c 61 69 6e 3b 20 63 68 61 72 73 65 74 3d 75 73 lain; charset=us
लगभग आधे रास्ते नीचे (बोल्ड + इटैलिक में चिह्नित), मूल हेडर में 501234567
और के बीच , आप एक सीआरएलएफ डाला जा सकता है ( बाएं हाथ की तरफ हेक्स डंप पर, दाहिने हाथ के सादे पाठ पर)।601234567
Subject:
0x0d 0x0a
..
MTA इसे पोस्ट-प्रोसेस करने में खुशी महसूस करता है, और जब मैं प्राप्त अंत में ऑन-डिस्क संग्रहित मेल को देखता हूं, तो मैं केवल LF (0x0a) को Subject में देखता हूं: लाइन, और लाइन को सही ढंग से और इसके रूप में पार्स किया गया है। द्वारा, जैसे संपूर्णता, alpine
। फिर भी, तार पर CRLF मौजूद है, और मेरे और (उत्कृष्ट) ईमेल-से-एसएमएस समर्थन लोगों के बीच, हमने स्थापित किया है कि ये समस्या का कारण हैं।
तो मेरा सवाल यह है: क्या एक एमटीए के लिए तार पर एक गंभीर सीआरएलएफ डालना वैध है?
यदि यह है, और मैं इसे साबित कर सकता हूं, तो यह ईमेल-टू-एसएमएस हाउस की समस्या है, क्योंकि वे असहिष्णु हो रहे हैं। यदि यह नहीं है, या यह है, लेकिन मैं इसे साबित नहीं कर सकता, तो यह मेरी समस्या बन जाती है, इसलिए संदर्भों के साथ एक उत्तर सबसे उपयोगी होगा।
संपादित करें : अब मैं साफ कर सकता हूं कि प्रश्न में ईमेल से एसएमएस सेवा kapow है । एक बार जब उन्हें यह समस्या समझाई गई, तो उन्होंने इसे प्राप्त करने के लिए मेरे साथ काम किया और एक फिक्स परीक्षण किया, और फिक्स को तैनात किया। कॉलन के साथ मेरी लंबी विषय-पंक्तियां अब एसएमएस में सही ढंग से रिले हो जाती हैं। मैं आम तौर पर अलग-अलग कंपनियों को ट्रम्पेट नहीं करता, विशेष रूप से एसएफ पर नहीं, लेकिन मुझे यह ध्यान देने योग्य लगा कि कप्पो द राइट थिंग। (डिस्क्लेमर: मेरे पास भुगतान करने वाले ग्राहक के रूप में कपो के साथ कोई संबंध नहीं है जो अपनी समस्या से निपटने के तरीके से खुश हैं।)