permit (extended)

Команда  permit (extended) используется для редактирования расширенных списков доступа. Эта команда разрешает трафик, соответствующий условиям, заданным в команде. Для отмены разрешающей записи в расширенном списке доступа используется та же команда с префиксом  no.

 

Синтаксис          permit protocol source source-wildcard [operator port [port]] destination destination-wildcard [operator port [port]] [established] flag-name | {match-any | match-all} {+ | -}flag-name] [log | log-input] [time-range time-range-name]

                   no permit protocol source source-wildcard [operator port [port]] destination destination-wildcard [operator port [port]] [established] flag-name |{match-any | match-all} {+ | -}flag-name] [log | log-input] [time-range time-range-name] 

protocol                       Протокол. Задается в виде номера протокола. Протоколы IP, TCP, UDP, AH, ESP, ICMP, EIGRP, GRE, IGMP, IPINIP, NOS, OSPF, PCP, PIM могут быть заданы аббревиатурой ip, tcp, udp, ahp, esp, icmp, eigrp, gre, igmp, ipinip, nos, ospf, pcp, pim. Соответствие названия протокола и его номера приведено в Таблица 13.

source                            Этот параметр описывает отправителя пакета.

                                         Возможны три варианта описания:

                            ·       явное указание IP-адреса в формате четырех десятичных значений, разделенных точками;

                            ·       использование ключевого слова any, обозначающего пару значений 0.0.0.0 255.255.255.255 для параметров source и source-wildcard;

                            ·       использование ключевого слова host перед значением source, что предполагает значение 0.0.0.0 для параметра source-wildcard.

Замечание 1:                 Использование значения any в IPsec фильтрах может привести к созданию большого количества SA. Отдельный SA будет строиться для трафика до каждого хоста сети.  

source-wildcard     инвертированная маска подсети отправителя (получателя) пакета.  Описан в разделе  "Permit (standard)". Используется в списках доступа для того, чтобы определить: соответствует ли IP-адрес в заголовке пакета IP-адресу в записях списка доступа.

operator                       Описывает условие сравнения, применяемое к портам источника и получателя. Используются операторы eq (equal, равно) и range (диапазон). Иные операторы не допускаются. Необязательный параметр.

port                                Только для протоколов TCP или UDP можно указывать порт или диапазон портов. Целое число из диапазона от 0 до 65535. Используется только в связке с параметром  operator. При использовании operator=range после него следуют два числа (лежащих в диапазоне от 0 до 65535), определяющие границы диапазона портов. Перечисление портов не допускается. Необязательный параметр. Поддерживаемые имена портов протоколов TCP и UDP приведены в Таблица 14 и Таблица 15.

Замечание 2:                  Если задать два одинаковых порта, например,

                                          permit udp any range non500-isakmp 4500 any,

                                          то это будет эквивалентно оператору eq.

Замечание 3:                  Если задать сначала порт с большим номером, то порты в диапазоне автоматически поменяются местами.

destination                  Этот параметр описывает получателя пакета.

                                         Возможны три варианта описания:

                            ·       явное указание IP-адреса в формате четырех десятичных значений, разделенных точками;

                            ·       использование ключевого слова any, обозначающего пару значений 0.0.0.0 255.255.255.255 для параметров destination и destination-wildcard (см. Замечание 1);

                            ·       использование ключевого слова host перед значением destination, что предполагает значение 0.0.0.0 для параметра destination-wildcard.

destination-wildcard                  инвертированная маска подсети получателя пакета. Аналогичен source- wildcard, который описан в разделе "Permit (standard)".

Замечание 4:                  Для указания TCP-флагов используется старый или новый формат. Старый формат используется в нумерованных и именованных расширенных списках доступа, и представляет собой комбинацию ключевого слова established и перечисления TCP-флагов – flag-name.

                                         Новый формат используется только в именованных расширенных списках доступа, и представляет собой комбинацию ключевого слова match-any|match-all и и перечисления TCP-флагов – {+|-}flag-name.

established                 Только для протокола TCP. Состояние соединения. Выделяются только установленные TCP-соединения и по ним могут передаваться данные.

flag-name                     Имена TCP-флагов – fin, syn, rst, psh, ack, urg. Порядок флагов при вводе не важен. Перечисление флагов работает как «ИЛИ» (аналог match-any в новом формате). Ключевое слово established эквивалентно флагам rst  ack и не может с ними сочетаться (синтаксическая ошибка).

Замечание 5:                  В пределах одной команды permit/deny старый формат указания TCP-флагов не может сочетаться с новым.

match-any|match-all  Только для протокола TCP и именованных списков доступа. Указывает условие сравнения TCP-флагов в пакете и правиле.

                                         Ключевое слово match-any означает, что должно выполняться одно из указанных далее условий по TCP-флагам. Ключевое слово match-all означает, что должны выполняться все заданные условия по TCP-флагам.

                                         Если попытаться использовать эти ключевые слова для нумерованного списка доступа, то будет выдано сообщение об ошибке: %match-all/match-any are allowed on named ACLs only

{+|-}flag-name           Имена TCP-флагов – fin, syn, rst, psh, ack, urg. Префикс “+” перед флагом означает, что этот флаг должен быть выставлен в заголовке пакета, а префикс “–“ означает, что этот флаг не должен быть выставлен в заголовке пакета. Порядок флагов при вводе не важен.

log|log-input             Флаг log или log-input задает ведение журнала. Оба флага задают одну и ту же функциональность (отличие от Cisco IOS). В Syslog выдаются сообщения о пакетах, удовлетворяющих условиям данного списка доступа. В сообщении указан номер списка доступа, разрешено или запрещено прохождение пакета, адрес отправителя и количество пакетов. Сообщение формируется для первого совпавшего пакета, а затем с периодичностью в 5 минут выдается сообщение о количестве пропущенных или запрещенных пакетов за этот интервал времени.

                    Флаги логирования могут смешиваться с другими флагами, например с TCP-флагами. Два флага логирования log и log-input не могут применяться вместе в одной команде permit/deny.

time-range time-range-name      Ссылка на расписание. В расписании указывается диапазон времени, в который будет работать данный список доступа. В другой период времени данный фильтр действовать не будет.

                    Ссылка на расписание может смешиваться с другими дополнительными параметрами, например с TCP-флагами.

                    Допускается ссылка на расписание, отсутствующее в конфигурации на момент ввода команды. Однако на момент конвертирования расписание должно существовать, в противном случае конвертирование будет прервано с сообщением об ошибке.

 

Режимы команды                               config-ext-nacl (режим редактирования расширенных списков доступа)

 

Рекомендации по использованию

Используйте эту команду после входа в режим редактирования расширенного списка доступа для задания условий доступа, разрешающих трафик.

 

Нумерация записей в списке 

Перед командой permit или deny допускается вводить порядковый номер записи в списке, который можно использовать для упрощения редактирования записей, например,

ip access-list extended acl2

 10 permit udp any any

 20 permit tcp any any

 30 deny udp host 10.1.1.1 eq snmp any

 

В режиме редактирования списка доступа запись с указанным номером будет вставлена на нужную позицию, например,

15 permit  udp 10.1.1.1 0.0.255.255 host 10.2.2.2

Если запись с таким номером существует, то будет выдано сообщение об ошибке: % Duplicate sequence number.

По умолчанию первой записи в списке присваивается номер 10, а следующие номера в списке следуют с приращением 10. Максимальный порядковый номер 2147483647. Если сгенерированный порядковый номер превысил максимальный, то выдается сообщение об ошибке: % Exceeded maximum sequence number.

При выходе из консоли нумерация записей теряется. При следующем старте консоли записи располагаются в порядке возрастания номеров в режиме по умолчанию.

 

Просмотр по команде show  running-config 

По команде show  running-config нумерованные списки доступа показываются в виде последовательности команд access-list  за одним исключением:

если после редактирования нумерованного списка доступа он становится пустым (в нем нет записей вида permit или deny (no permit, no deny)), то он будет показан в виде:

ip access-list {standard|extended} name

По команде show  running-config выводится конфигурация, в которой слово host может отсутствовать.

Так как по команде show  running-config ранее введенные номера записей в списке не показываются, то при редактировании, чтобы внести запись на нужную позицию, можно еще раз упорядочить записи в списке с заданным начальным номером и приращением. Для этого используется команда: ip access-list resequence.

По команде show  running-config флаги fin, syn, rst, psh, ack, urg будут указаны в этом порядке. А сочетание флагов «rst  ack» в команде будет заменено на established при выводе.

Флаги логирования log, log-input показываются после TCP-флагов, а расписание (time-range) – после флагов логирования. 

Удаление 

Удаление записи в списке доступа осуществляется:

·       командой no <полная запись>, например:
no permit tcp host 10.1.1.1 eq telnet any

·       или по номеру записи, например: no 15.

 

Отличие данной команды от подобной команды Cisco  IOS: 

·      В инвертированной маске подсети source-wildcard и destination-wildcard должна быть непрерывная линейка из установленных битов в конце, не допускается чередование 0 и 1.

·      Отсутствует возможность задавать отдельные ICMP-type и ICMP-code, только ICMP протокол целиком.

·      Не допускается использование hostname в качестве source и destination.

·      Не допускаются операторы кроме eq и range.

·      Пустой нумерованный список по команде show running-config показывается в виде ip access-list name. В Cisco IOS данный список вообще не показывается.

 

Имя и номер протокола 

Таблица 13

Имя протокола

Описание протокола

Номер протокола

ip

Any Internet Protocol

 

tcp

Transmission Control Protocol

6

udp

User Datagram Protocol

17

ahp

Authentication Header Protocol

51

icmp

Internet Control Message Protocol

1

esp

Encapsulation Security Payload

50

eigrp

Cisco's EIGRP routing protocol

88

gre

Cisco's GRE tunneling

47

igmp

Internet Gateway Message Protocol

2

ipinip

IP in IP tunneling

4

nos

KA9Q NOS compatible IP over IP tunneling

94

ospf

OSPF routing protocol

89

pcp

Payload Compression Protocol

108

pim

Protocol Independent Multicast

103

 

Поддерживаемые имена портов протокола TCP 

Таблица 14

Имя протокола

Описание протокола

Номер порта

bgp

Border Gateway Protocol

179

chargen

Character generator

19

cmd

Remote commands (rcmd)

514

daytime

Daytime

13

discard

Discard

9

domain

Domain Name Service

53

drip

Dynamic Routing Information Protocol

3949

echo

Echo

7

exec

Exec (rsh)

512

finger

Finger

79

ftp

File Transfer Protocol

21

ftp-data

FTP data connections

20

gopher

Gopher

70

hostname

NIC hostname server

101

ident

Ident Protocol

113

irc

Internet Relay Chat

194

klogin

Kerberos login

543

kshell

Kerberos shell

544

login

Login (rlogin)

513

lpd

Printer service

515

nntp

Network News Transport Protocol

119

pim-auto-rp

PIM Auto-RP

496

pop2

Post Office Protocol v2

109

pop3

Post Office Protocol v3

110

smtp

Simple Mail Transport Protocol

25

sunrpc

Sun Remote Procedure Call

111

syslog

Syslog

Примечание: по команде show running-config заменяется на cmd (аналогично Cisco).

514

tacacs

tacacs-ds

TAC Access Control System

Примечание: вторая запись эквивалентна первой, но не показывается в подсказке (аналогично Cisco).

49

talk

Talk

517

telnet

Telnet

23

time

Time

37

uucp

Unix-to-Unix Copy Program

540

whois

Nicname

43

www

World Wide Web (HTTP)

80

 

Поддерживаемые имена портов протокола UDP 

Таблица 15

Имя протокола

Описание протокола

Номер порта

biff

Biff (mail notification, comsat)

512

bootpc

Bootstrap Protocol (BOOTP) client

68

bootps

Bootstrap Protocol (BOOTP) server

67

discard

Discard

9

dnsix

DNSIX security protocol auditing

195

domain

Domain Name Service (DNS)

53

echo

Echo

7

isakmp

Internet Security Association and Key Management Protocol

500

mobile-ip

Mobile IP registration

434

nameserver

IEN116 name service (obsolete)

42

netbios-dgm

NetBios datagram service

138

netbios-ns

NetBios name service

137

netbios-ss

NetBios session service

139

non500-isakmp

Internet Security Association and Key Management Protocol

4500

ntp

Network Time Protocol

123

pim-auto-rp

PIM Auto-RP

496

rip

Routing Information Protocol (router, in.routed)

520

snmp

Simple Network Management Protocol

161

snmptrap

SNMP Traps

162

sunrpc

Sun Remote Procedure Call

111

syslog

Syslog

514

tacacs

tacacs-ds

TAC Access Control System

Примечание: вторая запись эквивалентна первой, но не показывается в подсказке (аналогично Cisco).

49

talk

Talk

517

tftp

Trivial File Transfer Protocol

69

time

Time

37

who

Who service (rwho)

513

xdmcp

X Display Manager Control Protocol

177

 

Пример 

Приведенный ниже пример демонстрирует добавление в расширенный список доступа с именем "a101" записи, разрешающей трафик между хостами 10.10.1.101 и 10.11.1.101 по протоколу udp:

Router(config)#ip access-list extended a101

Router(config-ext-nacl)#permit udp host 10.10.1.101 host 10.11.1.101

Router(config-ext-nacl)#exit

 

Примеры указания TCP-флагов в старом формате:

permit tcp any any established

permit tcp host 10.10.1.101 host 10.11.1.101 established syn urg

deny  tcp  any  any  psh 

 

Примеры указания TCP-флагов в новом формате:

permit tcp any any match-any +rst +ack

permit tcp host 10.10.1.101 host 10.11.1.101 match-all +syn –fin

permit tcp any any match-any -psh +urg