def link_lr_comp(): lr_uri = request.form['lr_uri'] c_id = request.form['c_id'] try: models.updateCompetencyLR(c_id, LR_NODE + lr_uri) except Exception, e: return e.message
def competencies(): # Look for comp args, if none display all comps d = {} uri = request.args.get('uri', None) mb = request.args.get('mb', False) if uri: if current_user.is_authenticated(): user = User(current_user.id) comps = user.getAllComps() d['registered'] = str(hash(uri)) in comps.keys() d['uri'] = uri comp = models.getCompetency(uri, objectid=True) d['cid'] = comp.pop('_id') d['comp'] = comp # If medbiq comp display xml if so since it's the original and not lossy internal one if mb: if not comp.get('edited', False) and competency.isMB(comp): try: thexml = requests.get(competency.addXMLSuffix( comp['uri'])).text except: thexml = mbc.toXML(comp) else: thexml = mbc.toXML(comp) return Response(thexml, mimetype='application/xml') else: compuri = d['uri'] if 'adlnet' in d['uri']: compuri = compuri[:7] + 'www.' + compuri[7:] url = "https://node01.public.learningregistry.net/slice?any_tags=%s" % compuri resp = requests.get(url) ids = [] if resp.status_code == 200: lrresults = json.loads(resp.content) ids = [s['doc_ID'] for s in lrresults['documents']] for d_id in ids: models.updateCompetencyLR( d['cid'], current_app.config['LR_NODE'] + d_id + '&by_doc_ID=T') updated_comp = models.getCompetency(uri, objectid=True) d['comp'] = updated_comp return render_template('comp-details.html', **d) d['comps'] = models.findCompetencies() return render_template('competencies.html', **d)
def frameworks(): if request.method == 'GET': # Determine if requesting specific fwk or not uri = request.args.get('uri', None) if uri: d = {} if current_user.is_authenticated(): d['registered'] = str(hash(uri)) in User( current_user.id).profile['compfwks'].keys() d['uri'] = uri fwk = models.getCompetencyFramework(uri) for c in fwk['competencies']: compuri = c['uri'] comp = models.getCompetency(compuri, objectid=True) if comp: cid = comp['_id'] if 'adlnet' in compuri: compuri = compuri[:7] + 'www.' + compuri[7:] url = "https://node01.public.learningregistry.net/slice?any_tags=%s" % compuri resp = requests.get(url) ids = [] if resp.status_code == 200: lrresults = json.loads(resp.content) ids = [s['doc_ID'] for s in lrresults['documents']] for d_id in ids: models.updateCompetencyLR( cid, current_app.config['LR_NODE'] + d_id + '&by_doc_ID=T') d['fwk'] = models.getCompetencyFramework(uri) return render_template('compfwk-details.html', **d) return_dict = {'frameworks_form': FrameworksForm()} else: # Validate submitted fwk uri/parse/add to system ff = FrameworksForm(request.form) if ff.validate_on_submit(): #add to system competency.parseComp(ff.framework_uri.data) return_dict = {'frameworks_form': FrameworksForm()} else: return_dict = {'frameworks_form': ff} return_dict['cfwks'] = models.findCompetencyFrameworks() return render_template('frameworks.html', **return_dict)
def frameworks(): if request.method == 'GET': # Determine if requesting specific fwk or not uri = request.args.get('uri', None) if uri: d = {} if current_user.is_authenticated(): username = current_user.id user = models.getUserProfile(username) d['registered'] = str(hash(uri)) in user['compfwks'].keys() d['uri'] = uri fwk = models.getCompetencyFramework(uri) for c in fwk['competencies']: compuri = c['uri'] comp = models.getCompetency(compuri, objectid=True) if comp: cid = comp['_id'] if 'adlnet' in compuri: compuri = compuri[:7] + 'www.' + compuri[7:] url = "https://node01.public.learningregistry.net/slice?any_tags=%s" % compuri resp = requests.get(url) ids = [] if resp.status_code == 200: lrresults = json.loads(resp.content) ids = [s['doc_ID'] for s in lrresults['documents']] for d_id in ids: models.updateCompetencyLR(cid, LR_NODE + d_id + '&by_doc_ID=T') d['fwk'] = models.getCompetencyFramework(uri) return render_template('compfwk-details.html', **d) return_dict = {'frameworks_form': FrameworksForm()} else: # Validate submitted fwk uri/parse/add to system ff = FrameworksForm(request.form) if ff.validate_on_submit(): #add to system competency.parseComp(ff.framework_uri.data) return_dict = {'frameworks_form': FrameworksForm()} else: return_dict = {'frameworks_form': ff} return_dict['cfwks'] = models.findCompetencyFrameworks() return render_template('frameworks.html', **return_dict)
def competencies(): # Look for comp args, if none display all comps d = {} uri = request.args.get('uri', None) mb = request.args.get('mb', False) if uri: if current_user.is_authenticated(): user = User(current_user.id) comps = user.getAllComps() d['registered'] = str(hash(uri)) in comps.keys() d['uri'] = uri comp = models.getCompetency(uri, objectid=True) d['cid'] = comp.pop('_id') d['comp'] = comp # If medbiq comp display xml if so since it's the original and not lossy internal one if mb: if not comp.get('edited', False) and competency.isMB(comp): try: thexml = requests.get(competency.addXMLSuffix(comp['uri'])).text except: thexml = mbc.toXML(comp) else: thexml = mbc.toXML(comp) return Response(thexml, mimetype='application/xml') else: compuri = d['uri'] if 'adlnet' in d['uri']: compuri = compuri[:7] + 'www.' + compuri[7:] url = "https://node01.public.learningregistry.net/slice?any_tags=%s" % compuri resp = requests.get(url) ids = [] if resp.status_code == 200: lrresults = json.loads(resp.content) ids = [s['doc_ID'] for s in lrresults['documents']] for d_id in ids: models.updateCompetencyLR(d['cid'], current_app.config['LR_NODE'] + d_id + '&by_doc_ID=T') updated_comp = models.getCompetency(uri, objectid=True) d['comp'] = updated_comp return render_template('comp-details.html', **d) d['comps'] = models.findCompetencies() return render_template('competencies.html', **d)
def link_lr_comp(): lr_uri = request.form['lr_uri'] c_id = request.form['c_id'] lr_title = request.form['lr_title'] c_uri = request.form['c_uri'] c_content = request.form['c_content'] user = User(current_user.id) roles = user.roles if 'admin' in roles: user_role = 'admin' elif 'teacher' in roles: user_role = 'teacher' try: models.updateCompetencyLR(c_id, current_app.config['LR_NODE'] + lr_uri) except Exception, e: return e.message