Welcome to mirror list, hosted at ThFree Co, Russian Federation.

CHANGES - github.com/Jajcus/pyxmpp.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 0b05545ed8f6ab18d217aa45ad84e70ff5466f41 (plain)
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
179
180
181
182
183
184
185
186
187
188
189
190
191
192
Most Important API Changes
--------------------------

Those are mentioned here as are not backward compatible.
I want the API to be stable and consistent in the next release and later,
so I do all the big changes now (I would have to do them at some time anyway).

2010-04-03

	M2Crypto dependency dropped in favor of the 'ssl' module from the
        standard Python library. TLS API has been changed a bit: certificate
	verification callback now should expect one argument only (a dictionary
	with certificate information)

	Python 2.6 is now _required!

2006-08-31

	Interface API for better externalisation of various components. First
	introduced to the Client classes -- one may create different classes
	to handle different stanza types and namespaces, annotate them with
	interfaces implemented (IFeaturesProvider, IPresenceHandlersProvider,
	IMessageHandlersProvider or IIqHandlersProvider) and list their
	instances in a Client object's interface_providers attribute.

	See the echocomponent.py example to see how to use that.

2006-08-26
	
	Exception handling improvements, part one.

	All PyXMPP-specific exceptions moved to pyxmpp.exceptions module. Some exceptions
	have been removed (those which were used where some standard exception, like ValueError,
	would be a better choice), the most important omission is StanzaError exception.

	ProtocolError exception with some derivatives added -- these are raised when 
	an error is detected in a stanza (received) processed. These exceptions
	will be handled internally by PyXMPP some day (automatically
	<bad-request/> or similar XMPP error will be raised).

2006-08-26

	CachedPropertyObject class removed and its usage in pyxmpp.jabber.disco
	Now all the DiscoItem/DiscoInfo/DiscoItems attributes are regular properties
	calling set_*, get_* funtions on every access. 
	The old cached properties were giving no speed gain and only complicated things.

2005-10-14

	Usage of non-unicode strings in PyXMPP API is deprecated. No
	no implicit conversion is made where utf-8 string would previously be
	accepted (e.g. JID constructor). Sometimes deprecation warning will be
	raised when string is used instead of unicode.


2005-03-20

	"common_doc", "common_root", and "common_ns" can no longer be imported
	from the "stanza" module. They were moved to the "xmlextra" module.

2005-01-20

	Minor change: now "disco_info" and "disco_items" attributes
	of pyxmpp.jabber.client and pyxmpp.jabberd.component are initialized
	in the constructors of those classes. Those __init__() methods now
	accept "disco_name", "disco_category" and "disco_type" arguments
	to set up the entity identity. Also register_feature() and
	unregister_feature() methods were added for managing the feature
	list in .disco_info.

2005-01-09

	Continuation of the big API unification.

	All attribute and parameter names "node", relating to XML node have
	been renamed to "xmlnode". The most important change is `Stanza.node` renamed
	to `Stanza.xmlnode`.

	Roster.items(), Roster.groups(), Roster.items_by_name(), Roster.items_by_group(),
	Roser.items_by_jid() renamed to: Roster.get_items(), Roster.get_groups(),
	Roster.get_items_by_name(), Roster.get_items_by_group(), Roster.get_item_by_jid()

	Keys of Roster.items_dict are now JIDs, not unicode.

	More .as_xml() methods unified. To reuse most of the code needed two
	new virtual classes were added: pyxmpp.objects.StanzaPayloadObject
	and pyxmpp.objects.StanzaPayloadWrapperObject. Objects providing .as_xml()
	methods may be used directly as argument to Stanza.set_content() and
	Stanza.add_content() methods.

2005-01-06

	Big API unification started.
	
	jabber.vcard.VCard and jabber.delay.Delay
	classes' method as_xml accepts now "parent" and "doc" arguments in
	that order. Argument interpretation is also unified. All other similar
	objects will have the add_xml() with the same signature soon.

	Classes in jabber.disco module were modified heavily, so  all the 
	getter are named get_*, all the setters set_* and all the interesting
	properties may be accessed as attributes which also adds some caching.
	Other classes, if they don't use that get_*/set_* naming, will be
	modified in similar way soon.

2004-12-31

	There was a design flaw in PyXMPP from the very beginning, which caused
	that many unnecessary modules from PyXMPP package (and subpackages,
	when they were used) were imported even when only one simple module was
	used. That was because pyxmpp imported all the useful names from
	submodules. That was a problem (unnecessarily long startup time
	sometimes), but it was also quite convenient.

	To resolve the problem those imports were removed from __init__
	modules, so importing a package doesn't cause any other imports now.
	To improve backward compatibility and keep the convenience of the old
	behavior "all" modules were added to "pyxmpp", "pyxmpp.jabber" and
	"pyxmpp.jabber" packages. 

	If your application was broken by that change just import "pyxmpp.all"
	(and/or "pyxmpp.jabber.all", "pyxmpp.jabberd.all" if you use them)
	there -- you need to do it once per application (no need to change
	every module). After that everything should work as before.

	If you use only small part of the API and don't want to import unused
	modules import names like "JID" or "Stanza" directly from modules that
	define them (e.g.: 'import JID from pyxmpp.jid').

2004-12-18

	dnspython (http://www.dnspython.org) is now used for resolving DNS
	names. Please note, that because of a conflict between dnspython and
	old PyXMPP DNS implementation you must clean up after old PyXMPP
	installation and do 'make clean' before building PyXMPP.

2004-09-16
	
	Stanza, Message, Iq and Presence constructors arguments have been
	changed again. "typ" and "sid" were really stupid and ugly.
	Now Stanza (derived classes) constructor keyword parameters are:
	from_jid, to_jid, stanza_type, stanza_id
	
	I hope this will never change again, at least not after the next
	official release. You may update your application code using
	"migrate-0_5-0_6.py" script.

2004-09-13
	
	Stanza, Message, Iq and Presence constructors arguments have been
	changed so build-ins "type" and "id" are not redefined. So the "type"
	argument has been changed to "typ" and the "id" argument to "sid"
	(stanza id).

2004-09-03

	Stream.data_in and Stream.data_out callbacks removed. Data sent and
	received is now logged via 'logging' module to 'pyxmpp.Stream.out' and
	'pyxmpp.Stream.in' loggers.  The raw data is available for logging
	handlers as the first element of 'args' attribute of the log record
	(record.args[0]).

2004-08-29

	All debug messages are passed to the standard python 'logging' module.
	There is no debug() methods in PyXMPP classes any more.

2005-06-02

	Python 2.2 support is gone. Compliant XMPP implementation
	requires stringprep and IDN support. Python 2.3 provides both,
	Python 2.2 none. Maintaining separete stringprep and IDN
	implementations for use with Python 2.2 is IMHO not worth the effort
	needed.

2005-05-28

	Roster and RosterItems classes rewritten. Now they are not wrapper
	around roster XML node any more. Old code was complicated, slow,
	and not standard compliant (ingored stringprep profiles).

	Most important changes:
	
	- no `node` attribute in Roster and RosterItem
	- RosterItem constructor doesn't take `roster` argument any more
	- `jid`, `ask`, `subscription`, `name` and `groups` are now attributes,
	  not methods, of `RosterItem`
	- `add_group`, `rm_group`, etc. methods of `RosterItem` are gone. Use
	  list operations on `groups` attribute now.
	- inline documentation included

 vi: spell spelllang=en