-
Notifications
You must be signed in to change notification settings - Fork 3
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Dealing with partial overlaps in documents #147
Comments
Maybe we need a way to describe the relationship between a statement and a movement. This could be done by splitting the 'payment' movement type into different types for inner/outer/etc. For 'invoice' we probably need a better word because it's really not the invoice itself, but the value delivery implied by it. So for instance By making the statements about the database entries and not about the message documents, it will be easier to deal with partial overlap in documents. |
The movementID of a statement from a bank statement import should probably be just the inner movement. |
We do need a way to remember the relation between the statement and the other movements though! |
So maybe we need an intermediate table and maybe the 'type' column should move there |
Ah, or ideally, the invoice should of course be machine-read and parsed, so the units can be taken from the line items! :) |
When importing downloaded CSV bank statements, there can be some overlap in time period.
Also when parsing the response body from an outgoing API call, or parsing the request from an incoming API call, there may be partial overlaps.
So maybe merging the sync table and the statements table was not exactly the right thing to do. We may need to have:
components
table like we have nowmovements
table like we have nowstatements
table like we have nowidentifiers
table that tracks how neighbouring systems identify each of our movementsAnd maybe also how they identify each of our components?
Tracking the identifiers may be more useful than tracking the source documents, if those source documents are sync messages.
Business documents like invoices do need to be tracked meticulously, of course. But they also have there own identifiers, usually... Maybe our concept of 'statements' should be more like linked data quads and less like sync messages.
Also, each line in a bank statement is linked to at least two movements:
So that gives a "bank statement line" a right of existence, by itself in the statements table, just like an invoice or a timesheet entry.
The text was updated successfully, but these errors were encountered: