Esempio n. 1
0
def archives():
    if request.method == "POST":
        action = request.values['submit']
        if action == "Create":
            a = models.Archive( name=request.values['archive'] )
            a.save()
            flash('New archive named ' + a.data["name"] + ' created')
        elif action == "Move":
            a = models.Archive.pull_by_name(request.values['move_from'])
            b = models.Archive.pull_by_name(request.values['move_to'])
            if a is None or b is None:
                flash('Sorry. One of the archives you specified could not be identified...')
            else:
                lena = len(a)
                for i in a.children(justids=True):
                    ir = models.Student.pull(i)
                    ir.data["archive"] = b.data["name"]
                    ir.save()
                time.sleep(1)
                flash(str(lena) + ' records moved from archive ' + a.data["name"] + ' to archive ' + b.data["name"] + ', which now contains ' + str(len(b)) + ' records. Archive ' + a.data["name"] + ' still exists, but is now empty. Feel free to delete it if you wish, or use it to put more records in.')
        elif action == "Delete":
            a = models.Archive.pull_by_name(request.values['delete'])
            length = len(a)
            a.delete()
            flash('Archive ' + a.data["name"] + ' deleted, along with all ' + str(length) + ' records it contained.')

        time.sleep(1)

    return render_template(
        'leaps/admin/archive.html', 
        currentcount=models.Student.query(q={"query":{"bool":{"must":[{"term":{"archive"+app.config['FACET_FIELD']:"current"}}]}}}).get('hits',{}).get('total',0),
        archives=dropdowns('archive','name')
    )
Esempio n. 2
0
def index():
    school = current_user.is_school
    students = _get_students(school)
    return render_template('leaps/schools/index.html', students=students, schools=dropdowns('school','name'))
Esempio n. 3
0
def student(uuid=None):
    if uuid is None:
        return render_template('leaps/admin/students.html')

    if uuid == "new":
        student = models.Student()
    else:
        student = models.Student.pull(uuid)
        if student is None: abort(404)

    selections={
        "schools": dropdowns('school'),
        "subjects": dropdowns('subject'),
        "advancedsubjects": dropdowns('advancedsubject'),
        "levels": dropdowns('level'),
        "grades": dropdowns('grade'),
        "institutions": dropdowns('institution'),
        "advancedlevels": dropdowns('advancedlevel'),
        "local_authorities": dropdowns('school','local_authority'),
        "leaps_categories": dropdowns('school','leaps_category'),
        "simd_deciles": dropdowns('simd','simd_decile'),
        "simd_quintiles": dropdowns('simd','simd_quintile'),
        "archives": dropdowns('archive','name')
    }

    if request.method == 'GET':
        return render_template(
            'leaps/admin/student.html', 
            record=student, 
            selections=selections
        )
    elif ( request.method == 'POST' and request.values.get('submit','') == "Delete" ) or request.method == 'DELETE':
        student.delete()
        time.sleep(1)
        flash("Student " + str(student.id) + " deleted")
        return redirect(url_for('.student'))
    elif request.method == 'POST':
        student.save_from_form(request)
        if uuid == 'new':
            flash("New student record has been created", "success")
            return redirect(url_for('.student') + '/' + str(student.id))
        else:
            flash("Student record has been updated", "success")
            return render_template(
                'leaps/admin/student.html', 
                record=student, 
                selections=selections
            )
Esempio n. 4
0
def index(model=None, deleteall=False):
    if request.method == 'GET':
        if model == 'subjects':
            sd = dropdowns('institution','name')
        else:
            sd = None
        return render_template('leaps/admin/import.html', model=model, subjects=sd)
    elif request.method == 'POST':
#        try:
        records = []
        if "csv" in request.files.get('upfile').filename:
            upfile = request.files.get('upfile')
            reader = csv.DictReader( upfile )
            records = [ row for row in reader ]
            sourcetype = "csv"
        elif "json" in request.files.get('upfile').filename:
            upfile = request.files.get('upfile')
            records = json.load(upfile)
            sourcetype = "json"

        if model is None:
            model = request.form.get('model',None)
            if model is None:
                flash("You must specify what sort of records you are trying to upload.")
                return render_template('leaps/admin/import.html')

        if model == 'subjects':
            klass = getattr(models, 'Institution' )
        else:
            klass = getattr(models, model[0].capitalize() + model[1:] )

        if (deleteall or request.values.get('deleteall',False)) and model != "subjects":
            klass.delete_all()

        if model.lower() == 'student':
            total = len(records)
            chunk = 500
            pos = 0
            while pos < total:
                if pos + chunk < total:
                    to = pos + chunk - 1
                else:
                    to = total - 1
                klass().bulk(records[pos:to])
                pos += chunk
                time.sleep(1)

        elif model.lower() in ['school'] and sourcetype == "csv":
            for rec in records:
                if 'contacts' not in rec:
                    rec['contacts'] = []
                    c = {}
                    if rec.get('contact_name',"") != "":
                        c["name"] = rec['contact_name']
                        del rec['contact_name']
                    if rec.get('contact_email',"") != "":
                        c["email"] = rec['contact_email']
                        del rec['contact_email']
                    if rec.get('contact_department',"") != "":
                        c["department"] = rec['contact_department']
                        del rec['contact_department']
                    if rec.get('contact_phone',"") != "":
                        c["phone"] = rec['contact_phone']
                        del rec['contact_phone']
                    if rec.get('password',"") != "":
                        c["password"] = rec['password']
                        del rec['password']
                    if len(c.keys()) > 0: rec['contacts'].append(c)
                c = klass(**rec)
                c.save()

        elif model.lower() in ['institution'] and sourcetype == "csv":
            for rec in records:
                if 'contacts' not in rec:
                    rec['contacts'] = []
                    c = {}
                    if rec.get('contact_name',"") != "":
                        c["name"] = rec['contact_name']
                        del rec['contact_name']
                    if rec.get('contact_email',"") != "":
                        c["email"] = rec['contact_email']
                        del rec['contact_email']
                    if rec.get('contact_department',"") != "":
                        c["department"] = rec['contact_department']
                        del rec['contact_department']
                    if rec.get('contact_phone',"") != "":
                        c["phone"] = rec['contact_phone']
                        del rec['contact_phone']
                    if len(c.keys()) > 0:
                        c['password'] = "******"
                        rec['contacts'].append(c)

                    c2 = {}
                    if rec.get('contact_name_2',"") != "":
                        c2["name"] = rec['contact_name_2']
                        del rec['contact_name_2']
                    if rec.get('contact_email_2',"") != "":
                        c2["email"] = rec['contact_email_2']
                        del rec['contact_email_2']
                    if rec.get('contact_department_2',"") != "":
                        c2["department"] = rec['contact_department_2']
                        del rec['contact_department_2']
                    if rec.get('contact_phone_2',"") != "" in rec:
                        c2["phone"] = rec['contact_phone_2']
                        del rec['contact_phone_2']
                    if len(c2.keys()) > 0:
                        c2['password'] = "******"
                        rec['contacts'].append(c2)

                if 'subjects' in rec:
                    if len(rec['subjects']) == 0:
                        del rec['subjects']
                    else:
                        def splitup(subj):
                            if '\t' in subj:
                                interim = subj.split('\t')
                                obj = {}
                                if len(interim) == 1:
                                    obj['name'] = interim[0]
                                elif len(interim) == 2:
                                    obj['level'] = interim[0]
                                    obj['name'] = interim[1]
                                elif len(interim) == 3:
                                    obj['level'] = interim[0]
                                    obj['name'] = interim[1]
                                    obj['coursecode'] = interim[2]
                            else:
                                obj = {"name":subj}
                            return obj
                        rec['subjects'] = [splitup(i) for i in rec['subjects'].replace('\r','').split('\n') if len(i) > 0]

                c = klass(**rec)
                c.save()

        elif model.lower() == "subjects":
            try:
                if isinstance(current_user.is_institution,bool):
                    if 'institution' not in request.values or request.values['institution'] == "":
                        flash('You cannot upload subjects without selecting an institution to upload them to. For uploading generic subjects, upload to subject or advancedsubject')
                        return redirect('/admin/import/subjects')
                    institution = klass().pull_by_name(request.values['institution'])
                else:
                    institution = klass().pull_by_name(current_user.is_institution)

                if not isinstance(records,list) or (len(records) > 0 and 'name' not in records[0].keys()):
                    flash('Your file appears to have no records or does not have the required keys - "name" is required. Please check your file and try again.')
                else:
                    try:
                        institution.data['subjects'] = records
                        institution.save()
                        time.sleep(1)
                        flash(str(len(records)) + " subjects have been added.")
                    except:
                        flash('Sorry, there was an unknown error. Please check your file and try again')
            except:
                flash('Sorry, there was an unknown error. Please check your file and try again')
            
            if isinstance(current_user.is_institution,bool):
                return redirect('/admin/data/institution')
            else:
                return redirect('/universities/subjects')

        else:
            klass().bulk(records)
        
        time.sleep(1)
        checklen = klass.query(q="*")['hits']['total']
        
        flash(str(len(records)) + " records have been imported, there are now " + str(checklen) + " records.")
        return redirect('admin/data/' + model)