예제 #1
0
        //RETRの後のメールの保存が完成したら、Job2をこちらに乗せ換えられる
        public bool Job(Logger logger, DateTime now, ILife iLife)
        {
            Debug.Assert(logger != null, "logger != null");

            var fetchDb       = new FetchDb(_kernel.ProgDir(), _oneFetch.Name);
            var remoteUidList = new List <String>();
            var getList       = new List <int>(); //取得するメールのリスト
            var delList       = new List <int>(); //削除するメールのリスト

            //受信間隔を過ぎたかどうかの判断
            if (_dt.AddMinutes(_oneFetch.Interval) > now)
            {
                return(false);
            }

            logger.Set(LogKind.Normal, null, 1, _oneFetch.ToString());
            if (_oneFetch.Ip == null)
            {
                logger.Set(LogKind.Error, null, 2, "");
                return(false);
            }
            var popClient = new PopClient(_kernel, _oneFetch.Ip, _oneFetch.Port, _timeout, iLife);

            //接続
            if (!popClient.Connect())
            {
                logger.Set(LogKind.Error, null, 3, popClient.GetLastError());
                return(false);
            }
            //ログイン
            if (!popClient.Login(_oneFetch.User, _oneFetch.Pass))
            {
                logger.Set(LogKind.Error, null, 4, popClient.GetLastError());
                return(false);
            }
            //UID
            var lines = new List <String>();

            if (!popClient.Uidl(lines))
            {
                logger.Set(LogKind.Error, null, 5, popClient.GetLastError());
                return(false);
            }
            for (int i = 0; i < lines.Count; i++)
            {
                var tmp = lines[i].Split(' ');
                if (tmp.Length == 2)
                {
                    var uid = tmp[1];
                    remoteUidList.Add(uid);

                    //既に受信が完了しているかどうかデータベースで確認する
                    if (fetchDb.IndexOf(uid) == -1)
                    {
                        //存在しない場合
                        getList.Add(i);//受信対象とする
                    }
                }
            }
            if (_oneFetch.Synchronize == 0)   //サーバに残す
            {
                for (var i = 0; i < remoteUidList.Count; i++)
                {
                    if (_oneFetch.KeepTime != 0)  //保存期間0の時は、削除しない
                    //保存期間が過ぎているかどうかを確認する
                    {
                        if (fetchDb.IsPast(remoteUidList[i], _oneFetch.KeepTime * 60))   //サーバに残す時間(分)
                        {
                            delList.Add(i);
                        }
                    }
                }
            }
            else if (_oneFetch.Synchronize == 1)     //メールボックスと同期する
            //メールボックスの状態を取得する
            {
                var localUidList = new List <string>();
                var folder       = string.Format("{0}\\{1}", _kernel.MailBox.Dir, _oneFetch.LocalUser);
                foreach (var fileName in Directory.GetFiles(folder, "DF_*"))
                {
                    var mailInfo = new MailInfo(fileName);
                    localUidList.Add(mailInfo.Uid);
                }
                //メールボックスに存在しない場合、削除対象になる
                for (var i = 0; i < remoteUidList.Count; i++)
                {
                    if (localUidList.IndexOf(remoteUidList[i]) == -1)
                    {
                        delList.Add(i);
                    }
                }
            }
            else if (_oneFetch.Synchronize == 2)     //サーバから削除
            //受信完了リストに存在する場合、削除対象になる
            {
                for (var i = 0; i < remoteUidList.Count; i++)
                {
                    if (fetchDb.IndexOf(remoteUidList[i]) != -1)
                    {
                        delList.Add(i);
                    }
                }
            }
            //RETR
            for (int i = 0; i < getList.Count; i++)
            {
                var mail = new Mail();
                if (!popClient.Retr(getList[i], mail))
                {
                    logger.Set(LogKind.Error, null, 6, popClient.GetLastError());
                    return(false);
                }
                //Ver5.9.8
                var fromStr = mail.GetHeader("From");
                if (fromStr == null)
                {
                    fromStr = string.Format("{0}@{1}_{2}", _oneFetch.User, _oneFetch.Host, _oneFetch.Port);
                }

                var from = new MailAddress(fromStr);
                mail.ConvertHeader("X-UIDL", remoteUidList[i]);
                var remoteAddr = _oneFetch.Ip;
                var remoteHost = _oneFetch.Host;

                var rcptList = new List <MailAddress>();
                rcptList.Add(new MailAddress(_oneFetch.LocalUser, _domainName));

                if (_mailSave != null)
                {
                    if (!_mailSave.Save(from, rcptList, mail, remoteHost, remoteAddr))
                    {
                        return(false);
                    }
                }

                fetchDb.Add(remoteUidList[i]);
            }
            //DELE
            for (int i = 0; i < delList.Count; i++)
            {
                if (!popClient.Dele(delList[i]))
                {
                    logger.Set(LogKind.Error, null, 7, popClient.GetLastError());
                    return(false);
                }
                fetchDb.Del(remoteUidList[i]);
            }
            //QUIT
            if (!popClient.Quit())
            {
                logger.Set(LogKind.Error, null, 5, popClient.GetLastError());
                return(false);
            }
            fetchDb.Save();
            _dt = DateTime.Now;//最終処理時刻の更新
            return(true);
        }
예제 #2
0
        //RETRの後のメールの保存が完成したら、Job2をこちらに乗せ換えられる
        public bool Job(Logger logger,DateTime now,ILife iLife)
        {
            Debug.Assert(logger != null, "logger != null");

            var fetchDb = new FetchDb(_kernel.ProgDir(), _oneFetch.Name);
            var remoteUidList = new List<String>();
            var getList = new List<int>();//取得するメールのリスト
            var delList = new List<int>();//削除するメールのリスト

            //受信間隔を過ぎたかどうかの判断
            if (_dt.AddMinutes(_oneFetch.Interval) > now){
                return false;
            }

            logger.Set(LogKind.Normal, null, 1, _oneFetch.ToString());
            if (_oneFetch.Ip == null) {
                logger.Set(LogKind.Error, null, 2, "");
                return false;
            }
            var popClient = new PopClient(_kernel,_oneFetch.Ip,_oneFetch.Port,_timeout,iLife);
            //接続
            if (!popClient.Connect()){
                logger.Set(LogKind.Error, null, 3, popClient.GetLastError());
                return false;
            }
            //ログイン
            if (!popClient.Login(_oneFetch.User, _oneFetch.Pass)){
                logger.Set(LogKind.Error, null, 4, popClient.GetLastError());
                return false;
            }
            //UID
            var lines = new List<String>();
            if (!popClient.Uidl(lines)) {
                logger.Set(LogKind.Error, null, 5, popClient.GetLastError());
                return false;
            }
            for (int i=0;i<lines.Count;i++){
                var tmp = lines[i].Split(' ');
                if (tmp.Length == 2){
                    var uid = tmp[1];
                    remoteUidList.Add(uid);

                    //既に受信が完了しているかどうかデータベースで確認する
                    if (fetchDb.IndexOf(uid) == -1) {
                        //存在しない場合
                        getList.Add(i);//受信対象とする
                    }
                }
            }
            if (_oneFetch.Synchronize == 0) { //サーバに残す
                for (var i = 0; i < remoteUidList.Count; i++) {
                    if (_oneFetch.KeepTime != 0){ //保存期間0の時は、削除しない
                        //保存期間が過ぎているかどうかを確認する
                        if (fetchDb.IsPast(remoteUidList[i], _oneFetch.KeepTime * 60)) { //サーバに残す時間(分)
                            delList.Add(i);
                        }
                    }
                }
            } else if (_oneFetch.Synchronize == 1) { //メールボックスと同期する
                //メールボックスの状態を取得する
                var localUidList = new List<string>();
                var folder = string.Format("{0}\\{1}", _kernel.MailBox.Dir, _oneFetch.LocalUser);
                foreach (var fileName in Directory.GetFiles(folder, "DF_*")) {
                    var mailInfo = new MailInfo(fileName);
                    localUidList.Add(mailInfo.Uid);
                }
                //メールボックスに存在しない場合、削除対象になる
                for (var i = 0; i < remoteUidList.Count; i++) {
                    if (localUidList.IndexOf(remoteUidList[i]) == -1) {
                        delList.Add(i);
                    }
                }
            } else if (_oneFetch.Synchronize == 2) { //サーバから削除
                //受信完了リストに存在する場合、削除対象になる
                for (var i = 0; i < remoteUidList.Count; i++) {
                    if (fetchDb.IndexOf(remoteUidList[i]) != -1) {
                        delList.Add(i);
                    }
                }
            }
            //RETR
            for (int i = 0; i < getList.Count;i++ ){
                var mail = new Mail();
                if (!popClient.Retr(getList[i], mail)) {
                    logger.Set(LogKind.Error, null, 6, popClient.GetLastError());
                    return false;
                }
                //Ver5.9.8
                var fromStr = mail.GetHeader("From");
                if (fromStr == null){
                    fromStr = string.Format("{0}@{1}_{2}", _oneFetch.User, _oneFetch.Host, _oneFetch.Port);
                }

                var from = new MailAddress(fromStr);
                mail.ConvertHeader("X-UIDL", remoteUidList[i]);
                var remoteAddr = _oneFetch.Ip;
                var remoteHost = _oneFetch.Host;

                var rcptList = new List<MailAddress>();
                rcptList.Add(new MailAddress(_oneFetch.LocalUser, _domainName));

                if (_mailSave != null){
                    if (!_mailSave.Save(from, rcptList, mail, remoteHost, remoteAddr)){
                        return false;
                    }
                }

                fetchDb.Add(remoteUidList[i]);
            }
            //DELE
            for (int i = 0; i < delList.Count;i++ ){
                if (!popClient.Dele(delList[i])){
                    logger.Set(LogKind.Error, null, 7, popClient.GetLastError());
                    return false;
                }
                fetchDb.Del(remoteUidList[i]);
            }
            //QUIT
            if (!popClient.Quit()){
                logger.Set(LogKind.Error, null, 5, popClient.GetLastError());
                return false;
            }
            fetchDb.Save();
            _dt = DateTime.Now;//最終処理時刻の更新
            return true;
        }
예제 #3
0
        public void 接続失敗_ポート間違い(InetKind inetKind,String addr,int port)
        {
            //setUp
            var sut = new PopClient(new Kernel(),new Ip(addr), port, 3, this);
            var expected = false;

            //exercise
            var actual = sut.Connect();

            //verify
            Assert.That(actual, Is.EqualTo(expected));
            Assert.That(sut.GetLastError(), Is.EqualTo("Faild in PopClient Connect()"));

            //tearDown
            sut.Dispose();
        }