| Age | Commit message (Collapse) | Author | 
|---|
|  | module installers don't have to know the grotty details of how it works. | 
|  | * Refactor blocks so that they have a separate id vs css_id.  This way
  we can have a unique identifier for each visual block.
* Store blocks with a random id as their unique identifier
* Add Admin_Dashboard::remove_block() and modify
  themes/admin_default/views/block.html.php to call it when you click the
  remove box. | 
|  | OLD:
  $form->submit("Foo")  -->  <input type="submit" value="Foo">
New:
  $form->submit("foo_button")->("Foo") --> <input type="submit" name="foo_button" value="Foo">
Mostly we don't care what the button is so we leave the name blank. | 
|  | both the sidebar and the center content area from a dropdown at the
top of the dashboard sidebar. | 
|  | And truncate strings before passing them to MySQL. | 
|  | comment.  Get rid of comment::update tests since, comment::update is
gone.
Found a bug in comment::create() in the process.. yay unit tests! | 
|  |  | 
|  | user modules.
* Don't delete vars when we delete a module.  This makes
  reinstalling a module a lot easier.
* Add user::lookup() as the preferred way to load a user, so that
  other modules don't delve into the user module (that'd be a
  problem when we swap out user modules)
* Notify site admins if Akismet is not fully configured
* Bundle all server variables into the comment so that if/when we
  re-check the comment, we are not using the server info from the
  site admin's request.
* Update Akismet to grab request context data from the comment
* Pre-seed comment fields if we have a logged in user.  Update
  comment::create() API to clarify it for this.
* Delete comment::update(), that's a controller function.
* Add url to User_Model
* Add author_name() author_email() and author_url() to
  Comment_Model.  It'll return the appropriate values depending
  on whether the comment was left by a logged in user or a guest.
* Use resetForm() instead of clearForm() when we reload the
  comment form after ajax submit, this way we preserve the
  pre-seeded values.
* In the user profile page, ignore blank passwords. | 
|  | - And refactor printf to our string interpolation / pluralization syntax
- Also, a slight change to the translations_incomings table, using binary(16) instead of char(32) as message key. | 
|  | 1) Akismet now detects when we change a comment's published state and submits
   info back to akismet.com as appropriate
2) We now show 4 different queues (all / approved / unapproved / spam) and let you
   move messages between the queues
3) We track and display "spam caught" stats.
4) You can delete comments entirely. | 
|  | (approved, unapproved, spam). | 
|  | fails set the comment
state to unpublished. | 
|  | "view comments" link to the comment menu helper. | 
|  | Rename menu "General Settings" -> "Settings"
  Rename "Comments Moderation" -> "Comments"
  Move "Content" -> "Configure Spam Filtering" -> "Settings" -> "Spam Filtering" | 
|  | 2) Replaced it with a string field (state) which contains the state of the comment. i.e. published, unpublished, spam.  Unsure if we want to create constants in comments.php to standardize the valid values... thoughts?
3) synchronized the spamfilter and comment unit tests with the current functionality | 
|  | the appropriate form content.  Add a callback so if the driver changes in the driver selection dropdown, then the api form fields are updated with the new form fields for that driver | 
|  | any spam services.  But you can go into the admin screen and choose the driver and set the api key. | 
|  | comment model) | 
|  | bytes on some systems. | 
|  |  | 
|  | the spam_filter module | 
|  | two columns to the comment table.  The url of the author's web site(default null) and a flag to indicate that the comment is visible (default true).
The comment block has changed to only display comments that are visible.
And there is code added to call the spam_filter helper if the spam_filter module is installed. | 
|  |  | 
|  | communicate.  Almost all controllers now use JSON to speak to the
theme when we're dealing with form processing.  This means tht we only
send the form back and forth, but we use a JSON protocol to tell the
browser success/error status as well as the location of any newly
created resources, or where the browser should redirect the user.
Lots of small changes:
1) Admin -> Edit Profile is gone.  Instead I fixed the "Modify Profile" link
   in the top right corner to be a modal dialog
2) We use json_encode everywhere.  No more Atom/XML for now.  We can bring those
   back later, though.  For now there's a lot of code duplication but that'll be
   easy to clean up.
3) REST_Controller is no longer abstract.   All methods its subclasses should create
   throw exceptions, which means that subclasses don't have to implement stubs for
   those methods.
4) New pattern: helper method get_add_form calls take an Item_Model,
   not an id since we have to load the Item_Model in the controller
   anyway to check permissions.
5) User/Groups REST resources are separate from User/Group in the site
   admin.  They do different things, we should avoid confusing overlap. | 
|  | and XML for now, we have no driver for those technologies so anything
we implement is not going to be sufficiently tested and therefore
it'll be broken.
Change all comment functions to return JSON and update the JS to deal
purely with JSON.  This is our new protocol for talking to the browser
and it should be flexible and portable.
Create comments.html.php.  This duplicates comment.html.php, but will
be more efficient for rendering comments since we won't be creating a
new View for every comment we render. | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | the various modules.  In the process, rename xxx_menu::site_navigation() to just
xxx_menu::site().  And add xxx_menu::admin().
The menus are the same as before, but I changed the HTML to be
consistent with the way that we do it in the regular site, and this
broke the superfish styles.  I don't know how to fix this.. help me
Chad! | 
|  | convention.  To respond to the "photo_created" event in the gmaps
module, you create modules/gmaps/helpers/gmaps_event.php containing
class gmaps_event which has function photo_created.
Renamed all events from gallery.foo.bar to foo_bar
Updated tag module to use new convention. | 
|  | creation.  I probably forgot some, but its a start. | 
|  |  | 
|  |  | 
|  |  | 
|  | li to comment thread ul. Added fadeIn for user login. | 
|  | readable)
Prefer url::abs_site() to atom::get_base_url() | 
|  | entries and feeds has been considerably simplified and reduced. | 
|  | http://example.gallery.com/index.php/comments/{comment_id}?_format=atom
* Changed Content-Type of Atom feeds and entries to XML for easier debugging.
* Added an Atom helper class with some common functions and cleaned up entry and feed generation code a bit in the comment helper.
* Style fixes. | 
|  | their proper parents.
* Added valid Atom 1.0 feeds for comments. They can be seen at:
  http://gallery.example.com/index.php/comments?item_id={photo_id}&_format=atom | 
|  | lower case:
http://docs.kohanaphp.com/general/helpers | 
|  | Removed gCommentForm id, it's not necessary, at least not  now. | 
|  | content | 
|  | * HTTP header setting in comment module now going through REST helper API.
* Fixed items controller test.
* Fixed user installer test.
* Fixed _create() handling in the REST controller.
* Fixed routing for edit and add forms.
* Added some tests for the REST controller.
* Set svn:eol-style to LF on a bunch of files.
* Added preamble to MY_Forge.php. | 
|  | 1) We now use __call() in REST_Controller to handle any requests to a controller
   that were not already handled.  In the case of RESTful controllers, this should
   be the only entry point (although they're free to break the model and add other
   ones.. nothing stops them).
   This means that we can remove all the catch-all routes in
   routes.php which greatly simplifies it.
2) Move request_method() and output_format() out of REST_Controller and into the REST
   helper in core/helpers/rest.php
3) Experiment with letting the various subclasses check the output_format and deal with
   it themselves.  This simplifies the API, but it might be a bad idea in that it might
   push too much work to the individual controllers.  It's a balancing act, time will tell,
   I'm willing to change it back later. | 
|  | - Return proper Content-Type header for GET /comments requests
- Got rid of the query processing for index() in REST_Controller()
- Small misc fixes | 
|  |  | 
|  | refer to collections should now have plural names and there should be only one controller per resource. Updated existing classes that implement REST_Controller. The routing now works like this:
GET    /controller    -> controller::_index()
POST   /controller    -> controller::_create()
GET    /controller/id -> controller::_show()
PUT    /controller/id -> controller::_update()
DELETE /controller/id -> controller::_delete()
GET    /form/edit/controller/resource_id -> controller::_form()
GET    /form/add/controller/data         -> controller::_form() | 
|  |  | 
|  | XML to the comment controllers as a proof of concept.  It's not fully
baked; we should examine ways to create helpers to make this process
easier. |