This changelog file follows few rules:
- rem: indicates removed features,
- new: indicates new features,
- upd: indicates updated features,
- dep: indicates deprecated features,
Deprecation means that in the next version feature will be removed.
Also, after every version there should be a brief note describing possible problems with migrating to it from older versions and usage of new features.
Users can always read the manual and dcumentation to make themselves more knowledgeable and are encouraged to do so. They only need to remember that documentation is usually more up-to-date than manual and if conflicts appear they should follow the order:
docstrings -> docs/ -> manual/
- bug:
diaspy
has problems/can't connect to pods using SNI (this is an issue with requests/urllib3/python),
-
new:
people.User().fetchprofile()
will issue a warning when user cannot be found on current pod, -
new:
settings.Profile
is now loaded during initialization (can be switched off), -
fix: fixed a bug in
__repr__()
method inpeople.User()
object,
This version has some small incompatibilities with 0.4.1
so read Changelog carefully.
-
new:
diaspy.people.User._fetchstream()
method, -
new:
diaspy.people.Me()
object representing current user, -
new:
**kwargs
added todiaspy.streams.Generic.json()
methdo to give developers control over the creation of JSON, -
new:
.getHCard()
method added todiaspy.people.User()
, -
upd:
diaspy.connection.Connection.login()
modifies connection object in-place and returns it (this allows more fluent API), -
upd:
diaspy.connection.Connection.login()
no longer returns status code (if login was unsuccessful it'll raise an exception), -
upd:
diaspy.connection.Connection._login()
no longer returns status code (if login was unsuccessful it'll raise an exception), -
upd: better error message in
diaspy.models.Post().__init__()
, -
upd:
data
variable indiaspy.models.Post()
renamed to_data
to indicate that it's considered private, -
upd: after deleting a post
Activity
stream is purged instead of being refilled (this preserves state of stream which is not reset to last 15 posts), -
upd:
filterByIDs()
method inAspects
stream renamed tofilter()
, -
rem:
diaspy.connection.Connection.getUserInfo()
moved todiaspy.connection.Connection.getUserData()
, -
rem:
fetch
parameter removed fromdiaspy.connection.Connection.getUserData()
, -
dep:
max_time
parameter indiaspy.streams.*.more()
method is deprecated, -
fix: this release should fix the bug which prevented diaspy from working with some pods (e.g. diasp.eu and joindiaspora.com),
Login and authentication procedure backend received major changes in this version.
There are no longer username
and password
variables in Connection
object.
Instead, credentials are stored (together with the token) in single variable _login_data
.
This is preserved until you call login()
at which point credentials are erased and
only token is left -- it can be obtained by calling repr(Connection)
.
Also, this release is compatible with DIASPORA* 0.2.0.0 but should still support pods running on older versions.
And the test suite was updated. Yay!
-
new:
diaspy.errors.SettingsError
. -
upd:
diaspy.settings.Account.setEmail()
can now raiseSettingsError
when request fails, -
upd:
diaspy.settings.Account.getEmail()
will now return empty string instead of raising an exception if cannot fetch mail, -
upd: improved language fetching in
diaspy.settings.Account.getLanguages()
. -
rem:
diaspy/client.py
is removed,
0.4.1-rc.3
(2013-09-08):
- new:
diaspy.settings.Profile.load()
method for loading profile information, - new:
diaspy.settings.Profile.update()
method for updating profile information, - new:
diaspy.settings.Profile.setName()
method, - new:
diaspy.settings.Profile.setBio()
method, - new:
diaspy.settings.Profile.setLocation()
method, - new:
diaspy.settings.Profile.setTags()
method, - new:
diaspy.settings.Profile.setGender()
method, - new:
diaspy.settings.Profile.setBirthDate()
method, - new:
diaspy.settings.Profile.setSearchable()
method, - new:
diaspy.settings.Profile.setNSFW()
method,
0.4.1-rc.2
(2013-09-06):
-
new:
diaspy.search.Search.tags()
method for getting tag suggestions, -
new:
diaspy.settings.Profile.getName()
method, -
new:
diaspy.settings.Profile.getBio()
method, -
new:
diaspy.settings.Profile.getLocation()
method, -
new:
diaspy.settings.Profile.getTags()
method, -
new:
diaspy.settings.Profile.getGender()
method, -
new:
diaspy.settings.Profile.getBirthDate()
method, -
new:
diaspy.settings.Profile.isSearchable()
method, -
new:
diaspy.settings.Profile.isNSFW()
method, -
new:
provider_display_name
parameter indiaspy.streams.Stream.post()
(thanks @svbergerem), -
upd:
remeber_me
parameter indiaspy.connection.Connection.login()
, -
upd: you must supply
username
andpassword
parameters on init ofdiaspy.connection.Connection
, -
upd: you must update your testconf.py (new fields are required for settings tests),
-
upd:
diaspy.settings.Settings
renamed todiaspy.settings.Account
, -
rem:
username
andpassword
parameters removed fromdiaspy.connection.Connection.login()
must be supplied on init,
0.4.1-rc.1
(2013-09-02):
-
new:
__getitem__()
indiaspy.models.Post
, -
new:
__dict__()
indiaspy.models.Post
, -
new:
guid
argument indiaspy.models.Post.__init__()
, -
new:
json()
method indiaspy.streams.Generic
adds the possibility to export streams to JSON, -
new:
full()
method indiaspy.streams.Generic
will try to fetch full stream (containing all posts), -
new:
setEmail()
method indiaspy.settings.Settings
, -
new:
setLanguage()
method indiaspy.settings.Settings
, -
new:
downloadPhotos()
method indiaspy.settings.Settings
, -
new:
backtime
argument inmore()
method indiaspy.streams.Generic
, -
new:
DiaspyError
will be raised when connection is created with empty password and/or username, -
new:
getSessionToken()
method indiaspy.connection.Connection
returns string from_diaspora_session
cookie, -
new:
direct
parameter indiaspy.connection.Connection().get()
allowing to disable pod expansion, -
upd: if
Post()
is created with fetched comments, data will also be fetched as a dependency, -
upd:
id
argument type is nowint
(diaspy.models.Post.__init__()
), -
upd:
Search().lookup_user()
renamed toSearch().lookupUser()
, -
upd:
diaspy.messages
renamed todiaspy.conversations
(but will be accessible under both names for this and next release), -
upd:
LoginError
moved todiaspy.errors
, -
upd:
TokenError
moved todiaspy.errors
, -
upd:
diaspy.connection.Connection.podswitch()
gained two new positional arguments:username
andpassword
, -
upd:
aspect_id
renamed toid
indiaspy.streams.Aspects().remove()
, -
fix: fixed some bugs in regular expressions used by
diaspy
internals (html tag removal, so you get nicer notifications), -
fix: fixed authentication issues,
This release is not backwards compatible with 0.3.x
line! You'll have to check your code for corrections.
Also, this release if first to officially released fork version.
-
dep:
diaspy.client
is officially deprecated (will be removed in0.4.1
), -
upd:
diaspy.conversations
renamed todiaspy.messages
, -
udp:
diaspy.conversations.Conversation
moved todiaspy.models
, -
new:
diaspy.messages.Mailbox()
object representing diaspora* mailbox,
-
upd:
diaspy.connection.getUserData()
raisesDiaspyError
when it cannot find user data, -
rem:
diaspy.client.Client
must be explicitly imported,
-
upd:
diaspy.people.sephandle()
raisesInvalidHandleError
instead ofUserError
-
upd:
models.Post()._fetch()
renamed to_fetchdata()
(because of new_fetchcomments()
method) -
new:
models.Comment()
object: wrapper for comments, not to be created manually -
new:
comments
parameter inmodels.Post
: defines whether to fetch post's commets -
new:
connection.Connection
has new parameter in__init__()
: it'sschema
-
new:
author()
method inmodels.Post()
The new parameter in connection.Connection
is useful when operating with handles.
As handle does not contain schema (http
, https
, etc.) _setlogin()
would raise an
unhandled exception -- requests.exceptions.MissingSchema
.
Now, however, Connection
will catch the exception, add missing schema and try once more.
This parameter is provided to give programmers ability to manipulate it.
Also, now you can pass just pod.example.com
as pod
parameter. Less typing!
When it comes to posts, we are now able to fetch comments.
First edition of Changelog for diaspy
.
Developers should update their code as version 0.3.0
may not be fully
backwards compatible depending on how the code is written.
If you always pass named arguments and do not rely on their order you can, at least in
theory, not worry about this update.
Version 0.3.0
introduces few new features, fixes several bugs and brings a bit of
redesign and refactoring od diaspy
's code.