# @name: resources.py # @creation_date: 2022-02-23 # @license: The MIT License # @author: Simon Bowie # @purpose: functions for resources # @acknowledgements: from flask import Blueprint, render_template, request, flash, redirect, url_for from .models import Resource from werkzeug.exceptions import abort from . import db # function to retrieve data about a single resource from the database def get_resource(resource_id): resource = Resource.query.filter_by(id=resource_id).first() if resource is None: abort(404) return resource # function to delete a single resource def delete_resource(resource_id): deletion = Resource.query.get(resource_id) db.session.delete(deletion) db.session.commit() flash('Successfully deleted!') # function to get filters for a specific field def get_filter_values(field): # get field values for filter field_filter = Resource.query.filter_by(type='tool').with_entities(getattr(Resource, field)) # turn SQLAlchemy object into list field_filter = [i for i, in field_filter] # split each element on '/' (useful for scriptingLanguage only) field_filter = [y for x in field_filter for y in x.split(' / ')] # consolidate duplicate values field_filter = list(dict.fromkeys(field_filter)) # filter None values from list field_filter = filter(None, field_filter) # sort list by alphabetical order field_filter = sorted(field_filter) return field_filter