Please, know that this is not going up as an idea or question because I want to spark a discussion on this and that it would not be something for Instructure to do, unless someone really wants to ask them to do it.
I know there have been ideas posted to request additional and more intuitive reporting within the Canvas LMS. However, I have found most of these are geared towards things like surrounding recording keeping of activities and actions taken within the LMS. I find that more often than not, I'm tasked with requests to find everywhere an LTI is used (this was a major one recently when the LMS was updated to support only one  external tool configuration per tool URL [https://community.canvaslms.com/docs/DOC-6092#jive_content_id_Assignments]) or where a particular URL is linked at. These are not exactly the easiest things to accomplish due to a complete lack of content searching functionality.
Now, don't get me wrong, Moodle, which we came from, lacked this, also. However, we could use querying plugins to run custom reports with little-to-no effort or time lost.
Obviously, this is entirely out of the question with Canvas, especially for the vast number of institutions that use an Instructure-hosted installation, so the recourse is to either use the API or manually search through every activity looking for what you need (albeit, using the API is basically the same thing, just automated).
Over the last year, I've written several scripts to accomplish these tasks, allowing them to be easily performed by anyone with sufficient permissions to access the scripts. Well, it just struck me as inefficient to have all the stand-alone scripts scattered about (they're actually in one nicely organized directory) doing much the same things in different orders to produce desired results. So, I have decided to consolidate them into a simple and expandable interface that makes all the tools available.
I've got much of the coding done to allow for uniform API GET calls, with fairly more consideration for error identification than the API currently supplies ("The specified resource does not exist." What resource? The course_id? The module_id? The module_item_id?), to most of the major points of the Course, Account, and User areas of the LMS. I even put in consideration for potentially expanding it for PUT, POST, and DELETE calls, but I'm giving focus to GET for reporting, as mentioned.
It's also expandable in that, if I did half as well as I think I did, a developer should be able to create a new report fairly easily. The most difficult part should be figuring out the logic to get the report. All the cURL calls can be ran through the uniform function to get either an error of the API response.
There's even a report generator (you have to format the data you want reported into a multidimensional array) and PHPExcel integration for easy exporting of a report to Excel.
Now, before I put any code out, I want to get feedback on this concept and ideas for reports that you feel would be helpful as developers/administrators. Most of the reports I've created are unique to how we deploy Canvas, having done a not insignificant amount of customization to our templating. As such, I only have three (3) reports currently written for use with this interface I've created:
Bare in mind, there is no "easy" way to get a complete list of all assignments in an account, so it will take time to generate these reports. The more content being sifted through, the longer it will take. Just to run the Content Searcher for a URL we needed to replace in a bunch of courses required me to increase the script execution time to four (4) hours. It is, mostly, just API call after API call after API call. When you have the occasional 504 Timeout, this adds up.
So, what do you all think? Is this something you would be interested in as developers/admins? If so, what would you like to see as premade reports?