None Events
None events are unspecified events, also called ‘blank’ events. For instance, a ’none’ start event technically means that the trigger for starting the process instance is unspecified. This means that the engine cannot anticipate when the process instance must be started. The none start event is used when the process instance is started through the API by calling one of the startProcessInstanceBy... methods.
ProcessInstance processInstance = runtimeService.startProcessInstanceByKey('invoice');
Note: a subprocess must always have a none start event.
None End Event
A ’none’ end event means that the result thrown when the event is reached is unspecified. As such, the engine will not do anything besides ending the current path of execution. The XML representation of a none end event is the normal end event declaration, without any sub-element (other end event types all have a sub-element declaring the type).
<endEvent id="end" name="my end event" />
Intermediate None Event (throwing)
The following process diagram shows a simple example of an intermediate none event, which is often used to indicate some state achieved in the process.
This can be a good hook to monitor some KPI’s, basically by adding an execution listener
<intermediateThrowEvent id="noneEvent">
  <extensionElements>
    <camunda:executionListener class="org.cibseven.bpm.engine.test.bpmn.event.IntermediateNoneEventTest$MyExecutionListener" event="start" />
  </extensionElements>
</intermediateThrowEvent>
You can add some own code to the execution listener to maybe send some event to your BAM tool or DWH. The engine itself doesn’t do anything in the event, it just passes through it.
Camunda Extensions
| Attributes | camunda:asyncBefore, camunda:asyncAfter, camunda:exclusive, camunda:jobPriority | 
|---|---|
| Extension Elements | camunda:failedJobRetryTimeCycle, camunda:inputOutput | 
| Constraints | The camunda:exclusiveattribute is only evaluated if the attributecamunda:asyncBeforeorcamunda:asyncAfteris set totrue |