sieve-protocol   [plain text]


Protocol for Sieve script exchange

    Please note that this document is not authoritative and may well be out
    of date, you should look at specs.html for the current authoritative
    document for the MANAGESIEVE protocol. Note: This is not a standards
    track protocol. If you decide to base a program upon it you have been
    warned. This is a simple text-based protocol for getting user sieve
    scripts onto the (presumably sealed) IMAP server. The requirements for
    this process are: 

      * the user must authenticate to gain access, preferably via a secure
        SASL mechanism. 
      * only valid sieve scripts may be accepted 

    Additional features provided: 

      * the ability to manage multiple scripts on the server with zero or
        one of them being the "active" sieve script 

Types

    This a line oriented protocol much like [IMAP] or [ACAP]. There are two
    types: ATOMS and strings. Strings may be quoted or literal. See [ACAP]
    for detailed descriptions. 
    sievename is a string where only certain characters are allowed and it
    must be at least 1 character long. 

Commands

    AUTHENTICATE SP string [SP string] EOL 
            SASL authentication; the parameters are the mechanism and
            optionally the initial data. Initial data is base64 encoded.
            The server replies with a OK or NO response, or a string base64
            encoded followed by an EOL. Client then replies with a string
            base64 encoded followed by an EOL and the procedure is
            repeated. 
    NOOP EOL 
            No side affects. OK, NO replies 
    LOGOUT EOL 
            Logout, terminates connection. OK, NO replies. 
    GETSCRIPT SP sievename EOL 
            The parameter is the name of the requested script. Returns:
            string EOL containing the script data. Get the script with name
            sievename from the server. OK, NO replies 
    PUTSCRIPT SP sievename SP string EOL 
            Puts sievename with data data onto the server if possible. OK,
            NO replies. 
    SETACTIVE SP sievename EOL 
            Set the script with the name sievename as the active script.
            Any other script that was active is no longer. OK, NO replies 
    DELETESCRIPT SP sievename EOL 
            Delete the script with sievename. OK or NO replies. 
    LISTSCRIPTS EOL 
            returns zero or more: sievename EOL. where the active script
            has a '*' at the end of it's name OK or NO replies