Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add Google Drive documentation #36690

Open
wants to merge 5 commits into
base: next
Choose a base branch
from

Conversation

tronikos
Copy link
Member

@tronikos tronikos commented Jan 3, 2025

Proposed change

SSIA

Type of change

  • Spelling, grammar or other readability improvements (current branch).
  • Adjusted missing or incorrect information in the current documentation (current branch).
  • Added documentation for a new integration I'm adding to Home Assistant (next branch).
  • Added documentation for a new feature I'm adding to Home Assistant (next branch).
  • Removed stale or deprecated documentation.

Additional information

Checklist

  • This PR uses the correct branch, based on one of the following:
    • I made a change to the existing documentation and used the current branch.
    • I made a change that is related to an upcoming version of Home Assistant and used the next branch.
  • The documentation follows the Home Assistant documentation standards.

Summary by CodeRabbit

Summary by CodeRabbit

  • New Features

    • Added Google Drive integration to Home Assistant
    • Enables backup storage through Google Drive
    • Users can rename the backup folder, which is automatically recreated if deleted
  • Documentation

    • Provided comprehensive setup instructions
    • Clarified prerequisites and credential requirements
    • Added troubleshooting guidance for integration management
    • Included links to Google Developer Console and Google Drive API
    • Noted limitations regarding file access within Google Drive

@home-assistant home-assistant bot added has-parent This PR has a parent PR in a other repo next This PR goes into the next branch labels Jan 3, 2025
Copy link

netlify bot commented Jan 3, 2025

Deploy Preview for home-assistant-docs ready!

Name Link
🔨 Latest commit 965cfe5
🔍 Latest deploy log https://app.netlify.com/sites/home-assistant-docs/deploys/6781131675eeb8000812660b
😎 Deploy Preview https://deploy-preview-36690--home-assistant-docs.netlify.app
📱 Preview on mobile
Toggle QR Code...

QR Code

Use your smartphone camera to open QR code link.

To edit notification comments on pull requests, go to your Netlify site configuration.

Copy link
Contributor

coderabbitai bot commented Jan 3, 2025

📝 Walkthrough

Walkthrough

The pull request introduces a new markdown documentation file for the Google Drive integration in Home Assistant. This file provides comprehensive information about integrating Google Drive with Home Assistant, focusing on backup functionality. It covers setup prerequisites, configuration details, credential requirements, and user guidance for connecting a Google Drive account to the home automation system.

Changes

File Change Summary
source/_integrations/google_drive.markdown New documentation file added for Google Drive integration, including metadata, setup instructions, prerequisites, configuration details, and troubleshooting guidance.

Sequence Diagram

sequenceDiagram
    participant User
    participant HomeAssistant
    participant GoogleDrive
    participant GoogleDevConsole

    User->>GoogleDevConsole: Create Developer Credentials
    User->>HomeAssistant: Configure Google Drive Integration
    HomeAssistant->>GoogleDrive: Request Authorization
    GoogleDrive-->>HomeAssistant: Grant Access
    HomeAssistant->>GoogleDrive: Create Backup Folder
    HomeAssistant->>GoogleDrive: Store Backups
Loading

The sequence diagram illustrates the high-level flow of setting up the Google Drive integration, from obtaining developer credentials to authorizing and creating a backup folder in the user's Google Drive.


Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai generate docstrings to generate docstrings for this PR. (Beta)
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai or @coderabbitai title anywhere in the PR title to generate the title automatically.

CodeRabbit Configuration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Nitpick comments (3)
source/_integrations/google_drive.markdown (3)

13-15: Remove duplicate Google Developer Console links

The google_dev_console_link and api_link point to the same URL. Consider removing one of them to avoid duplication.

 google_dev_console_link: https://console.developers.google.com/start/api?id=drive
 api: Google Drive API
-api_link: https://console.developers.google.com/start/api?id=drive

26-27: Remove extra blank line

Remove one of the consecutive blank lines to maintain consistent formatting.

 {% include integrations/google_client_secret.md %}

-
 {% include integrations/config_flow.md %}
🧰 Tools
🪛 Markdownlint (0.37.0)

26-26: Expected: 1; Actual: 2
Multiple consecutive blank lines

(MD012, no-multiple-blanks)


35-35: Clarify the file access limitation

The current statement about file access limitation could be clearer. Consider expanding it to better explain the implications.

-The integration only has access to files created by this integration.
+The integration can only access backup files that it creates in the Home Assistant folder. It cannot access or modify any other files in your Google Drive.
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 90d5287 and 3d44b50.

📒 Files selected for processing (1)
  • source/_integrations/google_drive.markdown (1 hunks)
🧰 Additional context used
🪛 Markdownlint (0.37.0)
source/_integrations/google_drive.markdown

26-26: Expected: 1; Actual: 2
Multiple consecutive blank lines

(MD012, no-multiple-blanks)

🔇 Additional comments (4)
source/_integrations/google_drive.markdown (4)

7-7: Verify the release version

The release version '2025.2' seems unusually far in the future. Please verify if this is the intended version number.


18-18: LGTM! Clear and informative introduction.

The introduction effectively explains the integration's purpose and basic functionality.


39-43: LGTM! Clear removal and troubleshooting instructions.

The instructions for removing the integration and handling credential errors are clear and helpful.


22-24: Verify credential sharing with other Google integrations

Please verify that the credentials are indeed shared with all listed integrations (Google Sheets, Nest, YouTube, and Google Mail).

✅ Verification successful

Let me check the credential configuration details in these integrations to verify the shared credentials claim.


Credential sharing statement is accurate with minor discrepancies

Based on the verification of all Google integration documentation files, the credential sharing statement is mostly accurate, but there are some minor inconsistencies in how different integrations reference each other. All integrations use the same OAuth setup through google_client_secret.md and the Application Credentials system. However:

  • Google Drive correctly lists all integrations it shares credentials with (Sheets, Nest, YouTube, and Google Mail)
  • Other integrations have slightly different lists but all confirm sharing credentials with each other
  • All integrations consistently note that these are not the same as the Device Auth credentials previously used for Google Calendar
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Check credential configuration in other Google integrations
# Expected: Similar OAuth setup and credential requirements

# Check other Google integration docs for credential setup
rg -l "google_client_secret.md" "source/_integrations/"

Length of output: 351


Script:

#!/bin/bash
# Check the content of these files to verify credential sharing statements
for file in $(rg -l "google_client_secret.md" "source/_integrations/"); do
  echo "=== $file ==="
  rg -A 3 "credential" "$file"
done

Length of output: 9003

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Nitpick comments (4)
source/_integrations/google_drive.markdown (4)

18-18: Consider enhancing the introduction with backup details.

While the introduction is clear, it would be helpful to add information about:

  • The types of backups supported
  • Backup frequency options (if any)
  • Size limitations (if applicable)

26-26: Remove extra blank line.

Remove one of the consecutive blank lines to comply with markdown formatting standards.

-

-
+
🧰 Tools
🪛 Markdownlint (0.37.0)

26-26: Expected: 1; Actual: 2
Multiple consecutive blank lines

(MD012, no-multiple-blanks)


33-35: Consider explaining the security benefit.

The limitation is clearly stated, but consider adding that this restricted access is a security feature that protects your other Google Drive files.


41-43: Enhance troubleshooting section.

Consider adding more common troubleshooting scenarios such as:

  • Backup creation failures
  • Storage quota issues
  • Permission problems
  • Network connectivity issues
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 3d44b50 and 9f6127f.

📒 Files selected for processing (1)
  • source/_integrations/google_drive.markdown (1 hunks)
🧰 Additional context used
🪛 Markdownlint (0.37.0)
source/_integrations/google_drive.markdown

26-26: Expected: 1; Actual: 2
Multiple consecutive blank lines

(MD012, no-multiple-blanks)

🔇 Additional comments (3)
source/_integrations/google_drive.markdown (3)

1-16: LGTM! Metadata section is well-structured.

The metadata follows Home Assistant documentation standards with appropriate categorization, IoT class, and external links.


22-24: LGTM! Clear credential requirements.

Excellent clarification about shared credentials across Google integrations and distinction from Device Auth credentials.


1-43: Verify consistency with core implementation.

Please ensure the documentation aligns with the implementation in the core PR (home-assistant/core#134576).

🧰 Tools
🪛 Markdownlint (0.37.0)

26-26: Expected: 1; Actual: 2
Multiple consecutive blank lines

(MD012, no-multiple-blanks)

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Nitpick comments (6)
source/_integrations/google_drive.markdown (6)

13-15: Update Google Console links to use the current domain.

The Google Developer Console links should be updated to use the current console.cloud.google.com domain instead of the older developers.google.com domain. Also, since both links are identical, consider consolidating them into a single variable.

-google_dev_console_link: https://console.developers.google.com/start/api?id=drive
-api: Google Drive API
-api_link: https://console.developers.google.com/start/api?id=drive
+google_dev_console_link: https://console.cloud.google.com/apis/library/drive.googleapis.com
+api: Google Drive API

18-18: Enhance the introduction with backup functionality details.

Consider adding information about automatic backup capabilities to make the integration's value proposition clearer to users.

-This integration allows you to connect your [Google Drive](https://drive.google.com) with Home Assistant Backups. When you set up a config entry, your drive will have a new folder called Home Assistant where all the backups will be stored. You can then rename this to whatever you like.
+This integration allows you to connect your [Google Drive](https://drive.google.com) with Home Assistant Backups, enabling automatic backup storage in the cloud. When you set up a config entry, your drive will have a new folder called Home Assistant where all the backups will be stored. You can then rename this to whatever you like.

22-24: Add information about required Google Drive permissions.

Consider adding details about the specific Google Drive API scopes/permissions that will be requested during setup. This helps users make informed decisions about security.


41-41: Fix typo in limitations section.

There's a spelling error in the word "instances".

-Every time you add the integration, a new Home Assistant folder is created. This is intentional to allow multiple Home Assistant instaces to upload to the same Google Drive account.
+Every time you add the integration, a new Home Assistant folder is created. This is intentional to allow multiple Home Assistant instances to upload to the same Google Drive account.

45-45: Enhance troubleshooting section and fix grammar.

  1. Add a comma after "credentials" for better readability.
  2. Consider adding more common troubleshooting scenarios, such as:
    • Quota limits
    • Network connectivity issues
    • Permission-related errors
-If you have an error with your credentials you can delete them in the [Application Credentials](/integrations/application_credentials/) user interface.
+If you have an error with your credentials, you can delete them in the [Application Credentials](/integrations/application_credentials/) user interface.
🧰 Tools
🪛 LanguageTool

[uncategorized] ~45-~45: Possible missing comma found.
Context: ...oting

If you have an error with your credentials you can delete them in the [Application...

(AI_HYDRA_LEO_MISSING_COMMA)


26-26: Remove extra blank line.

There are multiple consecutive blank lines here. One blank line is sufficient.

🧰 Tools
🪛 Markdownlint (0.37.0)

26-26: Expected: 1; Actual: 2
Multiple consecutive blank lines

(MD012, no-multiple-blanks)

📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 9f6127f and 95503c6.

📒 Files selected for processing (1)
  • source/_integrations/google_drive.markdown (1 hunks)
🧰 Additional context used
🪛 LanguageTool
source/_integrations/google_drive.markdown

[uncategorized] ~45-~45: Possible missing comma found.
Context: ...oting

If you have an error with your credentials you can delete them in the [Application...

(AI_HYDRA_LEO_MISSING_COMMA)

🪛 Markdownlint (0.37.0)
source/_integrations/google_drive.markdown

26-26: Expected: 1; Actual: 2
Multiple consecutive blank lines

(MD012, no-multiple-blanks)

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Nitpick comments (4)
source/_integrations/google_drive.markdown (4)

3-3: Enhance the description to be more specific about backup functionality.

Consider making the description more specific to better reflect the integration's primary purpose:

-description: Instructions on how to use Google Drive in Home Assistant.
+description: Instructions on how to use Google Drive for storing Home Assistant backups.

18-18: Add clarity about folder creation behavior.

Consider mentioning the automatic folder creation behavior upfront, as it's important for users with multiple Home Assistant instances.

-This integration allows you to connect your [Google Drive](https://drive.google.com) with Home Assistant Backups. When you set up a config entry, your drive will have a new folder called Home Assistant where all the backups will be stored. You can then rename this to whatever you like.
+This integration allows you to connect your [Google Drive](https://drive.google.com) with Home Assistant Backups. When you set up a config entry, your drive will have a new folder called Home Assistant where all the backups will be stored. You can then rename this to whatever you like. A new folder is created for each Home Assistant instance you connect, allowing multiple instances to use the same Google Drive account.

26-26: Remove extra blank line.

Fix the markdown formatting by removing one of the consecutive blank lines.

{% include integrations/google_client_secret.md %}

-
{% include integrations/config_flow.md %}
🧰 Tools
🪛 Markdownlint (0.37.0)

26-26: Expected: 1; Actual: 2
Multiple consecutive blank lines

(MD012, no-multiple-blanks)


43-45: Expand troubleshooting section.

Consider adding more common troubleshooting scenarios:

  • Network connectivity issues
  • Permission-related problems
  • Backup upload failures
  • Storage quota exceeded errors

Would you like me to help draft additional troubleshooting scenarios and their solutions?

📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 95503c6 and b70f19e.

📒 Files selected for processing (1)
  • source/_integrations/google_drive.markdown (1 hunks)
🧰 Additional context used
🪛 Markdownlint (0.37.0)
source/_integrations/google_drive.markdown

26-26: Expected: 1; Actual: 2
Multiple consecutive blank lines

(MD012, no-multiple-blanks)

⏰ Context from checks skipped due to timeout of 90000ms (3)
  • GitHub Check: Redirect rules - home-assistant-docs
  • GitHub Check: Header rules - home-assistant-docs
  • GitHub Check: Pages changed - home-assistant-docs
🔇 Additional comments (1)
source/_integrations/google_drive.markdown (1)

39-41: Consider adding information about storage limits.

The limitations section could benefit from addressing:

  • Any backup retention policies
  • Storage space limitations
  • Maximum file size restrictions

Would you like me to help draft additional documentation about these aspects?

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Nitpick comments (3)
source/_integrations/google_drive.markdown (3)

13-15: Remove duplicate Google Developer Console link.

The google_dev_console_link and api_link contain the same URL. Consider removing one of them to avoid maintenance overhead.

 google_dev_console_link: https://console.developers.google.com/start/api?id=drive
 api: Google Drive API
-api_link: https://console.developers.google.com/start/api?id=drive

26-26: Remove extra blank line.

There's an extra blank line that should be removed to comply with markdown formatting standards.

🧰 Tools
🪛 Markdownlint (0.37.0)

26-26: Expected: 1; Actual: 2
Multiple consecutive blank lines

(MD012, no-multiple-blanks)


42-44: Consider expanding troubleshooting scenarios.

While the current troubleshooting information is helpful, consider adding more common scenarios such as:

  • Backup folder permission issues
  • API quota limits
  • Network connectivity problems
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between b70f19e and 965cfe5.

📒 Files selected for processing (1)
  • source/_integrations/google_drive.markdown (1 hunks)
🧰 Additional context used
🪛 Markdownlint (0.37.0)
source/_integrations/google_drive.markdown

26-26: Expected: 1; Actual: 2
Multiple consecutive blank lines

(MD012, no-multiple-blanks)

⏰ Context from checks skipped due to timeout of 90000ms (3)
  • GitHub Check: Redirect rules - home-assistant-docs
  • GitHub Check: Header rules - home-assistant-docs
  • GitHub Check: Pages changed - home-assistant-docs
🔇 Additional comments (5)
source/_integrations/google_drive.markdown (5)

12-12: Verify integration type classification.

Please confirm if this should be classified as a service integration type. Since it's primarily used for backup functionality, would integration be more appropriate?


18-18: LGTM! Clear and informative description.

The description effectively communicates the integration's purpose and behavior regarding folder management.


33-41: LGTM! Well-documented limitations and removal process.

The sections clearly explain the integration's limitations and cleanup requirements. The use of standard templates ensures consistency with other integrations.


1-44: Verify documentation coverage against core implementation.

Since this documentation is part of a larger integration effort (core PR #134576), let's verify that all features are documented.

✅ Verification successful

Documentation appears complete and accurately reflects integration functionality

The documentation comprehensively covers all essential aspects of this backup-focused integration:

  • Setup process through config flow
  • OAuth authentication
  • Automatic backup storage functionality
  • Folder behavior and limitations
  • Removal process and troubleshooting
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Check for potential undocumented features
# Search for configurable options and services in the core PR

echo "Checking for integration features in core PR..."
gh api repos/home-assistant/core/pulls/134576 | jq -r '.diff_url' | xargs curl -s | grep -A 5 "^+"

echo "Checking for service definitions..."
fd -e yaml "google_drive.yaml" "source/_integrations/"

Length of output: 337


Script:

#!/bin/bash
# Search for all files related to google_drive integration
echo "=== Searching for google_drive integration files ==="
fd google_drive

# Look for potential service definitions or config schemas
echo -e "\n=== Checking for service/config definitions ==="
rg -l "google_drive" source/_integrations/

# Search for specific integration features
echo -e "\n=== Searching for feature descriptions ==="
rg "## Features|## Configuration|## Services" source/_integrations/google_drive.markdown

Length of output: 564


Script:

#!/bin/bash
# Deep dive into the documentation content
echo "=== Checking documentation content ==="
cat source/_integrations/google_drive.markdown

# Search for any potential service calls or config options
echo -e "\n=== Searching for potential service/config references ==="
rg -i "service|config|option|parameter" source/_integrations/google_drive.markdown

Length of output: 2696

🧰 Tools
🪛 Markdownlint (0.37.0)

26-26: Expected: 1; Actual: 2
Multiple consecutive blank lines

(MD012, no-multiple-blanks)


22-24: Verify credential sharing compatibility.

The documentation states that credentials are shared with Google Sheets, Nest, YouTube, and Google Mail integrations. Let's verify this compatibility.

✅ Verification successful

Documentation is accurate regarding credential sharing

The documentation correctly states that credentials are shared between Google Drive, Google Sheets, Nest, YouTube, and Google Mail integrations. All these integrations:

  • Use the same OAuth2 authentication flow
  • Share the same application credentials configuration
  • Follow identical setup processes in the Google Cloud Console
  • Use the same redirect URI for authentication
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify credential sharing compatibility with other Google integrations
# Search for OAuth scopes and credential configurations in other Google integrations

echo "Checking OAuth scopes in referenced integrations..."
rg -l "google_oauth.md" "source/_integrations/"

echo "Checking credential configurations..."
rg "application_credentials" "source/_integrations/google_*"

Length of output: 621


Script:

#!/bin/bash
# Check OAuth scopes and credential configurations in Google integrations

echo "Checking OAuth scopes and configurations..."
rg -A 5 -B 5 "oauth.*scope|required_files|configuration" source/_integrations/google_drive.markdown source/_integrations/google_sheets.markdown source/_integrations/youtube.markdown source/_integrations/google_mail.markdown

echo "Checking Nest integration..."
rg -A 5 -B 5 "oauth|configuration" source/_integrations/nest.markdown

Length of output: 13775


Script:

#!/bin/bash
# Check for application_credentials and OAuth configuration in other Google integrations

echo "Checking application_credentials references..."
rg -A 3 "application_credentials" source/_integrations/

echo "Checking OAuth configuration in Google integrations..."
for file in source/_integrations/google_*.markdown source/_integrations/youtube.markdown; do
  if [ -f "$file" ]; then
    echo "=== $file ==="
    rg -A 5 "oauth|configuration|credentials" "$file"
  fi
done

Length of output: 48155

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
has-parent This PR has a parent PR in a other repo next This PR goes into the next branch
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant