Uploaded image for project: 'Jackrabbit Content Repository'
  1. Jackrabbit Content Repository
  2. JCR-2740

On missing child node, automatically remove the entry (when a session attribute is set)

    XMLWordPrintableJSON

Details

    • New Feature
    • Status: Closed
    • Major
    • Resolution: Fixed
    • None
    • 2.2
    • jackrabbit-core
    • None

    Description

      If a node points to a non-existing child node (which is a repository inconsistency), currently this child node is silently ignored for read operations (as far as I can tell). However, when trying to add another child node with the same name, an exception is thrown with a message saying a child node with this name already exists. Also, the parent node can't be removed.

      One solution is to remove the bad child node entry, but only if the session attribute "org.apache.jackrabbit.autoFixCorruptions" is set (so by default the repository is not changed 'secretly'):

      SimpleCredentials cred = new SimpleCredentials(...);
      cred.setAttribute("org.apache.jackrabbit.autoFixCorruptions", "true");
      rep.login(cred);

      It's not a perfect solution, but it might be better than throwing an exception and basically preventing changes.

      Another solution (not implemented) would be to rename the missing child node entry when trying to add a child node with the same name (for example add the current date/time, or a random digit until there is no conflict), and then continue with adding the new child node.

      Attachments

        1. JCR-2740-d.patch
          18 kB
          Stefan Guggisberg
        2. jcr-2740-c.patch
          17 kB
          Thomas Mueller
        3. jcr-2740-b.patch
          7 kB
          Thomas Mueller
        4. jcr-2740.patch
          7 kB
          Thomas Mueller

        Activity

          People

            thomasm Thomas Mueller
            thomasm Thomas Mueller
            Votes:
            0 Vote for this issue
            Watchers:
            0 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved: