mirror of
https://github.com/esphome/esphome.git
synced 2024-12-22 21:44:55 +01:00
Allow Git credentials to be loaded from secrets (#2825)
This commit is contained in:
parent
5719cc1a24
commit
08cbb97ec9
3 changed files with 26 additions and 1 deletions
|
@ -12,6 +12,8 @@ from esphome.const import (
|
||||||
CONF_TYPE,
|
CONF_TYPE,
|
||||||
CONF_EXTERNAL_COMPONENTS,
|
CONF_EXTERNAL_COMPONENTS,
|
||||||
CONF_PATH,
|
CONF_PATH,
|
||||||
|
CONF_USERNAME,
|
||||||
|
CONF_PASSWORD,
|
||||||
)
|
)
|
||||||
from esphome.core import CORE
|
from esphome.core import CORE
|
||||||
from esphome import git, loader
|
from esphome import git, loader
|
||||||
|
@ -27,6 +29,8 @@ TYPE_LOCAL = "local"
|
||||||
GIT_SCHEMA = {
|
GIT_SCHEMA = {
|
||||||
cv.Required(CONF_URL): cv.url,
|
cv.Required(CONF_URL): cv.url,
|
||||||
cv.Optional(CONF_REF): cv.git_ref,
|
cv.Optional(CONF_REF): cv.git_ref,
|
||||||
|
cv.Optional(CONF_USERNAME): cv.string,
|
||||||
|
cv.Optional(CONF_PASSWORD): cv.string,
|
||||||
}
|
}
|
||||||
LOCAL_SCHEMA = {
|
LOCAL_SCHEMA = {
|
||||||
cv.Required(CONF_PATH): cv.directory,
|
cv.Required(CONF_PATH): cv.directory,
|
||||||
|
@ -99,6 +103,8 @@ def _process_git_config(config: dict, refresh) -> str:
|
||||||
ref=config.get(CONF_REF),
|
ref=config.get(CONF_REF),
|
||||||
refresh=refresh,
|
refresh=refresh,
|
||||||
domain=DOMAIN,
|
domain=DOMAIN,
|
||||||
|
username=config.get(CONF_USERNAME),
|
||||||
|
password=config.get(CONF_PASSWORD),
|
||||||
)
|
)
|
||||||
|
|
||||||
if (repo_dir / "esphome" / "components").is_dir():
|
if (repo_dir / "esphome" / "components").is_dir():
|
||||||
|
|
|
@ -10,6 +10,8 @@ from esphome.const import (
|
||||||
CONF_REF,
|
CONF_REF,
|
||||||
CONF_REFRESH,
|
CONF_REFRESH,
|
||||||
CONF_URL,
|
CONF_URL,
|
||||||
|
CONF_USERNAME,
|
||||||
|
CONF_PASSWORD,
|
||||||
)
|
)
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
|
|
||||||
|
@ -93,6 +95,8 @@ BASE_SCHEMA = cv.All(
|
||||||
cv.Schema(
|
cv.Schema(
|
||||||
{
|
{
|
||||||
cv.Required(CONF_URL): cv.url,
|
cv.Required(CONF_URL): cv.url,
|
||||||
|
cv.Optional(CONF_USERNAME): cv.string,
|
||||||
|
cv.Optional(CONF_PASSWORD): cv.string,
|
||||||
cv.Exclusive(CONF_FILE, "files"): validate_yaml_filename,
|
cv.Exclusive(CONF_FILE, "files"): validate_yaml_filename,
|
||||||
cv.Exclusive(CONF_FILES, "files"): cv.All(
|
cv.Exclusive(CONF_FILES, "files"): cv.All(
|
||||||
cv.ensure_list(validate_yaml_filename),
|
cv.ensure_list(validate_yaml_filename),
|
||||||
|
@ -124,6 +128,8 @@ def _process_base_package(config: dict) -> dict:
|
||||||
ref=config.get(CONF_REF),
|
ref=config.get(CONF_REF),
|
||||||
refresh=config[CONF_REFRESH],
|
refresh=config[CONF_REFRESH],
|
||||||
domain=DOMAIN,
|
domain=DOMAIN,
|
||||||
|
username=config.get(CONF_USERNAME),
|
||||||
|
password=config.get(CONF_PASSWORD),
|
||||||
)
|
)
|
||||||
files: str = config[CONF_FILES]
|
files: str = config[CONF_FILES]
|
||||||
|
|
||||||
|
|
|
@ -2,6 +2,7 @@ from pathlib import Path
|
||||||
import subprocess
|
import subprocess
|
||||||
import hashlib
|
import hashlib
|
||||||
import logging
|
import logging
|
||||||
|
import urllib.parse
|
||||||
|
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
|
|
||||||
|
@ -36,9 +37,21 @@ def _compute_destination_path(key: str, domain: str) -> Path:
|
||||||
|
|
||||||
|
|
||||||
def clone_or_update(
|
def clone_or_update(
|
||||||
*, url: str, ref: str = None, refresh: TimePeriodSeconds, domain: str
|
*,
|
||||||
|
url: str,
|
||||||
|
ref: str = None,
|
||||||
|
refresh: TimePeriodSeconds,
|
||||||
|
domain: str,
|
||||||
|
username: str = None,
|
||||||
|
password: str = None,
|
||||||
) -> Path:
|
) -> Path:
|
||||||
key = f"{url}@{ref}"
|
key = f"{url}@{ref}"
|
||||||
|
|
||||||
|
if username is not None and password is not None:
|
||||||
|
url = url.replace(
|
||||||
|
"://", f"://{urllib.parse.quote(username)}:{urllib.parse.quote(password)}@"
|
||||||
|
)
|
||||||
|
|
||||||
repo_dir = _compute_destination_path(key, domain)
|
repo_dir = _compute_destination_path(key, domain)
|
||||||
fetch_pr_branch = ref is not None and ref.startswith("pull/")
|
fetch_pr_branch = ref is not None and ref.startswith("pull/")
|
||||||
if not repo_dir.is_dir():
|
if not repo_dir.is_dir():
|
||||||
|
|
Loading…
Reference in a new issue