22 Aug 2017
 

Syncope Basics: Manage external DB

Written by malessandroni

We are going to see how to create an Apache Syncope 2.X instance that will simply pull a list of users from an external resource and propagate them to a second one.

Step 1: Create project from maven archetype:

Let's start by creating a Sycope 2.0.4 instance from Maven archetype:

mvn archetype:generate \
-DarchetypeGroupId=org.apache.syncope \
-DarchetypeArtifactId=syncope-archetype \
-DarchetypeRepository=http://repo1.maven.org/maven2 \
-DarchetypeVersion=2.0.4

By default, the embedded mode is populated with example data, so you should remove that first:

cd syncope-archetype
cp core/src/main/resources/domains/MasterContent.xml core/src/test/resources/domains/MasterContent.xml

Step 2: Run project in embedded mode:

From the project main directory:

mvn -P all clean install
cd enduser
mvn -P embedded,all

Open http://localhost:9080/syncope-console and you'll find the Syncope Admin Console.

Step 3: Configure the first MySQL external resource

Enter your MySQL server and run the following commands:

CREATE DATABASE IF NOT EXISTS syncope;
USE syncope;
CREATE TABLE users (email VARCHAR(100), username VARCHAR(150) NOT NULL, password VARCHAR(80), surname VARCHAR(150), firstname VARCHAR(150), PRIMARY KEY (username));
INSERT INTO users VALUES ("user1@gmail.com", "user1", "password", "Kant", "Jack");
INSERT INTO users VALUES ("user2@gmail.com", "user2", "password", "Red", "Frank");

Step 4: Configure the second MySQL external resource

Enter your MySQL server and run the following commands:

CREATE DATABASE IF NOT EXISTS syncope_backup;
USE syncope_backup;
CREATE TABLE users (email VARCHAR(100), username VARCHAR(150) NOT NULL, password VARCHAR(80), fullname VARCHAR(300), PRIMARY KEY (username));

Step 5: Create a new MySQL connector in Syncope

First, it is important to follow the instructions from the official Reference Guide in order to configure the bundles directory to have all necessary connector JAR files.

Then you just need to add the MySQL connector dependency to the "core/pom.xml" project file:

<dependency>
 <groupId>mysql</groupId>
 <artifactId>mysql-connector-java</artifactId>
 <version>5.1.42</version>
</dependency>

Now you need to rebuild the application.

Login to Admin Console, go to Topology and add a new connector by clicking on the node where you recognize the path of you project:

Edit the connector as below:


you should also add some Capabilities:

Step 6: Create two MySQL resources in Syncope

Create a second similar connector with a different name (for the other database you have created above "syncope_backup").

Click on each connector and proceed to create a 2 resources by clicking "Add new resource" from menu.

At the end you should have 2 resources like these:

Step 7: Create some useful "Schema"

Go to Configuration -> Types -> Schemas and add the following info:

Now you need to link the new Schemas to a specific AnyTypeClass so go to Configuration -> Types -> AnyTypeClasses and edit BaseUser:

Step 8: Add provision rules for the first resource

Go back to "Topology" section, select MySQL1, click on "Edit provision rules" and finally the "+" button:



Notice: before going further, you should know that if you will remove a user from Syncope it will be removed from external resource too, so if you don't want it to happen you should override capabilities in MySQL1 by editing it.

Step 9: Add provision rules for the second resource

Select MySQL2, click "Edit provision rules", then the "+" button:

 

Step 10: Create a pull task to import users from "MySQL1" to Syncope:

Select MySQL1 and choose "Pull Tasks" from menu, click the "+" button:

Fill the fields as below, notice that the last step tells Syncope to run the task every day at 12pm, but you can change it as you prefer and it is not mandatory schedule it. 

After saving it, click on the created "ImportUsers" task and select "Run", now click on the gear icon to run it.

You can see the result of the task by entering the "View" section from toggle menu.

Now the 2 users that you have in the MySQL1 resource are stored in Syncope:

Step 11: Create a push task to propagate users from Syncope to MySQL2:

As in Step 10, select MySQL2 and choose "Push Tasks" from menu, click the "+" button:

Fill the fields as below:

Now execute the task, as you did for the "ImportUsers" task, and check in your MySQL2 instance that data is synchronized:

Advanced section:

Assign a template to MySQL1 pull task in order to automatically propagate users from MySQL1 to MySQL2:

Go to Topology, select MySQL1 and choose "Pull Tasks" from menu.

Click on the previously created task and choose "template", then select "USER" and go on.

Find the "External resources" step in wizard and edit like this:

Now, if you have already executed the previous push task for MySQL2, access the external resource and remove the rows from it.
Also it could be necessary to remove all previously synchronized users from Syncope too, then run the "ImportUsers" pull task from MySQL1 resource.

All users will be pulled to Syncope again and propagated to MySQL2 resource. The result should be something like this:

Notice: this way the "fullname" attribute will be correctly populated.

       

« Return