@@ -6,78 +6,56 @@ Below you will find examples using `RelationService`.
66
77## Automatically relate to root node
88
9- To perform the said task we need a component in which we can register to the ` ContentService.Published ` event :
9+ To perform the said task we need a Notification Handler :
1010
1111[ You can read more about composing Umbraco here] ( ../../../implementation/composing.md )
1212
1313``` csharp
14- using System .Linq ;
15- using Umbraco .Core .Composing ;
16- using Umbraco .Core .Events ;
17- using Umbraco .Core .Services ;
18- using Umbraco .Core .Services .Implement ;
14+ using Umbraco .Cms .Core .Events ;
15+ using Umbraco .Cms .Core .Notifications ;
16+ using Umbraco .Cms .Core .Services ;
1917
2018namespace Doccers .Core .Components ;
2119
22- public class RelationComponent : IComponent
20+ public class ContentPublishedNotificationHandler ( IContentService contentService , IRelationService relationService ) : INotificationHandler < ContentPublishedNotification >
2321{
24- private readonly IRelationService _relationService ;
25-
26- public RelationComponent (IRelationService relationService )
27- {
28- _relationService = relationService ;
29- }
30-
31- public void Initialize ()
22+ public void Handle (ContentPublishedNotification notification )
3223 {
33- ContentService .Published += ContentService_Published ;
34- }
35-
36- private void ContentService_Published (IContentService sender ,
37- ContentPublishedEventArgs e )
38- {
39- // Should never be null, to be honest.
40- var home = sender .GetRootContent ()? .FirstOrDefault ();
24+ var home = contentService .GetRootContent ().FirstOrDefault ();
4125 if (home == null ) return ;
4226
4327 // Get the relation type by alias
44- var relationType = _relationService .GetRelationTypeByAlias (" homesick" );
28+ var relationType = relationService .GetRelationTypeByAlias (" homesick" );
29+
4530 if (relationType == null ) return ;
4631
47- foreach (var entity in e .PublishedEntities
48- .Where (x => x .Id != home .Id ))
32+ foreach (var entity in notification .PublishedEntities
33+ .Where (x => x .Id != home .Id ))
4934 {
5035 // Check if they are already related
51- if (! _relationService .AreRelated (home .Id , entity .Id ))
36+ if (! relationService .AreRelated (home .Id , entity .Id ))
5237 {
5338 // If not then let us relate the currenty entity to home
54- _relationService .Relate (home .Id , entity .Id , relationType );
39+ relationService .Relate (home .Id , entity .Id , relationType );
5540 }
5641 }
5742 }
58-
59- public void Terminate () {
60- // unsubscribe during shutdown
61- ContentService .Published -= ContentService_Published ;
62- }
6343}
6444```
6545
66- To have Umbraco recognize our component we need to register it in a composer:
46+ To have Umbraco recognize our Notification Handler we need to register it in a composer:
6747
6848``` csharp
69- using Doccers .Core .Components ;
70- using Umbraco .Core ;
71- using Umbraco .Core .Composing ;
49+ using Umbraco .Cms .Core .Composing ;
50+ using Umbraco .Cms .Core .Notifications ;
7251
7352namespace Doccers .Core .Composers ;
7453
75- [RuntimeLevel (MinLevel = RuntimeLevel .Run )]
76- public class RelationComposer : IUserComposer
54+ public class RelationComposer : IComposer
7755{
78- public void Compose (Composition composition )
56+ public void Compose (IUmbracoBuilder builder )
7957 {
80- composition . Components (). Append < RelationComponent >();
58+ builder . AddNotificationHandler < ContentPublishedNotification , ContentPublishedNotificationHandler >();
8159 }
8260}
8361```
@@ -93,45 +71,45 @@ The example below uses UmbracoApiController which is obsolete in Umbraco 14 and
9371{% endhint %}
9472
9573``` csharp
96- using System ;
97- using System .Linq ;
98- using System .Net ;
99- using System .Net .Http ;
100- using System .Web .Http ;
101- using Umbraco .Core .Services ;
102- using Umbraco .Web .WebApi ;
74+ using Microsoft .AspNetCore .Mvc ;
75+ using System .Runtime .Serialization ;
76+ using Umbraco .Cms .Core .Services ;
77+ using Umbraco .Cms .Web .Common ;
10378
10479namespace Doccers .Core .Controllers .Http ;
10580
106- public class RelationsController : UmbracoApiController
81+ [ApiController ]
82+ [Route (" /umbraco/api/relations" )]
83+ public class RelationsController : Controller
10784{
10885 private readonly IRelationService _relationService ;
86+ private readonly UmbracoHelper _umbracoHelper ;
10987
110- public RelationsController (IRelationService relationService )
88+ public RelationsController (IRelationService relationService , UmbracoHelper umbracoHelper )
11189 {
11290 // Alternatively you could also access
11391 // the service via the service context:
11492 // _relationService = Services.RelationService;
11593 _relationService = relationService ;
94+ _umbracoHelper = umbracoHelper ;
11695 }
11796
118- [HttpGet ]
119- public HttpResponseMessage GetByRelationTypeAlias (string alias )
97+ [HttpGet ( " getbyrelationtypealias " ) ]
98+ public IActionResult GetByRelationTypeAlias (string alias )
12099 {
121100 var relationType = _relationService .GetRelationTypeByAlias (alias );
122101 if (relationType == null )
123- return Request .CreateResponse (HttpStatusCode .BadRequest ,
124- " Invalid relation type alias" );
102+ return BadRequest (" Invalid relation type alias" );
125103
126104 var relations = _relationService .GetAllRelationsByRelationType (relationType .Id );
127- var content = relations .Select (x => Umbraco .Content (x .ChildId ))
105+ var content = relations .Select (x => _umbracoHelper .Content (x .ChildId ))
128106 .Select (x => new Relation ()
129107 {
130108 Name = x .Name ,
131109 UpdateDate = x .UpdateDate
132110 });
133111
134- return Request . CreateResponse ( HttpStatusCode . OK , content );
112+ return Ok ( content );
135113 }
136114}
137115```
0 commit comments