Regarding different templates: maybe it's better to have one template with a lot of if statements which is able to render urls, content, video images etc and then add suggestions based on $activity->getType(). cf Reader::buildMicrosubItem for inspiration.
Do you think that will be useful, a way to render non comment inbox (like "Create") activities? Or in this use case a new plugin to process inbox activities to nodes will make more sense ?
I think it's very useful to have rendering of this out of the box!
Currently, I'm using the reader module to view all incoming activities, but this should be possible with this module too.
Not a fan to create nodes from these though. I think we can use a viewBuilder class and than use inspiration from Reader::buildMicrosubItem to render inbox activities, and maybe have different templates depending on some logic: e.g. Inbox -> like template, Inbox -> Create template, Inbox -> Announce template, Inbox -> Follow template and a 'default' one which does something clever with the payload although I have no idea what yet :)
The view builder class should split rendering between inbox and outbox, especially when 📌 Allow like/announce not having to map to entities Active is resolved. (I briefly had the idea to maybe use bundles for inbox and outbox, but view builder classes can't be split in core for now).
That looks very, very, very cool! I wonder whether we can create our own ckeditor plugin instead of having to rely on getting that merged into ckeditor itself. That's just a thought because I have not dived into Ckeditor plugins yet, a bit too scared :)
Maybe the escape isn't that necessary, but maybe wildcards are?
Merged ✨ Make endpoints unlocalized Active - would the tests pass (in case you use dev require of webfinger?)
Hmm, I wonder if we also should escape the query as done in the 'search' part in baseQuery, or is it good enough for your use case?
I need this as part of 📌 Allow like/announce not having to map to entities Active - working on that one now, marking this duplicate.
Merged, thanks! Simplified the patch a little, no need for inline twig template.
These are not necessarily linked indeed to AP, and are not a problem in itself. Marking duplicate of #3174746: Add more responses for various crawlers → - which has a link to a Github issue where I was tracking all potential calls which start to come in once a site is connected with the fediverse.
Merged
Oh, nice catch! Merged, thanks!
Even better message indicating this needs to be configured in settings.php
I guess we can do this.
So third time it worked, so probably some issue on the mastodon side (username ending with underscore)
Ok using aliases makes this work as far as I can see, finally!
Not needed anymore at this point.
Marking duplicate of 🐛 indieweb_indieauth - not working with indielogin.com Active
Merged, thanks!
nvm, was able to create a merge request myself
Ha, funny! Could you create a merge request from that, the fix is working indeed!
Display Suite relies on the core plugin since a very long time now, and no issues are reported on that integration. I'm fairly sure the others are fine as well, so this can be closed imo.
Updated version fixing the explode
indielogin.com seems to work for me with patch 3
getting a notice though: Deprecated function: explode(): Passing null to parameter #2 ($string) of type string is deprecated in Drupal\indieweb_indieauth\Entity\IndieAuthAuthorizationCode->getScopes, so will fix that while we're at it
Hmm the invalid state is on indielogin.com? Haven't tested that patch yet, but I'll double check somewhere next week!
New patch, suble change where the 'me' optional, but, in case it's there muse validate. Fixes the tests as well.
Thanks for the detailed report! I'm pretty sure I've tested this at some point in time where it probably worked, but indeed, now it doesn't. I did a quick test with https://micropublish.net/ too for instance, and nothing, so either the spec has been changed, or it's more relaxed, hard to say.
However, attached is a patch which made me able to authenticate on indielogin.com and micropublish.net. From a security point of view, it doesn't seem to be less secure not validating me, so I think it's fine.
Tests will probably fail, need to look at this (locally, they don't run anymore on the DA test infrastructure due to https://www.drupal.org/project/drupalci_environments/issues/3387737#comm... 📌 Split PHP image into php(cli/apache) and yarn(node/nightwatch) Needs review ), but it would be great if you could verify the login works now.
Thanks for all the maintenance love too! :)
I'm amazed the module usage is still so low, because it really is wonderful, so thank you for all the fantastic work!
@andreas no, just regulary entity forms, created an issue at 🐛 Entity translation does not necessarily exist Active
Pushed! (sorry, needed patches file for composer.patches for a couple of projects quickly, so did that first :)
Hmm, change record says 10.2.0, and in 10.4.x branch of DC too: https://git.drupalcode.org/project/drupal/-/blob/10.4.x/core/modules/fil...
Also, those validations area introduced in 10.2.0, so it's fine no?
10.2.x is EOL, so just up the constraint of the module to 10.3 - that's good enough imo. A new branch seems way overkill for that.
Ah crap, that was stupid sorry :) New patch.
There's actually no guarantee there is a translation too for the entity. If not, it will crash
This is the current fix I have for now, but I'm not sure if it's the proper one. But at least it doesn't crash for now.
(which reminds me I should make a follow up for the formatter_settings crash, but close on a deadline atm)
diff --git a/src/Plugin/CustomFieldWidgetBase.php b/src/Plugin/CustomFieldWidgetBase.php
index 51e544cdf..00e5b26ea 100755
--- a/src/Plugin/CustomFieldWidgetBase.php
+++ b/src/Plugin/CustomFieldWidgetBase.php
@@ -112,7 +112,7 @@ public function widget(FieldItemListInterface $items, int $delta, array $element
$langcode = $this->languageManager->getCurrentLanguage(LanguageInterface::TYPE_CONTENT)->getId();
$is_default_translation = TRUE;
$is_translatable = $field_definition->isTranslatable() && $field->getWidgetSetting('translatable');
- if (!$entity->isNew()) {
+ if (!$entity->isNew() && $entity->hasTranslation($langcode)) {
$entity = $entity->getTranslation($langcode);
$is_default_translation = $entity->isDefaultTranslation();
}
New release will install. It means the testbot won't be able to run anymore, but that's ok for now. See 📌 Allow lcobucci/jwt 4.3.0 for PHP 8.3 support Active
Remove the sodium replace and compat, but that means the testbot will fail always now
Actually, I've released 8.x-1.25 :)
Let's meet in 📌 Allow lcobucci/jwt 4.3.0 for PHP 8.3 support Active for the sodium extension.
Laste update: it's actually another commit that is still in dev that updated composer.json, that one is not in a release yet. Sorry for the noise!
Note: dev release indeed has support for D11 (added in 📌 Automated Drupal 11 compatibility fixes for indieweb Needs review ), but not release yet, need to fix the sodium stuff :)
More or less duplicate of
📌
Allow lcobucci/jwt 4.3.0 for PHP 8.3 support
Active
- I thought the sodium polyfill could work, but I have to double check again.
I /think/ it should work locally, but the testbot has a problem installing it, so it's kind of a chicken/egg problem.
Sorry for the delay, last commit, or attached patch should do it! Test (which I can only run locally for some reason) has a subtle change which indeed failed, but with the changes in Expert.php then passes!
yes, running 3.1.3
Using the debugger, it happens on the formatter settings for a file, using the file_default formatter.
Looking at the code, it looks like this line is the problem: https://git.drupalcode.org/project/custom_field/-/blob/3.1.x/src/Plugin/...
It's totally possible that $settings[$name] does not contain the formatter_settings key, which happens in this case for a file.
Getting an error which is related:
TypeError: Drupal\custom_field\Plugin\Field\FieldFormatter\BaseFormatter::createOptionsForInstance(): Argument #3 ($formatter_settings) must be of type array, null given, called in /home/drupal/web/modules/contrib/custom_field/src/Plugin/Field/FieldFormatter/BaseFormatter.php on line 463 in Drupal\custom_field\Plugin\Field\FieldFormatter\BaseFormatter->createOptionsForInstance() (line 101 of modules/contrib/custom_field/src/Plugin/Field/FieldFormatter/BaseFormatter.php).
diff --git a//src/Plugin/Field/FieldFormatter/BaseFormatter.php b//src/Plugin/Field/FieldFormatter/BaseFormatter.php
index 4cd0936e5..0e351ac0f 100755
--- a//src/Plugin/Field/FieldFormatter/BaseFormatter.php
+++ b//src/Plugin/Field/FieldFormatter/BaseFormatter.php
@@ -460,7 +460,7 @@ protected function getFormattedValues(FieldItemInterface $item, string $langcode
$format_type = $formatter_settings['format_type'];
}
- $options = $this->createOptionsForInstance($custom_item, $format_type, $formatter_settings['formatter_settings']);
+ $options = $this->createOptionsForInstance($custom_item, $format_type, $formatter_settings['formatter_settings'] ?? []);
$plugin = $this->customFieldFormatterManager->getInstance($options);
$value = $plugin->formatValue($item, $value);
if ($value === '' || $value === NULL) {
Hmm is it a change in core, or in field_group that triggers this error?
Been bitten by this one too, this makes it work indeed!
Bitten by this one as well, the patch makes sense, and it works at the moment. Would be great to have some security eyes on this one!
Been bitten by this one too, patch seems to resolve the issue, so RTBC for now!
(I wonder if bcc might have the same problem?)
Hmm there's already the concept of a 'Site wide actor' in the module, but that still means an entity of course. The activity entity currently has an owner field, but having no owner (basically, anonymous) could work. Sounds like a good feature request which could live in its own dedicated issue. Question is, as always, time of course :)
Ok, confirmed that it doesn't work when the node that is being deleted had a path alias, makes sense!
Done
If you deselect it, that it will probably work indeed (but with the patch it will be ok too).
Question is: did you upload a file for that note? If so, than there is a problem though with the code itself, I'll test it myself as well.
It's configured on the activitypub types screen at /admin/config/services/activitypub/activitypub-type.
If you are using the standard note, check which field is assigned to the attachment fields (there's image, video and audio) (e.g. at /admin/config/services/activitypub/activitypub-type/note)
Hmm, interesting. Attached patch makes sure $file is actually a valid object. However, it's interesting that there's no file loaded. Did you upload one? And if yes, is it a media field or a file/image field?
Oh crap, you are right! Looking at the test, it enables the field item wrapper .. so, the test works by accident.
Looking at the code, the replacement could actually happen multiple times, which is completely unnecessary!
Oh lord, where was my mind :)
The problem is with XSS::filterAdmin
Ok I get it now. XSS::filterAdmin has always been there, but the problem is that for some reason the code in Expert.php fails to replace the token with the actual value. The token should have been replaced already at this point (which why I was confused since the test is green, but maybe the test is completely wrong too haha)
Will have a fresh look this weekend, thanks for the pointers.
Actually, adminTags does allow the a tag, oh well, will test more and add more tests!
Well, the test doesn't use the a tag, but span. Crap! So yeah, that's the problem indeed, I'm testing it with the wrong tags.
Interesting, especially because there's a test which works .. :)
@devarch in your example, that configuration happens on a block type right? Just to be completely sure.
The replace of the tokens already happens in Expert.php, unless there's something else I completely missed as well :)