Compare commits

..

71 Commits

Author SHA1 Message Date
Inex Code e38b736b60 fix: Remove unnecessary jobs.update call 2024-05-01 14:31:05 +03:00
dettlaff 2024ff4865 tests: add fp mock
continuous-integration/drone/push Build is passing Details
2024-04-13 14:58:13 +04:00
dettlaff a4b1c058f7 style: fix black
continuous-integration/drone/push Build is passing Details
2024-04-10 19:07:33 +04:00
dettlaff d182e365d6 Merge remote-tracking branch 'origin/master' into def/nix-collect-garbage-endpoint
continuous-integration/drone/push Build is failing Details
2024-04-10 18:58:16 +04:00
dettlaff ebf577b83a Merge branch 'def/nix-collect-garbage-endpoint' of git.selfprivacy.org:SelfPrivacy/selfprivacy-rest-api into def/nix-collect-garbage-endpoint 2024-04-03 03:02:20 +04:00
Inex Code dd5acae98a style: rename ip6 addresses variable 2024-03-28 17:43:31 +04:00
Inex Code 467796b2ad refactor: use ipaddress library for ip validation 2024-03-28 17:43:31 +04:00
Inex Code 9399a3bdf3 fix(dns): Ignore link-local IPv6 address 2024-03-28 17:43:31 +04:00
Inex Code fbd0ae0494 chore: Bump version to 3.0.1 2024-03-28 17:43:31 +04:00
Houkime aa3dc5fb05 fix(backups): fix wrong typing in autobackups 2024-03-28 17:43:31 +04:00
def 40c961dbe2 Merge branch 'master' into def/nix-collect-garbage-endpoint
continuous-integration/drone/push Build is failing Details
2024-03-01 17:10:35 +02:00
dettlaff 8ce83f7b7e fix: GIT
continuous-integration/drone/push Build is failing Details
2024-03-01 19:09:39 +04:00
dettlaff fc60d55994 Merge branch 'def/nix-collect-garbage-endpoint' 2024-02-15 02:57:57 +04:00
dettlaff 567f094336 fix: frem review
continuous-integration/drone/push Build is failing Details
2024-02-08 18:40:12 +04:00
dettlaff 29596a4f47 docs: changed the description of the error class
continuous-integration/drone/push Build is failing Details
2024-02-05 13:46:38 +04:00
dettlaff b3127fb1b4 Merge branch 'def/nix-collect-garbage-endpoint' of git.selfprivacy.org:SelfPrivacy/selfprivacy-rest-api into def/nix-collect-garbage-endpoint
continuous-integration/drone/push Build is failing Details
2024-02-03 23:10:55 +04:00
dettlaff eb1bc9d730 fix: from review 2024-02-03 23:10:01 +04:00
def 44d43c92d9 Merge branch 'master' into def/nix-collect-garbage-endpoint
continuous-integration/drone/push Build is failing Details
2024-01-30 16:05:04 +02:00
dettlaff 045ad30ec3 fix: add mock for nix collect garbage
continuous-integration/drone/push Build is failing Details
2024-01-30 18:04:43 +04:00
dettlaff d923b04aef Merge branch 'master' into def/nix-collect-garbage-endpoint
continuous-integration/drone/push Build is failing Details
2024-01-23 21:01:08 +04:00
dettlaff bb1e1bcae0 fix: rename functions
continuous-integration/drone/push Build is failing Details
2024-01-17 19:26:10 +04:00
dettlaff 372eadd306 tests: fix test_parse_line
continuous-integration/drone/push Build is failing Details
2023-11-29 13:02:59 +04:00
dettlaff 03e6d45279 fix: final typos fix
continuous-integration/drone/push Build is failing Details
2023-11-15 16:47:04 +04:00
dettlaff 3be5816f51 fix: del unused return from parse line
continuous-integration/drone/push Build is failing Details
2023-11-12 01:38:31 +04:00
dettlaff d31ad487eb fix: corrected from comment from pr
continuous-integration/drone/push Build is failing Details
2023-11-12 01:16:04 +04:00
dettlaff 9114bc6ae0 fix: remove unused imports
continuous-integration/drone/push Build is failing Details
2023-11-12 01:13:14 +04:00
dettlaff c0f8b9026b fix: corrected from comment from pr
continuous-integration/drone/push Build is failing Details
2023-10-16 20:39:58 +04:00
dettlaff eda5923cc6 tests: fix query
continuous-integration/drone/push Build is failing Details
2023-10-12 02:59:31 +04:00
dettlaff 98eef8d08e fix: tests, jobs.error return
continuous-integration/drone/push Build is failing Details
2023-10-12 02:40:47 +04:00
dettlaff 70a498d0e5 fix: missclick with Job jobs
continuous-integration/drone/push Build is failing Details
2023-10-12 02:26:27 +04:00
dettlaff f2ead0c77d fix: typos
continuous-integration/drone/push Build is failing Details
2023-10-12 02:18:29 +04:00
dettlaff 0503db9856 Merge branch 'def/nix-collect-garbage-endpoint' of git.selfprivacy.org:SelfPrivacy/selfprivacy-rest-api into def/nix-collect-garbage-endpoint
continuous-integration/drone/push Build is failing Details
2023-10-12 02:09:46 +04:00
dettlaff 3fbc93c998 tests: fix rename 2023-10-12 02:09:13 +04:00
dettlaff 5c42d7a907 refactor: problems from pr 2023-10-12 02:01:31 +04:00
dettlaff ec404464d8 Merge branch 'master' into def/nix-collect-garbage-endpoint
continuous-integration/drone/push Build is failing Details
2023-09-01 19:21:31 +04:00
dettlaff 446220a9c5 fix: replace os to subprocess
continuous-integration/drone/push Build is failing Details
2023-08-07 17:38:44 +04:00
def aadf0cb1a3 Delete 'zsh-config.nix'
continuous-integration/drone/push Build is failing Details
2023-08-07 16:00:01 +03:00
def be821fe1e0 Delete 'dump.rdb'
continuous-integration/drone/push Build is failing Details
2023-08-07 15:58:45 +03:00
dettlaff a316f8b910 tests: fix
continuous-integration/drone/push Build is failing Details
2023-08-07 16:56:35 +04:00
dettlaff be8d249a04 fix: do a redis reset() 2023-08-07 16:41:42 +04:00
dettlaff 1640ed44f6 tests: add success check
continuous-integration/drone/pr Build is failing Details
continuous-integration/drone/push Build is failing Details
2023-08-07 06:24:48 +04:00
dettlaff 7c68f05040 tests: delete old, fix
continuous-integration/drone/push Build is failing Details
continuous-integration/drone/pr Build is failing Details
2023-08-03 05:47:57 +04:00
dettlaff 66970e6375 fix: stupid russian C
continuous-integration/drone/push Build is failing Details
continuous-integration/drone/pr Build is failing Details
2023-06-30 20:51:06 +04:00
dettlaff 19005158a8 fix: add timewait
continuous-integration/drone/pr Build is failing Details
continuous-integration/drone/push Build is failing Details
2023-06-26 23:33:41 +04:00
dettlaff 993ea93ee4 fix: delete old gen 2023-06-21 10:52:31 +04:00
dettlaff 3d4caaf4ce fix: encoding 2023-06-20 23:25:54 +04:00
dettlaff 79ef4c9310 fix: task registry 2023-06-20 01:25:04 +04:00
dettlaff aa85b6963b Merge branch 'def/nix-collect-garbage-endpoint' of git.selfprivacy.org:SelfPrivacy/selfprivacy-rest-api into def/nix-collect-garbage-endpoint 2023-06-18 08:44:53 +04:00
dettlaff 83cf7cbd6f fix: jobs 2023-06-18 08:37:27 +04:00
dettlaff d6c4d458f7 tests: fix some tests 2023-06-16 08:08:36 +04:00
dettlaff 28701e1608 fix: do a redis reset() 2023-06-16 08:08:36 +04:00
dettlaff 96c013c4e7 refactor: delete purest of nix_collect_garbage() 2023-06-16 08:08:36 +04:00
ВашÐdettlaff 03b5a6b5e4 fix: percentage 2023-06-16 08:08:36 +04:00
def af0129bdfe fix: types, add tests 2023-06-16 04:06:49 +00:00
def 7553202a69 test: fix nix collect garbage, add tests 2023-06-16 04:06:49 +00:00
def 7e3adffb68 refactor: nix-collect-garbage is now pure 2023-06-16 04:06:49 +00:00
def f42594f1fb refactor: delete unnecessary import 2023-06-16 04:06:49 +00:00
def 6ef9222e32 feat: loading percentage 2023-06-16 04:06:49 +00:00
def ba168fc92b fix: subprocess.check_output 2023-06-16 04:06:49 +00:00
def 57ec87bf43 feat: add nix-collect-garbage job 2023-06-16 04:06:49 +00:00
dettlaff f781b51a6f Merge branch 'master' into def/nix-collect-garbage-endpoint 2023-04-05 13:52:48 +03:00
dettlaff a67f3e822a fix: do a redis reset() 2023-04-05 13:49:56 +03:00
dettlaff cf06d4c8d5 refactor: delete purest of nix_collect_garbage() 2023-04-03 17:41:41 +03:00
ВашÐdettlaff 88d66fea8c fix: percentage 2023-03-23 20:49:30 +03:00
def fcdd61006b fix: types, add tests 2022-12-27 04:15:02 +04:00
def 2340a0f8e9 test: fix nix collect garbage, add tests 2022-12-19 06:27:44 +04:00
def 510b94039e refactor: nix-collect-garbage is now pure 2022-12-13 05:44:52 +04:00
def 3ecd522bd2 refactor: delete unnecessary import 2022-12-03 22:30:41 +04:00
def 4ce96c303d feat: loading percentage 2022-12-03 22:27:10 +04:00
def 6b93df9630 fix: subprocess.check_output 2022-11-24 06:32:37 +04:00
def 13d3261d36 feat: add nix-collect-garbage job 2022-11-24 06:08:58 +04:00
5 changed files with 20 additions and 51 deletions

View File

@ -27,4 +27,4 @@ async def get_token_header(
def get_api_version() -> str:
"""Get API version"""
return "3.2.1"
return "3.1.0"

View File

@ -34,24 +34,6 @@ class BackupConfiguration:
location_id: typing.Optional[str]
# TODO: Ideally this should not be done in API but making an internal Service requires more work
# than to make an API record about a service
def tombstone_service(service_id: str) -> Service:
return Service(
id=service_id,
display_name=f"{service_id} (Orphaned)",
description="",
svg_icon="",
is_movable=False,
is_required=False,
is_enabled=False,
status=ServiceStatusEnum.OFF,
url=None,
can_be_backed_up=False,
backup_description="",
)
@strawberry.type
class Backup:
@strawberry.field
@ -73,21 +55,27 @@ class Backup:
result = []
snapshots = Backups.get_all_snapshots()
for snap in snapshots:
api_service = None
service = get_service_by_id(snap.service_name)
if service is None:
api_service = tombstone_service(snap.service_name)
else:
api_service = service_to_graphql_service(service)
if api_service is None:
raise NotImplementedError(
f"Could not construct API Service record for:{snap.service_name}. This should be unreachable and is a bug if you see it."
service = Service(
id=snap.service_name,
display_name=f"{snap.service_name} (Orphaned)",
description="",
svg_icon="",
is_movable=False,
is_required=False,
is_enabled=False,
status=ServiceStatusEnum.OFF,
url=None,
dns_records=None,
can_be_backed_up=False,
backup_description="",
)
else:
service = service_to_graphql_service(service)
graphql_snap = SnapshotInfo(
id=snap.id,
service=api_service,
service=service,
created_at=snap.created_at,
reason=snap.reason,
)

View File

@ -2,7 +2,7 @@ from setuptools import setup, find_packages
setup(
name="selfprivacy_api",
version="3.2.1",
version="3.1.0",
packages=find_packages(),
scripts=[
"selfprivacy_api/app.py",

View File

@ -208,7 +208,5 @@ def dummy_service(
service.enable()
yield service
# Cleanup because apparently it matters wrt tasks
# Some tests may remove it from the list intentionally, this is fine
if service in services.services:
services.services.remove(service)
# cleanup because apparently it matters wrt tasks
services.services.remove(service)

View File

@ -3,8 +3,6 @@ from tests.test_backup import backups
from tests.common import generate_backup_query
import selfprivacy_api.services as all_services
from selfprivacy_api.services import get_service_by_id
from selfprivacy_api.graphql.common_types.service import service_to_graphql_service
from selfprivacy_api.graphql.common_types.backup import (
_AutobackupQuotas,
@ -145,7 +143,6 @@ allSnapshots {
id
service {
id
displayName
}
createdAt
reason
@ -309,20 +306,6 @@ def test_snapshots_empty(authorized_client, dummy_service, backups):
assert snaps == []
def test_snapshots_orphaned_service(authorized_client, dummy_service, backups):
api_backup(authorized_client, dummy_service)
snaps = api_snapshots(authorized_client)
assert len(snaps) == 1
all_services.services.remove(dummy_service)
assert get_service_by_id(dummy_service.get_id()) is None
snaps = api_snapshots(authorized_client)
assert len(snaps) == 1
assert "Orphaned" in snaps[0]["service"]["displayName"]
assert dummy_service.get_id() in snaps[0]["service"]["displayName"]
def test_start_backup(authorized_client, dummy_service, backups):
response = api_backup(authorized_client, dummy_service)
data = get_data(response)["backup"]["startBackup"]