Skip to main content
Version: 3.0

AppEngine Jobs

Jobs are tasks that execute within the AppEngine environment, designed to automate processes within SAP Business One plugins. They may connect to a company's SAP database, a customer database (via ADO), or operate without a connection. This guide provides an overview of creating, configuring, and executing Jobs within the AppEngine.


Types of Jobs in AppEngine

Event-Based Jobs

Event-based jobs react to specific SAP Business One events occurring within the company database. These jobs rely on SAP Business One event data and standard message information:

  • ActionType: A, U, C, D
  • ContentType: SAP object type
  • Key: Key value
  • KeyName: Key name
  • UseCode: User code
  • UserId: User ID
  • UseRegex: Boolean inidcator if true then ContentType is RegexExpression eg:^(20|59|60)$'

To create an Event-Based Job, use the EventBusJob attribute: (!) You can use multiple EventBusAttribite on signle implementation

[EventBusJob(JobId = "Job Id", JobName = "Job Name", Description = "Job Description", ActionType = "*", ContentType = "CT_VO_OVMD")]

There are three base classes your job class must implement:

  • EventBusDatabaseJob: Executes with no SAP connection, but you can use the IDbConnection DBConnection property for custom logic. Application-scoped services are available via constructor injection.
  • EventBusJob: Executes without any connection, relying only on application-scoped services resolved via constructor.
  • EventBusSecureJob: Provides a full connection to the database, allowing access to connection-based services via GetService<T>().

One-Time and Recursive Jobs

  • One-Time Jobs: Execute on demand via the REST API.
  • Recursive Jobs: Execute periodically according to a Cron expression (see Quartz Cron Generator).

Classes for creating these jobs:

  • Job: No database connection, can only use application-scoped services resolved via constructor.
  • SecureJob: Full connection to the database; connection-based services can be accessed via GetService<T>().

To configure the job as one-time or recursive, add the appropriate attribute:

[BackgroundJob(JobId = "AE_Plugin_ScheduledJob3AsOneTime", JobName = "AE_Plugin_ScheduledJob3AsOneTime")]
[RecurringJob(JobId = "AE_Plugin_ScheduledJob3", JobName = "BackgroundJob3", CronExpression = "0/20 0 0 ? * * *")]

Job Configuration

You can add configuration to Secure and Database type jobs by using the AdditionalJobConfiguration attribute with a specified configuration type. In your job class, access the configuration by using the Configuration property. For more details on configurations, see Configurations

[AdditionalJobConfiguration(Type = typeof(Adv))]
public class ScheduledJob2 : EventBusSecureJob
{
public void ExecuteJob()
{
var config = Configuration; // Access configuration here
// Job logic
}
}

AppEngine Jobs for SAP Business One plugins offer a robust framework to streamline and automate critical processes within your business. This guide serves as a comprehensive introduction to implementing Jobs in AppEngine, empowering you to take full advantage of its automation capabilities.