# @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 flask_login import login_required, current_user from .models import Resource from .models import Relationship 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 retrieve linked resources def get_linked_resources(primary_id): primary_relationships = Relationship.query.filter_by(first_resource_id=primary_id).all() links = [] if primary_relationships: links = [] for relationship in primary_relationships: secondary_id = relationship.second_resource_id links.extend(Resource.query.filter_by(id=secondary_id).all()) secondary_relationships = Relationship.query.filter_by(second_resource_id=primary_id).all() if secondary_relationships: for relationship in secondary_relationships: primary_id = relationship.first_resource_id links.extend(Resource.query.filter_by(id=primary_id).all()) return links else: secondary_relationships = Relationship.query.filter_by(second_resource_id=primary_id).all() if secondary_relationships: links = [] for relationship in secondary_relationships: primary_id = relationship.first_resource_id links.extend(Resource.query.filter_by(id=primary_id).all()) return links # function to add a relationship to a linked resource def add_linked_resource(resource_id, linked_resource_id): first_resource_id = resource_id second_resource_id = linked_resource_id new_relationship = Relationship(first_resource_id=first_resource_id, second_resource_id=second_resource_id) # add the new relationship to the database db.session.add(new_relationship) db.session.commit() # 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 delete a single relationship def delete_relationship(first_resource_id, second_resource_id): relation = Relationship.query.filter((Relationship.first_resource_id == first_resource_id) & (Relationship.second_resource_id == second_resource_id)).first() deletion = Relationship.query.get(relation.id) db.session.delete(deletion) db.session.commit()