Registration and Posting Process
Table of Contents
Once a record is updated via the Registered QUB or via an index_registration workflow. The data gets written to the staging tables within the Adest database. 
Indexing_Registration (workflow)
Option One: The output of the registration data to an ERP system is preferably done by the ERP system, which polls our staging table for any record with a status of New.
Option Two: Alternatively the data can be output to a text file for processing by the ERP system.
The ERP system will poll all records within the AD_custom_reg_criteria and ad_custom_reg_lineitem tables where the Status is equal to New. 
Once polled, all records processed must be updated to processed, by setting the status field to “Processed”.
Upon successful confirmation of registration, the same record is updated with the ERP number and the status updated to “Registered”.
This is done via the ERP system which will populate the ERP number into the ERP number for the relevant DocmasterID and update the Status field to Registered.
A custom import will need to be written to import the registration confirmation and update the relevant DocmasterID with the status and ERP number.
Option One or Two must be followed to carry out the above registration acknowledgement.
A DB polling job (Registration Confirmation) will poll all criteria records in Adest AP category where the ERP status is Registered and ERP number is blank, and join to the registratration staging table where status is Registered. This is done via SP ADSP_CUSTOM_SELECT_REGISTERED. This will return all DocID’s to the Registration_Confirmation workflow.
The Registration_Confirmation workflow executes a SP activity which executes ADSP_CUSTOM_UPDATE_REG_ERPNUMBER. This SP updates the ERP Number within the AP category to the ERP number populated for the DocID within the registration staging table.
This process allows the record to be registered again once the issue that occurred has been corrected. This is only used when an error has occurred in the ERP system once it has left Adest.
To record an error from the ERP system to Adest. The ad_custom_reg_criteria is updated with the status “Error” and a comment populated into the comment field by the ERP system.
A DB polling job “Registration Error” calls an SP called ADSP_CUSTOM_SELECT_REG_ERROR which polls for all records with the status Error within the staging table, and the ERP Status Registered within the category table, linked by DocmasterID.
Each record returned is passed to a workflow called Registration_Error. 
This workflow executes an SP (ADSP_CUSTOM_UPDATE_REG_ERPSTATUS) where the record in the category table is updated to ERP Status “Not Registered”, with the exception table populated with the comment from the ERP system with the text “ERP System Error:” proceeding the comment supplied from the ERP system. 
If no comment is supplied, an error is thrown. The ERP status is not updated and an exception added.
The existing record within the staging table gets inserted into the Audit tables and then removed from the ad_custom_reg_criteria and  ad_custom_reg_lineitem tables.
The record within the Ad_Registration for that DocID is removed.
To record an error from the ERP system to Adest. The ad_custom_reg_criteria is updated with the status “Error” and a comment populated into the comment field. It is recommended that a table is created in the main database to import the data from the file. Join this table to the ad_custom_reg_criteria table and update the status to Error and populate the comment. Please see the guidelines section for a table example.
A DB polling job polls for all records with the status Error within the staging table, and the ERP Status Registered with the category table. 
Each record returned is passed to a workflow called Registration_Error. 
This executes an SP where each record in the category table is updated to ERP Status “Not Registered”, with the exception table populated with the comment from the ERP system with the text “ERP System Error:” proceeding the comment supplied from the ERP system. 
The existing record within the staging table gets inserted into the Audit tables and then removed from the ad_custom_reg_criteria and  ad_custom_reg_lineitem tables.
The record within the Ad_Registration for that DocID is removed.
Once a record is updated via the Posted QUB or via an updating_SentToERP workflow. The data gets written to the staging tables within the Adest database. 
Updating_SentToERP (workflow)
Option One: The output of the posting data to an ERP system is preferably done by the ERP system, which polls our staging table for any record with a status of New.
Option Two: Alternatively the data can be output to a text file for processing by the ERP system.
The ERP system will poll all records within the AD_custom_post_criteria and ad_custom_post_lineitem tables where the Status is equal to New. 
Once polled, all records processed must be updated to processed, by setting the status field to “Processed”.
Upon successful confirmation of registration, the same record is updated with the ERP number and the status updated to “Posted”.
This is done via the ERP system which will populate the ERP number into the ERP number for the relevant DocmasterID and update the Status field to Posted within the ad_custom_post_criteria table.
A custom import will need to be written to import the posting confirmation and update the relevant DocmasterID with the status and ERP number.
Option One or Two must be followed to carry out the above posting acknowledgement.
A DB polling job (Posting Confirmation) will poll all criteria records in Adest AP category where the ERP status is Sent To ERP and ERP number is blank, and join to the posting staging table where status is Posted. This is done via SP ADSP_CUSTOM_SELECT_POSTED. This will return all DocID’s to the Posting_Confirmation workflow.
The Posting_Confirmation workflow executes a SP activity which executes ADSP_CUSTOM_UPDATE_POST_ERPNUMBER. This SP updates the ERP Number within the AP category to the ERP number populated for the DocID within the posting staging table.
This process allows the record to be posted again once the issue that occurred has been corrected. This is only used when an error has occurred in the ERP system once it has left Adest.
To record an error from the ERP system to Adest. The ad_custom_post_criteria is updated with the status “Error” and a comment populated into the comment field by the ERP system.
A DB polling job polls for all records with the status Error within the staging table, and the ERP Status Sent To ERP within the category table. 
Each record returned is passed to a workflow called Posting_Error. 
This executes an SP where each record in the category table is updated to ERP Status “Not Posted”, with the exception table populated with the comment from the ERP system with the text “ERP System Error:” proceeding the comment supplied from the ERP system. 
The existing record within the staging table gets inserted into the Audit tables and then removed from the ad_custom_post_criteria and  ad_custom_post_lineitem tables.
The record within the Ad_Posted for that DocID is removed.
To record an error from the ERP system to Adest. The ad_custom_post_criteria is updated with the status “Error” and a comment populated into the comment field. It is recommended that a table is created in the main database to import the data from the file. Join this table to the ad_custom_post_criteria table and update the status to Error and populate the comment. Please see the guidelines section for a table example.
A DB polling job polls for all records with the status Error within the staging table, and the ERP Status Sent To ERP within the category table. 
Each record returned is passed to a workflow called Posting_Error. 
This executes an SP where each record in the category table is updated to ERP Status “Not Posted”, with the exception table populated with the comment from the ERP system with the text “ERP System Error:” proceeding the comment supplied from the ERP system. 
The existing record within the staging table gets inserted into the Audit tables and then removed from the ad_custom_post_criteria and  ad_custom_post_lineitem tables.
The record within the Ad_Posted for that DocID is removed.
AD_CUSTOM _REG_CRITERIA
| Column Name | Datatype | Constraints | 
| DocMasterID | Bigint | NOT NULL, PK | 
| CompanyName | Nvarchar(50) | NOT NULL | 
| CompanyNumber | Nvarchar(20) | NOT NULL | 
| SupplierCode | Nvarchar(50) | NOT NULL | 
| DocumentType | Nvarchar(30) | NOT NULL | 
| DocumentDate | SMALLDATETME | NOT NULL | 
| InvoiceNumber | Nvarchar(20) | NOT NULL | 
| PONumber | Nvarchar(50) | NOT NULL | 
| Net | Money | NOT NULL | 
| VAT | Money | NOT NULL | 
| Total | Money | NOT NULL | 
| Currency | Nvarchar(3) | NOT NULL | 
| PostingDate | Smalldatetime | NOT NULL | 
| InsertDate | Smalldatetime | NOT NULL | 
| UserName | Nvarchar(100) | NOT NULL | 
| Status | Nvarchar(10) | New, Processed, Registered, Posted, Error, NOT NULL | 
| Comment | Nvarchar(200) | NOT NULL | 
| ERPNumber | Nvarchar(50) | NOT NULL | 
AD_CUSTOM_REG_LINEITEM
| Column Name | Datatype | Constraints | 
| DocMasterID | Bigint | NOT NULL, PK | 
| ProductCode | Nvarchar(50) | NOT NULL | 
| ProductDescription | Nvarchar(200) | NOT NULL | 
| CostCode | Nvarchar(20) | NOT NULL | 
| GLCode | Nvarchar(20) | NOT NULL | 
| UnitsOrdered | Decimal(18,2) | NOT NULL | 
| UnitPrice | Money | NOT NULL | 
| Net | Money | NOT NULL | 
| VATCode | Nvarchar(12) | NOT NULL | 
| VATRate | Nvarchar(6) | NOT NULL | 
| VAT | Money | NOT NULL | 
| Total | Money | NOT NULL | 
| Status | Nvarchar(10) | NOT NULL | 
| Comment | Nvarchar(200) | NOT NULL | 
AD_CUSTOM _POST_CRITERIA
| Column Name | Datatype | Constraints | 
| DocMasterID | Bigint | NOT NULL, PK | 
| CompanyName | Nvarchar(50) | NOT NULL | 
| CompanyNumber | Nvarchar(20) | NOT NULL | 
| SupplierCode | Nvarchar(50) | NOT NULL | 
| DocumentType | Nvarchar(30) | NOT NULL | 
| DocumentDate | SMALLDATETME | NOT NULL | 
| InvoiceNumber | Nvarchar(20) | NOT NULL | 
| PONumber | Nvarchar(50) | NOT NULL | 
| Net | Money | NOT NULL | 
| VAT | Money | NOT NULL | 
| Total | Money | NOT NULL | 
| Currency | Nvarchar(3) | NOT NULL | 
| PostingDate | Smalldatetime | NOT NULL | 
| InsertDate | Smalldatetime | NOT NULL | 
| UserName | Nvarchar(100) | NOT NULL | 
| Status | Nvarchar(10) | New, Processed, Registered, Posted, Error, NOT NULL | 
| Comment | Nvarchar(200) | NOT NULL | 
| ERPNumber | Nvarchar(50) | NOT NULL | 
AD_CUSTOM_POST_LINEITEM
| Column Name | Datatype | Constraints | 
| DocMasterID | Bigint | NOT NULL, PK | 
| ProductCode | Nvarchar(50) | NOT NULL | 
| ProductDescription | Nvarchar(200) | NOT NULL | 
| CostCode | Nvarchar(20) | NOT NULL | 
| GLCode | Nvarchar(20) | NOT NULL | 
| UnitsOrdered | Decimal(18,2) | NOT NULL | 
| UnitPrice | Money | NOT NULL | 
| Net | Money | NOT NULL | 
| VATCode | Nvarchar(12) | NOT NULL | 
| VATRate | Nvarchar(6) | NOT NULL | 
| VAT | Money | NOT NULL | 
| Total | Money | NOT NULL | 
| Status | Nvarchar(10) | NOT NULL | 
| Comment | Nvarchar(200) | NOT NULL | 
AD_CUSTOM _CRITERIA_AUDIT
| Column Name | Datatype | Constraints | 
| DocMasterID | Bigint | NOT NULL, PK | 
| CompanyName | Nvarchar(50) | NOT NULL | 
| CompanyNumber | Nvarchar(20) | NOT NULL | 
| SupplierCode | Nvarchar(50) | NOT NULL | 
| DocumentType | Nvarchar(30) | NOT NULL | 
| DocumentDate | SMALLDATETME | NOT NULL | 
| InvoiceNumber | Nvarchar(20) | NOT NULL | 
| PONumber | Nvarchar(50) | NOT NULL | 
| Net | Money | NOT NULL | 
| VAT | Money | NOT NULL | 
| Total | Money | NOT NULL | 
| Currency | Nvarchar(3) | NOT NULL | 
| PostingDate | Smalldatetime | NOT NULL | 
| InsertDate | Smalldatetime | NOT NULL | 
| UserName | Nvarchar(100) | NOT NULL | 
| Status | Nvarchar(10) | New, Processed, Registered, Posted, Error, NOT NULL | 
| Comment | Nvarchar(200) | NOT NULL | 
| ERPNumber | Nvarchar(50) | NOT NULL | 
AD_CUSTOM_LINEITEM_AUDIT
| Column Name | Datatype | Constraints | 
| DocMasterID | Bigint | NOT NULL, PK | 
| ProductCode | Nvarchar(50) | NOT NULL | 
| ProductDescription | Nvarchar(200) | NOT NULL | 
| CostCode | Nvarchar(20) | NOT NULL | 
| GLCode | Nvarchar(20) | NOT NULL | 
| UnitsOrdered | Decimal(18,2) | NOT NULL | 
| UnitPrice | Money | NOT NULL | 
| Net | Money | NOT NULL | 
| VATCode | Nvarchar(12) | NOT NULL | 
| VATRate | Nvarchar(6) | NOT NULL | 
| VAT | Money | NOT NULL | 
| Total | Money | NOT NULL | 
| Status | Nvarchar(10) | NOT NULL | 
| Comment | Nvarchar(200) | NOT NULL |