Compare commits
12 commits
mycalendar
...
main
Author | SHA1 | Date | |
---|---|---|---|
16b3c1402e | |||
6dd511e4b0 | |||
44daeb5b59 | |||
4bc5e37c2c | |||
871af8215c | |||
c676439880 | |||
1bf04a4a40 | |||
fa1796eec1 | |||
cacfb2a730 | |||
09ba5cac00 | |||
d625750a7e | |||
dddd3e395f |
61 changed files with 1913 additions and 967 deletions
|
@ -21,7 +21,7 @@ jobs:
|
||||||
MYSQL_ROOT_PASSWORD: root
|
MYSQL_ROOT_PASSWORD: root
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
php-version: ['7.4', '8.0', '8.1', '8.2', '8.3']
|
php-version: ['7.4', '8.0', '8.1', '8.2', '8.3', '8.4']
|
||||||
wordpress-version: ['6.7']
|
wordpress-version: ['6.7']
|
||||||
name: PHPUnit – PHP ${{ matrix.php-version }}
|
name: PHPUnit – PHP ${{ matrix.php-version }}
|
||||||
env:
|
env:
|
||||||
|
@ -38,7 +38,7 @@ jobs:
|
||||||
path: |
|
path: |
|
||||||
${{ env.WP_CORE_DIR }}
|
${{ env.WP_CORE_DIR }}
|
||||||
${{ env.WP_TESTS_DIR }}
|
${{ env.WP_TESTS_DIR }}
|
||||||
key: cache-wordpress-67-2
|
key: cache-wordpress-67-4
|
||||||
|
|
||||||
- name: Cache Composer
|
- name: Cache Composer
|
||||||
id: cache-composer-phpunit
|
id: cache-composer-phpunit
|
||||||
|
@ -75,37 +75,52 @@ jobs:
|
||||||
if: steps.cache-wordpress.outputs.cache-hit != 'false'
|
if: steps.cache-wordpress.outputs.cache-hit != 'false'
|
||||||
run: bash bin/install-wp-tests.sh wordpress_test root root 127.0.0.1 ${{ matrix.wordpress-version }} false true true true
|
run: bash bin/install-wp-tests.sh wordpress_test root root 127.0.0.1 ${{ matrix.wordpress-version }} false true true true
|
||||||
|
|
||||||
|
- name: Run General Tests
|
||||||
|
run: cd /workspace/Event-Federation/wordpress-event-bridge-for-activitypub/ && ./vendor/bin/phpunit --filter=event_bridge_for_activitypub
|
||||||
|
env:
|
||||||
|
PHP_VERSION: ${{ matrix.php-version }}
|
||||||
|
|
||||||
- name: Run Integration tests for The Events Calendar
|
- name: Run Integration tests for The Events Calendar
|
||||||
run: cd /workspace/Event-Federation/wordpress-activitypub-event-bridge/ && ./vendor/bin/phpunit --filter=the_events_calendar
|
run: cd /workspace/Event-Federation/wordpress-event-bridge-for-activitypub/ && ./vendor/bin/phpunit --filter=the_events_calendar
|
||||||
env:
|
env:
|
||||||
PHP_VERSION: ${{ matrix.php-version }}
|
PHP_VERSION: ${{ matrix.php-version }}
|
||||||
|
|
||||||
- name: Run Integration tests for VS Event List
|
- name: Run Integration tests for VS Event List
|
||||||
run: cd /workspace/Event-Federation/wordpress-activitypub-event-bridge/ && ./vendor/bin/phpunit --filter=vs_event_list
|
run: cd /workspace/Event-Federation/wordpress-event-bridge-for-activitypub/ && ./vendor/bin/phpunit --filter=vs_event_list
|
||||||
env:
|
env:
|
||||||
PHP_VERSION: ${{ matrix.php-version }}
|
PHP_VERSION: ${{ matrix.php-version }}
|
||||||
|
|
||||||
- name: Run Integration tests for GatherPress
|
- name: Run Integration tests for GatherPress
|
||||||
run: cd /workspace/Event-Federation/wordpress-activitypub-event-bridge/ && ./vendor/bin/phpunit --filter=gatherpress
|
run: cd /workspace/Event-Federation/wordpress-event-bridge-for-activitypub/ && ./vendor/bin/phpunit --filter=gatherpress
|
||||||
env:
|
env:
|
||||||
PHP_VERSION: ${{ matrix.php-version }}
|
PHP_VERSION: ${{ matrix.php-version }}
|
||||||
|
|
||||||
- name: Run Integration tests for Events Manager
|
- name: Run Integration tests for Events Manager
|
||||||
run: cd /workspace/Event-Federation/wordpress-activitypub-event-bridge/ && ./vendor/bin/phpunit --filter=events_manager
|
run: cd /workspace/Event-Federation/wordpress-event-bridge-for-activitypub/ && ./vendor/bin/phpunit --filter=events_manager
|
||||||
env:
|
env:
|
||||||
PHP_VERSION: ${{ matrix.php-version }}
|
PHP_VERSION: ${{ matrix.php-version }}
|
||||||
|
|
||||||
- name: Run Integration tests for WP Event Manager
|
- name: Run Integration tests for WP Event Manager
|
||||||
run: cd /workspace/Event-Federation/wordpress-activitypub-event-bridge/ && ./vendor/bin/phpunit --filter=wp_event_manager
|
run: cd /workspace/Event-Federation/wordpress-event-bridge-for-activitypub/ && ./vendor/bin/phpunit --filter=wp_event_manager
|
||||||
env:
|
env:
|
||||||
PHP_VERSION: ${{ matrix.php-version }}
|
PHP_VERSION: ${{ matrix.php-version }}
|
||||||
|
|
||||||
- name: Run Integration tests for Eventin (WP Event Solution)
|
- name: Run Integration tests for Eventin (WP Event Solution)
|
||||||
run: cd /workspace/Event-Federation/wordpress-activitypub-event-bridge/ && ./vendor/bin/phpunit --filter=eventin
|
run: cd /workspace/Event-Federation/wordpress-event-bridge-for-activitypub/ && ./vendor/bin/phpunit --filter=eventin
|
||||||
env:
|
env:
|
||||||
PHP_VERSION: ${{ matrix.php-version }}
|
PHP_VERSION: ${{ matrix.php-version }}
|
||||||
|
|
||||||
- name: Run Integration tests for Modern Events Calendar Lite
|
- name: Run Integration tests for Modern Events Calendar Lite
|
||||||
run: cd /workspace/Event-Federation/wordpress-activitypub-event-bridge/ && ./vendor/bin/phpunit --filter=modern_events_calendar_lite
|
run: cd /workspace/Event-Federation/wordpress-event-bridge-for-activitypub/ && ./vendor/bin/phpunit --filter=modern_events_calendar_lite
|
||||||
|
env:
|
||||||
|
PHP_VERSION: ${{ matrix.php-version }}
|
||||||
|
|
||||||
|
- name: Run Integration tests for EventPrime
|
||||||
|
run: cd /workspace/Event-Federation/wordpress-event-bridge-for-activitypub/ && ./vendor/bin/phpunit --filter=eventprime
|
||||||
|
env:
|
||||||
|
PHP_VERSION: ${{ matrix.php-version }}
|
||||||
|
|
||||||
|
- name: Run Integration tests for Event Organiser
|
||||||
|
run: cd /workspace/Event-Federation/wordpress-event-bridge-for-activitypub/ && ./vendor/bin/phpunit --filter=event_organiser
|
||||||
env:
|
env:
|
||||||
PHP_VERSION: ${{ matrix.php-version }}
|
PHP_VERSION: ${{ matrix.php-version }}
|
15
CHANGELOG.md
15
CHANGELOG.md
|
@ -5,18 +5,13 @@ All notable changes to this project will be documented in this file.
|
||||||
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.1.0/),
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.1.0/),
|
||||||
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
||||||
|
|
||||||
## [0.2.1] - 2024-11-16
|
## Unreleased
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
|
|
||||||
|
* Add custom summary via shortcodes
|
||||||
|
|
||||||
|
## [0.3.2] - 2024-12-12
|
||||||
|
|
||||||
* Initial release on WordPress.org
|
* Initial release on WordPress.org
|
||||||
|
|
||||||
### Fixed
|
|
||||||
|
|
||||||
* Applied some WordPress best practices
|
|
||||||
|
|
||||||
## [0.2.0] - 2024-10-20
|
|
||||||
|
|
||||||
### Added
|
|
||||||
|
|
||||||
* Initial submission to WordPress.org
|
|
||||||
|
|
|
@ -4,7 +4,7 @@ module.exports = function (grunt) {
|
||||||
{
|
{
|
||||||
checktextdomain: {
|
checktextdomain: {
|
||||||
options:{
|
options:{
|
||||||
text_domain: 'activitypub-event-bridge',
|
text_domain: 'event-bridge-for-activitypub',
|
||||||
keywords: [
|
keywords: [
|
||||||
'__:1,2d',
|
'__:1,2d',
|
||||||
'_e:1,2d',
|
'_e:1,2d',
|
||||||
|
|
20
README.md
20
README.md
|
@ -1,9 +1,9 @@
|
||||||
# ActivityPub Event Bridge #
|
# Event Bridge for ActivityPub #
|
||||||
**Contributors:** [andremenrath](https://profiles.wordpress.org/andremenrath/)
|
**Contributors:** [andremenrath](https://profiles.wordpress.org/andremenrath/)
|
||||||
**Tags:** events, fediverse, activitypub, calendar
|
**Tags:** events, fediverse, activitypub, calendar
|
||||||
**Requires at least:** 6.5
|
**Requires at least:** 6.5
|
||||||
**Tested up to:** 6.7
|
**Tested up to:** 6.7
|
||||||
**Stable tag:** 0.2.1
|
**Stable tag:** 0.3.2
|
||||||
**Requires PHP:** 7.4
|
**Requires PHP:** 7.4
|
||||||
**License:** AGPL-3.0-or-later
|
**License:** AGPL-3.0-or-later
|
||||||
**License URI:** https://www.gnu.org/licenses/agpl-3.0.html
|
**License URI:** https://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
@ -14,7 +14,7 @@ Integrating popular event plugins with the ActivityPub plugin.
|
||||||
## Description ##
|
## Description ##
|
||||||
|
|
||||||
Make your events more discoverable, expand your reach effortlessly while being independent of other (commercial) platforms, and be a part of the growing decentralized web (the Fediverse).
|
Make your events more discoverable, expand your reach effortlessly while being independent of other (commercial) platforms, and be a part of the growing decentralized web (the Fediverse).
|
||||||
With the ActivityPub Event Bridge Plugin for WordPress, your events can be automatically followed, aggregated and displayed across decentralized platforms like [Mastodon](https://joinmastodon.org) or [Gancio](https://gancio.org), without any extra work.
|
With the Event Bridge for ActivityPub Plugin for WordPress, your events can be automatically followed, aggregated and displayed across decentralized platforms like [Mastodon](https://joinmastodon.org) or [Gancio](https://gancio.org), without any extra work.
|
||||||
Forget the hassle of managing multiple social media accounts just to keep your audience informed.
|
Forget the hassle of managing multiple social media accounts just to keep your audience informed.
|
||||||
|
|
||||||
This plugin is not an event managing plugin but an add-on to popular event plugins. It extends their functionality to fully support the [ActivityPub plugin](https://wordpress.org/plugins/activitypub/).
|
This plugin is not an event managing plugin but an add-on to popular event plugins. It extends their functionality to fully support the [ActivityPub plugin](https://wordpress.org/plugins/activitypub/).
|
||||||
|
@ -23,7 +23,7 @@ You retain full ownership of your content. By integrating into your existing set
|
||||||
|
|
||||||
### How It Works ###
|
### How It Works ###
|
||||||
|
|
||||||
With the ActivityPub Event Bridge WordPress plugin, sharing your events is effortless and automatic!
|
With the Event Bridge for ActivityPub WordPress plugin, sharing your events is effortless and automatic!
|
||||||
Once you create an event on your WordPress site, it is seamlessly shared across the decentralized web using the ActivityPub protocol.
|
Once you create an event on your WordPress site, it is seamlessly shared across the decentralized web using the ActivityPub protocol.
|
||||||
|
|
||||||
<p align="center">
|
<p align="center">
|
||||||
|
@ -44,7 +44,7 @@ The Event Federation plugin ensures that users from those platforms are provided
|
||||||
|
|
||||||
**ActivityPub-Enabled Event Sharing:** Your WordPress events are now compatible with the Fediverse, using the ActivityStreams format. This means your events can be easily discovered and followed by users on platforms like Mastodon and other ActivityPub-compatible services.
|
**ActivityPub-Enabled Event Sharing:** Your WordPress events are now compatible with the Fediverse, using the ActivityStreams format. This means your events can be easily discovered and followed by users on platforms like Mastodon and other ActivityPub-compatible services.
|
||||||
|
|
||||||
**Automatic Event Summaries:** When your event is shared on the Fediverse, platforms like Mastodon that don't fully support events will display a brief HTML summary of key details — such as the event's title, start time, and location. This ensures that even if someone can't view the full event on their platform, they still get the important info at a glance, with a link to your WordPress event page.
|
**Automatic Event Summaries:** When your event is shared on the Fediverse, platforms like Mastodon that don't fully support events will display a brief HTML summary of key details — such as the event's title, start time, and location. This ensures that even if someone can't view the full event on their platform, they still get the important info at a glance, with a link to your WordPress event page. Advanced users can create custom summaries via a set of shortcodes.
|
||||||
|
|
||||||
**Improved Event Discoverability:** Your custom event categories are mapped to a set of default categories used in the Fediverse, helping your events reach a wider audience. This improves the chances that users searching for similar events on other platforms will find yours.
|
**Improved Event Discoverability:** Your custom event categories are mapped to a set of default categories used in the Fediverse, helping your events reach a wider audience. This improves the chances that users searching for similar events on other platforms will find yours.
|
||||||
|
|
||||||
|
@ -63,6 +63,8 @@ This plugin depends on the [ActivityPub plugin](https://wordpress.org/plugins/ac
|
||||||
* [Eventin](https://de.wordpress.org/plugins/wp-event-solution/)
|
* [Eventin](https://de.wordpress.org/plugins/wp-event-solution/)
|
||||||
* [Modern Events Calendar Lite](https://webnus.net/modern-events-calendar/)
|
* [Modern Events Calendar Lite](https://webnus.net/modern-events-calendar/)
|
||||||
* [GatherPress](https://gatherpress.org/)
|
* [GatherPress](https://gatherpress.org/)
|
||||||
|
* [EventPrime – Events Calendar, Bookings and Tickets](https://wordpress.org/plugins/eventprime-event-calendar-management/)
|
||||||
|
* [Event Organiser](https://wordpress.org/plugins/event-organiser/)
|
||||||
|
|
||||||
## Configuration ##
|
## Configuration ##
|
||||||
|
|
||||||
|
@ -92,18 +94,16 @@ No, the Event Federation Plugin depends on the [ActivityPub plugin](https://word
|
||||||
|
|
||||||
### My event plugin is not supported, what can I do? ###
|
### My event plugin is not supported, what can I do? ###
|
||||||
|
|
||||||
If you know about coding have a look at the documentation of how to add your plugin or open an [issue](https://code.event-federation.eu/Event-Federation/wordpress-activitypub-event-bridge/issues), if we can spare some free hours we might add it.
|
If you know about coding have a look at the documentation of how to add your plugin or open an [issue](https://code.event-federation.eu/Event-Federation/wordpress-event-bridge-for-activitypub/issues), if we can spare some free hours we might add it.
|
||||||
|
|
||||||
### What if I experience problems? ###
|
### What if I experience problems? ###
|
||||||
|
|
||||||
We're always interested in your feedback. Feel free to reach out to us via [E-Mail](https://event-federation.eu/contact/) or create an [issue](https://code.event-federation.eu/Event-Federation/wordpress-activitypub-event-bridge/issues).
|
We're always interested in your feedback. Feel free to reach out to us via [E-Mail](https://event-federation.eu/contact/) or create an [issue](https://code.event-federation.eu/Event-Federation/wordpress-event-bridge-for-activitypub/issues).
|
||||||
|
|
||||||
## Changelog ##
|
## Changelog ##
|
||||||
|
|
||||||
### [0.2.1] 2024-11-16 ###
|
### [0.3.2] 2024-12-12 ###
|
||||||
|
|
||||||
* Initial release on https://wordpress.org/
|
* Initial release on https://wordpress.org/
|
||||||
|
|
||||||
### [0.2.0] 2024-10-29 ###
|
|
||||||
|
|
||||||
* Initial submission to https://wordpress.org/
|
|
||||||
|
|
|
@ -1,36 +0,0 @@
|
||||||
<?php
|
|
||||||
/**
|
|
||||||
* Plugin Name: ActivityPub Event Bridge
|
|
||||||
* Description: Integrating popular event plugins with the ActivityPub plugin.
|
|
||||||
* Plugin URI: https://event-federation.eu/
|
|
||||||
* Version: 0.2.1
|
|
||||||
* Author: André Menrath
|
|
||||||
* Author URI: https://graz.social/@linos
|
|
||||||
* Text Domain: activitypub-event-bridge
|
|
||||||
* License: AGPL-3.0-or-later
|
|
||||||
* License URI: https://www.gnu.org/licenses/agpl-3.0.html
|
|
||||||
* Requires PHP: 7.4
|
|
||||||
*
|
|
||||||
* Requires at least ActivityPub plugin with version >= 3.2.2. ActivityPub plugin tested up to: 4.2.0.
|
|
||||||
*
|
|
||||||
* @package ActivityPub_Event_Bridge
|
|
||||||
* @license AGPL-3.0-or-later
|
|
||||||
*/
|
|
||||||
|
|
||||||
// Exit if accessed directly.
|
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
|
||||||
|
|
||||||
define( 'ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_DIR', plugin_dir_path( __FILE__ ) );
|
|
||||||
define( 'ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_BASENAME', plugin_basename( __FILE__ ) );
|
|
||||||
define( 'ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_FILE', plugin_dir_path( __FILE__ ) . '/' . basename( __FILE__ ) );
|
|
||||||
define( 'ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_URL', plugin_dir_url( __FILE__ ) );
|
|
||||||
define( 'ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_VERSION', current( get_file_data( __FILE__, array( 'Version' ), 'plugin' ) ) );
|
|
||||||
define( 'ACTIVITYPUB_EVENT_BRIDGE_DOMAIN', 'activitypub-event-bridge' );
|
|
||||||
define( 'ACTIVITYPUB_EVENT_BRIDGE_ACTIVITYPUB_PLUGIN_MIN_VERSION', '3.2.2' );
|
|
||||||
|
|
||||||
// Include and register the autoloader class for automatic loading of plugin classes.
|
|
||||||
require_once ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_DIR . '/includes/class-autoloader.php';
|
|
||||||
ActivityPub_Event_Bridge\Autoloader::register();
|
|
||||||
|
|
||||||
// Initialize the plugin.
|
|
||||||
ActivityPub_Event_Bridge\Setup::get_instance();
|
|
|
@ -1,19 +1,19 @@
|
||||||
.settings_page_activitypub-event-bridge #wpcontent {
|
.settings_page_event-bridge-for-activitypub #wpcontent {
|
||||||
padding-left: 0;
|
padding-left: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-page .box {
|
.event-bridge-for-activitypub-settings-page .box {
|
||||||
border: 1px solid #c3c4c7;
|
border: 1px solid #c3c4c7;
|
||||||
background-color: #fff;
|
background-color: #fff;
|
||||||
padding: 1em 1.5em;
|
padding: 1em 1.5em;
|
||||||
margin-bottom: 1.5em;
|
margin-bottom: 1.5em;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-page .box ul.activitypub-event-bridge-list {
|
.event-bridge-for-activitypub-settings-page .box ul.event-bridge-for-activitypub-list {
|
||||||
margin-left: 0.6em;
|
margin-left: 0.6em;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-page .box pre {
|
.event-bridge-for-activitypub-settings-page .box pre {
|
||||||
padding: 1rem;
|
padding: 1rem;
|
||||||
min-height: 200px;
|
min-height: 200px;
|
||||||
box-shadow: none;
|
box-shadow: none;
|
||||||
|
@ -22,19 +22,19 @@
|
||||||
background-color: #f7f7f7;
|
background-color: #f7f7f7;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings {
|
.event-bridge-for-activitypub-settings {
|
||||||
max-width: 800px;
|
max-width: 800px;
|
||||||
margin: 0 auto;
|
margin: 0 auto;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-header {
|
.event-bridge-for-activitypub-settings-header {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
margin: 0 0 1rem;
|
margin: 0 0 1rem;
|
||||||
background: #fff;
|
background: #fff;
|
||||||
border-bottom: 1px solid #dcdcde;
|
border-bottom: 1px solid #dcdcde;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-title-section {
|
.event-bridge-for-activitypub-settings-title-section {
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
|
@ -42,7 +42,7 @@
|
||||||
padding-top: 8px;
|
padding-top: 8px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-tabs-wrapper {
|
.event-bridge-for-activitypub-settings-tabs-wrapper {
|
||||||
display: -ms-inline-grid;
|
display: -ms-inline-grid;
|
||||||
-ms-grid-columns: auto auto auto auto;
|
-ms-grid-columns: auto auto auto auto;
|
||||||
vertical-align: top;
|
vertical-align: top;
|
||||||
|
@ -50,12 +50,12 @@
|
||||||
grid-template-columns: auto auto auto auto;
|
grid-template-columns: auto auto auto auto;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-tab.active {
|
.event-bridge-for-activitypub-settings-tab.active {
|
||||||
box-shadow: inset 0 -3px #3582c4;
|
box-shadow: inset 0 -3px #3582c4;
|
||||||
font-weight: 600;
|
font-weight: 600;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-tab {
|
.event-bridge-for-activitypub-settings-tab {
|
||||||
display: block;
|
display: block;
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
color: inherit;
|
color: inherit;
|
||||||
|
@ -64,21 +64,21 @@
|
||||||
transition: box-shadow .5s ease-in-out;
|
transition: box-shadow .5s ease-in-out;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings .box h3 {
|
.event-bridge-for-activitypub-settings .box h3 {
|
||||||
font-size: 1.15em;
|
font-size: 1.15em;
|
||||||
margin-bottom: 0em;
|
margin-bottom: 0em;
|
||||||
}
|
}
|
||||||
|
|
||||||
#activitypub_event_bridge_initially_activated {
|
#event_bridge_for_activitypub_initially_activated {
|
||||||
display: hidden;
|
display: hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Accordions for admin pages */
|
/* Accordions for admin pages */
|
||||||
.activitypub-event-bridge-settings-accordion {
|
.event-bridge-for-activitypub-settings-accordion {
|
||||||
border: 1px solid #c3c4c7;
|
border: 1px solid #c3c4c7;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-accordion-heading {
|
.event-bridge-for-activitypub-settings-accordion-heading {
|
||||||
margin: 0;
|
margin: 0;
|
||||||
border-top: 1px solid #c3c4c7;
|
border-top: 1px solid #c3c4c7;
|
||||||
font-size: inherit;
|
font-size: inherit;
|
||||||
|
@ -87,17 +87,17 @@
|
||||||
color: inherit;
|
color: inherit;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-accordion-heading:first-child {
|
.event-bridge-for-activitypub-settings-accordion-heading:first-child {
|
||||||
border-top: none;
|
border-top: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-accordion-panel {
|
.event-bridge-for-activitypub-settings-accordion-panel {
|
||||||
margin: 0;
|
margin: 0;
|
||||||
padding: 1em 1.5em;
|
padding: 1em 1.5em;
|
||||||
background: #fff;
|
background: #fff;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-accordion-trigger {
|
.event-bridge-for-activitypub-settings-accordion-trigger {
|
||||||
background: #fff;
|
background: #fff;
|
||||||
border: 0;
|
border: 0;
|
||||||
color: #2c3338;
|
color: #2c3338;
|
||||||
|
@ -116,21 +116,21 @@
|
||||||
user-select: auto;
|
user-select: auto;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-accordion-trigger {
|
.event-bridge-for-activitypub-settings-accordion-trigger {
|
||||||
color: #2c3338;
|
color: #2c3338;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
font-weight: 400;
|
font-weight: 400;
|
||||||
text-align: left;
|
text-align: left;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-accordion-trigger .title {
|
.event-bridge-for-activitypub-settings-accordion-trigger .title {
|
||||||
pointer-events: none;
|
pointer-events: none;
|
||||||
font-weight: 600;
|
font-weight: 600;
|
||||||
flex-grow: 1;
|
flex-grow: 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-accordion-trigger .icon,
|
.event-bridge-for-activitypub-settings-accordion-trigger .icon,
|
||||||
.activitypub-event-bridge-settings-accordion-viewed .icon {
|
.event-bridge-for-activitypub-settings-accordion-viewed .icon {
|
||||||
border: solid #50575e medium;
|
border: solid #50575e medium;
|
||||||
border-width: 0 2px 2px 0;
|
border-width: 0 2px 2px 0;
|
||||||
height: .5rem;
|
height: .5rem;
|
||||||
|
@ -142,16 +142,16 @@
|
||||||
width: .5rem;
|
width: .5rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-accordion-trigger[aria-expanded="true"] .icon {
|
.event-bridge-for-activitypub-settings-accordion-trigger[aria-expanded="true"] .icon {
|
||||||
transform: translateY(-30%) rotate(-135deg);
|
transform: translateY(-30%) rotate(-135deg);
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-accordion-trigger:active,
|
.event-bridge-for-activitypub-settings-accordion-trigger:active,
|
||||||
.activitypub-event-bridge-settings-accordion-trigger:hover {
|
.event-bridge-for-activitypub-settings-accordion-trigger:hover {
|
||||||
background: #f6f7f7;
|
background: #f6f7f7;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-accordion-trigger:focus {
|
.event-bridge-for-activitypub-settings-accordion-trigger:focus {
|
||||||
color: #1d2327;
|
color: #1d2327;
|
||||||
border: none;
|
border: none;
|
||||||
box-shadow: none;
|
box-shadow: none;
|
||||||
|
@ -160,14 +160,14 @@
|
||||||
background-color: #f6f7f7;
|
background-color: #f6f7f7;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activitypub-event-bridge-settings-inline-icon {
|
.event-bridge-for-activitypub-settings-inline-icon {
|
||||||
width: 1.5em;
|
width: 1.5em;
|
||||||
height: 1.5em;
|
height: 1.5em;
|
||||||
vertical-align: middle;
|
vertical-align: middle;
|
||||||
margin: 0 0.3em;
|
margin: 0 0.3em;
|
||||||
}
|
}
|
||||||
|
|
||||||
code.activitypub-event-bridge-settings-example-url {
|
code.event-bridge-for-activitypub-settings-example-url {
|
||||||
display: block;
|
display: block;
|
||||||
background: rgb(28, 29, 33);
|
background: rgb(28, 29, 33);
|
||||||
padding: 8px;
|
padding: 8px;
|
||||||
|
@ -177,3 +177,11 @@ code.activitypub-event-bridge-settings-example-url {
|
||||||
overflow-x: auto;
|
overflow-x: auto;
|
||||||
word-break: break-all;
|
word-break: break-all;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#event_bridge_for_activitypub_summary_type_custom-details {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
#event_bridge_for_activitypub_summary_type_custom-details > details {
|
||||||
|
padding: 0.5em;
|
||||||
|
}
|
|
@ -1,14 +0,0 @@
|
||||||
jQuery( function( $ ) {
|
|
||||||
// Accordion handling in various areas.
|
|
||||||
$( '.activitypub-event-bridge-settings-accordion' ).on( 'click', '.activitypub-event-bridge-settings-accordion-trigger', function() {
|
|
||||||
var isExpanded = ( 'true' === $( this ).attr( 'aria-expanded' ) );
|
|
||||||
|
|
||||||
if ( isExpanded ) {
|
|
||||||
$( this ).attr( 'aria-expanded', 'false' );
|
|
||||||
$( '#' + $( this ).attr( 'aria-controls' ) ).attr( 'hidden', true );
|
|
||||||
} else {
|
|
||||||
$( this ).attr( 'aria-expanded', 'true' );
|
|
||||||
$( '#' + $( this ).attr( 'aria-controls' ) ).attr( 'hidden', false );
|
|
||||||
}
|
|
||||||
} );
|
|
||||||
} );
|
|
34
assets/js/event-bridge-for-activitypub-admin.js
Normal file
34
assets/js/event-bridge-for-activitypub-admin.js
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
jQuery( function( $ ) {
|
||||||
|
// Accordion handling in various areas.
|
||||||
|
$( '.event-bridge-for-activitypub-settings-accordion' ).on( 'click', '.event-bridge-for-activitypub-settings-accordion-trigger', function() {
|
||||||
|
var isExpanded = ( 'true' === $( this ).attr( 'aria-expanded' ) );
|
||||||
|
|
||||||
|
if ( isExpanded ) {
|
||||||
|
$( this ).attr( 'aria-expanded', 'false' );
|
||||||
|
$( '#' + $( this ).attr( 'aria-controls' ) ).attr( 'hidden', true );
|
||||||
|
} else {
|
||||||
|
$( this ).attr( 'aria-expanded', 'true' );
|
||||||
|
$( '#' + $( this ).attr( 'aria-controls' ) ).attr( 'hidden', false );
|
||||||
|
}
|
||||||
|
} );
|
||||||
|
|
||||||
|
// Function to toggle visibility of custom details based on selected radio button.
|
||||||
|
function toggleCustomDetailsForSummary() {
|
||||||
|
if ($("#event_bridge_for_activitypub_summary_type_custom").is(':checked')) {
|
||||||
|
$("#event_bridge_for_activitypub_summary_type_custom-details").show();
|
||||||
|
} else {
|
||||||
|
$("#event_bridge_for_activitypub_summary_type_custom-details").hide();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Run the toggle function on page load.
|
||||||
|
$(document).ready(function() {
|
||||||
|
window.console.log("test");
|
||||||
|
toggleCustomDetailsForSummary(); // Set the correct state on load.
|
||||||
|
|
||||||
|
// Listen for changes on the radio buttons
|
||||||
|
$("input[name=event_bridge_for_activitypub_summary_type]").change(function() {
|
||||||
|
toggleCustomDetailsForSummary(); // Update visibility on change.
|
||||||
|
});
|
||||||
|
});
|
||||||
|
} );
|
|
@ -209,7 +209,7 @@ install_wp_plugin() {
|
||||||
|
|
||||||
# Get the latest tag.
|
# Get the latest tag.
|
||||||
if [ -z "$2" ]; then
|
if [ -z "$2" ]; then
|
||||||
LATEST_TAG=$(svn log https://plugins.svn.wordpress.org/$PLUGIN_NAME/tags --limit 1 | awk 'NR == 4 { print $4 }' | sed 's/,$//')
|
LATEST_TAG=$(svn log https://plugins.svn.wordpress.org/$PLUGIN_NAME/tags --limit 1 | awk 'NR == 4 { print $4 }')
|
||||||
PLUGIN_VERSION=$LATEST_TAG
|
PLUGIN_VERSION=$LATEST_TAG
|
||||||
else
|
else
|
||||||
PLUGIN_VERSION=$2
|
PLUGIN_VERSION=$2
|
||||||
|
@ -257,11 +257,11 @@ install_wp_plugins() {
|
||||||
install_wp_plugin the-events-calendar "6.8.1"
|
install_wp_plugin the-events-calendar "6.8.1"
|
||||||
install_wp_plugin very-simple-event-list
|
install_wp_plugin very-simple-event-list
|
||||||
install_wp_plugin gatherpress
|
install_wp_plugin gatherpress
|
||||||
install_wp_plugin events-manager
|
install_wp_plugin eventprime-event-calendar-management
|
||||||
install_wp_plugin my-calendar
|
|
||||||
install_wp_plugin events-manager "6.6.3"
|
install_wp_plugin events-manager "6.6.3"
|
||||||
install_wp_plugin wp-event-manager "3.1.45.1"
|
install_wp_plugin wp-event-manager "3.1.45.1"
|
||||||
install_wp_plugin wp-event-solution "4.0.14"
|
install_wp_plugin wp-event-solution "4.0.14"
|
||||||
|
install_wp_plugin event-organiser "3.12.8"
|
||||||
# Mec is not installable via wordpress.org, we use our own mirror.
|
# Mec is not installable via wordpress.org, we use our own mirror.
|
||||||
install_wp_plugin_mec
|
install_wp_plugin_mec
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
{
|
{
|
||||||
"name": "menrath/wordpress-activitypub-event-bridge",
|
"name": "menrath/wordpress-event-bridge-for-activitypub",
|
||||||
"version": "1.0.0",
|
"version": "1.0.0",
|
||||||
"description": "The ActivityPub Event Bridge help for event custom post types to federate properly.",
|
"description": "The Event Bridge for ActivityPub help for event custom post types to federate properly.",
|
||||||
"type": "wordpress-plugin",
|
"type": "wordpress-plugin",
|
||||||
"require": {
|
"require": {
|
||||||
"php": ">=7.4.0",
|
"php": ">=7.4.0",
|
||||||
|
@ -33,7 +33,7 @@
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"extra": {
|
"extra": {
|
||||||
"installer-name": "activitypub-event-bridge"
|
"installer-name": "event-bridge-for-activitypub"
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"lint": [
|
"lint": [
|
||||||
|
@ -54,11 +54,13 @@
|
||||||
"@test-events-manager",
|
"@test-events-manager",
|
||||||
"@test-wp-event-manager",
|
"@test-wp-event-manager",
|
||||||
"@test-eventin",
|
"@test-eventin",
|
||||||
"@test-modern-events-calendar-lite"
|
"@test-modern-events-calendar-lite",
|
||||||
|
"@test-eventprime",
|
||||||
|
"@test-event-organiser"
|
||||||
],
|
],
|
||||||
"test-debug": [
|
"test-debug": [
|
||||||
"@prepare-test",
|
"@prepare-test",
|
||||||
"@test-my-calendar"
|
"@test-event-bridge-for-activitypub-shortcodes"
|
||||||
],
|
],
|
||||||
"test-vs-event-list": "phpunit --filter=vs_event_list",
|
"test-vs-event-list": "phpunit --filter=vs_event_list",
|
||||||
"test-the-events-calendar": "phpunit --filter=the_events_calendar",
|
"test-the-events-calendar": "phpunit --filter=the_events_calendar",
|
||||||
|
@ -67,7 +69,9 @@
|
||||||
"test-wp-event-manager": "phpunit --filter=wp_event_manager",
|
"test-wp-event-manager": "phpunit --filter=wp_event_manager",
|
||||||
"test-eventin": "phpunit --filter=eventin",
|
"test-eventin": "phpunit --filter=eventin",
|
||||||
"test-modern-events-calendar-lite": "phpunit --filter=modern_events_calendar_lite",
|
"test-modern-events-calendar-lite": "phpunit --filter=modern_events_calendar_lite",
|
||||||
"test-my-calendar": "phpunit --filter=my_calendar",
|
"test-eventprime": "phpunit --filter=eventprime",
|
||||||
|
"test-event-organiser": "phpunit --filter=event_organiser",
|
||||||
|
"test-event-bridge-for-activitypub-shortcodes": "phpunit --filter=event_bridge_for_activitypub_shortcodes",
|
||||||
"test-all": "phpunit"
|
"test-all": "phpunit"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,7 +16,7 @@ version: '3'
|
||||||
# "request": "launch",
|
# "request": "launch",
|
||||||
# "port": 9003,
|
# "port": 9003,
|
||||||
# "pathMappings": {
|
# "pathMappings": {
|
||||||
# "/app/": "${workspaceRoot}/wp-content/plugins/activitypub-event-bridge/",
|
# "/app/": "${workspaceRoot}/wp-content/plugins/event-bridge-for-activitypub/",
|
||||||
# "/tmp/wordpress/": "${workspaceRoot}/"
|
# "/tmp/wordpress/": "${workspaceRoot}/"
|
||||||
# },
|
# },
|
||||||
# },
|
# },
|
||||||
|
|
|
@ -13,7 +13,7 @@ To make the WordPress ActivityPub plugin use a custom transformer simply add a f
|
||||||
First you need to add some basic information about your event plugin. Just create a new file in `./includes/plugins/my-event-plugin.php`. Implement at least all abstract functions of the `Event_Plugin` class.
|
First you need to add some basic information about your event plugin. Just create a new file in `./includes/plugins/my-event-plugin.php`. Implement at least all abstract functions of the `Event_Plugin` class.
|
||||||
|
|
||||||
```php
|
```php
|
||||||
namespace ActivityPub_Event_Bridge\Plugins;
|
namespace Event_Bridge_For_ActivityPub\Integrations;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
@ -28,16 +28,16 @@ First you need to add some basic information about your event plugin. Just creat
|
||||||
final class My_Event_Plugin extends Event_Plugin {
|
final class My_Event_Plugin extends Event_Plugin {
|
||||||
```
|
```
|
||||||
|
|
||||||
Then you need to tell the ActivityPub Event Bridge about that class by adding it to the `EVENT_PLUGIN_CLASSES` constant in the `includes/setup.php` file:
|
Then you need to tell the Event Bridge for ActivityPub about that class by adding it to the `EVENT_PLUGIN_CLASSES` constant in the `includes/setup.php` file:
|
||||||
|
|
||||||
```php
|
```php
|
||||||
private const EVENT_PLUGIN_CLASSES = array(
|
private const EVENT_PLUGIN_CLASSES = array(
|
||||||
...
|
...
|
||||||
'\ActivityPub_Event_Bridge\Plugins\My_Event_Plugin',
|
'\Event_Bridge_For_ActivityPub\Integrations\My_Event_Plugin',
|
||||||
);
|
);
|
||||||
```
|
```
|
||||||
|
|
||||||
The ActivityPub Event Bridge then takes care of applying the transformer, so you can jump right into implementing it.
|
The Event Bridge for ActivityPub then takes care of applying the transformer, so you can jump right into implementing it.
|
||||||
|
|
||||||
## Writing an event transformer class
|
## Writing an event transformer class
|
||||||
|
|
||||||
|
@ -48,9 +48,9 @@ If you are writing a transformer for your event post type we recommend to start
|
||||||
So create a new file at `./includes/activitypub/transformer/my-event-plugin.php`.
|
So create a new file at `./includes/activitypub/transformer/my-event-plugin.php`.
|
||||||
|
|
||||||
```php
|
```php
|
||||||
namespace ActivityPub_Event_Bridge\Activitypub\Transformer;
|
namespace Event_Bridge_For_ActivityPub\Activitypub\Transformer;
|
||||||
|
|
||||||
use ActivityPub_Event_Bridge\Activitypub\Transformer\Event as Event_Transformer;
|
use Event_Bridge_For_ActivityPub\Activitypub\Transformer\Event as Event_Transformer;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ActivityPub Transformer for My Event Plugin' event post type.
|
* ActivityPub Transformer for My Event Plugin' event post type.
|
||||||
|
@ -142,7 +142,7 @@ Implement a check whether your event plugin is active in the `set_up` function.
|
||||||
}
|
}
|
||||||
|
|
||||||
// Make sure that ActivityPub support is enabled for The Events Calendar.
|
// Make sure that ActivityPub support is enabled for The Events Calendar.
|
||||||
$aec = \ActivityPub_Event_Bridge\Setup::get_instance();
|
$aec = \Event_Bridge_For_ActivityPub\Setup::get_instance();
|
||||||
$aec->activate_activitypub_support_for_active_event_plugins();
|
$aec->activate_activitypub_support_for_active_event_plugins();
|
||||||
|
|
||||||
// Delete all posts afterwards.
|
// Delete all posts afterwards.
|
||||||
|
@ -180,7 +180,7 @@ In the pipeline we want to run each event plugins integration tests in a single
|
||||||
To activate/load your plugin add it to the switch statement within the function `_manually_load_plugin()` within `tests/bootstrap.php`.
|
To activate/load your plugin add it to the switch statement within the function `_manually_load_plugin()` within `tests/bootstrap.php`.
|
||||||
|
|
||||||
```php
|
```php
|
||||||
switch ( $activitypub_event_bridge_integration_filter ) {
|
switch ( $event_bridge_for_activitypub_integration_filter ) {
|
||||||
...
|
...
|
||||||
case 'my_event_plugin':
|
case 'my_event_plugin':
|
||||||
$plugin_file = 'my-event-plugin/my-event-plugin.php';
|
$plugin_file = 'my-event-plugin/my-event-plugin.php';
|
||||||
|
@ -213,7 +213,7 @@ If you are using Visual Studio Code or VSCodium you can step-debug within the te
|
||||||
"request": "launch",
|
"request": "launch",
|
||||||
"port": 9003,
|
"port": 9003,
|
||||||
"pathMappings": {
|
"pathMappings": {
|
||||||
"/app/": "${workspaceRoot}/wp-content/plugins/activitypub-event-bridge/",
|
"/app/": "${workspaceRoot}/wp-content/plugins/event-bridge-for-activitypub/",
|
||||||
"/tmp/wordpress/": "${workspaceRoot}/"
|
"/tmp/wordpress/": "${workspaceRoot}/"
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
38
event-bridge-for-activitypub.php
Normal file
38
event-bridge-for-activitypub.php
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Plugin Name: Event Bridge for ActivityPub
|
||||||
|
* Description: Integrating popular event plugins with the ActivityPub plugin.
|
||||||
|
* Plugin URI: https://event-federation.eu/
|
||||||
|
* Version: 0.3.2
|
||||||
|
* Author: André Menrath
|
||||||
|
* Author URI: https://graz.social/@linos
|
||||||
|
* Text Domain: event-bridge-for-activitypub
|
||||||
|
* License: AGPL-3.0-or-later
|
||||||
|
* License URI: https://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
* Requires PHP: 7.4
|
||||||
|
*
|
||||||
|
* Requires at least ActivityPub plugin with version >= 3.2.2. ActivityPub plugin tested up to: 4.3.0.
|
||||||
|
*
|
||||||
|
* @package Event_Bridge_For_ActivityPub
|
||||||
|
* @license AGPL-3.0-or-later
|
||||||
|
*/
|
||||||
|
|
||||||
|
// Exit if accessed directly.
|
||||||
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
|
||||||
|
define( 'EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_DIR', plugin_dir_path( __FILE__ ) );
|
||||||
|
define( 'EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_BASENAME', plugin_basename( __FILE__ ) );
|
||||||
|
define( 'EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_FILE', plugin_dir_path( __FILE__ ) . '/' . basename( __FILE__ ) );
|
||||||
|
define( 'EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_URL', plugin_dir_url( __FILE__ ) );
|
||||||
|
define( 'EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_VERSION', current( get_file_data( __FILE__, array( 'Version' ), 'plugin' ) ) );
|
||||||
|
define( 'EVENT_BRIDGE_FOR_ACTIVITYPUB_DOMAIN', 'event-bridge-for-activitypub' );
|
||||||
|
define( 'EVENT_BRIDGE_FOR_ACTIVITYPUB_ACTIVITYPUB_PLUGIN_MIN_VERSION', '3.2.2' );
|
||||||
|
define( 'EVENT_BRIDGE_FOR_ACTIVITYPUB_CUSTOM_SUMMARY', "<ul>\n <li>[ap_start_time]</li>\n <li>[ap_end_time]</li>\n <li>[ap_location]</li>\n</ul>\n[ap_hashcats] [ap_hashtags]" );
|
||||||
|
define( 'EVENT_BRIDGE_FOR_ACTIVITYPUB_DEFAULT_SUMMARY_TYPE', 'preset' );
|
||||||
|
|
||||||
|
// Include and register the autoloader class for automatic loading of plugin classes.
|
||||||
|
require_once EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_DIR . '/includes/class-autoloader.php';
|
||||||
|
Event_Bridge_For_ActivityPub\Autoloader::register();
|
||||||
|
|
||||||
|
// Initialize the plugin.
|
||||||
|
Event_Bridge_For_ActivityPub\Setup::get_instance();
|
99
includes/activitypub/transformer/class-event-organiser.php
Normal file
99
includes/activitypub/transformer/class-event-organiser.php
Normal file
|
@ -0,0 +1,99 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* ActivityPub Transformer for the plugin Event Organiser.
|
||||||
|
*
|
||||||
|
* @package Event_Bridge_For_ActivityPub
|
||||||
|
* @license AGPL-3.0-or-later
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Event_Bridge_For_ActivityPub\Activitypub\Transformer;
|
||||||
|
|
||||||
|
// Exit if accessed directly.
|
||||||
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
|
||||||
|
use Activitypub\Activity\Extended_Object\Place;
|
||||||
|
use Event_Bridge_For_ActivityPub\Activitypub\Transformer\Event;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ActivityPub Transformer for Event Organiser.
|
||||||
|
*
|
||||||
|
* @since 1.0.0
|
||||||
|
*/
|
||||||
|
final class Event_Organiser extends Event {
|
||||||
|
/**
|
||||||
|
* Extended constructor.
|
||||||
|
*
|
||||||
|
* The wp_object is overridden with a the wp_object with filters. This object
|
||||||
|
* also contains attributes specific to the Event organiser plugin like the
|
||||||
|
* occurrence id.
|
||||||
|
*
|
||||||
|
* @param WP_Post $wp_object The WordPress object.
|
||||||
|
* @param string $wp_taxonomy The taxonomy slug of the event post type.
|
||||||
|
*/
|
||||||
|
public function __construct( $wp_object, $wp_taxonomy ) {
|
||||||
|
parent::__construct( $wp_object, $wp_taxonomy );
|
||||||
|
$this->wp_object = get_posts(
|
||||||
|
array(
|
||||||
|
'ID' => $wp_object->ID,
|
||||||
|
'post_type' => 'event',
|
||||||
|
'suppress_filters' => false,
|
||||||
|
)
|
||||||
|
)[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the end time from the event object.
|
||||||
|
*/
|
||||||
|
public function get_end_time(): ?string {
|
||||||
|
return eo_get_the_end( 'Y-m-d\TH:i:s\Z', $this->wp_object->ID, $this->wp_object->occurrence_id );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the end time from the event object.
|
||||||
|
*/
|
||||||
|
public function get_start_time(): string {
|
||||||
|
return eo_get_the_start( 'Y-m-d\TH:i:s\Z', $this->wp_object->ID, $this->wp_object->occurrence_id );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get location from the event object.
|
||||||
|
*/
|
||||||
|
public function get_location(): ?Place {
|
||||||
|
$venue_id = eo_get_venue( $this->wp_object->ID );
|
||||||
|
|
||||||
|
if ( ! $venue_id ) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
$address = eo_get_venue_address( $venue_id );
|
||||||
|
|
||||||
|
$venue_name = eo_get_venue_name( $venue_id );
|
||||||
|
|
||||||
|
$address['streetAddress'] = $address['address'];
|
||||||
|
unset( $address['address'] );
|
||||||
|
|
||||||
|
$address['postalCode'] = $address['postcode'];
|
||||||
|
unset( $address['postcode'] );
|
||||||
|
|
||||||
|
$address['addressRegion'] = $address['state'];
|
||||||
|
unset( $address['state'] );
|
||||||
|
|
||||||
|
$address['addressLocality'] = $address['city'];
|
||||||
|
unset( $address['city'] );
|
||||||
|
|
||||||
|
$address['addressCountry'] = $address['country'];
|
||||||
|
unset( $address['country'] );
|
||||||
|
|
||||||
|
$address['type'] = 'PostalAddress';
|
||||||
|
|
||||||
|
$location = new Place();
|
||||||
|
$location->set_name( eo_get_venue_name( $this->wp_object->ID ) );
|
||||||
|
$location->set_latitude( eo_get_venue_lat( $this->wp_object->ID ) ?? null );
|
||||||
|
$location->set_longitude( eo_get_venue_lng( $this->wp_object->ID ) ?? null );
|
||||||
|
$location->set_address( $address );
|
||||||
|
$location->set_name( $venue_name );
|
||||||
|
$location->set_content( eo_get_venue_description( $venue_id ) );
|
||||||
|
|
||||||
|
return $location;
|
||||||
|
}
|
||||||
|
}
|
|
@ -2,18 +2,20 @@
|
||||||
/**
|
/**
|
||||||
* Replace the default ActivityPub Transformer
|
* Replace the default ActivityPub Transformer
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @license AGPL-3.0-or-later
|
* @license AGPL-3.0-or-later
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Activitypub\Transformer;
|
namespace Event_Bridge_For_ActivityPub\Activitypub\Transformer;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
|
||||||
use Activitypub\Activity\Extended_Object\Event as Event_Object;
|
use Activitypub\Activity\Extended_Object\Event as Event_Object;
|
||||||
use Activitypub\Activity\Extended_Object\Place;
|
use Activitypub\Activity\Extended_Object\Place;
|
||||||
|
use Activitypub\Shortcodes;
|
||||||
use Activitypub\Transformer\Post;
|
use Activitypub\Transformer\Post;
|
||||||
|
|
||||||
use DateTime;
|
use DateTime;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -118,7 +120,7 @@ abstract class Event extends Post {
|
||||||
if ( is_null( $this->wp_taxonomy ) ) {
|
if ( is_null( $this->wp_taxonomy ) ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
$current_category_mapping = \get_option( 'activitypub_event_bridge_event_category_mappings', array() );
|
$current_category_mapping = \get_option( 'event_bridge_for_activitypub_event_category_mappings', array() );
|
||||||
$terms = \get_the_terms( $this->wp_object, $this->wp_taxonomy );
|
$terms = \get_the_terms( $this->wp_object, $this->wp_taxonomy );
|
||||||
|
|
||||||
// Check if the event has a category set and if that category has a specific mapping return that one.
|
// Check if the event has a category set and if that category has a specific mapping return that one.
|
||||||
|
@ -126,7 +128,7 @@ abstract class Event extends Post {
|
||||||
return sanitize_text_field( $current_category_mapping[ $terms[0]->slug ] );
|
return sanitize_text_field( $current_category_mapping[ $terms[0]->slug ] );
|
||||||
} else {
|
} else {
|
||||||
// Return the default event category.
|
// Return the default event category.
|
||||||
return sanitize_text_field( \get_option( 'activitypub_event_bridge_default_event_category', 'MEETING' ) );
|
return sanitize_text_field( \get_option( 'event_bridge_for_activitypub_default_event_category', 'MEETING' ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -148,14 +150,14 @@ abstract class Event extends Post {
|
||||||
*
|
*
|
||||||
* This is mandatory and must be implemented in the final event transformer class.
|
* This is mandatory and must be implemented in the final event transformer class.
|
||||||
*/
|
*/
|
||||||
abstract protected function get_start_time(): string;
|
abstract public function get_start_time(): string;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the end time.
|
* Get the end time.
|
||||||
*
|
*
|
||||||
* This is not mandatory and therefore just return null by default.
|
* This is not mandatory and therefore just return null by default.
|
||||||
*/
|
*/
|
||||||
protected function get_end_time(): ?string {
|
public function get_end_time(): ?string {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -164,14 +166,14 @@ abstract class Event extends Post {
|
||||||
*
|
*
|
||||||
* This should be overridden in the actual event transformer.
|
* This should be overridden in the actual event transformer.
|
||||||
*/
|
*/
|
||||||
protected function get_location(): ?Place {
|
public function get_location(): ?Place {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Default value for the event status.
|
* Default value for the event status.
|
||||||
*/
|
*/
|
||||||
protected function get_status(): ?string {
|
public function get_status(): ?string {
|
||||||
return 'CONFIRMED';
|
return 'CONFIRMED';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -194,7 +196,7 @@ abstract class Event extends Post {
|
||||||
*
|
*
|
||||||
* @param ?string $time The time which needs to be formatted.
|
* @param ?string $time The time which needs to be formatted.
|
||||||
*/
|
*/
|
||||||
private static function format_time( $time ) {
|
protected static function format_time( $time ) {
|
||||||
if ( is_null( $time ) ) {
|
if ( is_null( $time ) ) {
|
||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
|
@ -205,24 +207,160 @@ abstract class Event extends Post {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Format a human readable address.
|
* Generates output for the 'ap_start_time' shortcode.
|
||||||
|
*
|
||||||
|
* @param ?array $atts The shortcode's attributes.
|
||||||
|
* @return string The formatted start date and time of the event.
|
||||||
*/
|
*/
|
||||||
protected function format_address(): string {
|
public function shortcode_start_time( $atts ) {
|
||||||
|
$start_timestamp = $this->get_start_time();
|
||||||
|
return $this->generate_time_output( $start_timestamp, $atts, '🗓️', __( 'Start', 'event-bridge-for-activitypub' ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generates output for the 'ap_end_time' shortcode.
|
||||||
|
*
|
||||||
|
* @param ?array $atts The shortcode's attributes.
|
||||||
|
* @return string The formatted end date and time of the event.
|
||||||
|
*/
|
||||||
|
public function shortcode_end_time( $atts ) {
|
||||||
|
$end_timestamp = $this->get_end_time();
|
||||||
|
return $this->generate_time_output( $end_timestamp, $atts, '⏳', __( 'End', 'event-bridge-for-activitypub' ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generates the formatted time output for a shortcode.
|
||||||
|
*
|
||||||
|
* @param int|null $timestamp The timestamp for the event time.
|
||||||
|
* @param array $atts The shortcode attributes.
|
||||||
|
* @param string $icon The icon to display.
|
||||||
|
* @param string $label The label to display (e.g., 'Start', 'End').
|
||||||
|
* @return string The formatted date and time, or an empty string if the timestamp is invalid.
|
||||||
|
*/
|
||||||
|
private function generate_time_output( $timestamp, $atts, $icon, $label ) {
|
||||||
|
if ( ! $timestamp ) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$args = shortcode_atts(
|
||||||
|
array(
|
||||||
|
'icon' => 'true',
|
||||||
|
'label' => 'true',
|
||||||
|
),
|
||||||
|
$atts
|
||||||
|
);
|
||||||
|
|
||||||
|
$args['icon'] = filter_var( $args['icon'], FILTER_VALIDATE_BOOLEAN );
|
||||||
|
$args['label'] = filter_var( $args['label'], FILTER_VALIDATE_BOOLEAN );
|
||||||
|
|
||||||
|
$output = array();
|
||||||
|
|
||||||
|
if ( $args['icon'] ) {
|
||||||
|
$output[] = $icon;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( $args['label'] ) {
|
||||||
|
$output[] = $label . ':';
|
||||||
|
}
|
||||||
|
|
||||||
|
$output[] = self::format_time( $timestamp );
|
||||||
|
|
||||||
|
return implode( ' ', $output );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generates output for the 'ap_location' shortcode.
|
||||||
|
*
|
||||||
|
* @param ?array $atts The shortcode's attributes.
|
||||||
|
* @return string The formatted location/address of the event.
|
||||||
|
*/
|
||||||
|
public function shortcode_location( $atts ) {
|
||||||
|
$args = shortcode_atts(
|
||||||
|
array(
|
||||||
|
'icon' => 'true',
|
||||||
|
'label' => 'true',
|
||||||
|
'country' => 'true',
|
||||||
|
'zip' => 'true',
|
||||||
|
'city' => 'true',
|
||||||
|
'street' => 'true',
|
||||||
|
'name' => 'true',
|
||||||
|
),
|
||||||
|
$atts,
|
||||||
|
'ap_location'
|
||||||
|
);
|
||||||
|
|
||||||
|
// Convert attributes to booleans.
|
||||||
|
$args = array_map(
|
||||||
|
function ( $value ) {
|
||||||
|
return filter_var( $value, FILTER_VALIDATE_BOOLEAN );
|
||||||
|
},
|
||||||
|
$args
|
||||||
|
);
|
||||||
|
|
||||||
$location = $this->get_location();
|
$location = $this->get_location();
|
||||||
if ( is_null( $location ) ) {
|
if ( ! $location ) {
|
||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
$address = $location->get_address();
|
|
||||||
if ( ! $address ) {
|
$output = array();
|
||||||
return $location->get_name();
|
if ( $args['icon'] ) {
|
||||||
|
$output[] = '📍';
|
||||||
}
|
}
|
||||||
|
if ( $args['label'] ) {
|
||||||
|
$output[] = esc_html__( 'Location', 'event-bridge-for-activitypub' ) . ':';
|
||||||
|
}
|
||||||
|
|
||||||
|
$output[] = self::format_address( $location->get_address(), $args );
|
||||||
|
|
||||||
|
// Join output array into a single string with spaces and return.
|
||||||
|
return implode( ' ', array_filter( $output ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Formats the address based on provided arguments.
|
||||||
|
*
|
||||||
|
* @param mixed $address The address data, either as a string or an array.
|
||||||
|
* @param array $args The arguments for which components to include.
|
||||||
|
* @return string The formatted address.
|
||||||
|
*/
|
||||||
|
protected static function format_address( $address, $args = null ) {
|
||||||
if ( is_string( $address ) ) {
|
if ( is_string( $address ) ) {
|
||||||
return $address;
|
return esc_html( $address );
|
||||||
}
|
}
|
||||||
if ( ! is_array( $address ) ) {
|
|
||||||
return '';
|
if ( is_null( $args ) ) {
|
||||||
|
$args = array(
|
||||||
|
'icon' => 'true',
|
||||||
|
'title' => 'true',
|
||||||
|
'country' => 'true',
|
||||||
|
'zip' => 'true',
|
||||||
|
'city' => 'true',
|
||||||
|
'street' => 'true',
|
||||||
|
'name' => 'true',
|
||||||
|
);
|
||||||
}
|
}
|
||||||
return isset( $address['locality'] ) ? $address['locality'] : '';
|
|
||||||
|
if ( is_array( $address ) ) {
|
||||||
|
$address_parts = array();
|
||||||
|
|
||||||
|
$components = array(
|
||||||
|
'name' => 'name',
|
||||||
|
'street' => 'streetAddress',
|
||||||
|
'zip' => 'postalCode',
|
||||||
|
'city' => 'addressLocality',
|
||||||
|
'country' => 'addressCountry',
|
||||||
|
);
|
||||||
|
|
||||||
|
foreach ( $components as $arg_key => $address_key ) {
|
||||||
|
if ( $args[ $arg_key ] && ! empty( $address[ $address_key ] ) ) {
|
||||||
|
$address_parts[] = esc_html( $address[ $address_key ] );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return implode( ', ', $address_parts );
|
||||||
|
}
|
||||||
|
|
||||||
|
return '';
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -235,10 +373,10 @@ abstract class Event extends Post {
|
||||||
$categories = array();
|
$categories = array();
|
||||||
|
|
||||||
// Add the federated category string.
|
// Add the federated category string.
|
||||||
require_once ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_DIR . '/includes/event-categories.php';
|
require_once EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_DIR . '/includes/event-categories.php';
|
||||||
$federated_category = $this->get_category();
|
$federated_category = $this->get_category();
|
||||||
if ( array_key_exists( $federated_category, ACTIVITYPUB_EVENT_BRIDGE_EVENT_CATEGORIES ) ) {
|
if ( array_key_exists( $federated_category, EVENT_BRIDGE_FOR_ACTIVITYPUB_EVENT_CATEGORIES ) ) {
|
||||||
$categories[] = ACTIVITYPUB_EVENT_BRIDGE_EVENT_CATEGORIES[ $federated_category ];
|
$categories[] = EVENT_BRIDGE_FOR_ACTIVITYPUB_EVENT_CATEGORIES[ $federated_category ];
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add all category terms.
|
// Add all category terms.
|
||||||
|
@ -255,6 +393,68 @@ abstract class Event extends Post {
|
||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Register the shortcodes.
|
||||||
|
*/
|
||||||
|
public function register_shortcodes() {
|
||||||
|
foreach ( get_class_methods( self::class ) as $function ) {
|
||||||
|
if ( 'shortcode_' === substr( $function, 0, 10 ) ) {
|
||||||
|
add_shortcode( 'ap_' . substr( $function, 10, strlen( $function ) ), array( $this, $function ) );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Register the shortcodes.
|
||||||
|
*/
|
||||||
|
public function unregister_shortcodes() {
|
||||||
|
foreach ( get_class_methods( self::class ) as $function ) {
|
||||||
|
if ( 'shortcode_' === substr( $function, 0, 10 ) ) {
|
||||||
|
remove_shortcode( 'ap_' . substr( $function, 10, strlen( $function ) ), array( $this, $function ) );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the summary.
|
||||||
|
*/
|
||||||
|
public function get_summary(): ?string {
|
||||||
|
if ( 'preset' === get_option( 'event_bridge_for_activitypub_summary_type', 'preset' ) ) {
|
||||||
|
return $this->format_preset_summary();
|
||||||
|
}
|
||||||
|
|
||||||
|
// phpcs:ignore WordPress.WP.GlobalVariablesOverride.Prohibited
|
||||||
|
$post = $this->wp_object;
|
||||||
|
$summary = $this->get_event_summary_template();
|
||||||
|
|
||||||
|
// It seems that shortcodes are only applied to published posts.
|
||||||
|
if ( is_preview() ) {
|
||||||
|
$post->post_status = 'publish';
|
||||||
|
}
|
||||||
|
|
||||||
|
// Register our shortcodes just in time.
|
||||||
|
|
||||||
|
Shortcodes::register();
|
||||||
|
$this->register_shortcodes();
|
||||||
|
|
||||||
|
// Fill in the shortcodes.
|
||||||
|
\setup_postdata( $post );
|
||||||
|
$summary = \do_shortcode( $summary );
|
||||||
|
\wp_reset_postdata();
|
||||||
|
|
||||||
|
$summary = \wpautop( $summary );
|
||||||
|
$summary = \preg_replace( '/[\n\r\t]/', '', $summary );
|
||||||
|
$summary = \trim( $summary );
|
||||||
|
|
||||||
|
$summary = \apply_filters( 'event_bridge_for_activitypub_the_summary', $summary, $post );
|
||||||
|
|
||||||
|
// Unregister the shortcodes.
|
||||||
|
Shortcodes::unregister();
|
||||||
|
$this->unregister_shortcodes();
|
||||||
|
|
||||||
|
return $summary;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a custom summary.
|
* Create a custom summary.
|
||||||
*
|
*
|
||||||
|
@ -263,7 +463,7 @@ abstract class Event extends Post {
|
||||||
*
|
*
|
||||||
* @return string $summary The custom event summary.
|
* @return string $summary The custom event summary.
|
||||||
*/
|
*/
|
||||||
public function get_summary(): ?string {
|
public function format_preset_summary(): ?string {
|
||||||
add_filter( 'activitypub_object_content_template', array( self::class, 'remove_ap_permalink_from_template' ), 2, 2 );
|
add_filter( 'activitypub_object_content_template', array( self::class, 'remove_ap_permalink_from_template' ), 2, 2 );
|
||||||
$excerpt = $this->retrieve_excerpt();
|
$excerpt = $this->retrieve_excerpt();
|
||||||
// BeforeFirstRelease: decide whether this should be a admin setting.
|
// BeforeFirstRelease: decide whether this should be a admin setting.
|
||||||
|
@ -274,25 +474,29 @@ abstract class Event extends Post {
|
||||||
remove_filter( 'activitypub_object_content_template', array( self::class, 'remove_ap_permalink_from_template' ) );
|
remove_filter( 'activitypub_object_content_template', array( self::class, 'remove_ap_permalink_from_template' ) );
|
||||||
|
|
||||||
$category = $this->format_categories();
|
$category = $this->format_categories();
|
||||||
$start_time = $this->format_start_time();
|
$start_time = $this->get_start_time();
|
||||||
$end_time = $this->format_end_time();
|
$end_time = $this->get_end_time();
|
||||||
$address = $this->format_address();
|
$address = $this->format_address( $this->get_location() );
|
||||||
|
$time_atts = array(
|
||||||
|
'icon' => true,
|
||||||
|
'label' => true,
|
||||||
|
);
|
||||||
|
|
||||||
$formatted_items = array();
|
$formatted_items = array();
|
||||||
if ( ! empty( $category ) ) {
|
if ( ! empty( $category ) ) {
|
||||||
$formatted_items[] = '🏷️ ' . __( 'Category', 'activitypub-event-bridge' ) . ': ' . $category;
|
$formatted_items[] = '🏷️ ' . __( 'Category', 'event-bridge-for-activitypub' ) . ': ' . $category;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( ! empty( $start_time ) ) {
|
if ( ! empty( $start_time ) ) {
|
||||||
$formatted_items[] = '🗓️ ' . __( 'Start', 'activitypub-event-bridge' ) . ': ' . $start_time;
|
$formatted_items[] = $this->generate_time_output( $start_time, $time_atts, '🗓️', __( 'Start', 'event-bridge-for-activitypub' ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( ! empty( $end_time ) ) {
|
if ( ! empty( $end_time ) ) {
|
||||||
$formatted_items[] = '⏳ ' . __( 'End', 'activitypub-event-bridge' ) . ': ' . $end_time;
|
$formatted_items[] = $this->generate_time_output( $end_time, $time_atts, '⏳', __( 'End', 'event-bridge-for-activitypub' ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( ! empty( $address ) ) {
|
if ( ! empty( $address ) ) {
|
||||||
$formatted_items[] = '📍 ' . __( 'Address', 'activitypub-event-bridge' ) . ': ' . $address;
|
$formatted_items[] = '📍 ' . __( 'Address', 'event-bridge-for-activitypub' ) . ': ' . $address;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Compose the summary based on the number of meta items.
|
// Compose the summary based on the number of meta items.
|
||||||
|
@ -308,6 +512,18 @@ abstract class Event extends Post {
|
||||||
return $summary;
|
return $summary;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the template to use to generate the summary of the ActivityStreams representation of an event post.
|
||||||
|
*
|
||||||
|
* @return string The Template.
|
||||||
|
*/
|
||||||
|
protected function get_event_summary_template() {
|
||||||
|
$summary = \get_option( 'event_bridge_for_activitypub_custom_summary', EVENT_BRIDGE_FOR_ACTIVITYPUB_CUSTOM_SUMMARY );
|
||||||
|
$template = $summary ?? EVENT_BRIDGE_FOR_ACTIVITYPUB_CUSTOM_SUMMARY;
|
||||||
|
|
||||||
|
return apply_filters( 'event_bridge_for_activitypub_summary_template', $template, $this->wp_object );
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* By default set the timezone of the WordPress site.
|
* By default set the timezone of the WordPress site.
|
||||||
*
|
*
|
||||||
|
|
|
@ -4,17 +4,17 @@
|
||||||
*
|
*
|
||||||
* @link https://support.themewinter.com/docs/plugins/docs-category/eventin/
|
* @link https://support.themewinter.com/docs/plugins/docs-category/eventin/
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @license AGPL-3.0-or-later
|
* @license AGPL-3.0-or-later
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Activitypub\Transformer;
|
namespace Event_Bridge_For_ActivityPub\Activitypub\Transformer;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
|
||||||
use Activitypub\Activity\Extended_Object\Place;
|
use Activitypub\Activity\Extended_Object\Place;
|
||||||
use ActivityPub_Event_Bridge\Activitypub\Transformer\Event;
|
use Event_Bridge_For_ActivityPub\Activitypub\Transformer\Event;
|
||||||
use DateTime;
|
use DateTime;
|
||||||
use DateTimeZone;
|
use DateTimeZone;
|
||||||
use Etn\Core\Event\Event_Model;
|
use Etn\Core\Event\Event_Model;
|
||||||
|
|
78
includes/activitypub/transformer/class-eventprime.php
Normal file
78
includes/activitypub/transformer/class-eventprime.php
Normal file
|
@ -0,0 +1,78 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* ActivityPub Transformer for the plugin EventPrime.
|
||||||
|
*
|
||||||
|
* @package Event_Bridge_For_ActivityPub
|
||||||
|
* @license AGPL-3.0-or-later
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Event_Bridge_For_ActivityPub\Activitypub\Transformer;
|
||||||
|
|
||||||
|
// Exit if accessed directly.
|
||||||
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
|
||||||
|
use Activitypub\Activity\Extended_Object\Place;
|
||||||
|
use Event_Bridge_For_ActivityPub\Activitypub\Transformer\Event;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ActivityPub Transformer for VS Event
|
||||||
|
*
|
||||||
|
* @since 1.0.0
|
||||||
|
*/
|
||||||
|
final class EventPrime extends Event {
|
||||||
|
/**
|
||||||
|
* Get the end time from the event object.
|
||||||
|
*/
|
||||||
|
public function get_end_time(): ?string {
|
||||||
|
$timestamp = get_post_meta( $this->wp_object->ID, 'em_end_date', true );
|
||||||
|
if ( $timestamp ) {
|
||||||
|
return \gmdate( 'Y-m-d\TH:i:s\Z', $timestamp );
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the end time from the event object.
|
||||||
|
*/
|
||||||
|
public function get_start_time(): string {
|
||||||
|
$timestamp = get_post_meta( $this->wp_object->ID, 'em_start_date', true );
|
||||||
|
if ( $timestamp ) {
|
||||||
|
return \gmdate( 'Y-m-d\TH:i:s\Z', $timestamp );
|
||||||
|
} else {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get location from the event object.
|
||||||
|
*/
|
||||||
|
public function get_location(): ?Place {
|
||||||
|
$venue_term_id = get_post_meta( $this->wp_object->ID, 'em_venue', true );
|
||||||
|
if ( ! $venue_term_id ) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
$venue = wp_get_post_terms( $this->wp_object->ID, 'em_venue' );
|
||||||
|
|
||||||
|
if ( empty( $venue ) ) {
|
||||||
|
return null;
|
||||||
|
} else {
|
||||||
|
$venue = $venue[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
$place = new Place();
|
||||||
|
|
||||||
|
$place->set_name( $venue->name );
|
||||||
|
$place->set_content( $venue->description );
|
||||||
|
|
||||||
|
$address = get_term_meta( $venue->term_id, 'em_address', true );
|
||||||
|
$display_address = get_term_meta( $venue->term_id, 'em_display_address_on_frontend', true );
|
||||||
|
|
||||||
|
if ( $address && $display_address ) {
|
||||||
|
$place->set_address( get_term_meta( $venue->term_id, 'em_address', true ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
return $place;
|
||||||
|
}
|
||||||
|
}
|
|
@ -2,17 +2,17 @@
|
||||||
/**
|
/**
|
||||||
* ActivityPub Transformer for the plugin Very Simple Event List.
|
* ActivityPub Transformer for the plugin Very Simple Event List.
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @license AGPL-3.0-or-later
|
* @license AGPL-3.0-or-later
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Activitypub\Transformer;
|
namespace Event_Bridge_For_ActivityPub\Activitypub\Transformer;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
|
||||||
use Activitypub\Activity\Extended_Object\Place;
|
use Activitypub\Activity\Extended_Object\Place;
|
||||||
use ActivityPub_Event_Bridge\Activitypub\Transformer\Event as Event_Transformer;
|
use Event_Bridge_For_ActivityPub\Activitypub\Transformer\Event as Event_Transformer;
|
||||||
use DateTime;
|
use DateTime;
|
||||||
use DateTimeZone;
|
use DateTimeZone;
|
||||||
use EM_Event;
|
use EM_Event;
|
||||||
|
|
|
@ -1,19 +1,19 @@
|
||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* ActivityPub Transformer for the plugin Very Simple Event List.
|
* ActivityPub Transformer for the GatherPress event plugin.
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @license AGPL-3.0-or-later
|
* @license AGPL-3.0-or-later
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Activitypub\Transformer;
|
namespace Event_Bridge_For_ActivityPub\Activitypub\Transformer;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
|
||||||
use Activitypub\Activity\Extended_Object\Event as Event_Object;
|
use Activitypub\Activity\Extended_Object\Event as Event_Object;
|
||||||
use Activitypub\Activity\Extended_Object\Place;
|
use Activitypub\Activity\Extended_Object\Place;
|
||||||
use ActivityPub_Event_Bridge\Activitypub\Transformer\Event;
|
use Event_Bridge_For_ActivityPub\Activitypub\Transformer\Event;
|
||||||
use GatherPress\Core\Event as GatherPress_Event;
|
use GatherPress\Core\Event as GatherPress_Event;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -73,14 +73,14 @@ final class GatherPress extends Event {
|
||||||
/**
|
/**
|
||||||
* Get the end time from the event object.
|
* Get the end time from the event object.
|
||||||
*/
|
*/
|
||||||
protected function get_end_time(): ?string {
|
public function get_end_time(): ?string {
|
||||||
return $this->gp_event->get_datetime_end( 'Y-m-d\TH:i:s\Z' );
|
return $this->gp_event->get_datetime_end( 'Y-m-d\TH:i:s\Z' );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the end time from the event object.
|
* Get the end time from the event object.
|
||||||
*/
|
*/
|
||||||
protected function get_start_time(): string {
|
public function get_start_time(): string {
|
||||||
return $this->gp_event->get_datetime_start( 'Y-m-d\TH:i:s\Z' );
|
return $this->gp_event->get_datetime_start( 'Y-m-d\TH:i:s\Z' );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,17 +2,17 @@
|
||||||
/**
|
/**
|
||||||
* ActivityPub Tribe Transformer
|
* ActivityPub Tribe Transformer
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @license AGPL-3.0-or-later
|
* @license AGPL-3.0-or-later
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Activitypub\Transformer;
|
namespace Event_Bridge_For_ActivityPub\Activitypub\Transformer;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
|
||||||
use Activitypub\Activity\Extended_Object\Place;
|
use Activitypub\Activity\Extended_Object\Place;
|
||||||
use ActivityPub_Event_Bridge\Activitypub\Transformer\Event;
|
use Event_Bridge_For_ActivityPub\Activitypub\Transformer\Event;
|
||||||
|
|
||||||
use MEC;
|
use MEC;
|
||||||
use MEC\Events\Event as MEC_Event;
|
use MEC\Events\Event as MEC_Event;
|
||||||
|
|
|
@ -1,137 +0,0 @@
|
||||||
<?php
|
|
||||||
/**
|
|
||||||
* ActivityPub Transformer for the WordPress plugin "My Calendar – Accessible Event Manager".
|
|
||||||
*
|
|
||||||
* @see https://wordpress.org/plugins/my-calendar/
|
|
||||||
*
|
|
||||||
* @package Activitypub_Event_Extensions
|
|
||||||
* @license AGPL-3.0-or-later
|
|
||||||
*/
|
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Activitypub\Transformer;
|
|
||||||
|
|
||||||
// Exit if accessed directly.
|
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
|
||||||
|
|
||||||
use Activitypub\Activity\Extended_Object\Place;
|
|
||||||
use ActivityPub_Event_Bridge\Activitypub\Transformer\Event as Event_Transformer;
|
|
||||||
use DateTime;
|
|
||||||
use DateTimeZone;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ActivityPub Transformer for events from the WordPress plugin "My Calendar – Accessible Event Manager".
|
|
||||||
*
|
|
||||||
* @see https://wordpress.org/plugins/my-calendar/
|
|
||||||
*
|
|
||||||
* @since 1.0.0
|
|
||||||
*/
|
|
||||||
final class My_Calendar extends Event_Transformer {
|
|
||||||
/**
|
|
||||||
* Holds the My Calendar post object.
|
|
||||||
*
|
|
||||||
* @var object $event Event object.
|
|
||||||
*/
|
|
||||||
protected $mc_event;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Holds the My Calendar Schema object.
|
|
||||||
*
|
|
||||||
* @var array JSON/LD Schema for event.
|
|
||||||
*/
|
|
||||||
protected $mc_event_schema;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Extend the constructor, to also set the Event plugins API objects.
|
|
||||||
*
|
|
||||||
* This is a special class object form The Events Calendar which
|
|
||||||
* has a lot of useful functions, we make use of our getter functions.
|
|
||||||
*
|
|
||||||
* @param WP_Post $wp_object The WordPress object.
|
|
||||||
* @param string $wp_taxonomy The taxonomy slug of the event post type.
|
|
||||||
*/
|
|
||||||
public function __construct( $wp_object, $wp_taxonomy ) {
|
|
||||||
parent::__construct( $wp_object, $wp_taxonomy );
|
|
||||||
$mc_event_id = get_post_meta( $this->wp_object->ID, '_mc_event_id', true );
|
|
||||||
$this->mc_event = mc_get_event( $mc_event_id );
|
|
||||||
$this->mc_event_schema = mc_event_schema( $this->mc_event );
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Formats time from the plugin to the activitypub standard.
|
|
||||||
*
|
|
||||||
* @param string $date_string The plugins string representation for a date without time.
|
|
||||||
* @param string $time_string The plugins string representation for a time.
|
|
||||||
*
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
private function convert_time( $date_string, $time_string ): string {
|
|
||||||
// Create a DateTime object with the given date, time, and timezone.
|
|
||||||
$datetime = new DateTime( $date_string . ' ' . $time_string );
|
|
||||||
|
|
||||||
// Set the timezone for proper formatting.
|
|
||||||
$datetime->setTimezone( new DateTimeZone( 'UTC' ) );
|
|
||||||
|
|
||||||
// Format the DateTime object as 'Y-m-d\TH:i:s\Z'.
|
|
||||||
$formatted_date = $datetime->format( 'Y-m-d\TH:i:s\Z' );
|
|
||||||
return $formatted_date;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* Get the start time from the events metadata.
|
|
||||||
*
|
|
||||||
* @return string The events start date-time.
|
|
||||||
*/
|
|
||||||
public function get_start_time(): string {
|
|
||||||
return $this->convert_time( $this->mc_event->event_begin, $this->mc_event->event_time );
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the end time from the events metadata.
|
|
||||||
*
|
|
||||||
* @return string The events start end-time.
|
|
||||||
*/
|
|
||||||
public function get_end_time(): ?string {
|
|
||||||
return $this->convert_time( $this->mc_event->event_end, $this->mc_event->event_endtime );
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the event location.
|
|
||||||
*
|
|
||||||
* @return Place|null The place/venue if one is set.
|
|
||||||
*/
|
|
||||||
public function get_location(): ?Place {
|
|
||||||
if ( array_key_exists( 'location', $this->mc_event_schema ) && 'Place' === $this->mc_event_schema['location']['@type'] ) {
|
|
||||||
$mc_place = $this->mc_event_schema['location'];
|
|
||||||
|
|
||||||
$place = new Place();
|
|
||||||
$place->set_name( $mc_place['name'] );
|
|
||||||
$place->set_url( $mc_place['url'] );
|
|
||||||
$place->set_address( $mc_place['address'] );
|
|
||||||
|
|
||||||
if ( ! empty( $mc_place['geo'] ) ) {
|
|
||||||
$place->set_latitude( $mc_place['geo']['latitude'] );
|
|
||||||
$place->set_longitude( $mc_place['geo']['longitude'] );
|
|
||||||
}
|
|
||||||
return $place;
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get status of the event
|
|
||||||
*
|
|
||||||
* @return string status of the event
|
|
||||||
*/
|
|
||||||
public function get_status(): ?string {
|
|
||||||
return 'CONFIRMED'; // My Calendar doesn't implement canceled events.
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Extract the external participation url.
|
|
||||||
*
|
|
||||||
* @return ?string The external participation URL.
|
|
||||||
*/
|
|
||||||
public function get_external_participation_url(): ?string {
|
|
||||||
|
|
||||||
return $this->mc_event->event_tickets ? $this->mc_event->event_tickets : null;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -2,17 +2,17 @@
|
||||||
/**
|
/**
|
||||||
* ActivityPub Tribe Transformer
|
* ActivityPub Tribe Transformer
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @license AGPL-3.0-or-later
|
* @license AGPL-3.0-or-later
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Activitypub\Transformer;
|
namespace Event_Bridge_For_ActivityPub\Activitypub\Transformer;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
|
||||||
use Activitypub\Activity\Extended_Object\Place;
|
use Activitypub\Activity\Extended_Object\Place;
|
||||||
use ActivityPub_Event_Bridge\Activitypub\Transformer\Event;
|
use Event_Bridge_For_ActivityPub\Activitypub\Transformer\Event;
|
||||||
use WP_Post;
|
use WP_Post;
|
||||||
|
|
||||||
use function Activitypub\esc_hashtag;
|
use function Activitypub\esc_hashtag;
|
||||||
|
@ -72,7 +72,7 @@ final class The_Events_Calendar extends Event {
|
||||||
/**
|
/**
|
||||||
* Get the end time from the event object.
|
* Get the end time from the event object.
|
||||||
*/
|
*/
|
||||||
protected function get_end_time(): ?string {
|
public function get_end_time(): ?string {
|
||||||
if ( empty( $this->tribe_event->end_date ) ) {
|
if ( empty( $this->tribe_event->end_date ) ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -83,7 +83,7 @@ final class The_Events_Calendar extends Event {
|
||||||
/**
|
/**
|
||||||
* Get the end time from the event object.
|
* Get the end time from the event object.
|
||||||
*/
|
*/
|
||||||
protected function get_start_time(): string {
|
public function get_start_time(): string {
|
||||||
$date = date_create( $this->tribe_event->start_date, wp_timezone() );
|
$date = date_create( $this->tribe_event->start_date, wp_timezone() );
|
||||||
return \gmdate( 'Y-m-d\TH:i:s\Z', $date->getTimestamp() );
|
return \gmdate( 'Y-m-d\TH:i:s\Z', $date->getTimestamp() );
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,17 +2,17 @@
|
||||||
/**
|
/**
|
||||||
* ActivityPub Transformer for the plugin Very Simple Event List.
|
* ActivityPub Transformer for the plugin Very Simple Event List.
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @license AGPL-3.0-or-later
|
* @license AGPL-3.0-or-later
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Activitypub\Transformer;
|
namespace Event_Bridge_For_ActivityPub\Activitypub\Transformer;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
|
||||||
use Activitypub\Activity\Extended_Object\Place;
|
use Activitypub\Activity\Extended_Object\Place;
|
||||||
use ActivityPub_Event_Bridge\Activitypub\Transformer\Event as Event_Transformer;
|
use Event_Bridge_For_ActivityPub\Activitypub\Transformer\Event as Event_Transformer;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ActivityPub Transformer for VS Event.
|
* ActivityPub Transformer for VS Event.
|
||||||
|
@ -44,7 +44,7 @@ final class VS_Event_List extends Event_Transformer {
|
||||||
/**
|
/**
|
||||||
* Get the end time from the events metadata.
|
* Get the end time from the events metadata.
|
||||||
*/
|
*/
|
||||||
protected function get_end_time(): ?string {
|
public function get_end_time(): ?string {
|
||||||
if ( 'yes' === get_post_meta( $this->wp_object->ID, 'event-hide-end-time', true ) ) {
|
if ( 'yes' === get_post_meta( $this->wp_object->ID, 'event-hide-end-time', true ) ) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -58,7 +58,7 @@ final class VS_Event_List extends Event_Transformer {
|
||||||
/**
|
/**
|
||||||
* Get the end time from the events metadata.
|
* Get the end time from the events metadata.
|
||||||
*/
|
*/
|
||||||
protected function get_start_time(): string {
|
public function get_start_time(): string {
|
||||||
$start_time = get_post_meta( $this->wp_object->ID, 'event-start-date', true );
|
$start_time = get_post_meta( $this->wp_object->ID, 'event-start-date', true );
|
||||||
return \gmdate( 'Y-m-d\TH:i:s\Z', $start_time );
|
return \gmdate( 'Y-m-d\TH:i:s\Z', $start_time );
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,17 +2,17 @@
|
||||||
/**
|
/**
|
||||||
* ActivityPub Transformer for the plugin Very Simple Event List.
|
* ActivityPub Transformer for the plugin Very Simple Event List.
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @license AGPL-3.0-or-later
|
* @license AGPL-3.0-or-later
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Activitypub\Transformer;
|
namespace Event_Bridge_For_ActivityPub\Activitypub\Transformer;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
|
||||||
use Activitypub\Activity\Extended_Object\Place;
|
use Activitypub\Activity\Extended_Object\Place;
|
||||||
use ActivityPub_Event_Bridge\Activitypub\Transformer\Event as Event_Transformer;
|
use Event_Bridge_For_ActivityPub\Activitypub\Transformer\Event as Event_Transformer;
|
||||||
use DateTime;
|
use DateTime;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -101,7 +101,7 @@ final class WP_Event_Manager extends Event_Transformer {
|
||||||
if ( str_starts_with( $event_link_url, 'http' ) ) {
|
if ( str_starts_with( $event_link_url, 'http' ) ) {
|
||||||
return array(
|
return array(
|
||||||
'type' => 'Link',
|
'type' => 'Link',
|
||||||
'name' => \esc_html__( 'Video URL', 'activitypub-event-bridge' ),
|
'name' => \esc_html__( 'Video URL', 'event-bridge-for-activitypub' ),
|
||||||
'href' => \esc_url( $event_link_url ),
|
'href' => \esc_url( $event_link_url ),
|
||||||
'mediaType' => 'text/html',
|
'mediaType' => 'text/html',
|
||||||
);
|
);
|
||||||
|
|
|
@ -4,17 +4,17 @@
|
||||||
*
|
*
|
||||||
* Notices for guiding to proper configuration of ActivityPub with event plugins.
|
* Notices for guiding to proper configuration of ActivityPub with event plugins.
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
* @license AGPL-3.0-or-later
|
* @license AGPL-3.0-or-later
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Admin;
|
namespace Event_Bridge_For_ActivityPub\Admin;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
|
||||||
use ActivityPub_Event_Bridge\Plugins\Event_Plugin;
|
use Event_Bridge_For_ActivityPub\Integrations\Event_Plugin;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class responsible for Event Plugin related admin notices.
|
* Class responsible for Event Plugin related admin notices.
|
||||||
|
@ -69,17 +69,25 @@ class Event_Plugin_Admin_Notices {
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
private function do_admin_notice_post_type_not_activitypub_enabled(): void {
|
private function do_admin_notice_post_type_not_activitypub_enabled(): void {
|
||||||
$event_plugin_data = get_plugin_data( WP_PLUGIN_DIR . '/' . $this->event_plugin::get_plugin_file() );
|
$all_plugins = get_plugins();
|
||||||
|
$event_plugin_file = $this->event_plugin::get_relative_plugin_file();
|
||||||
|
if ( isset( $all_plugins[ $event_plugin_file ]['Name'] ) ) {
|
||||||
|
$event_plugin_name = $all_plugins[ $event_plugin_file ]['Name'];
|
||||||
|
} elseif ( isset( get_mu_plugins()[ $event_plugin_file ]['Name'] ) ) {
|
||||||
|
$event_plugin_name = get_mu_plugins()[ $event_plugin_file ]['Name'];
|
||||||
|
} else {
|
||||||
|
return;
|
||||||
|
}
|
||||||
$activitypub_plugin_data = get_plugin_data( ACTIVITYPUB_PLUGIN_FILE );
|
$activitypub_plugin_data = get_plugin_data( ACTIVITYPUB_PLUGIN_FILE );
|
||||||
$notice = sprintf(
|
$notice = sprintf(
|
||||||
/* translators: 1: the name of the event plugin a admin notice is shown. 2: The name of the ActivityPub plugin. */
|
/* translators: 1: the name of the event plugin a admin notice is shown. 2: The name of the ActivityPub plugin. */
|
||||||
_x(
|
_x(
|
||||||
'You have installed the <i>%1$s</i> plugin, but the event post type of the plugin <i>%2$s</i> is <b>not enabled</b> in the <a href="%3$s">%1$s settings</a>.',
|
'You have installed the <i>%1$s</i> plugin, but the event post type of the plugin <i>%2$s</i> is <b>not enabled</b> in the <a href="%3$s">%1$s settings</a>.',
|
||||||
'admin notice',
|
'admin notice',
|
||||||
'activitypub-event-bridge'
|
'event-bridge-for-activitypub'
|
||||||
),
|
),
|
||||||
esc_html( $activitypub_plugin_data['Name'] ),
|
esc_html( $activitypub_plugin_data['Name'] ),
|
||||||
esc_html( $event_plugin_data['Name'] ),
|
esc_html( $event_plugin_name ),
|
||||||
admin_url( 'options-general.php?page=activitypub&tab=settings' )
|
admin_url( 'options-general.php?page=activitypub&tab=settings' )
|
||||||
);
|
);
|
||||||
$allowed_html = array(
|
$allowed_html = array(
|
||||||
|
|
|
@ -4,12 +4,12 @@
|
||||||
*
|
*
|
||||||
* Notices for guiding to proper configuration of this plugin.
|
* Notices for guiding to proper configuration of this plugin.
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
* @license AGPL-3.0-or-later
|
* @license AGPL-3.0-or-later
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Admin;
|
namespace Event_Bridge_For_ActivityPub\Admin;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
@ -29,7 +29,7 @@ class General_Admin_Notices {
|
||||||
*/
|
*/
|
||||||
const ACTIVITYPUB_PLUGIN_URL = 'https://wordpress.org/plugins/activitypub';
|
const ACTIVITYPUB_PLUGIN_URL = 'https://wordpress.org/plugins/activitypub';
|
||||||
|
|
||||||
const ACTIVITYPUB_EVENT_BRIDGE_SUPPORTED_EVENT_PLUGINS_URL = 'https://code.event-federation.eu/Event-Federation/wordpress-activitypub-event-bridge#events-plugin-that-will-be-supported-at-first';
|
const EVENT_BRIDGE_FOR_ACTIVITYPUB_SUPPORTED_EVENT_PLUGINS_URL = 'https://code.event-federation.eu/Event-Federation/wordpress-event-bridge-for-activitypub#events-plugin-that-will-be-supported-at-first';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allowed HTML for admin notices.
|
* Allowed HTML for admin notices.
|
||||||
|
@ -54,9 +54,9 @@ class General_Admin_Notices {
|
||||||
return sprintf(
|
return sprintf(
|
||||||
/* translators: 1: An URL that points to the ActivityPub plugin. */
|
/* translators: 1: An URL that points to the ActivityPub plugin. */
|
||||||
_x(
|
_x(
|
||||||
'For the ActivityPub Event Bridge to work, you will need to install and activate the <a href="%1$s">ActivityPub</a> plugin.',
|
'For the Event Bridge for ActivityPub to work, you will need to install and activate the <a href="%1$s">ActivityPub</a> plugin.',
|
||||||
'admin notice',
|
'admin notice',
|
||||||
'activitypub-event-bridge'
|
'event-bridge-for-activitypub'
|
||||||
),
|
),
|
||||||
esc_html( self::ACTIVITYPUB_PLUGIN_URL )
|
esc_html( self::ACTIVITYPUB_PLUGIN_URL )
|
||||||
);
|
);
|
||||||
|
@ -71,12 +71,12 @@ class General_Admin_Notices {
|
||||||
return sprintf(
|
return sprintf(
|
||||||
/* translators: 1: The name of the ActivityPub plugin. 2: The minimum required version number of the ActivityPub plugin. */
|
/* translators: 1: The name of the ActivityPub plugin. 2: The minimum required version number of the ActivityPub plugin. */
|
||||||
_x(
|
_x(
|
||||||
'Please upgrade your <a href="%1$s">ActivityPub</a> plugin. At least version %2$s is required for the ActivityPub Event Bridge to work.',
|
'Please upgrade your <a href="%1$s">ActivityPub</a> plugin. At least version %2$s is required for the Event Bridge for ActivityPub to work.',
|
||||||
'admin notice',
|
'admin notice',
|
||||||
'activitypub-event-bridge'
|
'event-bridge-for-activitypub'
|
||||||
),
|
),
|
||||||
esc_html( self::ACTIVITYPUB_PLUGIN_URL ),
|
esc_html( self::ACTIVITYPUB_PLUGIN_URL ),
|
||||||
esc_html( ACTIVITYPUB_EVENT_BRIDGE_ACTIVITYPUB_PLUGIN_MIN_VERSION )
|
esc_html( EVENT_BRIDGE_FOR_ACTIVITYPUB_ACTIVITYPUB_PLUGIN_MIN_VERSION )
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -89,12 +89,12 @@ class General_Admin_Notices {
|
||||||
return sprintf(
|
return sprintf(
|
||||||
/* translators: 1: An URL to the list of supported event plugins. */
|
/* translators: 1: An URL to the list of supported event plugins. */
|
||||||
_x(
|
_x(
|
||||||
'The Plugin <i>ActivityPub Event Bridge</i> is of no use, because you do not have installed and activated a supported Event Plugin.
|
'The Plugin <i>Event Bridge for ActivityPub</i> is of no use, because you do not have installed and activated a supported Event Plugin.
|
||||||
<br> For a list of supported Event Plugins see <a href="%1$s">here</a>.',
|
<br> For a list of supported Event Plugins see <a href="%1$s">here</a>.',
|
||||||
'admin notice',
|
'admin notice',
|
||||||
'activitypub-event-bridge'
|
'event-bridge-for-activitypub'
|
||||||
),
|
),
|
||||||
esc_html( self::ACTIVITYPUB_EVENT_BRIDGE_SUPPORTED_EVENT_PLUGINS_URL )
|
esc_html( self::EVENT_BRIDGE_FOR_ACTIVITYPUB_SUPPORTED_EVENT_PLUGINS_URL )
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -107,12 +107,12 @@ class General_Admin_Notices {
|
||||||
return sprintf(
|
return sprintf(
|
||||||
/* translators: 1: An URL to the list of supported event plugins. */
|
/* translators: 1: An URL to the list of supported event plugins. */
|
||||||
_x(
|
_x(
|
||||||
'The Plugin <i>ActivityPub Event Bridge</i> is of no use, because you do not have installed and activated a supported Event Plugin.
|
'The Plugin <i>Event Bridge for ActivityPub</i> is of no use, because you do not have installed and activated a supported Event Plugin.
|
||||||
<br> For a list of supported Event Plugins see <a href="%1$s">here</a>.',
|
<br> For a list of supported Event Plugins see <a href="%1$s">here</a>.',
|
||||||
'admin notice',
|
'admin notice',
|
||||||
'activitypub-event-bridge'
|
'event-bridge-for-activitypub'
|
||||||
),
|
),
|
||||||
esc_html( self::ACTIVITYPUB_EVENT_BRIDGE_SUPPORTED_EVENT_PLUGINS_URL )
|
esc_html( self::EVENT_BRIDGE_FOR_ACTIVITYPUB_SUPPORTED_EVENT_PLUGINS_URL )
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,11 +5,11 @@
|
||||||
* @package Activitypub_Event_Bridge
|
* @package Activitypub_Event_Bridge
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Admin;
|
namespace Event_Bridge_For_ActivityPub\Admin;
|
||||||
|
|
||||||
use Activitypub\Transformer\Factory as Transformer_Factory;
|
use Activitypub\Transformer\Factory as Transformer_Factory;
|
||||||
use ActivityPub_Event_Bridge\Plugins\Event_Plugin;
|
use Event_Bridge_For_ActivityPub\Integrations\Event_Plugin;
|
||||||
use ActivityPub_Event_Bridge\Setup;
|
use Event_Bridge_For_ActivityPub\Setup;
|
||||||
use WP_Query;
|
use WP_Query;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -32,8 +32,8 @@ class Health_Check {
|
||||||
* @return array The filtered test array.
|
* @return array The filtered test array.
|
||||||
*/
|
*/
|
||||||
public static function add_tests( $tests ) {
|
public static function add_tests( $tests ) {
|
||||||
$tests['direct']['activitypub_event_bridge_test'] = array(
|
$tests['direct']['event_bridge_for_activitypub_test'] = array(
|
||||||
'label' => __( 'ActivityPub Event Transformer Test', 'activitypub-event-bridge' ),
|
'label' => __( 'ActivityPub Event Transformer Test', 'event-bridge-for-activitypub' ),
|
||||||
'test' => array( self::class, 'test_event_transformation' ),
|
'test' => array( self::class, 'test_event_transformation' ),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -47,15 +47,15 @@ class Health_Check {
|
||||||
*/
|
*/
|
||||||
public static function test_event_transformation() {
|
public static function test_event_transformation() {
|
||||||
$result = array(
|
$result = array(
|
||||||
'label' => \__( 'Transformation of Events to a valid ActivityStreams representation.', 'activitypub-event-bridge' ),
|
'label' => \__( 'Transformation of Events to a valid ActivityStreams representation.', 'event-bridge-for-activitypub' ),
|
||||||
'status' => 'good',
|
'status' => 'good',
|
||||||
'badge' => array(
|
'badge' => array(
|
||||||
'label' => \__( 'ActivityPub Event Bridge', 'activitypub-event-bridge' ),
|
'label' => \__( 'Event Bridge for ActivityPub', 'event-bridge-for-activitypub' ),
|
||||||
'color' => 'green',
|
'color' => 'green',
|
||||||
),
|
),
|
||||||
'description' => \sprintf(
|
'description' => \sprintf(
|
||||||
'<p>%s</p>',
|
'<p>%s</p>',
|
||||||
\__( 'The transformation of your most recent events was successful.', 'activitypub-event-bridge' )
|
\__( 'The transformation of your most recent events was successful.', 'event-bridge-for-activitypub' )
|
||||||
),
|
),
|
||||||
'actions' => '',
|
'actions' => '',
|
||||||
'test' => 'test_event_transformation',
|
'test' => 'test_event_transformation',
|
||||||
|
@ -68,7 +68,7 @@ class Health_Check {
|
||||||
}
|
}
|
||||||
|
|
||||||
$result['status'] = 'critical';
|
$result['status'] = 'critical';
|
||||||
$result['label'] = \__( 'One or more of your most recent events failed to transform to ActivityPub', 'activitypub-event-bridge' );
|
$result['label'] = \__( 'One or more of your most recent events failed to transform to ActivityPub', 'event-bridge-for-activitypub' );
|
||||||
$result['badge']['color'] = 'red';
|
$result['badge']['color'] = 'red';
|
||||||
$result['description'] = \sprintf(
|
$result['description'] = \sprintf(
|
||||||
'<p>%s</p>',
|
'<p>%s</p>',
|
||||||
|
@ -114,7 +114,9 @@ class Health_Check {
|
||||||
*/
|
*/
|
||||||
public static function get_most_recent_event_posts( $event_post_type = null, $number_of_posts = 5 ) {
|
public static function get_most_recent_event_posts( $event_post_type = null, $number_of_posts = 5 ) {
|
||||||
if ( ! $event_post_type ) {
|
if ( ! $event_post_type ) {
|
||||||
$event_post_type = Setup::get_instance()->get_active_event_plugins()[0]->get_post_type();
|
$active_event_plugins = Setup::get_instance()->get_active_event_plugins();
|
||||||
|
$active_event_plugin = reset( $active_event_plugins );
|
||||||
|
$event_post_type = $active_event_plugin->get_post_type();
|
||||||
}
|
}
|
||||||
|
|
||||||
$args = array(
|
$args = array(
|
||||||
|
@ -148,7 +150,7 @@ class Health_Check {
|
||||||
$active_event_plugins = Setup::get_instance()->get_active_event_plugins();
|
$active_event_plugins = Setup::get_instance()->get_active_event_plugins();
|
||||||
$info = array();
|
$info = array();
|
||||||
foreach ( $active_event_plugins as $active_event_plugin ) {
|
foreach ( $active_event_plugins as $active_event_plugin ) {
|
||||||
$event_plugin_file = $active_event_plugin->get_plugin_file();
|
$event_plugin_file = $active_event_plugin->get_relative_plugin_file();
|
||||||
$event_plugin_data = \get_plugin_data( $event_plugin_file );
|
$event_plugin_data = \get_plugin_data( $event_plugin_file );
|
||||||
$event_plugin_name = isset( $event_plugin_data['Plugin Name'] ) ? $event_plugin_data['Plugin Name'] : 'Name not found';
|
$event_plugin_name = isset( $event_plugin_data['Plugin Name'] ) ? $event_plugin_data['Plugin Name'] : 'Name not found';
|
||||||
$event_plugin_version = isset( $event_plugin_version['Plugin Version'] ) ? $event_plugin_version['Plugin Version'] : 'Version not found';
|
$event_plugin_version = isset( $event_plugin_version['Plugin Version'] ) ? $event_plugin_version['Plugin Version'] : 'Version not found';
|
||||||
|
@ -168,12 +170,12 @@ class Health_Check {
|
||||||
* @return array The extended information.
|
* @return array The extended information.
|
||||||
*/
|
*/
|
||||||
public static function add_debug_information( $info ) {
|
public static function add_debug_information( $info ) {
|
||||||
$info['activitypub_event_bridge'] = array(
|
$info['event_bridge_for_activitypub'] = array(
|
||||||
'label' => __( 'ActivityPub Event Bridge', 'activitypub-event-bridge' ),
|
'label' => __( 'Event Bridge for ActivityPub', 'event-bridge-for-activitypub' ),
|
||||||
'fields' => array(
|
'fields' => array(
|
||||||
'plugin_version' => array(
|
'plugin_version' => array(
|
||||||
'label' => __( 'Plugin Version', 'activitypub-event-bridge' ),
|
'label' => __( 'Plugin Version', 'event-bridge-for-activitypub' ),
|
||||||
'value' => ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_VERSION,
|
'value' => EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_VERSION,
|
||||||
'private' => true,
|
'private' => true,
|
||||||
),
|
),
|
||||||
'active_event_plugins' => self::get_info_about_active_event_plugins(),
|
'active_event_plugins' => self::get_info_about_active_event_plugins(),
|
||||||
|
|
|
@ -3,32 +3,32 @@
|
||||||
* General settings class.
|
* General settings class.
|
||||||
*
|
*
|
||||||
* This file contains the General class definition, which handles the "General" settings
|
* This file contains the General class definition, which handles the "General" settings
|
||||||
* page for the Activitypub Event Bridge Plugin, providing options for configuring various general settings.
|
* page for the Event Bridge for ActivityPub Plugin, providing options for configuring various general settings.
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Admin;
|
namespace Event_Bridge_For_ActivityPub\Admin;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
|
||||||
use ActivityPub_Event_Bridge\Plugins\Event_Plugin;
|
use Event_Bridge_For_ActivityPub\Integrations\Event_Plugin;
|
||||||
use ActivityPub_Event_Bridge\Setup;
|
use Event_Bridge_For_ActivityPub\Setup;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class responsible for the Activitypub Event Bridge related Settings.
|
* Class responsible for the Event Bridge for ActivityPub related Settings.
|
||||||
*
|
*
|
||||||
* Class which handles the "General" settings page for the Activitypub Event Bridge Plugin,
|
* Class which handles the "General" settings page for the Event Bridge for ActivityPub Plugin,
|
||||||
* providing options for configuring various general settings.
|
* providing options for configuring various general settings.
|
||||||
*
|
*
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
class Settings_Page {
|
class Settings_Page {
|
||||||
const STATIC = 'ActivityPub_Event_Bridge\Admin\Settings_Page';
|
const STATIC = 'Event_Bridge_For_ActivityPub\Admin\Settings_Page';
|
||||||
|
|
||||||
const SETTINGS_SLUG = 'activitypub-event-bridge';
|
const SETTINGS_SLUG = 'event-bridge-for-activitypub';
|
||||||
/**
|
/**
|
||||||
* Warning if the plugin is Active and the ActivityPub plugin is not.
|
* Warning if the plugin is Active and the ActivityPub plugin is not.
|
||||||
*
|
*
|
||||||
|
@ -36,8 +36,8 @@ class Settings_Page {
|
||||||
*/
|
*/
|
||||||
public static function admin_menu(): void {
|
public static function admin_menu(): void {
|
||||||
\add_options_page(
|
\add_options_page(
|
||||||
'Activitypub Event Bridge',
|
'Event Bridge for ActivityPub',
|
||||||
__( 'ActivityPub Event Bridge', 'activitypub-event-bridge' ),
|
__( 'Event Bridge for ActivityPub', 'event-bridge-for-activitypub' ),
|
||||||
'manage_options',
|
'manage_options',
|
||||||
self::SETTINGS_SLUG,
|
self::SETTINGS_SLUG,
|
||||||
array( self::STATIC, 'settings_page' ),
|
array( self::STATIC, 'settings_page' ),
|
||||||
|
@ -97,6 +97,9 @@ class Settings_Page {
|
||||||
$tab = sanitize_key( $_GET['tab'] );
|
$tab = sanitize_key( $_GET['tab'] );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Fallback to always re-scan active event plugins, when user visits admin area of this plugin.
|
||||||
|
Setup::get_instance()->redetect_active_event_plugins();
|
||||||
|
|
||||||
switch ( $tab ) {
|
switch ( $tab ) {
|
||||||
case 'settings':
|
case 'settings':
|
||||||
$plugin_setup = Setup::get_instance();
|
$plugin_setup = Setup::get_instance();
|
||||||
|
@ -114,7 +117,7 @@ class Settings_Page {
|
||||||
'event_terms' => $event_terms,
|
'event_terms' => $event_terms,
|
||||||
);
|
);
|
||||||
|
|
||||||
\load_template( ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_DIR . 'templates/settings.php', true, $args );
|
\load_template( EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_DIR . 'templates/settings.php', true, $args );
|
||||||
break;
|
break;
|
||||||
case 'welcome':
|
case 'welcome':
|
||||||
default:
|
default:
|
||||||
|
@ -122,7 +125,7 @@ class Settings_Page {
|
||||||
add_thickbox();
|
add_thickbox();
|
||||||
wp_enqueue_script( 'updates' );
|
wp_enqueue_script( 'updates' );
|
||||||
|
|
||||||
\load_template( ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_DIR . 'templates/welcome.php', true );
|
\load_template( EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_DIR . 'templates/welcome.php', true );
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,17 +1,17 @@
|
||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* Class responsible for autoloading ActivityPub Event Bridge class files.
|
* Class responsible for autoloading Event Bridge for ActivityPub class files.
|
||||||
*
|
*
|
||||||
* The Autoloader class is responsible for automatically loading class files as needed
|
* The Autoloader class is responsible for automatically loading class files as needed
|
||||||
* to ensure a clean and organized codebase. It maps class names to their corresponding
|
* to ensure a clean and organized codebase. It maps class names to their corresponding
|
||||||
* file locations within the GatherPress plugin.
|
* file locations within the GatherPress plugin.
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
* @license AGPL-3.0-or-later
|
* @license AGPL-3.0-or-later
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge;
|
namespace Event_Bridge_For_ActivityPub;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
@ -34,8 +34,8 @@ class Autoloader {
|
||||||
public static function register(): void {
|
public static function register(): void {
|
||||||
spl_autoload_register(
|
spl_autoload_register(
|
||||||
function ( $full_class ) {
|
function ( $full_class ) {
|
||||||
$base_dir = ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_DIR . '/includes/';
|
$base_dir = EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_DIR . '/includes/';
|
||||||
$base = 'ActivityPub_Event_Bridge\\';
|
$base = 'Event_Bridge_For_ActivityPub\\';
|
||||||
|
|
||||||
if ( strncmp( $full_class, $base, strlen( $base ) ) === 0 ) {
|
if ( strncmp( $full_class, $base, strlen( $base ) ) === 0 ) {
|
||||||
$maybe_uppercase = str_replace( $base, '', $full_class );
|
$maybe_uppercase = str_replace( $base, '', $full_class );
|
||||||
|
|
|
@ -3,13 +3,13 @@
|
||||||
* General settings class.
|
* General settings class.
|
||||||
*
|
*
|
||||||
* This file contains the General class definition, which handles the "General" settings
|
* This file contains the General class definition, which handles the "General" settings
|
||||||
* page for the Activitypub Event Bridge Plugin, providing options for configuring various general settings.
|
* page for the Event Bridge for ActivityPub Plugin, providing options for configuring various general settings.
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge;
|
namespace Event_Bridge_For_ActivityPub;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
@ -24,7 +24,7 @@ use Activitypub\Activity\Extended_Object\Event;
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
class Settings {
|
class Settings {
|
||||||
const SETTINGS_SLUG = 'activitypub-event-bridge';
|
const SETTINGS_SLUG = 'event-bridge-for-activitypub';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The default ActivityPub event category.
|
* The default ActivityPub event category.
|
||||||
|
@ -34,17 +34,17 @@ class Settings {
|
||||||
const DEFAULT_EVENT_CATEGORY = 'MEETING';
|
const DEFAULT_EVENT_CATEGORY = 'MEETING';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Register the settings for the ActivityPub Event Bridge plugin.
|
* Register the settings for the Event Bridge for ActivityPub plugin.
|
||||||
*
|
*
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public static function register_settings(): void {
|
public static function register_settings(): void {
|
||||||
\register_setting(
|
\register_setting(
|
||||||
'activitypub-event-bridge',
|
'event-bridge-for-activitypub',
|
||||||
'activitypub_event_bridge_default_event_category',
|
'event_bridge_for_activitypub_default_event_category',
|
||||||
array(
|
array(
|
||||||
'type' => 'string',
|
'type' => 'string',
|
||||||
'description' => \__( 'Define your own custom post template', 'activitypub-event-bridge' ),
|
'description' => \__( 'Define your own custom post template', 'event-bridge-for-activitypub' ),
|
||||||
'show_in_rest' => true,
|
'show_in_rest' => true,
|
||||||
'default' => self::DEFAULT_EVENT_CATEGORY,
|
'default' => self::DEFAULT_EVENT_CATEGORY,
|
||||||
'sanitize_callback' => array( self::class, 'sanitize_mapped_event_category' ),
|
'sanitize_callback' => array( self::class, 'sanitize_mapped_event_category' ),
|
||||||
|
@ -52,25 +52,47 @@ class Settings {
|
||||||
);
|
);
|
||||||
|
|
||||||
\register_setting(
|
\register_setting(
|
||||||
'activitypub-event-bridge',
|
'event-bridge-for-activitypub',
|
||||||
'activitypub_event_bridge_event_category_mappings',
|
'event_bridge_for_activitypub_event_category_mappings',
|
||||||
array(
|
array(
|
||||||
'type' => 'array',
|
'type' => 'array',
|
||||||
'description' => \__( 'Define your own custom post template', 'activitypub-event-bridge' ),
|
'description' => \__( 'Define your own custom post template', 'event-bridge-for-activitypub' ),
|
||||||
'default' => array(),
|
'default' => array(),
|
||||||
'sanitize_callback' => array( self::class, 'sanitize_event_category_mappings' ),
|
'sanitize_callback' => array( self::class, 'sanitize_event_category_mappings' ),
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
\register_setting(
|
\register_setting(
|
||||||
'activitypub-event-bridge',
|
'event-bridge-for-activitypub',
|
||||||
'activitypub_event_bridge_initially_activated',
|
'event_bridge_for_activitypub_initially_activated',
|
||||||
array(
|
array(
|
||||||
'type' => 'boolean',
|
'type' => 'boolean',
|
||||||
'description' => \__( 'Whether the plugin just got activated for the first time.', 'activitypub-event-bridge' ),
|
'description' => \__( 'Whether the plugin just got activated for the first time.', 'event-bridge-for-activitypub' ),
|
||||||
'default' => 1,
|
'default' => 1,
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
\register_setting(
|
||||||
|
'event-bridge-for-activitypub',
|
||||||
|
'event_bridge_for_activitypub_summary_type',
|
||||||
|
array(
|
||||||
|
'type' => 'string',
|
||||||
|
'description' => \__( 'Summary type to use for ActivityStreams', 'event-bridge-for-activitypub' ),
|
||||||
|
'show_in_rest' => true,
|
||||||
|
'default' => 'preset',
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
\register_setting(
|
||||||
|
'event-bridge-for-activitypub',
|
||||||
|
'event_bridge_for_activitypub_custom_summary',
|
||||||
|
array(
|
||||||
|
'type' => 'string',
|
||||||
|
'description' => \__( 'Define your own custom summary template for events', 'event-bridge-for-activitypub' ),
|
||||||
|
'show_in_rest' => true,
|
||||||
|
'default' => EVENT_BRIDGE_FOR_ACTIVITYPUB_CUSTOM_SUMMARY,
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -1,32 +1,32 @@
|
||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* Class responsible for initializing ActivityPub Event Bridge.
|
* Class responsible for initializing Event Bridge for ActivityPub.
|
||||||
*
|
*
|
||||||
* The setup class provides function for checking if this plugin should be activated.
|
* The setup class provides function for checking if this plugin should be activated.
|
||||||
* It detects supported event plugins and provides all setup hooks and filters.
|
* It detects supported event plugins and provides all setup hooks and filters.
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
* @license AGPL-3.0-or-later
|
* @license AGPL-3.0-or-later
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge;
|
namespace Event_Bridge_For_ActivityPub;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
|
||||||
use ActivityPub_Event_Bridge\Admin\Event_Plugin_Admin_Notices;
|
use Event_Bridge_For_ActivityPub\Admin\Event_Plugin_Admin_Notices;
|
||||||
use ActivityPub_Event_Bridge\Admin\General_Admin_Notices;
|
use Event_Bridge_For_ActivityPub\Admin\General_Admin_Notices;
|
||||||
use ActivityPub_Event_Bridge\Admin\Health_Check;
|
use Event_Bridge_For_ActivityPub\Admin\Health_Check;
|
||||||
use ActivityPub_Event_Bridge\Admin\Settings_Page;
|
use Event_Bridge_For_ActivityPub\Admin\Settings_Page;
|
||||||
use ActivityPub_Event_Bridge\Plugins\Event_Plugin;
|
use Event_Bridge_For_ActivityPub\Integrations\Event_Plugin;
|
||||||
|
|
||||||
require_once ABSPATH . 'wp-admin/includes/plugin.php';
|
require_once ABSPATH . 'wp-admin/includes/plugin.php';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class Setup.
|
* Class Setup.
|
||||||
*
|
*
|
||||||
* This class is responsible for initializing ActivityPub Event Bridge.
|
* This class is responsible for initializing Event Bridge for ActivityPub.
|
||||||
*
|
*
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
|
@ -64,12 +64,11 @@ class Setup {
|
||||||
is_plugin_active( 'activitypub/activitypub.php' );
|
is_plugin_active( 'activitypub/activitypub.php' );
|
||||||
// BeforeFirstRelease: decide whether we want to do anything at all when ActivityPub plugin is note active.
|
// BeforeFirstRelease: decide whether we want to do anything at all when ActivityPub plugin is note active.
|
||||||
// if ( ! $this->activitypub_plugin_is_active ) {
|
// if ( ! $this->activitypub_plugin_is_active ) {
|
||||||
// deactivate_plugins( ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_FILE );
|
// deactivate_plugins( EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_FILE );
|
||||||
// return;
|
// return;
|
||||||
// }.
|
// }.
|
||||||
$this->active_event_plugins = self::detect_active_event_plugins();
|
|
||||||
$this->activitypub_plugin_version = self::get_activitypub_plugin_version();
|
$this->activitypub_plugin_version = self::get_activitypub_plugin_version();
|
||||||
$this->setup_hooks();
|
add_action( 'plugins_loaded', array( $this, 'setup_hooks' ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -106,8 +105,7 @@ class Setup {
|
||||||
if ( defined( 'ACTIVITYPUB_PLUGIN_VERSION' ) ) {
|
if ( defined( 'ACTIVITYPUB_PLUGIN_VERSION' ) ) {
|
||||||
return constant( 'ACTIVITYPUB_PLUGIN_VERSION' );
|
return constant( 'ACTIVITYPUB_PLUGIN_VERSION' );
|
||||||
}
|
}
|
||||||
$version = get_file_data( WP_PLUGIN_DIR . '/activitypub/activitypub.php', array( 'Version' ) )[0];
|
return '0.0.0';
|
||||||
return $version ?? '0.0.0';
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -125,33 +123,58 @@ class Setup {
|
||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
private const EVENT_PLUGIN_CLASSES = array(
|
private const EVENT_PLUGIN_CLASSES = array(
|
||||||
'\ActivityPub_Event_Bridge\Plugins\Events_Manager',
|
'\Event_Bridge_For_ActivityPub\Integrations\Events_Manager',
|
||||||
'\ActivityPub_Event_Bridge\Plugins\GatherPress',
|
'\Event_Bridge_For_ActivityPub\Integrations\GatherPress',
|
||||||
'\ActivityPub_Event_Bridge\Plugins\The_Events_Calendar',
|
'\Event_Bridge_For_ActivityPub\Integrations\The_Events_Calendar',
|
||||||
'\ActivityPub_Event_Bridge\Plugins\VS_Event_List',
|
'\Event_Bridge_For_ActivityPub\Integrations\VS_Event_List',
|
||||||
'\ActivityPub_Event_Bridge\Plugins\My_Calendar',
|
'\Event_Bridge_For_ActivityPub\Integrations\WP_Event_Manager',
|
||||||
'\ActivityPub_Event_Bridge\Plugins\WP_Event_Manager',
|
'\Event_Bridge_For_ActivityPub\Integrations\Eventin',
|
||||||
'\ActivityPub_Event_Bridge\Plugins\Eventin',
|
'\Event_Bridge_For_ActivityPub\Integrations\Modern_Events_Calendar_Lite',
|
||||||
'\ActivityPub_Event_Bridge\Plugins\Modern_Events_Calendar_Lite',
|
'\Event_Bridge_For_ActivityPub\Integrations\EventPrime',
|
||||||
|
'\Event_Bridge_For_ActivityPub\Integrations\Event_Organiser',
|
||||||
);
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Force the re-scan for active event plugins without using the cached transient.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function redetect_active_event_plugins(): void {
|
||||||
|
delete_transient( 'event_bridge_for_activitypub_active_event_plugins' );
|
||||||
|
$this->detect_active_event_plugins();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Function that checks for supported activated event plugins.
|
* Function that checks for supported activated event plugins.
|
||||||
*
|
*
|
||||||
* @return array List of supported event plugins as keys from the SUPPORTED_EVENT_PLUGINS const.
|
* @return array List of supported event plugins as keys from the SUPPORTED_EVENT_PLUGINS const.
|
||||||
*/
|
*/
|
||||||
public static function detect_active_event_plugins(): array {
|
public function detect_active_event_plugins(): array {
|
||||||
$active_event_plugins = array();
|
$active_event_plugins = get_transient( 'event_bridge_for_activitypub_active_event_plugins' );
|
||||||
|
|
||||||
|
if ( $active_event_plugins ) {
|
||||||
|
$this->active_event_plugins = $active_event_plugins;
|
||||||
|
return $active_event_plugins;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ! function_exists( 'get_plugins' ) ) {
|
||||||
|
require_once ABSPATH . 'wp-admin/includes/plugin.php';
|
||||||
|
}
|
||||||
|
|
||||||
|
$all_plugins = array_merge( get_plugins(), get_mu_plugins() );
|
||||||
|
|
||||||
|
$active_event_plugins = array();
|
||||||
foreach ( self::EVENT_PLUGIN_CLASSES as $event_plugin_class ) {
|
foreach ( self::EVENT_PLUGIN_CLASSES as $event_plugin_class ) {
|
||||||
if ( ! class_exists( $event_plugin_class ) || ! method_exists( $event_plugin_class, 'get_plugin_file' ) ) {
|
$event_plugin_file = call_user_func( array( $event_plugin_class, 'get_relative_plugin_file' ) );
|
||||||
|
if ( ! $event_plugin_file ) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
$event_plugin_file = call_user_func( array( $event_plugin_class, 'get_plugin_file' ) );
|
if ( array_key_exists( $event_plugin_file, $all_plugins ) && \is_plugin_active( $event_plugin_file ) ) {
|
||||||
if ( \is_plugin_active( $event_plugin_file ) ) {
|
$active_event_plugins[ $event_plugin_file ] = new $event_plugin_class();
|
||||||
$active_event_plugins[] = new $event_plugin_class();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
set_transient( 'event_bridge_for_activitypub_active_event_plugins', $active_event_plugins );
|
||||||
|
$this->active_event_plugins = $active_event_plugins;
|
||||||
return $active_event_plugins;
|
return $active_event_plugins;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -164,15 +187,20 @@ class Setup {
|
||||||
*
|
*
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
protected function setup_hooks(): void {
|
public function setup_hooks(): void {
|
||||||
register_activation_hook( ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_FILE, array( $this, 'activate' ) );
|
$this->detect_active_event_plugins();
|
||||||
|
|
||||||
|
register_activation_hook( EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_FILE, array( $this, 'activate' ) );
|
||||||
|
|
||||||
|
add_action( 'activated_plugin', array( $this, 'redetect_active_event_plugins' ) );
|
||||||
|
add_action( 'deactivated_plugin', array( $this, 'redetect_active_event_plugins' ) );
|
||||||
|
|
||||||
add_action( 'admin_init', array( $this, 'do_admin_notices' ) );
|
add_action( 'admin_init', array( $this, 'do_admin_notices' ) );
|
||||||
add_action( 'admin_init', array( Settings::class, 'register_settings' ) );
|
add_action( 'admin_init', array( Settings::class, 'register_settings' ) );
|
||||||
add_action( 'admin_enqueue_scripts', array( self::class, 'enqueue_styles' ) );
|
add_action( 'admin_enqueue_scripts', array( self::class, 'enqueue_styles' ) );
|
||||||
add_action( 'admin_menu', array( Settings_Page::class, 'admin_menu' ) );
|
add_action( 'admin_menu', array( Settings_Page::class, 'admin_menu' ) );
|
||||||
add_filter(
|
add_filter(
|
||||||
'plugin_action_links_' . ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_BASENAME,
|
'plugin_action_links_' . EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_BASENAME,
|
||||||
array( Settings_Page::class, 'settings_link' )
|
array( Settings_Page::class, 'settings_link' )
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -184,7 +212,7 @@ class Setup {
|
||||||
add_action( 'init', array( Health_Check::class, 'init' ) );
|
add_action( 'init', array( Health_Check::class, 'init' ) );
|
||||||
|
|
||||||
// Check if the minimum required version of the ActivityPub plugin is installed.
|
// Check if the minimum required version of the ActivityPub plugin is installed.
|
||||||
if ( ! version_compare( $this->activitypub_plugin_version, ACTIVITYPUB_EVENT_BRIDGE_ACTIVITYPUB_PLUGIN_MIN_VERSION ) ) {
|
if ( ! version_compare( $this->activitypub_plugin_version, EVENT_BRIDGE_FOR_ACTIVITYPUB_ACTIVITYPUB_PLUGIN_MIN_VERSION ) ) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -199,24 +227,24 @@ class Setup {
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public static function enqueue_styles( $hook_suffix ): void {
|
public static function enqueue_styles( $hook_suffix ): void {
|
||||||
if ( false !== strpos( $hook_suffix, 'activitypub-event-bridge' ) ) {
|
if ( false !== strpos( $hook_suffix, 'event-bridge-for-activitypub' ) ) {
|
||||||
wp_enqueue_style(
|
wp_enqueue_style(
|
||||||
'activitypub-event-bridge-admin-styles',
|
'event-bridge-for-activitypub-admin-styles',
|
||||||
plugins_url(
|
plugins_url(
|
||||||
'assets/css/activitypub-event-bridge-admin.css',
|
'assets/css/event-bridge-for-activitypub-admin.css',
|
||||||
ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_FILE
|
EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_FILE
|
||||||
),
|
),
|
||||||
array(),
|
array(),
|
||||||
ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_VERSION
|
EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_VERSION
|
||||||
);
|
);
|
||||||
wp_enqueue_script(
|
wp_enqueue_script(
|
||||||
'activitypub-event-bridge-admin-script',
|
'event-bridge-for-activitypub-admin-script',
|
||||||
plugins_url(
|
plugins_url(
|
||||||
'assets/js/activitypub-event-bridge-admin.js',
|
'assets/js/event-bridge-for-activitypub-admin.js',
|
||||||
ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_FILE
|
EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_FILE
|
||||||
),
|
),
|
||||||
array( 'jquery' ),
|
array( 'jquery' ),
|
||||||
ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_VERSION,
|
EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_VERSION,
|
||||||
false
|
false
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -232,15 +260,15 @@ class Setup {
|
||||||
// Check if any general admin notices are needed and add actions to insert the needed admin notices.
|
// Check if any general admin notices are needed and add actions to insert the needed admin notices.
|
||||||
if ( ! $this->activitypub_plugin_is_active ) {
|
if ( ! $this->activitypub_plugin_is_active ) {
|
||||||
// The ActivityPub plugin is not active.
|
// The ActivityPub plugin is not active.
|
||||||
add_action( 'admin_notices', array( 'ActivityPub_Event_Bridge\Admin\General_Admin_Notices', 'activitypub_plugin_not_enabled' ), 10, 1 );
|
add_action( 'admin_notices', array( 'Event_Bridge_For_ActivityPub\Admin\General_Admin_Notices', 'activitypub_plugin_not_enabled' ), 10, 1 );
|
||||||
}
|
}
|
||||||
if ( ! version_compare( $this->activitypub_plugin_version, ACTIVITYPUB_EVENT_BRIDGE_ACTIVITYPUB_PLUGIN_MIN_VERSION ) ) {
|
if ( ! version_compare( $this->activitypub_plugin_version, EVENT_BRIDGE_FOR_ACTIVITYPUB_ACTIVITYPUB_PLUGIN_MIN_VERSION ) ) {
|
||||||
// The ActivityPub plugin is too old.
|
// The ActivityPub plugin is too old.
|
||||||
add_action( 'admin_notices', array( 'ActivityPub_Event_Bridge\Admin\General_Admin_Notices', 'activitypub_plugin_version_too_old' ), 10, 1 );
|
add_action( 'admin_notices', array( 'Event_Bridge_For_ActivityPub\Admin\General_Admin_Notices', 'activitypub_plugin_version_too_old' ), 10, 1 );
|
||||||
}
|
}
|
||||||
if ( empty( $this->active_event_plugins ) ) {
|
if ( empty( $this->active_event_plugins ) ) {
|
||||||
// No supported Event Plugin is active.
|
// No supported Event Plugin is active.
|
||||||
add_action( 'admin_notices', array( 'ActivityPub_Event_Bridge\Admin\General_Admin_Notices', 'no_supported_event_plugin_active' ), 10, 1 );
|
add_action( 'admin_notices', array( 'Event_Bridge_For_ActivityPub\Admin\General_Admin_Notices', 'no_supported_event_plugin_active' ), 10, 1 );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -253,7 +281,7 @@ class Setup {
|
||||||
*
|
*
|
||||||
* @return \Activitypub\Transformer\Base|null
|
* @return \Activitypub\Transformer\Base|null
|
||||||
*/
|
*/
|
||||||
public function register_activitypub_event_transformer( $transformer, $wp_object, $object_class ): \Activitypub\Transformer\Base {
|
public function register_activitypub_event_transformer( $transformer, $wp_object, $object_class ): ?\Activitypub\Transformer\Base {
|
||||||
// If the current WordPress object is not a post (e.g., a WP_Comment), don't change the transformer.
|
// If the current WordPress object is not a post (e.g., a WP_Comment), don't change the transformer.
|
||||||
if ( 'WP_Post' !== $object_class ) {
|
if ( 'WP_Post' !== $object_class ) {
|
||||||
return $transformer;
|
return $transformer;
|
||||||
|
@ -293,18 +321,19 @@ class Setup {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Activates the ActivityPub Event Bridge plugin.
|
* Activates the Event Bridge for ActivityPub plugin.
|
||||||
*
|
*
|
||||||
* This method handles the activation of the ActivityPub Event Bridge plugin.
|
* This method handles the activation of the Event Bridge for ActivityPub plugin.
|
||||||
*
|
*
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
* @see register_activation_hook()
|
* @see register_activation_hook()
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function activate(): void {
|
public function activate(): void {
|
||||||
|
$this->redetect_active_event_plugins();
|
||||||
// Don't allow plugin activation, when the ActivityPub plugin is not activated yet.
|
// Don't allow plugin activation, when the ActivityPub plugin is not activated yet.
|
||||||
if ( ! $this->activitypub_plugin_is_active ) {
|
if ( ! $this->activitypub_plugin_is_active ) {
|
||||||
deactivate_plugins( plugin_basename( ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_FILE ) );
|
deactivate_plugins( plugin_basename( EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_FILE ) );
|
||||||
$notice = General_Admin_Notices::get_admin_notice_activitypub_plugin_not_enabled();
|
$notice = General_Admin_Notices::get_admin_notice_activitypub_plugin_not_enabled();
|
||||||
wp_die(
|
wp_die(
|
||||||
wp_kses( $notice, General_Admin_Notices::ALLOWED_HTML ),
|
wp_kses( $notice, General_Admin_Notices::ALLOWED_HTML ),
|
||||||
|
@ -314,7 +343,7 @@ class Setup {
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( empty( $this->active_event_plugins ) ) {
|
if ( empty( $this->active_event_plugins ) ) {
|
||||||
deactivate_plugins( plugin_basename( ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_FILE ) );
|
deactivate_plugins( plugin_basename( EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_FILE ) );
|
||||||
$notice = General_Admin_Notices::get_admin_notice_no_supported_event_plugin_active();
|
$notice = General_Admin_Notices::get_admin_notice_no_supported_event_plugin_active();
|
||||||
wp_die(
|
wp_die(
|
||||||
wp_kses( $notice, General_Admin_Notices::ALLOWED_HTML ),
|
wp_kses( $notice, General_Admin_Notices::ALLOWED_HTML ),
|
||||||
|
|
|
@ -2,46 +2,46 @@
|
||||||
/**
|
/**
|
||||||
* File responsible for defining the event category strings.
|
* File responsible for defining the event category strings.
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
* @license AGPL-3.0-or-later
|
* @license AGPL-3.0-or-later
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge;
|
namespace Event_Bridge_For_ActivityPub;
|
||||||
|
|
||||||
define(
|
define(
|
||||||
'ACTIVITYPUB_EVENT_BRIDGE_EVENT_CATEGORIES',
|
'EVENT_BRIDGE_FOR_ACTIVITYPUB_EVENT_CATEGORIES',
|
||||||
array(
|
array(
|
||||||
'ARTS' => __( 'Arts', 'activitypub-event-bridge' ),
|
'ARTS' => __( 'Arts', 'event-bridge-for-activitypub' ),
|
||||||
'BOOK_CLUBS' => __( 'Book clubs', 'activitypub-event-bridge' ),
|
'BOOK_CLUBS' => __( 'Book clubs', 'event-bridge-for-activitypub' ),
|
||||||
'BUSINESS' => __( 'Business', 'activitypub-event-bridge' ),
|
'BUSINESS' => __( 'Business', 'event-bridge-for-activitypub' ),
|
||||||
'CAUSES' => __( 'Causes', 'activitypub-event-bridge' ),
|
'CAUSES' => __( 'Causes', 'event-bridge-for-activitypub' ),
|
||||||
'COMEDY' => __( 'Comedy', 'activitypub-event-bridge' ),
|
'COMEDY' => __( 'Comedy', 'event-bridge-for-activitypub' ),
|
||||||
'CRAFTS' => __( 'Crafts', 'activitypub-event-bridge' ),
|
'CRAFTS' => __( 'Crafts', 'event-bridge-for-activitypub' ),
|
||||||
'FOOD_DRINK' => __( 'Food & Drink', 'activitypub-event-bridge' ),
|
'FOOD_DRINK' => __( 'Food & Drink', 'event-bridge-for-activitypub' ),
|
||||||
'HEALTH' => __( 'Health', 'activitypub-event-bridge' ),
|
'HEALTH' => __( 'Health', 'event-bridge-for-activitypub' ),
|
||||||
'MUSIC' => __( 'Music', 'activitypub-event-bridge' ),
|
'MUSIC' => __( 'Music', 'event-bridge-for-activitypub' ),
|
||||||
'AUTO_BOAT_AIR' => __( 'Auto, boat and air', 'activitypub-event-bridge' ),
|
'AUTO_BOAT_AIR' => __( 'Auto, boat and air', 'event-bridge-for-activitypub' ),
|
||||||
'COMMUNITY' => __( 'Community', 'activitypub-event-bridge' ),
|
'COMMUNITY' => __( 'Community', 'event-bridge-for-activitypub' ),
|
||||||
'FAMILY_EDUCATION' => __( 'Family & Education', 'activitypub-event-bridge' ),
|
'FAMILY_EDUCATION' => __( 'Family & Education', 'event-bridge-for-activitypub' ),
|
||||||
'FASHION_BEAUTY' => __( 'Fashion & Beauty', 'activitypub-event-bridge' ),
|
'FASHION_BEAUTY' => __( 'Fashion & Beauty', 'event-bridge-for-activitypub' ),
|
||||||
'FILM_MEDIA' => __( 'Film & Media', 'activitypub-event-bridge' ),
|
'FILM_MEDIA' => __( 'Film & Media', 'event-bridge-for-activitypub' ),
|
||||||
'GAMES' => __( 'Games', 'activitypub-event-bridge' ),
|
'GAMES' => __( 'Games', 'event-bridge-for-activitypub' ),
|
||||||
'LANGUAGE_CULTURE' => __( 'Language & Culture', 'activitypub-event-bridge' ),
|
'LANGUAGE_CULTURE' => __( 'Language & Culture', 'event-bridge-for-activitypub' ),
|
||||||
'LEARNING' => __( 'Learning', 'activitypub-event-bridge' ),
|
'LEARNING' => __( 'Learning', 'event-bridge-for-activitypub' ),
|
||||||
'LGBTQ' => __( 'LGBTQ', 'activitypub-event-bridge' ),
|
'LGBTQ' => __( 'LGBTQ', 'event-bridge-for-activitypub' ),
|
||||||
'MOVEMENTS_POLITICS' => __( 'Movements and politics', 'activitypub-event-bridge' ),
|
'MOVEMENTS_POLITICS' => __( 'Movements and politics', 'event-bridge-for-activitypub' ),
|
||||||
'NETWORKING' => __( 'Networking', 'activitypub-event-bridge' ),
|
'NETWORKING' => __( 'Networking', 'event-bridge-for-activitypub' ),
|
||||||
'PARTY' => __( 'Party', 'activitypub-event-bridge' ),
|
'PARTY' => __( 'Party', 'event-bridge-for-activitypub' ),
|
||||||
'PERFORMING_VISUAL_ARTS' => __( 'Performing & Visual Arts', 'activitypub-event-bridge' ),
|
'PERFORMING_VISUAL_ARTS' => __( 'Performing & Visual Arts', 'event-bridge-for-activitypub' ),
|
||||||
'PETS' => __( 'Pets', 'activitypub-event-bridge' ),
|
'PETS' => __( 'Pets', 'event-bridge-for-activitypub' ),
|
||||||
'PHOTOGRAPHY' => __( 'Photography', 'activitypub-event-bridge' ),
|
'PHOTOGRAPHY' => __( 'Photography', 'event-bridge-for-activitypub' ),
|
||||||
'OUTDOORS_ADVENTURE' => __( 'Outdoors & Adventure', 'activitypub-event-bridge' ),
|
'OUTDOORS_ADVENTURE' => __( 'Outdoors & Adventure', 'event-bridge-for-activitypub' ),
|
||||||
'SPIRITUALITY_RELIGION_BELIEFS' => __( 'Spirituality, Religion & Beliefs', 'activitypub-event-bridge' ),
|
'SPIRITUALITY_RELIGION_BELIEFS' => __( 'Spirituality, Religion & Beliefs', 'event-bridge-for-activitypub' ),
|
||||||
'SCIENCE_TECH' => __( 'Science & Tech', 'activitypub-event-bridge' ),
|
'SCIENCE_TECH' => __( 'Science & Tech', 'event-bridge-for-activitypub' ),
|
||||||
'SPORTS' => __( 'Sports', 'activitypub-event-bridge' ),
|
'SPORTS' => __( 'Sports', 'event-bridge-for-activitypub' ),
|
||||||
'THEATRE' => __( 'Theatre', 'activitypub-event-bridge' ),
|
'THEATRE' => __( 'Theatre', 'event-bridge-for-activitypub' ),
|
||||||
'MEETING' => __( 'Meeting', 'activitypub-event-bridge' ), // Default value in federation.
|
'MEETING' => __( 'Meeting', 'event-bridge-for-activitypub' ), // Default value in federation.
|
||||||
'DEFAULT' => __( 'Default', 'activitypub-event-bridge' ), // Internal default for overrides.
|
'DEFAULT' => __( 'Default', 'event-bridge-for-activitypub' ), // Internal default for overrides.
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|
69
includes/integrations/class-event-organiser.php
Normal file
69
includes/integrations/class-event-organiser.php
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Event Organiser.
|
||||||
|
*
|
||||||
|
* Defines all the necessary meta information for the Event Organiser plugin.
|
||||||
|
*
|
||||||
|
* @link https://wordpress.org/plugins/event-organiser/
|
||||||
|
* @package Event_Bridge_For_ActivityPub
|
||||||
|
* @since 1.0.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Event_Bridge_For_ActivityPub\Integrations;
|
||||||
|
|
||||||
|
// Exit if accessed directly.
|
||||||
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interface for a supported event plugin.
|
||||||
|
*
|
||||||
|
* This interface defines which information is necessary for a supported event plugin.
|
||||||
|
*
|
||||||
|
* @since 1.0.0
|
||||||
|
*/
|
||||||
|
final class Event_Organiser extends Event_Plugin {
|
||||||
|
/**
|
||||||
|
* Returns the full plugin file.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function get_relative_plugin_file(): string {
|
||||||
|
return 'event-organiser/event-organiser.php';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the event post type of the plugin.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function get_post_type(): string {
|
||||||
|
return 'event';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the IDs of the admin pages of the plugin.
|
||||||
|
*
|
||||||
|
* @return array The settings page urls.
|
||||||
|
*/
|
||||||
|
public static function get_settings_pages(): array {
|
||||||
|
return array( 'event-organiser' );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the ActivityPub transformer class.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function get_activitypub_transformer_class_name(): string {
|
||||||
|
return 'Event_Organiser';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the taxonomy used for the plugin's event categories.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function get_event_category_taxonomy(): string {
|
||||||
|
return 'event-category';
|
||||||
|
}
|
||||||
|
}
|
|
@ -4,13 +4,13 @@
|
||||||
*
|
*
|
||||||
* Basic information that each supported event needs for this plugin to work.
|
* Basic information that each supported event needs for this plugin to work.
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Plugins;
|
namespace Event_Bridge_For_ActivityPub\Integrations;
|
||||||
|
|
||||||
use ActivityPub_Event_Bridge\Activitypub\Transformer\Event as Event_Transformer;
|
use Event_Bridge_For_ActivityPub\Activitypub\Transformer\Event as Event_Transformer;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
@ -24,11 +24,11 @@ defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
*/
|
*/
|
||||||
abstract class Event_Plugin {
|
abstract class Event_Plugin {
|
||||||
/**
|
/**
|
||||||
* Returns the full plugin file.
|
* Returns the plugin file relative to the plugins dir.
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
abstract public static function get_plugin_file(): string;
|
abstract public static function get_relative_plugin_file(): string;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the event post type of the plugin.
|
* Returns the event post type of the plugin.
|
||||||
|
@ -57,9 +57,9 @@ abstract class Event_Plugin {
|
||||||
* Get the plugins name from the main plugin-file's top-level-file-comment.
|
* Get the plugins name from the main plugin-file's top-level-file-comment.
|
||||||
*/
|
*/
|
||||||
final public static function get_plugin_name(): string {
|
final public static function get_plugin_name(): string {
|
||||||
$plugin_data = get_plugin_data( WP_PLUGIN_DIR . '/' . static::get_plugin_file() );
|
$all_plugins = array_merge( get_plugins(), get_mu_plugins() );
|
||||||
if ( isset( $plugin_data['Name'] ) ) {
|
if ( isset( $all_plugins[ static::get_relative_plugin_file() ]['Name'] ) ) {
|
||||||
return $plugin_data['Name'];
|
return $all_plugins[ static::get_relative_plugin_file() ]['Name'];
|
||||||
} else {
|
} else {
|
||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
|
@ -83,6 +83,6 @@ abstract class Event_Plugin {
|
||||||
* Returns the Activitypub transformer for the event plugins event post type.
|
* Returns the Activitypub transformer for the event plugins event post type.
|
||||||
*/
|
*/
|
||||||
public static function get_activitypub_event_transformer_class(): string {
|
public static function get_activitypub_event_transformer_class(): string {
|
||||||
return str_replace( 'Plugins', 'Activitypub\Transformer', static::class );
|
return str_replace( 'Integrations', 'Activitypub\Transformer', static::class );
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -5,11 +5,11 @@
|
||||||
* Defines all the necessary meta information for the events calendar.
|
* Defines all the necessary meta information for the events calendar.
|
||||||
*
|
*
|
||||||
* @link https://wordpress.org/plugins/the-events-calendar/
|
* @link https://wordpress.org/plugins/the-events-calendar/
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Plugins;
|
namespace Event_Bridge_For_ActivityPub\Integrations;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
@ -27,7 +27,7 @@ final class Eventin extends Event_plugin {
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public static function get_plugin_file(): string {
|
public static function get_relative_plugin_file(): string {
|
||||||
return 'wp-event-solution/eventin.php';
|
return 'wp-event-solution/eventin.php';
|
||||||
}
|
}
|
||||||
|
|
221
includes/integrations/class-eventprime.php
Normal file
221
includes/integrations/class-eventprime.php
Normal file
|
@ -0,0 +1,221 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* EventPrime – Events Calendar, Bookings and Tickets
|
||||||
|
*
|
||||||
|
* @link https://wordpress.org/plugins/eventprime-event-calendar-management/
|
||||||
|
* @package Event_Bridge_For_ActivityPub
|
||||||
|
* @since 1.0.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Event_Bridge_For_ActivityPub\Integrations;
|
||||||
|
|
||||||
|
use Activitypub\Signature;
|
||||||
|
use Eventprime_Basic_Functions;
|
||||||
|
|
||||||
|
// Exit if accessed directly.
|
||||||
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class defines which information is necessary for the EventPrime event plugin.
|
||||||
|
*
|
||||||
|
* @since 1.0.0
|
||||||
|
*/
|
||||||
|
final class EventPrime extends Event_Plugin {
|
||||||
|
/**
|
||||||
|
* Add filter for the template inclusion.
|
||||||
|
*/
|
||||||
|
public function __construct() {
|
||||||
|
\add_filter( 'template_include', array( self::class, 'render_activitypub_template' ), 100 );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the full plugin file.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function get_relative_plugin_file(): string {
|
||||||
|
return 'eventprime-event-calendar-management/event-prime.php';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the event post type of the plugin.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function get_post_type(): string {
|
||||||
|
return 'em_event';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the IDs of the admin pages of the plugin.
|
||||||
|
*
|
||||||
|
* @return array The settings page urls.
|
||||||
|
*/
|
||||||
|
public static function get_settings_pages(): array {
|
||||||
|
return array( 'ep-settings' );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the ActivityPub transformer class.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function get_activitypub_transformer_class_name(): string {
|
||||||
|
return 'EventPrime';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the taxonomy used for the plugin's event categories.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function get_event_category_taxonomy(): string {
|
||||||
|
return 'em_event_type';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Determine whether the current request is an EventPrime ActivityPub request.
|
||||||
|
*
|
||||||
|
* Forked from https://github.com/Automattic/wordpress-activitypub/blob/trunk/includes/functions.php
|
||||||
|
* the function is_activitypub_request.
|
||||||
|
*/
|
||||||
|
private static function is_eventprime_activitypub_request() {
|
||||||
|
global $wp_query;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ActivityPub requests are currently only made for
|
||||||
|
* author archives, singular posts, and the homepage.
|
||||||
|
*/
|
||||||
|
if ( ! \is_author() && ! \is_singular() && ! \is_home() && ! defined( '\REST_REQUEST' ) ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check if the current post type supports ActivityPub.
|
||||||
|
if ( \is_singular() ) {
|
||||||
|
$queried_object = \get_queried_object();
|
||||||
|
|
||||||
|
if ( ! $queried_object instanceof \WP_Post ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( '[em_event]' !== $queried_object->post_content && '[em_events]' !== $queried_object->post_content ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check if header already sent.
|
||||||
|
if ( ! \headers_sent() && ACTIVITYPUB_SEND_VARY_HEADER ) {
|
||||||
|
// Send Vary header for Accept header.
|
||||||
|
\header( 'Vary: Accept' );
|
||||||
|
}
|
||||||
|
|
||||||
|
// One can trigger an ActivityPub request by adding ?activitypub to the URL.
|
||||||
|
if ( isset( $wp_query->query_vars['activitypub'] ) ) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The other (more common) option to make an ActivityPub request
|
||||||
|
* is to send an Accept header.
|
||||||
|
*/
|
||||||
|
if ( isset( $_SERVER['HTTP_ACCEPT'] ) ) {
|
||||||
|
$accept = sanitize_text_field( wp_unslash( $_SERVER['HTTP_ACCEPT'] ) );
|
||||||
|
|
||||||
|
/*
|
||||||
|
* $accept can be a single value, or a comma separated list of values.
|
||||||
|
* We want to support both scenarios,
|
||||||
|
* and return true when the header includes at least one of the following:
|
||||||
|
* - application/activity+json
|
||||||
|
* - application/ld+json
|
||||||
|
* - application/json
|
||||||
|
*/
|
||||||
|
if ( preg_match( '/(application\/(ld\+json|activity\+json|json))/i', $accept ) ) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Extract the post id of the event for an EventPrime event query.
|
||||||
|
*
|
||||||
|
* @return bool|int The post ID if an event could be identified, false otherwise.
|
||||||
|
*/
|
||||||
|
private static function get_eventprime_post_id() {
|
||||||
|
$event = get_query_var( 'event' );
|
||||||
|
if ( ! $event ) {
|
||||||
|
if ( ! empty( filter_input( INPUT_GET, 'event', FILTER_SANITIZE_FULL_SPECIAL_CHARS ) ) ) {
|
||||||
|
$event = rtrim( filter_input( INPUT_GET, 'event', FILTER_SANITIZE_FULL_SPECIAL_CHARS ), '/\\' );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( $event ) {
|
||||||
|
$ep_basic_functions = new Eventprime_Basic_Functions();
|
||||||
|
return $ep_basic_functions->ep_get_id_by_slug( $event, 'em_event' );
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add the ActivityPub template for EventPrime.
|
||||||
|
*
|
||||||
|
* @param string $template The path to the template object.
|
||||||
|
* @return string The new path to the JSON template.
|
||||||
|
*/
|
||||||
|
public static function render_activitypub_template( $template ) {
|
||||||
|
if ( defined( 'REST_REQUEST' ) && REST_REQUEST ) {
|
||||||
|
return $template;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check if the request is a page with (solely) the eventprime shortcode in it.
|
||||||
|
if ( ! self::is_eventprime_activitypub_request() ) {
|
||||||
|
return $template;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ! \is_singular() ) {
|
||||||
|
return $template;
|
||||||
|
}
|
||||||
|
|
||||||
|
$post_id = self::get_eventprime_post_id();
|
||||||
|
|
||||||
|
if ( $post_id ) {
|
||||||
|
$preview = \get_query_var( 'preview' );
|
||||||
|
if ( $preview ) {
|
||||||
|
$activitypub_template = ACTIVITYPUB_PLUGIN_DIR . '/templates/post-preview.php';
|
||||||
|
} else {
|
||||||
|
$activitypub_template = ACTIVITYPUB_PLUGIN_DIR . '/templates/post-json.php';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Check if the request is authorized.
|
||||||
|
*
|
||||||
|
* @see https://www.w3.org/wiki/SocialCG/ActivityPub/Primer/Authentication_Authorization#Authorized_fetch
|
||||||
|
* @see https://swicg.github.io/activitypub-http-signature/#authorized-fetch
|
||||||
|
*/
|
||||||
|
if ( $activitypub_template && defined( 'ACTIVITYPUB_AUTHORIZED_FETCH' ) && constant( 'ACTIVITYPUB_AUTHORIZED_FETCH' ) ) {
|
||||||
|
$verification = Signature::verify_http_signature( $_SERVER );
|
||||||
|
if ( \is_wp_error( $verification ) ) {
|
||||||
|
header( 'HTTP/1.1 401 Unauthorized' );
|
||||||
|
|
||||||
|
// Fallback as template_loader can't return http headers.
|
||||||
|
return $template;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( $activitypub_template ) {
|
||||||
|
global $post;
|
||||||
|
|
||||||
|
$post = get_post( $post_id ); // phpcs:ignore WordPress.WP.GlobalVariablesOverride.Prohibited
|
||||||
|
|
||||||
|
// Ensure WordPress functions use the new post data.
|
||||||
|
setup_postdata( $post );
|
||||||
|
// Return the default ActivityPub template.
|
||||||
|
return $activitypub_template;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $template;
|
||||||
|
}
|
||||||
|
}
|
|
@ -5,11 +5,11 @@
|
||||||
* Defines all the necessary meta information for the Events Manager WordPress Plugin.
|
* Defines all the necessary meta information for the Events Manager WordPress Plugin.
|
||||||
*
|
*
|
||||||
* @link https://wordpress.org/plugins/events-manager/
|
* @link https://wordpress.org/plugins/events-manager/
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Plugins;
|
namespace Event_Bridge_For_ActivityPub\Integrations;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
@ -27,7 +27,7 @@ final class Events_Manager extends Event_Plugin {
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public static function get_plugin_file(): string {
|
public static function get_relative_plugin_file(): string {
|
||||||
return 'events-manager/events-manager.php';
|
return 'events-manager/events-manager.php';
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,11 +5,11 @@
|
||||||
* Defines all the necessary meta information for the GatherPress plugin.
|
* Defines all the necessary meta information for the GatherPress plugin.
|
||||||
*
|
*
|
||||||
* @link https://wordpress.org/plugins/gatherpress/
|
* @link https://wordpress.org/plugins/gatherpress/
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Plugins;
|
namespace Event_Bridge_For_ActivityPub\Integrations;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
@ -27,7 +27,7 @@ final class GatherPress extends Event_Plugin {
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public static function get_plugin_file(): string {
|
public static function get_relative_plugin_file(): string {
|
||||||
return 'gatherpress/gatherpress.php';
|
return 'gatherpress/gatherpress.php';
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,11 +5,11 @@
|
||||||
* Defines all the necessary meta information for the Modern Events Calendar (Lite).
|
* Defines all the necessary meta information for the Modern Events Calendar (Lite).
|
||||||
*
|
*
|
||||||
* @link https://webnus.net/modern-events-calendar/
|
* @link https://webnus.net/modern-events-calendar/
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Plugins;
|
namespace Event_Bridge_For_ActivityPub\Integrations;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
@ -27,7 +27,7 @@ final class Modern_Events_Calendar_Lite extends Event_plugin {
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public static function get_plugin_file(): string {
|
public static function get_relative_plugin_file(): string {
|
||||||
return 'modern-events-calendar-lite/modern-events-calendar-lite.php';
|
return 'modern-events-calendar-lite/modern-events-calendar-lite.php';
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,11 +5,11 @@
|
||||||
* Defines all the necessary meta information for the events calendar.
|
* Defines all the necessary meta information for the events calendar.
|
||||||
*
|
*
|
||||||
* @link https://wordpress.org/plugins/the-events-calendar/
|
* @link https://wordpress.org/plugins/the-events-calendar/
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Plugins;
|
namespace Event_Bridge_For_ActivityPub\Integrations;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
@ -27,7 +27,7 @@ final class The_Events_Calendar extends Event_plugin {
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public static function get_plugin_file(): string {
|
public static function get_relative_plugin_file(): string {
|
||||||
return 'the-events-calendar/the-events-calendar.php';
|
return 'the-events-calendar/the-events-calendar.php';
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,13 +6,13 @@
|
||||||
* "Very Simple Events List".
|
* "Very Simple Events List".
|
||||||
*
|
*
|
||||||
* @link https://de.wordpress.org/plugins/very-simple-event-list/
|
* @link https://de.wordpress.org/plugins/very-simple-event-list/
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Plugins;
|
namespace Event_Bridge_For_ActivityPub\Integrations;
|
||||||
|
|
||||||
use ActivityPub_Event_Bridge\Event_Plugins;
|
use Event_Bridge_For_ActivityPub\Event_Plugins;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
@ -30,7 +30,7 @@ final class VS_Event_List extends Event_Plugin {
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public static function get_plugin_file(): string {
|
public static function get_relative_plugin_file(): string {
|
||||||
return 'very-simple-event-list/vsel.php';
|
return 'very-simple-event-list/vsel.php';
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,13 +6,13 @@
|
||||||
* "WP Event Manager"
|
* "WP Event Manager"
|
||||||
*
|
*
|
||||||
* @link https://de.wordpress.org/plugins/wp-event-manager
|
* @link https://de.wordpress.org/plugins/wp-event-manager
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Plugins;
|
namespace Event_Bridge_For_ActivityPub\Integrations;
|
||||||
|
|
||||||
use ActivityPub_Event_Bridge\Plugins\Event_Plugin;
|
use Event_Bridge_For_ActivityPub\Integrations\Event_Plugin;
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
@ -30,7 +30,7 @@ final class WP_Event_Manager extends Event_Plugin {
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public static function get_plugin_file(): string {
|
public static function get_relative_plugin_file(): string {
|
||||||
return 'wp-event-manager/wp-event-manager.php';
|
return 'wp-event-manager/wp-event-manager.php';
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,63 +0,0 @@
|
||||||
<?php
|
|
||||||
/**
|
|
||||||
* My Calendar.
|
|
||||||
*
|
|
||||||
* Defines all the necessary meta information for the WordPress event plugin
|
|
||||||
* "My Calendar".
|
|
||||||
*
|
|
||||||
* @link https://wordpress.org/plugins/my-calendar/
|
|
||||||
* @package Activitypub_Event_Extensions
|
|
||||||
* @since 1.0.0
|
|
||||||
*/
|
|
||||||
|
|
||||||
namespace ActivityPub_Event_Bridge\Plugins;
|
|
||||||
|
|
||||||
use Activitypub_Event_Extensions\Event_Plugins;
|
|
||||||
|
|
||||||
// Exit if accessed directly.
|
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Interface for a supported event plugin.
|
|
||||||
*
|
|
||||||
* This interface defines which information is necessary for a supported event plugin.
|
|
||||||
*
|
|
||||||
* @since 1.0.0
|
|
||||||
*/
|
|
||||||
final class My_Calendar extends Event_Plugin {
|
|
||||||
/**
|
|
||||||
* Returns the full plugin file.
|
|
||||||
*
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
public static function get_plugin_file(): string {
|
|
||||||
return 'my-calendar/my-calendar.php';
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the event post type of the plugin.
|
|
||||||
*
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
public static function get_post_type(): string {
|
|
||||||
return 'mc-events';
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the ID of the main settings page of the plugin.
|
|
||||||
*
|
|
||||||
* @return string The settings page url.
|
|
||||||
*/
|
|
||||||
public static function get_settings_page(): string {
|
|
||||||
return 'my-calendar-config';
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the taxonomy used for the plugin's event categories.
|
|
||||||
*
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
public static function get_event_category_taxonomy(): string {
|
|
||||||
return 'mc-event-category';
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,6 +1,6 @@
|
||||||
|
|
||||||
{
|
{
|
||||||
"name": "activitypub-event-bridge",
|
"name": "event-bridge-for-activitypub",
|
||||||
"version": "0.1.0",
|
"version": "0.1.0",
|
||||||
"author": {
|
"author": {
|
||||||
"name": "André Menrath",
|
"name": "André Menrath",
|
||||||
|
@ -15,7 +15,7 @@
|
||||||
},
|
},
|
||||||
"license": "AGPL-3.0",
|
"license": "AGPL-3.0",
|
||||||
"bugs": {
|
"bugs": {
|
||||||
"url": "https://code.event-federation.eu/Event-Federation/wordpress-activitypub-event-bridge/issues"
|
"url": "https://code.event-federation.eu/Event-Federation/wordpress-event-bridge-for-activitypub/issues"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@wordpress/env": "^10.10.0",
|
"@wordpress/env": "^10.10.0",
|
||||||
|
|
|
@ -108,8 +108,7 @@
|
||||||
<rule ref="WordPress.WP.I18n">
|
<rule ref="WordPress.WP.I18n">
|
||||||
<properties>
|
<properties>
|
||||||
<property name="text_domain" type="array">
|
<property name="text_domain" type="array">
|
||||||
<element value="activitypub-event-bridge"/>
|
<element value="event-bridge-for-activitypub"/>
|
||||||
<element value="activitypub"/>
|
|
||||||
</property>
|
</property>
|
||||||
</properties>
|
</properties>
|
||||||
</rule>
|
</rule>
|
||||||
|
@ -117,7 +116,7 @@
|
||||||
<rule ref="WordPress.NamingConventions.PrefixAllGlobals">
|
<rule ref="WordPress.NamingConventions.PrefixAllGlobals">
|
||||||
<properties>
|
<properties>
|
||||||
<property name="prefixes" type="array">
|
<property name="prefixes" type="array">
|
||||||
<element value="ACTIVITYPUB_EVENT_BRIDGE"/>
|
<element value="EVENT_BRIDGE_FOR_ACTIVITYPUB"/>
|
||||||
</property>
|
</property>
|
||||||
</properties>
|
</properties>
|
||||||
</rule>
|
</rule>
|
||||||
|
|
22
readme.txt
22
readme.txt
|
@ -1,9 +1,9 @@
|
||||||
=== ActivityPub Event Bridge ===
|
=== Event Bridge for ActivityPub ===
|
||||||
Contributors: andremenrath
|
Contributors: andremenrath
|
||||||
Tags: events, fediverse, activitypub, calendar
|
Tags: events, fediverse, activitypub, calendar
|
||||||
Requires at least: 6.5
|
Requires at least: 6.5
|
||||||
Tested up to: 6.7
|
Tested up to: 6.7
|
||||||
Stable tag: 0.2.1
|
Stable tag: 0.3.2
|
||||||
Requires PHP: 7.4
|
Requires PHP: 7.4
|
||||||
License: AGPL-3.0-or-later
|
License: AGPL-3.0-or-later
|
||||||
License URI: https://www.gnu.org/licenses/agpl-3.0.html
|
License URI: https://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
@ -12,7 +12,7 @@ Integrating popular event plugins with the ActivityPub plugin.
|
||||||
== Description ==
|
== Description ==
|
||||||
|
|
||||||
Make your events more discoverable, expand your reach effortlessly while being independent of other (commercial) platforms, and be a part of the growing decentralized web (the Fediverse).
|
Make your events more discoverable, expand your reach effortlessly while being independent of other (commercial) platforms, and be a part of the growing decentralized web (the Fediverse).
|
||||||
With the ActivityPub Event Bridge Plugin for WordPress, your events can be automatically followed, aggregated and displayed across decentralized platforms like [Mastodon](https://joinmastodon.org) or [Gancio](https://gancio.org), without any extra work.
|
With the Event Bridge for ActivityPub Plugin for WordPress, your events can be automatically followed, aggregated and displayed across decentralized platforms like [Mastodon](https://joinmastodon.org) or [Gancio](https://gancio.org), without any extra work.
|
||||||
Forget the hassle of managing multiple social media accounts just to keep your audience informed.
|
Forget the hassle of managing multiple social media accounts just to keep your audience informed.
|
||||||
|
|
||||||
This plugin is not an event managing plugin but an add-on to popular event plugins. It extends their functionality to fully support the [ActivityPub plugin](https://wordpress.org/plugins/activitypub/).
|
This plugin is not an event managing plugin but an add-on to popular event plugins. It extends their functionality to fully support the [ActivityPub plugin](https://wordpress.org/plugins/activitypub/).
|
||||||
|
@ -21,7 +21,7 @@ You retain full ownership of your content. By integrating into your existing set
|
||||||
|
|
||||||
= How It Works =
|
= How It Works =
|
||||||
|
|
||||||
With the ActivityPub Event Bridge WordPress plugin, sharing your events is effortless and automatic!
|
With the Event Bridge for ActivityPub WordPress plugin, sharing your events is effortless and automatic!
|
||||||
Once you create an event on your WordPress site, it is seamlessly shared across the decentralized web using the ActivityPub protocol.
|
Once you create an event on your WordPress site, it is seamlessly shared across the decentralized web using the ActivityPub protocol.
|
||||||
|
|
||||||
![](./.wordpress-org/event-activitypub-publishing.gif)
|
![](./.wordpress-org/event-activitypub-publishing.gif)
|
||||||
|
@ -38,7 +38,7 @@ The Event Federation plugin ensures that users from those platforms are provided
|
||||||
|
|
||||||
**ActivityPub-Enabled Event Sharing:** Your WordPress events are now compatible with the Fediverse, using the ActivityStreams format. This means your events can be easily discovered and followed by users on platforms like Mastodon and other ActivityPub-compatible services.
|
**ActivityPub-Enabled Event Sharing:** Your WordPress events are now compatible with the Fediverse, using the ActivityStreams format. This means your events can be easily discovered and followed by users on platforms like Mastodon and other ActivityPub-compatible services.
|
||||||
|
|
||||||
**Automatic Event Summaries:** When your event is shared on the Fediverse, platforms like Mastodon that don't fully support events will display a brief HTML summary of key details — such as the event's title, start time, and location. This ensures that even if someone can't view the full event on their platform, they still get the important info at a glance, with a link to your WordPress event page.
|
**Automatic Event Summaries:** When your event is shared on the Fediverse, platforms like Mastodon that don't fully support events will display a brief HTML summary of key details — such as the event's title, start time, and location. This ensures that even if someone can't view the full event on their platform, they still get the important info at a glance, with a link to your WordPress event page. Advanced users can create custom summaries via a set of shortcodes.
|
||||||
|
|
||||||
**Improved Event Discoverability:** Your custom event categories are mapped to a set of default categories used in the Fediverse, helping your events reach a wider audience. This improves the chances that users searching for similar events on other platforms will find yours.
|
**Improved Event Discoverability:** Your custom event categories are mapped to a set of default categories used in the Fediverse, helping your events reach a wider audience. This improves the chances that users searching for similar events on other platforms will find yours.
|
||||||
|
|
||||||
|
@ -57,6 +57,8 @@ This plugin depends on the [ActivityPub plugin](https://wordpress.org/plugins/ac
|
||||||
* [Eventin](https://de.wordpress.org/plugins/wp-event-solution/)
|
* [Eventin](https://de.wordpress.org/plugins/wp-event-solution/)
|
||||||
* [Modern Events Calendar Lite](https://webnus.net/modern-events-calendar/)
|
* [Modern Events Calendar Lite](https://webnus.net/modern-events-calendar/)
|
||||||
* [GatherPress](https://gatherpress.org/)
|
* [GatherPress](https://gatherpress.org/)
|
||||||
|
* [EventPrime – Events Calendar, Bookings and Tickets](https://wordpress.org/plugins/eventprime-event-calendar-management/)
|
||||||
|
* [Event Organiser](https://wordpress.org/plugins/event-organiser/)
|
||||||
|
|
||||||
== Configuration ==
|
== Configuration ==
|
||||||
|
|
||||||
|
@ -86,18 +88,14 @@ No, the Event Federation Plugin depends on the [ActivityPub plugin](https://word
|
||||||
|
|
||||||
= My event plugin is not supported, what can I do? =
|
= My event plugin is not supported, what can I do? =
|
||||||
|
|
||||||
If you know about coding have a look at the documentation of how to add your plugin or open an [issue](https://code.event-federation.eu/Event-Federation/wordpress-activitypub-event-bridge/issues), if we can spare some free hours we might add it.
|
If you know about coding have a look at the documentation of how to add your plugin or open an [issue](https://code.event-federation.eu/Event-Federation/wordpress-event-bridge-for-activitypub/issues), if we can spare some free hours we might add it.
|
||||||
|
|
||||||
= What if I experience problems? =
|
= What if I experience problems? =
|
||||||
|
|
||||||
We're always interested in your feedback. Feel free to reach out to us via [E-Mail](https://event-federation.eu/contact/) or create an [issue](https://code.event-federation.eu/Event-Federation/wordpress-activitypub-event-bridge/issues).
|
We're always interested in your feedback. Feel free to reach out to us via [E-Mail](https://event-federation.eu/contact/) or create an [issue](https://code.event-federation.eu/Event-Federation/wordpress-event-bridge-for-activitypub/issues).
|
||||||
|
|
||||||
== Changelog ==
|
== Changelog ==
|
||||||
|
|
||||||
= [0.2.1] 2024-11-16 =
|
= [0.3.2] 2024-12-12 =
|
||||||
|
|
||||||
* Initial release on https://wordpress.org/
|
* Initial release on https://wordpress.org/
|
||||||
|
|
||||||
= [0.2.0] 2024-10-29 =
|
|
||||||
|
|
||||||
* Initial submission to https://wordpress.org/
|
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
/**
|
/**
|
||||||
* Template for the header and navigation of the admin pages.
|
* Template for the header and navigation of the admin pages.
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
|
@ -18,18 +18,18 @@ $args = wp_parse_args(
|
||||||
);
|
);
|
||||||
?>
|
?>
|
||||||
|
|
||||||
<div class="activitypub-event-bridge-settings-header">
|
<div class="event-bridge-for-activitypub-settings-header">
|
||||||
<div class="activitypub-event-bridge-settings-title-section">
|
<div class="event-bridge-for-activitypub-settings-title-section">
|
||||||
<h1><?php \esc_html_e( 'ActivityPub Event Bridge', 'activitypub-event-bridge' ); ?></h1>
|
<h1><?php \esc_html_e( 'Event Bridge for ActivityPub', 'event-bridge-for-activitypub' ); ?></h1>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<nav class="activitypub-event-bridge-settings-tabs-wrapper" aria-label="<?php \esc_attr_e( 'Secondary menu', 'activitypub-event-bridge' ); ?>">
|
<nav class="event-bridge-for-activitypub-settings-tabs-wrapper" aria-label="<?php \esc_attr_e( 'Secondary menu', 'event-bridge-for-activitypub' ); ?>">
|
||||||
<a href="<?php echo \esc_url( admin_url( 'options-general.php?page=activitypub-event-bridge' ) ); ?>" class="activitypub-event-bridge-settings-tab <?php echo \esc_attr( $args['welcome'] ); ?>">
|
<a href="<?php echo \esc_url( admin_url( 'options-general.php?page=event-bridge-for-activitypub' ) ); ?>" class="event-bridge-for-activitypub-settings-tab <?php echo \esc_attr( $args['welcome'] ); ?>">
|
||||||
<?php \esc_html_e( 'Welcome', 'activitypub-event-bridge' ); ?>
|
<?php \esc_html_e( 'Welcome', 'event-bridge-for-activitypub' ); ?>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<a href="<?php echo \esc_url( admin_url( 'options-general.php?page=activitypub-event-bridge&tab=settings' ) ); ?>" class="activitypub-event-bridge-settings-tab <?php echo \esc_attr( $args['settings'] ); ?>">
|
<a href="<?php echo \esc_url( admin_url( 'options-general.php?page=event-bridge-for-activitypub&tab=settings' ) ); ?>" class="event-bridge-for-activitypub-settings-tab <?php echo \esc_attr( $args['settings'] ); ?>">
|
||||||
<?php \esc_html_e( 'Settings', 'activitypub-event-bridge' ); ?>
|
<?php \esc_html_e( 'Settings', 'event-bridge-for-activitypub' ); ?>
|
||||||
</a>
|
</a>
|
||||||
</nav>
|
</nav>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* Template for ActivityPub Event Bridge settings page.
|
* Template for Event Bridge for ActivityPub settings page.
|
||||||
*
|
*
|
||||||
* This template is used to display and manage settings for the ActivityPub Event Bridge plugin.
|
* This template is used to display and manage settings for the Event Bridge for ActivityPub plugin.
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*
|
*
|
||||||
* @param array $args An array of arguments for the settings page.
|
* @param array $args An array of arguments for the settings page.
|
||||||
|
@ -33,26 +33,72 @@ if ( ! current_user_can( 'manage_options' ) ) {
|
||||||
|
|
||||||
$event_terms = $args['event_terms'];
|
$event_terms = $args['event_terms'];
|
||||||
|
|
||||||
require_once ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_DIR . '/includes/event-categories.php';
|
require_once EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_DIR . '/includes/event-categories.php';
|
||||||
|
|
||||||
$selected_default_event_category = \get_option( 'activitypub_event_bridge_default_event_category', 'MEETING' );
|
$selected_default_event_category = \get_option( 'event_bridge_for_activitypub_default_event_category', 'MEETING' );
|
||||||
$current_category_mapping = \get_option( 'activitypub_event_bridge_event_category_mappings', array() );
|
$current_category_mapping = \get_option( 'event_bridge_for_activitypub_event_category_mappings', array() );
|
||||||
?>
|
?>
|
||||||
|
|
||||||
<div class="activitypub-event-bridge-settings activitypub-event-bridge-settings-page hide-if-no-js">
|
<div class="event-bridge-for-activitypub-settings event-bridge-for-activitypub-settings-page hide-if-no-js">
|
||||||
<form method="post" action="options.php">
|
<form method="post" action="options.php">
|
||||||
<?php \settings_fields( 'activitypub-event-bridge' ); ?>
|
<?php \settings_fields( 'event-bridge-for-activitypub' ); ?>
|
||||||
|
<div class="box">
|
||||||
|
<h2> <?php esc_html_e( 'Event Summary Text', 'event-bridge-for-activitypub' ); ?> </h2>
|
||||||
|
<p><?php esc_html_e( 'Many Fediverse applications (e.g., Mastodon) don\'t fully support events, instead they will show a summary text along with the events title and the URL to your Website.', 'event-bridge-for-activitypub' ); ?></p>
|
||||||
|
<p>
|
||||||
|
<label for="event_bridge_for_activitypub_summary_type_preset">
|
||||||
|
<input type="radio" name="event_bridge_for_activitypub_summary_type" id="event_bridge_for_activitypub_summary_type_preset" value="preset" <?php echo \checked( 'preset', \get_option( 'event_bridge_for_activitypub_summary_type', EVENT_BRIDGE_FOR_ACTIVITYPUB_DEFAULT_SUMMARY_TYPE ) ); ?> />
|
||||||
|
<?php \esc_html_e( 'Automatic (default)', 'event-bridge-for-activitypub' ); ?>
|
||||||
|
-
|
||||||
|
<span class="description">
|
||||||
|
<?php \esc_html_e( 'Let the plugin compose a summary for you. ', 'event-bridge-for-activitypub' ); ?>
|
||||||
|
</span>
|
||||||
|
</label>
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
<label for="event_bridge_for_activitypub_summary_type_custom">
|
||||||
|
<input type="radio" name="event_bridge_for_activitypub_summary_type" id="event_bridge_for_activitypub_summary_type_custom" value="custom" <?php echo \checked( 'custom', \get_option( 'event_bridge_for_activitypub_summary_type', EVENT_BRIDGE_FOR_ACTIVITYPUB_DEFAULT_SUMMARY_TYPE ) ); ?> />
|
||||||
|
<?php \esc_html_e( 'Custom', 'event-bridge-for-activitypub' ); ?>
|
||||||
|
-
|
||||||
|
<span class="description">
|
||||||
|
<?php \esc_html_e( 'For advanced users: compose your custom summary via shortcodes.', 'event-bridge-for-activitypub' ); ?>
|
||||||
|
</span>
|
||||||
|
</label>
|
||||||
|
</p>
|
||||||
|
<div id="event_bridge_for_activitypub_summary_type_custom-details">
|
||||||
|
<textarea name="event_bridge_for_activitypub_custom_summary" id="event_bridge_for_activitypub_custom_summary" rows="10" cols="50" class="large-text" placeholder="<?php echo wp_kses( EVENT_BRIDGE_FOR_ACTIVITYPUB_CUSTOM_SUMMARY, 'post' ); ?>"><?php echo esc_textarea( wp_kses( \get_option( 'event_bridge_for_activitypub_custom_summary', EVENT_BRIDGE_FOR_ACTIVITYPUB_CUSTOM_SUMMARY ), 'post' ) ); ?></textarea>
|
||||||
|
<details>
|
||||||
|
<summary><?php esc_html_e( 'See a list Template Tags available for the summary.', 'event-bridge-for-activitypub' ); ?></summary>
|
||||||
|
<div class="description">
|
||||||
|
<dl>
|
||||||
|
<dt><code>[ap_start_time]</code><dt>
|
||||||
|
<dd><?php \esc_html_e( 'The events title.', 'event-bridge-for-activitypub' ); ?></dd>
|
||||||
|
<dt><code>[ap_end_time]</code><dt>
|
||||||
|
<dd><?php \esc_html_e( 'The events content.', 'event-bridge-for-activitypub' ); ?></dd>
|
||||||
|
<dt><code>[ap_location]</code><dt>
|
||||||
|
<dd><?php \esc_html_e( 'The events location.', 'event-bridge-for-activitypub' ); ?></dd>
|
||||||
|
<dt><code>[ap_hashtags]</code><dt>
|
||||||
|
<dd><?php \esc_html_e( 'The events tags as hashtags.', 'event-bridge-for-activitypub' ); ?></dd>
|
||||||
|
<dt><code>[ap_excerpt]</code><dt>
|
||||||
|
<dd><?php \esc_html_e( 'The events excerpt (may be truncated).', 'event-bridge-for-activitypub' ); ?></dd>
|
||||||
|
<dt><code>[ap_content]</code><dt>
|
||||||
|
<dd><?php \esc_html_e( 'The events description.', 'event-bridge-for-activitypub' ); ?></dd>
|
||||||
|
</dl>
|
||||||
|
</div>
|
||||||
|
</details>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="box">
|
<div class="box">
|
||||||
<h2> <?php esc_html_e( 'ActivityPub Event Category', 'activitypub-event-bridge' ); ?> </h2>
|
<h2> <?php esc_html_e( 'ActivityPub Event Category', 'event-bridge-for-activitypub' ); ?> </h2>
|
||||||
<p> <?php esc_html_e( 'To help visitors find events more easily, the community created a set of basic event categories. Please select the category that best matches the majority of the events you organize.', 'activitypub-event-bridge' ); ?> </p>
|
<p> <?php esc_html_e( 'To help visitors find events more easily, the community created a set of basic event categories. Please select the category that best matches the majority of the events you organize.', 'event-bridge-for-activitypub' ); ?> </p>
|
||||||
<table class="form-table">
|
<table class="form-table">
|
||||||
<tr>
|
<tr>
|
||||||
<th scope="row"> <?php esc_html_e( 'Default Category', 'activitypub-event-bridge' ); ?> </th>
|
<th scope="row"> <?php esc_html_e( 'Default Category', 'event-bridge-for-activitypub' ); ?> </th>
|
||||||
<td>
|
<td>
|
||||||
<select id="activitypub_event_bridge_default_event_category" name="activitypub_event_bridge_default_event_category">';
|
<select id="event_bridge_for_activitypub_default_event_category" name="event_bridge_for_activitypub_default_event_category">';
|
||||||
<?php
|
<?php
|
||||||
foreach ( ACTIVITYPUB_EVENT_BRIDGE_EVENT_CATEGORIES as $value => $label ) {
|
foreach ( EVENT_BRIDGE_FOR_ACTIVITYPUB_EVENT_CATEGORIES as $value => $label ) {
|
||||||
echo '<option value="' . esc_attr( $value ) . '" ' . selected( $selected_default_event_category, $value, false ) . '>' . esc_html( $label ) . '</option>';
|
echo '<option value="' . esc_attr( $value ) . '" ' . selected( $selected_default_event_category, $value, false ) . '>' . esc_html( $label ) . '</option>';
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
|
@ -62,14 +108,14 @@ $current_category_mapping = \get_option( 'activitypub_event_bridge_event_
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
<?php if ( ! empty( $event_terms ) ) : ?>
|
<?php if ( ! empty( $event_terms ) ) : ?>
|
||||||
<h3> <?php esc_html_e( 'Advanced Event Category Settings', 'activitypub-event-bridge' ); ?> </h3>
|
<h3> <?php esc_html_e( 'Advanced Event Category Settings', 'event-bridge-for-activitypub' ); ?> </h3>
|
||||||
<p> <?php esc_html_e( 'Take more control by adjusting how your event categories are mapped to the basic category set used in ActivityPub. This option lets you override the default selection above, ensuring more accurate categorization and better visibility for your events.', 'activitypub-event-bridge' ); ?> </p>
|
<p> <?php esc_html_e( 'Take more control by adjusting how your event categories are mapped to the basic category set used in ActivityPub. This option lets you override the default selection above, ensuring more accurate categorization and better visibility for your events.', 'event-bridge-for-activitypub' ); ?> </p>
|
||||||
<table class="form-table">
|
<table class="form-table">
|
||||||
<?php foreach ( $event_terms as $event_term ) { ?>
|
<?php foreach ( $event_terms as $event_term ) { ?>
|
||||||
<tr>
|
<tr>
|
||||||
<th scope="row"> <?php echo esc_html( $event_term->name ); ?> </th>
|
<th scope="row"> <?php echo esc_html( $event_term->name ); ?> </th>
|
||||||
<td>
|
<td>
|
||||||
<select name="activitypub_event_bridge_event_category_mappings[<?php echo esc_attr( $event_term->slug ); ?>]">
|
<select name="event_bridge_for_activitypub_event_category_mappings[<?php echo esc_attr( $event_term->slug ); ?>]">
|
||||||
<?php
|
<?php
|
||||||
$current_mapping_is_set = false;
|
$current_mapping_is_set = false;
|
||||||
if ( ! empty( $current_category_mapping ) ) {
|
if ( ! empty( $current_category_mapping ) ) {
|
||||||
|
@ -81,13 +127,13 @@ $current_category_mapping = \get_option( 'activitypub_event_bridge_event_
|
||||||
$mapping = 'DEFAULT';
|
$mapping = 'DEFAULT';
|
||||||
}
|
}
|
||||||
if ( 'DEFAULT' === $mapping ) {
|
if ( 'DEFAULT' === $mapping ) {
|
||||||
echo '<option value="' . esc_attr( $mapping ) . '"> -- ' . esc_html( ACTIVITYPUB_EVENT_BRIDGE_EVENT_CATEGORIES[ $mapping ] ) . ' -- </option>';
|
echo '<option value="' . esc_attr( $mapping ) . '"> -- ' . esc_html( EVENT_BRIDGE_FOR_ACTIVITYPUB_EVENT_CATEGORIES[ $mapping ] ) . ' -- </option>';
|
||||||
} else {
|
} else {
|
||||||
echo '<option value="' . esc_attr( $mapping ) . '">' . esc_html( ACTIVITYPUB_EVENT_BRIDGE_EVENT_CATEGORIES[ $mapping ] ) . '</option>';
|
echo '<option value="' . esc_attr( $mapping ) . '">' . esc_html( EVENT_BRIDGE_FOR_ACTIVITYPUB_EVENT_CATEGORIES[ $mapping ] ) . '</option>';
|
||||||
}
|
}
|
||||||
echo '<option value="DEFAULT" ' . selected( $selected_default_event_category, 'DEFAULT', false ) . '> -- ' . esc_html__( 'Default', 'activitypub-event-bridge' ) . ' -- </option>';
|
echo '<option value="DEFAULT" ' . selected( $selected_default_event_category, 'DEFAULT', false ) . '> -- ' . esc_html__( 'Default', 'event-bridge-for-activitypub' ) . ' -- </option>';
|
||||||
foreach ( Event::DEFAULT_EVENT_CATEGORIES as $event_category ) {
|
foreach ( Event::DEFAULT_EVENT_CATEGORIES as $event_category ) {
|
||||||
echo '<option value="' . esc_attr( $event_category ) . '" ' . selected( $mappings[ $event_term->slug ] ?? '', $event_category, false ) . '>' . esc_html( ACTIVITYPUB_EVENT_BRIDGE_EVENT_CATEGORIES[ $event_category ] ) . '</option>';
|
echo '<option value="' . esc_attr( $event_category ) . '" ' . selected( $mappings[ $event_term->slug ] ?? '', $event_category, false ) . '>' . esc_html( EVENT_BRIDGE_FOR_ACTIVITYPUB_EVENT_CATEGORIES[ $event_category ] ) . '</option>';
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
</select>
|
</select>
|
||||||
|
@ -99,7 +145,7 @@ $current_category_mapping = \get_option( 'activitypub_event_bridge_event_
|
||||||
</div>
|
</div>
|
||||||
<!-- This disables the setup wizard. -->
|
<!-- This disables the setup wizard. -->
|
||||||
<div class="hidden">
|
<div class="hidden">
|
||||||
<input type="checkbox" id="activitypub_event_bridge_initially_activated" name="activitypub_event_bridge_initially_activated"/>
|
<input type="checkbox" id="event_bridge_for_activitypub_initially_activated" name="event_bridge_for_activitypub_initially_activated"/>
|
||||||
</div>
|
</div>
|
||||||
<?php \submit_button(); ?>
|
<?php \submit_button(); ?>
|
||||||
</form>
|
</form>
|
||||||
|
|
|
@ -1,16 +1,16 @@
|
||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* Status page for the ActivityPub Event Bridge.
|
* Status page for the Event Bridge for ActivityPub.
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// Exit if accessed directly.
|
// Exit if accessed directly.
|
||||||
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore
|
||||||
|
|
||||||
use ActivityPub_Event_Bridge\Setup;
|
use Event_Bridge_For_ActivityPub\Setup;
|
||||||
use ActivityPub_Event_Bridge\Admin\Settings_Page;
|
use Event_Bridge_For_ActivityPub\Admin\Settings_Page;
|
||||||
use ActivityPub_Event_Bridge\Admin\Health_Check;
|
use Event_Bridge_For_ActivityPub\Admin\Health_Check;
|
||||||
|
|
||||||
\load_template(
|
\load_template(
|
||||||
__DIR__ . '/admin-header.php',
|
__DIR__ . '/admin-header.php',
|
||||||
|
@ -20,9 +20,9 @@ use ActivityPub_Event_Bridge\Admin\Health_Check;
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
$active_event_plugins = Setup::get_instance()->get_active_event_plugins();
|
$active_event_plugins = Setup::get_instance()->get_active_event_plugins();
|
||||||
$activitypub_event_bridge_status_ok = true;
|
$event_bridge_for_activitypub_status_ok = true;
|
||||||
$example_event_post = Health_Check::get_most_recent_event_posts();
|
$example_event_post = Health_Check::get_most_recent_event_posts();
|
||||||
|
|
||||||
if ( empty( $example_event_post ) ) {
|
if ( empty( $example_event_post ) ) {
|
||||||
$example_event_post = 'https://yoursite.com/events/event-name';
|
$example_event_post = 'https://yoursite.com/events/event-name';
|
||||||
|
@ -37,13 +37,13 @@ WP_Filesystem();
|
||||||
|
|
||||||
?>
|
?>
|
||||||
|
|
||||||
<div class="activitypub-event-bridge-settings activitypub-event-bridge-settings-page hide-if-no-js">
|
<div class="event-bridge-for-activitypub-settings event-bridge-for-activitypub-settings-page hide-if-no-js">
|
||||||
<div class="box">
|
<div class="box">
|
||||||
<h2><?php \esc_html_e( 'Status', 'activitypub-event-bridge' ); ?></h2>
|
<h2><?php \esc_html_e( 'Status', 'event-bridge-for-activitypub' ); ?></h2>
|
||||||
<p><?php \esc_html_e( 'The ActivityPub Event Bridge detected the following (activated) event plugins:', 'activitypub-event-bridge' ); ?></p>
|
<p><?php \esc_html_e( 'The Event Bridge for ActivityPub detected the following (activated) event plugins:', 'event-bridge-for-activitypub' ); ?></p>
|
||||||
<?php foreach ( $active_event_plugins as $active_event_plugin ) { ?>
|
<?php foreach ( $active_event_plugins as $active_event_plugin ) { ?>
|
||||||
<h3><?php echo esc_html( $active_event_plugin->get_plugin_name() ); ?>:</h3>
|
<h3><?php echo esc_html( $active_event_plugin->get_plugin_name() ); ?>:</h3>
|
||||||
<ul class="activitypub-event-bridge-list">
|
<ul class="event-bridge-for-activitypub-list">
|
||||||
<li>
|
<li>
|
||||||
<?php
|
<?php
|
||||||
if ( in_array( $active_event_plugin::get_post_type(), get_option( 'activitypub_support_post_types', array() ), true ) ) {
|
if ( in_array( $active_event_plugin::get_post_type(), get_option( 'activitypub_support_post_types', array() ), true ) ) {
|
||||||
|
@ -53,21 +53,21 @@ WP_Filesystem();
|
||||||
_x(
|
_x(
|
||||||
'The ActivityPub support for the event post type of the plugin <i>%2$s</i> is enabled in the <a href="%3$s">%1$s settings</a>.',
|
'The ActivityPub support for the event post type of the plugin <i>%2$s</i> is enabled in the <a href="%3$s">%1$s settings</a>.',
|
||||||
'admin notice',
|
'admin notice',
|
||||||
'activitypub-event-bridge'
|
'event-bridge-for-activitypub'
|
||||||
),
|
),
|
||||||
esc_html( get_plugin_data( ACTIVITYPUB_PLUGIN_FILE )['Name'] ),
|
esc_html( get_plugin_data( ACTIVITYPUB_PLUGIN_FILE )['Name'] ),
|
||||||
esc_html( $active_event_plugin->get_plugin_name() ),
|
esc_html( $active_event_plugin->get_plugin_name() ),
|
||||||
admin_url( 'options-general.php?page=activitypub&tab=settings' )
|
admin_url( 'options-general.php?page=activitypub&tab=settings' )
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
$activitypub_event_bridge_status_ok = false;
|
$event_bridge_for_activitypub_status_ok = false;
|
||||||
echo '❌ ';
|
echo '❌ ';
|
||||||
$status_message_post_type_enabled = sprintf(
|
$status_message_post_type_enabled = sprintf(
|
||||||
/* translators: 1: the name of the event plugin a admin notice is shown. 2: The name of the ActivityPub plugin. */
|
/* translators: 1: the name of the event plugin a admin notice is shown. 2: The name of the ActivityPub plugin. */
|
||||||
_x(
|
_x(
|
||||||
'The post type for events of the plugin <i>%2$s</i> is <b>not enabled</b> in the <a href="%3$s">%1$s settings</a>.',
|
'The post type for events of the plugin <i>%2$s</i> is <b>not enabled</b> in the <a href="%3$s">%1$s settings</a>.',
|
||||||
'admin notice',
|
'admin notice',
|
||||||
'activitypub-event-bridge'
|
'event-bridge-for-activitypub'
|
||||||
),
|
),
|
||||||
esc_html( get_plugin_data( ACTIVITYPUB_PLUGIN_FILE )['Name'] ),
|
esc_html( get_plugin_data( ACTIVITYPUB_PLUGIN_FILE )['Name'] ),
|
||||||
esc_html( $active_event_plugin->get_plugin_name() ),
|
esc_html( $active_event_plugin->get_plugin_name() ),
|
||||||
|
@ -89,11 +89,11 @@ WP_Filesystem();
|
||||||
<?php
|
<?php
|
||||||
if ( Health_Check::test_if_event_transformer_is_used( $active_event_plugin ) ) {
|
if ( Health_Check::test_if_event_transformer_is_used( $active_event_plugin ) ) {
|
||||||
echo '✅ ';
|
echo '✅ ';
|
||||||
esc_html_e( 'The ActivityPub Event Bridge successfully registered to the ActivityPub plugin.', 'activitypub-event-bridge' );
|
esc_html_e( 'The Event Bridge for ActivityPub successfully registered to the ActivityPub plugin.', 'event-bridge-for-activitypub' );
|
||||||
} else {
|
} else {
|
||||||
$activitypub_event_bridge_status_ok = false;
|
$event_bridge_for_activitypub_status_ok = false;
|
||||||
echo '❌ ';
|
echo '❌ ';
|
||||||
esc_html_e( 'The ActivityPub Event Bridge could not register to the ActivityPub plugin.', 'activitypub-event-bridge' );
|
esc_html_e( 'The Event Bridge for ActivityPub could not register to the ActivityPub plugin.', 'event-bridge-for-activitypub' );
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
</li>
|
</li>
|
||||||
|
@ -101,95 +101,95 @@ WP_Filesystem();
|
||||||
<?php } ?>
|
<?php } ?>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<?php if ( get_option( 'activitypub_event_bridge_initially_activated', true ) ) : ?>
|
<?php if ( get_option( 'event_bridge_for_activitypub_initially_activated', true ) ) : ?>
|
||||||
<a href="<?php echo esc_url( admin_url( 'options-general.php?page=' . Settings_Page::SETTINGS_SLUG ) . '&tab=settings' ); ?>" role="button">
|
<a href="<?php echo esc_url( admin_url( 'options-general.php?page=' . Settings_Page::SETTINGS_SLUG ) . '&tab=settings' ); ?>" role="button">
|
||||||
<button class="button button-primary">
|
<button class="button button-primary">
|
||||||
<strong>→</strong> <?php \esc_html_e( 'Continue your setup', 'activitypub-event-bridge' ); ?>
|
<strong>→</strong> <?php \esc_html_e( 'Continue your setup', 'event-bridge-for-activitypub' ); ?>
|
||||||
</button>
|
</button>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<?php else : ?>
|
<?php else : ?>
|
||||||
|
|
||||||
<div class="box">
|
<div class="box">
|
||||||
<h2><?php \esc_html_e( 'How to Check if It\'s Working', 'activitypub-event-bridge' ); ?></h2>
|
<h2><?php \esc_html_e( 'How to Check if It\'s Working', 'event-bridge-for-activitypub' ); ?></h2>
|
||||||
<?php
|
<?php
|
||||||
if ( ! $activitypub_event_bridge_status_ok ) {
|
if ( ! $event_bridge_for_activitypub_status_ok ) {
|
||||||
echo '<div class="notice-warning"><p>' . \esc_html__( 'Please fix the status issues above first.', 'activitypub-event-bridge' ) . '</p></div>';
|
echo '<div class="notice-warning"><p>' . \esc_html__( 'Please fix the status issues above first.', 'event-bridge-for-activitypub' ) . '</p></div>';
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
<p><?php esc_html_e( 'Most of the magic happens behind the scenes, but here is how you can verify that your events are ready to be discovered:', 'activitypub-event-bridge' ); ?></p>
|
<p><?php esc_html_e( 'Most of the magic happens behind the scenes, but here is how you can verify that your events are ready to be discovered:', 'event-bridge-for-activitypub' ); ?></p>
|
||||||
<div class="activitypub-event-bridge-settings-accordion">
|
<div class="event-bridge-for-activitypub-settings-accordion">
|
||||||
<h4 class="activitypub-event-bridge-settings-accordion-heading">
|
<h4 class="event-bridge-for-activitypub-settings-accordion-heading">
|
||||||
<button aria-expanded="false" class="activitypub-event-bridge-settings-accordion-trigger" aria-controls="activitypub-event-bridge-help-accordion-mastodon" type="button">
|
<button aria-expanded="false" class="event-bridge-for-activitypub-settings-accordion-trigger" aria-controls="event-bridge-for-activitypub-help-accordion-mastodon" type="button">
|
||||||
<span class="title">
|
<span class="title">
|
||||||
1.
|
1.
|
||||||
<img src="<?php echo esc_url( plugins_url( '/assets/img/mastodon.svg', ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_FILE ) ); ?>" alt="Mastodon Icon" class="activitypub-event-bridge-settings-inline-icon">
|
<img src="<?php echo esc_url( plugins_url( '/assets/img/mastodon.svg', EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_FILE ) ); ?>" alt="Mastodon Icon" class="event-bridge-for-activitypub-settings-inline-icon">
|
||||||
<?php \esc_html_e( 'Using Your Mastodon Account', 'activitypub-event-bridge' ); ?>
|
<?php \esc_html_e( 'Using Your Mastodon Account', 'event-bridge-for-activitypub' ); ?>
|
||||||
</span>
|
</span>
|
||||||
<span class="icon"></span>
|
<span class="icon"></span>
|
||||||
</button>
|
</button>
|
||||||
</h4>
|
</h4>
|
||||||
<div id="activitypub-event-bridge-help-accordion-mastodon" class="activitypub-event-bridge-settings-accordion-panel" hidden="hidden">
|
<div id="event-bridge-for-activitypub-help-accordion-mastodon" class="event-bridge-for-activitypub-settings-accordion-panel" hidden="hidden">
|
||||||
<ol class="activitypub-event-bridge-settings-numbered-list">
|
<ol class="event-bridge-for-activitypub-settings-numbered-list">
|
||||||
<li><?php \esc_html_e( 'Log into your Mastodon account.', 'activitypub-event-bridge' ); ?></li>
|
<li><?php \esc_html_e( 'Log into your Mastodon account.', 'event-bridge-for-activitypub' ); ?></li>
|
||||||
<li>
|
<li>
|
||||||
<?php \esc_html_e( 'In the search bar, type or copy the full URL of one of your event pages. For example:', 'activitypub-event-bridge' ); ?>
|
<?php \esc_html_e( 'In the search bar, type or copy the full URL of one of your event pages. For example:', 'event-bridge-for-activitypub' ); ?>
|
||||||
<code class="activitypub-event-bridge-settings-example-url"><?php echo \esc_url( $example_event_post ); ?></code>
|
<code class="event-bridge-for-activitypub-settings-example-url"><?php echo \esc_url( $example_event_post ); ?></code>
|
||||||
</li>
|
</li>
|
||||||
<li><?php \esc_html_e( 'If everything is set up correctly, you\'ll see a post representing your event. It should include the event\'s image, title, and a brief description.', 'activitypub-event-bridge' ); ?></li>
|
<li><?php \esc_html_e( 'If everything is set up correctly, you\'ll see a post representing your event. It should include the event\'s image, title, and a brief description.', 'event-bridge-for-activitypub' ); ?></li>
|
||||||
</ol>
|
</ol>
|
||||||
</div>
|
</div>
|
||||||
<h4 class="activitypub-event-bridge-settings-accordion-heading">
|
<h4 class="event-bridge-for-activitypub-settings-accordion-heading">
|
||||||
<button aria-expanded="false" class="activitypub-event-bridge-settings-accordion-trigger" aria-controls="activitypub-event-bridge-help-accordion-mobilizon" type="button">
|
<button aria-expanded="false" class="event-bridge-for-activitypub-settings-accordion-trigger" aria-controls="event-bridge-for-activitypub-help-accordion-mobilizon" type="button">
|
||||||
<span class="title">
|
<span class="title">
|
||||||
2.
|
2.
|
||||||
<img src="<?php echo esc_url( plugins_url( '/assets/img/mobilizon.svg', ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_FILE ) ); ?>" alt="Mastodon Icon" class="activitypub-event-bridge-settings-inline-icon">
|
<img src="<?php echo esc_url( plugins_url( '/assets/img/mobilizon.svg', EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_FILE ) ); ?>" alt="Mastodon Icon" class="event-bridge-for-activitypub-settings-inline-icon">
|
||||||
<?php \esc_html_e( 'Using Your Mobilizon Account', 'activitypub-event-bridge' ); ?>
|
<?php \esc_html_e( 'Using Your Mobilizon Account', 'event-bridge-for-activitypub' ); ?>
|
||||||
</span>
|
</span>
|
||||||
<span class="icon"></span>
|
<span class="icon"></span>
|
||||||
</button>
|
</button>
|
||||||
</h4>
|
</h4>
|
||||||
<div id="activitypub-event-bridge-help-accordion-mobilizon" class="activitypub-event-bridge-settings-accordion-panel" hidden="hidden">
|
<div id="event-bridge-for-activitypub-help-accordion-mobilizon" class="event-bridge-for-activitypub-settings-accordion-panel" hidden="hidden">
|
||||||
<ol class="activitypub-event-bridge-settings-numbered-list">
|
<ol class="event-bridge-for-activitypub-settings-numbered-list">
|
||||||
<li><?php \esc_html_e( 'Log into your Mobilizon account.', 'activitypub-event-bridge' ); ?></li>
|
<li><?php \esc_html_e( 'Log into your Mobilizon account.', 'event-bridge-for-activitypub' ); ?></li>
|
||||||
<li>
|
<li>
|
||||||
<?php \esc_html_e( 'In the search bar, type or copy the full URL of one of your event pages. For example:', 'activitypub-event-bridge' ); ?>
|
<?php \esc_html_e( 'In the search bar, type or copy the full URL of one of your event pages. For example:', 'event-bridge-for-activitypub' ); ?>
|
||||||
<code class="activitypub-event-bridge-settings-example-url"><?php echo \esc_url( $example_event_post ); ?></code>
|
<code class="event-bridge-for-activitypub-settings-example-url"><?php echo \esc_url( $example_event_post ); ?></code>
|
||||||
</li>
|
</li>
|
||||||
<li><?php \esc_html_e( 'If everything is set up correctly, you\'ll see a full representation of your WordPress event. This will include the event\'s banner image, title, complete description, start and end times, categories, tags, and whether it\'s an online event.', 'activitypub-event-bridge' ); ?></li>
|
<li><?php \esc_html_e( 'If everything is set up correctly, you\'ll see a full representation of your WordPress event. This will include the event\'s banner image, title, complete description, start and end times, categories, tags, and whether it\'s an online event.', 'event-bridge-for-activitypub' ); ?></li>
|
||||||
</ol>
|
</ol>
|
||||||
</div>
|
</div>
|
||||||
<h4 class="activitypub-event-bridge-settings-accordion-heading">
|
<h4 class="event-bridge-for-activitypub-settings-accordion-heading">
|
||||||
<button aria-expanded="false" class="activitypub-event-bridge-settings-accordion-trigger" aria-controls="activitypub-event-bridge-help-accordion-fediverse" type="button">
|
<button aria-expanded="false" class="event-bridge-for-activitypub-settings-accordion-trigger" aria-controls="event-bridge-for-activitypub-help-accordion-fediverse" type="button">
|
||||||
<span class="title">
|
<span class="title">
|
||||||
3.
|
3.
|
||||||
<img src="<?php echo esc_url( plugins_url( '/assets/img/fediverse.svg', ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_FILE ) ); ?>" alt="Mastodon Icon" class="activitypub-event-bridge-settings-inline-icon">
|
<img src="<?php echo esc_url( plugins_url( '/assets/img/fediverse.svg', EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_FILE ) ); ?>" alt="Mastodon Icon" class="event-bridge-for-activitypub-settings-inline-icon">
|
||||||
<?php \esc_html_e( 'Using Any Other Fediverse Application', 'activitypub-event-bridge' ); ?>
|
<?php \esc_html_e( 'Using Any Other Fediverse Application', 'event-bridge-for-activitypub' ); ?>
|
||||||
</span>
|
</span>
|
||||||
<span class="icon"></span>
|
<span class="icon"></span>
|
||||||
</button>
|
</button>
|
||||||
</h4>
|
</h4>
|
||||||
<div id="activitypub-event-bridge-help-accordion-fediverse" class="activitypub-event-bridge-settings-accordion-panel" hidden="hidden">
|
<div id="event-bridge-for-activitypub-help-accordion-fediverse" class="event-bridge-for-activitypub-settings-accordion-panel" hidden="hidden">
|
||||||
<p><?php \esc_html_e( 'Of course any other application in the Fediverse should work as well. Most applications support importing external content via searching for the contents full URL.', 'activitypub-event-bridge' ); ?></p>
|
<p><?php \esc_html_e( 'Of course any other application in the Fediverse should work as well. Most applications support importing external content via searching for the contents full URL.', 'event-bridge-for-activitypub' ); ?></p>
|
||||||
<ol class="activitypub-event-bridge-settings-numbered-list">
|
<ol class="event-bridge-for-activitypub-settings-numbered-list">
|
||||||
<li><?php \esc_html_e( 'Log into your account on any Fediverse app.', 'activitypub-event-bridge' ); ?></li>
|
<li><?php \esc_html_e( 'Log into your account on any Fediverse app.', 'event-bridge-for-activitypub' ); ?></li>
|
||||||
<li>
|
<li>
|
||||||
<?php \esc_html_e( 'In the search bar, type or copy the full URL of one of your event pages. For example:', 'activitypub-event-bridge' ); ?>
|
<?php \esc_html_e( 'In the search bar, type or copy the full URL of one of your event pages. For example:', 'event-bridge-for-activitypub' ); ?>
|
||||||
<code class="activitypub-event-bridge-settings-example-url"><?php echo \esc_url( $example_event_post ); ?></code>
|
<code class="event-bridge-for-activitypub-settings-example-url"><?php echo \esc_url( $example_event_post ); ?></code>
|
||||||
</li>
|
</li>
|
||||||
<li><?php \esc_html_e( 'If the application which your are using natively supports ActivityPub events, you should see a representation of your WordPress event. If your application is supports receiving ActivityPub events you will get a post which summarizes the event. Keep in mind that some apps may not support events at all.', 'activitypub-event-bridge' ); ?></li>
|
<li><?php \esc_html_e( 'If the application which your are using natively supports ActivityPub events, you should see a representation of your WordPress event. If your application is supports receiving ActivityPub events you will get a post which summarizes the event. Keep in mind that some apps may not support events at all.', 'event-bridge-for-activitypub' ); ?></li>
|
||||||
</ol>
|
</ol>
|
||||||
</div>
|
</div>
|
||||||
<h4 class="activitypub-event-bridge-settings-accordion-heading">
|
<h4 class="event-bridge-for-activitypub-settings-accordion-heading">
|
||||||
<button aria-expanded="false" class="activitypub-event-bridge-settings-accordion-trigger" aria-controls="activitypub-event-bridge-help-accordion-advanced" type="button">
|
<button aria-expanded="false" class="event-bridge-for-activitypub-settings-accordion-trigger" aria-controls="event-bridge-for-activitypub-help-accordion-advanced" type="button">
|
||||||
<span class="title">
|
<span class="title">
|
||||||
4.
|
4.
|
||||||
<img src="<?php echo esc_url( plugins_url( '/assets/img/activitypub.svg', ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_FILE ) ); ?>" alt="Mastodon Icon" class="activitypub-event-bridge-settings-inline-icon">
|
<img src="<?php echo esc_url( plugins_url( '/assets/img/activitypub.svg', EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_FILE ) ); ?>" alt="Mastodon Icon" class="event-bridge-for-activitypub-settings-inline-icon">
|
||||||
<?php \esc_html_e( 'Advanced: Verifying the ActivityStreams JSON', 'activitypub-event-bridge' ); ?></span>
|
<?php \esc_html_e( 'Advanced: Verifying the ActivityStreams JSON', 'event-bridge-for-activitypub' ); ?></span>
|
||||||
<span class="icon"></span>
|
<span class="icon"></span>
|
||||||
</button>
|
</button>
|
||||||
</h4>
|
</h4>
|
||||||
<div id="activitypub-event-bridge-help-accordion-advanced" class="activitypub-event-bridge-settings-accordion-panel" hidden="hidden">
|
<div id="event-bridge-for-activitypub-help-accordion-advanced" class="event-bridge-for-activitypub-settings-accordion-panel" hidden="hidden">
|
||||||
<p>
|
<p>
|
||||||
<?php
|
<?php
|
||||||
// Assume $event_url contains the dynamic URL, and '?activitypub' is appended to it.
|
// Assume $event_url contains the dynamic URL, and '?activitypub' is appended to it.
|
||||||
|
@ -202,7 +202,7 @@ WP_Filesystem();
|
||||||
|
|
||||||
// Translator comment to explain the placeholder.
|
// Translator comment to explain the placeholder.
|
||||||
/* translators: %1$s is the <code>?activitypub</code> string, and %2$s is the full URL of an example event */
|
/* translators: %1$s is the <code>?activitypub</code> string, and %2$s is the full URL of an example event */
|
||||||
$raw_string = sprintf( __( 'For more technical users, you can inspect how your event is converted into an ActivityPub object. Simply append %1$s to the end of any single event pages URL to view the raw ActivityStreams JSON data (e.g., %2$s).', 'activitypub-event-bridge' ), $activitypub_query, $activitypub_url_html );
|
$raw_string = sprintf( __( 'For more technical users, you can inspect how your event is converted into an ActivityPub object. Simply append %1$s to the end of any single event pages URL to view the raw ActivityStreams JSON data (e.g., %2$s).', 'event-bridge-for-activitypub' ), $activitypub_query, $activitypub_url_html );
|
||||||
|
|
||||||
// Allowed HTML tags in the string (only <code> and <a>).
|
// Allowed HTML tags in the string (only <code> and <a>).
|
||||||
$allowed_html = array(
|
$allowed_html = array(
|
||||||
|
@ -223,10 +223,10 @@ WP_Filesystem();
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="box">
|
<div class="box">
|
||||||
<h2><?php \esc_html_e( 'Changelog', 'activitypub-event-bridge' ); ?></h2>
|
<h2><?php \esc_html_e( 'Changelog', 'event-bridge-for-activitypub' ); ?></h2>
|
||||||
<pre>
|
<pre>
|
||||||
<?php
|
<?php
|
||||||
$changelog = $wp_filesystem->get_contents( ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_DIR . '/CHANGELOG.md' );
|
$changelog = $wp_filesystem->get_contents( EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_DIR . '/CHANGELOG.md' );
|
||||||
echo esc_html( substr( $changelog, strpos( $changelog, "\n", 180 ) + 1 ) );
|
echo esc_html( substr( $changelog, strpos( $changelog, "\n", 180 ) + 1 ) );
|
||||||
?>
|
?>
|
||||||
</pre>
|
</pre>
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
/**
|
/**
|
||||||
* PHPUnit bootstrap file.
|
* PHPUnit bootstrap file.
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
*/
|
*/
|
||||||
|
|
||||||
$_tests_dir = getenv( 'WP_TESTS_DIR' );
|
$_tests_dir = getenv( 'WP_TESTS_DIR' );
|
||||||
|
@ -25,6 +25,21 @@ if ( ! file_exists( "{$_tests_dir}/includes/functions.php" ) ) {
|
||||||
// Give access to tests_add_filter() function.
|
// Give access to tests_add_filter() function.
|
||||||
require_once "{$_tests_dir}/includes/functions.php";
|
require_once "{$_tests_dir}/includes/functions.php";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to manually load an event plugin.
|
||||||
|
*
|
||||||
|
* @param string $plugin_file The main plugin file of the event plugin.
|
||||||
|
*/
|
||||||
|
function _manually_load_event_plugin( $plugin_file ) {
|
||||||
|
$plugin_dir = ABSPATH . '/wp-content/plugins/';
|
||||||
|
require_once $plugin_dir . $plugin_file;
|
||||||
|
update_option( 'purchase_history_table_structure_migration_done', true );
|
||||||
|
$current = get_option( 'active_plugins', array() );
|
||||||
|
$current[] = $plugin_file;
|
||||||
|
sort( $current );
|
||||||
|
update_option( 'active_plugins', $current );
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Manually load the plugin being tested and its integrations.
|
* Manually load the plugin being tested and its integrations.
|
||||||
*/
|
*/
|
||||||
|
@ -35,10 +50,10 @@ function _manually_load_plugin() {
|
||||||
require_once $plugin_dir . 'activitypub/activitypub.php';
|
require_once $plugin_dir . 'activitypub/activitypub.php';
|
||||||
|
|
||||||
// Capture the --filter argument.
|
// Capture the --filter argument.
|
||||||
$activitypub_event_bridge_integration_filter = null;
|
$event_bridge_for_activitypub_integration_filter = null;
|
||||||
foreach ( $_SERVER['argv'] as $arg ) {
|
foreach ( $_SERVER['argv'] as $arg ) {
|
||||||
if ( strpos( $arg, '--filter=' ) === 0 ) {
|
if ( strpos( $arg, '--filter=' ) === 0 ) {
|
||||||
$activitypub_event_bridge_integration_filter = substr( $arg, strlen( '--filter=' ) );
|
$event_bridge_for_activitypub_integration_filter = substr( $arg, strlen( '--filter=' ) );
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -49,7 +64,7 @@ function _manually_load_plugin() {
|
||||||
|
|
||||||
$plugin_file = null;
|
$plugin_file = null;
|
||||||
// See if we want to run integration tests for a specific event-plugin.
|
// See if we want to run integration tests for a specific event-plugin.
|
||||||
switch ( $activitypub_event_bridge_integration_filter ) {
|
switch ( $event_bridge_for_activitypub_integration_filter ) {
|
||||||
case 'the_events_calendar':
|
case 'the_events_calendar':
|
||||||
$plugin_file = 'the-events-calendar/the-events-calendar.php';
|
$plugin_file = 'the-events-calendar/the-events-calendar.php';
|
||||||
break;
|
break;
|
||||||
|
@ -71,42 +86,39 @@ function _manually_load_plugin() {
|
||||||
case 'wp_event_manager':
|
case 'wp_event_manager':
|
||||||
$plugin_file = 'wp-event-manager/wp-event-manager.php';
|
$plugin_file = 'wp-event-manager/wp-event-manager.php';
|
||||||
break;
|
break;
|
||||||
case 'my_calendar':
|
case 'eventprime':
|
||||||
$plugin_file = 'my-calendar/my-calendar.php';
|
$plugin_file = 'eventprime-event-calendar-management/event-prime.php';
|
||||||
|
break;
|
||||||
|
case 'event_organiser':
|
||||||
|
$plugin_file = 'event-organiser/event-organiser.php';
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( $plugin_file ) {
|
if ( $plugin_file ) {
|
||||||
// Manually load the event plugin.
|
_manually_load_event_plugin( $plugin_file );
|
||||||
require_once $plugin_dir . $plugin_file;
|
} else {
|
||||||
update_option( 'purchase_history_table_structure_migration_done', true );
|
// For all other tests we mainly use the Events Calendar as a reference.
|
||||||
$current = get_option( 'active_plugins', array() );
|
_manually_load_event_plugin( 'the-events-calendar/the-events-calendar.php' );
|
||||||
$current[] = $plugin_file;
|
_manually_load_event_plugin( 'very-simple-event-list/vsel.php' );
|
||||||
sort( $current );
|
|
||||||
update_option( 'active_plugins', $current );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Hot fix that allows using Events Manager within unit tests, because the em_init() is later not run as admin.
|
// Hot fix that allows using Events Manager within unit tests, because the em_init() is later not run as admin.
|
||||||
if ( 'events_manager' === $activitypub_event_bridge_integration_filter ) {
|
if ( 'events_manager' === $event_bridge_for_activitypub_integration_filter ) {
|
||||||
require_once $plugin_dir . 'events-manager/em-install.php';
|
require_once $plugin_dir . 'events-manager/em-install.php';
|
||||||
em_create_events_table();
|
em_create_events_table();
|
||||||
em_create_events_meta_table();
|
em_create_events_meta_table();
|
||||||
em_create_locations_table();
|
em_create_locations_table();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( 'modern_events_calendar_lite' === $activitypub_event_bridge_integration_filter ) {
|
if ( 'modern_events_calendar_lite' === $event_bridge_for_activitypub_integration_filter ) {
|
||||||
require_once $plugin_dir . 'modern-events-calendar-lite/app/libraries/factory.php';
|
require_once $plugin_dir . 'modern-events-calendar-lite/app/libraries/factory.php';
|
||||||
$mec_factory = new MEC_factory();
|
$mec_factory = new MEC_factory();
|
||||||
$mec_factory->install();
|
$mec_factory->install();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( 'my_calendar' === $activitypub_event_extension_integration_filter ) {
|
|
||||||
require_once $plugin_dir . 'my-calendar/my-calendar.php';
|
|
||||||
add_action( 'init', 'mc_default_settings' );
|
|
||||||
}
|
|
||||||
|
|
||||||
// At last manually load our WordPress plugin.
|
// At last manually load our WordPress plugin.
|
||||||
require dirname( __DIR__ ) . '/activitypub-event-bridge.php';
|
require dirname( __DIR__ ) . '/event-bridge-for-activitypub.php';
|
||||||
}
|
}
|
||||||
|
|
||||||
tests_add_filter( 'muplugins_loaded', '_manually_load_plugin' );
|
tests_add_filter( 'muplugins_loaded', '_manually_load_plugin' );
|
||||||
|
|
193
tests/test-class-activitypub-event-bridge-shortcodes.php
Normal file
193
tests/test-class-activitypub-event-bridge-shortcodes.php
Normal file
|
@ -0,0 +1,193 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Test file for Activitypub Shortcodes.
|
||||||
|
*
|
||||||
|
* @package Event_Bridge_For_ActivityPub
|
||||||
|
* @license AGPL-3.0-or-later
|
||||||
|
*/
|
||||||
|
|
||||||
|
use Activitypub\Shortcodes;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test class for Activitypub Shortcodes.
|
||||||
|
*
|
||||||
|
* @coversDefaultClass \Activitypub\Shortcodes
|
||||||
|
*/
|
||||||
|
class Test_Activitypub_Event_Bridge_Shortcodes extends WP_UnitTestCase {
|
||||||
|
/**
|
||||||
|
* Override the setup function, so that tests don't run if the Events Calendar is not active.
|
||||||
|
*/
|
||||||
|
public function set_up() {
|
||||||
|
parent::set_up();
|
||||||
|
|
||||||
|
if ( ! class_exists( '\Tribe__Events__Main' ) ) {
|
||||||
|
self::markTestSkipped( 'The Events Calendar plugin is needed to test Event Shortcodes' );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Make sure that ActivityPub support is enabled for The Events Calendar.
|
||||||
|
$aec = \Event_Bridge_For_ActivityPub\Setup::get_instance();
|
||||||
|
$aec->activate_activitypub_support_for_active_event_plugins();
|
||||||
|
|
||||||
|
// Delete all posts afterwards.
|
||||||
|
_delete_all_posts();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test the shortcode for rendering the events start time.
|
||||||
|
*/
|
||||||
|
public function test_start_time() {
|
||||||
|
// Create a The Events Calendar Event without content.
|
||||||
|
$wp_object = tribe_events()
|
||||||
|
->set_args( Test_The_Events_Calendar::MOCKUP_EVENTS['minimal_event'] )
|
||||||
|
->create();
|
||||||
|
|
||||||
|
// Call the transformer Factory.
|
||||||
|
$transformer = \Activitypub\Transformer\Factory::get_transformer( $wp_object );
|
||||||
|
|
||||||
|
if ( ! $transformer instanceof \Event_Bridge_For_ActivityPub\Activitypub\Transformer\Event ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$transformer->register_shortcodes();
|
||||||
|
|
||||||
|
$summary = '[ap_start_time]';
|
||||||
|
$summary = do_shortcode( $summary );
|
||||||
|
$this->assertEquals( '🗓️ Start: December 1, 2024 3:00 pm', $summary );
|
||||||
|
|
||||||
|
$summary = '[ap_start_time icon="false"]';
|
||||||
|
$summary = do_shortcode( $summary );
|
||||||
|
$this->assertEquals( 'Start: December 1, 2024 3:00 pm', $summary );
|
||||||
|
|
||||||
|
$summary = '[ap_start_time icon="false" label="false"]';
|
||||||
|
$summary = do_shortcode( $summary );
|
||||||
|
$this->assertEquals( 'December 1, 2024 3:00 pm', $summary );
|
||||||
|
|
||||||
|
$transformer->unregister_shortcodes();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test the shortcode for rendering the events end time.
|
||||||
|
*/
|
||||||
|
public function test_end_time() {
|
||||||
|
// Create a The Events Calendar Event without content.
|
||||||
|
$wp_object = tribe_events()
|
||||||
|
->set_args( Test_The_Events_Calendar::MOCKUP_EVENTS['minimal_event'] )
|
||||||
|
->create();
|
||||||
|
|
||||||
|
// Call the transformer Factory.
|
||||||
|
$transformer = \Activitypub\Transformer\Factory::get_transformer( $wp_object );
|
||||||
|
|
||||||
|
if ( ! $transformer instanceof \Event_Bridge_For_ActivityPub\Activitypub\Transformer\Event ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$transformer->register_shortcodes();
|
||||||
|
|
||||||
|
$summary = '[ap_end_time]';
|
||||||
|
$summary = do_shortcode( $summary );
|
||||||
|
$this->assertEquals( '⏳ End: December 1, 2024 4:00 pm', $summary );
|
||||||
|
|
||||||
|
$summary = '[ap_end_time icon="false"]';
|
||||||
|
$summary = do_shortcode( $summary );
|
||||||
|
$this->assertEquals( 'End: December 1, 2024 4:00 pm', $summary );
|
||||||
|
|
||||||
|
$summary = '[ap_end_time icon="false" label="false"]';
|
||||||
|
$summary = do_shortcode( $summary );
|
||||||
|
$this->assertEquals( 'December 1, 2024 4:00 pm', $summary );
|
||||||
|
|
||||||
|
$transformer->unregister_shortcodes();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test the shortcode for rendering the events location when no location is set.
|
||||||
|
*/
|
||||||
|
public function test_location_when_no_location_is_set() {
|
||||||
|
// Create a The Events Calendar Event without content.
|
||||||
|
$wp_object = tribe_events()
|
||||||
|
->set_args( Test_The_Events_Calendar::MOCKUP_EVENTS['minimal_event'] )
|
||||||
|
->create();
|
||||||
|
|
||||||
|
// Call the transformer Factory.
|
||||||
|
$transformer = \Activitypub\Transformer\Factory::get_transformer( $wp_object );
|
||||||
|
|
||||||
|
if ( ! $transformer instanceof \Event_Bridge_For_ActivityPub\Activitypub\Transformer\Event ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$transformer->register_shortcodes();
|
||||||
|
|
||||||
|
$summary = '[ap_location]';
|
||||||
|
$summary = do_shortcode( $summary );
|
||||||
|
$this->assertEquals( '', $summary );
|
||||||
|
|
||||||
|
$transformer->unregister_shortcodes();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test the shortcode for rendering the events location when location is set.
|
||||||
|
*/
|
||||||
|
public function test_location_when_location_is_set() {
|
||||||
|
// Create Venue.
|
||||||
|
$venue = tribe_venues()->set_args( Test_The_Events_Calendar::MOCKUP_VENUS['minimal_venue'] )->create();
|
||||||
|
// Create a The Events Calendar Event.
|
||||||
|
$wp_object = tribe_events()
|
||||||
|
->set_args( Test_The_Events_Calendar::MOCKUP_EVENTS['complex_event'] )
|
||||||
|
->set( 'venue', $venue->ID )
|
||||||
|
->create();
|
||||||
|
|
||||||
|
// Call the transformer Factory.
|
||||||
|
$transformer = \Activitypub\Transformer\Factory::get_transformer( $wp_object );
|
||||||
|
|
||||||
|
if ( ! $transformer instanceof \Event_Bridge_For_ActivityPub\Activitypub\Transformer\Event ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$transformer->register_shortcodes();
|
||||||
|
|
||||||
|
$summary = '[ap_location]';
|
||||||
|
$summary = do_shortcode( $summary );
|
||||||
|
$this->assertEquals( '📍 Location: Minimal Venue', $summary );
|
||||||
|
|
||||||
|
$summary = '[ap_location icon="false"]';
|
||||||
|
$summary = do_shortcode( $summary );
|
||||||
|
$this->assertEquals( 'Location: Minimal Venue', $summary );
|
||||||
|
|
||||||
|
$summary = '[ap_location icon="false" label="false"]';
|
||||||
|
$summary = do_shortcode( $summary );
|
||||||
|
$this->assertEquals( 'Minimal Venue', $summary );
|
||||||
|
|
||||||
|
$transformer->unregister_shortcodes();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test the shortcode for rendering the events location when location with detailed address is set.
|
||||||
|
*/
|
||||||
|
public function test_location_when_detailed_location_is_set() {
|
||||||
|
// Create Venue.
|
||||||
|
$venue = tribe_venues()->set_args( Test_The_Events_Calendar::MOCKUP_VENUS['complex_venue'] )->create();
|
||||||
|
// Create a The Events Calendar Event.
|
||||||
|
$wp_object = tribe_events()
|
||||||
|
->set_args( Test_The_Events_Calendar::MOCKUP_EVENTS['complex_event'] )
|
||||||
|
->set( 'venue', $venue->ID )
|
||||||
|
->create();
|
||||||
|
|
||||||
|
// Call the transformer Factory.
|
||||||
|
$transformer = \Activitypub\Transformer\Factory::get_transformer( $wp_object );
|
||||||
|
|
||||||
|
if ( ! $transformer instanceof \Event_Bridge_For_ActivityPub\Activitypub\Transformer\Event ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$transformer->register_shortcodes();
|
||||||
|
|
||||||
|
$summary = '[ap_location]';
|
||||||
|
$summary = do_shortcode( $summary );
|
||||||
|
$this->assertEquals( '📍 Location: Complex Venue, Venue address, Venue zip, Venue city, Venue country', $summary );
|
||||||
|
|
||||||
|
$summary = '[ap_location country="false"]';
|
||||||
|
$summary = do_shortcode( $summary );
|
||||||
|
$this->assertEquals( '📍 Location: Complex Venue, Venue address, Venue zip, Venue city', $summary );
|
||||||
|
|
||||||
|
$transformer->unregister_shortcodes();
|
||||||
|
}
|
||||||
|
}
|
153
tests/test-class-plugin-event-organiser.php
Normal file
153
tests/test-class-plugin-event-organiser.php
Normal file
|
@ -0,0 +1,153 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Test class for the integration of the Event Organiser.
|
||||||
|
*
|
||||||
|
* @package Event_Bridge_For_ActivityPub
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sample test case.
|
||||||
|
*/
|
||||||
|
class Test_Event_Organiser extends WP_UnitTestCase {
|
||||||
|
/**
|
||||||
|
* Override the setup function, so that tests don't run if the Events Calendar is not active.
|
||||||
|
*/
|
||||||
|
public function set_up() {
|
||||||
|
parent::set_up();
|
||||||
|
|
||||||
|
if ( ! function_exists( 'eo_get_events' ) ) {
|
||||||
|
self::markTestSkipped( 'Event Organiser plugin is not active.' );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Make sure that ActivityPub support is enabled.
|
||||||
|
$aec = \Event_Bridge_For_ActivityPub\Setup::get_instance();
|
||||||
|
$aec->activate_activitypub_support_for_active_event_plugins();
|
||||||
|
|
||||||
|
// Run the install script just in time which makes sure the custom tables exist and more.
|
||||||
|
eventorganiser_install();
|
||||||
|
|
||||||
|
// Delete all posts afterwards.
|
||||||
|
_delete_all_posts();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test that the right transformer gets applied.
|
||||||
|
*/
|
||||||
|
public function test_transformer_class() {
|
||||||
|
// We only test for one event plugin being active at the same time,
|
||||||
|
// even though we support multiple onces in theory.
|
||||||
|
// But testing all combinations is beyond scope.
|
||||||
|
$active_event_plugins = \Event_Bridge_For_ActivityPub\Setup::get_instance()->get_active_event_plugins();
|
||||||
|
$this->assertEquals( 1, count( $active_event_plugins ) );
|
||||||
|
|
||||||
|
// Enable ActivityPub support for the event plugin.
|
||||||
|
$this->assertContains( 'event', get_option( 'activitypub_support_post_types' ) );
|
||||||
|
|
||||||
|
$event_data = array(
|
||||||
|
'start' => new DateTime( '+10 days 15:00:00', eo_get_blog_timezone() ),
|
||||||
|
'end' => new DateTime( '+10 days 16:00:00', eo_get_blog_timezone() ),
|
||||||
|
'all_day' => 0,
|
||||||
|
'schedule' => 'once',
|
||||||
|
);
|
||||||
|
|
||||||
|
$post_data = array(
|
||||||
|
'post_title' => 'Unit Test Event',
|
||||||
|
'post_content' => 'Unit Test description.',
|
||||||
|
'post_status' => 'publish',
|
||||||
|
);
|
||||||
|
|
||||||
|
$post_id = eo_insert_event( $post_data, $event_data );
|
||||||
|
|
||||||
|
// Call the transformer Factory.
|
||||||
|
$transformer = \Activitypub\Transformer\Factory::get_transformer( get_post( $post_id ) );
|
||||||
|
|
||||||
|
// Check that we got the right transformer.
|
||||||
|
$this->assertInstanceOf( \Event_Bridge_For_ActivityPub\Activitypub\Transformer\Event_Organiser::class, $transformer );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test transformation to ActivityPub for basic event.
|
||||||
|
*/
|
||||||
|
public function test_transform_of_basic_event() {
|
||||||
|
// Mock Event.
|
||||||
|
$event_data = array(
|
||||||
|
'start' => new DateTime( '+10 days 15:00:00', eo_get_blog_timezone() ),
|
||||||
|
'end' => new DateTime( '+10 days 16:00:00', eo_get_blog_timezone() ),
|
||||||
|
'all_day' => 0,
|
||||||
|
'schedule' => 'once',
|
||||||
|
);
|
||||||
|
|
||||||
|
$post_data = array(
|
||||||
|
'post_title' => 'Unit Test Event',
|
||||||
|
'post_content' => 'Unit Test description.',
|
||||||
|
'post_status' => 'publish',
|
||||||
|
);
|
||||||
|
|
||||||
|
$post_id = eo_insert_event( $post_data, $event_data );
|
||||||
|
|
||||||
|
// Call the transformer Factory.
|
||||||
|
$event_array = \Activitypub\Transformer\Factory::get_transformer( get_post( $post_id ) )->to_object()->to_array();
|
||||||
|
|
||||||
|
// Check that the event ActivityStreams representation contains everything as expected.
|
||||||
|
$this->assertEquals( 'Event', $event_array['type'] );
|
||||||
|
$this->assertEquals( 'Unit Test Event', $event_array['name'] );
|
||||||
|
$this->assertEquals( 'Unit Test description.', wp_strip_all_tags( $event_array['content'] ) );
|
||||||
|
$this->assertEquals( gmdate( 'Y-m-d', strtotime( '+10 days 15:00:00' ) ) . 'T15:00:00Z', $event_array['startTime'] );
|
||||||
|
$this->assertEquals( gmdate( 'Y-m-d', strtotime( '+10 days 16:00:00' ) ) . 'T16:00:00Z', $event_array['endTime'] );
|
||||||
|
$this->assertEquals( 'external', $event_array['joinMode'] );
|
||||||
|
$this->assertArrayNotHasKey( 'location', $event_array );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test transformation to ActivityPub for event with location.
|
||||||
|
*/
|
||||||
|
public function test_transform_of_event_with_location() {
|
||||||
|
// Create venue.
|
||||||
|
$venue_args = array(
|
||||||
|
'description' => 'This is a test venue for the Fediverse.',
|
||||||
|
'address' => 'Fediverse-Street 1337',
|
||||||
|
'city' => 'Fediverse-Town',
|
||||||
|
'state' => 'Fediverse-Sate',
|
||||||
|
'postcode' => '1337',
|
||||||
|
'country' => 'Fediverse-Country',
|
||||||
|
'latitude' => 7.076668,
|
||||||
|
'longitude' => 15.421371,
|
||||||
|
);
|
||||||
|
$venue_name = 'Fediverse Venue';
|
||||||
|
$venue = eo_insert_venue( $venue_name, $venue_args );
|
||||||
|
|
||||||
|
// Mock Event.
|
||||||
|
$event_data = array(
|
||||||
|
'start' => new DateTime( '+10 days 15:00:00', eo_get_blog_timezone() ),
|
||||||
|
'end' => new DateTime( '+10 days 16:00:00', eo_get_blog_timezone() ),
|
||||||
|
'all_day' => 0,
|
||||||
|
'schedule' => 'once',
|
||||||
|
);
|
||||||
|
$post_data = array(
|
||||||
|
'post_title' => 'Unit Test Event',
|
||||||
|
'post_content' => 'Unit Test description.',
|
||||||
|
'post_status' => 'publish',
|
||||||
|
);
|
||||||
|
$post_id = eo_insert_event( $post_data, $event_data );
|
||||||
|
wp_set_object_terms( $post_id, $venue['term_id'], 'event-venue' );
|
||||||
|
|
||||||
|
// Call the transformer Factory.
|
||||||
|
$event_array = \Activitypub\Transformer\Factory::get_transformer( get_post( $post_id ) )->to_object()->to_array();
|
||||||
|
|
||||||
|
// Check that the event ActivityStreams representation contains everything as expected.
|
||||||
|
$this->assertEquals( 'Event', $event_array['type'] );
|
||||||
|
$this->assertEquals( 'Unit Test Event', $event_array['name'] );
|
||||||
|
$this->assertEquals( 'Unit Test description.', wp_strip_all_tags( $event_array['content'] ) );
|
||||||
|
$this->assertEquals( gmdate( 'Y-m-d', strtotime( '+10 days 15:00:00' ) ) . 'T15:00:00Z', $event_array['startTime'] );
|
||||||
|
$this->assertEquals( gmdate( 'Y-m-d', strtotime( '+10 days 16:00:00' ) ) . 'T16:00:00Z', $event_array['endTime'] );
|
||||||
|
$this->assertEquals( 'external', $event_array['joinMode'] );
|
||||||
|
$this->assertArrayHasKey( 'location', $event_array );
|
||||||
|
$this->assertEquals( $venue_args['description'], wp_strip_all_tags( $event_array['location']['content'] ) );
|
||||||
|
$this->assertEquals( $venue_args['address'], $event_array['location']['address']['streetAddress'] );
|
||||||
|
$this->assertEquals( $venue_args['city'], $event_array['location']['address']['addressLocality'] );
|
||||||
|
$this->assertEquals( $venue_args['state'], $event_array['location']['address']['addressRegion'] );
|
||||||
|
$this->assertEquals( $venue_args['country'], $event_array['location']['address']['addressCountry'] );
|
||||||
|
$this->assertEquals( $venue_args['postcode'], $event_array['location']['address']['postalCode'] );
|
||||||
|
$this->assertEquals( $venue_name, $event_array['location']['name'] );
|
||||||
|
}
|
||||||
|
}
|
|
@ -2,7 +2,7 @@
|
||||||
/**
|
/**
|
||||||
* Tests for WP Event Solution.
|
* Tests for WP Event Solution.
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -36,7 +36,7 @@ class Test_Eventin extends WP_UnitTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Make sure that ActivityPub support is enabled for The Events Calendar.
|
// Make sure that ActivityPub support is enabled for The Events Calendar.
|
||||||
$aec = \ActivityPub_Event_Bridge\Setup::get_instance();
|
$aec = \Event_Bridge_For_ActivityPub\Setup::get_instance();
|
||||||
$aec->activate_activitypub_support_for_active_event_plugins();
|
$aec->activate_activitypub_support_for_active_event_plugins();
|
||||||
|
|
||||||
// Delete all posts afterwards.
|
// Delete all posts afterwards.
|
||||||
|
@ -50,7 +50,7 @@ class Test_Eventin extends WP_UnitTestCase {
|
||||||
// We only test for one event plugin being active at the same time,
|
// We only test for one event plugin being active at the same time,
|
||||||
// even though we support multiple onces in theory.
|
// even though we support multiple onces in theory.
|
||||||
// But testing all combinations is beyond scope.
|
// But testing all combinations is beyond scope.
|
||||||
$active_event_plugins = \ActivityPub_Event_Bridge\Setup::get_instance()->get_active_event_plugins();
|
$active_event_plugins = \Event_Bridge_For_ActivityPub\Setup::get_instance()->get_active_event_plugins();
|
||||||
$this->assertEquals( 1, count( $active_event_plugins ) );
|
$this->assertEquals( 1, count( $active_event_plugins ) );
|
||||||
|
|
||||||
// Enable ActivityPub support for the event plugin.
|
// Enable ActivityPub support for the event plugin.
|
||||||
|
@ -64,7 +64,7 @@ class Test_Eventin extends WP_UnitTestCase {
|
||||||
$transformer = \Activitypub\Transformer\Factory::get_transformer( get_post( $event->id ) );
|
$transformer = \Activitypub\Transformer\Factory::get_transformer( get_post( $event->id ) );
|
||||||
|
|
||||||
// Check that we got the right transformer.
|
// Check that we got the right transformer.
|
||||||
$this->assertInstanceOf( \ActivityPub_Event_Bridge\Activitypub\Transformer\Eventin::class, $transformer );
|
$this->assertInstanceOf( \Event_Bridge_For_ActivityPub\Activitypub\Transformer\Eventin::class, $transformer );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
186
tests/test-class-plugin-eventprime.php
Normal file
186
tests/test-class-plugin-eventprime.php
Normal file
|
@ -0,0 +1,186 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Class SampleTest
|
||||||
|
*
|
||||||
|
* @package Event_Bridge_For_ActivityPub
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sample test case.
|
||||||
|
*/
|
||||||
|
class Test_EventPrime extends WP_UnitTestCase {
|
||||||
|
/**
|
||||||
|
* Mockup venues of certain complexity.
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
private $mockup_venue = array();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Mockup events for tests.
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
protected $mockup_events = array();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Override the setup function, so that tests don't run if the Events Calendar is not active.
|
||||||
|
*/
|
||||||
|
public function set_up() {
|
||||||
|
parent::set_up();
|
||||||
|
|
||||||
|
if ( ! class_exists( '\Eventprime_Basic_Functions' ) ) {
|
||||||
|
self::markTestSkipped( 'The EventPrime Calendar management plugin is not active.' );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Make sure that ActivityPub support is enabled for The Events Calendar.
|
||||||
|
$aeb = \Event_Bridge_For_ActivityPub\Setup::get_instance();
|
||||||
|
$aeb->activate_activitypub_support_for_active_event_plugins();
|
||||||
|
|
||||||
|
// Delete all posts afterwards.
|
||||||
|
_delete_all_posts();
|
||||||
|
|
||||||
|
$this->setup_mockup_data();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Setup mockup events.
|
||||||
|
*/
|
||||||
|
private function setup_mockup_data() {
|
||||||
|
$this->mockup_events = array(
|
||||||
|
'minimal_event' => array(
|
||||||
|
'name' => 'EventPrime Event title',
|
||||||
|
'description' => 'EventPrime event description',
|
||||||
|
'status' => 'Publish',
|
||||||
|
'em_event_type' => '',
|
||||||
|
'em_venue' => '',
|
||||||
|
'em_organizer' => '',
|
||||||
|
'em_performer' => '',
|
||||||
|
'em_start_date' => strtotime( '+10 days 15:00:00' ),
|
||||||
|
'em_end_date' => strtotime( '+10 days 16:00:00' ),
|
||||||
|
'em_enable_booking' => 'bookings_off',
|
||||||
|
'em_ticket_price' => 0,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->mockup_venue = array(
|
||||||
|
'name' => 'Test Venue',
|
||||||
|
'address' => 'Fediverse-street 1337, 1234 Fediverse-town',
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test that the right transformer gets applied.
|
||||||
|
*/
|
||||||
|
public function test_the_events_calendar_transformer_class() {
|
||||||
|
// We only test for one event plugin being active at the same time,
|
||||||
|
// even though we support multiple onces in theory.
|
||||||
|
// But testing all combinations is beyond scope.
|
||||||
|
$active_event_plugins = \Event_Bridge_For_ActivityPub\Setup::get_instance()->get_active_event_plugins();
|
||||||
|
$this->assertEquals( 1, count( $active_event_plugins ) );
|
||||||
|
|
||||||
|
// Enable ActivityPub support for the event plugin.
|
||||||
|
$this->assertContains( 'em_event', get_option( 'activitypub_support_post_types' ) );
|
||||||
|
|
||||||
|
// Create an EventPrime Event without content.
|
||||||
|
$ep_functions = new Eventprime_Basic_Functions();
|
||||||
|
|
||||||
|
$post_id = $ep_functions->insert_event_post_data( $this->mockup_events['minimal_event'] );
|
||||||
|
|
||||||
|
$wp_object = get_post( $post_id );
|
||||||
|
|
||||||
|
// Call the transformer Factory.
|
||||||
|
$transformer = \Activitypub\Transformer\Factory::get_transformer( $wp_object );
|
||||||
|
|
||||||
|
// Check that we got the right transformer.
|
||||||
|
$this->assertInstanceOf( \Event_Bridge_For_ActivityPub\Activitypub\Transformer\EventPrime::class, $transformer );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test transformation of minimal event.
|
||||||
|
*/
|
||||||
|
public function test_transformation_of_minimal_event() {
|
||||||
|
// Create an EventPrime Event without content.
|
||||||
|
$ep_functions = new Eventprime_Basic_Functions();
|
||||||
|
|
||||||
|
$post_id = $ep_functions->insert_event_post_data( $this->mockup_events['minimal_event'] );
|
||||||
|
|
||||||
|
$wp_object = get_post( $post_id );
|
||||||
|
|
||||||
|
// Call the transformer Factory.
|
||||||
|
$event_array = \Activitypub\Transformer\Factory::get_transformer( $wp_object )->to_object()->to_array();
|
||||||
|
|
||||||
|
// Check that the event ActivityStreams representation contains everything as expected.
|
||||||
|
$this->assertEquals( 'Event', $event_array['type'] );
|
||||||
|
$this->assertEquals( 'EventPrime Event title', $event_array['name'] );
|
||||||
|
$this->assertEquals( 'EventPrime event description', wp_strip_all_tags( $event_array['content'] ) );
|
||||||
|
$this->assertEquals( gmdate( 'Y-m-d', strtotime( '+10 days 15:00:00' ) ) . 'T15:00:00Z', $event_array['startTime'] );
|
||||||
|
$this->assertEquals( gmdate( 'Y-m-d', strtotime( '+10 days 16:00:00' ) ) . 'T16:00:00Z', $event_array['endTime'] );
|
||||||
|
$this->assertTrue( $event_array['commentsEnabled'] );
|
||||||
|
$this->assertEquals( 'allow_all', $event_array['repliesModerationOption'] );
|
||||||
|
$this->assertEquals( 'external', $event_array['joinMode'] );
|
||||||
|
$this->assertArrayNotHasKey( 'location', $event_array );
|
||||||
|
$this->assertEquals( 'MEETING', $event_array['category'] );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test transformation of minimal event.
|
||||||
|
*/
|
||||||
|
public function test_transformation_of_minimal_event_with_venue() {
|
||||||
|
// Create an EventPrime Event without content.
|
||||||
|
$ep_functions = new Eventprime_Basic_Functions();
|
||||||
|
|
||||||
|
$venue_term_id = wp_insert_term( $this->mockup_venue['name'], 'em_venue' )['term_id'];
|
||||||
|
add_term_meta( $venue_term_id, 'em_address', $this->mockup_venue['address'], true );
|
||||||
|
add_term_meta( $venue_term_id, 'em_display_address_on_frontend', true, true );
|
||||||
|
|
||||||
|
$event_data = $this->mockup_events['minimal_event'];
|
||||||
|
$event_data['em_venue'] = $venue_term_id;
|
||||||
|
|
||||||
|
$post_id = $ep_functions->insert_event_post_data( $event_data );
|
||||||
|
|
||||||
|
$wp_object = get_post( $post_id );
|
||||||
|
|
||||||
|
// Call the transformer Factory.
|
||||||
|
$event_array = \Activitypub\Transformer\Factory::get_transformer( $wp_object )->to_object()->to_array();
|
||||||
|
|
||||||
|
// Check that the event ActivityStreams representation contains everything as expected.
|
||||||
|
$this->assertEquals( 'Event', $event_array['type'] );
|
||||||
|
$this->assertEquals( 'EventPrime Event title', $event_array['name'] );
|
||||||
|
$this->assertEquals( 'EventPrime event description', wp_strip_all_tags( $event_array['content'] ) );
|
||||||
|
$this->assertEquals( gmdate( 'Y-m-d', strtotime( '+10 days 15:00:00' ) ) . 'T15:00:00Z', $event_array['startTime'] );
|
||||||
|
$this->assertEquals( gmdate( 'Y-m-d', strtotime( '+10 days 16:00:00' ) ) . 'T16:00:00Z', $event_array['endTime'] );
|
||||||
|
$this->assertTrue( $event_array['commentsEnabled'] );
|
||||||
|
$this->assertEquals( 'allow_all', $event_array['repliesModerationOption'] );
|
||||||
|
$this->assertEquals( 'external', $event_array['joinMode'] );
|
||||||
|
$this->assertEquals( $this->mockup_venue['name'], $event_array['location']['name'] );
|
||||||
|
$this->assertEquals( $this->mockup_venue['address'], $event_array['location']['address'] );
|
||||||
|
|
||||||
|
$this->assertEquals( 'MEETING', $event_array['category'] );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test transformation of minimal event with venue which has a hidden address.
|
||||||
|
*/
|
||||||
|
public function test_transformation_of_minimal_event_with_venue_with_hidden_address() {
|
||||||
|
// Create an EventPrime Event without content.
|
||||||
|
$ep_functions = new Eventprime_Basic_Functions();
|
||||||
|
|
||||||
|
$venue_term_id = wp_insert_term( $this->mockup_venue['name'], 'em_venue' )['term_id'];
|
||||||
|
add_term_meta( $venue_term_id, 'em_address', $this->mockup_venue['address'], true );
|
||||||
|
add_term_meta( $venue_term_id, 'em_display_address_on_frontend', false, true );
|
||||||
|
|
||||||
|
$event_data = $this->mockup_events['minimal_event'];
|
||||||
|
$event_data['em_venue'] = $venue_term_id;
|
||||||
|
|
||||||
|
$post_id = $ep_functions->insert_event_post_data( $event_data );
|
||||||
|
|
||||||
|
$wp_object = get_post( $post_id );
|
||||||
|
|
||||||
|
// Call the transformer Factory.
|
||||||
|
$event_array = \Activitypub\Transformer\Factory::get_transformer( $wp_object )->to_object()->to_array();
|
||||||
|
|
||||||
|
// Check that the event ActivityStreams representation contains everything as expected.
|
||||||
|
$this->assertArrayNotHasKey( 'address', $event_array['location'] );
|
||||||
|
}
|
||||||
|
}
|
|
@ -2,7 +2,7 @@
|
||||||
/**
|
/**
|
||||||
* Class SampleTest
|
* Class SampleTest
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -23,7 +23,7 @@ class Test_Events_Manager extends WP_UnitTestCase {
|
||||||
update_option( 'dbem_events_anonymous_submissions', true );
|
update_option( 'dbem_events_anonymous_submissions', true );
|
||||||
|
|
||||||
// Make sure that ActivityPub support is enabled for Events Manager.
|
// Make sure that ActivityPub support is enabled for Events Manager.
|
||||||
$aec = \ActivityPub_Event_Bridge\Setup::get_instance();
|
$aec = \Event_Bridge_For_ActivityPub\Setup::get_instance();
|
||||||
$aec->activate_activitypub_support_for_active_event_plugins();
|
$aec->activate_activitypub_support_for_active_event_plugins();
|
||||||
|
|
||||||
// Delete all posts afterwards.
|
// Delete all posts afterwards.
|
||||||
|
@ -37,7 +37,7 @@ class Test_Events_Manager extends WP_UnitTestCase {
|
||||||
// We only test for one event plugin being active at the same time,
|
// We only test for one event plugin being active at the same time,
|
||||||
// even though we support multiple onces in theory.
|
// even though we support multiple onces in theory.
|
||||||
// But testing all combinations is beyond scope.
|
// But testing all combinations is beyond scope.
|
||||||
$active_event_plugins = \ActivityPub_Event_Bridge\Setup::get_instance()->get_active_event_plugins();
|
$active_event_plugins = \Event_Bridge_For_ActivityPub\Setup::get_instance()->get_active_event_plugins();
|
||||||
$this->assertEquals( 1, count( $active_event_plugins ) );
|
$this->assertEquals( 1, count( $active_event_plugins ) );
|
||||||
|
|
||||||
// Enable ActivityPub support for the event plugin.
|
// Enable ActivityPub support for the event plugin.
|
||||||
|
@ -61,7 +61,7 @@ class Test_Events_Manager extends WP_UnitTestCase {
|
||||||
$transformer = \Activitypub\Transformer\Factory::get_transformer( $wp_object );
|
$transformer = \Activitypub\Transformer\Factory::get_transformer( $wp_object );
|
||||||
|
|
||||||
// Check that we got the right transformer.
|
// Check that we got the right transformer.
|
||||||
$this->assertInstanceOf( \ActivityPub_Event_Bridge\Activitypub\Transformer\Events_Manager::class, $transformer );
|
$this->assertInstanceOf( \Event_Bridge_For_ActivityPub\Activitypub\Transformer\Events_Manager::class, $transformer );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
/**
|
/**
|
||||||
* Class SampleTest
|
* Class SampleTest
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -23,7 +23,7 @@ class Test_GatherPress extends WP_UnitTestCase {
|
||||||
GatherPress\Core\Setup::get_instance()->activate_gatherpress_plugin( false );
|
GatherPress\Core\Setup::get_instance()->activate_gatherpress_plugin( false );
|
||||||
|
|
||||||
// Make sure that ActivityPub support is enabled for The Events Calendar.
|
// Make sure that ActivityPub support is enabled for The Events Calendar.
|
||||||
$aec = \ActivityPub_Event_Bridge\Setup::get_instance();
|
$aec = \Event_Bridge_For_ActivityPub\Setup::get_instance();
|
||||||
$aec->activate_activitypub_support_for_active_event_plugins();
|
$aec->activate_activitypub_support_for_active_event_plugins();
|
||||||
|
|
||||||
// Delete all posts afterwards.
|
// Delete all posts afterwards.
|
||||||
|
@ -37,7 +37,7 @@ class Test_GatherPress extends WP_UnitTestCase {
|
||||||
// We only test for one event plugin being active at the same time,
|
// We only test for one event plugin being active at the same time,
|
||||||
// even though we support multiple onces in theory.
|
// even though we support multiple onces in theory.
|
||||||
// But testing all combinations is beyond scope.
|
// But testing all combinations is beyond scope.
|
||||||
$active_event_plugins = \ActivityPub_Event_Bridge\Setup::get_instance()->get_active_event_plugins();
|
$active_event_plugins = \Event_Bridge_For_ActivityPub\Setup::get_instance()->get_active_event_plugins();
|
||||||
$this->assertEquals( 1, count( $active_event_plugins ) );
|
$this->assertEquals( 1, count( $active_event_plugins ) );
|
||||||
|
|
||||||
// Enable ActivityPub support for the event plugin.
|
// Enable ActivityPub support for the event plugin.
|
||||||
|
@ -65,7 +65,7 @@ class Test_GatherPress extends WP_UnitTestCase {
|
||||||
$transformer = \Activitypub\Transformer\Factory::get_transformer( $event->event );
|
$transformer = \Activitypub\Transformer\Factory::get_transformer( $event->event );
|
||||||
|
|
||||||
// Check that we got the right transformer.
|
// Check that we got the right transformer.
|
||||||
$this->assertInstanceOf( \ActivityPub_Event_Bridge\Activitypub\Transformer\GatherPress::class, $transformer );
|
$this->assertInstanceOf( \Event_Bridge_For_ActivityPub\Activitypub\Transformer\GatherPress::class, $transformer );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
/**
|
/**
|
||||||
* Tests or Modern Events Calendar Lite
|
* Tests or Modern Events Calendar Lite
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -27,7 +27,7 @@ class Test_Modern_Events_Calendar_Lite extends WP_UnitTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Make sure that ActivityPub support is enabled for The Events Calendar.
|
// Make sure that ActivityPub support is enabled for The Events Calendar.
|
||||||
$aec = \ActivityPub_Event_Bridge\Setup::get_instance();
|
$aec = \Event_Bridge_For_ActivityPub\Setup::get_instance();
|
||||||
$aec->activate_activitypub_support_for_active_event_plugins();
|
$aec->activate_activitypub_support_for_active_event_plugins();
|
||||||
|
|
||||||
$this->mec_main = \MEC::getInstance( 'app.libraries.main' );
|
$this->mec_main = \MEC::getInstance( 'app.libraries.main' );
|
||||||
|
@ -43,7 +43,7 @@ class Test_Modern_Events_Calendar_Lite extends WP_UnitTestCase {
|
||||||
// We only test for one event plugin being active at the same time,
|
// We only test for one event plugin being active at the same time,
|
||||||
// even though we support multiple onces in theory.
|
// even though we support multiple onces in theory.
|
||||||
// But testing all combinations is beyond scope.
|
// But testing all combinations is beyond scope.
|
||||||
$active_event_plugins = \ActivityPub_Event_Bridge\Setup::get_instance()->get_active_event_plugins();
|
$active_event_plugins = \Event_Bridge_For_ActivityPub\Setup::get_instance()->get_active_event_plugins();
|
||||||
$this->assertEquals( 1, count( $active_event_plugins ) );
|
$this->assertEquals( 1, count( $active_event_plugins ) );
|
||||||
|
|
||||||
// Enable ActivityPub support for the event plugin.
|
// Enable ActivityPub support for the event plugin.
|
||||||
|
@ -74,7 +74,7 @@ class Test_Modern_Events_Calendar_Lite extends WP_UnitTestCase {
|
||||||
$transformer = \Activitypub\Transformer\Factory::get_transformer( $wp_object );
|
$transformer = \Activitypub\Transformer\Factory::get_transformer( $wp_object );
|
||||||
|
|
||||||
// Check that we got the right transformer.
|
// Check that we got the right transformer.
|
||||||
$this->assertInstanceOf( \ActivityPub_Event_Bridge\Activitypub\Transformer\Modern_Events_Calendar_Lite::class, $transformer );
|
$this->assertInstanceOf( \Event_Bridge_For_ActivityPub\Activitypub\Transformer\Modern_Events_Calendar_Lite::class, $transformer );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -1,232 +0,0 @@
|
||||||
<?php
|
|
||||||
/**
|
|
||||||
* Test class for My Calendar.
|
|
||||||
*
|
|
||||||
* @package ActivityPub_Event_Bridge
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Test class for My Calendar.
|
|
||||||
*/
|
|
||||||
class Test_My_Calendar extends WP_UnitTestCase {
|
|
||||||
/**
|
|
||||||
* Mockup Event.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
private $mockup_event;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Mockup Location.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
private $mockup_location;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Mockup Category.
|
|
||||||
*
|
|
||||||
* @var array
|
|
||||||
*/
|
|
||||||
private $mockup_category;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Setup mockup data.
|
|
||||||
*/
|
|
||||||
private function setUpMockupEvents() {
|
|
||||||
$this->mockup_event = array(
|
|
||||||
// Begin strings.
|
|
||||||
'event_begin' => date( 'Y-m-d', strtotime( '+10 days' ) ), // phpcs:ignore WordPress.DateTime.RestrictedFunctions.date_date
|
|
||||||
'event_end' => date( 'Y-m-d', strtotime( '+10 days', ) ), // phpcs:ignore WordPress.DateTime.RestrictedFunctions.date_date
|
|
||||||
'event_title' => 'Demo: Florence Price: Symphony No. 3 in c minor',
|
|
||||||
'event_desc' => "<p>Florence Price's <a href='https://en.wikipedia.org/wiki/Symphony_No._3_(Price)'>Symphony No. 3</a> was commissioned by the Works Progress Administration's <a href='https://en.wikipedia.org/wiki/Federal_Music_Project'>Federal Music Project</a> during the height of the Great Depression. It was first performed at the Detroit Institute of Arts on November 6, 1940, by the Detroit Civic Orchestra under the conductor Valter Poole.</p><p>The composition is Price's third symphony, following her Symphony in E minor—the first symphony by a black woman to be performed by a major American orchestra—and her lost Symphony No. 2.</p>",
|
|
||||||
'event_short' => "Florence Price's Symphony No.3 was first performed on November 6th, 1940. It was Ms. Price's third symphony, following her lost Symphony No. 2",
|
|
||||||
'event_time' => '15:00:00',
|
|
||||||
'event_endtime' => '16:00:00',
|
|
||||||
'event_link' => 'https://www.youtube.com/watch?v=1jgJ1OkjnaI&list=OLAK5uy_lKldgbFTYBDa7WN6jf2ubB595wncDU7yc&index=2',
|
|
||||||
'event_recur' => 'S1',
|
|
||||||
'event_image' => plugins_url( '/.wordpress-org/banner-772x250.jpg', ACTIVITYPUB_EVENT_BRIDGE_PLUGIN_FILE ),
|
|
||||||
'event_access' => '',
|
|
||||||
'event_tickets' => '',
|
|
||||||
'event_registration' => '',
|
|
||||||
'event_repeats' => '',
|
|
||||||
// Begin integers.
|
|
||||||
'event_author' => wp_get_current_user()->ID,
|
|
||||||
'event_category' => 1,
|
|
||||||
'event_link_expires' => 0,
|
|
||||||
'event_zoom' => 16,
|
|
||||||
'event_approved' => 1,
|
|
||||||
'event_host' => wp_get_current_user()->ID,
|
|
||||||
'event_flagged' => 0,
|
|
||||||
'event_fifth_week' => 0,
|
|
||||||
'event_holiday' => 0,
|
|
||||||
'event_group_id' => 1,
|
|
||||||
'event_span' => 0,
|
|
||||||
'event_hide_end' => 0,
|
|
||||||
// Array: removed before DB insertion.
|
|
||||||
'event_categories' => array( 1 ),
|
|
||||||
);
|
|
||||||
|
|
||||||
$access = array( 1, 2, 3, 4, 6, 8, 9 );
|
|
||||||
|
|
||||||
$this->mockup_location = array(
|
|
||||||
'location_label' => 'Demo: Minnesota Orchestra',
|
|
||||||
'location_street' => '1111 Nicollet Mall',
|
|
||||||
'location_street2' => '',
|
|
||||||
'location_city' => 'Minneapolis',
|
|
||||||
'location_state' => 'MN',
|
|
||||||
'location_postcode' => '55403',
|
|
||||||
'location_region' => '',
|
|
||||||
'location_country' => 'United States',
|
|
||||||
'location_url' => 'https://www.minnesotaorchestra.org',
|
|
||||||
'location_latitude' => '44.9722',
|
|
||||||
'location_longitude' => '-93.2749',
|
|
||||||
'location_zoom' => 16,
|
|
||||||
'location_phone' => '612-371-5600',
|
|
||||||
'location_phone2' => '',
|
|
||||||
'location_access' => serialize( $access ),
|
|
||||||
);
|
|
||||||
|
|
||||||
$this->mockup_category = array(
|
|
||||||
'category_name' => 'General',
|
|
||||||
'category_color' => '#243f82',
|
|
||||||
'category_icon' => 'event.svg',
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Override the setup function, so that tests don't run if the Events Calendar is not active.
|
|
||||||
*/
|
|
||||||
public function set_up() {
|
|
||||||
parent::set_up();
|
|
||||||
|
|
||||||
if ( ! function_exists( 'mc_get_event' ) ) {
|
|
||||||
self::markTestSkipped( 'My Calendar plugin is not active.' );
|
|
||||||
}
|
|
||||||
|
|
||||||
self::setUpMockupEvents();
|
|
||||||
|
|
||||||
// Make sure that ActivityPub support is enabled for The Events Calendar.
|
|
||||||
$aec = \ActivityPub_Event_Bridge\Setup::get_instance();
|
|
||||||
$aec->activate_activitypub_support_for_active_event_plugins();
|
|
||||||
|
|
||||||
// Delete all posts afterwards.
|
|
||||||
_delete_all_posts();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Test that the right transformer gets applied.
|
|
||||||
*/
|
|
||||||
public function test_transformer_class() {
|
|
||||||
// We only test for one event plugin being active at the same time,
|
|
||||||
// even though we support multiple onces in theory.
|
|
||||||
// But testing all combinations is beyond scope.
|
|
||||||
$active_event_plugins = \ActivityPub_Event_Bridge\Setup::get_instance()->get_active_event_plugins();
|
|
||||||
$this->assertEquals( 1, count( $active_event_plugins ) );
|
|
||||||
|
|
||||||
// Enable ActivityPub support for the event plugin.
|
|
||||||
$this->assertContains( 'mc-events', get_option( 'activitypub_support_post_types' ) );
|
|
||||||
|
|
||||||
// mc_create_category( $this->mockup_category );
|
|
||||||
// $location = mc_insert_location( $this->mockup_location );
|
|
||||||
// $location = apply_filters( 'mc_save_location', $location, $this->mockup_location, $this->mockup_location );
|
|
||||||
// $event = array( true, false, $this->mockup_event, false, array() );
|
|
||||||
// $event = my_calendar_save( 'add', $event );
|
|
||||||
// mc_update_event( 'event_location', (int) $location, $event['event_id'] );
|
|
||||||
|
|
||||||
// Insert a category.
|
|
||||||
mc_create_category(
|
|
||||||
array(
|
|
||||||
'category_name' => 'General',
|
|
||||||
'category_color' => '#243f82',
|
|
||||||
'category_icon' => 'event.svg',
|
|
||||||
)
|
|
||||||
);
|
|
||||||
// Insert a location.
|
|
||||||
$access = array( 1, 2, 3, 4, 6, 8, 9 );
|
|
||||||
$add = array(
|
|
||||||
'location_label' => 'Demo: Minnesota Orchestra',
|
|
||||||
'location_street' => '1111 Nicollet Mall',
|
|
||||||
'location_street2' => '',
|
|
||||||
'location_city' => 'Minneapolis',
|
|
||||||
'location_state' => 'MN',
|
|
||||||
'location_postcode' => '55403',
|
|
||||||
'location_region' => '',
|
|
||||||
'location_country' => 'United States',
|
|
||||||
'location_url' => 'https://www.minnesotaorchestra.org',
|
|
||||||
'location_latitude' => '44.9722',
|
|
||||||
'location_longitude' => '-93.2749',
|
|
||||||
'location_zoom' => 16,
|
|
||||||
'location_phone' => '612-371-5600',
|
|
||||||
'location_phone2' => '',
|
|
||||||
'location_access' => serialize( $access ),
|
|
||||||
);
|
|
||||||
$results = mc_insert_location( $add );
|
|
||||||
/**
|
|
||||||
* Executed an action when the demo location is saved at installation.
|
|
||||||
*
|
|
||||||
* @hook mc_save_location
|
|
||||||
*
|
|
||||||
* @param {int|false} $results Result of database insertion. Row ID or false.
|
|
||||||
* @param {array} $add Array of location parameters to add.
|
|
||||||
* @param {array} $add Demo location array.
|
|
||||||
*/
|
|
||||||
$results = apply_filters( 'mc_save_location', $results, $add, $add );
|
|
||||||
// Insert an event.
|
|
||||||
$submit = array(
|
|
||||||
// Begin strings.
|
|
||||||
'event_begin' => date( 'Y-m-d', strtotime( '+1 day' ) ), // phpcs:ignore WordPress.DateTime.RestrictedFunctions.date_date
|
|
||||||
'event_end' => date( 'Y-m-d', strtotime( '+1 day' ) ), // phpcs:ignore WordPress.DateTime.RestrictedFunctions.date_date
|
|
||||||
'event_title' => 'Demo: Florence Price: Symphony No. 3 in c minor',
|
|
||||||
'event_desc' => "<p>Florence Price's <a href='https://en.wikipedia.org/wiki/Symphony_No._3_(Price)'>Symphony No. 3</a> was commissioned by the Works Progress Administration's <a href='https://en.wikipedia.org/wiki/Federal_Music_Project'>Federal Music Project</a> during the height of the Great Depression. It was first performed at the Detroit Institute of Arts on November 6, 1940, by the Detroit Civic Orchestra under the conductor Valter Poole.</p><p>The composition is Price's third symphony, following her Symphony in E minor—the first symphony by a black woman to be performed by a major American orchestra—and her lost Symphony No. 2.</p>",
|
|
||||||
'event_short' => "Florence Price's Symphony No.3 was first performed on November 6th, 1940. It was Ms. Price's third symphony, following her lost Symphony No. 2",
|
|
||||||
'event_time' => '19:30:00',
|
|
||||||
'event_endtime' => '21:00:00',
|
|
||||||
'event_link' => 'https://www.youtube.com/watch?v=1jgJ1OkjnaI&list=OLAK5uy_lKldgbFTYBDa7WN6jf2ubB595wncDU7yc&index=2',
|
|
||||||
'event_recur' => 'S1',
|
|
||||||
'event_image' => plugins_url( '/images/demo/event.jpg', __FILE__ ),
|
|
||||||
'event_access' => '',
|
|
||||||
'event_tickets' => '',
|
|
||||||
'event_registration' => '',
|
|
||||||
'event_repeats' => '',
|
|
||||||
// Begin integers.
|
|
||||||
'event_author' => wp_get_current_user()->ID,
|
|
||||||
'event_category' => 1,
|
|
||||||
'event_link_expires' => 0,
|
|
||||||
'event_zoom' => 16,
|
|
||||||
'event_approved' => 1,
|
|
||||||
'event_host' => wp_get_current_user()->ID,
|
|
||||||
'event_flagged' => 0,
|
|
||||||
'event_fifth_week' => 0,
|
|
||||||
'event_holiday' => 0,
|
|
||||||
'event_group_id' => 1,
|
|
||||||
'event_span' => 0,
|
|
||||||
'event_hide_end' => 0,
|
|
||||||
// Array: removed before DB insertion.
|
|
||||||
'event_categories' => array( 1 ),
|
|
||||||
);
|
|
||||||
|
|
||||||
$event = array( true, false, $submit, false, array() );
|
|
||||||
$response = my_calendar_save( 'add', $event );
|
|
||||||
$event_id = $response['event_id'];
|
|
||||||
$r = mc_update_event( 'event_location', (int) $results, $event_id );
|
|
||||||
|
|
||||||
$e = mc_get_first_event( $event_id );
|
|
||||||
$post_id = $e->event_post;
|
|
||||||
$image = media_sideload_image( plugins_url( '/images/demo/event.jpg', __FILE__ ), $post_id, null, 'id' );
|
|
||||||
|
|
||||||
if ( ! is_wp_error( $image ) ) {
|
|
||||||
set_post_thumbnail( $post_id, $image );
|
|
||||||
}
|
|
||||||
|
|
||||||
$wp_object = get_post( $event['event_post'] );
|
|
||||||
|
|
||||||
// Call the transformer Factory.
|
|
||||||
$transformer = \Activitypub\Transformer\Factory::get_transformer( $wp_object );
|
|
||||||
|
|
||||||
// Check that we got the right transformer.
|
|
||||||
$this->assertInstanceOf( \ActivityPub_Event_Bridge\Activitypub\Transformer\My_Calendar::class, $transformer );
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -2,7 +2,7 @@
|
||||||
/**
|
/**
|
||||||
* Class SampleTest
|
* Class SampleTest
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -62,7 +62,7 @@ class Test_The_Events_Calendar extends WP_UnitTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Make sure that ActivityPub support is enabled for The Events Calendar.
|
// Make sure that ActivityPub support is enabled for The Events Calendar.
|
||||||
$aec = \ActivityPub_Event_Bridge\Setup::get_instance();
|
$aec = \Event_Bridge_For_ActivityPub\Setup::get_instance();
|
||||||
$aec->activate_activitypub_support_for_active_event_plugins();
|
$aec->activate_activitypub_support_for_active_event_plugins();
|
||||||
|
|
||||||
// Delete all posts afterwards.
|
// Delete all posts afterwards.
|
||||||
|
@ -76,7 +76,7 @@ class Test_The_Events_Calendar extends WP_UnitTestCase {
|
||||||
// We only test for one event plugin being active at the same time,
|
// We only test for one event plugin being active at the same time,
|
||||||
// even though we support multiple onces in theory.
|
// even though we support multiple onces in theory.
|
||||||
// But testing all combinations is beyond scope.
|
// But testing all combinations is beyond scope.
|
||||||
$active_event_plugins = \ActivityPub_Event_Bridge\Setup::get_instance()->get_active_event_plugins();
|
$active_event_plugins = \Event_Bridge_For_ActivityPub\Setup::get_instance()->get_active_event_plugins();
|
||||||
$this->assertEquals( 1, count( $active_event_plugins ) );
|
$this->assertEquals( 1, count( $active_event_plugins ) );
|
||||||
|
|
||||||
// Enable ActivityPub support for the event plugin.
|
// Enable ActivityPub support for the event plugin.
|
||||||
|
@ -91,7 +91,7 @@ class Test_The_Events_Calendar extends WP_UnitTestCase {
|
||||||
$transformer = \Activitypub\Transformer\Factory::get_transformer( $wp_object );
|
$transformer = \Activitypub\Transformer\Factory::get_transformer( $wp_object );
|
||||||
|
|
||||||
// Check that we got the right transformer.
|
// Check that we got the right transformer.
|
||||||
$this->assertInstanceOf( \ActivityPub_Event_Bridge\Activitypub\Transformer\The_Events_Calendar::class, $transformer );
|
$this->assertInstanceOf( \Event_Bridge_For_ActivityPub\Activitypub\Transformer\The_Events_Calendar::class, $transformer );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -128,10 +128,10 @@ class Test_The_Events_Calendar extends WP_UnitTestCase {
|
||||||
$category_id_theatre = wp_insert_term( 'Theatre', Tribe__Events__Main::TAXONOMY, array( 'slug' => 'theatre' ) );
|
$category_id_theatre = wp_insert_term( 'Theatre', Tribe__Events__Main::TAXONOMY, array( 'slug' => 'theatre' ) );
|
||||||
|
|
||||||
// Set default mapping for event categories.
|
// Set default mapping for event categories.
|
||||||
update_option( 'activitypub_event_bridge_default_event_category', 'MUSIC' );
|
update_option( 'event_bridge_for_activitypub_default_event_category', 'MUSIC' );
|
||||||
|
|
||||||
// Set an override for the category with the slug theatre.
|
// Set an override for the category with the slug theatre.
|
||||||
update_option( 'activitypub_event_bridge_event_category_mappings', array( 'theatre' => 'THEATRE' ) );
|
update_option( 'event_bridge_for_activitypub_event_category_mappings', array( 'theatre' => 'THEATRE' ) );
|
||||||
|
|
||||||
// Create a The Events Calendar event with the music category.
|
// Create a The Events Calendar event with the music category.
|
||||||
$wp_object = tribe_events()
|
$wp_object = tribe_events()
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
/**
|
/**
|
||||||
* Class SampleTest
|
* Class SampleTest
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -20,7 +20,7 @@ class Test_VS_Event_List extends WP_UnitTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Make sure that ActivityPub support is enabled for The Events Calendar.
|
// Make sure that ActivityPub support is enabled for The Events Calendar.
|
||||||
$aec = \ActivityPub_Event_Bridge\Setup::get_instance();
|
$aec = \Event_Bridge_For_ActivityPub\Setup::get_instance();
|
||||||
$aec->activate_activitypub_support_for_active_event_plugins();
|
$aec->activate_activitypub_support_for_active_event_plugins();
|
||||||
|
|
||||||
// Delete all posts afterwards.
|
// Delete all posts afterwards.
|
||||||
|
@ -34,7 +34,7 @@ class Test_VS_Event_List extends WP_UnitTestCase {
|
||||||
// We only test for one event plugin being active at the same time,
|
// We only test for one event plugin being active at the same time,
|
||||||
// even though we support multiple onces in theory.
|
// even though we support multiple onces in theory.
|
||||||
// But testing all combinations is beyond scope.
|
// But testing all combinations is beyond scope.
|
||||||
$active_event_plugins = \ActivityPub_Event_Bridge\Setup::get_instance()->get_active_event_plugins();
|
$active_event_plugins = \Event_Bridge_For_ActivityPub\Setup::get_instance()->get_active_event_plugins();
|
||||||
$this->assertEquals( 1, count( $active_event_plugins ) );
|
$this->assertEquals( 1, count( $active_event_plugins ) );
|
||||||
|
|
||||||
// Enable ActivityPub support for the event plugin.
|
// Enable ActivityPub support for the event plugin.
|
||||||
|
@ -58,7 +58,7 @@ class Test_VS_Event_List extends WP_UnitTestCase {
|
||||||
$transformer = \Activitypub\Transformer\Factory::get_transformer( $wp_object );
|
$transformer = \Activitypub\Transformer\Factory::get_transformer( $wp_object );
|
||||||
|
|
||||||
// Check that we got the right transformer.
|
// Check that we got the right transformer.
|
||||||
$this->assertInstanceOf( \ActivityPub_Event_Bridge\Activitypub\Transformer\VS_Event_List::class, $transformer );
|
$this->assertInstanceOf( \Event_Bridge_For_ActivityPub\Activitypub\Transformer\VS_Event_List::class, $transformer );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -173,10 +173,10 @@ class Test_VS_Event_List extends WP_UnitTestCase {
|
||||||
$category_id_theatre = wp_insert_term( 'Theatre', 'event_cat', array( 'slug' => 'theatre' ) );
|
$category_id_theatre = wp_insert_term( 'Theatre', 'event_cat', array( 'slug' => 'theatre' ) );
|
||||||
|
|
||||||
// Set default mapping for event categories.
|
// Set default mapping for event categories.
|
||||||
update_option( 'activitypub_event_bridge_default_event_category', 'MUSIC' );
|
update_option( 'event_bridge_for_activitypub_default_event_category', 'MUSIC' );
|
||||||
|
|
||||||
// Set an override for the category with the slug theatre.
|
// Set an override for the category with the slug theatre.
|
||||||
update_option( 'activitypub_event_bridge_event_category_mappings', array( 'theatre' => 'THEATRE' ) );
|
update_option( 'event_bridge_for_activitypub_event_category_mappings', array( 'theatre' => 'THEATRE' ) );
|
||||||
|
|
||||||
// Create a VS Event List event with the music category.
|
// Create a VS Event List event with the music category.
|
||||||
$wp_post_id = wp_insert_post(
|
$wp_post_id = wp_insert_post(
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
/**
|
/**
|
||||||
* Class SampleTest
|
* Class SampleTest
|
||||||
*
|
*
|
||||||
* @package ActivityPub_Event_Bridge
|
* @package Event_Bridge_For_ActivityPub
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -20,7 +20,7 @@ class Test_WP_Event_Manager extends WP_UnitTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Make sure that ActivityPub support is enabled for The Events Calendar.
|
// Make sure that ActivityPub support is enabled for The Events Calendar.
|
||||||
$aec = \ActivityPub_Event_Bridge\Setup::get_instance();
|
$aec = \Event_Bridge_For_ActivityPub\Setup::get_instance();
|
||||||
$aec->activate_activitypub_support_for_active_event_plugins();
|
$aec->activate_activitypub_support_for_active_event_plugins();
|
||||||
|
|
||||||
// Delete all posts afterwards.
|
// Delete all posts afterwards.
|
||||||
|
@ -34,7 +34,7 @@ class Test_WP_Event_Manager extends WP_UnitTestCase {
|
||||||
// We only test for one event plugin being active at the same time,
|
// We only test for one event plugin being active at the same time,
|
||||||
// even though we support multiple onces in theory.
|
// even though we support multiple onces in theory.
|
||||||
// But testing all combinations is beyond scope.
|
// But testing all combinations is beyond scope.
|
||||||
$active_event_plugins = \ActivityPub_Event_Bridge\Setup::get_instance()->get_active_event_plugins();
|
$active_event_plugins = \Event_Bridge_For_ActivityPub\Setup::get_instance()->get_active_event_plugins();
|
||||||
$this->assertEquals( 1, count( $active_event_plugins ) );
|
$this->assertEquals( 1, count( $active_event_plugins ) );
|
||||||
|
|
||||||
// Enable ActivityPub support for the event plugin.
|
// Enable ActivityPub support for the event plugin.
|
||||||
|
@ -58,7 +58,7 @@ class Test_WP_Event_Manager extends WP_UnitTestCase {
|
||||||
$transformer = \Activitypub\Transformer\Factory::get_transformer( $wp_object );
|
$transformer = \Activitypub\Transformer\Factory::get_transformer( $wp_object );
|
||||||
|
|
||||||
// Check that we got the right transformer.
|
// Check that we got the right transformer.
|
||||||
$this->assertInstanceOf( \ActivityPub_Event_Bridge\Activitypub\Transformer\WP_Event_Manager::class, $transformer );
|
$this->assertInstanceOf( \Event_Bridge_For_ActivityPub\Activitypub\Transformer\WP_Event_Manager::class, $transformer );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -134,7 +134,7 @@ class Test_WP_Event_Manager extends WP_UnitTestCase {
|
||||||
$this->assertContains(
|
$this->assertContains(
|
||||||
array(
|
array(
|
||||||
'type' => 'Link',
|
'type' => 'Link',
|
||||||
'name' => __( 'Video URL', 'activitypub-event-bridge' ),
|
'name' => __( 'Video URL', 'event-bridge-for-activitypub' ),
|
||||||
'href' => 'https://event-federation.eu/meeting-room',
|
'href' => 'https://event-federation.eu/meeting-room',
|
||||||
'mediaType' => 'text/html',
|
'mediaType' => 'text/html',
|
||||||
),
|
),
|
||||||
|
|
Loading…
Reference in a new issue