mirror of
https://github.com/Rushilwiz/SkoolOS.git
synced 2025-04-20 12:20:18 -04:00
bug fix2
This commit is contained in:
parent
266ed360f1
commit
fc88e6c4c9
87
CLI/t-git.py
87
CLI/t-git.py
|
@ -6,6 +6,7 @@ import pprint
|
||||||
import json
|
import json
|
||||||
import shutil
|
import shutil
|
||||||
import time
|
import time
|
||||||
|
import prompt_toolkit.clipboard.pyperclip
|
||||||
|
|
||||||
#git clone student directory ==> <student-id>/classes/assignments
|
#git clone student directory ==> <student-id>/classes/assignments
|
||||||
|
|
||||||
|
@ -56,6 +57,7 @@ def command(command):
|
||||||
output = process.communicate()[1]
|
output = process.communicate()[1]
|
||||||
#print(output.decode('utf-8'))
|
#print(output.decode('utf-8'))
|
||||||
|
|
||||||
|
#public methods: deleteClass, makeClass, update
|
||||||
class Teacher:
|
class Teacher:
|
||||||
def __init__(self, data):
|
def __init__(self, data):
|
||||||
# teacher info already stored in API
|
# teacher info already stored in API
|
||||||
|
@ -99,15 +101,26 @@ class Teacher:
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
#list of classes that have been deleted (not with deleteClass)
|
#list of classes that have been deleted (not with deleteClass)
|
||||||
extra = self.classes
|
extra = []
|
||||||
|
for c in self.classes:
|
||||||
|
extra.append(c)
|
||||||
|
for i in range(len(extra)):
|
||||||
|
e = extra[i]['path']
|
||||||
|
extra[i] = e
|
||||||
|
print("Extra: "+str(extra))
|
||||||
|
print("Local:" + str(classes))
|
||||||
#checks all class directories first
|
#checks all class directories first
|
||||||
for c in classes:
|
for c in classes:
|
||||||
path = self.username + "/" + c
|
path = self.username + "/" + c
|
||||||
if(self.checkClass(path) == False):
|
if(self.checkClass(path) == False):
|
||||||
return
|
return
|
||||||
ind=0
|
extra.remove(path)
|
||||||
|
print("Current classes: " + path)
|
||||||
|
|
||||||
|
for e in extra:
|
||||||
|
self.deleteClass(e)
|
||||||
|
|
||||||
for i in range(len(classes)):
|
for i in range(len(classes)):
|
||||||
print(extra)
|
|
||||||
c = classes[i]
|
c = classes[i]
|
||||||
path = self.username + "/" + c
|
path = self.username + "/" + c
|
||||||
#lists all assignments and default files
|
#lists all assignments and default files
|
||||||
|
@ -124,16 +137,6 @@ class Teacher:
|
||||||
command('git commit -m "Update"')
|
command('git commit -m "Update"')
|
||||||
command('git push -u origin master')
|
command('git push -u origin master')
|
||||||
os.chdir(loc)
|
os.chdir(loc)
|
||||||
try:
|
|
||||||
extra.pop(ind)
|
|
||||||
ind=i-1
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
print(i)
|
|
||||||
print("EXTRA: " + str(extra))
|
|
||||||
ind=ind+1
|
|
||||||
for e in extra:
|
|
||||||
self.deleteClass(e['path'])
|
|
||||||
|
|
||||||
#class name format: <course-name>_<ion_user>
|
#class name format: <course-name>_<ion_user>
|
||||||
|
|
||||||
|
@ -142,6 +145,9 @@ class Teacher:
|
||||||
def checkClass(self,path):
|
def checkClass(self,path):
|
||||||
cname = path.split("/")
|
cname = path.split("/")
|
||||||
cname = cname[len(cname)-1]
|
cname = cname[len(cname)-1]
|
||||||
|
if(os.path.isfile(path)):
|
||||||
|
print(path + " must be in a Class directory.")
|
||||||
|
return False
|
||||||
if(("_" + self.username) in cname) == False:
|
if(("_" + self.username) in cname) == False:
|
||||||
print("Incorrect class name: Must be in the format: " + self.username+ "/<course-name>_<ion_user>, not " + path)
|
print("Incorrect class name: Must be in the format: " + self.username+ "/<course-name>_<ion_user>, not " + path)
|
||||||
return False
|
return False
|
||||||
|
@ -183,21 +189,26 @@ class Teacher:
|
||||||
return False
|
return False
|
||||||
|
|
||||||
#adds class to git, not API
|
#adds class to git, not API
|
||||||
|
#Assuming valid class name
|
||||||
def addClasstoGit(self, path):
|
def addClasstoGit(self, path):
|
||||||
cname = path.split("/")
|
cname = path.split("/")
|
||||||
cname = cname[len(cname)-1]
|
cname = cname[len(cname)-1]
|
||||||
#push to remote repo
|
#push to remote repo
|
||||||
url='https://github.com/' + self.git + "/" + cname
|
url='https://github.com/' + self.git + "/" + cname
|
||||||
if(self.checkClass(path)):
|
|
||||||
if(requests.get(url).status_code != 200):
|
if(requests.get(url).status_code != 200):
|
||||||
input("Make new Git Repo with name: " + cname + " (Press any key to continue)\n")
|
input("Make new Git Repo with name: " + cname + " (Press any key to continue)\n")
|
||||||
|
try:
|
||||||
|
pyperclip.copy(cname)
|
||||||
|
spam = pyperclip.paste()
|
||||||
|
print(cname + " copied to clipboard.")
|
||||||
|
except:
|
||||||
|
pass
|
||||||
time.sleep(2)
|
time.sleep(2)
|
||||||
webbrowser.open('https://github.com/new')
|
webbrowser.open('https://github.com/new')
|
||||||
input("Repo created? (Press any key to continue)\n")
|
input("Repo created? (Press any key to continue)\n")
|
||||||
|
|
||||||
print(url)
|
print(url)
|
||||||
while(requests.get(url).status_code != 200):
|
while(requests.get(url).status_code != 200):
|
||||||
print(requests.get(url))
|
|
||||||
r = input("Repo not created yet. (Press any key to continue after repo created, or 'N' to exit)\n")
|
r = input("Repo not created yet. (Press any key to continue after repo created, or 'N' to exit)\n")
|
||||||
if(r=="N" or r=="No"):
|
if(r=="N" or r=="No"):
|
||||||
return None
|
return None
|
||||||
|
@ -227,48 +238,32 @@ class Teacher:
|
||||||
'teacher':self.username
|
'teacher':self.username
|
||||||
}
|
}
|
||||||
return data
|
return data
|
||||||
return None
|
|
||||||
|
|
||||||
#make class from existing directory, add to git and api
|
#make class from existing directory, add to git and api
|
||||||
def addClass(self, path):
|
def addClass(self, path):
|
||||||
|
|
||||||
if (self.checkClass(path)):
|
if (self.checkClass(path)):
|
||||||
data = self.addClasstoGit(path)
|
data = self.addClasstoGit(path)
|
||||||
#add class to db
|
#make class instance in db
|
||||||
data = postDB(data, 'http://127.0.0.1:8000/classes/')
|
data = postDB(data, 'http://127.0.0.1:8000/classes/')
|
||||||
if(len(self.sclass)==0):
|
#add to instance
|
||||||
classes = data['id']
|
#upate self.classes
|
||||||
else:
|
|
||||||
classes = self.sclass + "," + str(data['id'])
|
|
||||||
self.sclass=classes
|
|
||||||
self.classes.append(data)
|
self.classes.append(data)
|
||||||
print(self.sclass)
|
if(len(self.sclass)==0):
|
||||||
print(self.classes)
|
self.sclass = data['id']
|
||||||
|
else:
|
||||||
|
self.sclass = self.sclass + "," + str(data['id'])
|
||||||
|
|
||||||
|
#update teacher instance in db, classes field
|
||||||
data={
|
data={
|
||||||
'first_name':self.first_name,
|
'first_name':self.first_name,
|
||||||
'last_name':self.last_name,
|
'last_name':self.last_name,
|
||||||
'git':self.git,
|
'git':self.git,
|
||||||
'ion_user':self.username,
|
'ion_user':self.username,
|
||||||
'url':self.url,
|
'url':self.url,
|
||||||
'classes':classes
|
'classes':self.sclass
|
||||||
}
|
}
|
||||||
|
putDB(data, self.url)
|
||||||
print(putDB(data, self.url))
|
|
||||||
|
|
||||||
cid=getDB(self.url)['classes'].split(",")
|
|
||||||
try:
|
|
||||||
cid.remove('')
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
try:
|
|
||||||
cid.remove("")
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
classes=[]
|
|
||||||
for c in cid:
|
|
||||||
url = "http://127.0.0.1:8000/classes/" + str(c) + "/"
|
|
||||||
classes.append(getDB(url))
|
|
||||||
self.classes = classes
|
|
||||||
|
|
||||||
return data
|
return data
|
||||||
|
|
||||||
|
@ -317,14 +312,15 @@ class Teacher:
|
||||||
cid = str(c['id'])
|
cid = str(c['id'])
|
||||||
repo = c['repo']
|
repo = c['repo']
|
||||||
print(cid)
|
print(cid)
|
||||||
#remove from api
|
|
||||||
|
|
||||||
|
#remove from api
|
||||||
for i in range(len(self.classes)):
|
for i in range(len(self.classes)):
|
||||||
if(self.classes[i]['id'] == int(cid)):
|
if(self.classes[i]['id'] == int(cid)):
|
||||||
|
print("DELETE: " + self.classes[i]['name'])
|
||||||
del self.classes[i]
|
del self.classes[i]
|
||||||
s=""
|
s=""
|
||||||
for c in self.classes:
|
for c in self.classes:
|
||||||
s = s + str(c['id']) + ","
|
s = s + str(self.classes[i]['id']) + ","
|
||||||
print(s)
|
print(s)
|
||||||
s = s[:-1]
|
s = s[:-1]
|
||||||
print(s)
|
print(s)
|
||||||
|
@ -355,7 +351,6 @@ class Teacher:
|
||||||
|
|
||||||
print(repo)
|
print(repo)
|
||||||
while(requests.get(repo).status_code == 200):
|
while(requests.get(repo).status_code == 200):
|
||||||
print(requests.get(repo))
|
|
||||||
r = input("Repo still no deleted yet. (Press any key to continue after repo deleted, or 'N' to exit)\n")
|
r = input("Repo still no deleted yet. (Press any key to continue after repo deleted, or 'N' to exit)\n")
|
||||||
if(r=="N" or r=="No" or r=='n'):
|
if(r=="N" or r=="No" or r=='n'):
|
||||||
return None
|
return None
|
||||||
|
@ -369,5 +364,5 @@ class Teacher:
|
||||||
|
|
||||||
data = getTeacher("eharris1")
|
data = getTeacher("eharris1")
|
||||||
t = Teacher(data)
|
t = Teacher(data)
|
||||||
|
t.deleteClass("eharris1/Crypto_eharris1")
|
||||||
t.update()
|
t.update()
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user