aboutsummaryrefslogtreecommitdiff
path: root/IkiWiki/CGI.pm
Commit message (Collapse)AuthorAge
* Fix CSRF attacks against the preferences and edit forms. Closes: #475445Joey Hess2008-04-10
| | | | | | | | | | | | | | | | | | | | | | | | | The fix involved embedding the session id in the forms, and not allowing the forms to be submitted if the embedded id does not match the session id. In the case of the preferences form, if the session id is not embedded, then the CGI parameters are cleared. This avoids a secondary attack where the link to the preferences form prefills password or other fields, and the user hits "submit" without noticing these prefilled values. In the case of the editpage form, the anonok plugin can allow anyone to edit, and so I chose not to guard against CSRF attacks against users who are not logged in. Otherwise, it also embeds the session id and checks it. For page editing, I assume that the user will notice if content or commit message is changed because of CGI parameters, and won't blndly hit save page. So I didn't block those CGI paramters. (It's even possible to use those CGI parameters, for good, not for evil, I guess..) The only other CSRF attack I can think of in ikiwiki involves the poll plugin. It's certianly possible to set up a link that causes the user to unknowingly vote in a poll. However, the poll plugin is not intended to be used for things that people would want to attack, since anyone can after all edit the poll page and fill in any values they like. So this "attack" is ignorable.
* * Record new pages in %pagesources temporarily when previewing so thatJoey Hess2008-03-17
| | | | | things that need to know the page source or type can query it from there. Fixes previewing of tables when creating a new page.
* * Use forcebaseurl to make page previews be displayed with the html baseJoey Hess2008-03-12
| | | | | | set to the destination page. This avoids need for hacks to munge the urls in preview mode, which fixes several bugs. * Several destpage fixes in plugins.
* Fix links generated by preprocessor directives when previewing.Joey Hess2008-02-24
| | | | | | | | | | As was already done for linkfication, links generated in a prevew page are relative to the top of the wiki, so it has to be told that the destpage is there. I was using "" to indicate this, but that may confuse some preprocessor plugins, which treat parameters with an empry value specially (sparkline is one such). Instead, use "/", which is more accurate anyway and works just as well.
* * Preview limits the page dropdown to what's selected previouslyJoey Hess2008-02-14
| | | | | | | | (as preserving the full list across preview would be tricky). Userdirs were still being offered as an option there, remove them. * Fix a bug where user A created a page concurrently with user B, and when B previewed it would redirect B to A's new page, losing B's work. Instead, don't redirect and let conflict handling resolve it.
* move saveindex call into preview blockJoey Hess2008-02-03
| | | | | This call is only present to handle the case where previewing a page actually causes files to be rendered.
* remove another commit mail mentionJoey Hess2008-02-03
|
* * cgi hooks are now run before ikiwiki state is loaded.Joey Hess2008-02-03
| | | | | * This allows locking the wiki before loading state, which avoids some tricky locking code when saving a web edit.
* non-tabular recentchanges displayJoey Hess2008-01-29
| | | | Doesn't look as good as the old table, but works as a rss feed.
* * Removed support for sending commit notification mails. Along with it wentJoey Hess2008-01-29
| | | | | the svnrepo and notify settings, though both will be ignored if left in setup files.
* support for internal-use page typesJoey Hess2008-01-28
| | | | | | If a page type starts with an underscore, hide it from the list of page types in the edit form, and don't allow editing pages of that type. This allows for plugins to add page types for internal use.
* move userlink to IkiWiki.pmJoey Hess2008-01-28
| | | | I have a plugin that needs to use userlink.
* change rcs_recentchanges when to absolute, not relative, timeJoey Hess2008-01-28
| | | | | No point in using a relative time value in rcs_recentchanges. Different consumers of the info want different things.
* In preferences, allow the subscriptions and email fields to be clearedJoey Hess2008-01-09
|
* add explicit test for do=postsigninJoey Hess2008-01-07
| | | | This happens when openid auth fails in certian ways
* fixesJoey Hess2008-01-07
|
* * Improved the canedit hook interface, allowing a callback function to beJoey Hess2008-01-07
| | | | | | | returned (and not run in some cases) rather than the plugins directly forcing a user to log in. * opendiscussion: allow editing of the toplevel discussion page, and, indirectly, allow creating new discussion pages.
* * Only try postsignin if no other action matched. Fixes a bug where theJoey Hess2008-01-07
| | | | | user goes back from the signin screen and does something else. * Improve behavior when trying to sign in with no cookies.
* fix an uninitialised value warningJoey Hess2008-01-05
|
* * Stop testing Encode::is_utf8 in decode_form_utf8: That doesn't work.Joey Hess2008-01-01
| | | | | | | | | | * decode_form_utf8 only fixed the utf-8 encoding for fields that were registered at the time it was called, which was before the formbuilder_setup hook. Fields added by the hook didn't get decoded. But it can't be put after the hook either, since plugins using the hook need to be able to use form values. To fix this dilemma, it's been changed to a decode_cgi_utf8, which is called on the cgi query object, before the form is set up, and decodes *all* cgi parameters.
* * Allow editing a page and deleting all content, while still disallowingJoey Hess2007-12-12
| | | | creating a new page that's entirely empty.
* * Ensure that web edited pages always end in a newline.Joey Hess2007-12-12
|
* * Change formbuilder hook to not be responsible for displaying a form,Joey Hess2007-12-12
| | | | | | so that more than one plugin can use this hook. I believe this is a safe change, since only passwordauth uses this hook. (If some other plugin already used it, it would have broken passwordauth!)
* MAJOR basewiki reorgJoey Hess2007-12-08
| | | | | Including redir pages for the moved basewiki pages. These will be removed in a future release.
* * In the cgi edit path, reload the index file before rendering. A bugjoey2007-10-10
| | | | | | | | | | showed up where a web edit that added a page caused a near-concurrent web edit to fail in will_render. While it would be hard to reproduce this, my analysis is that the failing cgi started first, loaded the index file (prior to locking) then the other cgi created the new page and rendered it, and then the failing cgi choked on the new file when _it_ tried to render it. Ensuring that the index file is loaded after taking the lock will avoid this bug.
* * Save index after previewing page edit, since even previewing can createjoey2007-09-22
| | | | | | files in some situations, and this is appropriate in some cases, such as the teximg plugin's error log file. Such files will be automatically cleaned up at an appopriate later time.
* * Support for looking in multiple directories for underlay files.joey2007-08-28
| | | | | | | * Plugins can add new directories to the search path with the add_underlay function. * Split out smiley underlay files into a separate underlay, so if the plugin isn't used, the wiki isn't bloated with all those files.
* * Add an editcontent hook.joey2007-08-26
|
* * Call the formbuilder hook for the edit page.joey2007-08-22
| | | | | | * Call decode_form_utf8 before running formbuilder_setup hooks. * Add editdiff plugin contributed by Jeremie Koenig. * Fix it to not leak path info.
* * Applied Jeremie Koenig's pluggable editpage buttons patch:joey2007-08-17
| | | | | | | | | | | | - add a title to the editpage form; - pass a reference to the list of buttons to the formbuilder_setup hooks, so we can add ours; - relax asumption about the possible submit values (use "Save Page" explicitly); - de-hardcode the submit buttons from the editpage template (This was needed for compatability with a bug in CGI::FormBuilder 3.0401, but ikiwiki already needs a newer version.) * Pass buttons to all other formbuilder_setup hooks too.
* proper fix for adding file, based on jkoenig's patchjoey2007-08-15
|
* * Fix bug when editing file from underlaydir, need to rcs_add it even thoughjoey2007-08-14
| | | | a page creation isn't occuring.
* * Fix bug in deletion/move during edit code introduced in 1.44. Need to takejoey2007-08-14
| | | | the underlaydir into account.
* Remove two header => 1 settings that were overridden by later header => 0joey2007-08-14
|
* * Move blog form code out of CGI.pm and into the inline plugin.joey2007-08-05
|
* * Add sessioncgi hook. joey2007-08-05
|
* remove cruftjoey2007-08-05
|
* * Wrap the editpage template in the standard misctemplate, this allows thejoey2007-07-16
| | | | | pagetemplate hook to work for that page. * Above change fixes the favicon plugin to work on edit pages.
* * Add a destpage parameter to the filter hook.joey2007-05-17
| | | | | * Fix links to smilies generated by the smiley plugin for inlined pages. The old links were often wrong, but often still worked by accident.
* * Make all templates have a footer div to ease themeing. Required templatejoey2007-05-11
| | | | | | | | and style sheet updates, and unless you're using customised versions, you'll want to rebuild wikis on upgrade to this version to avoid inconsistencies. * Allow WIKINAME to to used in footers, as an example of something to put there.
* * Use div layout for the signin and preferences forms, so that they can bejoey2007-04-30
| | | | | | styled using the stylesheet, rather than by creating signin and prefs templates. * Make the openid login form nicely styled.
* * Use fieldsets in the preferences form to group related options together.joey2007-04-29
| | | | Especially cleans up the ordering of the admin's preferences form.
* * Detect the case of two people independently creating the same page at thejoey2007-03-17
| | | | same time, and let the second person resolve the conflict.
* * Fix some broken logic in cgi creation of a subpage when a toplevel pagejoey2007-03-17
| | | | with the same name already exists, and generally simplify the edit code.
* simplify preview codejoey2007-03-17
|
* correct dup page name detect in blog posting codejoey2007-03-08
|
* * The underscore escaping support exposed a bug in edit links: Such linksjoey2007-03-08
| | | | | | | | | were titlepage escaped in the urls, and then doubly escaped by the CGI when editing. To fix this, I removed the titlepage escaping in the edit urls. * That means that *every edit link* on the wiki is potentially changed. Rebuilding wikis on upgrade to this version therefore necessary; enabled that in postinst.
* My fix to support encoded underscores in page titles broke links to pagesjoey2007-03-07
| | | | | | | with underscores in their filenames, since the link code also used titlepage. Create a new linkpage function and have the link code use that instead.
* * The slash escaping when adding to a blog from the CGI was not workingjoey2007-03-07
| | | | | | since it ended up being double-escaped. Instead, just remove slashes. * Fix some nasty issues with page name escaping during previewing (introduced in 1.44).
* * Add preview parameter to preprocesser calls, use this rather than thejoey2007-03-06
| | | | | | | | previous ugly hack used to avoid writing rss feeds in previews. * Fix the img plugin to avoid overwriting images in previews. Instead it does all the work to make sure the resizing works, and dummys up a resized image using width and height attributes. * Also fixes img preview display, the links were wrong in preview before.