! Copyright (c) 2021 Approximatrix, LLC ! ! Permission is hereby granted, free of charge, to any person obtaining a copy ! of this software and associated documentation files (the "Software"), to deal ! in the Software without restriction, including without limitation the rights ! to use, copy, modify, merge, publish, distribute, sublicense, and/or sell ! copies of the Software, and to permit persons to whom the Software is ! furnished to do so, subject to the following conditions: ! ! The above copyright notice and this permission notice shall be included in ! all copies or substantial portions of the Software. ! ! The Software shall be used for Good, not Evil. ! ! THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR ! IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, ! FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE ! AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER ! LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, ! OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE ! SOFTWARE. module special_filenames implicit none contains function get_special_full_filename(category, filename) result(res) use utilities, only: combine_paths use config use logging implicit none character(*), intent(in)::category, filename character(len=:), pointer::res res => null() call write_log("category: "//trim(category)) call write_log("file: "//trim(filename)) if(trim(category) == "releases") then allocate(character(len=(len_trim(release_dir)+len_trim(filename)+1)) :: res) call combine_paths(release_dir, filename, res) else if(trim(category) == "uploads") then allocate(character(len=(len_trim(release_dir)+len_trim(filename)+1)) :: res) call combine_paths(release_dir, filename, res) else if(trim(category) == "results") then allocate(character(len=(len_trim(results_dir)+len_trim(filename)+1)) :: res) call combine_paths(results_dir, filename, res) else if(trim(category) == "static") then allocate(character(len=(len_trim(static_dir)+len_trim(filename)+1)) :: res) call combine_paths(static_dir, filename, res) else if(trim(category) == "favicon.txt") then allocate(character(len=(len_trim(static_dir)+len_trim(filename)+1)) :: res) call combine_paths(static_dir, "favicon.txt", res) else if(trim(category) == "instructions") then allocate(character(len=(len_trim(instructions_dir)+len_trim(filename)+1)) :: res) call combine_paths(instructions_dir, filename, res) end if call write_log("path: "//trim(res)) end function get_special_full_filename function get_instructions_static_filename(instruction_id) result(res) use captain_db implicit none integer, intent(in)::instruction_id character(len=:), pointer::res character(PLAYER_NAME_LENGTH)::instruction_name call get_instruction_name(instruction_id, instruction_name) res => get_special_full_filename("instructions", trim(instruction_name)//".json") end function get_instructions_static_filename function get_task_result_static_filename(job_id, task_num, no_path) result(res) use config implicit none integer, intent(in)::job_id, task_num logical, intent(in), optional::no_path character(len=:), pointer::res character(64)::filename character(12)::job_text, task_text write(job_text, '(I8)') job_id write(task_text, '(I8)') task_num filename = "results-job"//trim(adjustl(job_text))//"-task"//trim(adjustl(task_text))//".txt" if(present(no_path)) then if(no_path) then allocate(character(len=len_trim(filename)) :: res) res = filename else res => get_special_full_filename("results", filename) end if else res => get_special_full_filename("results", filename) end if end function get_task_result_static_filename function get_full_filename_from_request(req) result(res) use server_response implicit none class(request)::req character(len=:), pointer::res character(256)::first character(1024)::remaining integer::i call req%path_component(1, first) i = index(req%location, trim(first)) i = i + len_trim(first) + 1 remaining = req%location(i:len_trim(req%location)) res => get_special_full_filename(first, trim(remaining)) end function get_full_filename_from_request end module special_filenames