Periodic End Calculations: Difference between revisions
Wolfganguhr (talk | contribs) No edit summary |
Wolfganguhr (talk | contribs) |
||
Line 53: | Line 53: | ||
The iteration process guarantees that every account and every cost centre has been considered. In any valid combination of a cost centre code and account code, there exist a predefinded accounting target. | The iteration process guarantees that every account and every cost centre has been considered. In any valid combination of a cost centre code and account code, there exist a predefinded accounting target. | ||
== General | == General Period End Operations Handling == | ||
Actually in openpetra mfinance we have to manage two different Types of period end operations the smaller period is the month and the larger period is the year, while in normal cases the year contains 12 months but in different countries one (or two?) months are added in order to account some | Actually in openpetra mfinance we have to manage two different Types of period end operations the smaller period is the month and the larger period is the year, while in normal cases the year contains 12 months but in different countries one (or two?) months are added in order to account some additionally and country specific accountings. | ||
In the actual version the TCarryForwardENum (Ict.Petra.Server.MFinance.GL in GL.PeriodEnd.cs) holds the values Month and Year. | In the actual version the TCarryForwardENum (Ict.Petra.Server.MFinance.GL in GL.PeriodEnd.cs) holds the values Month and Year. | ||
The Object TCarryForward manages the complete switch from one period to the next one. That means TCarryForward.SetNextPeriod() moves the system to the next month if it is evaluated inside a year and it moves to the first month if it is done at the end of a year. So if someone in the future decides to include a TCarryForwardENum property like Month13, be | The Object TCarryForward manages the complete switch from one period to the next one. That means TCarryForward.SetNextPeriod() moves the system to the next month if it is evaluated inside a year and it moves to the first month if it is done at the end of a year. So if someone in the future decides to include a TCarryForwardENum property like Month13, be sure that TCarryForward will be able to handle it. | ||
The next important class is the class TPerdiodEndOperations, which is | The next important class is the class TPerdiodEndOperations, which is inherited by TYearEnd and in future by TMonthEnd. It supports some parameters and the main routines RunPeriodEndCheck and RunPeriodEndSequence. | ||
A check is something which only runs some tests and produces an error message or ar warning if something is wrong but a sequence is | A check is something which only runs some tests and produces an error message or ar warning if something is wrong but a sequence is something which makes significant and relevant changes in the data base. Both routines uses a first parameter of the type AbstractPerdiodEndOperation. Inside of the main code this looks like: | ||
<pre>RunPeriodEndSequence(new TReallocation(ledgerInfo), | <pre>RunPeriodEndSequence(new TReallocation(ledgerInfo), | ||
Line 89: | Line 89: | ||
And for a final test the last abstract routine will be called and this is GetActualizedClone(). As shown above in RunPeriodEndSequence you have to create an internal duplicate of TReallocation(ledgerInfo) for example. This object is created after the changes has been written to the database and so the JobSize of the new object shall be zero. | And for a final test the last abstract routine will be called and this is GetActualizedClone(). As shown above in RunPeriodEndSequence you have to create an internal duplicate of TReallocation(ledgerInfo) for example. This object is created after the changes has been written to the database and so the JobSize of the new object shall be zero. | ||
If the first object | If the first object reports a JobSize of zero there is nothing to do and only a user message will be generated. But if the second object reports a non zero value, this will be interpreted as a critical error and this will switch of all the following data base operations. |
Revision as of 06:09, 3 Mayıs 2011
In Accounting Systems the term "Periodic End" either means a period like a month and or a period like a year. In "older systems" you also know the period of 10 years (deletion of old data) but actually we speak about the month and the year.
Today this two periods split the state of the accounting system into three different types.
Actually we speak about
- the standard accounting
- standard gift batches are allowed
- standard batches are allowed
- foreign currencies are allowed
- the revaluated accounting
- standard gift batches are allowed
- standard batches are allowed
- foreign currencies are allowed
- the year end accounting
- actually unknown ...
So:
- the month end only can change to the status "standard accounting" if it is a month of the same year or to "year end accounting" if the last month of the year has been closed.
- the year end has been done to set the value to the next year.
Info: The number of months can be lager than 12. In some countries the 31th decembre is used as the 13th month to run some additional accounting which are required by national laws.
Month End
The month end will run the tests
- If a revaluation is done (i.e if the status "revaluated accounting" ist activated) (critical)
- If the system is not in the "year end accounting" (critical)
- If there are unposted batches (critical)
- If there are unposted gift batches (critical)
- If there are non zeroed suspense accounts (critical)
- If there are zeroed suspense accounts the user gets an informal message
The critical messages will disconnect any possibilities to continue.
The month end will include:
- Calculation of the admin fees (to be done)
- Calculation of the ICH fees (to be done)
- switch to the next month or to the "year end accounting" state
Year End
The Reallocation
Inside the routines for the year end we have the Account Reallocation. Shortly spoken it is the movement from the account values of the type Income and Expense to Equity values. Se we've go to the complete list of income- and expense accounts, iterate the list of cost centers used on that account and account them to a equity account.
The ICH-Account (in petra this are the accounts 85*) are of type Assets but they have to be reallocated to.
The iteration process guarantees that every account and every cost centre has been considered. In any valid combination of a cost centre code and account code, there exist a predefinded accounting target.
General Period End Operations Handling
Actually in openpetra mfinance we have to manage two different Types of period end operations the smaller period is the month and the larger period is the year, while in normal cases the year contains 12 months but in different countries one (or two?) months are added in order to account some additionally and country specific accountings.
In the actual version the TCarryForwardENum (Ict.Petra.Server.MFinance.GL in GL.PeriodEnd.cs) holds the values Month and Year.
The Object TCarryForward manages the complete switch from one period to the next one. That means TCarryForward.SetNextPeriod() moves the system to the next month if it is evaluated inside a year and it moves to the first month if it is done at the end of a year. So if someone in the future decides to include a TCarryForwardENum property like Month13, be sure that TCarryForward will be able to handle it.
The next important class is the class TPerdiodEndOperations, which is inherited by TYearEnd and in future by TMonthEnd. It supports some parameters and the main routines RunPeriodEndCheck and RunPeriodEndSequence.
A check is something which only runs some tests and produces an error message or ar warning if something is wrong but a sequence is something which makes significant and relevant changes in the data base. Both routines uses a first parameter of the type AbstractPerdiodEndOperation. Inside of the main code this looks like:
RunPeriodEndSequence(new TReallocation(ledgerInfo), Catalog.GetString("Reallocation of all income and expense accounts")); RunPeriodEndSequence(new TGlmNewYearInit(ledgerInfo.LedgerNumber, intYear), Catalog.GetString("Initialize the glm-entries of the next year")); RunPeriodEndSequence(new TAccountPeriodToNewYear(ledgerInfo.LedgerNumber, intYear), Catalog.GetString("Set the account period values to the New Year"));
In this example TReallocation, TGlmNewYearInit and TAccountPeriodToNewYear inherits AbstractPerdiodEndOperation and therefore the can be used as a parameter here. The constructors are different and of course the parameter list are different, but the "rest" which is done below are equivalent.
The AbstractPerdiodEndOperation supports a property that enables to pass the standard parameters blnIsInInfoMode and the VerificationResultCollection.
Then the property JobSize is the very first calculation of the object. This value shall report the real number of affected data base records. This routine has to detect each record and more important it has to decide if the requested operation has been done or not. Let us assume a System crash betwee the TReallocation has been done and TGlmNewYearInit is actually not done. It is not allowed to do the TReallocation a second time in order to to a TGlmNewYearInit.
So JobSize has to
- find all records which really need to be changed.
- only to report the number of jobs without doing it.
And after the JobSize has been called and after the JobSize was not zero, the next abstract routine is called RunEndOfPeriodOperation(). Here all database transactions shall be done but only and only if blnIsInInfoMode is false and if blnCriticalErrors is false.
And for a final test the last abstract routine will be called and this is GetActualizedClone(). As shown above in RunPeriodEndSequence you have to create an internal duplicate of TReallocation(ledgerInfo) for example. This object is created after the changes has been written to the database and so the JobSize of the new object shall be zero.
If the first object reports a JobSize of zero there is nothing to do and only a user message will be generated. But if the second object reports a non zero value, this will be interpreted as a critical error and this will switch of all the following data base operations.