[스크랩] IMAP COMMAND 정리
telnet XXX.XXX.XXX.XXX 143
확인할 사용자 확인
a LOGIN [사용자] 0000
a SELECT INBOX
a FETCH 0:[최대UID|*] (UID RFC822.SIZE FLAGS BODY[HEADER.FIELDS (FROM TO SUBJECT DATE MESSAGE-ID)])
a UID FETCH [해당 UID] BODY.PEEK[]
1. SELECT Command
A. 설명
메일 박스를 선택 한다. ( <-> CLOSE )
B. 사용예
A1 SELECT INBOX
<-> A1 CLOSE
2. EXAMINE Command
A. 설명
SELECT 명령과 같다. 그러나 the selected mailbox is identified as read-only.
B. 사용예
A1 EXAMINE INBOX
3. CREATE Command
A. 설명
메일 박스를 생성 한다.
B. 사용예
A1 CREATE OUTBOX1
4. DELETE Command
A. 설명
메일 박스를 삭제 한다.
B. 사용예
A1 DELETE OUTBOX1
5. RENAME Command
A. 설명
메일박스의 이름을 변경한다.
B. 사용예
A1 RENAME OUTBOX1 OUTBOX3
6. SUBSCRIBE Command
A. 설명
LSUB Command에 의해 리턴되는 메일박스의 서버측 세팅인 ACTIVE, SUBSCRIBED 명시된 메일박스의 이름을 이 명령으로 추가 한다. (등록)
B. 사용예
A1 SUBSCRIBE OUTBOX1
7. UNSUBSCRIBE Command
A. 설명
SUBSCRIBE의 반대 작업 (등록해제).
B. 사용예
A1 UNSUBSCRIBE OUTBOX1
8. LIST Command
A. 설명
리스팅 기능.
B. 사용예
A1 LIST “” *
9. LSUB Command
A. 설명
LIST와 기능이 비슷함
B. 사용예
a1 lsub "#news." "comp.mail.*"
a1 OK LSUB completed
10. STATUS Command
A. 설명
메일박스의 상태 정보를 리턴 함.
Parameter
MESSAGES : 메일박스에 메세지의 수를 리턴
RECENT : 최근에 등록된 메시지의 수 리턴
UIDNEXT : 새로운 메시지에 부여될 UID의 번호 리턴
UIDVALIDITY : 메일박스에서 unique identifier validity value 리턴
UNSEEN : The number of messages which do not have the \Seen flag set.
B. 사용예
A1 STATUS INBOX (MESSAGES)
A1 STATUS INBOX (MESSAGES UIDNEXT UIDVALIDITY)
11. APPEND Command
A. 설명
명시된 메일박스의 끝에 새로운 메시지를 추가 할 수 있는 명령이다.
B. 사용예
A003 APPEND outbox1 (\Seen) {310}
Date: Mon, 7 Feb 1994
From: Fred Foobar
Subject: afternoon meeting
To: sjjung@mdminc.net
Message-Id:
MIME-Version: 1.0
Content-Type: TEXT/PLAIN; CHARSET=US-ASCII
C:
Hello Joe, do you think we can meet at
C:
C:
C:
S: A003 OK APPEND completed
12. CHECK Command
A. 설명
현재 선택된 메일박스의 체크포인트를 요구 한다.
B. 사용예
a1 check
a1 OK CHECK completed
13. CLOSE Command
A. 설명 (좀더 읽어 봐야 함)
현재 선택된 메일박스의 close, 메시지중 \Deleted flag 로 세팅 되어 있는 것들은 영구적으로 삭제 해버린다.
B. 사용예
a1 close
14. EXPUNGE Command
A. 설명
현재 선택된 메일박스의 메시지중 \Deleted flag 로 세팅 되어 있는 것들은 영구적으로 삭제 해버린다.
B. 사용예
a1 expunge
15. SEARCH Command
A. 설명 (argument가 많음 다시 읽어 보기)
메일박스에서 given searching criteria 를 찾는다.
Searching criteria consist of one or more search keys.
B. 사용예
A282 SEARCH FLAGGED SINCE 1-Feb-1994 NOT FROM "Smith"
16. FETCH Command
A. 설명
fetch 명령은 메일박스안의 메시지에 첨부된 데이터를 가져온다.
Fetch되 data는 single atom 또는 parenthesized list 로 할 수 있다.
사용해본 결과 아래와 같이도 됨
* 7 FETCH (FLAGS (\Seen) BODY[HEADER.FIELDS ("DATE" "FROM" "SUBJECT")] {118}
Date: Mon, 7 Feb 1994
From: Fred Foobar
Subject: afternoon meeting
B. 사용예
A654 FETCH
A654 FETCH
A654 FETCH
17. STORE Command
A. 설명
메일박스안의 메시지에 첨부된 데이터를 바꾼다.
STORE가 플래그의 설정을 할 수 있음
B. 사용예
A003 STORE
18. COPY Command
A. 설명
명시된 목적지 메일박스의 끝에 명시된 메시지를 복사 할 수 있다.
Flag 및 internal date는 복사본 에서도 유지 된다.
B. 사용예
A003 COPY
19. UID Command
A. 설명
UID는 두개의 폼을 가지고 있다.
첫번째
복합 명령을 위해 적당한 argument를 copy, fetch, store 명령과 함께 쓸수 있다. 그러나 message set argument 의 수는 message sequence numbers 대신에 유일하게 인식 한다.
두번째
search 폼과 같이 쓸 수 있다. Argument의 해석은 SEARCH 명령과 같다. 그러나 UID SEARCH command를 위해 SEARCH 응답안데 돌려 보내는 수는 message sequence numbers 대신에 유일하게 인식 한다.
For example, the command UID SEARCH
1:100 UID 443:557 returns the unique identifiers corresponding to
the intersection of the message sequence number set 1:100 and the
UID set 443:557.
B. 사용예
A999 UID FETCH
* 1 FETCH (UID 4 FLAGS (\Seen))
A999 OK UID FETCH completed
/* (0) call login - Login ID, Login Password, Login Prompt */
cmd_struct tel_login[] = {
{"* OK", "login login %s %s", NULL, NULL},
{"login OK", "~", NULL, NULL},
};
/* (1) call logout*/
cmd_struct tel_logout[] = {
{"~", "logout logout", NULL, NULL},
{"logout OK", "~", NULL, NULL},
};
/* (2) close message sequence of MMBox */
cmd_struct close_mmbox_cmd_list[] = {
{"~", "MMBox close", NULL, NULL},
{"MMBox ", "~", NULL, parse_error_detect},
};
/* (3) noop MMBox */
cmd_struct noop_mmbox_cmd_list[] = {
{"~", "MMBox noop", NULL, NULL},
{"MMBox ", "~", NULL, parse_error_detect},
};
/* (4) create MMBox */
cmd_struct create_mmbox_cmd_list[] = {
{"~", "MMBox create %s", NULL, NULL},
{"MMBox ", "~", NULL, parse_error_detect},
};
/* (5) remove MMBox */
cmd_struct remove_mmbox_cmd_list[] = {
{"~", "MMBox delete %s", NULL, NULL},
{"MMBox ", "~", NULL, parse_error_detect},
};
/* (6) upload MMBox */
cmd_struct upload_mmbox_cmd_list[] = {
{"~", "MMBox append %s (\\Seen) {%s}", NULL, NULL},
{"+ OK", "%s", append_proc, NULL},
// {"+ Ready", "%s", append_proc, NULL},
{"MMBox ", "~", NULL, parse_error_detect},
};
/* (7) move Mail in MMBox to other MMBox */
cmd_struct move_mmbox_cmd_list[] = {
{"~", "MMBox select %s", NULL, NULL},
{"MMBox ", "MMBox search HEADER Message-ID %s", NULL, parse_error_detect},
{"MMBox ", "MMBox copy %s %s", NULL, parse_search_sqn},
{"MMBox ", "MMBox store %s +FLAGS (\\Deleted)",
NULL, parse_error_ignore},
{"MMBox ", "MMBox expunge", NULL, NULL},
{"MMBox ", "MMBox close", NULL, NULL},
{"MMBox ", "~", NULL, parse_error_detect},
};
/* (8) copy Mail in MMBox to other MMBox */
cmd_struct copy_mmbox_cmd_list[] = {
{"~", "MMBox select %s", NULL, NULL},
{"MMBox ", "MMBox search HEADER Message-ID %s", NULL, parse_error_detect},
{"MMBox ", "MMBox copy %s %s", NULL, parse_search_sqn},
{"MMBox ", "MMBox close", NULL, parse_error_ignore},
{"MMBox ", "~", NULL, parse_error_detect},
};
/* (9) del Mail in MMBox */
cmd_struct del_mmbox_cmd_list[] = {
{"~", "MMBox select %s", NULL, NULL},
{"MMBox ", "MMBox search HEADER Message-ID %s", NULL, parse_error_detect},
{"MMBox ", "MMBox store %s +FLAGS (\\Deleted)",
NULL, parse_search_sqn},
{"MMBox ", "MMBox expunge", NULL, NULL},
{"MMBox ", "MMBox close", NULL, NULL},
{"MMBox ", "~", NULL, parse_error_detect},
};
/* (10) get Mail in MMBox */
cmd_struct get_mmbox_cmd_list[] = {
{"~", "MMBox select %s", NULL, NULL},
{"MMBox ", "MMBox search HEADER Message-ID %s", NULL, parse_error_detect},
{"MMBox ", "MMBox fetch %s RFC822.TEXT", NULL, parse_search_sqn},
{"MMBox ", "MMBox close", NULL, parse_get_mm},
{"MMBox ", "~", NULL, parse_error_detect},
};
/* (11) get Mail header in MMBox */
cmd_struct get_header_cmd_list[] = {
{"~", "MMBox select %s", NULL, NULL},
{"MMBox ", "MMBox search HEADER Message-ID %s", NULL, parse_error_detect},
{"MMBox ", "MMBox fetch %s BODY[HEADER]", NULL, parse_search_sqn},
{"MMBox ", "MMBox close", NULL, parse_get_mm},
{"MMBox ", "~", NULL, parse_error_detect},
};
/* (12) view Mail list in MMBox */
cmd_struct view_mmbox_cmd_list[] = {
{"~", "MMBox select %s", NULL, NULL},
{"MMBox ", "MMBox fetch 1:* (FLAGS BODY[HEADER])", NULL, parse_error_detect}, /* UID FETCH 1:* (FLAGS) */
{"MMBox ", "MMBox close", NULL, parse_fetch_mmbox_list},
{"MMBox ", "~", NULL, parse_error_detect},
};
/* (13) status MMBox */
cmd_struct status_mmbox_cmd_list[] = {
{"~", "MMBox status %s (MESSAGES)", NULL, NULL},
{"MMBox ", "~", NULL, parse_error_detect},
};
/* (14) store flags of MM of MMBox */
cmd_struct set_status_mmbox_cmd_list[] = {
{"~", "MMBox select %s", NULL, NULL},
{"MMBox ", "MMBox search HEADER Message-ID %s", NULL, parse_error_detect},
{"MMBox ", "MMBox store %s flags %s", NULL, parse_search_sqn},
{"MMBox ", "MMBox close", NULL, parse_error_detect},
{"MMBox ", "~", NULL, parse_error_detect},
};