File: PKG-INFO

package info (click to toggle)
python-sievelib 1.2.0-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 312 kB
  • sloc: python: 3,153; makefile: 7
file content (178 lines) | stat: -rw-r--r-- 6,305 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
Metadata-Version: 1.1
Name: sievelib
Version: 1.2.0
Summary: Client-side SIEVE library
Home-page: https://github.com/tonioo/sievelib
Author: Antoine Nguyen
Author-email: tonio@ngyn.org
License: MIT
Description: sievelib
        ========
        
        |travis| |codecov| |latest-version|
        
        Client-side Sieve and Managesieve library written in Python.
        
        * Sieve : An Email Filtering Language
          (`RFC 5228 <http://tools.ietf.org/html/rfc5228>`_)
        * ManageSieve : A Protocol for Remotely Managing Sieve Scripts
          (`RFC 5804 <http://tools.ietf.org/html/rfc5804>`_)
        
        Installation
        ------------
        
        To install ``sievelib`` from PyPI::
        
          pip install sievelib
        
        To install sievelib from git::
        
          git clone git@github.com:tonioo/sievelib.git
          cd sievelib
          python ./setup.py install
        
        Sieve tools
        -----------
        
        What is supported
        ^^^^^^^^^^^^^^^^^
        
        Currently, the provided parser supports most of the functionalities
        described in the RFC. The only exception concerns section
        *2.4.2.4. Encoding Characters Using "encoded-character"* which is not
        supported.
        
        The following extensions are also supported:
        
        * Copying Without Side Effects (`RFC 3894 <https://tools.ietf.org/html/rfc3894>`_)
        * Body (`RFC 5173 <https://tools.ietf.org/html/rfc5173>`_)
        * Vacation (`RFC 5230 <http://tools.ietf.org/html/rfc5230>`_)
        * Relational (`RFC 5231 <https://tools.ietf.org/html/rfc5231>`_)
        * Imap4flags (`RFC 5232 <https://tools.ietf.org/html/rfc5232>`_)
        
        The following extensions are partially supported:
        
        * Date and Index (`RFC 5260 <https://tools.ietf.org/html/rfc5260>`_)
        * Checking Mailbox Status and Accessing Mailbox Metadata (`RFC 5490 <https://tools.ietf.org/html/rfc5490>`_)
        
        Extending the parser
        ^^^^^^^^^^^^^^^^^^^^
        
        It is possible to extend the parser by adding new supported
        commands. For example::
        
          import sievelib
        
          class MyCommand(sievelib.commands.ActionCommand):
              args_definition = [
                  {"name": "testtag",
                      "type": ["tag"],
                      "write_tag": True,
                      "values": [":testtag"],
                      "extra_arg": {"type": "number",
                                    "required": False},
                      "required": False},
                  {"name": "recipients",
                      "type": ["string", "stringlist"],
                      "required": True}
              ]
        
          sievelib.commands.add_commands(MyCommand)
        
        Basic usage
        ^^^^^^^^^^^
        
        The parser can either be used from the command-line::
        
          $ cd sievelib
          $ python parser.py test.sieve
          Syntax OK
          $
        
        Or can be used from a python environment (or script/module)::
        
          >>> from sievelib.parser import Parser
          >>> p = Parser()
          >>> p.parse('require ["fileinto"];')
          True
          >>> p.dump()
          require (type: control)
              ["fileinto"]
          >>> 
          >>> p.parse('require ["fileinto"]')
          False
          >>> p.error
          'line 1: parsing error: end of script reached while semicolon expected'
          >>>
        
        Simple filters creation
        ^^^^^^^^^^^^^^^^^^^^^^^
        
        Some high-level classes are provided with the ``factory`` module, they
        make the generation of Sieve rules easier::
        
          >>> from sievelib.factory import FiltersSet
          >>> fs = FiltersSet("test")
          >>> fs.addfilter("rule1",
          ...              [("Sender", ":is", "toto@toto.com"),],
          ...              [("fileinto", "Toto"),])
          >>> fs.tosieve()
          require ["fileinto"];
          
          # Filter: rule1
          if anyof (header :is "Sender" "toto@toto.com") {
              fileinto "Toto";
          }
          >>> 
        
        Additional documentation is available within source code.
        
        ManageSieve tools
        -----------------
        
        What is supported
        ^^^^^^^^^^^^^^^^^
        
        All mandatory commands are supported. The ``RENAME`` extension is
        supported, with a simulated behaviour for server that do not support
        it.
        
        For the ``AUTHENTICATE`` command, supported mechanisms are ``DIGEST-MD5``,
        ``PLAIN`` and ``LOGIN``.
            
        Basic usage
        ^^^^^^^^^^^
        
        The ManageSieve client is intended to be used from another python
        application (there isn't any shell provided)::
        
          >>> from sievelib.managesieve import Client
          >>> c = Client("server.example.com")
          >>> c.connect("user", "password", starttls=False, authmech="DIGEST-MD5")
          True
          >>> c.listscripts()
          ("active_script", ["script1", "script2"])
          >>> c.setactive("script1")
          True
          >>> c.havespace("script3", 45)
          True
          >>>
        
        Additional documentation is available with source code.
        
        .. |latest-version| image:: https://badge.fury.io/py/sievelib.svg
           :target: https://badge.fury.io/py/sievelib
        .. |travis| image:: https://travis-ci.org/tonioo/sievelib.png?branch=master
           :target: https://travis-ci.org/tonioo/sievelib
        .. |codecov| image:: http://codecov.io/github/tonioo/sievelib/coverage.svg?branch=master
           :target: http://codecov.io/github/tonioo/sievelib?branch=master
        
Keywords: sieve,managesieve,parser,client
Platform: UNKNOWN
Classifier: Programming Language :: Python
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Topic :: Communications :: Email :: Filters