Module ogr.factory
Functions
def get_instances_from_dict(instances: dict) ‑> set[GitService]
-
Expand source code
def get_instances_from_dict(instances: dict) -> set[GitService]: """ Load the service instances from the dictionary in the following form: - `key` : hostname, url or name that can be mapped to the service-type - `value` : dictionary with arguments used when creating a new instance of the service (passed to the `__init__` method) e.g.: ```py get_instances_from_dict({ "github.com": {"token": "abcd"}, "pagure": { "token": "abcd", "instance_url": "https://src.fedoraproject.org", }, }) == { GithubService(token="abcd"), PagureService(token="abcd", instance_url="https://src.fedoraproject.org") } ``` When the mapping `key->service-type` is not recognised, you can add a `type` key to the dictionary and specify the type of the instance. (It can be either name, hostname or url. The used mapping is same as for key->service-type.) The provided `key` is used as an `instance_url` and passed to the `__init__` method as well. e.g.: ```py get_instances_from_dict({ "https://my.gtlb": {"token": "abcd", "type": "gitlab"}, }) == {GitlabService(token="abcd", instance_url="https://my.gtlb")} ``` Args: instances: Mapping from service name/url/hostname to attributes for the service creation. Returns: Set of the service instances. """ services = set() for key, value in instances.items(): service_kls = get_service_class_or_none(url=key) if not service_kls: if "type" not in value: raise OgrException( f"No matching service was found for url '{key}'. " f"Add the service name as a `type` attribute.", ) service_type = value["type"] if service_type not in _SERVICE_MAPPING: raise OgrException( f"No matching service was found for type '{service_type}'.", ) service_kls = _SERVICE_MAPPING[service_type] value.setdefault("instance_url", key) del value["type"] service_instance = service_kls(**value) services.add(service_instance) return services
Load the service instances from the dictionary in the following form:
key
: hostname, url or name that can be mapped to the service-typevalue
: dictionary with arguments used when creating a new instance of the service (passed to the__init__
method)
e.g.:
get_instances_from_dict({ "github.com": {"token": "abcd"}, "pagure": { "token": "abcd", "instance_url": "https://src.fedoraproject.org", }, }) == { GithubService(token="abcd"), PagureService(token="abcd", instance_url="https://src.fedoraproject.org") }
When the mapping
key->service-type
is not recognised, you can add atype
key to the dictionary and specify the type of the instance. (It can be either name, hostname or url. The used mapping is same as for key->service-type.)The provided
key
is used as aninstance_url
and passed to the__init__
method as well.e.g.:
get_instances_from_dict({ "https://my.gtlb": {"token": "abcd", "type": "gitlab"}, }) == {GitlabService(token="abcd", instance_url="https://my.gtlb")}
Args
instances
- Mapping from service name/url/hostname to attributes for the service creation.
Returns
Set of the service instances.
def get_project(url,
service_mapping_update: dict[str, type[GitService]] | None = None,
custom_instances: Iterable[GitService] | None = None,
force_custom_instance: bool = True,
**kwargs) ‑> GitProject-
Expand source code
def get_project( url, service_mapping_update: Optional[dict[str, type[GitService]]] = None, custom_instances: Optional[Iterable[GitService]] = None, force_custom_instance: bool = True, **kwargs, ) -> GitProject: """ Return the project for the given URL. Args: url: URL of the project, e.g. `"https://github.com/packit/ogr"`. service_mapping_update: Custom mapping from service url/hostname (`str`) to service class. Defaults to no mapping. custom_instances: List of instances that will be used when creating a project instance. Defaults to `None`. force_custom_instance: Force picking a Git service from the `custom_instances` list, if there is any provided, raise an error if that is not possible. Defaults to `True`. **kwargs: Arguments forwarded to __init__ of the matching service. Returns: `GitProject` using the matching implementation. """ mapping = service_mapping_update.copy() if service_mapping_update else {} custom_instances = custom_instances or [] for instance in custom_instances: mapping[instance.hostname] = instance.__class__ kls = get_service_class(url=url, service_mapping_update=mapping) parsed_repo_url = parse_git_repo(url) service = None if custom_instances: for service_inst in custom_instances: if ( isinstance(service_inst, kls) and service_inst.hostname == parsed_repo_url.hostname ): service = service_inst break else: if force_custom_instance: raise OgrException( f"Instance of type {kls.__name__} " f"matching instance url '{url}' was not provided.", ) if not service: service = kls(instance_url=parsed_repo_url.get_instance_url(), **kwargs) return service.get_project_from_url(url=url)
Return the project for the given URL.
Args
url
- URL of the project, e.g.
"https://github.com/packit/ogr"
. service_mapping_update
-
Custom mapping from service url/hostname (
str
) to service class.Defaults to no mapping.
custom_instances
-
List of instances that will be used when creating a project instance.
Defaults to
None
. force_custom_instance
-
Force picking a Git service from the
custom_instances
list, if there is any provided, raise an error if that is not possible.Defaults to
True
. **kwargs
- Arguments forwarded to init of the matching service.
Returns
GitProject
using the matching implementation. def get_service_class(url: str,
service_mapping_update: dict[str, type[GitService]] | None = None) ‑> type[GitService]-
Expand source code
def get_service_class( url: str, service_mapping_update: Optional[dict[str, type[GitService]]] = None, ) -> type[GitService]: """ Get the matching service class from the URL. Args: url: URL of the project, e.g. `"https://github.com/packit/ogr"`. service_mapping_update: Custom mapping from service url/hostname (str) to service class. Defaults to `None`. Returns: Matched class (subclass of `GitService`). """ service_kls = get_service_class_or_none( url=url, service_mapping_update=service_mapping_update, ) if service_kls: return service_kls raise OgrException("No matching service was found.")
Get the matching service class from the URL.
Args
url
- URL of the project, e.g.
"https://github.com/packit/ogr"
. service_mapping_update
-
Custom mapping from service url/hostname (str) to service class.
Defaults to
None
.
Returns
Matched class (subclass of
GitService
). def get_service_class_or_none(url: str,
service_mapping_update: dict[str, type[GitService]] | None = None) ‑> type[GitService] | None-
Expand source code
def get_service_class_or_none( url: str, service_mapping_update: Optional[dict[str, type[GitService]]] = None, ) -> Optional[type[GitService]]: """ Get the matching service class from the URL. Args: url: URL of the project, e.g. `"https://github.com/packit/ogr"`. service_mapping_update: Custom mapping from service url/hostname (`str`) to service class. Defaults to `None`. Returns: Matched class (subclass of `GitService`) or `None`. """ mapping = {} mapping.update(_SERVICE_MAPPING) if service_mapping_update: mapping.update(service_mapping_update) parsed_url = parse_git_repo(url) for service, service_kls in mapping.items(): if parse_git_repo(service).hostname in parsed_url.hostname: return service_kls return None
Get the matching service class from the URL.
Args
url
- URL of the project, e.g.
"https://github.com/packit/ogr"
. service_mapping_update
-
Custom mapping from service url/hostname (
str
) to service class.Defaults to
None
.
Returns
Matched class (subclass of
GitService
) orNone
. def use_for_service(service: str)
-
Expand source code
def use_for_service(service: str, _func=None): """ Class decorator that adds the class to the service mapping. When the project url contains the `service` as a substring, this implementation will be used to initialize the project. When using this decorator, be sure that your class is initialized. (Add the import to `ogr/__init__.py`) Usage: ```py @use_for_service("github.com") class GithubService(BaseGitService): pass @use_for_service("pagure.io") @use_for_service("src.fedoraproject.org") class PagureService(BaseGitService): pass ``` Args: service: URL of the service. Returns: Decorator. """ def decorator_cover(func): @functools.wraps(func) def covered_func(kls: type[GitService]): _SERVICE_MAPPING[service] = kls return kls return covered_func return decorator_cover(_func)
Class decorator that adds the class to the service mapping.
When the project url contains the
service
as a substring, this implementation will be used to initialize the project.When using this decorator, be sure that your class is initialized. (Add the import to
ogr/__init__.py
)Usage:
@use_for_service("github.com") class GithubService(BaseGitService): pass @use_for_service("pagure.io") @use_for_service("src.fedoraproject.org") class PagureService(BaseGitService): pass
Args
service
- URL of the service.
Returns
Decorator.