MediaCMS is a modern, fully featured open source video and media CMS, written in Python/Django and React, featuring a REST API.
Go to file
Laurentiu 294ac5b0a3
Create .env
Resolve warning messages "The POSTGRES_DB/USER variable is not set. Defaulting to a blank string."
2024-07-03 07:02:46 +03:00
.github Developer Experience (#911) 2023-11-13 11:13:08 +02:00
actions update versions for pre-commit (#741) 2023-03-14 14:09:52 +02:00
cli-tool cli.py missing f string (#877) 2023-11-10 15:09:22 +02:00
cms Developer Experience (#911) 2023-11-13 11:13:08 +02:00
deploy Feat celery run (#860) 2023-11-10 16:06:17 +02:00
docs Developer Experience (#911) 2023-11-13 11:13:08 +02:00
files Feat celery run (#860) 2023-11-10 16:06:17 +02:00
fixtures Fixed duplicate 'pk' on fixtures 2022-06-01 13:21:22 +03:00
frontend Fix null bug in More Options button (#913) 2023-11-14 09:24:05 +02:00
media_files/userlogos change default banner 2020-12-25 16:03:58 +02:00
static fix issues with comments (#802) 2023-06-13 19:01:52 +03:00
templates Add sitemap (#572) 2023-11-10 15:03:36 +02:00
tests Fixed duplicate 'pk' on fixtures 2022-06-01 13:21:22 +03:00
uploader Python requirements and Docker version upgrades (#826) 2023-07-03 13:40:39 +03:00
users Python requirements and Docker version upgrades (#826) 2023-07-03 13:40:39 +03:00
.coveragerc adds instructions to get coverage (#299) 2022-01-31 20:53:57 +02:00
.dockerignore Frontent dev env (#247) 2021-07-11 18:01:34 +03:00
.env Create .env 2024-07-03 07:02:46 +03:00
.gitignore CLI API Tool (#273) 2022-01-31 21:12:29 +02:00
.pre-commit-config.yaml update versions for pre-commit (#741) 2023-03-14 14:09:52 +02:00
AUTHORS.txt Developer Experience (#911) 2023-11-13 11:13:08 +02:00
CODE_OF_CONDUCT.md adds drf-yasg and automated generation of Swagger Schemas (#165) 2021-05-29 16:34:36 +03:00
conftest.py Segregation of Dev and Prod envs (#218) 2021-07-01 18:05:43 +03:00
docker-compose-dev.yaml Developer Experience (#911) 2023-11-13 11:13:08 +02:00
docker-compose-http-proxy.yaml Upgrade postgres docker compose (#749) 2023-07-03 13:39:15 +03:00
docker-compose-https-proxy.yaml Upgrade postgres docker compose (#749) 2023-07-03 13:39:15 +03:00
docker-compose-letsencrypt.yaml Upgrade postgres docker compose (#749) 2023-07-03 13:39:15 +03:00
docker-compose-named-volumes.yaml Upgrade postgres docker compose (#749) 2023-07-03 13:39:15 +03:00
docker-compose.yaml Upgrade postgres docker compose (#749) 2023-07-03 13:39:15 +03:00
Dockerfile Developer Experience (#911) 2023-11-13 11:13:08 +02:00
Dockerfile-dev Developer Experience (#911) 2023-11-13 11:13:08 +02:00
HISTORY.md Python requirements and Docker version upgrades (#826) 2023-07-03 13:40:39 +03:00
install-rhel.sh add rhel8 installation script (#792) 2023-06-14 15:18:12 +03:00
install.sh Python requirements and Docker version upgrades (#826) 2023-07-03 13:40:39 +03:00
LICENSE.txt MediaCMS backend, initial commit 2020-12-15 23:33:43 +02:00
manage.py add tests for new uploads (#291) 2021-09-23 18:34:27 +03:00
pyproject.toml Add pre-commit (#140) 2021-05-26 17:58:17 +03:00
pytest.ini Segregation of Dev and Prod envs (#218) 2021-07-01 18:05:43 +03:00
README.md Developer Experience (#911) 2023-11-13 11:13:08 +02:00
requirements-dev.txt Developer Experience (#911) 2023-11-13 11:13:08 +02:00
requirements.txt Python requirements and Docker version upgrades (#826) 2023-07-03 13:40:39 +03:00
setup.cfg Feat flake8 strength (#209) 2021-06-03 18:26:53 +03:00
version.py Python requirements and Docker version upgrades (#826) 2023-07-03 13:40:39 +03:00

MediaCMS

GitHub license Releases DockerHub

MediaCMS is a modern, fully featured open source video and media CMS. It is developed to meet the needs of modern web platforms for viewing and sharing media. It can be used to build a small to medium video and media portal within minutes.

It is built mostly using the modern stack Django + React and includes a REST API.

A demo is available at https://demo.mediacms.io

Screenshots

Features

  • Complete control over your data: host it yourself!
  • Support for multiple publishing workflows: public, private, unlisted and custom
  • Modern technologies: Django/Python/Celery, React.
  • Multiple media types support: video, audio, image, pdf
  • Multiple media classification options: categories, tags and custom
  • Multiple media sharing options: social media share, videos embed code generation
  • Easy media searching: enriched with live search functionality
  • Playlists for audio and video content: create playlists, add and reorder content
  • Responsive design: including light and dark themes
  • Advanced users management: allow self registration, invite only, closed.
  • Configurable actions: allow download, add comments, add likes, dislikes, report media
  • Configuration options: change logos, fonts, styling, add more pages
  • Enhanced video player: customized video.js player with multiple resolution and playback speed options
  • Multiple transcoding profiles: sane defaults for multiple dimensions (240p, 360p, 480p, 720p, 1080p) and multiple profiles (h264, h265, vp9)
  • Adaptive video streaming: possible through HLS protocol
  • Subtitles/CC: support for multilingual subtitle files
  • Scalable transcoding: transcoding through priorities. Experimental support for remote workers
  • Chunked file uploads: for pausable/resumable upload of content
  • REST API: Documented through Swagger

Example cases

  • Schools, education. Administrators and editors keep what content will be published, students are not distracted with advertisements and irrelevant content, plus they have the ability to select either to stream or download content.

  • Organization sensitive content. In cases where content is sensitive and cannot be uploaded to external sites.

  • Build a great community. MediaCMS can be customized (URLs, logos, fonts, aesthetics) so that you create a highly customized video portal for your community!

  • Personal portal. Organize, categorize and host your content the way you prefer.

Philosophy

We believe there's a need for quality open source web applications that can be used to build community portals and support collaboration.

We have three goals for MediaCMS: a) deliver all functionality one would expect from a modern system, b) allow for easy installation and maintenance, c) allow easy customization and addition of features.

License

MediaCMS is released under GNU Affero General Public License v3.0 license. Copyright Markos Gogoulos.

Support and paid services

We provide custom installations, development of extra functionality, migration from existing systems, integrations with legacy systems, training and support. Contact us at info@mediacms.io for more information.

Hardware considerations

For a small to medium installation, with a few hours of video uploaded daily, and a few hundreds of active daily users viewing content, 4GB Ram / 2-4 CPUs as minimum is ok. For a larger installation with many hours of video uploaded daily, consider adding more CPUs and more Ram.

In terms of disk space, think of what the needs will be. A general rule is to multiply by three the size of the expected uploaded videos (since the system keeps original versions, encoded versions plus HLS), so if you receive 1G of videos daily and maintain all of them, you should consider a 1T disk across a year (1G * 3 * 365).

Releases

Visit Releases Page for detailed Changelog

Installation / Maintanance

There are two ways to run MediaCMS, through Docker Compose and through installing it on a server via an automation script that installs and configures all needed services. Find the related pages:

Configuration

Visit Configuration page.

Information for developers

Check out the new section on the Developer Experience page

Documentation

Technology

This software uses the following list of awesome technologies: Python, Django, Django Rest Framework, Celery, PostgreSQL, Redis, Nginx, uWSGI, React, Fine Uploader, video.js, FFMPEG, Bento4

Who is using it

How to contribute

If you like the project, here's a few things you can do

  • Hire us, for custom installations, training, support, maintenance work
  • Suggest us to others that are interested to hire us
  • Write a blog post/article about MediaCMS
  • Share on social media about the project
  • Open issues, participate on discussions, report bugs, suggest ideas
  • Show and tell how you are using the project
  • Star the project
  • Add functionality, work on a PR, fix an issue!

Contact

info@mediacms.io