-
Notifications
You must be signed in to change notification settings - Fork 780
Initial commit of persistence extensions #1872
Initial commit of persistence extensions #1872
Conversation
Signed-off-by: Chris Jackson <chris@cd-jackson.com>
* @author Chris Jackson - Initial implementation and API | ||
* | ||
*/ | ||
public interface HistoricalPersistenceStoreService { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The current interfaces are called PersistenceService and QueryablePersistenceService.
So "Store" is definitely too much here. I also wonder, if there is a better description than "Historical". How about ModifiablePersistenceService?
Should this interface directly extend QueryablePersistenceService or can there be real cases where it isn't queryable?
The PersistenceAdminService also wants to address removal of entries. If I remember our past discussions right, you probably want to add some delete/remove methods to this interface as well, don't you?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So "Store" is definitely too much here.
Ok - HistoricalPersistenceService
?
How about ModifiablePersistenceService?
But it's not modifyable - it just allows you to store information with a time - you can't update anything in the store so in this respect it's no different than the other services.
Should this interface directly extend QueryablePersistenceService
Yes - you're probably right - I don't think it makes sense without query.
The PersistenceAdminService also wants to address removal of entries. If I remember our past discussions right, you probably want to add some delete/remove methods to this interface as well, don't you?
Yes - I split those into a separate interface though. I'm happy to consolidate into a single interface if you prefer, but I recall in the past you wanted to keep admin (delete) functions separate.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
But it's not modifyable
Right, but if we combine it with your other "separate interface to come", it will be :-)
I'm happy to consolidate into a single interface if you prefer, but I recall in the past you wanted to keep admin (delete) functions separate.
Well, I wanted to keep any non-chonological write operations separate. If we introduce a "store with timestamp" method, I think this anyhow means that the service is able to modify its already persisted data - and hence also offers deletion of entries etc. So for me, it makes sense to combine those methods in one interface.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Right, but if we combine it with your other "separate interface to come", it will be :-)
Yes, if we combine into a single interface, then this is fine with me.
Ok - so I will update this PR with a single I'll also look to see if I can port a single persistence service to ESH to implement these services. This might take a little thought - ideally I would have done the JDBC, but there might be license issues and I might need to break out the drivers into separate repos to make it ESH compatible. |
You are the native speaker, but isn't the correct spelling Modifiable?
What about your H2 efforts you were once doing? As it is available under EPL, this sounds like a pretty good candidate? |
* Returns a list of items that are stored in the persistence service | ||
* | ||
* This is returned as a string to allow the persistence service to return items that are no long available as an | ||
* openHAB {@link Item}. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
please don't mention openHAB here
Native speaker, yes, but also an engineer, so be definition, spelling is far from my strong point! :) |
Signed-off-by: Chris Jackson <chris@cd-jackson.com>
API updated -:
Any thoughts on this appreciated. I've already made most of the mods to the persistence service and added the H2SQL service - more testing and tidying required of course, but before I do I thought I'd get feedback on the API. |
* | ||
* @return true if the item was deleted | ||
*/ | ||
public boolean removeItemData(String itemName); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
to make it very clear, I would call it removeAllItemData
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am considering to remove this method and instead just have the remove
method. If all data is removed using the remove
method, then the item should also be deleted from the database. I think this is a more fail safe method - it means you need to actively configure a filter with a start/stop time that includes all data.
What do you think?
lgtm, so fine for me if you go ahead. @maggu2810 Any comments from your end? |
* @param date the date of the record | ||
* @param item the data to be stored | ||
*/ | ||
public void store(Date date, Item item); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If you don't care, I would prefer to use Item as first argument and Date as second one.
Why? Because there is already the method void store(Item item);
.
https://github.com/eclipse/smarthome/blob/e0985e9/bundles/core/org.eclipse.smarthome.core.persistence/src/main/java/org/eclipse/smarthome/core/persistence/PersistenceService.java#L40
And if this one has an additional argument I prefer to add it at the endt.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We can remove "public" modifiers on interface functions (its default).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I know - the reason I added them was to maintain the same style as other interfaces in this package. I’m happy to remove it though.
Updated following latest comments. As per previous comment, I've now removed the method to delete the item. It is expected that the persistence service should free resources associated with an item if all data is deleted. I've also added the REST changes if you have comments here. H2SQL implementation to follow. |
Signed-off-by: Chris Jackson <chris@cd-jackson.com>
8d86c5a
to
b0791d3
Compare
So, there is another issue with the So, options...
|
22e805f
to
76e2938
Compare
Signed-off-by: Chris Jackson <chris@cd-jackson.com>
76e2938
to
bcaa729
Compare
I assume 2) or 3) should be fine. |
* | ||
* @return count of the number of rows of data. | ||
*/ | ||
Integer getRows(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks like I missed a reference in bundles/ui/org.eclipse.smarthome.ui/src/main/java/org/eclipse/smarthome/ui/internal/chart/DefaultChartProvider.java. I'll update this tonight. |
* | ||
* @param filter the filter to apply to the data removal. ItemName can not be null. | ||
* @return true if the query executed successfully | ||
* @throws {@link InvalidParameterException} if item name is null. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Err, no: "This exception, designed for use by the JCA/JCE engine classes".
Better use IllegalArgumentException instead.
Signed-off-by: Chris Jackson <chris@cd-jackson.com>
Updated, and hopefully good to go ;) |
Thanks, looks all good to me! |
Signed-off-by: Chris Jackson <chris@cd-jackson.com>
Sorry- missed that one... Fixed now ;) |
Wonderful 👍 |
* master: Initial commit of persistence extensions (eclipse-archived#1872) fixed concurrency issues (eclipse-archived#1950) Fix usage of normalizer in Automation module. (eclipse-archived#1938) changed log level for config validation (eclipse-archived#1953) Enhancement to hue binding documentation (eclipse-archived#1952) Change the hue binding to include the thing type id in the thingUID again (eclipse-archived#1946)
S%$#t, @cdjackson, I didn't notice that PersistenceExtensions is in smarthome.model, not in smarthome.core, so using it created an invalid dependency, see https://openhab.ci.cloudbees.com/job/openHAB-Core/60/console:
So we will need a different solution after all. |
Other than for historical reasons, is there a reason that the persistence extensons are in the model bundle? IMHO, they should probably be part of the core.persistence bundle anyway. I don't mind adding a registry, but I'm just wondering if we shouldn't do a slightly bigger refactor and move the PersistenceExtensions into the core bundle anyway, and then add the registry in with that? That would keep the model dealing with the model stuff only, and this is probably (??) a closer architecture to other models (like items at least) although I've not looked at them all. I'm not sure if that would break anything (further!) or not - it just seems to be to be more logical and I suspect if we want to change it, now would be the time? |
If you check the history, you will actually notice that it had been in core before and was moved to model on purpose. |
Shall I work on this? It is rather critical as the OH distro build is currently broken by it... |
Ok - I'd assumed that these extensions were also going to be available in other rules as well - ie not just the 'old' DSL rules...
Sure - I can't do anything until later in the day, so if you have the time today then it might be safer (he says, knowing no-one really has 'time' :) ). |
Maybe only in some changed form and definitely without joda (hoping we then have Java8 instead) - so this refactoring might be done later.
How true :-/ Anyhow, I'll look into it now! |
@cdjackson I have created #1962. |
Sure - will be done early evening... |
This contains initial thoughts for persistence extensions.
Two extensions are considered -:
I'm sure there are other ideas that can improve this, but hopefully this will help to prompt some discussion...
Signed-off-by: Chris Jackson chris@cd-jackson.com