def GetMoreNotifications(Request): if not GF.SESSION(Request) or not URL.REFERER_is_Set(Request): return StatusPages.UnAuthurithedUserPage(Request, 'Un Authorized User') if URL.GetREFERER(Request) != init.Notifications: return StatusPages.UnAuthurithedUserPage(Request, 'Un Authorized User') Form = CheckPostsNumberForm(Request.POST) if not Form.isValid(): return JsonResponse(GF.Returns(-1, 'Not Valid Number')) index = int(Form.GetNumber()) Slice = slice(index, index + 7) The_Notifications = Notifications.objects.filter(User_Email=Hashing.Hash_Notifications( Request.session["Email"])).order_by('-id')[Slice] if not len(The_Notifications): return JsonResponse(GF.Returns(0, 'No Data')) Result = GF.Returns(1, { 'Notifications': {}, 'Count': 0 }) Count = 0 for Notification in The_Notifications: Text = GetTheWholeNotification(Notification) if Text != '': Count += 1 Result['Data']['Notifications'][str(Count)] = Text Result['Data']['Count'] = Count return JsonResponse(Result)
def GetPosts(Request): Form = CheckPostsNumberForm(Request.POST) if not Form.isValid(): return JsonResponse(GF.Returns(-1, 'Not Valid Number')) Options = '0' Articles = '' index = int(Form.GetNumber()) Slice = slice(index, index + 5) if URL.REFERER_is_Set(Request): if URL.GetREFERER(Request) == init.Articles+ '/': Options = '0' Articles = Posts.objects.filter(Deleted=0)[Slice] elif URL.GetREFERER(Request) == init.MyProfile: Options = '1' Articles = Posts.objects.filter(User_Email=Hashing.Hash_Articles( Request.session["Email"]), Deleted=0)[Slice] else: Match = re.search(r'' + init.User + '(\d)+', URL.GetREFERER(Request)) if not Match: return StatusPages.UnAuthurithedUserPage(Request, 'Un Authorized User') User = Users.objects.filter(id=Match.group(1)) if not User.exists(): return StatusPages.UnAuthurithedUserPage(Request, 'Un Authorized User') Result = Hashing.GetAllFromHashing([{ 'Type': 'Users', 'Data': User[0].Email, 'Key': 'Email'}]) if Result['Result'] == -1: return GF.Returns(-1, 'Getting Data From Hashing', Result['Result']['Error']) Articles = Posts.objects.filter(User_Email=Hashing.Hash_Articles( Result['Data']['Email']), Deleted=0)[Slice] Options = '2' if not Articles.exists(): return JsonResponse(GF.Returns(0, 'No Data')) Result = GF.Returns(1, { 'Posts': {}, 'Count': 0 }) Count = 0 for Article in Articles: Text = ASF.GetPost(Article, Options) if Text != '': Count += 1 Result['Data']['Posts'][str(Count)] = Text Result['Data']['Count'] = Count return JsonResponse(Result)
def UserProfile(Request, User_id): User = Users.objects.filter(id=User_id, Activate=1, Deleted=0) if not User.exists(): return StatusPages.NotFoundPage(Request, 'User') Result = Hashing.GetAllFromHashing([{'Type': 'Users', 'Data': User[0].Email, 'Key': 'Email'}]) if Result['Result'] == -1: return StatusPages.ErrorPage(Request, 'User') Articles = Posts.objects.filter(User_Email=Hashing.Hash_Articles(Result['Data']['Email']), Deleted=0)[:5] return UserProfile_Render(Request, User[0], Articles)
def Like_DisLikePost(Request): Form = LikeDisLikeForm(Request.POST) Result = CheckPost(Request, Form) if Result['Result'] != 1: if Result['Data'] == 'Not Valid': return StatusPages.UnAuthurithedUserPage(Request, 'Un Authorized User') return JsonResponse(Result) Post_Like_DisLike = LikesDisLikes.objects.filter(Post_id=Form.GetID(), User_Email=Hashing.Hash_LikeDisLike( Request.session["Email"])) if Post_Like_DisLike.exists(): return JsonResponse(GF.Returns(0, 'You Already ' + ('Liked' if Post_Like_DisLike[0].Status == 0 else 'DisLiked'))) LikeOrDisLike = LikesDisLikes(Post_id=Form.GetID(), User_Email=Hashing.Hash_LikeDisLike(Request.session["Email"]), Status=Form.GetType()) LikeOrDisLike.save() if Request.session["Email"] != Result['Data']['Email']: Notification = Notifications(Type=(Form.GetType()+1), User_Email=Hashing.Hash_Notifications( Result['Data']['Email']), Message=Hashing.Hash_Notifications( json.dumps({ 'Email': Request.session["Email"], 'PostID': Form.GetID() }) )) Notification.save() return JsonResponse(GF.Returns(1, 'Done'))
def MakeArticle(Request): if not GF.SESSION(Request): return StatusPages.UnAuthurithedUserPage(Request, 'Make Article') if Request.method == 'POST' and URL.REFERER_is_Set(Request): Form = MakeArticleForm(Request.POST) if Form.isValid() and URL.GetREFERER(Request) == init.MakeArticle: return MakeArticle_POSTResponse(Request, Form) Post = Posts.objects.filter(User_Email=Hashing.Hash_Articles( Request.session["Email"]), Deleted=0).order_by('-id')[:1] if not Post.exists(): Article_id = '' else: Article_id = Post[0].id if 'Done' in Request.GET: Result = { 'id': Article_id, 'GetButtonValue': 'Make New Article', 'GetResult': 'Done', 'GetPage': '' } return Render.MakeOrEditSuccess_Render(Request, 'Make Article', Result) return Render.__Render(Request, init.MakeArticle_Template, 'Make Article')
def Settings_Account(Request, Type): User = Users.objects.filter(Email=Hashing.Hash_Users(Request.session["Email"]))[0] User.Activate = '0' if Type == 1 else '1' User.save() if GF.Delete_Session(Request)['Result'] == -1: return StatusPages.ErrorPage(Request, 'Settings') return HttpResponseRedirect(init.Articles)
def EditArticle(Request, Article_id): if not GF.SESSION(Request): return StatusPages.UnAuthurithedUserPage(Request, 'Edit Article') Post = Posts.objects.filter(User_Email=Hashing.Hash_Articles( Request.session["Email"]), id=Article_id, Deleted=0) if not Post.exists(): return StatusPages.NotFoundPage(Request, 'Edit Article') if Request.method == 'POST' and URL.REFERER_is_Set(Request): Form = MakeArticleForm(Request.POST) if Form.isValid() and URL.GetREFERER( Request) == init.EditArticle + str(Post[0].id): return EditArticle_POSTResponse(Form, Article_id) Result = Hashing.GetAllFromHashing([{ 'Type': 'Articles', 'Data': Post[0].Article, 'Key': 'Post' }, { 'Type': 'Articles', 'Data': Post[0].ArticleTitle, 'Key': 'Title' }, { 'Type': 'Articles', 'Data': Post[0].Tags, 'Key': 'Tags' }]) if Result['Result'] == -1: return StatusPages.ErrorPage(Request, 'Edit Article') if 'Edited' in Request.GET: Result = { 'id': Article_id, 'GetButtonValue': 'Edit This Article', 'GetResult': 'Edited', 'GetPage': '' } return Render.MakeOrEditSuccess_Render(Request, 'Edit Article', Result) return Render.EditArticle_Render( Request, 'Edited' if 'Edited' in Request.GET else '', Result['Data']['Title'], Result['Data']['Post'], Result['Data']['Tags'])
def CheckEmail(Request): Form = CheckEmailForm(Request.POST) if Form.isValid() and URL.REFERER_is_Set(Request): if URL.GetREFERER(Request) == init.SignUP: if Users.objects.filter(Email=Hashing.Hash_Users(Form.GetEmail())).exists(): return JsonResponse(GF.Returns('1')) return JsonResponse(GF.Returns('0')) return StatusPages.UnAuthurithedUserPage(Request, 'Un Authorized User')
def DeletePost(Request): Form = CheckPostsNumberForm(Request.POST) if not Form.isValid() or not URL.REFERER_is_Set(Request) or not GF.SESSION(Request): return StatusPages.UnAuthurithedUserPage(Request, 'Un Authorized User') if URL.GetREFERER(Request) != init.MyProfile: return StatusPages.UnAuthurithedUserPage(Request, 'Un Authorized User') if not Posts.objects.filter(User_Email=Hashing.Hash_Articles(Request.session["Email"]), Deleted=0, id=Form.GetNumber()).exists(): return JsonResponse(GF.Returns(0, 'Post Not Found')) Posts.objects.filter(User_Email=Hashing.Hash_Articles(Request.session["Email"]), id=Form.GetNumber()).update(Deleted=1) Request.session["Articles_Number"] -= 1 return JsonResponse(GF.Returns(1, 'Deleted'))
def MyProfile(Request): if not GF.SESSION(Request): return StatusPages.UnAuthurithedUserPage(Request, 'My Profile') return __Render(Request, init.MyProfile_Template, 'My Profile', A=Posts.objects.filter(User_Email=Hashing.Hash_Articles( Request.session["Email"]), Deleted='0')[:5])
def MyNotifications(Request): if not GF.SESSION(Request): return StatusPages.UnAuthurithedUserPage(Request, 'My Notifications') UserNotifications = Notifications.objects.filter(User_Email=Hashing.Hash_Notifications( Request.session["Email"] )).order_by('-id')[:7] return MyNotifications_Render(Request, UserNotifications)
def Settings(Request, Section='Picture'): if not GF.SESSION(Request): return StatusPages.UnAuthurithedUserPage(Request, 'Settings') if Request.method == 'POST' and URL.REFERER_is_Set(Request): if URL.GetURL(Request) == init.Settings: return Settings_PictureResponse(Request) elif URL.GetURL(Request) == init.Settings+'/Name': return Settings_NameResponse(Request) elif URL.GetURL(Request) == init.Settings+'/Password': return Settings_PasswordResponse(Request) elif URL.GetURL(Request) == init.Settings+'/DeActivate': if 'DeactivateSubmit' in Request.POST: return Settings_Account(Request, 1) return Settings_Account(Request, 0) return Settings_Render(Request, Section, Request.GET["Result"] if 'Result' in Request.GET else '')
def MakeComment(Request): Form = MakeCommentForm(Request.POST) Result = CheckPost(Request, Form) if Result['Result'] != 1: if Result['Data'] == 'Not Valid': return StatusPages.UnAuthurithedUserPage(Request, 'Un Authorized User') return JsonResponse(Result) Comment = Comments(Post_id=Form.GetID(), User_Email=Hashing.Hash_Comments(Request.session["Email"]), Comment=Hashing.Hash_Comments(Form.GetComment())) Comment.save() Comment = Comments.objects.filter().order_by('-id')[:1] if not Comment.exists(): Comment = '' else: Comment = Comment[0].id if Request.session["Email"] != Result['Data']['Email']: Notification = Notifications(Type=3, User_Email=Hashing.Hash_Notifications( Result['Data']['Email']), Message=Hashing.Hash_Notifications( json.dumps({ 'Email': Request.session["Email"], 'PostID': Form.GetID(), 'Comment': Comment }) )) Notification.save() return JsonResponse(GF.Returns(1, Div( Div(A(init.User+str(Request.session["ID"]), InputImage(Request.session["Picture"])) + Div(P('By : '+Request.session["Name"]) + P('Date : '+str(datetime.datetime.now())))) + Div(P(GetText(Form.GetComment())), 'Comment_Text') , 'Comments')))
def LogOut(Request): if GF.Delete_Session(Request)['Result'] == -1: return StatusPages.ErrorPage(Request, 'Log Out') return HttpResponseRedirect(init.Articles)