Skip to content

MaxAndreasLundin/Stream-Microservice

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Stream Microservice Documentation

Welcome to the Stream Microservice, a robust and scalable solution for managing video streams. Our service is built to ensure that users can enjoy their favorite content without exceeding their stream limit, offering an optimal balance between user experience and resource management.

Table of Contents

  1. Overview
  2. Setup Instructions
  1. Service Dependencies
  1. Configuration
  2. Running the Service
  3. Error Handling
  4. API Versioning
  5. Service Details
  1. Testing
  1. Deployment
  2. API Documentation

Overview

The Stream Microservice is a Spring Boot application that serves to limit the number of simultaneous video streams that a user can consume. The service exposes REST APIs to start and stop video streams and to fetch the currently running streams for a user. It interacts with the https://tv4-search.a2d.tv/ API to validate video IDs.

Setup Instructions

This section guides you on how to set up the Stream Microservice on your local machine.

Prerequisites

  • Ensure that you have Docker installed on your machine.
  • Ensure that you have Docker Compose installed on your machine.
  • Ensure that you have Maven installed on your machine.

Steps

  1. Clone the repository to your local machine.
  2. Navigate to the root directory of the project.
  3. Build the JAR file for your application using the following command: mvn clean package This command builds a JAR file of your application using Maven. The clean command removes any previous builds, and the package command compiles your code and packages it into a JAR file.
  4. Build the Docker image for your application using the following command: docker build -t tv4-image . This command builds a Docker image named "tv4-image" using the Dockerfile in your current directory.
  5. Start the database and the microservice using Docker Compose with the following command: docker compose up This command starts the services defined in your docker-compose.yml.
  6. To stop the services, you can use the following command: docker compose down This command stops and removes the containers defined in your docker-compose.yml.

Service Dependencies

The Stream Microservice relies on the following external service:

TV4 Search API

The Stream Microservice validates video IDs by interacting with the TV4 Search API. The base URL for this API is https://tv4-search.a2d.tv/. Documentation for the TV4 Search API can be found at https://tv4-search.a2d.tv/docs/.

When a video stream is started, the Stream Microservice makes a GET request to the TV4 Search API at the endpoint /assets/{videoId} where {videoId} is the ID of the video to be streamed. The API's response is used to validate whether the video ID is valid. If the TV4 Search API returns a 404 Not Found status, the video ID is considered invalid, and the stream cannot be started. However, in case of other server errors (5xx status codes), the video ID validation is bypassed to allow the user to start the stream.

It's important to note that the availability and performance of the Stream Microservice can be impacted by the TV4 Search API. If the TV4 Search API is down or experiencing issues, the Stream Microservice may also experience problems when trying to start a video stream, unless the API error is a server error, in which case the stream start operation would proceed as if the video ID is valid.

Configuration

The Stream Microservice relies on the following environment variables, which can be set in the application.yml file:

  • DB_HOST: The host of the database (default is localhost).
  • DB_USERNAME: The username for the database (default is postgres).
  • DB_PASSWORD: The password for the database (default is 123).

Note: For testing, the application-test.yml file is used, which sets up an in-memory H2 database.

Running the Service

After following the setup instructions and configuring the service, you can interact with it via the following REST endpoints:

  • POST /v1/stream: Start a new video stream. Requires userId and videoId parameters. If the user has already started the maximum number of streams (2), a 403 Forbidden response is returned. If the videoId is invalid, a 400 Bad Request response is returned.
  • DELETE /v1/stream: Stop an existing video stream. Requires userId and videoId parameters. If the specified stream does not exist, a 404 Not Found response is returned.
  • GET /v1/stream: Get all currently running streams for a user. Requires the userId parameter.

Error Handling

The Stream Microservice uses standard HTTP status codes to indicate the success or failure of an API request. Here are some common scenarios:

  • 403 Forbidden: This status code is returned when the request is valid, but the server is refusing to respond to it. For example, if a user tries to start more than two streams, the service will respond with this status code.
  • 404 Not Found: This status code is returned when the requested resource could not be found. For example, if a user tries to stop a stream that does not exist, this status code will be returned.
  • 500 Internal Server Error: This is a generic error message, given when an unexpected condition was encountered and no more specific message is suitable.

API Versioning

The Stream Microservice API uses URI versioning. This means that the version of the API is included in the path of the URI. Currently, the API is at version 1, and so all endpoints begin with /v1. For example, to start a new stream, you would send a POST request to /v1/stream.

When a new version of the API is released, the version number in the URI will be incremented. For example, if version 2 of the API is released, the endpoint to start a new stream would be /v2/stream.

Please note that when a new version is released, older versions will eventually be deprecated. We will provide a migration guide with each new version to assist with the transition, and we will give advance notice before any version is fully deprecated.

Remember to always use the latest version of the API in your new projects to have access to the latest features and improvements.

Service Details

StreamService

This is the core service that manages the operations of starting, stopping, and fetching video streams for a user. It ensures that a user does not exceed the maximum limit of two concurrent streams and checks for the validity of video IDs. The service utilizes StreamRepository to interact with the database for these operations. Additionally, it employs a scheduled task, running every 60 seconds, that purges any streams that have been inactive for over an hour. This is an important feature for maintaining system performance and preventing the accumulation of stale data.

StreamRepository

The StreamRepository is a Spring Data JPA repository that provides methods for finding, saving, and deleting streams in the database. It also provides a method for deleting all streams that have been inactive for over an hour.

StreamController

The StreamController is the REST controller for the application. It maps the above endpoints to their corresponding service methods and handles any errors that occur.

RestTemplateConfig

This configuration class provides a RestTemplate bean used by the StreamService class. RestTemplate is a utility class that offers convenient methods for consuming RESTful web services, essentially abstracting the communication between our application and other services via HTTP. In our application, RestTemplate is used to make outbound HTTP requests to verify video IDs with the TV4 Search API, ensuring that users can only start streams with valid video IDs. This validation process is crucial for maintaining the integrity of our service.

Stream entity

The Stream entity represents a video stream. It includes the ID of the stream, the ID of the user, and the ID of the video. It also includes a 'lastSeen' timestamp, which indicates the last point of contact between the Stream Microservice and the external microservice that communicated this information. This 'lastSeen' timestamp is crucial for tracking the activity status of each stream and facilitating the regular purging of inactive streams.

Testing

The Stream Microservice contains unit tests that validate the functionality of the StreamService and StreamController classes.

StreamServiceTest

The StreamServiceTest class contains tests for the StreamService. These tests include:

  • shouldStopStreamGivenValidUserAndVideoId: This test verifies that a stream is successfully stopped given a valid user ID and video ID. It mocks the StreamRepository to simulate the stream and checks if the stream is deleted successfully.
  • shouldThrowExceptionWhenStoppingNonExistingStream: This test checks if an exception is thrown when attempting to stop a non-existing stream.
  • shouldStartStreamGivenValidUserAndVideoId: This test checks if a stream is successfully started given a valid user ID and video ID. It mocks the StreamRepository and RestTemplate to simulate the conditions for starting a stream and checks if the stream is saved successfully.
  • shouldThrowExceptionWhenStartingStreamAndMaxRunningStreamsReached: This test verifies that an exception is thrown when the maximum number of running streams for a user is reached.
  • shouldThrowExceptionWhenStartingStreamWithInvalidVideoId: This test verifies that an exception is thrown when attempting to start a stream with an invalid video ID.

StreamControllerTest

The StreamControllerTest class contains tests for the StreamController. These tests include:

  • shouldStartStreamGivenValidUserAndVideoId: This test verifies that a POST request to the /v1/stream endpoint with a valid user ID and video ID returns an OK status. It mocks the StreamService to simulate the conditions for starting a stream.
  • shouldStopStreamGivenValidUserAndVideoId: This test verifies that a DELETE request to the /v1/stream endpoint with a valid user ID and video ID returns an OK status.
  • shouldGetRunningStreamsGivenValidUserId: This test checks if a GET request to the /v1/stream endpoint with a valid user ID returns an OK status. It mocks the StreamService to simulate the conditions for getting running streams.

To run the tests, use the following Maven command: mvn test

Deployment

The MicroserviceApplication class includes a main method that runs the application. It also enables scheduling for the @Scheduled annotation in StreamService.

The application is packaged into a Docker image and runs as a Docker container along with a database container. The Dockerfile and docker-compose.yml file in the project root directory provide the configuration for this.

API Documentation

This microservice uses Swagger UI for API documentation, which provides an interactive interface for exploring the API's endpoints. Once the microservice is running, the Swagger UI page is available at: http://localhost:8080/swagger-ui/index.html#/ You can explore the various API endpoints, their parameters, responses, and test them directly from this page.

In addition, the OpenAPI description of the API, which provides a machine-readable specification of the API's endpoints, parameters, responses, etc., is available in JSON format at: http://localhost:8080/v3/api-docs

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published