]> git.immae.eu Git - github/shaarli/Shaarli.git/blob - CHANGELOG.md
14a4f14313a91dcd4ab6fa4e882671a5879ec7a6
[github/shaarli/Shaarli.git] / CHANGELOG.md
1 # Change Log
2 All notable changes to this project will be documented in this file.
3
4 The format is based on [Keep a Changelog](http://keepachangelog.com/)
5 and this project adheres to [Semantic Versioning](http://semver.org/).
6
7 ## [v0.9.6](https://github.com/shaarli/Shaarli/releases/tag/v0.9.6) - 2018-03-25
8 ## Changed
9 - htaccess: prevent accessing resources not managed by SCM
10 - htaccess: always forward the 'Authorization' HTTP header
11
12
13 ## [v0.9.5](https://github.com/shaarli/Shaarli/releases/tag/v0.9.5) - 2018-02-02
14 ### Fixed
15 - Fix a warning happening when `php-intl` is not installed on the system
16 - Fix warnings happening when updating from legacy SebSauvage version
17
18 ## [v0.9.4](https://github.com/shaarli/Shaarli/releases/tag/v0.9.4) - 2018-01-30
19 ### Added
20 - Enable translations: Shaarli is now also available in French. Other language translations are welcome!
21 - Add EditorConfig configuration
22 - Add favicons for mobile devices
23 - Add Alpine Linux arm32v7 Dockerfiles (master, latest)
24
25 ### Changed
26 - Do not write bookmark edition history during file imports (performance)
27 - Migrate Docker images (master, latest) to Alpine Linux
28 - Improve unitary tests and code coverage
29 - Improve thumbnail display
30 - Improve theme ergonomics
31 - Improve messages if there is no plugin or parameter available in the admin page
32 - Increase buffer size for cURL download
33 - Force HTTPS if the original port is 443 behind a reverse proxy (workaround)
34 - Improve page title retrieval performances
35
36 ### Removed
37 - Remove redirector setting from Configure page
38
39 ### Fixed
40 - Fix broken links in the documentation
41 - Enable access to `data/user.css` (Apache 2.2 & 2.4)
42 - Don't URL encode description links if parameter `redirector.encode_url` is set to false
43 - Fix an issue preventing the Save button to appear for plugin parameters
44
45
46 ## [v0.9.3](https://github.com/shaarli/Shaarli/releases/tag/v0.9.3) - 2018-01-04
47 **XSS vulnerability fixed. Please update.**
48
49 ## Security
50 - Fix an XSS (cross-site-scripting) vulnerability in `index.php` -
51 [CVE-2018-5249](https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2018-5249)
52
53
54 ## [v0.9.2](https://github.com/shaarli/Shaarli/releases/tag/v0.9.2) - 2017-10-07
55
56 **Major security issue fixed. Please update.**
57
58 ### Added
59 - Tag search now supports wildcards `*`
60 - New setting `privacy.force_login` which can be used with `privacy.hide_public_links` to redirect anonymous users to the login page.
61 - New setting `general.default_note_title` used to override default `Note:` title prefix for notes.
62 - Add a version hash for asset loading to prevent browser's cache issue
63
64 ### Changed
65 - The "Remember me" checkbox is unchecked by default
66 - The default value of the "Remember me" checkbox can be configured under `data/config.json.php`
67
68 ### Removed
69 - Remove obsolete PHP magic quote support
70
71 ### Fixed
72 - Generates a permalink URL if the URL is set to blank
73 - Replace links to the old GitHub wiki with ReadTheDocs URIs
74 - Use single quotes in the note bookmarklet
75 - Daily page if there is no link
76 - Bulk link deletion with a single link
77 - HTTPS detection behind a reverse proxy
78 - Travis tests environment and localization
79 - Improve template paths robustness (trailing slash)
80 - Robustness: safer gzinflate/zlib usage
81 - Description links parsing with parenthesis (without Markdown)
82 - Templates:
83 - Sort the tag cloud alphabetically
84 - Firefox social title
85 - Improved visited link color
86 - Fix jumpy textarea with long content in post edit
87
88 ### Security
89
90 - Fixed reflected XSS vulnerability introduced in v0.9.1, discovered by @chb9 ([CVE-2017-15215](https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2017-15215)).
91
92
93 ## [v0.9.1](https://github.com/shaarli/Shaarli/releases/tag/v0.9.1) - 2017-08-23
94
95 The documentation has been migrated to ReadTheDocs:
96 - https://shaarli.readthedocs.io/
97 - edits are submitted as pull requests
98
99 ### Added
100 - Allow bulk link deletion
101 - Display subtags in the tag cloud
102 - Add an endpoint to refresh the token
103 - Add a token on every page
104 - Add a tag list view for management
105 - Add Note bookmarklet
106 - Add creation date when editing a link
107
108 ### Changed
109 - Documentation:
110 - Generate static HTML documentation with [mkdocs](http://www.mkdocs.org/)
111 - Host documentation on [ReadTheDocs](http://www.mkdocs.org/)
112 - Update documentation structure
113 - Update Makefile targets to:
114 - Build the docs locally
115 - Include the generated docs in the release archives
116 - Theme:
117 - Use the new theme as the default
118 - Rename the tag cloud template to `tag.cloud.html`
119 - Display visited links in grey
120 - Use only one search form in `linklist.html`
121 - Hide the "search links with these tags" option when an empty `searchtags` is passed to `tag.list.html`
122 - Improve HTTP header handling when hosting Shaarli with Docker behind a reverse proxy
123 - Searching for tags with an empty value returns untagged links only
124 - Set Travis environment to `precise` until the new `trusty` environment is ready
125
126 ### Removed
127 - Remove dead Pubsubhubbub code
128 - Disable the GitHub wiki (see changed/documentation)
129 - Remove Docker `dev` image and resources
130 - Theme:
131 - Remove the bottom "Sort by" menu in `tag.list.html`
132
133 ### Fixed
134 - Fix file existence check for `user.css`
135 - Limit selection to 2k characters when using the bookmarklet
136 - Fix JS error `uncaught type error`
137 - Fix Firefox Social button
138 - Use pinned PHP dependencies when generating release archives
139 - Make sure that the tag exists before altering/removing it
140
141 ### Security
142 - Add a whitelist for protocols for URLs
143
144
145 ## [v0.9.0](https://github.com/shaarli/Shaarli/releases/tag/v0.9.0) - 2017-05-07
146
147 This release introduces the REST API, and requires updating HTTP server
148 configuration to enable URL rewriting, see:
149 - https://shaarli.github.io/api-documentation/
150 - https://shaarli.readthedocs.io/en/master/Server-configuration/
151
152 **WARNING**: Shaarli now requires PHP 5.5+.
153
154 ### Added
155 - REST API v1
156 - [Slim](https://www.slimframework.com/) framework
157 - [JSON Web Token](https://jwt.io/introduction/) (JWT) authentication
158 - versioned API endpoints:
159 - `/api/v1/info`: get general information on the Shaarli instance
160 - `/api/v1/links`: get a list of shaared links
161 - `/api/v1/history`: get a list of latest actions
162 Theming:
163 - Introduce a new theme
164 - Allow selecting themes/templates from the configuration page
165 - New/Edit link form can be submitted using CTRL+Enter in the textarea
166 - Shaarli version is displayed in the footer when logged in
167 - Add plugin placeholders to Atom/RSS feed templates
168 - Add OpenSearch to feed templates
169 - Add `campaign_` to the URL cleanup pattern list
170 - Add an AUTHORS file and Makefile target to list authors from Git commit data
171 - Link imports are now logged in `data/` folder, and can be debug using `dev.debug=true` setting.
172 - `composer.lock` is now included in git file to allow proper `composer install`
173 - History mechanism which logs link addition/modification/deletion
174
175 ### Changed
176 - Docker: enable nginx URL rewriting for the REST API
177 - Theming:
178 - Move `user.css` to the `data` folder
179 - Move default template files to a subfolder (`default`)
180 - Rename the legacy theme to `vintage`
181 - Private only filter is now displayed as a search parameter
182 - Autocomplete: pre-select the first element
183 - Display daily date in the page title (browser title)
184 - Timezone lists are now passed as an array instead of raw HTML
185 - Move PubSubHub to a dedicated plugin
186 - Coding style:
187 - explicit method visibility
188 - safe boolean comparisons
189 - remove unused variables
190 - The updater now keeps custom theme preferences
191 - Simplify the COPYING information
192 - Improved client locale detection
193 - Improved date time display depending on the locale
194 - Partial namespace support for Shaarli classes
195 - Shaarli version is now only present in `shaarli_version.php`
196 - Human readable maximum file size upload
197
198
199 ### Removed
200 - PHP < 5.5 compatibility
201 - ReadItYourself plugin
202
203 ### Fixed
204 - Ignore generated release tarballs
205 - Hide default port when behind a reverse proxy
206 - Fix a typo in the Markdown plugin description
207 - Fix the presence of empty tags for private tags and in search results
208 - Fix a fatal error during the install
209 - Fix permalink image alignment in daily page
210 - Fix the delete button in `editlink`
211 - Fix redirection after link deletion
212 - Do not access LinkDB links by ID before the Updater applies migrations
213 - Remove extra spaces in the bookmarklet's name
214 - Piwik plugin: Piwik URL protocol can now be set (http or https)
215 - All inline JS has been moved to dedicated JS files
216 - Keep tags after login redirection
217
218 ### Security
219 - Markdown plugin: escape HTML entities by default
220
221
222 ## [v0.8.5](https://github.com/shaarli/Shaarli/releases/tag/v0.8.5) - 2018-01-04
223 **XSS vulnerability fixed. Please update.**
224
225 ## Security
226 - Fix an XSS (cross-site-scripting) vulnerability in `index.php` -
227 [CVE-2018-5249](https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2018-5249)
228
229 ## [v0.8.4](https://github.com/shaarli/Shaarli/releases/tag/v0.8.4) - 2017-03-04
230 ### Security
231 - Markdown plugin: escape HTML entities by default
232
233 ## [v0.8.3](https://github.com/shaarli/Shaarli/releases/tag/v0.8.3) - 2017-01-20
234 ### Fixed
235 - PHP 7.1 compatibility: add ConfigManager parameter to anti-bruteforce function call in login template.
236
237 ## [v0.8.2](https://github.com/shaarli/Shaarli/releases/tag/v0.8.2) - 2016-12-15
238 ### Fixed
239
240 - Editing a link created before the new ID system would change its permalink.
241
242 ## [v0.8.1](https://github.com/shaarli/Shaarli/releases/tag/v0.8.1) - 2016-12-12
243
244 > Note: this version will create an automatic backup of your database if anything goes wrong.
245
246 ### Added
247 - Add CHANGELOG.md to track the whole project's history
248 - Enable Composer cache for Travis builds
249 - Save the last edition date for shaares and use it in Atom/RSS feeds
250 - Plugins:
251 - Add an [Isso](https://posativ.org/isso/) plugin to enable user comments on permalinks
252 - Allow defining init functions, e.g. for performing checks and error processing
253 - Add a Piwik plugin for analytics.
254 - Markdown: add warning notice regarding HTML rendering
255 - Meta tag to *not* send the referrer to external resources.
256
257 ### Changed
258 - Link ID complete refactoring:
259 - Links now have a numeric ID instead of dates
260 - Short URLs are now created once and can't change over time (previous URL are kept)
261 - Templates:
262 - Changed placeholder behaviour for: `buttons_toolbar`, `fields_toolbar` and `action_plugin`
263 - Cleanup `{loop}` declarations in templates
264 - Tools: hide Firefox Social button when not in HTTPS
265 - Firefox Social: show Shaarli's title when shaaring using Firefox Social
266 - Release archives now have the same structure as GitHub-generated archives:
267 - archives contain a `Shaarli` directory, itself containing sources + dependencies
268 - the tarball is now gzipped
269 - Plugins:
270 - Markdown: Parsedown library is now imported through Composer
271 - Minor code cleanup: PHPDoc, spelling, unused variables, etc.
272 - Docker: explicitly set the maximum file upload size to 10 MiB
273
274 ### Fixed
275 - Fix the server `<self>` value in Atom/RSS feeds
276 - Plugins:
277 - Tools: only display parameter description when it exists
278 - archive.org: do not propose archival of private notes
279 - Markdown:
280 - render links properly in code blocks
281 - bug regarding the `nomarkdown` tag
282 - W3C compliance
283 - Use absolute URL for hashtags in RSS and ATOM feeds
284 - Docker: specify the location of the favicon
285 - ATOM feed: remove new line between content tag and data
286
287 ### Security
288 - Allow whitelisting trusted IPs, else continue banning clients upon login failure
289
290
291 ## [v0.8.0](https://github.com/shaarli/Shaarli/releases/tag/v0.8.0) - 2016-10-12
292 Shaarli now uses [Composer](https://getcomposer.org/) to handle its dependencies.
293 Please use our release archives, or follow the
294 [installation documentation](https://github.com/shaarli/Shaarli/wiki/Download-and-Installation).
295
296 ### Added
297 - Composer is required to resolve Shaarli's PHP dependencies
298 - Shaarli now supports `#hashtags`
299 - Firefox social share now uses selected text as a description
300 - Plugin parameters can have a description in each plugin's `.meta` file
301
302 ### Changed
303 - Configuration is now stored as a JSON file
304 - Previous configuration format will be automatically updated (PHP -> JSON)
305 - Shaarli now defaults to cURL to fetch shaare titles
306 - URL cleanup: remove `PHPSESSID` parameter
307 - `nomarkdown` tag is no longer private, and now affects visitors
308 - Cleanup template indentation
309 - Rewrite bookmark import using a generic Netscape parser
310
311 ### Removed
312 - Shaarli no longer references Delicious in its description
313
314 ### Deprecated
315 - Shaarli configuration is not held as PHP globals anymore
316
317 ### Fixed
318 - Ignore case for tags in autocompletion and cloud tag
319 - Avoid generating empty tags
320 - Fix a Dockerfile syntax error
321
322 ### Security
323 - Fixed a bug preventing to change password
324 - XSRF token now generated each time a page is rendered
325
326
327 ## [v0.7.1](https://github.com/shaarli/Shaarli/releases/tag/v0.7.1) - 2017-03-08
328 ### Security
329 - Markdown plugin: escape HTML entities by default
330
331 ## [v0.7.0](https://github.com/shaarli/Shaarli/releases/tag/v0.7.0) - 2016-05-14
332 ### Added
333 - Adds an option to encode redirector URL parameter
334 - Atom/RSS feeds now support Markdown formatting, and plugins in general
335 - Markdown: use the tag `.nomarkdown` to avoid markdown processing
336 - Prefill the login field when the authentication has failed
337 - Show a private links counter
338
339 ### Changed
340 - Allow to use the bookmarklet in Firefox reader view (URL clean up)
341 - Improve tagcloud font size
342 - Improve title retrieving
343 - Markdown: inline code background color
344 - Refactor Netscape bookmark export
345 - Refactor Atom/RSS feed generation
346
347 ### Removed
348 - Remove delicious from Shaarli description
349
350 ### Fixed
351 - Fix bad login redirections causing a 404 in a few cases
352 - Fix tagcloud font-size with French locale
353 - Don't display empty tags in tag search
354 - Fix Awesomeplete conflicts with jQuery
355 - Fix UTC timezone selection
356 - Fix a bug preventing to import notes in browsers from bookmarks export
357 - Don't redirect to ?post if ?addlink is reached while logged out
358
359
360 ## [v0.6.5](https://github.com/shaarli/Shaarli/releases/tag/v0.6.5) - 2016-03-02
361 ### Fixed
362 - Fixes a regression generating an unnecessary warning (language in HTTP request)
363 - Fixes a bug where going through multiple reverse proxy could generate malformed URL
364 - Markdown: Fixes a bug where empty description blocks were displayed
365
366
367 ## [v0.6.4](https://github.com/shaarli/Shaarli/releases/tag/v0.6.4) - 2016-02-28
368 ### Added
369 - Add an updater class to automate user data upgrades
370 - Plugin admin page: adds a label for checkboxes and improve name display
371 - Plugin Wallabag: API version can be specified in plugin admin page
372
373 ### Changed
374 - Better tag cloud sorting, including special chars (`a > E > é > z`)
375 - Autolocale now sets all locale categories, not just time
376 - Use PHP's DateTime object instead of custom functions
377 - Plugin hooks: process includes before header/footer
378 - Markdown plugin: better styles for `<code>` and `<pre>` tags
379 - Improve searching:
380 - search terms are now considered separated and won't only return exact results anymore
381 - exact search can be done with quotes `"this exact sentence"`
382 - search supports excluded terms starting a dash `-exclude`
383 - implement crossed search: terms + tags
384 - all of them combined across all shaare fields
385 - New tag behaviour:
386 - tags starting with a dash will be renamed without it
387 - tags starting with a dot `.` will be hidden unless the user is logged in
388
389 ### Fixed
390 - Fix Markdown plugin escape issues (code/quote blocks, etc.)
391 - Link description aren't trimmed anymore to allow markdown format at the beginning of a shaare
392 - Fixes plugin admin redirection page on error
393
394 ### Security
395 - Fix a bug where non initialized variables were causing a warning
396 - Fix a bug where saving a link after edit could cause a 404 error
397
398
399 ## [v0.6.3](https://github.com/shaarli/Shaarli/releases/tag/v0.6.3) - 2016-01-31
400 ### Added
401 - Plugins administration page
402 - Markdown plugin added for shaares description
403 - Docker: Dockerfile is now in the main git repository and improved
404 - Add a `.gitattributes` to ease repository management
405 - Travis: include file permission checks
406
407 ### Changed
408 - Auto retrieve of title know works with websites (HTTPS, follow redirections, etc.)
409 - 404 page is now handled in a template
410 - Date in log files updated to work with fail2ban
411 - Wallabag: support of Wallabag v2 and minor fixes
412 - Link search refactoring
413 - Logging function refactoring
414
415 ### Fixed
416 - Fix a bug where renaming a tag was causing a 404
417 - Fix a bug allowing to search blank terms
418 - Fix a bug preventing to remove a tag with special chars when searching
419
420
421 ## [v0.6.2](https://github.com/shaarli/Shaarli/releases/tag/v0.6.2) - 2015-12-23
422 ### Changed
423 - Plugins: new footer hook
424 - Plugins: improve QR code
425 - Cleanup templates
426
427 ### Fixed
428 - Plugins: use the actual link URL to generate QR codes
429 - Templates: missing/erroneous page titles
430 - Templates: missing variables resulting in PHP errors
431
432 ### Security
433 - Fix invalid file permissions (remove executable bit)
434
435
436 ## [v0.6.1](https://github.com/shaarli/Shaarli/releases/tag/v0.6.1) - 2015-12-01
437 ### Added
438 - Add OpenSearch support
439 - Add a Doxygen makefile target
440 - Tools: add fine-grained file/directory permission checks (installation)
441
442 ### Changed
443 - Tools: check the 'stable' branch for new versions (updates)
444 - Cleanup: introduce an `ApplicationUtils` class
445
446 ### Removed
447 - Cleanup: remove `json_encode()` function (built-in since PHP 5.2)
448
449 ### Fixed
450 - Auto-complete more than one tag
451 - Bookmarklet: support titles containing quotes
452 - URL encode links when setting a redirector
453
454
455 ## [v0.6.0](https://github.com/shaarli/Shaarli/releases/tag/v0.6.0) - 2015-11-18
456 ### Added
457 - Introduce a plugin system
458 - Add a demo_plugin
459 - Add plugins:
460 - addlink_toolbar
461 - archiveorg
462 - playvideos
463 - qrcode
464 - readityourself
465 - wallabag
466
467 ### Changed
468 - Coding style
469
470 ### Fixed
471 - Adding a new link now returns the correct anchor in the URL
472 - Set default file permissions
473
474
475 ## [v0.5.4](https://github.com/shaarli/Shaarli/releases/tag/v0.5.4) - 2015-09-15
476 ### Added
477 - HTTPS: support being served behing an SSL-enabled proxy
478
479 ### Changed
480 - HTTP/Server utilities: refactor & add test coverage
481 - Project & documentation:
482 - improve/rewrite `README.md`
483 - update contributor list
484 - update `index.php` header
485
486 ### Fixed
487 - PHP session IDs: handle hash algorithms and bits per char representations
488
489
490 ## [v0.5.3](https://github.com/shaarli/Shaarli/releases/tag/v0.5.3) - 2015-09-02
491 ### Fixed
492 - Fix a bug that could prevent user to login
493
494
495 ## [0.5.3](https://github.com/shaarli/Shaarli/releases/tag/0.5.3) - 2015-09-02
496 This release has been YANKED as it points to a tag that does not follow our naming convention. Please use `v0.5.3` instead
497
498 ### Fixed
499 - Allow uppercase letters in PHP sessionid format
500
501
502 ## [v0.5.2](https://github.com/shaarli/Shaarli/releases/tag/v0.5.2) - 2015-08-31
503 ### Added
504 - Add PHP 7 to Travis platforms
505
506 ### Changed
507 - Also extract HTTPS page metadata (title)
508
509 ### Fixed
510 - Fix regression preventing to load LinkDB info when adding an existing link
511
512 ### Security
513 - Fix Full Path Disclosure upon cookie forgery
514
515
516 ## [v0.5.1](https://github.com/shaarli/Shaarli/releases/tag/v0.5.1) - 2015-08-17
517 ### Added
518 - Add a link to the shaarli/shaarli DockerHub repository
519
520 ### Changed
521 - Update local documentation
522 - Improve timezone detection at installation
523 - Improve feed cache handling
524 - Improve URL cleanup for new links
525
526 ### Fixed
527 - Fix 404 after editing a link while being logged out
528
529
530 ## [v0.5.0](https://github.com/shaarli/Shaarli/releases/tag/v0.5.0) - 2015-07-31
531 ### Added
532 - Add Firefox Social API
533 - Start code refactoring:
534 - add unit test coverage
535 - add Travis integration
536
537 ### Changed
538 - Search/Filter by tag fieds can now be accessed quickly with the `Tab` key
539 - Update documentation
540 - Remove duplicate tags in links
541 - Remove annoying URL patterns
542 - Start code refactoring:
543 - move all settings to `data/config.php`
544 - refactor Config, LinkDB, TimeZone, Utils
545
546 ### Fixed
547 - Fix locale handling
548 - Fix note URLs
549 - Fix page redirections
550 - Fix daily RSS browsing
551 - Fix title display
552 - Restore compatibility with PHP 5.3
553
554 ### Security
555 - Fix links not being hidden when `HIDE_PUBLIC_LINKS` is set
556
557
558 ## [v0.0.45beta](https://github.com/shaarli/Shaarli/releases/tag/v0.0.45beta) - 2015-03-16
559 ### Fixed
560 - Fix improperly displayed Unicode character
561 - Fix incorrect font size for "Add link" input field
562
563
564 ## [v0.0.44beta](https://github.com/shaarli/Shaarli/releases/tag/v0.0.44beta) - 2015-03-15
565 ### Added
566 - Add a Makefile to run static code checkers
567 - Add local documentation (help link in page footer)
568 - Use awesomplete library for autocompletion
569 - Use bLazy.js library for images lazy loading
570 - New 'Add Note' bookmarklet to immediatly open a note (text post) compose window
571
572 ### Changed
573 - Theme improvements and cleanup (menu, search fields, icons, linklist...)
574 - Allow 'javascript:' links sharing (bookmarklets)
575 - Make update check optional
576 - Redirect to homepage after adding a link via "Add Link" dialog
577 - Remove more annoying URL parameters for shared links
578 - Code cleanup
579
580 ### Removed
581 - Remove jQuery
582
583 ### Security
584 - Don't disclose version to visitors (shaarli-version.txt)
585
586
587 ## [v0.0.43beta](https://github.com/shaarli/Shaarli/releases/tag/v0.0.43beta) - 2015-02-20
588 ### Added
589 - Title button link URL is now configurable
590 - RainTPL's TMP and TPL directories path are now configurable
591 - Displayed URLs for each link are now clickable links
592 - Show links timestamps in Daily view
593
594 ### Changed
595 - Automatically prepend "Note:" to title of self-posts (posts not pointing to an URL)
596 - Make ATOM toolbar button optional (`SHOW_ATOM` configuration variable)
597 - Optional archive.org links for each Shaarli link (`ARCHIVE_ORG` option)
598 - Thumbnails: force HTTPS when possible
599 - Improve tag cloud font scaling
600 - Allow pointing RSS items to the permalink instead of the direct URL (`ENABLE_RSS_PERMALINKS` option)
601 - Update JS libraries and add version numbers in filenames
602 - Updates to README and footer
603
604 ### Fixed
605 - Fix problems when running Shaarli behind a reverse proxy (invalid RSS feed URL)
606 - Update check now checks against the community fork version
607 - Include `cache/`, `data/`, `pagecache/` and `tmp/` directories in the repository
608 - Fix duplicate tag search returning no results
609 - Fix unnecessary 404 error on "Add link" when the user is logged out
610 - Fixes to copyright/licensing information and unlicensed media
611 - Fixes for tag cloud invalid links
612 - Coding style fixes/cleanup
613 - Fix redirection after deleteing a link leading to a 404 error
614 - Shaarli's HTML is now W3C-compliant
615 - Search now works with Unicode characters
616
617 ### Security
618 - Do not leak server's PHP version and Shaarli's full path on errors
619 - Prevent Shaarli from sending a lot of duplicate cookies
620
621
622 ## [v0.0.42beta](https://github.com/shaarli/Shaarli/releases/tag/v0.0.42beta) - 2014-07-27
623 ### Added
624 - Add QRCode Javascript library
625 - Allow importing bookmarks with the same timestamp (hack)
626 - Allow putting a description in the bookmarklet URL
627 - Add `json_encode()` implementation for PHP<5.2
628 - Highlight search results
629
630 ### Changed
631 - Improve 'Stay signed in' behaviour
632 - Improve `smallHash()`
633 - Refactor QRCode generation
634 - Update Javascript lazyloading
635 - Update CSS
636
637 ### Removed
638 - Remove jQuery from almost all pages
639
640 ### Fixed
641 - Fix overlapping tags
642 - Fix field foxus in the bookmarklet
643 - Fix error message when `data/` is not writable
644 - Fix HTML generation
645
646 ### Security
647 - Fix XSS flaw
648
649
650 ## [v0.0.41beta](https://github.com/shaarli/Shaarli/releases/tag/v0.0.41beta) - 2013-03-08
651 ### Added
652 - Add HTTPS to the allowed protocols
653 - Add support for magnet links in link descriptions
654 - Allow creating new links as private by default
655 - Allow disabling jQuery
656 - Check write permissions
657 - Check session support before installation
658
659 ### Changed
660 - Improve token security
661 - RSS feed: allow inverting links/permalinks
662
663 ### Fixed
664 - Fix display issues during installation
665 - Fix popup redirection after login failure
666 - Fix RSS formatting for Thunderbird
667 - Fix thumbnail creation
668 - Fix cache purge
669
670 ### Security
671 - Fix login issue with WebKit browsers
672
673
674 ## [v0.0.40beta](https://github.com/shaarli/Shaarli/releases/tag/v0.0.40beta) - 2013-02-26
675 Initial release on GitHub.
676
677
678 ## [v0.0.40beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history) - 2012-08-24
679 ### Added
680 - Flickr thumbnail now also support albums, galleries and users
681 - Add a configuration option to disable session cookie protection
682 Check this if your get disconnected often or your IP address changes often
683
684 ### Removed
685 - Removed the xml comment in cached RSS/ATOM feed
686 (although W3C-compliant, this may cause problems in some feed readers)
687
688 ### Fixed
689 - A bug in the RSS cache would present old items as new in some cases
690 - A small bug (non-initialized variable) in page cache cleaning
691 - Proper "Nothing found" message when search returns no results
692 - No more 404 error when searching with empty input
693 - Flickr thumbnails are back (Flickr has made some changes to their domains)
694
695 ## [v0.0.39beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history) - 2012-08-10
696 ### Added
697 - A cache for RSS feed, ATOM feed and Daily RSS feed, because these URLs
698 are massively hammered. Cache is automatically purged whenever the database
699 is changed. This will reduce server load. I may add cache to other pages later.
700
701 ### Changed
702 - No more global `$LINKSDB` (Yuk)
703 - Background color was removed when hovering a link
704
705 ### Fixed
706 - Small bug corrected in config screen on timezones
707 - Calling a non-existing permalink now returns a crude 404 error instead of 200 (OK)
708 This is done on purpose
709 - The `shaarli` session cookie now has a proper path
710 Thus you can now install several Shaarlis on the same server in different paths,
711 and each will have its session
712 - Now when you delete a link, you go back the same page/search parameters you were on
713 - Restore previously removed `error_get_last()`, to ensure PHP 5.1 compatibility
714 (Yes, now it works on free.fr hosting)
715 - Added `dialog=1` in bookmarklet code for some browsers
716
717
718 ## [v0.0.38beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history) - 2012-02-06
719 ### Added
720 - Automatic creation of the `tmp` directory with proper rights (for RainTPL)
721 - When you click the key to see only private links, it turns yellow
722
723 ### Changed
724 - The "Daily" page now automatically skips empty days.
725
726 ### Fixed
727 - Corrected the tag encoding (there was a bug when selecting a second tag which contains accented characters)
728
729
730 ## [v0.0.37beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history) - 2012-02-01
731 ### Added
732 - Basic CSS for mobiles, which makes Shaarli //much// more usable on mobile devices
733 - Picture wall no more instantly kills your browser. Now it uses
734 [lazy image loading](http://www.appelsiini.net/projects/lazyload);
735 the pictures are loaded only as you scroll the page.
736 This will reduce browser memory usage (especially on mobile devices),
737 as well as server load.
738 If you have javascript disabled, the page will still work as before
739 (all images loaded at once)
740 - RSS feed for the "Daily" page. 1 RSS entry per day, with all links of that day.
741 RSS feed provides the last 7 days (only non-empty days are returned).
742 - In link list, added an icon to see only private links. Click to toggle (only private / all)
743
744
745 ## [v0.0.36beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history) - 2012-01-25
746 ### Added
747 - Shaarli licence in COPYING
748
749 ### Changed
750 - Display adjustments in "Daily" page
751
752 ### Fixed
753 - Improper text color in install form
754 - Error in QRCode url (missing '?')
755
756
757 ## [v0.0.35beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history) - 2012-01-25
758 ### Fixed
759 - Corrected a bug introduced in 0.0.34 which would improperly preprend data to URLs
760
761
762 ## [v0.0.34beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history) - 2012-01-25
763 ### Added
764 - There is now a QR-Code of each permalink to easily open a link on your smartphone
765 - Protocols `file:` and `apt:` are now also converted to clickable links (patch by Francis Chavanon)
766 - Thumbnail support for http://xkcd.com/ (patch by Emilien Klein)
767 - Thumbnail support for http://pix.toile-libre.org/
768 - Well I had _some_ mercy for users with antique browsers (IE) which do not have
769 support for gradients: I added a few `background-color`
770 - First version of the "Shaarli Daily", a page showing all links of a specific day.
771 By default, you see the links of the previous day.
772 There is still work to do on this page (error checking, better navigation (calendar?),
773 RSS feed, CSS for mobile and printing...)
774
775 ### Changed
776 - Upgraded bundled versions of jQuery (1.7.1) and jQuery UI (1.8.17)
777 - Upgraded bundled version of RainTPL (2.7)
778 - Changed HTTPS detection code
779
780 ### Fixed
781 - In link edition, you can now click the word "Private" to check the box
782 - Clicking a tag would not work properly if the tag contained special characters (like +)
783 - Added proper jQuery licence (shame on me)
784
785
786 ## [v0.0.33beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history) - 2012-01-17
787 ### Added
788 - Shaarli packaged to ease Linux distributions integration
789 As a simple user, you do not need to cope with these versions
790 Future releases of Shaarli will also be customized and published in these directories
791 Differences with the standard Shaarli version:
792 - deb:
793 - .tar.gz instead of .zip
794 - COPYING licence file added
795 - jQuery/jQuery-UI libraries removed to cope with Debian rules
796 This version links to the libs hosted at http://code.jquery.com
797 - rpm:
798 - sources located in a subdirectory with the same name as the zip file
799 - COPYING licence file added
800 - WARNING: When downloading the .tar.gz, always use wget (and not your browser),
801 otherwise the .tar.gz will be corrupted
802
803 ### Fixed
804 - ATOM feed validates again
805
806 ### Security
807 - XSS vulnerability patched (thanks to Stanislas D.!)
808
809
810 ## [v0.0.32beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history) - 2011-12-16
811 ### Added
812 - Better check on URL parameters (patch by gege2061)
813 - Add `max-height` and `overflow:auto` attributes so that content can be scrolled if too large
814
815 ### Changed
816 - HTML generation moved to RainTPL templates (in the `tpl/` directory)
817 - Better detection of HTTPS (patch by gege2061)
818 - In RSS/ATOM feeds, the GUID is now the permalink instead of the final URL (patch by gege2061)
819 - Jerrywham CSS patch included
820 - Multiple spaces are now respected in description.
821 Thus you can use Shaarli as a personal pastebin (for posting source code, for example).
822
823 ### Removed
824 - Page time generation was removed
825
826 ### Fixed
827 - Tab order changed in login screen
828 - Permalinks now work even if additional parameters have been added
829 (e.g. `/?E8Yj2Q&utm_source=blablabla...`)
830 - user.css is included only if the file is present
831 (This prevents a useless CSS include which makes a harmless but useless 404 error.)
832
833
834 ## [v0.0.31beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history) - 2011-11-29
835 ### Added
836 - Support for TED Talks (ted.com/talks) thumbnails (patch by Emilien K.)
837 - partial [patch](http://www.idleman.fr/blog/?p=508) by Idleman: Better design consistency, icon on private links. In-page popup was not included because it causes problem on some websites
838 - Support for bookmark files without ADD_DATE attributes
839 - Logo is clickable
840 - `user.css` can be added to overload Shaarli base CSS.(patch by Jerrywham).
841 Just put `user.css` in the same directory as shaarli.css.
842 Example: `<code css>#pageheader { background: blue; }</code>`
843 Please note that Shaarli CSS are not stable and may completely change on each version
844
845 ### Changed
846 - Edit and Delete buttons in link list were replaced with icons. (patch by Jerrywham)
847
848 ### Fixed
849 - Better error handling in thumbnail generation (patch by Emilien K.)
850 - The top menu is no longer displayed in bookmarklet popup
851 - Bookmark which have the exact same date/time are now correctly imported.
852 Most remaining import problems should be solved now
853 - Comment in Shaarli export moved to beginning of file to prevent clash with last link description
854
855
856 ## [v0.0.30beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history) - 2011-11-18
857 ### Added
858 - Add a small `delete` button in link list (after the `edit` button)
859
860 ### Fixed
861 - Moved the call to PubSubHub
862
863
864 ## [v0.0.29beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history) - 2011-11-18
865 ### Fixed
866 - Corrected a bug introduced in v0.0.28beta
867 (there was an error if you use the bookmarklet and you're not logged in)
868
869
870 ## [v0.0.28beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history) - 2011-11-17
871 ### Added
872 - Thumbnail support for youtu.be URLs (YouTube short url service)
873 - PubSubHub protocol support (from http://aldarone.fr/les-flux-rss-shaarli-et-pubsubhubbub/).
874 Warning: This was not tested. You need to set your hub url in
875 `$GLOBALS['config']['PUBSUBHUB_URL']` and put the official client (`publisher.php`)
876 in the same directory as Shaarli's `index.php`
877 - RSS and ATOM feeds now also contain tags (in `category` tags, as per their
878 respective specifications)
879
880 ### Changed
881 - New Shaarli theme and logo by Idle (http://www.idleman.fr/blog/?p=469)
882 - In picture wall, pictures point to Shaarli permalink instead of final URL.
883 This way, users can read the description.
884 - In RSS/ATOM feeds, guid and link URL of permalinks are now proper absolute URLs
885 - In RSS/ATOM feeds, URLs are now clickable
886 - Rename `http_parse_headers()` to `http_parse_headers_shaarli()` to prevent
887 name collision with some PHP extensions
888
889 ### Fixed
890 - Thumbnails removed for imgur.com/a/ URLs (Thumbnails are not available for albums on imgur)
891 - Shaarli now correctly only tries to get thumbnails for vimeo video URLs
892 - Fix a bug in imgur.com URLs handling that would cause some thumbnails not to appear
893 - The search engine would not return a result if the word to search was the first in description
894 - Extracted title is now correct if the page has two `title` html tags
895
896
897 ## [v0.0.27beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history) - 2011-10-18
898 ### Added
899 - Add a picture wall, which can be filtered too: it will use the same filters
900 (tags,text search) as current page when clicked.
901
902
903 ## [v0.0.26beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history) - 2011-10-17
904 ### Changed
905 - Made permalink more visible (smallHash)
906
907 ### Fixed
908 - Removed extras space in description when URLs are converted to clickable links
909 - Thumbnail for subreddit imgur urls (/r/...) were corrected (thanks to Accent Grave)
910
911
912 ## [v0.0.25beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history) - 2011-10-13
913 ### Added
914 - Better CSS for printing (thanks to jerrywham suggestion)
915 - Allow using a redirector or anonymizing proxy for links
916 (such as `http://anonym.to/?` to mask you `HTTP_REFERER`).
917 Just go to `Tools > Configure > Redirector`
918 (thanks to Accent Grave for the suggestion).
919 - The `ENABLE_LOCALCACHE` option can be set to `false` for those who have
920 a limited quota on their host.
921 This will disable the local thumbnail cache.
922 Services which require the use of the cache will have no thumbnails
923 (vimeo, flickr, direct link to image).
924 Other services will still have a thumbnail (youtube,imgur.com,dailymotion,imageshack.us)
925
926 ### Changed
927 - Now thumbnails generated by Shaarli are croped to a height of 120 pixels
928 - YouTube thumbnails now use `default.jpg` instead of `2.jpg` (This is usually more pertinent)
929 - Configuration options (such as `HIDE_TIMESTAMPS`, `ENABLE_THUMBNAILS`, etc.)
930 can now be put in a an external file so that you do not have to tweak them again
931 when you upgrade Shaarli.
932 Just add the file `data/options.php`.
933 - If a single link is displayed, the page title contains the title of the link
934 - Shaarli page title is clickable (and has the same link as "Home")
935 - A few CSS tweaks (thanks to maethor for suggestion)
936
937 ### Fixed
938 - Shaarli now supports newlines in titles (thanks to dixy)
939 - The link to the RSS feed in page header was not correct
940
941
942 ## [v0.0.24beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history)
943 ### Added
944 - Allow posting an entry without a link. (You can use Shaarli as a kind of "personal twitter")
945 - Each Shaarli entry now has a short link (just click on the date of a link).
946 Now you can send a link that points to a single entry in your Shaarli
947 - In descriptions, URLs are now clickable
948 - Thumbnails will be generated for all link pointing to .jpg/png/gif
949 (as long as the images are less than 4 Mb and take less than 30 seconds to download)
950
951 ### Fixed
952 - Now thumbnails also work for imgur gallery links (/gallery/...)
953 (Thanks to Accent Grave for the correction)
954 - Removed useless debugging information in log
955 - The filter in RSS/ATOM feed now works again properly (it was broken in 0.0.17beta)
956
957
958 ## [v0.0.23beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history)
959 ### Added
960 - Added thumbnail support for imageshack.us
961
962 ### Changed
963 - Now you can clic the sentence "Stay signed in" to tick the checkbox (patch by Emilien)
964 - In tag editing, comma (,) are now automatically converted to spaces
965 - In tag editing, autocomplete no longuer suggests a tag you have already entered in the same line
966
967
968 ## [v0.0.22beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history)
969 ### Added
970 - Support for thumbnails for flickr.com
971 - Allow staying signed in:
972 Your session will be kept open even if you close the browser.
973 This is available through a checkbox in the login screen.
974
975 ### Changed
976 - Some hosts (flickr, vimeo) are slow as hell for the thumbnails,
977 or require an extra HTTP request.
978 For these hosts the thumbnail generation has been deported outside the generation
979 of the page to keep Shaarli snappy.
980 For these slow services, the thumbnails are also cached.
981
982 ### Fixed
983 - Title was not properly passed if you had to login when using the bookmarklet (patch by shenshei)
984
985
986 ## [v0.0.21beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history)
987 ### Added
988 - Thumbnails for some services
989 Currently supports: YouTube.com, dailymotion.com, vimeo.com (slow!) and imgur.com.
990 Thumbnails are enabled by default, but you can turn them off
991 (set `define('ENABLE_THUMBNAILS',true);` to `false`).
992
993 ### Changed
994 - Removed the focus on the searchbox (this is cumbersome when you want to browse pages
995 and scroll with the keyboard)
996
997
998 ## [v0.0.20beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history)
999 ### Fixed
1000 - RSS feed is now served as `application/rss+xml` instead of `application/xhtml+xml`
1001 (which was causing problem in //RSS Lounge//)
1002 - ATOM feed is now served as `application/atom+xml` instead of `application/xhtml+xml`
1003
1004
1005 ## [v0.0.19beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history)
1006 ### Added
1007 - ATOM feed
1008
1009 ### Fixed
1010 - Patch by Emilien to remove the update notification after the update
1011
1012
1013 ## [v0.0.18beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history)
1014 ### Added
1015 - You can now configure the title of your page
1016 - New screen to configure title and timezone
1017
1018 ### Changed
1019 - Nicer timezone selection patch by killruana
1020
1021 ### Fixed
1022 - New lines now appear correctly in the RSS feed descriptions.
1023
1024
1025 ## [v0.0.17beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history)
1026 ### Added
1027 - Change password screen added (based on a patch by killruana)
1028 - Autocomplete in the tag search form
1029 - You can rename or delete a tag in all links
1030 (very handy if you misspelled a tag or want to merge tags)
1031 - When you click the RSS feed, the feed will be filtered with the same filters
1032 as the page you were viewing
1033
1034 ### Changed
1035 - CSS adjustments by jerrywham
1036 - Minor corrections
1037
1038
1039 ## [v0.0.16beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history)
1040 ### Added
1041 - Upgrade notification:
1042 If a new version of Shaarli is available, you will be notified by a discreet
1043 message in top-right corner.
1044 This message will only be visible if you are logged in, and the check will be
1045 performed at most once a day.
1046 - Preliminary tag cloud (ugly for the moment, I need to find something better)
1047
1048 ### Changed
1049 - Replaced `preg_match()` with `version_compare()` to check PHP version
1050 - Includes a patch by Emilien K. to mask dates if user is not logged in.
1051 The option can be activated by changing `define('HIDE_TIMESTAMPS',false);` to `true`
1052
1053
1054 ## [v0.0.15beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history)
1055 ### Added
1056 - New in import: Option to overwrite existing links when importing
1057 - On free.fr, automatic creation of the `/sessions` directory
1058
1059 ### Changed
1060 - CSS Stylesheet is now an external file (shaarli.css).
1061 This reduces page size and eases customization.
1062
1063 ### Removed
1064 - Removed some parameters in URL added by some feed proxies (`#xtor=RSS-...`)
1065
1066 ### Fixed
1067 - Bug corrected: Prevented loop on login screen upon successful login after a failed login
1068 - Bug corrected in import: HTML entities were not properly decoded.
1069 If you imported your Delicious/Diigo bookmarks, your should import them again
1070 and use the 'overwrite' option of the import feature.
1071
1072
1073 ## [v0.0.14beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history)
1074 ### Added
1075 - You no longer need to disable `magic_quotes` on your host.
1076 Shaarli will cope with this option beeing activated.
1077
1078
1079 ## [v0.0.13beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history)
1080 ### Added
1081 - Import: New option to import html bookmark file as private links
1082 - Import: Importing a bookmark file will not overwrite existing links anymore
1083 - Export: New options to export only public or private links
1084
1085 ### Changed
1086 - In tag autocomplete, tags are presented in use order
1087 (most used tags first, instead of alphabetical order)
1088 - RSS Feed can now be filtered by tags or fulltext search. Just add to the feed url:
1089 - `&searchtags=minecraft+video` for tag filtering
1090 - `&searchterm=portal` for fulltext search to the feed url
1091
1092
1093 ## [v0.0.12beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history)
1094 ### Added
1095 - Add a check that the config file was properly created
1096 (in case Shaarli does not have the write rights in its folder)
1097 - Open Shaarli: there is an option to open your Shaarli to anyone.
1098 Anybody will be able to add/edit/delete links without having to login.
1099 In code, change `define('OPEN_SHAARLI',false);` to `true`.
1100 Note: No anti-spam for the moment. You are warned!
1101 - Autocomplete for tags
1102
1103
1104 ## [v0.0.11beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history)
1105 ### Added
1106 - Add a check and a warning for some hosts which still have `magic_quotes` activated
1107
1108
1109 ## [v0.0.10beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history)
1110 ### Added
1111 - Get rid of `&quot;` in titles
1112
1113
1114 ## [v0.0.9beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history)
1115 ### Added
1116 - Now works on hosts `free.fr` and `1and1`
1117 - Now works with PHP 5.1
1118 - PHP version is now checked and an error message is displayed if version is not correct
1119
1120 ### Fixed
1121 - No more error messages if the browser does not send `HTTP_REFERER`
1122 - No more error messages if the host has disabled http protocol in PHP config (eg. 1and1)
1123
1124
1125 ## [v0.0.8beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history)
1126 ### Changed
1127 - In RSS feed, GUID content replaced with the URL of the link, because some
1128 stupid RSS reader (like Google Reader) use `<guid>` as a link instead of using `<link>`
1129
1130
1131 ## [v0.0.7beta](http://sebsauvage.net/wiki/doku.php?id=php:shaarli:history) - 2011-09-16
1132 First public release by Sebsauvage, see original article:
1133 [Adieu Delicious, Diigo et StumbleUpon. Salut Shaarli !](http://sebsauvage.net/rhaa/index.php?2011/09/16/09/29/58-adieu-delicious-diigo-et-stumbleupon-salut-shaarli-) (FR)