mirror of
https://github.com/microsoft/onefuzz.git
synced 2025-06-16 11:58:09 +00:00
data migration in the deployment script (#12)
This commit is contained in:
45
src/deployment/data_migration.py
Normal file
45
src/deployment/data_migration.py
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
from azure.cosmosdb.table.tableservice import TableService
|
||||||
|
from azure.cosmosdb.table.models import Entity
|
||||||
|
from azure.cosmosdb.table.tablebatch import TableBatch
|
||||||
|
import json
|
||||||
|
from typing import Optional, Callable, Dict, List
|
||||||
|
|
||||||
|
|
||||||
|
def migrate_task_os(table_service: TableService) -> None:
|
||||||
|
table_name = "Task"
|
||||||
|
tasks = table_service.query_entities(
|
||||||
|
table_name, select="PartitionKey,RowKey,os,config"
|
||||||
|
)
|
||||||
|
partitionKey = None
|
||||||
|
|
||||||
|
count = 0
|
||||||
|
batch = TableBatch()
|
||||||
|
for task in tasks:
|
||||||
|
if partitionKey != task.PartitionKey:
|
||||||
|
table_service.commit_batch(table_name, batch)
|
||||||
|
batch = TableBatch()
|
||||||
|
|
||||||
|
partitionKey = task.PartitionKey
|
||||||
|
if "os" not in task or (not task.os):
|
||||||
|
config = json.loads(task.config)
|
||||||
|
print(config)
|
||||||
|
if "windows".lower() in config["vm"]["image"].lower():
|
||||||
|
task["os"] = "windows"
|
||||||
|
else:
|
||||||
|
task["os"] = "linux"
|
||||||
|
count = count + 1
|
||||||
|
batch.merge_entity(task)
|
||||||
|
table_service.commit_batch(table_name, batch)
|
||||||
|
print("migrated %s rows" % count)
|
||||||
|
|
||||||
|
|
||||||
|
migrations: Dict[str, Callable[[TableService], None]] = {
|
||||||
|
"migrate_task_os": migrate_task_os
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
def migrate(table_service: TableService, migration_names: List[str]) -> None:
|
||||||
|
for name in migration_names:
|
||||||
|
print("applying migration '%s'" % name)
|
||||||
|
migrations[name](table_service)
|
||||||
|
print("migration '%s' applied" % name)
|
@ -14,9 +14,11 @@ import tempfile
|
|||||||
import uuid
|
import uuid
|
||||||
import zipfile
|
import zipfile
|
||||||
from datetime import datetime, timedelta
|
from datetime import datetime, timedelta
|
||||||
|
from data_migration import migrate
|
||||||
|
|
||||||
from azure.common.client_factory import get_client_from_cli_profile
|
from azure.common.client_factory import get_client_from_cli_profile
|
||||||
from azure.common.credentials import get_cli_profile
|
from azure.common.credentials import get_cli_profile
|
||||||
|
from azure.cosmosdb.table.tableservice import TableService
|
||||||
from azure.core.exceptions import ResourceExistsError
|
from azure.core.exceptions import ResourceExistsError
|
||||||
from azure.graphrbac import GraphRbacManagementClient
|
from azure.graphrbac import GraphRbacManagementClient
|
||||||
from azure.graphrbac.models import (
|
from azure.graphrbac.models import (
|
||||||
@ -98,6 +100,7 @@ class Client:
|
|||||||
arm_template,
|
arm_template,
|
||||||
workbook_data,
|
workbook_data,
|
||||||
create_registration,
|
create_registration,
|
||||||
|
migrations,
|
||||||
):
|
):
|
||||||
self.resource_group = resource_group
|
self.resource_group = resource_group
|
||||||
self.arm_template = arm_template
|
self.arm_template = arm_template
|
||||||
@ -117,6 +120,7 @@ class Client:
|
|||||||
"client_id": ONEFUZZ_CLI_APP,
|
"client_id": ONEFUZZ_CLI_APP,
|
||||||
"authority": ONEFUZZ_CLI_AUTHORITY,
|
"authority": ONEFUZZ_CLI_AUTHORITY,
|
||||||
}
|
}
|
||||||
|
self.migrations = migrations
|
||||||
|
|
||||||
if os.name == "nt":
|
if os.name == "nt":
|
||||||
self.azcopy = os.path.join(self.tools, "win64", "azcopy.exe")
|
self.azcopy = os.path.join(self.tools, "win64", "azcopy.exe")
|
||||||
@ -325,6 +329,13 @@ class Client:
|
|||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
self.results["deploy"] = result.properties.outputs
|
self.results["deploy"] = result.properties.outputs
|
||||||
|
|
||||||
|
def apply_migrations(self):
|
||||||
|
self.results["deploy"]["func-storage"]["value"]
|
||||||
|
name = self.results["deploy"]["func-name"]["value"]
|
||||||
|
key = self.results["deploy"]["func-key"]["value"]
|
||||||
|
table_service = TableService(account_name=name, account_key=key)
|
||||||
|
migrate(table_service, self.migrations)
|
||||||
|
|
||||||
def create_queues(self):
|
def create_queues(self):
|
||||||
logger.info("creating eventgrid destination queue")
|
logger.info("creating eventgrid destination queue")
|
||||||
|
|
||||||
@ -525,6 +536,7 @@ def main():
|
|||||||
("check_region", Client.check_region),
|
("check_region", Client.check_region),
|
||||||
("rbac", Client.setup_rbac),
|
("rbac", Client.setup_rbac),
|
||||||
("arm", Client.deploy_template),
|
("arm", Client.deploy_template),
|
||||||
|
("apply_migrations", Client.apply_migrations),
|
||||||
("queues", Client.create_queues),
|
("queues", Client.create_queues),
|
||||||
("eventgrid", Client.create_eventgrid),
|
("eventgrid", Client.create_eventgrid),
|
||||||
("tools", Client.upload_tools),
|
("tools", Client.upload_tools),
|
||||||
@ -592,6 +604,13 @@ def main():
|
|||||||
help="Create an application registration and/or generate a "
|
help="Create an application registration and/or generate a "
|
||||||
"password for the pool agent (default: False)",
|
"password for the pool agent (default: False)",
|
||||||
)
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
"--apply_migrations",
|
||||||
|
type=str,
|
||||||
|
nargs="+",
|
||||||
|
default=[],
|
||||||
|
help="list of migration to apply to the azure table",
|
||||||
|
)
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
|
|
||||||
if shutil.which("func") is None:
|
if shutil.which("func") is None:
|
||||||
@ -612,6 +631,7 @@ def main():
|
|||||||
args.arm_template,
|
args.arm_template,
|
||||||
args.workbook_data,
|
args.workbook_data,
|
||||||
args.create_pool_registration,
|
args.create_pool_registration,
|
||||||
|
args.apply_migrations,
|
||||||
)
|
)
|
||||||
if args.verbose:
|
if args.verbose:
|
||||||
level = logging.DEBUG
|
level = logging.DEBUG
|
||||||
|
Reference in New Issue
Block a user