CERN Indico Feeds
The CERN Indico Events and CERN Indico Feeds modules are offered as part of the CERN Drupal Distribution and allows you to import feeds from Indico directly onto your Drupal website(s) and display the associated events. The CERN Indico Events module introduces a dedicated content type and views for Indico feeds, and the CERN Indico Feeds module features functionality to integrate against the Indico API (see more at https://docs.getindico.io/en/stable/http-api/).
While the CERN Indico Feeds module is readily available via Gitlab, it is included in the CERN Drupal Distribution by default. Thus, it should already be installed on your website and a local installation is not necessary. If for some reason you are using a locally installed copy, please ensure to always use the newest available version!
::warn This guide utilises API Keys which will be deprecated in a future Indico release. As a consequence, we will update the CERN Indicio Feeds module to support token-based authentication. This means that with a future release, you must enter a token instead of an API key. No other changes are expected. :::
Configuring CERN Indico Feeds
Ensure that both the CERN Indico Events and CERN Indico Feeds modules are installed and enabled.
Head to Structure and select Feed types.
- Select Indico Feed and click Edit.
This page contains general settings for the CERN Indico Feed type.
- Settings defines the import period (i.e. the frequency with which feeds should be updated). The default value is six hours and should be sufficient for the vast majority of websites. If you require very frequent updates (i.e. every hour or several times an hour), consider linking users directly to Indico instead.
- Fetcher settings provides an interface to manage authentication with the Indico API.
- Processor settings provides an interface to manage how existing content should be updated, what happens with previously imported items, when content should expire, and who should be the owner of the created items. The default settings should meet the requirements for the vast majority of websites. Only advanced users should change processor settings.
- Select Fetcher settings.
On here, we need to update the API Key and Secret Key. This step needs to be completed once.
- Head to https://indico.cern.ch/user/api/ and sign in. Click Create API key.
This will load the following page. Do not share your keys with anyone!
- Copy the Token and paste it as your API Key.
Copy the Secret and paste it as your Secret Key.
- Click Save feed type. Your website can now make authenticated calls to the Indico service.
Creating a new Feed
In order to create a new feed and start pulling events from Indico, follow the below steps.
Kindly note that the CERN Indico Events content type does not include all the fields from Indico. If you require a field that is not included, you must add it manually in the content type and otherwise map it to the Indico field in the Mapping section of the feed. This is done by going to Structure → Feed types → Edit Indico Feed → Mapping tab.
- Go to Content and click Feeds.
- Click Add feed.
- Add information describing your feed.
- Title is the title of your feed.
- Categories is the list of Indico category ids from which you wish to pull events. If, for instance, you put category id 1279 (Schools), the module will pull all events from the child categories under it (namely CERN Official Schools and Other Schools). In the event that you are only interested in a specific category, please put the specific id. There is no limitation on the number of categories from which the module can pull.
- Start date is the date from which the module should start pulling events from Indico.
- End date is the latest date from which the module should pull events from Indico.
- Room should be left empty unless strictly necessary.
- Retrieve only public events should be ticked by default. If you require private events from the Indico categories, untick this accordingly. Kindly note that private events will only be visible to users who have access to see them in the first place and have signed in on your website. Additionally, if you require private events, please ensure that the account from which you generated API keys has access to the events.
- Import options should be left unchanged. Unticking this option will stop the pulling of events.
- Authoring information should be left unchanged.
Once done, click Save and import.
Imported events can now be displayed using Grid of event boxes, Collisions of events, or Countdown to next event content types.