I’m just starting to work with JCR (apache jackrabbit), i want to ask simple question (because i coudn’t find good tutorial for it):
So for what do i need Node.checkout and Node.checkin methods?
What do they mean?
Thx
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
The ‘checkin’ and ‘checkout’ methods have to do with how a JCR repository tracks the versions of content. The ‘checkout’ method signals to the repository that your client application is (likely) going to be modifying some versionable content. The ‘checkin’ methods signals to the repository that your client application has made changes to the versionable content, and that the repository should record those changes (e.g., the new version) in the version history.
For example, let’s imagine that we want to create a node at ‘/a/b/c’ that is versionable. This is done using something like the following code:
To create content, you simply set the ‘mix:versionable’ mixin (or use a mixin or primary node type that inherits from ‘mix:versionable’) on a node and then save your changes. At that point, the repository will initialize the version history for that node (or subgraph).
Upon ‘session.save()’, the repository will note the ‘mix:versionable’ mixin and will initialize the version history for the content at ‘/a/b/c’. From this point on, your client application uses ‘checkout’ and ‘checkin’ to add new versions to the history.
When ‘checkin’ is called, the repository will take the current state of ‘/a/b/c’ and will add it to the version history. Of course, this process is repeated each time you want to make changes to versionable nodes.