This project is a web-based application that serves as a utility for generating queries to fetch articles from GDELT 2.0 and as a repository for classifying, accessing, displaying, summarizing and managing the fetched articles.
Users can search and store articles or news on specific GKG (Global Knowledge Graph) Themes, categories (groups of related GKG themes under a single label), within specific countries or globally, and for selected timelines. They can further fetch article content and summarize using their configured summarization API.
For instance, a query might retrieve articles in the Business and Economy category (themes like EPU_ECONOMY, ECON_TAXATION, and ECON_INFLATION) published in Nigeria, in English, between 2024/10/22 at 12 PM and 2024/11/20 at 11 AM. The application not only fetches these results but also organizes them into a well-structured repository for easy tracking and future reference.
Since the inital commit of this repository on 26th November, 2024, major changes and augmentations have been made. they as as follows:
-
In line with the roadmap of this project and the requirements of 234Ledger.com.ng Admin, an extra tab has been added which enable users to extract the actual content of an article from its URL, and further summarize it using any configured summarization API of their choice. This tab can be accessed from the "Actions" column of the articles' view.
-
This feature has brought about the inclusion of jsdom and @mozilla/readability to the project dependencies. Do not forget to
npm install
when you update your local repositories. The .env file has also been augmented with new configurations. -
With reference to the summarization feature, users can decide on a summarization API and integrate it based on the instructions in the .env file. Personally, due to my dislike for limits, I set up a local python-based abstractive summarization API using Anaconda, pyTorch, HuggingFace transformers (models include t5-small, pegasus, or even most suitable facebook/bart-large-cnn), and Flask. It can be easily done.
-
Please note that summarization will not work for you if you have not set it up.
- The roadmap list has been updated with an important third item. Please contact me if you wish to contribute to it.
This application allows users to classify GKG Themes into categories using the categories.json file and specify additional query parameters, such as source countries, languages, formats, and sorting, in the .env file.
Once configured, the application can be run, and the web app can be accessed in a browser. From the web app, users can:
- Set timelines for queries.
- Make GDELT 2.0 requests.
- View, access, and manage the resulting articles directly from the interface, including extracting and summarizing their content.
This setup streamlines the process of fetching and organizing global news articles for further exploration and management.
While working on 234Ledger.com.ng, a news aggregator website for Nigerian audiences, the admin needed a simple way to source and track news and trends across various topics and categories without manually navigating multiple websites and blogs.
Several APIs, such as Newsdata.io, Mediastack.com, and NewsAPI.ai, were considered, but these were either limited in their free versions or required paid subscriptions. The GDELT 2.0 API emerged as the ideal choice due to its free access and extensive coverage, but its implementation required significant technical expertise.
This utility was developed to simplify access to GDELT, providing an easy-to-use tool for sourcing and organizing up-to-date news and articles. While designed with Nigeria in mind, the tool is highly flexible and customizable, making it suitable for anyone looking to track news and trends on any topic, anywhere in the world.
This utility can be adapted to a variety of scenarios, making it an invaluable tool for individuals, organizations, and businesses looking to stay informed and organized:
-
News Bloggers:
- Use the tool to keep track of up-to-date news and articles, simplifying the process of sourcing content for blogs and websites.
-
News Aggregators:
- Platforms like 234Ledger.com.ng can leverage this utility to streamline content sourcing, ensuring diverse and timely news coverage.
-
Organizations and Institutions:
- Businesses can monitor industry news, market trends, or competitor updates within specific regions or sectors.
- Non-profits can track global events related to their causes, such as climate change or humanitarian crises.
-
Law Enforcement and Security Agencies:
- Track news and reports related to security incidents, crime patterns, or ongoing investigations in specific areas.
-
Academics and Researchers:
- Gather news articles for data analysis, trend tracking, or case studies in various fields like politics, economics, or media studies.
-
Individuals:
- Stay updated on topics of personal interest, such as technology, sports, or entertainment, by organizing news from reliable sources.
-
Custom Applications:
- The utility’s flexibility allows it to be tailored for niche applications, such as monitoring regional news in remote areas or tracking specialized themes like environmental disasters or economic policies.
The possibilities are endless, making this tool a versatile solution for accessing and managing global news and trends across various use cases.
This project is designed to run locally and does not include server-side validation or user authentication for its UI. If you wish to deploy it on a publicly accessible server, you can set it up behind a proxy with authentication or contact me (details in the Support section) for customization.
- Node.js: Version 20.17.0 or compatible.
- NPM: Version 9.2.0 or compatible.
- A web browser and a code editor (for optional customization).
-
Clone the Repository:
Clone or download this repository to your local machine. -
Install Dependencies:
Open a terminal in the project root folder and run:npm install
-
Customize Environment Variables:
Edit the .env file in the project root to configure the application settings. Instructions are included within the file. -
Define Categories (Optional):
- Edit the categories.json file to organize GKG themes into categories.
- Ensure the file adheres to the following structure:
class Category { name!: string; // Unique name for the category id!: number; // Unique integer identifier themes!: string[]; // Array of GKG themes for the category }[]
- Refer to the GKG Themes page for the full list of themes.
-
Start the Application:
Run the following command in the project root directory:npm start
Open the link printed in the terminal in your web browser to access the UI.
-
UI Instructions:
The UI is intuitive and includes instructions for usage. -
Translate the UI (Optional):
To translate the interface, edit the values in interface/i18n/default.json with your preferred language and reload the browser tab.
-
UI/Front-End:
Built with Angular 18.2.8, Bootstrap 5.3.3, and @ngx-translate/core 16.0.3. -
Server:
Powered by Express 4.18.2 and TypeScript 5.3.3. -
Communication:
- Between UI and Server: Socket.io (socket.io 4.7.5 and ngx-socketio2-updated 18.1.0).
- Between Server and GDELT: Axios 1.7.2.
-
Persistence:
Utilizes Debbiebase 1.0.0, a lightweight file-system-based JSON database I developed for private projects. -
Content Extraction:
Utilizes JSDOM 25.0.1 and @Mozilla/readability 0.5.0. -
Content Summarization
Locally set up python-based abstractive summarization API using Anaconda, Pytorch, HuggingFace Transformers (with models like t5-small, pegasus, or facebook/bart-large-cnn), and Flask.
- The UI includes a one-click toggle for light and dark modes, enhancing user convenience.
- The Application includes the ability to extract the actual contents of the articles from their URL.
- Abstractive summarization of the content using AI models.
This project continues to evolve based on 234Ledger.com.ng admin’s requirements. Future plans include:
-
AI-Powered Super Highway (Done):
- A feature to extract, summarize, categorize, and upload article content directly to 234Ledger.com.ng.
- Ensures no duplicate articles, news, or stories are uploaded.
-
Automation:
- Fully automating the Super Highway for seamless operation.
-
Trading Sentiment Indicator:
-
Although not directly related to this project, utilizing the GDELT API, with HuggingFace Transformers and Pytorch (possibly for classification, organization and redundancy elimination), and a bit of Node.js-based automation to build a real-time scaled headless sentiment indicator for both FX and Cryptocurrencies, as an additional microservice and indicator to my trading network, "The Ark". It should be able to detect real-time sentiments towards cryptocurrencies and individual fiats, bull and bear markets, hence, being used to enhance decision-making on Spot and Futures trading protocols in The Ark.
-
Although The Ark is not public, this indicator will likely be public, free and open-sourced as my contribution to the traders' community. It should be available to the public by January 2025.
-
For support, collaboration, or inquiries about development, programming, maintenance, or optimization services, feel free to contact me:
- Email: [email protected]
- Website: jtorque.online
I’m an all-round tech enthusiast and open to various opportunities!
This project is free to use without limitations, in line with GDELT's free usage policy.
Articles view - table with pagination