mirror of
https://github.com/rzmk/learnhouse.git
synced 2025-12-19 04:19:25 +00:00
fix: only show public courses for anon users
This commit is contained in:
parent
c3a5f43f13
commit
cd7ec3a4d7
4 changed files with 28 additions and 44 deletions
|
|
@ -1,9 +1,10 @@
|
||||||
|
|
||||||
import React from "react";
|
import React from "react";
|
||||||
import Courses from "./courses";
|
import Courses from "./courses";
|
||||||
import { getOrgCourses } from "@services/courses/courses";
|
import { getOrgCoursesWithAuthHeader } from "@services/courses/courses";
|
||||||
import { Metadata } from "next";
|
import { Metadata } from "next";
|
||||||
import { getOrganizationContextInfo } from "@services/organizations/orgs";
|
import { getOrganizationContextInfo } from "@services/organizations/orgs";
|
||||||
|
import { cookies } from "next/headers";
|
||||||
|
|
||||||
type MetadataProps = {
|
type MetadataProps = {
|
||||||
params: { orgslug: string };
|
params: { orgslug: string };
|
||||||
|
|
@ -24,7 +25,9 @@ export async function generateMetadata(
|
||||||
|
|
||||||
const CoursesPage = async (params: any) => {
|
const CoursesPage = async (params: any) => {
|
||||||
const orgslug = params.params.orgslug;
|
const orgslug = params.params.orgslug;
|
||||||
const courses = await getOrgCourses(orgslug, { revalidate: 0, tags: ['courses'] });
|
const cookieStore = cookies();
|
||||||
|
const access_token_cookie: any = cookieStore.get('access_token_cookie');
|
||||||
|
const courses = await getOrgCoursesWithAuthHeader(orgslug, { revalidate: 0, tags: ['courses'] }, access_token_cookie ? access_token_cookie.value : null);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
|
|
|
||||||
|
|
@ -9,7 +9,6 @@ import { RequestBody, RequestBodyForm, RequestBodyWithAuthHeader, errorHandling
|
||||||
export async function getOrgCourses(org_id: number, next: any) {
|
export async function getOrgCourses(org_id: number, next: any) {
|
||||||
const result: any = await fetch(`${getAPIUrl()}courses/org_slug/${org_id}/page/1/limit/10`, RequestBody("GET", null, next));
|
const result: any = await fetch(`${getAPIUrl()}courses/org_slug/${org_id}/page/1/limit/10`, RequestBody("GET", null, next));
|
||||||
const res = await errorHandling(result);
|
const res = await errorHandling(result);
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,7 @@
|
||||||
from fastapi import APIRouter, Depends, UploadFile, Form, Request
|
from fastapi import APIRouter, Depends, UploadFile, Form, Request
|
||||||
from src.security.auth import get_current_user
|
from src.security.auth import get_current_user
|
||||||
|
|
||||||
from src.services.courses.courses import Course, create_course, get_course, get_course_meta, get_courses, get_courses_orgslug, update_course, delete_course, update_course_thumbnail
|
from src.services.courses.courses import Course, create_course, get_course, get_course_meta, get_courses_orgslug, update_course, delete_course, update_course_thumbnail
|
||||||
from src.services.users.users import PublicUser
|
from src.services.users.users import PublicUser
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -41,21 +41,12 @@ async def api_get_course_meta(request: Request, course_id: str, current_user: P
|
||||||
"""
|
"""
|
||||||
return await get_course_meta(request, course_id, current_user=current_user)
|
return await get_course_meta(request, course_id, current_user=current_user)
|
||||||
|
|
||||||
|
|
||||||
@router.get("/org_id/{org_id}/page/{page}/limit/{limit}")
|
|
||||||
async def api_get_course_by(request: Request, page: int, limit: int, org_id: str):
|
|
||||||
"""
|
|
||||||
Get houses by page and limit
|
|
||||||
"""
|
|
||||||
return await get_courses(request, page, limit, org_id)
|
|
||||||
|
|
||||||
|
|
||||||
@router.get("/org_slug/{org_slug}/page/{page}/limit/{limit}")
|
@router.get("/org_slug/{org_slug}/page/{page}/limit/{limit}")
|
||||||
async def api_get_course_by_orgslug(request: Request, page: int, limit: int, org_slug: str):
|
async def api_get_course_by_orgslug(request: Request, page: int, limit: int, org_slug: str, current_user: PublicUser = Depends(get_current_user)):
|
||||||
"""
|
"""
|
||||||
Get houses by page and limit
|
Get houses by page and limit
|
||||||
"""
|
"""
|
||||||
return await get_courses_orgslug(request, page, limit, org_slug)
|
return await get_courses_orgslug(request, current_user, page, limit, org_slug)
|
||||||
|
|
||||||
|
|
||||||
@router.put("/{course_id}")
|
@router.put("/{course_id}")
|
||||||
|
|
|
||||||
|
|
@ -313,31 +313,15 @@ async def delete_course(request: Request, course_id: str, current_user: PublicUs
|
||||||
####################################################
|
####################################################
|
||||||
|
|
||||||
|
|
||||||
async def get_courses(
|
|
||||||
request: Request, page: int = 1, limit: int = 10, org_id: str | None = None
|
|
||||||
):
|
|
||||||
courses = request.app.db["courses"]
|
|
||||||
# TODO : Get only courses that user is admin/has roles of
|
|
||||||
# get all courses from database
|
|
||||||
all_courses = (
|
|
||||||
courses.find({"org_id": org_id})
|
|
||||||
.sort("name", 1)
|
|
||||||
.skip(10 * (page - 1))
|
|
||||||
.limit(limit)
|
|
||||||
)
|
|
||||||
|
|
||||||
return [
|
|
||||||
json.loads(json.dumps(course, default=str))
|
|
||||||
for course in await all_courses.to_list(length=100)
|
|
||||||
]
|
|
||||||
|
|
||||||
|
|
||||||
async def get_courses_orgslug(
|
async def get_courses_orgslug(
|
||||||
request: Request, page: int = 1, limit: int = 10, org_slug: str | None = None
|
request: Request,
|
||||||
|
current_user: PublicUser,
|
||||||
|
page: int = 1,
|
||||||
|
limit: int = 10,
|
||||||
|
org_slug: str | None = None,
|
||||||
):
|
):
|
||||||
courses = request.app.db["courses"]
|
courses = request.app.db["courses"]
|
||||||
orgs = request.app.db["organizations"]
|
orgs = request.app.db["organizations"]
|
||||||
# TODO : Get only courses that user is admin/has roles of
|
|
||||||
|
|
||||||
# get org_id from slug
|
# get org_id from slug
|
||||||
org = await orgs.find_one({"slug": org_slug})
|
org = await orgs.find_one({"slug": org_slug})
|
||||||
|
|
@ -347,7 +331,15 @@ async def get_courses_orgslug(
|
||||||
status_code=status.HTTP_409_CONFLICT, detail="Organization does not exist"
|
status_code=status.HTTP_409_CONFLICT, detail="Organization does not exist"
|
||||||
)
|
)
|
||||||
|
|
||||||
# get all courses from database
|
# show only public courses if user is not logged in
|
||||||
|
if current_user.user_id == "anonymous":
|
||||||
|
all_courses = (
|
||||||
|
courses.find({"org_id": org["org_id"], "public": True})
|
||||||
|
.sort("name", 1)
|
||||||
|
.skip(10 * (page - 1))
|
||||||
|
.limit(limit)
|
||||||
|
)
|
||||||
|
else:
|
||||||
all_courses = (
|
all_courses = (
|
||||||
courses.find({"org_id": org["org_id"]})
|
courses.find({"org_id": org["org_id"]})
|
||||||
.sort("name", 1)
|
.sort("name", 1)
|
||||||
|
|
@ -396,7 +388,6 @@ async def verify_rights(
|
||||||
request, action, current_user.user_id, course_id, course["org_id"]
|
request, action, current_user.user_id, course_id, course["org_id"]
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
if not hasRoleRights and not isAuthor:
|
if not hasRoleRights and not isAuthor:
|
||||||
raise HTTPException(
|
raise HTTPException(
|
||||||
status_code=status.HTTP_403_FORBIDDEN,
|
status_code=status.HTTP_403_FORBIDDEN,
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue