From 917c3372ad7b03825403492142567c6500ce6475 Mon Sep 17 00:00:00 2001 From: ctevans Date: Fri, 1 Apr 2016 12:21:03 -0600 Subject: [PATCH] Merged? --- README.md | 4 + backend/.yardoc/checksums | 49 +-- backend/.yardoc/object_types | Bin 5872 -> 5978 bytes backend/.yardoc/objects/root.dat | Bin 134652 -> 140891 bytes .../controllers/api/aggregated_controller.rb | 17 +- backend/app/lib/information.rb | 56 ++- backend/app/models/mentorship.rb | 282 ++++++++++----- backend/app/models/supervision.rb | 271 ++++++++++---- backend/doc/AccessDeniedError.html | 4 +- backend/doc/Admin.html | 4 +- backend/doc/AdminSerializer.html | 4 +- backend/doc/AdminsController.html | 297 ++++++++++++++++ backend/doc/Api/AdminsController.html | 4 +- backend/doc/Api/AggregatedController.html | 76 ++-- backend/doc/Api/AuditTrailController.html | 4 +- backend/doc/Api/DegreeSerializer.html | 4 +- backend/doc/Api/DegreesController.html | 4 +- backend/doc/Api/InstitutionSerializer.html | 4 +- backend/doc/Api/InstitutionsController.html | 4 +- backend/doc/Api/MentorshipSerializer.html | 4 +- backend/doc/Api/MentorshipsController.html | 4 +- backend/doc/Api/NotificationController.html | 4 +- backend/doc/Api/PeopleController.html | 4 +- backend/doc/Api/PersonSerializer.html | 4 +- backend/doc/Api/PostdocSerializer.html | 4 +- backend/doc/Api/SupervisionSerializer.html | 4 +- backend/doc/Api/SupervisionsController.html | 4 +- backend/doc/Api/VerificationController.html | 4 +- backend/doc/ApiController.html | 4 +- backend/doc/ApplicationController.html | 6 +- backend/doc/AuditTrail.html | 4 +- backend/doc/AuthController.html | 4 +- backend/doc/AuthToken.html | 4 +- backend/doc/AuthenticationTimeoutError.html | 4 +- backend/doc/AutoComplete.html | 20 +- backend/doc/AutoCompleteController.html | 4 +- backend/doc/Degree.html | 4 +- backend/doc/Deleter.html | 6 +- backend/doc/ErrorsController.html | 4 +- backend/doc/FindDetail.html | 4 +- backend/doc/FindId.html | 4 +- backend/doc/Information.html | 10 +- backend/doc/Institution.html | 4 +- backend/doc/Mentor.html | 4 +- backend/doc/Mentorship.html | 4 +- backend/doc/NotAuthenticatedError.html | 4 +- backend/doc/Notifier.html | 36 +- backend/doc/Person.html | 4 +- backend/doc/Postdoc.html | 4 +- backend/doc/Search.html | 330 ++++++++++++------ backend/doc/SearchController.html | 4 +- backend/doc/SearchSerializer.html | 4 +- backend/doc/Supervision.html | 4 +- backend/doc/Supervisor.html | 4 +- backend/doc/User.html | 4 +- backend/doc/UserController.html | 107 ++++-- backend/doc/UserMailer.html | 239 +++++++++++++ backend/doc/UserSerializer.html | 4 +- backend/doc/Verifier.html | 79 +++-- backend/doc/_index.html | 13 +- backend/doc/class_list.html | 2 +- backend/doc/file.README.html | 4 +- backend/doc/index.html | 4 +- backend/doc/method_list.html | 278 ++++++++------- backend/doc/top-level-namespace.html | 6 +- backend/spec/lib/information_spec.rb | 221 ++++++++++-- doc/log/Individual Log/steven_myers.md | 9 + doc/log/Individual Log/theresa_ngo.md | 26 ++ doc/log/Meeting Log/weekly_log.textile | 24 ++ .../web/app/controllers/editController.js | 5 +- .../web/app/controllers/submitController.js | 2 +- frontend/web/app/services/editService.js | 9 +- frontend/web/app/services/submitService.js | 6 +- frontend/web/app/views/submit.html | 28 +- 74 files changed, 1993 insertions(+), 689 deletions(-) create mode 100644 backend/doc/AdminsController.html create mode 100644 backend/doc/UserMailer.html diff --git a/README.md b/README.md index 9c0e1ef..0b5c6be 100644 --- a/README.md +++ b/README.md @@ -5,6 +5,10 @@ Relevant documentation can be found in the [wiki](https://github.com/401ChemistryGenealogy/ChemistryGenealogy/wiki). Don't forget to check the 'pages' section on the right. + +### E2E (End to end) Tests using Protractor: +https://github.com/401ChemistryGenealogy/ChemistryGenealogy/wiki/End-to-end-testing-using-Protractor!----A-Detailed-Guide-step-by-step-including-bugs + ### auto-generated docs These can be found [online](http://401chemistrygenealogy.github.io/) or in the [docs folder](https://github.com/401ChemistryGenealogy/ChemistryGenealogy/tree/master/backend/doc) diff --git a/backend/.yardoc/checksums b/backend/.yardoc/checksums index d8121cf..59a506a 100644 --- a/backend/.yardoc/checksums +++ b/backend/.yardoc/checksums @@ -1,48 +1,49 @@ -app/lib/search.rb 641aeb729fc6e5e1f4e9c317afc48f37b52f4a5a +app/lib/search.rb 8e3abf28f9a98d807ffb15948f3f2e1523852065 app/models/user.rb d3c9dedf945d625674077a30bf2f2cbb6409fdb1 +app/lib/deleter.rb 553d75b0f6a214d49c53967ffd31f7b190a0a4b4 app/lib/find_id.rb 61a4c30ea5f784c42491d1ee09d5fa3a300ac284 -app/lib/deleter.rb 35ea32167a4221c52c9149b7e3babebcef121db2 app/models/admin.rb 619c9860fd009f905a3c46c3d0d97d9fc7aa1e62 -app/lib/verifier.rb 7f1f2e80ef565f0cb6998c8eed710a288343da1b -app/lib/notifier.rb a9f713a84d8fa05b20e88ae7a514e041dfb08807 -app/models/degree.rb b997b7c6aa0433b8197e6a1c8dc8734f677339ed +app/lib/notifier.rb 923d38d8159a0d36074f722e5271a8694c2cb8cc +app/lib/verifier.rb 71dbc08b7a1a8599aeeb3d31442bffd97dacdac6 app/models/person.rb 02bf6a6a92f918964104359c94502aca19d6be90 +app/models/degree.rb b997b7c6aa0433b8197e6a1c8dc8734f677339ed app/models/mentor.rb d937e3fae7662242bb9d03879a8269cdd337940a app/models/postdoc.rb 16d732aae82cd9407c5610967ef5b747fd2ef923 app/lib/auth_token.rb 4fe2ba5cc707a564a5da3709e6f81bb30bf3b82f +app/lib/information.rb ee4604cb12400fb0a0705a0e8660d82898582807 app/lib/find_detail.rb 1edc0d8e0562c51fe0a3f92cbd5eb40e19d8e815 -app/lib/information.rb fc69764146c61f7a1dc9c946898255e43923c018 app/models/supervisor.rb 5e2529b6114b1edaf8316733a3ae2081a925c53b app/models/mentorship.rb 636669725c94485d83231f55e585b499f90166ce -app/lib/auto_complete.rb af4a0eee76a76a6cb7a6474bba1887e8f929d3cf +app/lib/auto_complete.rb 77e7d9cb2854a17aaeaa8667919f2c6280f172b9 +app/models/supervision.rb 237a0369fefdac62ad7ce20be912ae04c8865dfd app/models/institution.rb 8897f5c4178f7308577a15acd329adf5abf87530 app/models/audit_trail.rb 0ce06729b003a9150ee8f5d019beca55abdb6a66 -app/models/supervision.rb 237a0369fefdac62ad7ce20be912ae04c8865dfd -app/controllers/api_controller.rb 439079430f75c5ee36083463c9622caf5b76e1c0 -app/controllers/auth_controller.rb f87eda4c62d55a8316476802d6866b17a18bc78d -app/controllers/user_controller.rb 279c1a49fd694ecb8316dd4894720d3b6828f72c +app/mailers/user_mailer.rb 2ec80c9dcad50a29363f289f4d4c94b012ced0e4 +app/controllers/api_controller.rb 1f76bcbbf6a4c4f653a7c531518928586f4c70e0 app/serializers/user_serializer.rb 3e2275741192602828a96ed0bd399c2c4bc1f9f9 -app/controllers/admin_controller.rb c766d1575bf70d3e6cfe63f5a96cb6fed1f3649e +app/controllers/auth_controller.rb f87eda4c62d55a8316476802d6866b17a18bc78d +app/controllers/user_controller.rb bf75f031170458d43cd25d08179ae8eb1ebd25d0 app/serializers/admin_serializer.rb ade50ceaf1d63c7f528fc887300b4aff58bef003 -app/controllers/search_controller.rb 09f2930f31161dfabccd75bb32e1e23ac033eb5a -app/controllers/errors_controller.rb 2fde7d97e22d9e9a7655aa76cbefb06177d59aef app/serializers/search_serializer.rb 6dc86c5cbc82b9c3d7748349c14aee4d0f05b668 -app/controllers/api/people_controller.rb 5820c0f4ed3cd7afcd75494b2c15a54ce3acabd8 -app/controllers/api/admins_controller.rb b176a597dad8e26790c4373478e002f3460bd5e0 +app/controllers/errors_controller.rb 2fde7d97e22d9e9a7655aa76cbefb06177d59aef +app/controllers/admins_controller.rb 2d4abe358fe1a1dc2073f087862ed89cf7d9a46b +app/controllers/search_controller.rb 09f2930f31161dfabccd75bb32e1e23ac033eb5a app/serializers/api/degree_serializer.rb d4e18e8637dfa7d61372ef5a3e80a2221e1d9d1e app/serializers/api/person_serializer.rb 2bc7ff00c5442a3bae47499d04d3755001e807ed -app/controllers/application_controller.rb 50904503abc5d2481c22a8f0edda9c7ca90e8350 -app/controllers/api/degrees_controller.rb ad31dd8b09048fb7b4b9146c19af54adbb1f0a3f +app/controllers/api/admins_controller.rb b176a597dad8e26790c4373478e002f3460bd5e0 +app/controllers/api/people_controller.rb 5820c0f4ed3cd7afcd75494b2c15a54ce3acabd8 app/serializers/api/postdoc_serializer.rb 6ed5494af99bb1c2864452b842483fd598543a82 +app/controllers/application_controller.rb a68303f475cbdd49091729d5c33dc513e822b773 +app/controllers/api/degrees_controller.rb ad31dd8b09048fb7b4b9146c19af54adbb1f0a3f app/controllers/auto_complete_controller.rb 202d7df112dcf6125ebb8fdabac92fbdaeb6b35f -app/controllers/api/aggregated_controller.rb 76b6e25a492a2c7983d6e43da12ddc443e330216 -app/serializers/api/supervisor_serializer.rb 98a1de762611491b8e7047a980b1d3f066cc3992 app/serializers/api/mentorship_serializer.rb af6118d9abdbcba72206491b8e799d4260415c7a -app/controllers/api/mentorships_controller.rb f6432d45654930656cca8cc498534c5d7321c7c2 -app/controllers/api/audit_trail_controller.rb 946558ff78057781001760dec6b9ccbcb22412a2 +app/serializers/api/supervisor_serializer.rb 98a1de762611491b8e7047a980b1d3f066cc3992 +app/controllers/api/aggregated_controller.rb 20f5e954caed9502a22b0b369e3162941c21135c app/serializers/api/supervision_serializer.rb f0d83d20361f18a8f904a477c828a59d7fbb94b1 app/serializers/api/institution_serializer.rb 3c718fab8745eec7bbaaff7fda234dc2348fa82c -app/controllers/api/verification_controller.rb 30756a39440a5c2d39e3b6cd69df6aab979846a4 +app/controllers/api/mentorships_controller.rb f6432d45654930656cca8cc498534c5d7321c7c2 +app/controllers/api/audit_trail_controller.rb 946558ff78057781001760dec6b9ccbcb22412a2 app/controllers/api/supervisions_controller.rb 9b119c65b20ecfe893cc9002ff69cd7583e4d7c0 -app/controllers/api/institutions_controller.rb 6299bb48caef66a71d9580065d7d8f04439a80b1 app/controllers/api/notification_controller.rb b076b8eaff36609753c36128a2ece398de4db7db +app/controllers/api/institutions_controller.rb 6299bb48caef66a71d9580065d7d8f04439a80b1 +app/controllers/api/verification_controller.rb 30756a39440a5c2d39e3b6cd69df6aab979846a4 diff --git a/backend/.yardoc/object_types b/backend/.yardoc/object_types index c4244cea9aaef8b0128aa4b7ebca5110fcfc82bf..7ceb803c8ad6dd491bb4569a14284a633c0626b3 100644 GIT binary patch delta 501 zcmYjNzf0qA9Oc`jF-_7o)ixHZr?x6sX;E+}>Tty>mcyeUx`>owBaOyHlZZI@4~U5M zf#N0{IJjxSMF%J4@Hn`^!5h3ya8Mi^T!c$oi%y^SK0n|4JjedVx1~ZN9p)$GoH1Kq z2AGl2bl5d%$_6u7XG0++tFl#N{HUVk)A?$NOXe39t%}{>bxWC3YJKi0+4w~HjBJ>? zR$TTMccLv~TAS02#hj(+@6+D$+LUbN6t#Fegaq-yPa*+tS;n}XtgWq2E-6?gotPm} zoRAj05fT4L&{I)j4(pm_=&Fhf(uxsB0^N=pbmHibWI5HZ&^`nfH2 zv$>3MV2jx0+i=5A<4Wj4udqk@&?iWs-M?`uHlo|>tHhoF2UGl6dU1atwg(AcMWG~k UgQPU%JE!a~+~e8*gkMs}f1H`2^#A|> delta 456 zcmcbm_d$1pScbW$5_fQFVo`Din-!a@o2L?IXmM&0n>9O-$?cYzm*SZM;qbVm=A@Ru zq_`YYax?QFGQ44_MVV=tFezTY{1PNCw@YezQEKYMLXnA+v}E}~M!KYyBxdG7Gz)m< zrR5jpCYEI8=S{q6Gg+NcX|f2T5RZ^!L8fzlUP)1YPR`_NMx)7jjG}BJU|T28Wz?O_ z&m_Pv>RMEkUsMcNwwqCYaxs(4^5kG)k;#S3x|3s> z6(-+jww}C$S#fd$i^AkO7LLgZEJ~A8fY^yeYVraWF2?rBt64Tqe#e?HIfivIFW64y z#Nzm@;{3eHv)SivPGYlXoZP{oJK2IGVDeTDy~*mF5|bZuxJ$uKvj% zxvo!E;*p(vf?J+ZeeyvbvB_aPE|U-NOlMR9@i;S!;}bz)Xg@iS_chRJvB_EdJd^tb w*fxjoOE7MpA|S*#*^i%XavNAi2uxS;UD>=$a1Zn30I_G2qeS0LHWOC?0D?J@Gynhq diff --git a/backend/.yardoc/objects/root.dat b/backend/.yardoc/objects/root.dat index 1fb040f2ebd3fc1eb4faabf089eae8cd7b9b35d0..070db6fba895b31d7ccc357343118a32001a75dd 100644 GIT binary patch delta 22237 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 delta 17830 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

+E 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 String, Number}>] array of the person's postdoc information - # @param degree_array [Array String, Number}>] array of the person's degree information + # @param postdoc_array [Array String, Number}>] array of the person's personal postdoc information + # @param degree_array [Array String, Number}>] array of the person's personal degree information + # @param superdoc_array [Array String, Number}>] array of the person's supervised postdocs + # @param superdeg_array [Array String, Number}>] array of the person's supervised degrees # @return [Hash{String} => String, Number] created person in the database - def Information.submit_handling(name, position, institution_name, postdoc_array, degree_array) + def Information.submit_handling(name, position, institution_name, postdoc_array, degree_array, superdoc_array, superdeg_array) + person = Person.new_person(name.downcase, position, institution_name) - # Checks that the postdoc_array is not null before adding new mentorships - unless postdoc_array.nil? - postdoc_array.each do |postdoc| - Mentorship.new_mentorship(name.downcase, postdoc[:pdSupervisor], postdoc[:pdInstitution], - postdoc[:pdStartYear], postdoc[:pdEndYear]) + # Checks that the superdeg_array is not nil before adding the new person, degree, and supervisions as needed + unless superdeg_array.nil? + superdeg_array.each do |degree| + Person.new_person(degree[:superDegNameOfPerson], degree[:superDegCurrPosition], degree[:superDegCurrInst]) + Degree.new_degree(degree[:superDegYear], degree[:superDegDegType], degree[:superDegInst]) + Supervision.new_supervision(degree[:superDegYear], + degree[:superDegDegType], + degree[:superDegInst], + degree[:superDegNameOfPerson], + name) end end @@ -25,7 +33,26 @@ def Information.submit_handling(name, position, institution_name, postdoc_array, unless degree_array.nil? degree_array.each do |degree| Degree.new_degree(degree[:year], degree[:type], degree[:institution]) - Supervision.new_supervision(degree[:year], degree[:type], degree[:institution], name, degree[:supervisor]) + Supervision.new_supervision(degree[:year], degree[:type], degree[:institution], + name, degree[:supervisor]) + end + end + + + # Checks that the postdoc_array is not nil before adding new mentorships + unless postdoc_array.nil? + postdoc_array.each do |postdoc| + Mentorship.new_mentorship(name, postdoc[:pdSupervisor], postdoc[:pdInstitution], + postdoc[:pdStartYear], postdoc[:pdEndYear]) + end + end + + # Checks that the superdoc_array is not nil before adding the new mentorship + unless superdoc_array.nil? + superdoc_array.each do |postdoc| + Person.new_person(postdoc[:superDocNameOfPerson], nil, postdoc[:superDocInstitution]) + Mentorship.new_mentorship(postdoc[:superDocNameOfPerson], name, postdoc[:superDocInstitution], + postdoc[:superDocStartYear], postdoc[:superDocEndYear]) end end @@ -39,10 +66,12 @@ def Information.submit_handling(name, position, institution_name, postdoc_array, # @param name [String] name of the person # @param position [String] current position of the person # @param institution_name [String] current institution of the person - # @param postdoc_array [Array String, Number}>] array of the person's postdoc information - # @param degree_array [Array String, Number}>] array of the person's degree information + # @param postdoc_array [Array String, Number}>] array of the person's personal postdoc information + # @param degree_array [Array String, Number}>] array of the person's personal degree information + # @param superdoc_array [Array String, Number}>] array of the person's supervised postdocs + # @param superdeg_array [Array String, Number}>] array of the person's supervised degrees # @return [Hash{String => String}] updated person - def Information.update_handling(id, name, position, institution_name, postdoc_array, degree_array) + def Information.update_handling(id, name, position, institution_name, postdoc_array, degree_array, superdoc_array, superdeg_array) # Gets the person's information from the People table person_object = Person.find(id) @@ -74,7 +103,10 @@ def Information.update_handling(id, name, position, institution_name, postdoc_ar # Update postdocs and degrees respectively Mentorship.update_mentorship(id, name, postdoc_array) + Mentorship.update_superdoc(id, name, superdoc_array) Supervision.update_supervision(id, name, degree_array) + Supervision.update_superdeg(id, name, superdeg_array) + # Updates person_object (not sure if we need this) person_object = Person.find(id) diff --git a/backend/app/models/mentorship.rb b/backend/app/models/mentorship.rb index 78e53a9..7777558 100644 --- a/backend/app/models/mentorship.rb +++ b/backend/app/models/mentorship.rb @@ -32,130 +32,241 @@ def Mentorship.new_mentorship(person_name, mentor_name, institution_name, start_ end # Updates the mentorships connected to a person. - # @note Currently uses a quick-fix. Will hopefully update later. + # @note Since the postdocs themselves cannot be edited, this will only update the postdocs connected to a person # # @param id [Number] id of the person mentored # @param person_name [String] name of the person mentored # @param mentorship_array_received [Array String, Number}>] array of the person's postdoc information def Mentorship.update_mentorship(id, person_name, mentorship_array_received) + # Make an array of mentorship ids that are connected to the person in the database + mentorship_array = Array.new + mentorship_list = Mentorship.where(:person_id => id) + mentorship_list.each do |mentorship_single| + mentorship_array.push(mentorship_single.id) + end + + # Check that the mentorship array is not nil + unless mentorship_array.nil? + + # Check that the mentorship_array_received is not nil + unless mentorship_array_received.nil? + + # For each mentorship in the mentorship_array_received, + # see if it already exists in the database + # IF so, then the mentorship is present and can be removed from the mentorship_array + # as well as the mentorship_array_received + mentorship_array_received.each do |mentorship| + if mentorship.has_key?(:id) + mentorship_array.delete(mentorship[:id]) + mentorship_array_received.delete(mentorship) + end + end + + # The results left are ones that were either deleted or new + # Check if mentorship_array is not empty + unless mentorship_array.empty? + + # Check if the mentorship_array_received is not empty + unless mentorship_array_received.empty? + + # For each of the ids left in the array, update them with a new postdoc information + mentorship_array.each do |mentorship_id| + unless mentorship_array_received.empty? + new_mentorship = mentorship_array_received[0] + mentor_id = FindId.person(new_mentorship[:pdSupervisor]) + institution_id = FindId.institution(new_mentorship[:pdInstitution]) + Mentorship.update(mentorship_id, mentor_id: mentor_id) + Mentorship.update(mentorship_id, institution_id: institution_id) + Mentorship.update(mentorship_id, start: new_mentorship[:pdStartYear]) + Mentorship.update(mentorship_id, end: new_mentorship[:pdEndYear]) + + mentorship_array.delete(mentorship_id) + mentorship_array_received.delete(new_mentorship) + end + end + + # If there are any mentorships left in the mentorship_array, delete them + unless mentorship_array.empty? + mentorship_array.each do |mentorship_id| + Mentorship.delete(mentorship_id) + end + end + + # If there are any mentorships left in the mentorship_array_received, create them + unless mentorship_array_received.empty? + mentorship_array_received.each do |mentorship| + Mentorship.new_mentorship(person_name, + mentorship[:pdSupervisor], + mentorship[:pdInstitution], + mentorship[:pdStartYear], + mentorship[:pdEndYear]) + end + end + + # If the mentorship_array_received is empty, + # then the rest of the mentorships connected to the person are removed from the database + else + mentorship_array.each do |mentorship_id| + Mentorship.delete(mentorship_id) + end + end + # If it is empty, add remaining mentorships to the database + else + unless mentorship_array_received.empty? + mentorship_array_received.each do |mentorship| + Mentorship.new_mentorship(person_name, + mentorship[:pdSupervisor], + mentorship[:pdInstitution], + mentorship[:pdStartYear], + mentorship[:pdEndYear]) + end + end + end + + # If the mentorship_array_received is nil (or the person no longer has mentorships), + # then all mentorships connected to the person are removed from the database + else + mentorship_array.each do |mentorship_id| + Mentorship.delete(mentorship_id) + end + end + + # If mentorship_array is nil (or person has no mentorships), + # then if mentorship_array_received (or the mentorships received from edit page) + # is not nil, then add all of them to the table + # These should just be using the same format as a new postdoc + else + unless mentorship_array_received.nil? + mentorship_array_received.each do |mentorship| + Mentorship.new_mentorship(person_name, + mentorship[:pdSupervisor], + mentorship[:pdInstitution], + mentorship[:pdStartYear], + mentorship[:pdEndYear]) + end + end + end + end + + # Updates the mentorships that the person supervised. + # @note This could probably be combined with Mentorship.update_mentorship + # + # @param id [Number] id of the person mentored + # @param person_name [String] name of the person mentored + # @param mentorship_array_received [Array String, Number}>] array of the person's postdoc information + def Mentorship.update_superdoc(id, person_name, mentorship_array_received) + # Make an array of mentorship ids that are connected to the person in the database mentorship_array = Array.new - mentorship_list = Mentorship.where(:person_id => id) + mentorship_list = Mentorship.where(:mentor_id => id) mentorship_list.each do |mentorship_single| mentorship_array.push(mentorship_single.id) end - # Check that mentorship_array is not nil + # Check that the mentorship array is not nil unless mentorship_array.nil? - # Check that mentorship_array_received is not nil + # Check that the mentorship_array_received is not nil unless mentorship_array_received.nil? - # For each mentorship in the mentorship_array_received, see if it - # already exists in the database - # If it exists, don't do anything. If not, create it. + # For each mentorship in the mentorship_array_received, + # see if it already exists in the database + # IF so, then the mentorship is present and can be removed from the mentorship_array + # as well as the mentorship_array_received mentorship_array_received.each do |mentorship| - - # Reminder that this function will find or create a mentorship with - # the required attributes - mentorship_object = Mentorship.new_mentorship(person_name, - mentorship[:pdSupervisor], - mentorship[:pdInstitution], - mentorship[:pdStartYear], - mentorship[:pdEndYear]) - mentorship_id = mentorship_object.id - - # If the mentorship is in the mentorship_array, remove from the array - if mentorship_array.include? mentorship_id - mentorship_array.delete(mentorship_id) + if mentorship.has_key?(:id) + mentorship_array.delete(mentorship[:id]) + mentorship_array_received.delete(mentorship) end end - # If there's anything left in the mentorship_array after, remove them - unless mentorship_array.nil? - mentorship_array.each do |mentorship_id| - Mentorship.delete(mentorship_id) + # The results left are ones that were either deleted or new + # Check if mentorship_array is not empty + unless mentorship_array.empty? + + # Check if the mentorship_array_received is not empty + unless mentorship_array_received.empty? + + # For each of the ids left in the array, update them with a new postdoc information + mentorship_array.each do |mentorship_id| + unless mentorship_array_received.empty? + new_mentorship = mentorship_array_received[0] + mentored_id = FindId.person(new_mentorship[:superDocNameOfPerson]) + institution_id = FindId.institution(new_mentorship[:superDocInstitution]) + Mentorship.update(mentorship_id, person_id: mentored_id) + Mentorship.update(mentorship_id, institution_id: institution_id) + Mentorship.update(mentorship_id, start: new_mentorship[:superDocStartYear]) + Mentorship.update(mentorship_id, end: new_mentorship[:superDocEndYear]) + + mentorship_array.delete(mentorship_id) + mentorship_array_received.delete(new_mentorship) + end + end + + # If there are any mentorships left in the mentorship_array, delete them + unless mentorship_array.empty? + mentorship_array.each do |mentorship_id| + Mentorship.delete(mentorship_id) + end + end + + # If there are any mentorships left in the mentorship_array_received, create them + unless mentorship_array_received.empty? + mentorship_array_received.each do |mentorship| + Mentorship.new_mentorship(mentorship[:superDocNameOfPerson], + person_name, + mentorship[:superDocInstitution], + mentorship[:superDocStartYear], + mentorship[:superDocEndYear]) + end + end + + # If the mentorship_array_received is empty, + # then the rest of the mentorships connected to the person are removed from the database + else + mentorship_array.each do |mentorship_id| + Mentorship.delete(mentorship_id) + end + end + # If mentorship_array empty, add remaining mentorships to the database + else + unless mentorship_array_received.empty? + mentorship_array_received.each do |mentorship| + Mentorship.new_mentorship(mentorship[:superDocNameOfPerson], + person_name, + mentorship[:superDocInstitution], + mentorship[:superDocStartYear], + mentorship[:superDocEndYear]) + end end end - # If the mentorship_array_received is nil, remove all mentorships - # connected to the person + # If the mentorship_array_received is nil (or the person no longer has mentorships they supervised), + # then all mentorships connected to the person are removed from the database else mentorship_array.each do |mentorship_id| Mentorship.delete(mentorship_id) end end - # If mentorship_array is nil (or person has no mentorships), + # If mentorship_array is nil (or person has no mentorships they supervised), # then if mentorship_array_received (or the mentorships received from edit page) # is not nil, then add all of them to the table + # These should just be using the same format as a new postdoc else unless mentorship_array_received.nil? mentorship_array_received.each do |mentorship| - Mentorship.new_mentorship(person_name, - mentorship[:pdSupervisor], - mentorship[:pdInstitution], - mentorship[:pdStartYear], - mentorship[:pdEndYear]) + Mentorship.new_mentorship(mentorship[:superDocNameOfPerson], + person_name, + mentorship[:superDocInstitution], + mentorship[:superDocStartYear], + mentorship[:superDocEndYear]) end end end end - # # Check that mentorship_array is not nil - # unless mentorship_array.nil? - # - # # Check that mentorship_array_received is not nil - # unless mentorship_array_received.nil? - # - # # For each mentorship in the mentorship_array_received, see if it - # # already exists in the database - # # If it exists, update it. If not, create it. - # mentorship_array_received.each do |mentorship| - # - # # mentorship[:postdoc_id] should be set to nil if it is a new mentorship - # # Maybe this instead: if mentorship_array.include? mentorship[:postdoc_id] - # unless mentorship[:postdoc_id].nil? - # - # # Person_id should still stay the same. Everything else is updated. - # # *There's probably a nicer way of updating all info at once* - # mentor_id = FindId.person(mentorship[:pdSupervisor]) - # institution_id = FindId.institution(mentorship[:pdInstitution]) - # Mentorship.update(mentorship[:postdoc_id], mentor_id: mentor_id) - # Mentorship.update(mentorship[:postdoc_id], institution_id: institution_id) - # Mentorship.update(mentorship[:postdoc_id], start: mentorship[:pdStartYear]) - # Mentorship.update(mentorship[:postdoc_id], end: mentorship[:pdEndYear]) - # - # # Remove id from the mentorship_array - # mentorship_array.delete(mentorship[:postdoc_id]) - # - # # If the mentorship is not in the array, it is a new mentorship that - # # must be added (the mentorship[:postdoc_id] should be nil) - # else - # Mentorship.new_mentorship(person_name, - # mentorship[:pdSupervisor], - # mentorship[:pdInstitution], - # mentorship[:pdStartYear], - # mentorship[:pdEndYear]) - # end - # end - # - # # If there's anything left in the mentorship_array after, remove them - # unless mentorship_array.nil? - # mentorship_array.each do |mentorship_id| - # Mentorship.delete(mentorship_id) - # end - # end - # - # - # - # - # end - # end - # end - # end - # Makes a serialized postdoc to be sent to the frontend in a JSON format. # @note Could probably take id off if the frontend isn't using it # @@ -168,6 +279,7 @@ def serializer_for_mentorship(mentorship) result[:pdEndYear] = mentorship.end result[:pdSupervisor] = Person.find_by(id: mentorship.mentor_id).name result[:pdInstitution] = Institution.find_by(id: mentorship.institution_id).name + result[:pdSupervised] = Person.find_by(id: mentorship.person_id).name result = result.except(:id, :approved) result[:postdoc_id] = mentorship.id result[:postdoc_approved] = mentorship.approved diff --git a/backend/app/models/supervision.rb b/backend/app/models/supervision.rb index d714bd0..fcd5c16 100644 --- a/backend/app/models/supervision.rb +++ b/backend/app/models/supervision.rb @@ -33,7 +33,7 @@ def Supervision.new_supervision(degree_year, end # Updates the supervisions and degrees that the person has - # @note Currently uses a quick-fix. Will hopefully actually update later. + # @note Since the supervisions themselves cannot be edited, this will only update the supervisions connected to a person # # @param id [Number] id of the person # @param name [String] name of the person @@ -54,29 +54,75 @@ def Supervision.update_supervision(id, name, supervision_array_received) # Check that the supervision_array_received is not nil unless supervision_array_received.nil? - # For each supervision, see if it already exists in the database - # If not, create a new one + # For each supervision in the supervision_array_received, + # see if it already exists in the database + # If so, then the supervision is present and can be removed from the supervision_array + # as well as the supervision_array_received supervision_array_received.each do |supervision| - - # This function will find or create a supervision given the required - # attributes. It will also create a new degree if needed. - supervision_object = Supervision.new_supervision(supervision[:year], - supervision[:type], - supervision[:institution], - name, - supervision[:supervisor],) - supervision_id = supervision_object.id - - # If the supervision is in the supervision_array, remove from the array - if supervision_array.include? supervision_id - supervision_array.delete(supervision_id) + if supervision.has_key?(:id) + supervision_array.delete(supervision[:id]) + supervision_array_received.delete(supervision) end end - # If there are any supervisions left in supervision_array, delete them - unless supervision_array.nil? - supervision_array.each do |supervision_id| - Supervision.delete(supervision_id) + # The results left are ones that were either deleted or new + # Check if supervision_array is not empty + unless supervision_array.empty? + + # Check if the supervision_array_received is not empty + unless supervision_array_received.empty? + + # For each of the ids left in the array, update them with a new supervision information + supervision_array.each do |supervision_id| + unless supervision_array_received.empty? + new_supervision = supervision_array_received[0] + supervisor_id = FindId.person(new_supervision[:supervisor]) + degree_id = FindId.degree(new_supervision[:year], new_supervision[:type], new_supervision[:institution]) + Supervision.update(supervision_id, supervisor_id: supervisor_id) + Supervision.update(supervision_id, degree_id: degree_id) + + supervision_array.delete(supervision_id) + supervision_array_received.delete(new_supervision) + end + end + + # If there are any supervisions left in the supervision_array, delete them + unless supervision_array.empty? + supervision_array.each do |supervision_id| + Supervision.delete(supervision_id) + end + end + + # If there are any supervisions left in the supervision_array_received, create them + unless supervision_array_received.empty? + supervision_array_received.each do |supervision| + Degree.new_degree(supervision[:year], supervision[:type], supervision[:institution]) + Supervision.new_supervision(supervision[:year], + supervision[:type], + supervision[:institution], + name, + supervision[:supervisor]) + end + end + + # If the supervision_array_received is empty, + # then the rest of the supervisions connected to the person are removed from the database + else + supervision_array.each do |supervision_id| + Supervision.delete(supervision_id) + end + end + # If supervision_array is empty, add remaining supervisions to the database + else + unless supervision_array_received.empty? + supervision_array_received.each do |supervision| + Degree.new_degree(supervision[:year], supervision[:type], supervision[:institution]) + Supervision.new_supervision(supervision[:year], + supervision[:type], + supervision[:institution], + name, + supervision[:supervisor]) + end end end @@ -91,8 +137,6 @@ def Supervision.update_supervision(id, name, supervision_array_received) # If there are no supervisions connected to the person, create new # supervisions and degrees for the person as long as supervision_array_received # is not nil either - # In this case, degree_id, degree_approved, supervision_id, and supervision_approved - # are all nil else unless supervision_array_received.nil? supervision_array_received.each do |supervision| @@ -105,56 +149,142 @@ def Supervision.update_supervision(id, name, supervision_array_received) end end end + end + + # Updates the supervisions and degrees that the person has supervised + # @note @note This could probably be combined with Supervision.update_supervision + # + # @param id [Number] id of the person + # @param name [String] name of the person + # @param supervision_array_received [Array String, Number}>] array of supervisions that the person has supervised + def Supervision.update_superdeg(id, name, supervision_array_received) + + # Creates an array of supervision ids that are connected to the person in + # the database + supervision_array = Array.new + supervision_find = Supervision.where(:supervisor_id => id) + supervision_find.each do |single| + supervision_array.push(single.id) + end + + # Check that supervision_array is not nil + unless supervision_array.nil? - # # For each supervision in the supervision_array_received, check if it - # # exists in the supervision_array. - # # If so, then update. If not, create a new supervision and degree - # supervision_array_received.each do |supervision| - # - # # If the supervision is new, then the supervision[:supervision_id] - # # should be nil - # # Maybe this as well: if supervision_array.include? supervision[:supervision_id] - # unless supervision[:supervision_id].nil? - # - # # Check if the supervisor has changed. If so, then get new id. - # # Gets the supervision object and the supervisor person object - # # from the database to compare - # # See if there's a matching supervisor in the database and update - # # if it's not the same - # supervisor_id = FindId.person(supervision[:supervisor]) - # supervision_object = Supervision.find(supervision[:supervision_id]) - # if supervision_object.person_id != supervisor_id - # Supervision.update(supervision[:supervision_id], supervisor_id: supervisor_id) - # end - # - # # Find or create the degree id from the database - # # If it is not the same as supervision[:degree_id], then update - # # supervision with the new id - # # * Since multiple people may have the same degree, it may be best - # # not to update the degree in the database * - # degree_id = FindId.degree(supervision[:year], - # supervision[:type], - # supervision[:institution]) - # if degree_id != supervision[:degree_id] - # Supervision.update(supervision[:supervision_id], degree_id: degree_id) - # end - # - # # Remove id from the supervision_array - # supervision_array.delete(supervision[:supervision_id]) - # - # # If the supervision[:supervision_id] is nil, then it is new so create - # # a new supervision and degree - # else - # Degree.new_degree(supervision[:year], supervision[:type], supervision[:institution]) - # Supervision.new_supervision(supervision[:year], - # supervision[:type], - # supervision[:institution], - # name, - # supervision[:supervisor]) - # end - # end + # Check that the supervision_array_received is not nil + unless supervision_array_received.nil? + # For each supervision in the supervision_array_received, + # see if it already exists in the database + # If so, then the supervision is present and can be removed from the supervision_array + # as well as the supervision_array_received + supervision_array_received.each do |supervision| + if supervision.has_key?(:id) + supervision_array.delete(supervision[:id]) + supervision_array_received.delete(supervision) + end + end + # The results left are ones that were either deleted or new + # Check if supervision_array is not empty + unless supervision_array.empty? + + # Check if the supervision_array_received is not empty + unless supervision_array_received.empty? + + # For each of the ids left in the array, update them with a new supervision information + supervision_array.each do |supervision_id| + unless supervision_array_received.empty? + new_supervision = supervision_array_received[0] + supervised_id = FindId.person(new_supervision[:superDegNameOfPerson]) + degree_id = FindId.degree(new_supervision[:superDegYear], + new_supervision[:superDegDegType], + new_supervision[:superDegInst]) + Supervision.update(supervision_id, person_id: supervised_id) + Supervision.update(supervision_id, degree_id: degree_id) + + supervision_array.delete(supervision_id) + supervision_array_received.delete(new_supervision) + end + end + + # If there are any supervisions left in the supervision_array, delete them + unless supervision_array.empty? + supervision_array.each do |supervision_id| + Supervision.delete(supervision_id) + end + end + + # If there are any supervisions left in the supervision_array_received, create them + unless supervision_array_received.empty? + supervision_array_received.each do |supervision| + Person.new_person(supervision[:superDegNameOfPerson], + supervision[:superDegCurrPosition], + supervision[:superDegCurrInst]) + Degree.new_degree(supervision[:superDegYear], + supervision[:superDegDegType], + supervision[:superDegInst]) + Supervision.new_supervision(supervision[:superDegYear], + supervision[:superDegDegType], + supervision[:superDegInst], + supervision[:superDegNameOfPerson], + name) + end + end + + # If the supervision_array_received is empty, + # then the rest of the supervisions connected to the person are removed from the database + else + supervision_array.each do |supervision_id| + Supervision.delete(supervision_id) + end + end + # If it is empty, add remaining supervisions to the database + else + unless supervision_array_received.empty? + supervision_array_received.each do |supervision| + Person.new_person(supervision[:superDegNameOfPerson], + supervision[:superDegCurrPosition], + supervision[:superDegCurrInst]) + Degree.new_degree(supervision[:superDegYear], + supervision[:superDegDegType], + supervision[:superDegInst]) + Supervision.new_supervision(supervision[:superDegYear], + supervision[:superDegDegType], + supervision[:superDegInst], + supervision[:superDegNameOfPerson], + name) + end + end + end + + # If the supervision_array_received is nil (person has no degrees/supervisions) + # Then delete all supervisions in the supervision_array + else + supervision_array.each do |supervision_id| + Supervision.delete(supervision_id) + end + end + + # If there are no supervisions connected to the person, create new + # supervisions and degrees for the person as long as supervision_array_received + # is not nil either + else + unless supervision_array_received.nil? + supervision_array_received.each do |supervision| + Person.new_person(supervision[:superDegNameOfPerson], + supervision[:superDegCurrPosition], + supervision[:superDegCurrInst]) + Degree.new_degree(supervision[:superDegYear], + supervision[:superDegDegType], + supervision[:superDegInst]) + Supervision.new_supervision(supervision[:superDegYear], + supervision[:superDegDegType], + supervision[:superDegInst], + supervision[:superDegNameOfPerson], + name) + end + end + end end # Makes a serialized supervision with degree information to be sent to the frontend in a JSON format. @@ -167,9 +297,10 @@ def serializer_for_supervision(supervision) degree = Degree.find_by(id: degree_id) result[:year] = degree.year - result[:supervisor] = Person.find_by(:id => supervision.supervisor_id).name + result[:supervisor] = Person.find_by(id: supervision.supervisor_id).name result[:institution] = Institution.find_by(id: degree.institution_id).name result[:type] = degree.degree_type + result[:supervised] = Person.find_by(id: supervision.person_id).name result[:degree_id] = degree.id result[:degree_approved] = degree.approved diff --git a/backend/doc/AccessDeniedError.html b/backend/doc/AccessDeniedError.html index 007de02..ba0185d 100644 --- a/backend/doc/AccessDeniedError.html +++ b/backend/doc/AccessDeniedError.html @@ -114,9 +114,9 @@

diff --git a/backend/doc/Admin.html b/backend/doc/Admin.html index f817d77..d78a839 100644 --- a/backend/doc/Admin.html +++ b/backend/doc/Admin.html @@ -183,9 +183,9 @@

diff --git a/backend/doc/AdminSerializer.html b/backend/doc/AdminSerializer.html index d0d02cb..fed5282 100644 --- a/backend/doc/AdminSerializer.html +++ b/backend/doc/AdminSerializer.html @@ -114,9 +114,9 @@ diff --git a/backend/doc/AdminsController.html b/backend/doc/AdminsController.html new file mode 100644 index 0000000..fbf60e2 --- /dev/null +++ b/backend/doc/AdminsController.html @@ -0,0 +1,297 @@ + + + + + + Class: AdminsController + + — Documentation by YARD 0.8.7.6 + + + + + + + + + + + + + + + + + + + + + +

Class: AdminsController + + + +

+ +
+ +
Inherits:
+
+ ApplicationController + + + show all + +
+ + + + + + + + + +
Defined in:
+
app/controllers/admins_controller.rb
+ +
+
+ + + + + + + +

Instance Attribute Summary

+ +

Attributes inherited from ApplicationController

+

#current_user

+ + + +

+ Instance Method Summary + (collapse) +

+ + + + + + + + + + + + + +
+

Instance Method Details

+ + +
+

+ + - (Object) create + + + + + +

+ + + + +
+
+
+
+17
+18
+19
+20
+21
+22
+23
+24
+25
+26
+27
+28
+
+
# File 'app/controllers/admins_controller.rb', line 17
+
+def create
+  if params.has_key?(:user_id)
+    if User.exists?('id' => params[:user_id])
+      @admin = Admin.create(user_id: params[:user_id], approved: true)
+      render json: {created_admin: @admin}, status: 200
+      return
+    end
+    render json: {error: 'user does not exist'}, status:  :bad_request
+    return
+  end
+  render json: {error: 'user does not exist'}, status: :bad_request
+end
+
+
+ +
+

+ + - (Object) index + + + + + +

+ + + + +
+
+
+
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15
+
+
# File 'app/controllers/admins_controller.rb', line 2
+
+def index
+  @admins = Admin.where('approved' => true)
+            .includes(:user)
+
+  @response_array = Array.new
+  @admins.each do |a|
+    @response_hash = {
+      'data' => a,
+      'user' => a.user
+    }
+    @response_array.push(@response_hash)
+  end
+  render json: @response_array.to_json, status: 200
+end
+
+
+ +
+ +
+ + + + + \ No newline at end of file diff --git a/backend/doc/Api/AdminsController.html b/backend/doc/Api/AdminsController.html index 0602b13..6752d6e 100644 --- a/backend/doc/Api/AdminsController.html +++ b/backend/doc/Api/AdminsController.html @@ -495,9 +495,9 @@

diff --git a/backend/doc/Api/AggregatedController.html b/backend/doc/Api/AggregatedController.html index b64b721..a2dbb0d 100644 --- a/backend/doc/Api/AggregatedController.html +++ b/backend/doc/Api/AggregatedController.html @@ -354,18 +354,18 @@

 
 
-34
-35
-36
-37
 38
 39
 40
 41
-42
+42 +43 +44 +45 +46 -
# File 'app/controllers/api/aggregated_controller.rb', line 34
+      
# File 'app/controllers/api/aggregated_controller.rb', line 38
 
 def create
   Rails.logger.info(params)
@@ -396,12 +396,12 @@ 

 
 
-57
-58
-59
+61 +62 +63

-
# File 'app/controllers/api/aggregated_controller.rb', line 57
+      
# File 'app/controllers/api/aggregated_controller.rb', line 61
 
 def destroy
 	render json: {warning: 'not implemented'}, status: 200
@@ -426,12 +426,12 @@ 

 
 
-29
-30
-31
+33 +34 +35

-
# File 'app/controllers/api/aggregated_controller.rb', line 29
+      
# File 'app/controllers/api/aggregated_controller.rb', line 33
 
 def edit
   render json: {warning: 'not implemented'}, status: 200
@@ -498,12 +498,12 @@ 

 
 
-25
-26
-27
+29 +30 +31

-
# File 'app/controllers/api/aggregated_controller.rb', line 25
+      
# File 'app/controllers/api/aggregated_controller.rb', line 29
 
 def new
   render json: {warning: 'not implemented'}, status: 200
@@ -528,12 +528,12 @@ 

 
 
-61
-62
-63
+65 +66 +67

-
# File 'app/controllers/api/aggregated_controller.rb', line 61
+      
# File 'app/controllers/api/aggregated_controller.rb', line 65
 
 def notify_admin
   render json: {warning: 'not implemented'}, status: 200
@@ -585,16 +585,24 @@ 

20 21 22 -23

+23 +24 +25 +26 +27
# File 'app/controllers/api/aggregated_controller.rb', line 15
 
 def show
-  if params.has_key?(:id)
-    @person = Search.person(params[:id])
+  Rails.logger.info(params)
+  if params.has_key?(:id) && params.has_key?(:approved)
+    @person = Search.person(params[:id], params[:approved])
+    render :json => @person.to_json
+  elsif params.has_key?(:id)
+    @person = Search.person(params[:id], nil)
     render :json => @person.to_json
-  elsif
+  else
     render json: {warning: 'expected id param'}, status: 200
   end
 
@@ -631,19 +639,19 @@ 

 
 
-46
-47
-48
-49
 50
 51
 52
 53
 54
-55
+55 +56 +57 +58 +59

-
# File 'app/controllers/api/aggregated_controller.rb', line 46
+      
# File 'app/controllers/api/aggregated_controller.rb', line 50
 
 def update
   Rails.logger.info(params)
@@ -665,9 +673,9 @@ 

diff --git a/backend/doc/Api/AuditTrailController.html b/backend/doc/Api/AuditTrailController.html index 5fe5fe3..546410f 100644 --- a/backend/doc/Api/AuditTrailController.html +++ b/backend/doc/Api/AuditTrailController.html @@ -417,9 +417,9 @@

diff --git a/backend/doc/Api/DegreeSerializer.html b/backend/doc/Api/DegreeSerializer.html index bb964d6..ee9e133 100644 --- a/backend/doc/Api/DegreeSerializer.html +++ b/backend/doc/Api/DegreeSerializer.html @@ -125,9 +125,9 @@

Overview

diff --git a/backend/doc/Api/DegreesController.html b/backend/doc/Api/DegreesController.html index 732ba0b..2ed0279 100644 --- a/backend/doc/Api/DegreesController.html +++ b/backend/doc/Api/DegreesController.html @@ -552,9 +552,9 @@

diff --git a/backend/doc/Api/InstitutionSerializer.html b/backend/doc/Api/InstitutionSerializer.html index d7eeec0..e7a1de5 100644 --- a/backend/doc/Api/InstitutionSerializer.html +++ b/backend/doc/Api/InstitutionSerializer.html @@ -125,9 +125,9 @@

Overview

diff --git a/backend/doc/Api/InstitutionsController.html b/backend/doc/Api/InstitutionsController.html index 48abdc4..093df59 100644 --- a/backend/doc/Api/InstitutionsController.html +++ b/backend/doc/Api/InstitutionsController.html @@ -540,9 +540,9 @@

diff --git a/backend/doc/Api/MentorshipSerializer.html b/backend/doc/Api/MentorshipSerializer.html index be83c9e..ceba03d 100644 --- a/backend/doc/Api/MentorshipSerializer.html +++ b/backend/doc/Api/MentorshipSerializer.html @@ -125,9 +125,9 @@

Overview

diff --git a/backend/doc/Api/MentorshipsController.html b/backend/doc/Api/MentorshipsController.html index f3030ba..d1a3079 100644 --- a/backend/doc/Api/MentorshipsController.html +++ b/backend/doc/Api/MentorshipsController.html @@ -552,9 +552,9 @@

diff --git a/backend/doc/Api/NotificationController.html b/backend/doc/Api/NotificationController.html index 7c5389b..8a7a035 100644 --- a/backend/doc/Api/NotificationController.html +++ b/backend/doc/Api/NotificationController.html @@ -214,9 +214,9 @@

diff --git a/backend/doc/Api/PeopleController.html b/backend/doc/Api/PeopleController.html index 7ac009a..6578e56 100644 --- a/backend/doc/Api/PeopleController.html +++ b/backend/doc/Api/PeopleController.html @@ -558,9 +558,9 @@

diff --git a/backend/doc/Api/PersonSerializer.html b/backend/doc/Api/PersonSerializer.html index 2548ff3..e673323 100644 --- a/backend/doc/Api/PersonSerializer.html +++ b/backend/doc/Api/PersonSerializer.html @@ -125,9 +125,9 @@

Overview

diff --git a/backend/doc/Api/PostdocSerializer.html b/backend/doc/Api/PostdocSerializer.html index 8143160..709cadd 100644 --- a/backend/doc/Api/PostdocSerializer.html +++ b/backend/doc/Api/PostdocSerializer.html @@ -125,9 +125,9 @@

Overview

diff --git a/backend/doc/Api/SupervisionSerializer.html b/backend/doc/Api/SupervisionSerializer.html index d6b96a6..71b4243 100644 --- a/backend/doc/Api/SupervisionSerializer.html +++ b/backend/doc/Api/SupervisionSerializer.html @@ -127,9 +127,9 @@

Overview

diff --git a/backend/doc/Api/SupervisionsController.html b/backend/doc/Api/SupervisionsController.html index b73ead8..d0c5ccf 100644 --- a/backend/doc/Api/SupervisionsController.html +++ b/backend/doc/Api/SupervisionsController.html @@ -562,9 +562,9 @@

diff --git a/backend/doc/Api/VerificationController.html b/backend/doc/Api/VerificationController.html index e57a4c0..9301e1e 100644 --- a/backend/doc/Api/VerificationController.html +++ b/backend/doc/Api/VerificationController.html @@ -640,9 +640,9 @@

diff --git a/backend/doc/ApiController.html b/backend/doc/ApiController.html index e43bebc..01f58a5 100644 --- a/backend/doc/ApiController.html +++ b/backend/doc/ApiController.html @@ -159,9 +159,9 @@

Attributes inherited from diff --git a/backend/doc/ApplicationController.html b/backend/doc/ApplicationController.html index 44a899d..0414633 100644 --- a/backend/doc/ApplicationController.html +++ b/backend/doc/ApplicationController.html @@ -130,7 +130,7 @@

Overview

@@ -227,9 +227,9 @@

diff --git a/backend/doc/AuditTrail.html b/backend/doc/AuditTrail.html index 3a1c6f8..667d065 100644 --- a/backend/doc/AuditTrail.html +++ b/backend/doc/AuditTrail.html @@ -114,9 +114,9 @@ diff --git a/backend/doc/AuthController.html b/backend/doc/AuthController.html index 90fc29b..c7fa2f0 100644 --- a/backend/doc/AuthController.html +++ b/backend/doc/AuthController.html @@ -234,9 +234,9 @@

diff --git a/backend/doc/AuthToken.html b/backend/doc/AuthToken.html index 7d2e575..ecc34d4 100644 --- a/backend/doc/AuthToken.html +++ b/backend/doc/AuthToken.html @@ -302,9 +302,9 @@

diff --git a/backend/doc/AuthenticationTimeoutError.html b/backend/doc/AuthenticationTimeoutError.html index b49b671..45e4b33 100644 --- a/backend/doc/AuthenticationTimeoutError.html +++ b/backend/doc/AuthenticationTimeoutError.html @@ -114,9 +114,9 @@ diff --git a/backend/doc/AutoComplete.html b/backend/doc/AutoComplete.html index b3c9ee2..5d35e97 100644 --- a/backend/doc/AutoComplete.html +++ b/backend/doc/AutoComplete.html @@ -212,14 +212,14 @@

 
 
-15
-16
 17
 18
-19
+19 +20 +21

-
# File 'app/lib/auto_complete.rb', line 15
+      
# File 'app/lib/auto_complete.rb', line 17
 
 def self.find_institutions(institution)
   @institution = "%#{institution}%".downcase
@@ -251,14 +251,18 @@ 

10 11 12 -13

+13 +14 +15
# File 'app/lib/auto_complete.rb', line 8
 
 def self.find_names(name)
   @name = "%#{name}%".downcase
-  @response = Person.where("name LIKE ?", @name).includes(:institution)
+  @response = Person.where("name LIKE ?", @name)
+                    .where('approved' => true)
+                    .includes(:institution)
   @institutions = Set.new
   return @response
 end
@@ -272,9 +276,9 @@

diff --git a/backend/doc/AutoCompleteController.html b/backend/doc/AutoCompleteController.html index f88da7f..d08f644 100644 --- a/backend/doc/AutoCompleteController.html +++ b/backend/doc/AutoCompleteController.html @@ -218,9 +218,9 @@

diff --git a/backend/doc/Degree.html b/backend/doc/Degree.html index d3c59d6..528b4fd 100644 --- a/backend/doc/Degree.html +++ b/backend/doc/Degree.html @@ -371,9 +371,9 @@

diff --git a/backend/doc/Deleter.html b/backend/doc/Deleter.html index 5279d1b..1050e2b 100644 --- a/backend/doc/Deleter.html +++ b/backend/doc/Deleter.html @@ -405,7 +405,7 @@

# File 'app/lib/deleter.rb', line 49
 
 def self.delete_person(person_id)
-  @person = Search.person_info(person_id)
+  @person = Search.person_info(person_id, false)
 
   @person["person"].mentorships.each do |m|
     m.destroy
@@ -518,9 +518,9 @@ 

diff --git a/backend/doc/ErrorsController.html b/backend/doc/ErrorsController.html index 10e3e68..b010f89 100644 --- a/backend/doc/ErrorsController.html +++ b/backend/doc/ErrorsController.html @@ -224,9 +224,9 @@

diff --git a/backend/doc/FindDetail.html b/backend/doc/FindDetail.html index 5fa8bc6..3719dd9 100644 --- a/backend/doc/FindDetail.html +++ b/backend/doc/FindDetail.html @@ -318,9 +318,9 @@

diff --git a/backend/doc/FindId.html b/backend/doc/FindId.html index cec2d3e..47aa7fa 100644 --- a/backend/doc/FindId.html +++ b/backend/doc/FindId.html @@ -648,9 +648,9 @@

diff --git a/backend/doc/Information.html b/backend/doc/Information.html index 60d1813..72ac095 100644 --- a/backend/doc/Information.html +++ b/backend/doc/Information.html @@ -344,12 +344,12 @@

# File 'app/lib/information.rb', line 13
 
 def Information.submit_handling(name, position, institution_name, postdoc_array, degree_array)
-  person = Person.new_person(name, position, institution_name)
+  person = Person.new_person(name.downcase, position, institution_name)
 
   # Checks that the postdoc_array is not null before adding new mentorships
   unless postdoc_array.nil?
     postdoc_array.each do |postdoc|
-      Mentorship.new_mentorship(name, postdoc[:pdSupervisor], postdoc[:pdInstitution],
+      Mentorship.new_mentorship(name.downcase, postdoc[:pdSupervisor], postdoc[:pdInstitution],
         postdoc[:pdStartYear], postdoc[:pdEndYear])
     end
   end
@@ -572,7 +572,7 @@ 

# Checks if the name is the same. If not, change it. unless name.nil? if person_object.name != name - Person.update(id, name: name) + Person.update(id, name: name.downcase) end end @@ -611,9 +611,9 @@

diff --git a/backend/doc/Institution.html b/backend/doc/Institution.html index 5c7a0c8..031e203 100644 --- a/backend/doc/Institution.html +++ b/backend/doc/Institution.html @@ -333,9 +333,9 @@

diff --git a/backend/doc/Mentor.html b/backend/doc/Mentor.html index 60826d4..112f45e 100644 --- a/backend/doc/Mentor.html +++ b/backend/doc/Mentor.html @@ -125,9 +125,9 @@

Overview

diff --git a/backend/doc/Mentorship.html b/backend/doc/Mentorship.html index e74104c..36289dd 100644 --- a/backend/doc/Mentorship.html +++ b/backend/doc/Mentorship.html @@ -791,9 +791,9 @@

diff --git a/backend/doc/NotAuthenticatedError.html b/backend/doc/NotAuthenticatedError.html index 7fa3f33..0bfa4d2 100644 --- a/backend/doc/NotAuthenticatedError.html +++ b/backend/doc/NotAuthenticatedError.html @@ -114,9 +114,9 @@ diff --git a/backend/doc/Notifier.html b/backend/doc/Notifier.html index 861a5e3..d88d2bd 100644 --- a/backend/doc/Notifier.html +++ b/backend/doc/Notifier.html @@ -422,6 +422,7 @@

 
 
+28
 29
 30
 31
@@ -436,11 +437,10 @@ 

40 41 42 -43 -44

+43

-
# File 'app/lib/notifier.rb', line 29
+      
# File 'app/lib/notifier.rb', line 28
 
 def self.admin_notifications
   @unapproved_admins = Admin.where({:approved => false})
@@ -489,6 +489,7 @@ 

 
 
+6
 7
 8
 9
@@ -496,11 +497,10 @@ 

11 12 13 -14 -15

+14

-
# File 'app/lib/notifier.rb', line 7
+      
# File 'app/lib/notifier.rb', line 6
 
 def self.all_notifications
   return {
@@ -673,6 +673,7 @@ 

 
 
+79
 80
 81
 82
@@ -698,11 +699,10 @@ 

102 103 104 -105 -106

+105

-
# File 'app/lib/notifier.rb', line 80
+      
# File 'app/lib/notifier.rb', line 79
 
 def self.mentorship_notifications
   @unapproved_mentorships = Mentorship.where({:approved => false})
@@ -750,7 +750,7 @@ 

this method will bundle all relationships + information w.r.t. an unapproved person. This reflects a person that was just added to the -database.

+database. TODO: refactor and fold with Search.person_info

@@ -978,6 +978,7 @@

 
 
+47
 48
 49
 50
@@ -1005,11 +1006,10 @@ 

72 73 74 -75 -76

+75

-
# File 'app/lib/notifier.rb', line 48
+      
# File 'app/lib/notifier.rb', line 47
 
 def self.supervision_notifications
   @unapproved_supervisions = Supervision.where({:approved => false})
@@ -1145,6 +1145,7 @@ 

 
 
+17
 18
 19
 20
@@ -1152,11 +1153,10 @@ 

22 23 24 -25 -26

+25

-
# File 'app/lib/notifier.rb', line 18
+      
# File 'app/lib/notifier.rb', line 17
 
 def self.user_notifications
   @unapproved_users = User.where({:approved => false})
@@ -1177,9 +1177,9 @@ 

diff --git a/backend/doc/Person.html b/backend/doc/Person.html index d4ae7b2..bd0188b 100644 --- a/backend/doc/Person.html +++ b/backend/doc/Person.html @@ -554,9 +554,9 @@

diff --git a/backend/doc/Postdoc.html b/backend/doc/Postdoc.html index adf9a62..d0b27d2 100644 --- a/backend/doc/Postdoc.html +++ b/backend/doc/Postdoc.html @@ -125,9 +125,9 @@

Overview

diff --git a/backend/doc/Search.html b/backend/doc/Search.html index 2b7480e..e88998e 100644 --- a/backend/doc/Search.html +++ b/backend/doc/Search.html @@ -149,7 +149,7 @@

  • - + (Object) person(id) + + (Object) person(id, approved) @@ -259,7 +259,7 @@

    Class Method Details

    - + (Object) person(id) + + (Object) person(id, approved) @@ -270,8 +270,7 @@

    this class is different from relations_by_id, because it not only gathers the relations, but also the information required to “fill” out these -relations. used to detail or “view” a person on the frontend. TODO: take -out the begining of the function and call self.person_info instead.

    +relations. used to detail or “view” a person on the frontend.

    @@ -285,13 +284,6 @@

     
     
    -109
    -110
    -111
    -112
    -113
    -114
    -115
     116
     117
     118
    @@ -382,101 +374,222 @@ 

    203 204 205 -206

    +206 +207 +208 +209 +210 +211 +212 +213 +214 +215 +216 +217 +218 +219 +220 +221 +222 +223 +224 +225 +226 +227 +228 +229 +230 +231 +232 +233 +234 +235 +236 +237 +238 +239 +240 +241 +242 +243 +244 +245 +246 +247 +248 +249 +250 +251 +252 +253 +254 +255 +256 +257 +258 +259 +260 +261 +262 +263 +264 +265 +266 +267 +268 +269 +270

  • -
    # File 'app/lib/search.rb', line 109
    +      
    # File 'app/lib/search.rb', line 116
     
    -def self.person(id)
    +def self.person(id, approved)
       unless Person.exists?(id) then return nil end
    +  @person_info = self.person_info(id)
    +  if @person_info["person"] == nil
    +    return nil
    +  end
     
    -  @person = Person.includes(:institution)
    -            .includes( {mentorships: [:institution, {mentor: [:institution]}] })
    -            .includes( {supervisions: [ {degree:  [:institution] }, {supervisor: [:institution]}] })
    -            .where(:id => id).first
    -
    -  @mentored = Mentorship.where(:mentor_id => id)
    -              .includes(:institution)
    -              .includes(person: :institution)
    -
    -  @supervised = Supervision.where(:supervisor_id => id)
    -                .includes(degree: :institution)
    -                .includes(person: :institution)
    -
    +  # be warned: the following nested if-elsif statements are ugly as sin
    +  # but i'm experiencing a bug and don't have time for elegance
    +
    +  # TODO: the problem is that the approved value is a string and not a boolean
    +  # so, write a helper method that returns true/false depending on the value
    +  # of the string and then use the returned boolean value to query database
    +  # instead of these nested if/elsif blocks of nasty
    +
       @mentorships_array = Array.new
    -  unless @person.mentorships.blank?
    -    @person.mentorships.each do |m|
    -      @mentorship = {
    -        'id' => m.id,
    -        'start' => m.start,
    -        'end' => m.end,
    -        'institution' => m.institution,
    -        'mentor' => {
    -          'data' => m.mentor,
    -          'institution' => m.mentor.institution
    +  unless @person_info["person"].mentorships.blank?
    +    @person_info["person"].mentorships.each do |m|
    +      if m.approved && approved == 'true'
    +        @mentorship = {
    +          'id' => m.id,
    +          'start' => m.start,
    +          'end' => m.end,
    +          'institution' => m.institution,
    +          'mentor' => {
    +            'data' => m.mentor,
    +            'institution' => m.mentor.institution
    +          }
    +        }
    +        @mentorships_array.push(@mentorship)
    +      elsif approved == 'false'
    +        @mentorship = {
    +          'id' => m.id,
    +          'start' => m.start,
    +          'end' => m.end,
    +          'institution' => m.institution,
    +          'mentor' => {
    +            'data' => m.mentor,
    +            'institution' => m.mentor.institution
    +          }
             }
    -      }
    -      @mentorships_array.push(@mentorship)
    +        @mentorships_array.push(@mentorship)
    +      end
         end
       end
     
       @supervision_array = Array.new
    -  unless @person.supervisions.blank?
    -    @person.supervisions.each do |s|
    -      @supervision = {
    -        'id' => s.id,
    -        'degree' => {
    -          'data' => s.degree,
    -          'institution' => s.degree.institution
    -        },
    -        'supervisor' => {
    -          'person' => s.supervisor,
    -          'institution' => s.supervisor.institution
    +  unless @person_info["person"].supervisions.blank?
    +     @person_info["person"].supervisions.each do |s|
    +      if s.approved && approved == 'true'
    +        @supervision = {
    +          'id' => s.id,
    +          'degree' => {
    +            'data' => s.degree,
    +            'institution' => s.degree.institution
    +          },
    +          'supervisor' => {
    +            'person' => s.supervisor,
    +            'institution' => s.supervisor.institution
    +          }
             }
    -      }
    -      @supervision_array.push(@supervision)
    +        @supervision_array.push(@supervision)
    +      elsif approved == 'false'
    +        @supervision = {
    +          'id' => s.id,
    +          'degree' => {
    +            'data' => s.degree,
    +            'institution' => s.degree.institution
    +          },
    +          'supervisor' => {
    +            'person' => s.supervisor,
    +            'institution' => s.supervisor.institution
    +          }
    +        }
    +        @supervision_array.push(@supervision)
    +      end
         end
       end
     
       @mentored_array = Array.new
    -  unless @mentored.blank?
    -    @mentored.each do |m|
    -      @mentored_obj = {
    -        'id' => m.id,
    -        'start' => m.start,
    -        'end' => m.end,
    -        'institution' => m.institution,
    -        'mentored' => {
    -          'person' => m.person,
    -          'institution' => m.person.institution
    +  unless @person_info["mentored"].blank?
    +    @person_info["mentored"].each do |m|
    +      if m.approved && approved == 'true'
    +        @mentored_obj = {
    +          'id' => m.id,
    +          'start' => m.start,
    +          'end' => m.end,
    +          'institution' => m.institution,
    +          'mentored' => {
    +            'person' => m.person,
    +            'institution' => m.person.institution
    +            }
               }
    -        }
    -      @mentored_array.push(@mentored_obj)
    +        @mentored_array.push(@mentored_obj)
    +      elsif approved == 'false'
    +        @mentored_obj = {
    +          'id' => m.id,
    +          'start' => m.start,
    +          'end' => m.end,
    +          'institution' => m.institution,
    +          'mentored' => {
    +            'person' => m.person,
    +            'institution' => m.person.institution
    +            }
    +          }
    +        @mentored_array.push(@mentored_obj)
    +      end
         end
       end
     
       @supervised_array = Array.new
    -  unless @supervised.blank?
    -    @supervised.each do |s|
    -      @supervised_obj = {
    -        'id' => s.id,
    -        'degree' => {
    -          'data' => s.degree,
    -          'institution' => s.degree.institution
    -        },
    -        'person' => {
    -          'data' => s.person,
    -          'institution' => s.person.institution
    +  unless @person_info["supervised"].blank?
    +    @person_info["supervised"].each do |s|
    +      if s.approved && approved == 'true'
    +        @supervised_obj = {
    +          'id' => s.id,
    +          'degree' => {
    +            'data' => s.degree,
    +            'institution' => s.degree.institution
    +          },
    +          'person' => {
    +            'data' => s.person,
    +            'institution' => s.person.institution
    +          }
             }
    -      }
    -      @supervised_array.push(@supervised_obj)
    +        @supervised_array.push(@supervised_obj)
    +      elsif approved == 'false'
    +        @supervised_obj = {
    +          'id' => s.id,
    +          'degree' => {
    +            'data' => s.degree,
    +            'institution' => s.degree.institution
    +          },
    +          'person' => {
    +            'data' => s.person,
    +            'institution' => s.person.institution
    +          }
    +        }
    +        @supervised_array.push(@supervised_obj)
    +      end
         end
       end
     
       @data = {
         'person' => {
    -      'data' => @person,
    -      'institution' => @person.institution
    +      'data' => @person_info["person"],
    +      'institution' => @person_info["person"].institution
         },
         'mentors' => @mentorships_array,
         'mentored' => @mentored_array,
    @@ -503,7 +616,8 @@ 

    this function was extracted from self.person(id) and is called by Notifier -and Deleter. It is used to retrieve the relationships w.r.t

    +and Deleter. It is used to retrieve the relationships w.r.t if approved == +nil then we will gather all information, good for notifications

    @@ -550,15 +664,6 @@

     
     
    -82
    -83
    -84
    -85
    -86
    -87
    -88
    -89
    -90
     91
     92
     93
    @@ -571,14 +676,21 @@ 

    100 101 102 -103

    +103 +104 +105 +106 +107 +108 +109 +110 +111

    -
    # File 'app/lib/search.rb', line 82
    +      
    # File 'app/lib/search.rb', line 91
     
     def self.person_info(id)
       unless Person.exists?(id) then return nil end
    -
       @person = Person.includes(:institution)
                 .includes( {mentorships: [:institution, {mentor: [:institution]}] })
                 .includes( {supervisions: [ {degree:  [:institution] }, {supervisor: [:institution]}] })
    @@ -616,8 +728,8 @@ 

    returns a hash that contains the relations to a person and the -person/institution records. it is used in conjunction with autocomplete on -the frontend, and it is likely that this class can be optimized TODO: +person/institution records. it is used in conjunction with search on the +frontend, and it is likely that this class can be optimized TODO: investigate optimizations

    @@ -683,7 +795,15 @@

    73 74 75 -76

    +76 +77 +78 +79 +80 +81 +82 +83 +84
    # File 'app/lib/search.rb', line 25
    @@ -706,23 +826,31 @@ 

    end @mentors = Person.joins('LEFT OUTER JOIN mentorships ON mentorships.mentor_id = people.id') - .where('mentorships.person_id' => person_id).where('approved' => true) + .where('mentorships.person_id' => person_id) + .where('approved' => true) + .where('mentorships.approved' => true) .includes(:institution) unless @mentors.blank? then @persons.add(@mentors) end @mentored = Person.joins(:mentorships) - .where('mentorships.mentor_id' => person_id).where('approved' => true) + .where('mentorships.mentor_id' => person_id) + .where('approved' => true) + .where('mentorships.approved' => true) .includes(:institution) unless @mentored.blank? then @persons.add(@mentored) end @supervisors = Person.joins('LEFT OUTER JOIN supervisions ON supervisions.supervisor_id = people.id') - .where('supervisions.person_id' => person_id).where('approved' => true) + .where('supervisions.person_id' => person_id) + .where('approved' => true) + .where('supervisions.approved' => true) .includes(:institution) unless @supervisors.blank? then @persons.add(@supervisors) end @supervised = Person.joins(:supervisions) - .where('supervisions.supervisor_id' => person_id).where('approved' => true) + .where('supervisions.supervisor_id' => person_id) + .where('approved' => true) + .where('supervisions.approved' => true) .includes(:institution) unless @supervised.blank? then @persons.add(@supervised) end @@ -800,9 +928,9 @@

    diff --git a/backend/doc/SearchController.html b/backend/doc/SearchController.html index 4371bba..b9c0c53 100644 --- a/backend/doc/SearchController.html +++ b/backend/doc/SearchController.html @@ -243,9 +243,9 @@

    diff --git a/backend/doc/SearchSerializer.html b/backend/doc/SearchSerializer.html index 5938c81..9fbcfc5 100644 --- a/backend/doc/SearchSerializer.html +++ b/backend/doc/SearchSerializer.html @@ -114,9 +114,9 @@ diff --git a/backend/doc/Supervision.html b/backend/doc/Supervision.html index 6c24c50..f2dfdb9 100644 --- a/backend/doc/Supervision.html +++ b/backend/doc/Supervision.html @@ -909,9 +909,9 @@

    diff --git a/backend/doc/Supervisor.html b/backend/doc/Supervisor.html index 2370133..84efc15 100644 --- a/backend/doc/Supervisor.html +++ b/backend/doc/Supervisor.html @@ -125,9 +125,9 @@

    Overview

    diff --git a/backend/doc/User.html b/backend/doc/User.html index 6c202ef..877e2e6 100644 --- a/backend/doc/User.html +++ b/backend/doc/User.html @@ -331,9 +331,9 @@

    diff --git a/backend/doc/UserController.html b/backend/doc/UserController.html index d5ccf22..610e04f 100644 --- a/backend/doc/UserController.html +++ b/backend/doc/UserController.html @@ -213,7 +213,9 @@

    -
    +
    +

    TODO: make less sloppy (joins etc).

    +
    @@ -304,24 +306,24 @@

     
     
    -12
    -13
    -14
    -15
    -16
    -17
    -18
    -19
     20
     21
     22
     23
     24
     25
    -26
    +26 +27 +28 +29 +30 +31 +32 +33 +34

    -
    # File 'app/controllers/user_controller.rb', line 12
    +      
    # File 'app/controllers/user_controller.rb', line 20
     
     def create
       Rails.logger.info(params)
    @@ -358,15 +360,33 @@ 

     
     
    -36
    -37
    -38
    +44 +45 +46 +47 +48 +49 +50 +51 +52 +53 +54 +55

    -
    # File 'app/controllers/user_controller.rb', line 36
    +      
    # File 'app/controllers/user_controller.rb', line 44
     
     def destroy
    -  render json: {warning: 'not implemented'}, status: 200
    +  if params.has_key?(:id)
    +    if User.exists?('id' => params[:id])
    +      User.find(params[:id]).destroy
    +      render json: {user_destroyed: params[:id]}, status: 200
    +      return
    +    end
    +    render json: {user_not_exist: params[:id]}, status: 200
    +  else
    +    render json: {error: 'insufficient params'}, status: :bad_request
    +  end
     end
    @@ -382,21 +402,46 @@

    -

    +
    +
    + +

    TODO: make less sloppy (joins etc)

    + + +
    +
    +
    + + +
    @@ -418,12 +463,12 @@

     
     
    -28
    -29
    -30
    +36 +37 +38

     
     
    -6
     7
    -8
    +8 +9 +10 +11 +12 +13 +14 +15 +16
    -
    # File 'app/controllers/user_controller.rb', line 6
    +      
    # File 'app/controllers/user_controller.rb', line 7
     
     def index
    -  render json: {warning: 'not implemented'}, status: 200
    +  @admins = Admin.where('approved' => true)
    +  @user_ids = Array.new
    +  @admins.each do |a|
    +    @user_ids.push(a.user_id)
    +  end
    +  @users = User.where('approved' => true)
    +           .where.not('id' => @user_ids)
    +  render json: @users, status: 200
     end
    -
    # File 'app/controllers/user_controller.rb', line 28
    +      
    # File 'app/controllers/user_controller.rb', line 36
     
     def show
       render json: {warning: 'not implemented'}, status: 200
    @@ -448,12 +493,12 @@ 

     
     
    -32
    -33
    -34
    +40 +41 +42

    -
    # File 'app/controllers/user_controller.rb', line 32
    +      
    # File 'app/controllers/user_controller.rb', line 40
     
     def update
       render json: {warning: 'not implemented'}, status: 200
    @@ -468,9 +513,9 @@ 

    diff --git a/backend/doc/UserMailer.html b/backend/doc/UserMailer.html new file mode 100644 index 0000000..6cbb429 --- /dev/null +++ b/backend/doc/UserMailer.html @@ -0,0 +1,239 @@ + + + + + + Class: UserMailer + + — Documentation by YARD 0.8.7.6 + + + + + + + + + + + + + + + + + + + + + +

    Class: UserMailer + + + +

    + +
    + +
    Inherits:
    +
    + ActionMailer::Base + +
      +
    • Object
    • + + + + + +
    + show all + +
    + + + + + + + + + +
    Defined in:
    +
    app/mailers/user_mailer.rb
    + +
    +
    + +

    Overview

    +
    + +

    This mailer is used to notify a user that registered that their account has +been approved. NOTE: this is not fully implemented due to lack of +requirment, so you should view this as a starting point for extending the +application.

    + + +
    +
    +
    + +

    Author:

    +
      + +
    • + + + + + +
      +

      Steven Myers

      +
      + +
    • + +
    + +
    + + + + + + + +

    + Class Method Summary + (collapse) +

    + +
      + +
    • + + + + (Object) notify_user(user) + + + + + + + + + + + + + +
      +

      the view for this email is textual and it should be extended to have a link +to the site in the email.

      +
      + +
    • + + +
    + + + + + +
    +

    Class Method Details

    + + +
    +

    + + + (Object) notify_user(user) + + + + + +

    +
    + +

    the view for this email is textual and it should be extended to have a link +to the site in the email. view: /app/views/user_mailer/notify_user.text.erb

    + + +
    +
    +
    + + +
    + + + + +
    +
    +
    +
    +12
    +13
    +14
    +15
    +
    +
    # File 'app/mailers/user_mailer.rb', line 12
    +
    +def self.notify_user(user)
    +  @user = user
    +  mail(to: @user.email, subject: 'Chemistry Geneology registration')
    +end
    +
    +
    + +
    + +
    + + + + + \ No newline at end of file diff --git a/backend/doc/UserSerializer.html b/backend/doc/UserSerializer.html index 337d64e..d7d68f1 100644 --- a/backend/doc/UserSerializer.html +++ b/backend/doc/UserSerializer.html @@ -114,9 +114,9 @@ diff --git a/backend/doc/Verifier.html b/backend/doc/Verifier.html index 94dc358..c3137a0 100644 --- a/backend/doc/Verifier.html +++ b/backend/doc/Verifier.html @@ -159,7 +159,9 @@

    -
    +
    +

    verifies an admin by their id.

    +
    @@ -252,7 +254,7 @@

    -

    yeah it does what you think.

    +

    verifies a user by their id.

    @@ -276,13 +278,23 @@

    -

    +
    +
    + +

    verifies an admin by their id

    + + +
    +
    +
    + + +
     
     
    -18
     19
     20
     21
    @@ -290,15 +302,20 @@ 

    23 24 25 -26

    +26 +27 +28 +29
    -
    # File 'app/lib/verifier.rb', line 18
    +      
    # File 'app/lib/verifier.rb', line 19
     
     def self.verify_admin(admin_id)
       @admin = Admin.find_by_id(admin_id)
       @admin.approved = true
    -  if @admin.save
    +  @user = User.find_by_id(@admin.user_id)
    +  @user.approved = true
    +  if @admin.save && @user.save
         return {'admin' => @admin}
       else
         return nil
    @@ -324,9 +341,6 @@ 

     
     
    -28
    -29
    -30
     31
     32
     33
    @@ -342,10 +356,13 @@ 

    43 44 45 -46

    +46 +47 +48 +49

    -
    # File 'app/lib/verifier.rb', line 28
    +      
    # File 'app/lib/verifier.rb', line 31
     
     def self.verify_mentorship(mentorship_id)
       @mentorship = Mentorship.includes(:institution)
    @@ -401,9 +418,6 @@ 

     
     
    -80
    -81
    -82
     83
     84
     85
    @@ -464,16 +478,29 @@ 

    140 141 142 -143

    +143 +144 +145 +146 +147 +148 +149 +150 +151

    -
    # File 'app/lib/verifier.rb', line 80
    +      
    # File 'app/lib/verifier.rb', line 83
     
     def self.verify_person(person_id)
    -  @person = Search.person_info(person_id)
    +  # false because we're using the search function to find unapproved person
    +  # information. False is handed to the :approved key in the where clause
    +  # for Search.person_info(id, approved)
    +  @person = Search.person_info(person_id)
     
       if @person["person"].approved == false
         @person["person"].approved = true
    +    #search/autocomplete is performed assuming all lower cases in name
    +    @person["person"].name = @person["person"].name.downcase
         @person["person"].save
       end
       if @person["person"].institution.approved == false
    @@ -553,9 +580,6 @@ 

     
     
    -48
    -49
    -50
     51
     52
     53
    @@ -578,10 +602,13 @@ 

    70 71 72 -73

    +73 +74 +75 +76

    -
    # File 'app/lib/verifier.rb', line 48
    +      
    # File 'app/lib/verifier.rb', line 51
     
     def self.verify_supervision(supervision_id)
       @supervision = Supervision.includes(degree: :institution)
    @@ -626,7 +653,7 @@ 

    -

    yeah it does what you think

    +

    verifies a user by their id

    @@ -674,9 +701,9 @@

    diff --git a/backend/doc/_index.html b/backend/doc/_index.html index 1852469..dd04865 100644 --- a/backend/doc/_index.html +++ b/backend/doc/_index.html @@ -95,12 +95,12 @@

    Namespace Listing A-Z

  • - AdminController + AdminSerializer
  • - AdminSerializer + AdminsController
  • @@ -424,6 +424,11 @@

    Namespace Listing A-Z

    +
  • + UserMailer + +
  • +
  • UserSerializer @@ -461,9 +466,9 @@

    Namespace Listing A-Z

    diff --git a/backend/doc/class_list.html b/backend/doc/class_list.html index f5ed8c2..353b5f7 100644 --- a/backend/doc/class_list.html +++ b/backend/doc/class_list.html @@ -50,7 +50,7 @@

    Class List

    diff --git a/backend/doc/file.README.html b/backend/doc/file.README.html index 869ba66..ce0abbd 100644 --- a/backend/doc/file.README.html +++ b/backend/doc/file.README.html @@ -87,9 +87,9 @@

    futher documentation

    diff --git a/backend/doc/index.html b/backend/doc/index.html index 869ba66..ce0abbd 100644 --- a/backend/doc/index.html +++ b/backend/doc/index.html @@ -87,9 +87,9 @@

    futher documentation

    diff --git a/backend/doc/method_list.html b/backend/doc/method_list.html index 63bb11d..6219b83 100644 --- a/backend/doc/method_list.html +++ b/backend/doc/method_list.html @@ -76,14 +76,14 @@

    Method List

  • - #as_json - Degree + #as_json + Person
  • - #as_json - Person + #as_json + Degree
  • @@ -94,14 +94,14 @@

    Method List

  • - #as_json - Institution + #as_json + Supervision
  • - #as_json - Supervision + #as_json + Institution
  • @@ -118,44 +118,44 @@

    Method List

  • - #create - Api::InstitutionsController + #create + AdminsController
  • - #create - Api::SupervisionsController + #create + Api::VerificationController
  • - #create - Api::VerificationController + #create + Api::InstitutionsController
  • - #create - Api::MentorshipsController + #create + Api::SupervisionsController
  • - #create - Api::AggregatedController + #create + Api::MentorshipsController
  • - #create - Api::DegreesController + #create + Api::AggregatedController
  • - #create - Api::AdminsController + #create + Api::DegreesController
  • @@ -166,59 +166,71 @@

    Method List

  • + #create + Api::AdminsController +
  • + + +
  • #current_user ApplicationController
  • -
  • +
  • decode AuthToken
  • -
  • +
  • degree FindId
  • -
  • +
  • delete_admin Deleter
  • -
  • +
  • delete_mentorship Deleter
  • -
  • +
  • delete_person Deleter
  • -
  • +
  • delete_supervision Deleter
  • -
  • +
  • delete_user Deleter
  • -
  • +
  • #destroy UserController
  • +
  • + #destroy + Api::VerificationController +
  • + +
  • #destroy Api::InstitutionsController @@ -232,29 +244,29 @@

    Method List

  • - #destroy - Api::VerificationController -
  • - - -
  • #destroy Api::MentorshipsController
  • -
  • +
  • #destroy Api::AggregatedController
  • -
  • +
  • #destroy Api::DegreesController
  • +
  • + #destroy + Api::PeopleController +
  • + +
  • #destroy Api::AdminsController @@ -262,8 +274,8 @@

    Method List

  • - #destroy - Api::PeopleController + #edit + Api::VerificationController
  • @@ -280,35 +292,23 @@

    Method List

  • - #edit - Api::VerificationController -
  • - - -
  • #edit Api::MentorshipsController
  • -
  • +
  • #edit Api::AggregatedController
  • -
  • +
  • #edit Api::DegreesController
  • -
  • - #edit - Api::AdminsController -
  • - -
  • #edit Api::PeopleController @@ -316,35 +316,47 @@

    Method List

  • + #edit + Api::AdminsController +
  • + + +
  • encode AuthToken
  • -
  • +
  • find_by_credentials User
  • -
  • +
  • find_institutions AutoComplete
  • -
  • +
  • find_names AutoComplete
  • -
  • +
  • #index UserController
  • +
  • + #index + AdminsController +
  • + +
  • #index SearchController @@ -358,8 +370,8 @@

    Method List

  • - #index - Api::NotificationController + #index + Api::VerificationController
  • @@ -370,14 +382,14 @@

    Method List

  • - #index - Api::SupervisionsController + #index + Api::NotificationController
  • - #index - Api::VerificationController + #index + Api::SupervisionsController
  • @@ -406,14 +418,14 @@

    Method List

  • - #index - Api::AdminsController + #index + Api::PeopleController
  • - #index - Api::PeopleController + #index + Api::AdminsController
  • @@ -448,20 +460,20 @@

    Method List

  • - #new - Api::InstitutionsController + #new + Api::VerificationController
  • - #new - Api::SupervisionsController + #new + Api::InstitutionsController
  • - #new - Api::VerificationController + #new + Api::SupervisionsController
  • @@ -484,14 +496,14 @@

    Method List

  • - #new - Api::AdminsController + #new + Api::PeopleController
  • - #new - Api::PeopleController + #new + Api::AdminsController
  • @@ -538,77 +550,89 @@

    Method List

  • + notify_user + UserMailer +
  • + + +
  • person Search
  • -
  • +
  • person FindId
  • -
  • +
  • person FindDetail
  • -
  • +
  • person_info Search
  • -
  • +
  • person_notifications Notifier
  • -
  • +
  • relations_by_id Search
  • -
  • +
  • relations_by_name Search
  • -
  • +
  • #routing ErrorsController
  • -
  • +
  • #serializer_for_mentorship Mentorship
  • -
  • +
  • #serializer_for_person Person
  • -
  • +
  • #serializer_for_supervision Supervision
  • -
  • +
  • #show UserController
  • +
  • + #show + Api::VerificationController +
  • + +
  • #show Api::InstitutionsController @@ -622,41 +646,29 @@

    Method List

  • - #show - Api::VerificationController -
  • - - -
  • #show Api::AuditTrailController
  • -
  • +
  • #show Api::MentorshipsController
  • -
  • +
  • #show Api::AggregatedController
  • -
  • +
  • #show Api::DegreesController
  • -
  • - #show - Api::AdminsController -
  • - -
  • #show Api::PeopleController @@ -664,35 +676,47 @@

    Method List

  • + #show + Api::AdminsController +
  • + + +
  • submit_handling Information
  • -
  • +
  • supervised Notifier
  • -
  • +
  • supervision_notifications Notifier
  • -
  • +
  • supervisors Notifier
  • -
  • +
  • #update UserController
  • +
  • + #update + Api::VerificationController +
  • + +
  • #update Api::InstitutionsController @@ -706,35 +730,23 @@

    Method List

  • - #update - Api::VerificationController -
  • - - -
  • #update Api::MentorshipsController
  • -
  • +
  • #update Api::AggregatedController
  • -
  • +
  • #update Api::DegreesController
  • -
  • - #update - Api::AdminsController -
  • - -
  • #update Api::PeopleController @@ -742,54 +754,60 @@

    Method List

  • + #update + Api::AdminsController +
  • + + +
  • update_handling Information
  • -
  • +
  • update_mentorship Mentorship
  • -
  • +
  • update_supervision Supervision
  • -
  • +
  • user_notifications Notifier
  • -
  • +
  • verify_admin Verifier
  • -
  • +
  • verify_mentorship Verifier
  • -
  • +
  • verify_person Verifier
  • -
  • +
  • verify_supervision Verifier
  • -
  • +
  • verify_user Verifier
  • diff --git a/backend/doc/top-level-namespace.html b/backend/doc/top-level-namespace.html index 61408d0..1f8dd03 100644 --- a/backend/doc/top-level-namespace.html +++ b/backend/doc/top-level-namespace.html @@ -87,7 +87,7 @@

    Defined Under Namespace

    - Classes: AccessDeniedError, Admin, AdminController, AdminSerializer, ApiController, ApplicationController, AuditTrail, AuthController, AuthToken, AuthenticationTimeoutError, AutoComplete, AutoCompleteController, Degree, Deleter, ErrorsController, FindDetail, FindId, Information, Institution, Mentor, Mentorship, NotAuthenticatedError, Notifier, Person, Postdoc, Search, SearchController, SearchSerializer, Supervision, Supervisor, User, UserController, UserSerializer, Verifier + Classes: AccessDeniedError, Admin, AdminSerializer, AdminsController, ApiController, ApplicationController, AuditTrail, AuthController, AuthToken, AuthenticationTimeoutError, AutoComplete, AutoCompleteController, Degree, Deleter, ErrorsController, FindDetail, FindId, Information, Institution, Mentor, Mentorship, NotAuthenticatedError, Notifier, Person, Postdoc, Search, SearchController, SearchSerializer, Supervision, Supervisor, User, UserController, UserMailer, UserSerializer, Verifier

    @@ -103,9 +103,9 @@

    Defined Under Namespace

    diff --git a/backend/spec/lib/information_spec.rb b/backend/spec/lib/information_spec.rb index 6b60be3..a201cc7 100644 --- a/backend/spec/lib/information_spec.rb +++ b/backend/spec/lib/information_spec.rb @@ -11,10 +11,10 @@ # actually this test will pass, because because an ActiveRecord will never # be equal to a number. http://guides.rubyonrails.org/active_record_querying.html - expect(@person.find_by_name("Ji Hwan Kim")).not_to eql(1) + expect(@person.find_by_name("Ji Hwan Kim")).to eql(nil) @person.new_person("Ji Hwan Kim", "Doctorate", "University of Alberta") # check if the person got created in db - expect(@person.find_by_name("Ji Hwan Kim")).not_to eql(0) + expect(@person.where(name: "Ji Hwan Kim")).not_to eql(nil) end end @@ -24,11 +24,11 @@ end it 'creates a new institution to db' do - # this test will fail since the new name doesn't exist in db yet - expect(@institution.find_by_name("University A")).not_to eql(1) + # this test will pass since the new name doesn't exist in db yet + expect(@institution.find_by_name("University A")).to eql(nil) @institution.new_institution("University A") # check if the person got created in db - expect(@institution.find_by_name("University A")).not_to eql(0) + expect(@institution.where(name: "University A")).not_to eql(nil) end end @@ -36,17 +36,18 @@ before do @person = Person @mentorship = Mentorship + @mentorshipLast = Mentorship.last end it 'creates a new mentorship to db' do - # this test will fail since there is only 10 ids in the person db - expect(@person.find_by_id(11)).not_to eql(1) - # this test will fail since there is only 6 ids in the mentorship db - expect(@mentorship.find_by_id(7)).not_to eql(1) - @mentorship.new_mentorship("Ji Hwan Kim", "Mentor A", "University of Alberta", "2014", "2016") + # this test will pass since there is no person with name Mentee A + expect(@person.find_by_name("Mentee A")).to eql(nil) + @mId = (@mentorshipLast.id) + 1 + expect(@mentorship.find_by_id(@mId)).to eql(nil) + @mentorship.new_mentorship("Mentee A", "Mentor A", "University of Alberta", "2014", "2016") # check if the person and mentorship got created in db - expect(@person.find_by_id(11)).not_to eql(0) - expect(@mentorship.find_by_id(7)).not_to eql(0) + expect(@person.where(name: "Mentee A")).not_to eql(nil) + expect(@mentorship.where(id: @mId)).not_to eql(nil) end end @@ -54,29 +55,209 @@ before do @person = Person @supervision = Supervision + @supervisionLast = Supervision.last end it 'creates a new supervision to db' do - # this test should fail as there are only 4 supervisions in db - expect(@person.find_by_id(11)).not_to eql(1) - expect(@supervision.find_by_id(5)).not_to eql(1) - @supervision.new_supervision("2016", "Doctorate", "University of Alberta", "Ji Hwan Kim", "Supervisor A") + # this test should pass as there is no person named Doctor A + expect(@person.find_by_name("Doctor A")).to eql(nil) + @sId = (@supervisionLast.id) + 1 + expect(@supervision.find_by_id(@sId)).to eql(nil) + @supervision.new_supervision("2016", "Doctorate", "University of Alberta", "Doctor A", "Supervisor A") # check if the supervision got created in db - expect(@supervision.find_by_id(5)) - expect(@person.find_by_id(11)).not_to eql(0) + expect(@supervision.where(id: @sId)).not_to eql(nil) + # check if the person got created in db + expect(@person.where(name: "Doctor A")).not_to eql(nil) end end describe Degree, '.new_degree' do before do @degree = Degree + @degreeLast = Degree.last end it 'creates a new degree to db' do # this test should fail as there are only 4 degrees in db - expect(@degree.find_by_id(5)).not_to eql(1) + @dId = (@degreeLast.id) + 1 + expect(@degree.find_by_id(@dId)).to eql(nil) @degree.new_degree("2016", "Doctorate", "University of Alberta") # check if the supervision got created in db - expect(@degree.find_by_id(5)).not_to eql(0) + expect(@degree.where(id: @dId)).not_to eql(nil) + end +end + +describe Person, '.edit_Person_Information' do + before do + @personFirst = Person.first + end + + it 'edits an existing person information' do + # this test will test for edtiting information + + # test for edit name + # I want to change the name to Ji Hwan Kim, first check if it is not equal to Ji Hwan Kim + # first check if the parameter is not nil + expect(@personFirst.name).to_not eql(nil) + + expect(@personFirst.name).to_not eql("Ji Hwan Kim") + @personFirst.update(name: "Ji Hwan Kim") + expect(@personFirst.name).to eql("Ji Hwan Kim") + + # test for edit position + # check if param is not nil + expect(@personFirst.position).not_to eql(nil) + + expect(@personFirst.position).to_not eql("Postition A") + @personFirst.update(position: "Position A") + expect(@personFirst.position).to eql("Position A") + end +end + +describe Degree, '.edit_Degree_Information' do + before do + @degreeFirst = Degree.first + end + + it 'edits an existing degree information' do + # this test will test for edtiting information + + # test for edit name + # I want to change the name to Ji Hwan Kim, first check if it is not equal to Ji Hwan Kim + # first check if the parameter is not nil + expect(@degreeFirst.degree_type).to_not eql(nil) + + expect(@degreeFirst.degree_type).to_not eql("Degree A") + @degreeFirst.update(degree_type: "Degree A") + expect(@degreeFirst.degree_type).to eql("Degree A") + + # test for edit degree year + # check if param is not nil + expect(@degreeFirst.year).not_to eql(nil) + + expect(@degreeFirst.year).to_not eql(2016) + @degreeFirst.update(year: 2016) + expect(@degreeFirst.year).to eql(2016) + end +end + +describe Institution, '.edit_Institution_Information' do + before do + @institutionFirst = Institution.first + end + + it 'edits an existing institution information' do + # test for editing institution information + # first check if param is not nil + expect(@institutionFirst.name).to_not eql(nil) + + expect(@institutionFirst.name).to_not eql("University A") + @institutionFirst.update(name: "University A") + expect(@institutionFirst.name).to eql("University A") + end +end + +describe Mentorship, '.edit_Mentorship_Information' do + before do + @mentorshipFirst = Mentorship.first + @person = Person + end + + it 'edits an existing mentorship information' do + # test for editing mentorship information + # first check if param is not nil + @mId = @mentorshipFirst.mentor_id + expect(@mId).to_not eql(nil) + + @mentor = @person.find_by_id(@mId) + + expect(@mentor.name).to_not eql("Mentor A") + @mentor.update(name: "Mentor A") + expect(@mentor.name).to eql("Mentor A") + end +end + +describe Supervision, '.edit_Supervision_Information' do + before do + @supervisionFirst = Supervision.first + @person = Person + end + + it 'edits an exsiting supervision information' do + # test for editing supervision information + # first check if param is not nil + @sId = @supervisionFirst.supervisor_id + expect(@sId).to_not eql(nil) + + @supervisor = @person.find_by_id(@sId) + + expect(@supervisor.name).to_not eql("Supervisor A") + @supervisor.update(name: "Supervisor A") + expect(@supervisor.name).to eql("Supervisor A") end end + +describe Person, '.check_Admin_Approval' do + before do + @personLast = Person.last + end + + it '.checks the admin approval' do + # test for checking admin approval + expect(@personLast.approved).to eql(true) + @personLast.update(approved: false) + expect(@personLast.approved).to eql(false) + end +end + +describe Institution, '.check_Admin_Approval' do + before do + @institutionLast = Institution.last + end + + it '.checks the admin approval' do + # test for checking admin approval + expect(@institutionLast.approved).to eql(false) + @institutionLast.update(approved: true) + expect(@institutionLast.approved).to eql(true) + end +end + +describe Mentorship, '.check_Admin_Approval' do + before do + @mentorshipLast = Mentorship.last + end + + it '.checks the admin approval' do + # test for checking admin approval + expect(@mentorshipLast.approved).to eql(false) + @mentorshipLast.update(approved: true) + expect(@mentorshipLast.approved).to eql(true) + end +end + +describe Supervision, '.check_Admin_Approval' do + before do + @supervisionLast = Supervision.last + end + + it '.checks the admin approval' do + # test for checking admin approval + expect(@supervisionLast.approved).to eql(false) + @supervisionLast.update(approved: true) + expect(@supervisionLast.approved).to eql(true) + end +end + +describe Degree, '.check_Admin_Approval' do + before do + @degreeLast = Degree.last + end + + it '.checks the admin approval' do + # test for checking admin approval + expect(@degreeLast.approved).to eql(false) + @degreeLast.update(approved: true) + expect(@degreeLast.approved).to eql(true) + end +end \ No newline at end of file diff --git a/doc/log/Individual Log/steven_myers.md b/doc/log/Individual Log/steven_myers.md index 2a8a082..1436d23 100644 --- a/doc/log/Individual Log/steven_myers.md +++ b/doc/log/Individual Log/steven_myers.md @@ -113,3 +113,12 @@ https://github.com/401ChemistryGenealogy/ChemistryGenealogy/wiki/Initial-Softwar * auto generated documentation * wrote various tests * updated UI + +--- + +###Sprint 5 + +* reworked UI for view/admin panels +* found bugs in search +* found bugs in autocomplete +* found bugs in verification diff --git a/doc/log/Individual Log/theresa_ngo.md b/doc/log/Individual Log/theresa_ngo.md index 39b3ef7..51a08ce 100644 --- a/doc/log/Individual Log/theresa_ngo.md +++ b/doc/log/Individual Log/theresa_ngo.md @@ -37,3 +37,29 @@ #####February 27, 2016 - March 4, 2016 * Worked on backend submit and edit information models + +--- + +###Sprint 4 + +#####March 5, 2016 - March 11, 2016 +* Made a class for formatting information to be sent to the frontend (not in use) + +#####March 12, 2016 - March 18, 2016 +* Made a serializer for sending edit information to the frontend (not currently in use) +* Submit completed +* Edit mostly complete, but with some bugs +* Documented submit and edit + +--- + +###Sprint 5 + +#####March 19, 2016 - March 25, 2016 +* Research on what could be causing the edit bugs + +#####March 26, 2016 - April 1, 2016 +* Submit updated to include new sections +* Edit updated to include new sections +* Edit completed +* Updated documentation for submit and edit diff --git a/doc/log/Meeting Log/weekly_log.textile b/doc/log/Meeting Log/weekly_log.textile index a99a5a5..d0d5ab7 100644 --- a/doc/log/Meeting Log/weekly_log.textile +++ b/doc/log/Meeting Log/weekly_log.textile @@ -63,3 +63,27 @@ |Participants|Cole, Connor, Daniel, Theresa| |Minutes|2 hours| |Agenda|Meeting with the professor and TA
  • Update on project planning and progress
  • | + +|Date|March 4, 2016| +|Formality|Formal| +|Participants|Cole, Daniel, Ji Hwan, Steven, Theresa| +|Minutes|2 hours| +|Agenda|Meeting with the professor and TA
  • Update on project progress
  • Made deadlines for the remaining use cases
  • | + +|Date|March 11, 2016| +|Formality|Formal| +|Participants|Cole, Connor, Daniel, Ji Hwan, Steven, Theresa| +|Minutes|2 hours| +|Agenda|Meeting with the TA
  • Update on project progress
  • Received feedback on part of the demo
  • Set a meeting time for the entire group to meet with the TA and work on the project
  • | + +|Date|March 14, 2016| +|Formality|Formal| +|Participants|Cole, Connor, Daniel, Ji Hwan, Steven, Theresa| +|Minutes|5 hours| +|Agenda|Meeting with the TA
  • Mandatory meeting to work on the project
  • | + +|Date|March 18, 2016| +|Formality|Formal| +|Participants|Cole, Connor, Daniel, Steven, Theresa| +|Minutes|2 hours| +|Agenda|Meeting with the TA
  • Update on project progress
  • Received feedback on the working demo
  • | diff --git a/frontend/web/app/controllers/editController.js b/frontend/web/app/controllers/editController.js index 0fbb5c0..b8077fa 100644 --- a/frontend/web/app/controllers/editController.js +++ b/frontend/web/app/controllers/editController.js @@ -827,7 +827,6 @@ angular.module('chemGeno') return; }else{ $scope.pdInstitutionWarning = false; - alert("alert value: " + pdInstitution); console.log(pdInstitution); } @@ -1006,13 +1005,13 @@ angular.module('chemGeno') }else{ $scope.diTypeWarning = false; } - var newDegreeInfoInstance = new DegreeInfoInstance(diYear, diSupervisor, diInstitution, diType, idId, supervisionId); + var newDegreeInfoInstance = new DegreeInfoInstance(diYear, diSupervisor, diInstitution, diType, diId, supervisionId); $scope.degreeInformation.push(newDegreeInfoInstance); console.log("AddPostDocInstance Called on" + $scope.degreeInfoInformation); //Refresh the view of the scope. - $scope.$apply(); + //$scope.$apply(); }; /** diff --git a/frontend/web/app/controllers/submitController.js b/frontend/web/app/controllers/submitController.js index 20f378b..379e104 100644 --- a/frontend/web/app/controllers/submitController.js +++ b/frontend/web/app/controllers/submitController.js @@ -656,7 +656,7 @@ angular.module('chemGeno') var newDegreeInfoInstance = new DegreeInfoInstance(diYear, diSupervisor, diInstitution, diType); $scope.degreeInformation.push(newDegreeInfoInstance); - console.log("AddPostDocInstance Called on" + $scope.degreeInfoInformation); + console.log("AddDegreeInfoInstance Called on" + $scope.degreeInformation); diInstitution = null; diYear = null; diff --git a/frontend/web/app/services/editService.js b/frontend/web/app/services/editService.js index e38dda5..791f651 100644 --- a/frontend/web/app/services/editService.js +++ b/frontend/web/app/services/editService.js @@ -60,11 +60,12 @@ angular.module('chemGeno') */ var sendEditedData = function(modifications, idObj){ var d = $q.defer(); - console.log("modification"+modifications); + console.log(modifications.name); + console.log(idObj) var token = loginService.getAuthToken(); //Obtain the authentication token from the login service. return $http({ headers: { - "Content-Type": "application/json'", + "Content-Type": "application/json;charset=utf-8'", "Authorization": token }, method: 'PUT', @@ -77,8 +78,8 @@ angular.module('chemGeno') institution: modifications.currentInstitutionName, degree: modifications.degreeInformation, postdoc: modifications.postDocInformation, - superdoc:submitFileObject.superDocInformation, - superdeg: submitFileObject.superDegInformation + superdoc: modifications.superDocInformation, + superdeg: modifications.superDegInformation } }).success(function(resp) { d.resolve(resp); diff --git a/frontend/web/app/services/submitService.js b/frontend/web/app/services/submitService.js index 5bfef9e..e3c83c4 100644 --- a/frontend/web/app/services/submitService.js +++ b/frontend/web/app/services/submitService.js @@ -30,9 +30,9 @@ angular.module('chemGeno') position: submitFileObject.currentPositionTitle, institution: submitFileObject.currentInstitutionName, degree: submitFileObject.degreeInformation, - postdoc:submitFileObject.postDocInformation, - superdoc:submitFileObject.superDocInformation, - superdeg: submitFileObject.superDegInformation + postdoc: submitFileObject.postDocInformation, + superdeg: submitFileObject.superDegInformation, + superdoc: submitFileObject.superDocInformation } }).success(function(resp) { d.resolve(resp); diff --git a/frontend/web/app/views/submit.html b/frontend/web/app/views/submit.html index 4fc4463..a6fd28a 100644 --- a/frontend/web/app/views/submit.html +++ b/frontend/web/app/views/submit.html @@ -240,11 +240,11 @@

    Postdoctoral Appointments Section

    - Clear Fields + @@ -290,11 +290,11 @@

    Postdoctoral Appointments Section

    - Edit + @@ -413,11 +413,11 @@

    Degree Information Section

    - Clear Fields + @@ -460,11 +460,11 @@

    Degree Information Section

    - Edit + @@ -561,11 +561,11 @@

    Postdocs this Person SUPERVISED

    - Clear Fields + @@ -609,11 +609,11 @@

    Postdocs this Person SUPERVISED

    - Edit + @@ -743,11 +743,11 @@

    People who this person supervised their DEGREES

    - Clear Fields +