Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

InTime provides a SOAP Web Service Interface that allows two-way flow of information to external systems. This enables automated and efficient transfer of data to and from your other systems reducing effort and duplication.  

...

RETRIEVING INVOICES TO EXPORT:

def needRatePayElementCode = false //Not usually needed but if required change to true 
def entityList = getModifiedItemsWithRefCodeByType(java.lang.String token, java.util.Calendar since, java.lang.String "Reckoning")
for(entityList){
    def entityRefCode = entity.getRefCode()
    def invoiceInfo = getInvoiceByRefCode(java.lang.String token, java.lang.String entityRefCode)
   

if(!(invoiceInfo.getExported)){

def invoicingAccount
   

    for(

def entityType = invoiceInfo.

getInvoiceLineInfo

getEntityType()

:InvoiceLineInfo invoiceLineInfo){


   

       

def

invoiceLineInfoPlacementId

entityRefCode =

invoiceLineInfo

invoiceInfo.

getPlacementId

getEntityRefCode()
   

        def invoiceLineInfoTimesheetId = invoiceLineInfo.getTimesheetId
            def placement = getPlacementById(java.lang.String token, java.lang.Long invoiceLineInfoPlacementId)

if(entityType="Client")invoicingAccount.getClientByRefCode(entityRefCode)
    if(entityType="Worker")invoicingAccount.getWorkerByRefCode(entityRefCode)
    if(entityType="Provider")invoicingAccount.getProviderByRefCode(entityRefCode)
    if(!invoicingAccount){
        System.Error("ERROR SALES OR PURCHASE ACCOUNT REQUIRED FOR ACCOUNTS PACKAGE")
    }else{
        //Get details from Entity to create / update purchase or sales account in accounts package.
    }
    if(!(invoiceInfo.getExported)){
        for(invoiceInfo.getInvoiceLineInfo():InvoiceLineInfo invoiceLineInfo){
            def invoiceLineInfoPlacementId = invoiceLineInfo.getPlacementId
            def invoiceLineInfoTimesheetId = invoiceLineInfo.getTimesheetId
            def placement = getPlacementById(java.lang.String token, java.lang.Long invoiceLineInfoPlacementId)
            def timesheet = getTimesheetById(java.lang.String token, java.lang.Long invoiceLineInfoTimesheetId)
            //Collect details from InvoiceInfo, InvoiceLineInfo, Placement and Timesheet as required for transaction
            if(needRatePayElementCode){
                def invoiceInfoShiftId = invoiceinfo.getShiftId()
                def invoiceInfoTimesheetId = invoiceinfo.getTimesheetId()
                def timesheet = webservice.getTimesheetById(invoiceInfoTimesheetId)
                def shifts = timesheet.getShifts()
                def wantedShift
                for(shifts s where s.id=invoiceInfoShiftId) wantedShift = s
                if(wantedShift){
                    def rate = wantedShift.getRate()
                    def

timesheet

payElementCode =

getTimesheetById(java.lang.String token, java.lang.Long invoiceLineInfoTimesheetId)

rate.getPayElementCode()
               

#Collect details from InvoiceInfo, InvoiceLineInfo, Placement and Timesheet as required for transaction

}
            }
        }
        def exportSuccessful = false;
        #Attempt to export details to Accounts System and if successfull exportSuccessful=true
        if(exportSuccessful)markInvoiceAsExported(java.lang.String token, java.lang.String entityRefCode, java.lang.String now())
    }
}

Java Code

Authenticate

try {

//Create an instance of the stub

IntimeServiceV3_0Stub stub = new IntimeServiceV3_0Stub("https://demo.in-time.co.uk/services/IntimeServiceV3_1?wsdl");


//Get an authentication token

IntimeServiceV3_0Stub.Authenticate auth=new IntimeServiceV3_0Stub.Authenticate();

auth.setAgencyRefCode("<supplied_credentials>");

auth.setUsername("<supplied_credentials>");

auth.setPassword("<supplied_credentials>");

IntimeServiceV3_0Stub.AuthenticateResponse authResp=stub.authenticate(auth);

String ticket=authResp.get_return();

System.out.println("Authentication token:" + ticket);

//Use this authentication token (ticket) to pass in to any of the other WebService calls

} catch (java.lang.Exception e) {

System.out.println("Exception occurred: " + e);

}

...

FieldConstant

Comment

Notes
Client


invoicePeriod0Weekly

1Two-Weekly

2Four-Weekly

3Calendar Monthly

44-4-5




howSendInvoices0PostInvoice delivery method

1Email

2Fax

3Not sent




Worker


workerTypepayeFor PAYE Workers

ltdFor Ltd Company Workers

external-contractorFor Non Ltd Company Workers

cisFor CIS Workers

umbFor Workers operating through an UmbrellaYou must also reference the umbrella against the worker, otherwise the worker will appear as LTD.

ir35For workers inside scope of IR35 (deemed)




cisBusinessTypeSoleTrader


Company


Trust


Partnership





cisPercentage0


20


30





paymentFrequencyweekly


monthly


<InPay Payroll Name>If InPay connected, for PAYE workers, use the InPay Payroll Name




timesheetsOnInvoices0Timesheets On Invoices

1Timesheets Not On Invoices




paperOnInvoices-1Agency Default

0No Attachments

1Attach Paper Timesheets

2Attach Expense Group Paper

4Attach Expense Receipts Paper

<sum of the above>Attach the appropriate paperFor example, 5 to attach timesheets and receipts




genderM


F





LTD invoice period0Weekly

1Two-Weekly

2Four-Weekly

3Calendar Monthly

44-4-5




Payment Methodbacs
NOT CASE SENSITIVE

cheque
NOT CASE SENSITIVE

cash
NOT CASE SENSITIVE

chaps
NOT CASE SENSITIVE

ach
NOT CASE SENSITIVE

international
NOT CASE SENSITIVE

building society
NOT CASE SENSITIVE




Placement


layoutstandard
See Maintaining Placements

calendar





timesheetDateCalculatorweekly
See Maintaining Placements. You can see all possible values for this in the ui.

monthly


<many more>See UI for all options.




Rates


period60For hourly rates entered in hours format (hours only or start, break, finish).

1440For fixed rates of a specified duration entered in decimal format (decimal or tickbox)




periodDuration<any integer>The duration in minutes for the fixed rate (e.g. 60 for hours, 480 for a day).




timePatterndefaultWill use the selected default time pattern

<any string>The string should match the name of a time pattern in the system




timesheetFieldsSTART_FINISH_BREAKEnter start, break, finishOnly when period above is 60

HOURSEnter hours onlyOnly when period above is 60

DECIMALEnter time as a decimalOnly when period above is 1440

DAYTickbox only (equivalent to entering decimals as 1.00)Only when period above is 1440

InvoiceAdjustmentSettings

(Company / Worker)




AdjustBy0Fixed Amount

1Percentage
AdjustPer0Per Worker

1Per Timesheet

2Per Invoice
AdjustType0Addition

1Deduction
ExpenseType


EntryMethod

0Gross valuePopulate the GrossValue and optionally the VatAmount field on an ExpenseItem with this entry method

1Net ValuePopulate the NetValue field on an ExpenseItem with this entry method

2Units and Unit netPopulate the Unit and UnitNet fields on an ExpenseItem with this entry method. E.g. Set Unit = 30 and UnitNet = 0.45 to claim 30 miles at 45p per mile.

3Units and NetPopulate the Unit and Net Value fields on an ExpenseItem with this entry method.
Timesheet


StatusgetTimesheetStatus()getStatus()

-1

DELETED



1

INCOMPLETE



2

SUBMITTED



3

APPROVED



5

COMPLETED



-2

MISSING



-3

REVERTED