26 lines
1.0 KiB
C#
26 lines
1.0 KiB
C#
using Microsoft.SqlServer.TransactSql.ScriptDom;
|
|
using SQLLinter.Common;
|
|
using SQLLinter.Common.Helpers;
|
|
|
|
namespace SQLLinter.Infrastructure.Rules;
|
|
|
|
public class CreateProcedureInDboRule : BaseRuleVisitor
|
|
{
|
|
public override string Text => "Запрещено создание процедур в схеме dbo: {0}";
|
|
|
|
public override void Visit(CreateProcedureStatement node)
|
|
{
|
|
if (node.ProcedureReference.Name.SchemaIdentifier?.Value.Equals("dbo", StringComparison.OrdinalIgnoreCase) == true)
|
|
{
|
|
AddViolation(node.ProcedureReference.Name.SchemaIdentifier, SQLHelpers.ObjectGetFullName(node.ProcedureReference.Name));
|
|
}
|
|
}
|
|
public override void Visit(CreateOrAlterProcedureStatement node)
|
|
{
|
|
if (node.ProcedureReference.Name.SchemaIdentifier?.Value.Equals("dbo", StringComparison.OrdinalIgnoreCase) == true)
|
|
{
|
|
AddViolation(node.ProcedureReference.Name.SchemaIdentifier, SQLHelpers.ObjectGetFullName(node.ProcedureReference.Name));
|
|
}
|
|
}
|
|
}
|