-
Notifications
You must be signed in to change notification settings - Fork 112
Границы обращения к метаданным #1837
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
base: develop
Are you sure you want to change the base?
Changes from 12 commits
cd9ef8b
768ab7d
ea1e7dd
b17d97f
2bc45e1
f06515a
65557a8
fdad879
8912ca2
36f4e78
f05deaa
1248793
1379891
84e4d9d
7171d3f
239f1c0
5ce7014
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
# Границы метаданных (MetadataBorders) | ||
|
||
| Тип | Поддерживаются<br>языки | Важность | Включена<br>по умолчанию | Время на<br>исправление (мин) | Теги | | ||
|:-------------:|:-----------------------------:|:----------------:|:------------------------------:|:-----------------------------------:|:-------:| | ||
| `Дефект кода` | `BSL`<br>`OS` | `Информационный` | `Нет` | `1` | `error` | | ||
|
||
## Параметры | ||
|
||
|
||
| Имя | Тип | Описание | Значение<br>по умолчанию | | ||
|:---------------------------:|:--------:|:-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------:|:------------------------------:| | ||
| `metadataBordersParameters` | `Строка` | `JSON-структура для пар "регулярное выражение для операторов":"регулярное выражение для имени модуля". Например, "Регистры?Сведений.КонтактнаяИнформация:ОбщийМодуль.РаботаСКонтактами".` | `` | | ||
<!-- Блоки выше заполняются автоматически, не трогать --> | ||
## Описание диагностики | ||
Диагностика обращения к метаданным за пределами разрешенных границ. | ||
Нужна, если, например, в компании установлены правила обращения | ||
к каким-то метаданным только из определенного общего модуля. | ||
|
||
## Примеры | ||
Например, получение контактной информации по внутренним правилам должно происходить | ||
только через функции общего модуля РаботаСКонтактами. | ||
Golovanoff marked this conversation as resolved.
Show resolved
Hide resolved
|
||
Тогда заданные настройки вида | ||
|
||
```{"Регистры?Сведений.КонтактнаяИнформация":"CommonModules/РаботаСКонтактами"}``` | ||
Golovanoff marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
вызовут срабатывание диагностики на запросе с текстом | ||
|
||
``` | ||
"ВЫБРАТЬ | ||
... | ||
ИЗ | ||
РегистрСведений.КонтактнаяИнформация КАК КИ" | ||
``` | ||
|
||
если этот запрос будет не в общем модуле РаботаСКонтактами. | ||
|
||
Так же эта диагностика с такой настройкой сработает и на оператор | ||
|
||
```НаборЗаписей = РегистрыСведений.ИспользованиеКонтактов.СоздатьНаборЗаписей();``` | ||
Golovanoff marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
В настройках обе части - это регулярные выражения java. | ||
Вторая часть настройки сравнивается с путем к файлу выгрузки конфигурации. | ||
|
||
Можно запретить использование нескольких метаданных: | ||
|
||
```{"Регистры?Сведений.КонтактнаяИнформация|Справочники?.Контакты":"CommonModules/РаботаСКонтактами"}``` | ||
|
||
Настройки задаются в виде json-строки: | ||
``` | ||
Golovanoff marked this conversation as resolved.
Show resolved
Hide resolved
|
||
{ | ||
"Регистры?Сведений.КонтактнаяИнформация":"CommonModules/РаботаСКонтактами", | ||
"Справочники?.СтрокиСоединения":"DataProcessors/ВнешниеСоединения|CommonModules/ПодключениеК*" | ||
Golovanoff marked this conversation as resolved.
Show resolved
Hide resolved
|
||
} | ||
``` | ||
|
||
|
||
## Источники | ||
|
||
## Сниппеты | ||
|
||
<!-- Блоки ниже заполняются автоматически, не трогать --> | ||
### Экранирование кода | ||
|
||
```bsl | ||
// BSLLS:MetadataBorders-off | ||
// BSLLS:MetadataBorders-on | ||
``` | ||
|
||
### Параметр конфигурационного файла | ||
|
||
```json | ||
"MetadataBorders": { | ||
"metadataBordersParameters": "" | ||
} | ||
``` |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
# Metadata borders (MetadataBorders) | ||
|
||
| Type | Scope | Severity | Activated<br>by default | Minutes<br>to fix | Tags | | ||
|:------------:|:-------------------:|:--------:|:-----------------------------:|:-----------------------:|:-------:| | ||
| `Code smell` | `BSL`<br>`OS` | `Info` | `No` | `1` | `error` | | ||
|
||
## Parameters | ||
|
||
|
||
| Name | Type | Description | Default value | | ||
|:---------------------------:|:--------:|:-------------------------------------------------------------------------------------------------------------------------------------------------:|:-------------:| | ||
| `metadataBordersParameters` | `String` | `JSON-structure for pairs "regex for statements":"regex for module names". Etc "InformationRegisters?.RegisterName:CommonModules/SpecialModule".` | `` | | ||
<!-- Блоки выше заполняются автоматически, не трогать --> | ||
## Description | ||
<!-- Описание диагностики заполняется вручную. Необходимо понятным языком описать смысл и схему работу --> | ||
|
||
## Examples | ||
<!-- В данном разделе приводятся примеры, на которые диагностика срабатывает, а также можно привести пример, как можно исправить ситуацию --> | ||
|
||
## Sources | ||
<!-- Необходимо указывать ссылки на все источники, из которых почерпнута информация для создания диагностики --> | ||
<!-- Примеры источников | ||
|
||
* Источник: [Стандарт: Тексты модулей](https://its.1c.ru/db/v8std#content:456:hdoc) | ||
* Полезная информация: [Отказ от использования модальных окон](https://its.1c.ru/db/metod8dev#content:5272:hdoc) | ||
* Источник: [Cognitive complexity, ver. 1.4](https://www.sonarsource.com/docs/CognitiveComplexity.pdf) --> | ||
|
||
## Snippets | ||
|
||
<!-- Блоки ниже заполняются автоматически, не трогать --> | ||
### Diagnostic ignorance in code | ||
|
||
```bsl | ||
// BSLLS:MetadataBorders-off | ||
// BSLLS:MetadataBorders-on | ||
``` | ||
|
||
### Parameter for config | ||
|
||
```json | ||
"MetadataBorders": { | ||
"metadataBordersParameters": "" | ||
} | ||
``` |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,93 @@ | ||
/* | ||
* This file is a part of BSL Language Server. | ||
* | ||
* Copyright (c) 2018-2021 | ||
* Alexey Sosnoviy <labotamy@gmail.com>, Nikita Gryzlov <nixel2007@gmail.com> and contributors | ||
* | ||
* SPDX-License-Identifier: LGPL-3.0-or-later | ||
* | ||
* BSL Language Server is free software; you can redistribute it and/or | ||
* modify it under the terms of the GNU Lesser General Public | ||
* License as published by the Free Software Foundation; either | ||
* version 3.0 of the License, or (at your option) any later version. | ||
* | ||
* BSL Language Server is distributed in the hope that it will be useful, | ||
* but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
* Lesser General Public License for more details. | ||
* | ||
* You should have received a copy of the GNU Lesser General Public | ||
* License along with BSL Language Server. | ||
*/ | ||
package com.github._1c_syntax.bsl.languageserver.diagnostics; | ||
|
||
import com.fasterxml.jackson.core.JsonProcessingException; | ||
import com.fasterxml.jackson.databind.ObjectMapper; | ||
import com.fasterxml.jackson.databind.type.MapType; | ||
import com.github._1c_syntax.bsl.languageserver.diagnostics.metadata.*; | ||
import com.github._1c_syntax.bsl.parser.*; | ||
import com.github._1c_syntax.utils.*; | ||
import org.antlr.v4.runtime.tree.*; | ||
|
||
import java.util.*; | ||
import java.util.regex.*; | ||
Golovanoff marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
@DiagnosticMetadata( | ||
type = DiagnosticType.CODE_SMELL, | ||
severity = DiagnosticSeverity.INFO, | ||
minutesToFix = 1, | ||
activatedByDefault = false, | ||
tags = { | ||
DiagnosticTag.ERROR | ||
Golovanoff marked this conversation as resolved.
Show resolved
Hide resolved
|
||
} | ||
|
||
) | ||
public class MetadataBordersDiagnostic extends AbstractVisitorDiagnostic { | ||
|
||
private static final String METADATA_BORDERS_DEFAULT = ""; | ||
nixel2007 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
@DiagnosticParameter( | ||
type = String.class, | ||
defaultValue = "" | ||
) | ||
private HashMap<String, String> metadataBordersParameters = MapFromJSON(METADATA_BORDERS_DEFAULT); | ||
Golovanoff marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
private static HashMap<String, String> MapFromJSON(String userSettings) { | ||
ObjectMapper mapper = new ObjectMapper(); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. создание ObjectMapper на каждый configure - довольно дорогая операция. лучше его закэшировать или просто указать его конструкторе - его туда подложит спринг. |
||
MapType mapType = mapper.getTypeFactory().constructMapType(HashMap.class, String.class, String.class); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. mapType тоже можно закэшировать в конструторе по принятому инстансу обджект-маппера |
||
try { | ||
return mapper.readValue(userSettings, mapType); | ||
} catch (JsonProcessingException e) { | ||
return new HashMap<>(); | ||
Golovanoff marked this conversation as resolved.
Show resolved
Hide resolved
|
||
} | ||
} | ||
|
||
@Override | ||
public void configure(Map<String, Object> configuration) { | ||
this.metadataBordersParameters = MapFromJSON( | ||
(String) configuration.getOrDefault("metadataBordersParameters", METADATA_BORDERS_DEFAULT)); | ||
} | ||
|
||
@Override | ||
public ParseTree visitStatement(BSLParser.StatementContext ctx){ | ||
|
||
for (Map.Entry<String, String> entry: metadataBordersParameters.entrySet()) { | ||
|
||
if (entry.getKey().isBlank() || entry.getValue().isBlank()) { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. это условие нужно проверять на этапе configure и создавать мапу без неверных значений |
||
continue; | ||
} | ||
|
||
Matcher matcher = CaseInsensitivePattern.compile(entry.getKey()) | ||
Golovanoff marked this conversation as resolved.
Show resolved
Hide resolved
|
||
.matcher(ctx.getText()); | ||
|
||
boolean insideBorders = CaseInsensitivePattern.compile(entry.getValue()) | ||
Golovanoff marked this conversation as resolved.
Show resolved
Hide resolved
|
||
.matcher(this.documentContext.getUri().getPath()) | ||
.find(); | ||
|
||
while (matcher.find() && ! insideBorders) { | ||
Golovanoff marked this conversation as resolved.
Show resolved
Hide resolved
|
||
diagnosticStorage.addDiagnostic(ctx); | ||
} | ||
} | ||
return super.visitStatement(ctx); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. если ты проверяешь текст statement целиком, то нет смысла дергать super, т.к. вложенные стэйтменты проверят тот же самый кусок текста. т.е. здесь будет фонить на вложенных конструкциях вида Если Истина Тогда
Если Истина Тогда
ЗапрещенныйВызов(); // тут кинет два срабатывания на одно и то же место
КонецЕсли;
КонецЕсли; |
||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
diagnosticMessage=Use metadata outside the borders | ||
diagnosticName=Metadata borders | ||
metadataBordersParameters=JSON-structure for pairs "regex for statements":"regex for module names". Etc "InformationRegisters?.RegisterName:CommonModules/SpecialModule". | ||
Golovanoff marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
diagnosticMessage=Обращение к метаданным за пределами разрешенных границ | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. может быть в сообщение стоит добавить регулярку/пару регулярок, на которой произошло срабатывание? |
||
diagnosticName=Границы метаданных | ||
metadataBordersParameters=JSON-структура для пар "регулярное выражение для операторов":"регулярное выражение для имени модуля". Например, "Регистры?Сведений.КонтактнаяИнформация:ОбщийМодуль.РаботаСКонтактами". | ||
Golovanoff marked this conversation as resolved.
Show resolved
Hide resolved
|
Uh oh!
There was an error while loading. Please reload this page.