mirror of
https://github.com/apache/superset.git
synced 2026-04-19 08:04:53 +00:00
refactor(sqllab): migrate share queries via kv by permalink (#29163)
This commit is contained in:
16
superset/commands/sql_lab/permalink/__init__.py
Normal file
16
superset/commands/sql_lab/permalink/__init__.py
Normal file
@@ -0,0 +1,16 @@
|
||||
# Licensed to the Apache Software Foundation (ASF) under one
|
||||
# or more contributor license agreements. See the NOTICE file
|
||||
# distributed with this work for additional information
|
||||
# regarding copyright ownership. The ASF licenses this file
|
||||
# to you under the Apache License, Version 2.0 (the
|
||||
# "License"); you may not use this file except in compliance
|
||||
# with the License. You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing,
|
||||
# software distributed under the License is distributed on an
|
||||
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
# KIND, either express or implied. See the License for the
|
||||
# specific language governing permissions and limitations
|
||||
# under the License.
|
||||
35
superset/commands/sql_lab/permalink/base.py
Normal file
35
superset/commands/sql_lab/permalink/base.py
Normal file
@@ -0,0 +1,35 @@
|
||||
# Licensed to the Apache Software Foundation (ASF) under one
|
||||
# or more contributor license agreements. See the NOTICE file
|
||||
# distributed with this work for additional information
|
||||
# regarding copyright ownership. The ASF licenses this file
|
||||
# to you under the Apache License, Version 2.0 (the
|
||||
# "License"); you may not use this file except in compliance
|
||||
# with the License. You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing,
|
||||
# software distributed under the License is distributed on an
|
||||
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
# KIND, either express or implied. See the License for the
|
||||
# specific language governing permissions and limitations
|
||||
# under the License.
|
||||
from abc import ABC
|
||||
|
||||
from superset.commands.base import BaseCommand
|
||||
from superset.key_value.shared_entries import get_permalink_salt
|
||||
from superset.key_value.types import (
|
||||
KeyValueResource,
|
||||
MarshmallowKeyValueCodec,
|
||||
SharedKey,
|
||||
)
|
||||
from superset.sqllab.permalink.schemas import SqlLabPermalinkSchema
|
||||
|
||||
|
||||
class BaseSqlLabPermalinkCommand(BaseCommand, ABC):
|
||||
resource: KeyValueResource = KeyValueResource.SQLLAB_PERMALINK
|
||||
codec = MarshmallowKeyValueCodec(SqlLabPermalinkSchema())
|
||||
|
||||
@property
|
||||
def salt(self) -> str:
|
||||
return get_permalink_salt(SharedKey.SQLLAB_PERMALINK_SALT)
|
||||
49
superset/commands/sql_lab/permalink/create.py
Normal file
49
superset/commands/sql_lab/permalink/create.py
Normal file
@@ -0,0 +1,49 @@
|
||||
# Licensed to the Apache Software Foundation (ASF) under one
|
||||
# or more contributor license agreements. See the NOTICE file
|
||||
# distributed with this work for additional information
|
||||
# regarding copyright ownership. The ASF licenses this file
|
||||
# to you under the Apache License, Version 2.0 (the
|
||||
# "License"); you may not use this file except in compliance
|
||||
# with the License. You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing,
|
||||
# software distributed under the License is distributed on an
|
||||
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
# KIND, either express or implied. See the License for the
|
||||
# specific language governing permissions and limitations
|
||||
# under the License.
|
||||
import logging
|
||||
from typing import Any
|
||||
|
||||
from superset import db
|
||||
from superset.commands.sql_lab.permalink.base import BaseSqlLabPermalinkCommand
|
||||
from superset.daos.key_value import KeyValueDAO
|
||||
from superset.key_value.exceptions import KeyValueCodecEncodeException
|
||||
from superset.key_value.utils import encode_permalink_key
|
||||
from superset.sqllab.permalink.exceptions import SqlLabPermalinkCreateFailedError
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class CreateSqlLabPermalinkCommand(BaseSqlLabPermalinkCommand):
|
||||
def __init__(self, state: dict[str, Any]):
|
||||
self._properties = state.copy()
|
||||
|
||||
def run(self) -> str:
|
||||
self.validate()
|
||||
try:
|
||||
entry = KeyValueDAO.create_entry(
|
||||
self.resource, self._properties, self.codec
|
||||
)
|
||||
db.session.flush()
|
||||
key = entry.id
|
||||
if key is None:
|
||||
raise SqlLabPermalinkCreateFailedError("Unexpected missing key id")
|
||||
return encode_permalink_key(key=key, salt=self.salt)
|
||||
except KeyValueCodecEncodeException as ex:
|
||||
raise SqlLabPermalinkCreateFailedError(str(ex)) from ex
|
||||
|
||||
def validate(self) -> None:
|
||||
pass
|
||||
71
superset/commands/sql_lab/permalink/get.py
Normal file
71
superset/commands/sql_lab/permalink/get.py
Normal file
@@ -0,0 +1,71 @@
|
||||
# Licensed to the Apache Software Foundation (ASF) under one
|
||||
# or more contributor license agreements. See the NOTICE file
|
||||
# distributed with this work for additional information
|
||||
# regarding copyright ownership. The ASF licenses this file
|
||||
# to you under the Apache License, Version 2.0 (the
|
||||
# "License"); you may not use this file except in compliance
|
||||
# with the License. You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing,
|
||||
# software distributed under the License is distributed on an
|
||||
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
# KIND, either express or implied. See the License for the
|
||||
# specific language governing permissions and limitations
|
||||
# under the License.
|
||||
import logging
|
||||
from typing import Optional
|
||||
|
||||
from superset import db
|
||||
from superset.commands.dataset.exceptions import DatasetNotFoundError
|
||||
from superset.commands.sql_lab.permalink.base import BaseSqlLabPermalinkCommand
|
||||
from superset.daos.key_value import KeyValueDAO
|
||||
from superset.key_value.exceptions import (
|
||||
KeyValueCodecDecodeException,
|
||||
KeyValueGetFailedError,
|
||||
KeyValueParseKeyError,
|
||||
)
|
||||
from superset.key_value.utils import decode_permalink_id
|
||||
from superset.models import core as models
|
||||
from superset.sqllab.permalink.exceptions import SqlLabPermalinkGetFailedError
|
||||
from superset.sqllab.permalink.types import SqlLabPermalinkValue
|
||||
from superset.utils import core as utils, json
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class GetSqlLabPermalinkCommand(BaseSqlLabPermalinkCommand):
|
||||
def __init__(self, key: str):
|
||||
self.key = key
|
||||
|
||||
def run(self) -> Optional[SqlLabPermalinkValue]:
|
||||
self.validate()
|
||||
if self.key.startswith("kv:"):
|
||||
id = int(self.key[3])
|
||||
try:
|
||||
kv = db.session.query(models.KeyValue).filter_by(id=id).scalar()
|
||||
if not kv:
|
||||
return None
|
||||
return json.loads(kv.value)
|
||||
except Exception as ex:
|
||||
raise SqlLabPermalinkGetFailedError(
|
||||
message=utils.error_msg_from_exception(ex)
|
||||
) from ex
|
||||
|
||||
try:
|
||||
key = decode_permalink_id(self.key, salt=self.salt)
|
||||
value = KeyValueDAO.get_value(self.resource, key, self.codec)
|
||||
if value:
|
||||
return value
|
||||
return None
|
||||
except (
|
||||
DatasetNotFoundError,
|
||||
KeyValueCodecDecodeException,
|
||||
KeyValueGetFailedError,
|
||||
KeyValueParseKeyError,
|
||||
) as ex:
|
||||
raise SqlLabPermalinkGetFailedError(message=ex.message) from ex
|
||||
|
||||
def validate(self) -> None:
|
||||
pass
|
||||
Reference in New Issue
Block a user