Dragonfly.Umbraco10.DataEditingTools
2.1.0
dotnet add package Dragonfly.Umbraco10.DataEditingTools --version 2.1.0
NuGet\Install-Package Dragonfly.Umbraco10.DataEditingTools -Version 2.1.0
<PackageReference Include="Dragonfly.Umbraco10.DataEditingTools" Version="2.1.0" />
paket add Dragonfly.Umbraco10.DataEditingTools --version 2.1.0
#r "nuget: Dragonfly.Umbraco10.DataEditingTools, 2.1.0"
// Install Dragonfly.Umbraco10.DataEditingTools as a Cake Addin #addin nuget:?package=Dragonfly.Umbraco10.DataEditingTools&version=2.1.0 // Install Dragonfly.Umbraco10.DataEditingTools as a Cake Tool #tool nuget:?package=Dragonfly.Umbraco10.DataEditingTools&version=2.1.0
Dragonfly.Umbraco10.DataEditingTools
Data cleaning/conversion tools for Umbraco 10+ created by Heather Floyd. (Based on original code in "Dragonfly.Migration7To8Helpers")
Installation
PM> Install-Package Dragonfly.Umbraco10.DataEditingTools
Description
Includes various quick-to-use "Find-Replace" functionality to edit underlying Content node data directly. Also allows the ability to create custom programmed data-editing functions, with a UI to facilitate selecting, checking, and updating Content values.
DISCLAIMER: This tool gives you a lot of power to alter your property data directly. Be responsible. Make database backups in case something goes horribly wrong. Use the "Preview Only" option to check the results before actually updating the data, etc.
If you screw up your website, it is your own fault.
Usage
After Installing, log-in to the Umbraco back-office, then visit:
http://YOURSITE.COM/Umbraco/backoffice/Api/TransformationHelperApi/Start
Features
General Visibility
You can view lists of Doctypes, DataTypes, and PropertyEditors, and see what other items are referencing them. Drill-down and view raw property data.
Additionally, there is a UDI / GUID Lookup tool, which can be helpful when you are seeing error messages with limited information, or when you need to quickly figure out what a UDI/GUID is referring to.
Data Conversion Tools
Find/Replace in PropertyData
Allows you to bulk alter a node's property's raw data directly.
- Simple Text-to-Text - An exact replacement of the entered text inside the property data
- Replace Integer Ids with UDIs - To update Node IDs with UDIs inside of data (for example - in the case of Nested Content or other JSON)
- Custom Transform - use your own custom Transformation code (implementing interface ICustomFindReplaceTransformer)
Property-To-Property
Documentation TBD
Custom Data Transformers : ICustomFindReplaceTransformer
You can create your own custom data transformations to update data inside a property. This is useful when you are dealing with changing data formats inside of third-party property editors or other more complex data.
Just add a class to your project that implements interface ICustomFindReplaceTransformer. The two methods are simple to work with.
IsValidForData
bool IsValidForData(int NodeId, string ContentTypeAlias, PropertyType PropType, object OriginalData);
Here you can add whatever tests are needed to ensure that you are only operating on the data you want. The calling function will provide you with the current node Id, ContentType Alias, PropertyType, and the current data in the property. You can use what you need to and ignore the rest. Use Services to get more information about the objects as needed.
Examples:
//Check that it is a specific DataType
string MyDataTypeGuid = "2274379b-de2c-4e8c-bd88-3c1fb2caa5e8";
if (PropType.DataTypeKey.ToString() == MyDataTypeGuid)
{
return true;
}
else
{
return false;
}
--
//Check that it is a specific Property Editor
if (PropertyType.PropertyEditorAlias == "Umbraco.NestedContent")
{
return true;
}
else
{
return false;
}
Your transformer will only get called if the original data in the node/property is not NULL. If your function returns "FALSE", the data will NOT be changed for that node/property.
ConvertOriginalData
object ConvertOriginalData(object OriginalData,out string ConversionErrorMsg);
This is where you do the conversion. You can do whatever you want here, just return the "new" data. Keep in mind that you are working with the data in the raw DB format, so objects will be in JSON format, for instance, and should be Serialized to a string before getting returned.
Use the ConversionErrorMessage
to also return any messages about why data was unable to be converted. In the event of an error, you should probably return the original data unchanged. The ConversionErrorMessage will be shown in the table on the "Find Replace Results" Page
Some Tips:
- When dealing with NestedContent or other complex object data, you should create some simple class models for deserializing to make it easier to work with your new data. The quickest way to do that is to copy some example data from the property and use https://app.quicktype.io with the "Attributes Only" option selected.
Examples: See the '~Custom Transformer Samples' folder for sample code
Resources
GitHub Repository: https://github.com/hfloyd/Dragonfly.Umbraco10.DataEditingTools
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net6.0
- Dragonfly.Net6 (>= 1.0.0)
- Dragonfly.Umbraco10 (>= 1.0.0)
- Umbraco.Cms.Core (>= 10.0.1 && <= 13.999.999)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Fixing dependencies