Gulla.Episerver.SqlStudio
1.2.0
See the version list below for details.
dotnet add package Gulla.Episerver.SqlStudio --version 1.2.0
NuGet\Install-Package Gulla.Episerver.SqlStudio -Version 1.2.0
<PackageReference Include="Gulla.Episerver.SqlStudio" Version="1.2.0" />
paket add Gulla.Episerver.SqlStudio --version 1.2.0
#r "nuget: Gulla.Episerver.SqlStudio, 1.2.0"
// Install Gulla.Episerver.SqlStudio as a Cake Addin #addin nuget:?package=Gulla.Episerver.SqlStudio&version=1.2.0 // Install Gulla.Episerver.SqlStudio as a Cake Tool #tool nuget:?package=Gulla.Episerver.SqlStudio&version=1.2.0
Gulla.Episerver.SqlStudio
Warning
With great powers comes great responsibility! This addon will indeed provide great powers. Delegate and use them wisely, and with caution. The addon should not be enabled for users you would not trust with full access to your database, and it is probably not wise to enable it in production. There is literally no limits to what you can do with this addon, unless you correctly configure the limits.
Intro
This addon will let you query the database directly from Episerver user interface. The result set can be exported to Excel, CSV or PDF.
Enter your query, execute it with the execute-button - or hit F5 like in Microsoft SQL Management Studio.
IntelliSense / AutoComplete
IntelliSense is added for all tables in the database, both Episerver tables and any custom tables you might have. The IntelliSense function will trigger after every key-up, with exception for some special keys. The IntelliSense popup can be closed with [ESC].
IntelliSense will show SQL keywords, table names and columns from the last table name you entered.
Automatically displaying IntelliSense on every key-up can be disabled with this appsetting.
<add key="Gulla.Episerver.SqlStudio:AutoIntelliSense.Enabled" value="false" />
You can always trigger IntelliSense with [CTRL] + [SPACE].
Light mode
The default editor is dark mode, but dark mode can be disabled with the following appsetting.
<add key="Gulla.Episerver.SqlStudio:DarkMode.Enabled" value="false" />
Access control
The addon is only available for users in the group SqlAdmin
. Other users will be blocked, and will not be able to see the addon's menu item or access it in any other way. The addon can also be completely disabled for specific environments by adding the following to your appsettings. If disabled by appsettings, the addon will not be available for users in the group SqlAdmin
either.
<add key="Gulla.Episerver.SqlStudio:Enabled" value="false" />
The addon can also be made available to users not in the group SqlAdmin
by listing their user names like this.
<add key="Gulla.Episerver.SqlStudio:Users" value="UserName1,UserName2,UserName3" />
A safety net
You can control what queries are allowed by providing a regular expression that will be validated (ignore case) against the query prior to execution. Provide a message that is shown if validation fails. Example below.
<add key="Gulla.Episerver.SqlStudio:AllowPattern" value="^\s*SELECT.*" />
<add key="Gulla.Episerver.SqlStudio:AllowMessage" value="Nothing but SELECTs please!" />
In the same way, you can also control what queries are denied by providing a regular expressions. Example below.
<add key="Gulla.Episerver.SqlStudio:DenyPattern" value="^.*DROP.*" />
<add key="Gulla.Episerver.SqlStudio:DenyMessage" value="No DROPing allowed!" />
Saving queries
To save queries for later, first create a new table. You can do this from within the module. The name of the table and columns must match.
CREATE TABLE SqlQueries (
Name varchar(256) NOT NULL,
Category varchar(256) NOT NULL,
Query varchar(2048) NOT NULL,
CONSTRAINT PK_SqlQueries PRIMARY KEY CLUSTERED (Name, Category))
Then simply add queries to that table (using SQL). Two queries with identical categories will be placed in the same named dropdown list. Example of adding a query named All
to the category Content
:
INSERT INTO SqlQueries VALUES('All', 'Content', 'SELECT * FROM tblContent')
In order to insert queries with '
, simply double them (''
). Example:
INSERT INTO SqlQueries VALUES('Jpg-images', 'Content', 'SELECT * FROM tblContentLanguage WHERE URLSegment LIKE ''%.jpg''')
Will save the following query:
SELECT * FROM tblContentLanguage WHERE URLSegment LIKE '%.jpg'
Saved queries will be displayed by category.
Dependencies
- CodeMirror is used for the editor, and basic IntelliSense.
- DataTables is used for displaying the result, and export to CSV, PDF and Excel.
Contribute
You are welcome to register an issue, or create a pull request, if you see something that should be improved.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET Framework | net471 is compatible. net472 was computed. net48 is compatible. net481 was computed. |
-
- Castle.Core (>= 4.2.1)
- EPiServer.CMS.Core (>= 11.12.0 && < 12.0.0)
- EPiServer.CMS.UI (>= 11.20.1 && < 12.0.0)
- EPiServer.CMS.UI.Core (>= 11.20.1 && < 12.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
2.11.0 | 2,304 | 10/28/2024 |
2.10.0 | 143 | 10/27/2024 |
2.9.2 | 13,097 | 9/4/2023 |
2.9.1 | 274 | 8/28/2023 |
2.9.0 | 1,981 | 6/23/2023 |
2.8.0 | 193 | 6/22/2023 |
2.7.2 | 227 | 6/13/2023 |
2.7.1 | 780 | 6/1/2023 |
2.6.0 | 4,299 | 2/16/2023 |
2.5.0 | 896 | 2/1/2023 |
2.4.0 | 321 | 2/1/2023 |
2.3.0 | 1,409 | 12/7/2022 |
2.2.1 | 1,789 | 9/11/2022 |
2.2.0 | 453 | 9/9/2022 |
2.1.0 | 504 | 5/28/2022 |
2.0.2 | 501 | 5/9/2022 |
1.3.1 | 1,496 | 6/12/2023 |
1.3.0 | 22,292 | 10/3/2021 |
1.2.1 | 378 | 10/1/2021 |
1.2.0 | 382 | 10/1/2021 |
1.1.4 | 1,593 | 8/13/2021 |
1.1.3 | 379 | 8/12/2021 |
1.1.2 | 370 | 8/12/2021 |
1.1.1 | 369 | 8/12/2021 |
Make it possible to select connection string.