Walidator
Walidatory to komponenty użytkownika, umożliwiające sprawdzenie formularza podczas akceptacji zadania oraz zablokowanie akceptacji, gdy jakieś dane nie są prawidłowe. Przykładowe walidatory mogą np.
- weryfikować, czy kwota została odpowiednio ustawiona
- weryfikować, czy w zadaniu został dodany komentarz lub dokument.
Stworzone walidatory dostępne są w edytorze procesów i mogą być łatwo wykorzystane w procesie biznesowym umożliwiając tym samym realizacje logiki biznesowej. Ich zachowanie może być dodatkowo konfigurowane za pomocą parametrów.
Definiowanie walidatora
Walidatory tworzone są w oparciu o ich definicję stworzoną przez użytkownika. Definicja taka musi zawierać następujące elementy:
- Adnotację @Validator (jeżeli walidator nie jest definiowany we wtyczce, musi on pochodzić z pakietu
com.suncode
) - Publiczną metodę oznaczoną adnotacją @Define z jednym parametrem ValidatorDefinitionBuilder
- Publiczną metodę o nazwie validate, która odpowiada za przeprowadzenie walidacji formularza.
Przykładowa definicja przedstawiona jest poniżej:
@Validator public class PeselValidator { private final String PESEL_REGEX = "^\\d{11}$"; @Define public void definition( ValidatorDefinitionBuilder builder ) { builder .id( "pesel-validator" ) .name( "validator.pesel" ) .description( "validator.pesel.desc" ) .category( Categories.TEST ) .parameter() .id( "pesel_param" ) .name( "validator.pesel.parameter.name" ) .description( "validator.pesel.parameter.desc" ) .type( Types.VARIABLE) .create(); } //Metoda walidująca public void validate( @Param( value = "pesel_param" ) Variable pesel, ValidationErrors errors, Translator translator ) { boolean isPesel = Pattern.matches( PESEL_REGEX, (String) pesel.getValue() ); if ( isPesel == false ) { errors.add( translator.getMessage( "validator.pesel.invalid" ), pesel.getId() ); } } }
Implementacja funkcji walidującej
Walidator musi posiadać metodę walidującą o nazwie validate. Metoda może posiadać następujące typy parametrów:
- pojedynczy parametr walidatora - typ parametru musi być zgodny ze zdefiniowanym typem oraz musi być poprzedzony adnotacją @Param,
- Parameters - zawiera wszystkie zdefiniowane parametry walidatora wraz z ich wartościami, jest to alternatywa dla pobierania parametru za pomocą wyżej wspomnianej adnotacji@Param,
- ValidationErrors - obiekt, w którym ustawiane są wszystkie błędy,
- ValidationContext - kontekst walidacji, można z niego odczytać identyfikator procesu i zadania, których dotyczy ta walidacja,
- ActivityContextMap - obiekt przechowujący zmienne formularza wraz z aktualnymi wartościami oraz identyfikator procesu i zadania; jest on w całości tylko do odczytu, nie ma możliwości zmiany wartości zmiennych,
- ContextVariables - zmienne kontekstowe dostępne w tym walidatorze. Więcej informacji tutaj,
- Translator - translator dla tego komponentu, dzięki któremu wiadomości zwracane przez walidator mogą być tłumaczone. Więcej informacji tutaj,
- UserInfo - obiekt zawierający informacje na temat użytkownika akceptującego zadanie.
W celu przerwania akceptacji zadania i wyświetlenia stosownego komunikatu należy dodać wiadomość do obiektu ValidationErrors. Jeżeli żadna wiadomośc nie zostanie dodana, to akceptacja zadania przejdzie do kolejnego etapu.
Rejestracja walidatora we wtyczce
Jeżeli walidator jest definiowany we wtyczce to należy dodatkowo zaznaczyć, że wtyczka ta udostępnia komponenty. W tym celu należy w pliku suncode-plugin.xml dodać wpis:
<!-- Udostępnianie walidatorów --> <workflow-components key="components" />
Callback przy błędzie walidatora
Funkcja jeszcze niedostępna.
Od wersji możliwe jest dodanie JavaScriptowej funkcji, która zostanie wywołana zamiast wyświetlenia okienka systemowego po błędnym wywołaniu walidatora. Aby dodać callback do komponentu, obok adnotacji Validator należy dodać adnotację ValidatorsScript określającą ścieżkę do skryptu (znajdującego się w resources).
@Validator @ValidatorsScript( value = "scripts/peselValidatorCallback.js" ) public class PeselValidator
Implementacja callbacka w JavaScripcie jest analogiczna do tworzenia skryptów Akcji.
PW.FormValidators.create('pesel-validator', { callback : function() { console.log('Pesel validator callback'); } });
Pierwszy argument funkcji create musi być taki sam, jak id walidatora. Drugim argumentem jest obiekt implementujący metodę callback, która jest wywoływana przy dodaniu błędu w walidatorze.