diff --git a/.vscode/settings.json b/.vscode/settings.json new file mode 100644 index 0000000..3736b9a --- /dev/null +++ b/.vscode/settings.json @@ -0,0 +1,4 @@ +{ + "commentTranslate.targetLanguage": "en", + "commentTranslate.hover.enabled": true +} \ No newline at end of file diff --git a/config/settings.py b/config/settings.py index e332a2b..91faf4d 100644 --- a/config/settings.py +++ b/config/settings.py @@ -37,6 +37,7 @@ 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', + 'files_management' ] MIDDLEWARE = [ diff --git a/config/urls.py b/config/urls.py index b6601c1..1deaae2 100644 --- a/config/urls.py +++ b/config/urls.py @@ -1,21 +1,14 @@ -"""config URL Configuration - -The `urlpatterns` list routes URLs to views. For more information please see: - https://docs.djangoproject.com/en/4.1/topics/http/urls/ -Examples: -Function views - 1. Add an import: from my_app import views - 2. Add a URL to urlpatterns: path('', views.home, name='home') -Class-based views - 1. Add an import: from other_app.views import Home - 2. Add a URL to urlpatterns: path('', Home.as_view(), name='home') -Including another URLconf - 1. Import the include() function: from django.urls import include, path - 2. Add a URL to urlpatterns: path('blog/', include('blog.urls')) -""" from django.contrib import admin from django.urls import path +from ninja import NinjaAPI +from files_management.controller import post_controller + + + +api = NinjaAPI() +api.add_router('/posts' , post_controller) urlpatterns = [ path('admin/', admin.site.urls), + path('api/', api.urls) ] diff --git a/files_management/controller.py b/files_management/controller.py index 45a329d..e9768cc 100644 --- a/files_management/controller.py +++ b/files_management/controller.py @@ -1,2 +1,52 @@ from django.shortcuts import render +from ninja import Router +import re +from django.core.files.storage import default_storage +from django.core.files.base import ContentFile # Create your views here. + + +post_controller = Router() + +@post_controller.get('') +def list_posts(request): + + _, filenames = default_storage.listdir("posts") + return list(sorted(re.sub(r"\.md$", "", filename) + for filename in filenames if filename.endswith(".md"))) + + + + +@post_controller.get('/{title}') +def get_post(request ,title): + + try: + f = default_storage.open(f"posts/{title}.md") + return f.read().decode("utf-8") + except FileNotFoundError: + return None + + + +@post_controller.post('') +def save_post(request , title , content): + + filename = f"posts/{title}.md" + if default_storage.exists(filename): + default_storage.delete(filename) + default_storage.save(filename, ContentFile(content)) + + + + + + +@post_controller.delete('/{title}') +def del_post(request ,title): + + + filename = f"posts/{title}.md" + default_storage.delete(filename) + return {'messege': 'The file has been deleted successfully'} + \ No newline at end of file diff --git a/posts/Ali_Khaleel.md b/posts/Ali_Khaleel.md new file mode 100644 index 0000000..051386f --- /dev/null +++ b/posts/Ali_Khaleel.md @@ -0,0 +1 @@ +This is a content of post 4 \ No newline at end of file diff --git a/posts/Ali_Khaleel_pro.md b/posts/Ali_Khaleel_pro.md new file mode 100644 index 0000000..a53e899 --- /dev/null +++ b/posts/Ali_Khaleel_pro.md @@ -0,0 +1 @@ +This is a content of post 5 \ No newline at end of file diff --git a/posts/post_2.md b/posts/post_2.md index aeba1ac..40dbac3 100644 --- a/posts/post_2.md +++ b/posts/post_2.md @@ -1 +1 @@ -This is the content of post 2 \ No newline at end of file +This is a content of post 2 \ No newline at end of file diff --git a/posts/post_3.md b/posts/post_3.md new file mode 100644 index 0000000..b12b749 --- /dev/null +++ b/posts/post_3.md @@ -0,0 +1 @@ +This is a content of post 3 \ No newline at end of file