You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

116 lines
5.8KB

  1. # @name: create.py
  2. # @creation_date: 2021-10-25
  3. # @license: The MIT License <https://opensource.org/licenses/MIT>
  4. # @author: Simon Bowie <ad7588@coventry.ac.uk>
  5. # @purpose: create route for creating tools, examples, and practices
  6. # @acknowledgements:
  7. # https://www.digitalocean.com/community/tutorials/how-to-make-a-web-application-using-flask-in-python-3
  8. from flask import Blueprint, render_template, request, flash, redirect, url_for
  9. from flask_login import login_required, current_user
  10. from .models import Resource
  11. from .models import Relationship
  12. from .resources import *
  13. from .relationships import *
  14. from . import db
  15. import os
  16. create = Blueprint('create', __name__)
  17. # route for creating a new resource
  18. @create.route('/create', methods=('GET', 'POST'))
  19. @login_required
  20. def create_resource():
  21. if request.method == 'POST':
  22. if request.form.get('resource_type') == 'tool':
  23. type = 'tool'
  24. name = request.form.get('tool_name')
  25. description = request.form.get('description')
  26. developer = request.form.get('developer')
  27. developerUrl = request.form.get('developerUrl')
  28. projectUrl = request.form.get('projectUrl')
  29. repositoryUrl = request.form.get('repositoryUrl')
  30. license = request.form.get('license')
  31. scriptingLanguage = request.form.get('scriptingLanguage')
  32. expertiseToUse = request.form.get('expertiseToUse')
  33. expertiseToHost = request.form.get('expertiseToHost')
  34. dependencies = request.form.get('dependencies')
  35. ingestFormats = request.form.get('ingestFormats')
  36. outputFormats = request.form.get('outputFormats')
  37. status = request.form.get('status')
  38. if not name:
  39. flash('Name is required!')
  40. else:
  41. tool = Resource.query.filter_by(type='tool').filter_by(name=name).first() # if this returns a tool, then the name already exists in database
  42. if tool: # if a tool is found, we want to redirect back to create page
  43. flash('Tool with same name already exists')
  44. return redirect(url_for('create.create_resource',_external=True,_scheme=os.environ.get('SSL_SCHEME')))
  45. # create a new tool with the form data
  46. new_tool = Resource(type=type, name=name, description=description, developer=developer, developerUrl=developerUrl, projectUrl=projectUrl, repositoryUrl=repositoryUrl, license=license, scriptingLanguage=scriptingLanguage, expertiseToUse=expertiseToUse, expertiseToHost=expertiseToHost, dependencies=dependencies, ingestFormats=ingestFormats, outputFormats=outputFormats, status=status)
  47. # add the new tool to the database
  48. db.session.add(new_tool)
  49. db.session.commit()
  50. if request.form.getlist('linked_resources'):
  51. for linked_resource in request.form.getlist('linked_resources'):
  52. tool = Resource.query.filter_by(type='tool').filter_by(name=name).first()
  53. add_relationship(tool.id, linked_resource)
  54. elif request.form.get('resource_type') == 'practice':
  55. type = 'practice'
  56. name = request.form.get('practice_name')
  57. description = request.form.get('description')
  58. longDescription = request.form.get('longDescription')
  59. experimental = request.form.get('experimental')
  60. considerations = request.form.get('considerations')
  61. references = request.form.get('references')
  62. if not name:
  63. flash('Name is required!')
  64. else:
  65. practice = Resource.query.filter_by(type='practice').filter_by(name=name).first() # if this returns a practice, then the name already exists in database
  66. if practice: # if a practice is found, we want to redirect back to create page
  67. flash('Practice with same name already exists')
  68. return redirect(url_for('create.create_resource',_external=True,_scheme=os.environ.get('SSL_SCHEME')))
  69. # create a new practice with the form data
  70. new_practice = Resource(type=type, name=name, description=description, longDescription=longDescription, experimental=experimental, considerations=considerations, references=references)
  71. # add the new practice to the database
  72. db.session.add(new_practice)
  73. db.session.commit()
  74. elif request.form.get('resource_type') == 'book':
  75. type = 'book'
  76. name = request.form.get('book_name')
  77. description = request.form.get('description')
  78. author = request.form.get('author')
  79. year = request.form.get('year')
  80. typology = request.form.get('typology')
  81. bookUrl = request.form.get('bookUrl')
  82. isbn = request.form.get('isbn')
  83. if not name:
  84. flash('Name is required!')
  85. else:
  86. book = Resource.query.filter_by(type='book').filter_by(name=name).first() # if this returns a book, then the name already exists in database
  87. if book: # if a book is found, we want to redirect back to create page
  88. flash('Book with same name already exists')
  89. return redirect(url_for('create.create_resource',_external=True,_scheme=os.environ.get('SSL_SCHEME')))
  90. # create a new book with the form data
  91. new_book = Resource(type=type, name=name, description=description, author=author, year=year, typology=typology, bookUrl=bookUrl, isbn=isbn)
  92. # add the new book to the database
  93. db.session.add(new_book)
  94. db.session.commit()
  95. resource_dropdown = Resource.query
  96. return render_template('create.html', resource_dropdown=resource_dropdown)