From 3562cd6c75b6b786d51c8eca57cbe330f2d8dcb1 Mon Sep 17 00:00:00 2001 From: Animesh Kumar Date: Mon, 13 Nov 2023 20:05:05 +0530 Subject: [PATCH] feat: youtube to anchor workflow (#805) Co-authored-by: V Thulisile Sibanda <66913810+thulieblack@users.noreply.github.com>%0ACo-authored-by: Lukasz Gornicki --- .../youtube-to-spotify-for-podcasters.yml | 36 ++++++ MEETINGS_ORGANIZATION.md | 109 ++++++++++++++---- 2 files changed, 125 insertions(+), 20 deletions(-) create mode 100644 .github/workflows/youtube-to-spotify-for-podcasters.yml diff --git a/.github/workflows/youtube-to-spotify-for-podcasters.yml b/.github/workflows/youtube-to-spotify-for-podcasters.yml new file mode 100644 index 000000000..685042da9 --- /dev/null +++ b/.github/workflows/youtube-to-spotify-for-podcasters.yml @@ -0,0 +1,36 @@ +name: 'Upload Episode from YouTube To Spotify for Podcasters' + +on: + workflow_dispatch: + inputs: + video_id: + description: 'Enter YouTube video ID to upload on Spotify for Podcasters.' + required: true + +jobs: + upload_episode: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + - name: Create episode.json file + run: | + # Get the video ID from the workflow_dispatch input. + video_id="${{ github.event.inputs.video_id }}" + + # Create episode.json content with the video ID + json_content="{\"id\": \"${video_id}\"}" + + # Write the content to episode.json in the workspace directory + echo "${json_content}" > episode.json + + # Verify the content was written successfully + cat episode.json + - name: Upload Episode from YouTube To Anchor.Fm + uses: Schrodinger-Hat/youtube-to-anchorfm@99a4a5409262b356a1bb54e6756d230ee97d3407 #commit related to https://github.com/Schrodinger-Hat/youtube-to-anchorfm/commit/99a4a5409262b356a1bb54e6756d230ee97d3407 || The latest commit which is of Oct 22, 2023 + env: + ANCHOR_EMAIL: ${{ secrets.ANCHOR_EMAIL }} + ANCHOR_PASSWORD: ${{ secrets.ANCHOR_PASSWORD }} + EPISODE_PATH: /github/workspace + URL_IN_DESCRIPTION: true + LOAD_THUMBNAIL: true + POSTPROCESSOR_ARGS: 'ffmpeg:-ac 1' diff --git a/MEETINGS_ORGANIZATION.md b/MEETINGS_ORGANIZATION.md index 7960b8842..6ad1e9a6f 100644 --- a/MEETINGS_ORGANIZATION.md +++ b/MEETINGS_ORGANIZATION.md @@ -1,15 +1,15 @@ -This document covers the aspect of different meetings organization at AsyncAPI. +This document covers the aspects of different meeting organizations at AsyncAPI. ## FAQ ### What do I need to schedule a meeting? To schedule a meeting, you need to be: -- one of the licensed Zoom users associated with the AsyncAPI Zoom account. It is required because only licensed users can start meeting, live transcripts, and streaming. +- one of the licensed Zoom users associated with the AsyncAPI Zoom account. It is required because only licensed users can start meetings, live transcripts, and streaming. - GitHub Action workflow for `Ad Hoc` meeting scheduling should be updated. Newly licensed users should be added as alternative hosts. -- a member of [GitHub team called meetings-organizars](https://github.com/orgs/asyncapi/teams/meetings-organizers). It is required because only maintainers of the given repository can manually trigger GitHub Actions workflows. This group has a `Maintain` role in the `community` repository where meeting automation is implemented. -- a member of a team in the AsyncAPI Restream account. It is required because hosts must log in to Restream before they start streaming the meeting from Zoom and modify the stream's title that will show up on social platforms. -- a member of the AsyncAPI YouTube account. It is required because after the meeting is over, hosts need to add live their stream recording to the proper YouTube Playlist to improve recording discoverability. +- a member of [GitHub team called meetings-organizers](https://github.com/orgs/asyncapi/teams/meetings-organizers). This is required because only repository maintainers can manually trigger GitHub Actions workflows. This group has a `Maintain` role in the `community` repository where meeting automation is implemented. +- a member of a team in the AsyncAPI Restream account. It is required because hosts must log in to Restream before streaming the meeting from Zoom and modify the stream's title that will appear on social platforms. +- a member of the AsyncAPI YouTube account. It is required because hosts need to add live stream recordings to the proper YouTube Playlist after the meeting is over to improve recording discoverability. ### What meetings do we have? @@ -25,16 +25,16 @@ To schedule a meeting, you need to be: We have an automated workflow in place: 1. Automation starts after clicking **Run workflow**. (Unless there is another GitHub Actions outage and proper events are not delivered to automation :smiley: ) -1. It creates a new meeting in Zoom. It is by default configured to support live streaming +1. It creates a new meeting in Zoom. It is, by default, configured to support live streaming 1. It creates a GitHub issue with all details about the meeting 1. It creates a new Google Calendar entry with special metadata containing the GitHub issue number 1. It sends a tweet with information about a newly scheduled event ### What are my responsibilities as meeting host? -Technically there are two types of meetings: -- Zoom-first: Meeting takes place on Zoom and through integration with Restream.io it is streamed to different channels. These meetings happen on Zoom to enable as many people as possible to join live conversation. -- Restream-first: Meeting takes place on Restream and is is streamed to different channels. These meetings are focused on showing or explaining some topic without live audio conversation with the audience. +Technically, there are two types of meetings: +- Zoom-first: The meeting takes place on Zoom and is streamed to different channels through integration with Restream.io. The goal is to enable as many people as possible to join the live conversation. +- Restream-first: The meeting takes place on Restream and is streamed to different channels. These meetings are focused on showing or explaining some topic without a live audio conversation with the audience. #### Zoom-first @@ -53,7 +53,7 @@ This is what you need to do to kick it off: 1. Provide title and description: - Title for the live stream that corresponds with the meeting you just started, - - Meeting description must be provided even if the field is empty, otherwise the old one from other streams will be used. + - Meeting description must be provided even if the field is empty; otherwise, the old one from other streams will be used. @@ -75,15 +75,15 @@ This is what you need to do to kick it off: #### Restream-first -You need to first start with YouTube, even though Restream can directly stream there. It is because by +You must start with YouTube first, even though Restream can directly stream there. It is because by This is what you need to do to kick it off: -1. In [YouTube](https://youtube.com) click on your profile picture and select `Switch account`: +1. In [YouTube](https://youtube.com), click on your profile picture and select `Switch account`: -1. Select `AsyncAPI`. If you do not see it on the list, means you did not have all access rights needed to setup a live stream: +1. Select `AsyncAPI`. If you do not see it on the list, it means you did not have all the access rights needed to set up a live stream: @@ -91,7 +91,7 @@ This is what you need to do to kick it off: -1. Once new live stream is created, in the list of `Upcomming` streams, click `View in Live Control Room` icon next to your live stream: +1. Once a new live stream is created, in the list of `Upcoming` streams, click `View in Live Control Room` icon next to your live stream: @@ -103,7 +103,7 @@ This is what you need to do to kick it off: -1. After enabling audio, video and providing name, you will see a Restream Studio. +1. After enabling the audio, video and providing the name, you will see a Restream Studio. 1. `Edit` the title and description of the stream: @@ -112,7 +112,7 @@ This is what you need to do to kick it off: 1. Provide title and description and click `Next`: - Title for the live stream that corresponds with the meeting you just started, - - Meeting description must be provided even if the field is empty, otherwise the old one from other streams will be used. + - Meeting description must be provided even if the field is empty; otherwise, the old one from other streams will be used. @@ -120,7 +120,7 @@ This is what you need to do to kick it off: -1. Make sure you do not create new event but you select the one you already created on YouTube, with closed captions on: +1. Make sure you do not create a new event, but select the one you already created on YouTube, with closed captions on: @@ -140,7 +140,7 @@ Subscribe to the [AsyncAPI Newsletter](https://asyncapi.com/newsletter) to get i We have an automated workflow in place: 1. Automation starts every Friday at midnight 1. It gets information from Google Calendar about all the meetings scheduled for the upcoming week -1. It schedules a MailChimp campaign to send emails with a list of meetings. It's sent on Friday at 11AM in the subscriber's time zone +1. It schedules a MailChimp campaign to send emails with a list of meetings. It's sent on Friday at 11 AM in the subscriber's time zone ### Where can I find the AsyncAPI calendar? @@ -156,7 +156,7 @@ We have an automated workflow in place: 1. It checks if a closed issue represents a future event 1. It removes meetings from the AsyncAPI Google Calendar -### How do I register a new regular meeting? +### How do I register for a new regular meeting? Start [discussion in community repository](https://github.com/asyncapi/community/discussions). Explain the idea and justify why it requires a separate meeting. We currently have [approval from the Technical Steering Commitee](https://github.com/asyncapi/community/discussions/295) to pay for up to 8 Zoom licenses. @@ -165,4 +165,73 @@ Once a new meeting is approved, add a [new workflow like this one](.github/workf ### How can I become a host? -Once your `Regular` meeting gets approved, contact `Fran Mendez` so that he can give you access to all required tools. +Once your `Regular` meeting gets approved, contact `Fran Mendez` so he can give you access to all required tools. + + + +## How do I publish broadcasted meetings as podcasts? + +### Why do we need this feature? + +- Some people prefer to listen to the video/livestream as an audio (podcast) instead of watching the video. + +- The goal is to upload our AsyncAPI video/live streams on `Spotify For Podcasters` platform, ultimately allowing the listener to play the episodes on Spotify. Almost every YouTube video can be converted into a podcast. + + +### Who can upload the videos? + +- The workflow can only be triggered by a person with write access to the `master` branch of the `asyncapi/community` repository. + +### What is needed? + +- The YouTube video ID is needed to trigger the workflow. + +### What is YouTube video ID? + +- A YouTube video ID is a unique combination of characters that identifies a specific video on the YouTube platform. It's used in the URL of the video to direct users to the exact video they want to watch. The video ID is typically a sequence of letters, numbers, and special characters that generally comes after the "v=" parameter in the URL. +- [More examples](#list-of-different-types-of-youtube-links) of video ID are given below: ⬇️ + +#### How to find YouTube ID? + +Let's take this video link, for example: https://www.youtube.com/watch?v=3rg_7hIb9PQ. + +Here the video ID is the word/entity after `https://www.youtube.com/watch?v=`, i.e., `3rg_7hIb9PQ` + + +### List of different types of YouTube links + +- `https://www.youtube.com/watch?v=VIDEO_ID` + - Here, it can be https://www.youtube.com/watch?v=3rg_7hIb9PQ +- `https://youtu.be/VIDEO_ID` + - Here, it can be https://www.youtu.be/3rg_7hIb9PQ +- `https://www.youtube.com/embed/VIDEO_ID` + - Here, it can be https://www.youtube.com/embed/3rg_7hIb9PQ +- `https://www.youtube.com/playlist?list=PLAYLIST_ID` + - Here, it can be https://www.youtube.com/playlist?list=PLbi1gRlP7piiaD67o1F4EOPoZztg2r8l6 +- `https://www.youtube.com/shorts/VIDEO_ID` + - Here, it can be https://www.youtube.com/shorts/3rg_7hIb9PQ +- `https://www.youtube.com/watch?v=VIDEO_ID&list=PLAYLIST_ID` + - Here, it can be https://www.youtube.com/watch?v=deLUAobdVpw&list=PLbi1gRlP7piiaD67o1F4EOPoZztg2r8l6 +- `https://youtube.com/shorts/VIDEO_ID?feature=share` + - Here, it can be https://youtube.com/shorts/U5jUr8XAF_M?feature=share + + +### Step-by-step procedure + +Here is an example with a procedure on how to use this workflow: + +1. Go to the `Actions` section on GitHub. +2. Scroll down the menu on the left-hand side. +3. Click on the `Upload Episode from YouTube To Spotify for Podcasters` option. +4. Click on the `Run Workflow` button. +5. Provide the YouTube ID in the box. +6. Click on `Run workflow` button. +7. Wait for the workflow to finish. (Depending on video size, it may take some time to upload, so please have patience. Thank you.) . +8. A few moments later....Hurray! Your episode is now uploaded successfully! + +You can also modify description and other information for uploaded podcast directly in Spotify: + +1. Go to https://podcasters.spotify.com/. +2. Login using AsyncAPI account. +2. Go to `Episodes` section. There, you will see your latest upload. +3. Perform edits and save them.