In this dev blog post, we will be learning about How to create Akeneo API Connection. So let us get started, but first, learn some basics.
What is a connection?
A PIM without any third-party connection is pretty useless, right?
Indeed, for your PIM to properly work, you first need to connect it to the data flows that are coming from your ERP, DAM or even MDM.
Once your products are enriched into the PIM, you then need them to be delivered to all your channels, being syndication, e-commerce or publishing platforms.
Maybe, you also need to connect your PIM to a translation tool to enrich your data even more efficiently.
One can also think of connecting the PIM to some BI tools, to get reports on the enrichment workload.
In the end, all those data flows represent a great deal of connections around your PIM.
How to Create API Connection in Akeneo?
API stands for Application Programming Interface, which is a software intermediary that allows two applications to talk to each other.
With the help of API, will be easier to implement, easier to integrate, easier to maintain, and above all, you will not suffer from painful migrations again.
So now, you will learn “How to create an API key in Akeneo”
What you can connect in Akeneo using API
You can connect the following using the Akeneo API
- DAM (Digital Asset Management)
- Multiple eCommerce solutions
- Syndication solution
- Translation solution
- ERP solution
- Print Solution
- Akeneo postman collection
How to Create an API?
To Create an API Key in Akeneo you have to navigate to connect>>connection-settings.
After that click on the connections option. After that, it will redirect to the new page.
Then after that click on the create button and fill in the details like label, code and flow type.
Settings
In the setting, you can edit the label, flow type and add images.
In flow type, there are three options data source, data destination and others.
Credentials
Then after adding the details, you will get the following details.
- Client Id
- Client Secret Key
- Username
- Password
Permission
After creating the key you can give permission of the API to the selected role and group of Akeneo
See at a glance all your connections
From Akeneo PIM, you can easily see all the connections to third parties, such as ERPs, DAMs, e-commerce platforms, syndication tools,…
To do so, click on Connect
, then on Connection settings
.
The following screen should be displayed.
As an example, here, we have 3 connections around this PIM:
- 2 source connections: an ERP and a retail collaboration platform,
- and one destination connection: an e-commerce platform.
Those 3 third parties are either sending or receiving information to/from the PIM.
There is no connection declared here yet? Discover what is an Akeneo connection and then don’t hesitate to create a new Akeneo connection! 😉
How to Create a Connection?
To connect your PIM to a third-party solution, you will need to create a connection.
You can connect up to 50 third parties through connections and connected Apps. 🚀
Here are the simple steps to create a connection:
- Click on
Connect
. - Then on
Connection settings
. - Click on
Create
. - In the
Label
field, enter the name of your connector. For example, if you wish to connect your PIM to Magento, writeMagento
orMagento connector
.
Sidenote: the code of the connection is automatically generated based on the label. You can keep it as is or change it, it’s up to you! - Choose the flow type of your connection. To choose wisely, see the section below.
You’re done! 🎉
Once your connection is created, you’ll be able to assign it a visual to easily see which connection it refers to.
For example, if your connection represents your connection to Magento, you may want to put a picture of the logo.
After creating the connection, you’ll also need a set of credentials to authenticate your connector.
Choose your flow type
When you create or update a connection, you have to define a “flow type”. But what does it mean?
The flow type is a central concept in the connection notion. It allows you to characterize the data flows that will interact with your PIM.
More precisely it allows indicating the direction of a given flow.
It will determine the way your connection flows are monitored in the data flows dashboard.
This flow type has three available options you’ll have to choose from. The next sections describe each of them. It will help make your decision.
The Source connection flow type
Choose this option for your connection whenever it represents a data flow entering the PIM.
For example, your data flow mainly creates or updates PIM data, such as products, product models, assets, and reference entities.
With this flow type, you can connect your ERP, DAM, MDM, etc.
If you choose this option, the Data flows dashboard will focus on the data that is pushed inside the PIM via this connection.
The Destination connection flow type
Choose this option for your connection whenever it represents a data flow that mainly extracts product information from your PIM.
With this flow type, you can connect e-commerce platforms, publishing and syndication tools…
If you choose this option, the Data flows dashboard will focus on the data that is pushed outside the PIM via this connection.
The Other flow type
Choose this option whenever you can’t opt for any of the options above.
Try avoiding choosing this option. Indeed, you won’t have any connection monitoring for your Other connections, as we can’t know what is the direction of your flows in this connection.
You may be tempted to declare the connections connecting to translation tools as Others
. Indeed, in this case, product information in one language is being retrieved from the PIM to be translated.
Then, once the translation is done, the translated product information is pushed back into the PIM. So, it is both a Source
and a Destination
connection.
That being said, even in this case, we advise you to choose between the two options, instead of choosing Others
.
The question you should ask yourself here is “Do I wish to have a monitoring of the flows that are going out or the flows that are going in?”.
Enable the monitoring
For each connection, you can choose whether you want to monitor it in Data flows.
To do so, check Track in Data flows dashboard
, in the connection settings screen of the connection you want to track.
Others
connections can’t be tracked. Indeed, we wouldn’t know what to track about them.
If you want to track the data entering your PIM, change your connection flow type to Source
.
If you want to track the data that is pulled out of the PIM by your connector, change your connection flow type to Destination
. You can disable the monitoring whenever you want.
We will stop monitoring the connection immediately and you won’t be able to select it in the filters of the Data flows dashboard.
However, note that all the data collected up to that point for this connection will still appear in some KPIs.
Grab your credentials
Whenever you create a connection, the PIM automatically generates a set of credentials for you.
These credentials are necessary if you want to make any API calls to the PIM. Don’t hesitate to learn more about the authentication over the API in our dedicated API website.
These credentials consist of 4 different strings:
- the
client id
, - the
secret
, - the connection
username
, - the connection
password
.
To access the client ID, the secret and the username, go to Connect
/ Connection settings
, click on the connection for which you want to see the credentials.
They are displayed on the right side of the screen in the Credentials
column.
You can easily copy/paste the credentials by clicking on the button next to them.
The password is only shown once to you, just after the connection creation. So, make sure you save it somewhere. When the password is visible, there is a copy icon next to it for easy copy-paste. 😉
Did you forget your password? Don’t worry, you can regenerate a new one. Take a look at the Regenerate your connection password section.
Use these credentials to authenticate the API calls in the Connector that match your connection. For this step, take a look at this guide.
Why should you use the connection username?
You may have noticed that nothing prevents you from using another username than the one generated for you when your connection is created. It’s possible but it’s, in fact, not recommended at all!
Instead, we highly recommend using the connection username to authenticate all the API calls coming from the Connector linked to your connection.
Here are the 2 main reasons why:
- First, all the permissions set on your connection are based on the connection username. So if you don’t use it, your permission connection won’t be enforced.
- The connection monitoring in the dashboard is also based on the connection username. So if you want to benefit from this feature, use this username to authenticate your API calls.
Revoke/regenerate your connection secret
In some cases, your connection secret may have leaked and fallen into the wrong hands. So you want to revoke this secret, to avoid enabling these “wrong hands” to access your PIM via the API.
Along with the secret revocation, the PIM will automatically regenerate a new secret for you.
Here are the simple steps to go through to revoke your secret:
- Click on
Connect
. - Click on
Connection settings
. - Click on the connection for which you want to revoke the secret.
- In the Credentials section, on the right side of the Secret line, click on the regenerate icon. Revoke/Regenerate icon button
- A popup asks you for confirmation. Click on
Regenerate
.
The current secret will be revoked. It means that no one will be able to use it anymore to authenticate their API calls.
Also, a new secret has been generated. Be sure to use this new one in your connector, to be able to make API calls again.
As you may have understood, revoking a secret can have an impact on the Connector linked to your connection.
Indeed, when you revoke a secret that is used by one of your connectors, all its API calls will automatically stop working and send 401 errors instead. You won’t be authenticated anymore.
To be authenticated again, launch a new authentication request using the newly generated secret.
Regenerate your connection password
The PIM shows you the connection password only once, at the connection creation. In case you may have forgotten it, you can regenerate a new one.
Here’s how:
- Click on
Connect
. - Click on
Connection settings
. - Click on the connection for which you want to revoke the password.
- In the Credentials section, on the right side of the Password line, click on the regenerate icon.
- A popup asks you for confirmation. Click on
Regenerate
.
The current password will be deleted and a new one will be generated. It means that no one will be able to use it anymore to authenticate their API calls.
Be sure to use the new password in your connector, to be able to make API calls again.
As you may have understood, regenerating a password can have an impact on the Connector linked to your connection.
Indeed, when you regenerate a password that is used by one of your connectors, all its API calls will automatically stop working and send 401 errors instead. You won’t be authenticated anymore.
To be authenticated again, launch a new authentication request using the newly generated password.
Don’t know how the authentication via API works? Don’t worry, there is Akeneo API authentication documentation to help you! It’s right here!
Set the permissions
For each connection, you can define a set of permissions that can restrict the access to:
- some API endpoints. In this case, those permissions are defined thanks to your connection user role.
- some parts of your product catalog. In this case, those permissions are enforced thanks to the connection user group. Note that they are only available in the Enterprise Edition.
Configure the connection user role
For each connection, you can define an Akeneo user role. This user role should be first created in the User role
screens.
By default, your connection is created with the User
user role. You may want to change that as this user role is quite generic and may not assign the desired permissions to your connection.
We strongly recommend you to create one dedicated user role for your connections, different from the user roles that you use for your UI users.
It’s even better if you create one user role for every connection you will need, as it will allow you to fine-tune what each connection will be able to access. 😉
Also, we don’t recommend giving UI permissions to your connection user roles.
To create a user role and link it to your connection:
- Click on
System
. - Click on
Roles
. - Click on
Create role
. - In the form that appears, give a name to your user role,
My Magento user role
for example. - Click on
Web API permissions
and selectOverall Web API access
. - You can also select other accesses in the list below depending on what you want your connection to be able to achieve.
- Save your configuration by clicking on
Save
. - Click on
Connect
. - Click on
Connection settings
. - Click on the connection for which you want to set the permissions.
- On the right side of the screen, there is a Permissions section. Select the user role you’ve just created in the Role dropdown.
- Don’t forget to save by clicking on Save.
Configure the connection user group
For each connection, you can define an Akeneo user group. This user group should be first created in the User group
screens.
By default, your connection is created with the All
user group. You may want to change that as this user group is quite generic and may not assign the desired permissions to your connection.
We strongly recommend you create one dedicated user group for your connections, different from the user groups that you use for your UI users.
It’s even better if you create one user group for every connection you will need, as it will allow you to fine-tune what each connection will be able to access. 😉
To create a user group and link it to your connection:
- Click on
System
. - Click on
User groups
. - Click on
Create group
. - In the form that appears, give a name to your user group,
My Magento user group
for example. - Click on
Save
. - Click on
Connect
. - Click on
Connection settings
. - Click on the connection for which you want to set the permissions.
- On the right side of the screen, there is a Permissions section. Select the user group you’ve just created in the Group dropdown.
- Don’t forget to save by clicking on the Save button.
By default, the user group you’ve just created does not give any rights to the catalog.
So it’s perfectly normal if you receive no products when you ask for products via the API using the connection credentials.
To be able to view the catalog, you will need to give permission to your connection user group. Here is the Akeneo product access rights documentation to help you with this task.
Delete a connection
If you created a connection you don’t want to use anymore, you can delete it.
- Click on
Connect
. - Click on
Connection settings
. - Click on the connection you want to delete.
- Click on in the top right corner of your screen.
- Click on Delete. Delete a connection
- A pop-up asks you for confirmation. Again click on
Delete
.
As a result, your connection will be deleted. It means that:
- you will no longer be able to follow its data flows inside the Akeneo Data Flows dashboard,
- the credentials that were generated with the connection will be revoked.
- The API authentication made with these credentials will be revoked as well.
- It means that all the API calls using a token that was generated based on these credentials will now send 401 errors.
- If this does not ring a bell for you, you might want to learn more about Akeneo authentication in API. 😉
Therefore, in conclusion, that’s all for the How to Create Akeneo API Connection.
So if you still have any doubts or suggestions, feel free to add a ticket. https://webkul.uvdesk.com/
Be the first to comment.