Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Web apps snapshot commands #145

Merged
merged 5 commits into from
Apr 27, 2018
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 4 additions & 4 deletions src/index.json
Original file line number Diff line number Diff line change
Expand Up @@ -281,9 +281,9 @@
],
"webapp": [
{
"filename": "webapp-0.2.1-py2.py3-none-any.whl",
"sha256Digest": "fe3b28cc9cb2272a36c395ed6279b2a9f925b16877962bf2448a3fa56819bfa4",
"downloadUrl": "https://github.com/panchagnula/azure-cli-extensions/raw/sisirap-extensions-whl/dist/webapp-0.2.1-py2.py3-none-any.whl",
"filename": "webapp-0.2.2-py2.py3-none-any.whl",
"sha256Digest": "1787bea76770e13d72d6a0d29fd5af50788051ca12ca64f010ee6fa7657fe5df",
"downloadUrl": "https://github.com/panchagnula/azure-cli-extensions/raw/sisirap-extensions-whl/dist/webapp-0.2.2-py2.py3-none-any.whl",
"metadata": {
"azext.isPreview": true,
"azext.minCliCoreVersion": "2.0.24",
Expand Down Expand Up @@ -322,7 +322,7 @@
"metadata_version": "2.0",
"name": "webapp",
"summary": "An Azure CLI Extension to manage appservice resources",
"version": "0.2.1"
"version": "0.2.2"
}
}
],
Expand Down
15 changes: 15 additions & 0 deletions src/webapp/azext_webapp/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,8 @@ def __init__(self, cli_ctx=None):
def load_command_table(self, _):
with self.command_group('webapp') as g:
g.custom_command('up', 'create_deploy_webapp')
g.custom_command('config snapshot list', 'list_webapp_snapshots')
g.custom_command('config snapshot restore', 'restore_webapp_snapshot')
return self.command_table

def load_arguments(self, _):
Expand All @@ -31,6 +33,19 @@ def load_arguments(self, _):
c.argument('dryrun',
help="shows summary of the create and deploy operation instead of executing it",
default=False, action='store_true')
with self.argument_context('webapp config snapshot list') as c:
c.argument('resource_group', options_list=['--resource-group', '-g'], help='Name of resource group.')
c.argument('name', options_list=['--webapp-name', '-n'], help='Name of the webapp.')
c.argument('slot', options_list=['--slot', '-s'], help='Name of the webapp slot.')
with self.argument_context('webapp config snapshot restore') as c:
c.argument('resource_group', options_list=['--resource-group', '-g'], help='Name of resource group to restore to.')
c.argument('name', options_list=['--webapp-name', '-n'], help='Name of the webapp to restore to.')
c.argument('time', options_list=['--time', '-t'], help='Timestamp of the snapshot to restore.')
c.argument('slot', options_list=['--slot', '-s'], help='Name of the webapp slot to restore to.')
c.argument('restore_config', options_list=['--restore-config'], help='Restore the previous configuration along with web app content.')
c.argument('source_resource_group', options_list=['--source-resource-group'], help='Name of the resource group to retrieve snapshot from.')
c.argument('source_name', options_list=['--source-webapp-name'], help='Name of the webapp to retrieve snapshot from.')
c.argument('source_slot', options_list=['--source-slot'], help='Name of the webapp slot to retrieve snapshot from.')


COMMAND_LOADER_CLS = WebappExtCommandLoader
23 changes: 23 additions & 0 deletions src/webapp/azext_webapp/_help.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,3 +16,26 @@
az webapp up -n MyUniqueAppName --dryrun \n
az webapp up -n MyUniqueAppName -l locationName
"""

helps['webapp config snapshot list'] = """
type: command
short-summary: List the snapshots available for a web app.
Snapshots are automatically managed backups of web app content and configuration.
examples:
- name: List the snapshots available for a web app named MyApp.
text: >
az webapp config snapshot list -g Default-Web-WestUS -n MyApp
"""

helps['webapp config snapshot restore'] = """
type: command
short-summary: Restore a snapshot to a web app.
A snapshot from a different web app or slot can be restored by specifying the source.
examples:
- name: Overwrite a web app with its own snapshot.
text: >
az webapp config snapshot restore -g Default-Web-WestUS -n MyApp -t 2018-04-25T00:09:20.8736381Z
- name: Overwrite a web app's staging slot with a snapshot from its production slot.
text: >
az webapp config snapshot restore -g Default-Web-WestUS -n MyApp -s staging -t 2018-04-25T00:09:20.8736381Z --source-resource-group Default-Web-WestUS --source-name MyApp --restore-config
"""
37 changes: 36 additions & 1 deletion src/webapp/azext_webapp/custom.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,11 @@

from __future__ import print_function
from knack.log import get_logger
from knack.util import CLIError

from azure.mgmt.web.models import (AppServicePlan, SkuDescription)
from azure.mgmt.web.models import (AppServicePlan, SkuDescription, SnapshotRecoveryRequest, SnapshotRecoveryTarget)

from azure.cli.core.commands.client_factory import get_subscription_id

from azure.cli.command_modules.appservice.custom import (
enable_zip_deploy,
Expand Down Expand Up @@ -178,3 +181,35 @@ def create_deploy_webapp(cmd, name, location=None, dryrun=False):
create_json.update({'app_url': url})
logger.warning("All done.")
return create_json


def list_webapp_snapshots(cmd, resource_group, name, slot=None):
client = web_client_factory(cmd.cli_ctx)
if slot is None:
return client.web_apps.list_snapshots(resource_group, name)
else:
return client.web_apps.list_snapshots_slot(resource_group, name, slot)


def restore_webapp_snapshot(cmd, resource_group, name, time, slot=None, restore_config=False, source_resource_group=None, source_name=None, source_slot=None):
client = web_client_factory(cmd.cli_ctx)

if all([source_resource_group, source_name]):
sub_id = get_subscription_id(cmd.cli_ctx)
target_id = "/subscriptions/" + sub_id + "/resourceGroups/" + resource_group + "/providers/Microsoft.Web/sites/" + name
if slot:
target_id = target_id + "/slots/" + slot
target = SnapshotRecoveryTarget(id=target_id)
request = SnapshotRecoveryRequest(False, snapshot_time=time, recovery_target=target, recover_configuration=restore_config)
if source_slot:
return client.web_apps.recover_slot(source_resource_group, source_name, request, source_slot)
else:
return client.web_apps.recover(source_resource_group, source_name, request)
elif any([source_resource_group, source_name]):
raise CLIError('usage error: source-resource_group and source-name must both be specified if one is used')
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The proper param names are --source-resource-group and --source-name.
It's not clear what source-resource_group and source-name refer to.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks, that was a typo. I've updated these

else:
request = SnapshotRecoveryRequest(True, snapshot_time=time, recover_configuration=restore_config)
if slot:
return client.web_apps.recover_slot(resource_group, name, request, slot)
else:
return client.web_apps.recover(resource_group, name, request)
2 changes: 1 addition & 1 deletion src/webapp/setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
from codecs import open
from setuptools import setup, find_packages

VERSION = "0.2.1"
VERSION = "0.2.2"

CLASSIFIERS = [
'Development Status :: 4 - Beta',
Expand Down