Module ogr.factory
Functions
- def get_instances_from_dict(instances: dict) ‑> set[GitService]
- 
Expand source codedef 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 servicesLoad 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.: 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-typeis not recognised, you can add atypekey 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 keyis used as aninstance_urland 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.
 ReturnsSet 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 codedef 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_instanceslist, 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.
 ReturnsGitProjectusing the matching implementation.
- def get_service_class(url: str,
 service_mapping_update: dict[str, type[GitService]] | None = None) ‑> type[GitService]
- 
Expand source codedef 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.
 ReturnsMatched 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 codedef 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 NoneGet 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.
 ReturnsMatched class (subclass of GitService) orNone.
- def use_for_service(service: str)
- 
Expand source codedef 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 serviceas 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): passArgs- service
- URL of the service.
 ReturnsDecorator.