mirror of
https://github.com/netbox-community/netbox.git
synced 2025-07-27 10:58:37 -06:00
parent
d1ea60f082
commit
9b7c10e864
@ -15,7 +15,7 @@ body:
|
||||
attributes:
|
||||
label: NetBox version
|
||||
description: What version of NetBox are you currently running?
|
||||
placeholder: v4.2.4
|
||||
placeholder: v4.2.3
|
||||
validations:
|
||||
required: true
|
||||
- type: dropdown
|
||||
|
2
.github/ISSUE_TEMPLATE/02-bug_report.yaml
vendored
2
.github/ISSUE_TEMPLATE/02-bug_report.yaml
vendored
@ -27,7 +27,7 @@ body:
|
||||
attributes:
|
||||
label: NetBox Version
|
||||
description: What version of NetBox are you currently running?
|
||||
placeholder: v4.2.4
|
||||
placeholder: v4.2.3
|
||||
validations:
|
||||
required: true
|
||||
- type: dropdown
|
||||
|
@ -1,7 +1,7 @@
|
||||
[main]
|
||||
host = https://app.transifex.com
|
||||
|
||||
[o:netbox-community:p:netbox:r:034999968a7366ba27a8bdf1ab63bf42]
|
||||
[o:netbox-community:p:netbox:r:9cbf4fcf95b3d92e4ebbf1a5e5d1caee]
|
||||
file_filter = netbox/translations/<lang>/LC_MESSAGES/django.po
|
||||
source_file = netbox/translations/en/LC_MESSAGES/django.po
|
||||
type = PO
|
||||
|
@ -8,8 +8,6 @@ This documentation describes the process of packaging and publishing a new NetBo
|
||||
|
||||
While major releases generally introduce some very substantial change to the application, they are typically treated the same as minor version increments for the purpose of release packaging.
|
||||
|
||||
For patch releases (e.g. upgrading from v4.2.2 to v4.2.3), begin at the [patch releases](#patch-releases) heading below. For minor or major releases, complete the entire checklist.
|
||||
|
||||
## Minor Version Releases
|
||||
|
||||
### Address Constrained Dependencies
|
||||
@ -87,20 +85,7 @@ In cases where upgrading a dependency to its most recent release is breaking, it
|
||||
|
||||
### Update UI Dependencies
|
||||
|
||||
Check whether any UI dependencies (JavaScript packages, fonts, etc.) need to be updated by running `yarn outdated` from within the `project-static/` directory. [Upgrade these dependencies](./web-ui.md#updating-dependencies) as necessary, then run `yarn bundle` to generate the necessary files for distribution:
|
||||
|
||||
```
|
||||
$ yarn bundle
|
||||
yarn run v1.22.19
|
||||
$ node bundle.js
|
||||
✅ Bundled source file 'styles/external.scss' to 'netbox-external.css'
|
||||
✅ Bundled source file 'styles/netbox.scss' to 'netbox.css'
|
||||
✅ Bundled source file 'styles/svg/rack_elevation.scss' to 'rack_elevation.css'
|
||||
✅ Bundled source file 'styles/svg/cable_trace.scss' to 'cable_trace.css'
|
||||
✅ Bundled source file 'index.ts' to 'netbox.js'
|
||||
✅ Copied graphiql files
|
||||
Done in 1.00s.
|
||||
```
|
||||
Check whether any UI dependencies (JavaScript packages, fonts, etc.) need to be updated by running `yarn outdated` from within the `project-static/` directory. [Upgrade these dependencies](./web-ui.md#updating-dependencies) as necessary, then run `yarn bundle` to generate the necessary files for distribution.
|
||||
|
||||
### Rebuild the Device Type Definition Schema
|
||||
|
||||
@ -131,12 +116,9 @@ Then, compile these portable (`.po`) files for use in the application:
|
||||
|
||||
### Update Version and Changelog
|
||||
|
||||
* Update the version number and date in `netbox/release.yaml`. Add or remove the designation (e.g. `beta1`) if applicable.
|
||||
* Update the version and published date in `release.yaml` with the current version & date. Add a designation (e.g.g `beta1`) if applicable.
|
||||
* Update the example version numbers in the feature request and bug report templates under `.github/ISSUE_TEMPLATES/`.
|
||||
* Add a section for this release at the top of the changelog page for the minor version (e.g. `docs/release-notes/version-4.2.md`) listing all relevant changes made in this release.
|
||||
|
||||
!!! tip
|
||||
Put yourself in the shoes of the user when recording change notes. Focus on the effect that each change has for the end user, rather than the specific bits of code that were modified in a PR. Ensure that each message conveys meaning absent context of the initial feature request or bug report. Remember to include key words or phrases (such as exception names) that can be easily searched.
|
||||
* Replace the "FUTURE" placeholder in the release notes with the current date.
|
||||
|
||||
### Submit a Pull Request
|
||||
|
||||
@ -144,9 +126,6 @@ Commit the above changes and submit a pull request titled **"Release vX.Y.Z"** t
|
||||
|
||||
Once CI has completed and a colleague has reviewed the PR, merge it. This effects a new release in the `main` branch.
|
||||
|
||||
!!! warning
|
||||
To ensure a streamlined review process, the pull request for a release **must** be limited to the changes outlined in this document. A release PR must never include functional changes to the application: Any unrelated "cleanup" needs to be captured in a separate PR prior to the release being shipped.
|
||||
|
||||
### Create a New Release
|
||||
|
||||
Create a [new release](https://github.com/netbox-community/netbox/releases/new) on GitHub with the following parameters.
|
||||
|
@ -22,7 +22,7 @@ NetBox generally follows the [Django style guide](https://docs.djangoproject.com
|
||||
|
||||
### Linting
|
||||
|
||||
The [ruff](https://docs.astral.sh/ruff/) linter is used to enforce code style, and is run automatically by [pre-commit](./getting-started.md#5-install-pre-commit). To invoke `ruff` manually, run:
|
||||
The [ruff](https://docs.astral.sh/ruff/) linter is used to enforce code style. A [pre-commit hook](./getting-started.md#3-enable-pre-commit-hooks) which runs this automatically is included with NetBox. To invoke `ruff` manually, run:
|
||||
|
||||
```
|
||||
ruff check netbox/
|
||||
|
@ -30,7 +30,7 @@ To download translated strings automatically, you'll need to:
|
||||
1. Install the [Transifex CLI client](https://github.com/transifex/cli)
|
||||
2. Generate a [Transifex API token](https://app.transifex.com/user/settings/api/)
|
||||
|
||||
Once you have the client set up, run the following command from the project root (e.g. `/opt/netbox/`):
|
||||
Once you have the client set up, run the following command:
|
||||
|
||||
```no-highlight
|
||||
TX_TOKEN=$TOKEN tx pull
|
||||
@ -46,9 +46,6 @@ Once retrieved, the updated strings need to be compiled into new `.mo` files so
|
||||
|
||||
Once any new `.mo` files have been generated, they need to be committed and pushed back up to GitHub. (Again, this is typically done as part of publishing a new NetBox release.)
|
||||
|
||||
!!! tip
|
||||
Run `git status` to check that both `*.mo` & `*.po` files have been updated as expected.
|
||||
|
||||
## Proposing New Languages
|
||||
|
||||
If you'd like to add support for a new language to NetBox, the first step is to [submit a GitHub issue](https://github.com/netbox-community/netbox/issues/new?assignees=&labels=type%3A+translation&projects=&template=translation.yaml) to capture the proposal. While we'd like to add as many languages as possible, we do need to limit the rate at which new languages are added. New languages will be selected according to community interest and the number of volunteers who sign up as translators.
|
||||
|
@ -2,7 +2,7 @@
|
||||
|
||||
## What is a REST API?
|
||||
|
||||
REST stands for [representational state transfer](https://en.wikipedia.org/wiki/REST). It's a particular type of API which employs HTTP requests and [JavaScript Object Notation (JSON)](https://www.json.org/) to facilitate create, retrieve, update, and delete (CRUD) operations on objects within an application. Each type of operation is associated with a particular HTTP verb:
|
||||
REST stands for [representational state transfer](https://en.wikipedia.org/wiki/Representational_state_transfer). It's a particular type of API which employs HTTP requests and [JavaScript Object Notation (JSON)](https://www.json.org/) to facilitate create, retrieve, update, and delete (CRUD) operations on objects within an application. Each type of operation is associated with a particular HTTP verb:
|
||||
|
||||
* `GET`: Retrieve an object or list of objects
|
||||
* `POST`: Create an object
|
||||
|
@ -1,32 +1,5 @@
|
||||
# NetBox v4.2
|
||||
|
||||
## v4.2.4 (2025-02-21)
|
||||
|
||||
### Enhancements
|
||||
|
||||
* [#17309](https://github.com/netbox-community/netbox/issues/17309) - Omit empty counts in related object tables
|
||||
* [#18277](https://github.com/netbox-community/netbox/issues/18277) - Improve multi-table inheritance in serialization of change-logged models
|
||||
* [#18286](https://github.com/netbox-community/netbox/issues/18286) - Add more job duration choices
|
||||
* [#18357](https://github.com/netbox-community/netbox/issues/18357) - Display author name in plugin list for locally installed plugins
|
||||
* [#18408](https://github.com/netbox-community/netbox/issues/18408) - Add Paused status for virtual machines
|
||||
* [#18584](https://github.com/netbox-community/netbox/issues/18584) - Add rack type column to manufacturer list
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* [#17436](https://github.com/netbox-community/netbox/issues/17436) - Fix {module} replacement in module bays
|
||||
* [#18013](https://github.com/netbox-community/netbox/issues/18013) - Limit object type to selected object in change log filter
|
||||
* [#18241](https://github.com/netbox-community/netbox/issues/18241) - Default logging level of custom scripts changed to INFO
|
||||
* [#18247](https://github.com/netbox-community/netbox/issues/18247) - Fix visibility of disabled cable paths in dark mode
|
||||
* [#18480](https://github.com/netbox-community/netbox/issues/18480) - Clean data passed to script in runscript command
|
||||
* [#18555](https://github.com/netbox-community/netbox/issues/18555) - Add default get_absolute_url method to plugin models
|
||||
* [#18585](https://github.com/netbox-community/netbox/issues/18585) - Fix filtering circuits by location
|
||||
* [#18593](https://github.com/netbox-community/netbox/issues/18593) - Fix "Create & Add Another" IP Address workflow
|
||||
* [#18594](https://github.com/netbox-community/netbox/issues/18594) - Enable sorting by ASN count on site and provider lists
|
||||
* [#18619](https://github.com/netbox-community/netbox/issues/18619) - Ensure shift-click selection selects only visible list items
|
||||
* [#18674](https://github.com/netbox-community/netbox/issues/18674) - Preserve form values when selecting speed on circuit termination
|
||||
|
||||
---
|
||||
|
||||
## v4.2.3 (2025-02-04)
|
||||
|
||||
### Enhancements
|
||||
|
@ -64,8 +64,6 @@ markdown_extensions:
|
||||
format: !!python/name:pymdownx.superfences.fence_code_format
|
||||
- pymdownx.tabbed:
|
||||
alternate_style: true
|
||||
not_in_nav: |
|
||||
/index.md
|
||||
nav:
|
||||
- Introduction: 'introduction.md'
|
||||
- Features:
|
||||
|
@ -234,11 +234,6 @@ class CircuitFilterSet(NetBoxModelFilterSet, TenancyFilterSet, ContactModelFilte
|
||||
to_field_name='slug',
|
||||
label=_('Site (slug)'),
|
||||
)
|
||||
location_id = django_filters.ModelMultipleChoiceFilter(
|
||||
field_name='terminations___location',
|
||||
label=_('Location (ID)'),
|
||||
queryset=Location.objects.all(),
|
||||
)
|
||||
termination_a_id = django_filters.ModelMultipleChoiceFilter(
|
||||
queryset=CircuitTermination.objects.all(),
|
||||
label=_('Termination A (ID)'),
|
||||
|
@ -126,7 +126,7 @@ class CircuitFilterForm(TenancyFilterForm, ContactModelFilterForm, NetBoxModelFi
|
||||
'type_id', 'status', 'install_date', 'termination_date', 'commit_rate', 'distance', 'distance_unit',
|
||||
name=_('Attributes')
|
||||
),
|
||||
FieldSet('region_id', 'site_group_id', 'site_id', 'location_id', name=_('Location')),
|
||||
FieldSet('region_id', 'site_group_id', 'site_id', name=_('Location')),
|
||||
FieldSet('tenant_group_id', 'tenant_id', name=_('Tenant')),
|
||||
FieldSet('contact', 'contact_role', 'contact_group', name=_('Contacts')),
|
||||
)
|
||||
@ -181,11 +181,6 @@ class CircuitFilterForm(TenancyFilterForm, ContactModelFilterForm, NetBoxModelFi
|
||||
},
|
||||
label=_('Site')
|
||||
)
|
||||
location_id = DynamicModelMultipleChoiceField(
|
||||
queryset=Location.objects.all(),
|
||||
required=False,
|
||||
label=_('Location')
|
||||
)
|
||||
install_date = forms.DateField(
|
||||
label=_('Install date'),
|
||||
required=False,
|
||||
|
@ -349,8 +349,9 @@ class CircuitTermination(
|
||||
def clean(self):
|
||||
super().clean()
|
||||
|
||||
# Must define either site *or* provider network
|
||||
if self.termination is None:
|
||||
raise ValidationError(_("A circuit termination must attach to a terminating object."))
|
||||
raise ValidationError(_("A circuit termination must attach to termination."))
|
||||
|
||||
def save(self, *args, **kwargs):
|
||||
# Cache objects associated with the terminating object (for filtering)
|
||||
|
@ -33,6 +33,7 @@ class ProviderTable(ContactsColumnMixin, NetBoxTable):
|
||||
verbose_name=_('ASNs')
|
||||
)
|
||||
asn_count = columns.LinkedCountColumn(
|
||||
accessor=tables.A('asns__count'),
|
||||
viewname='ipam:asn_list',
|
||||
url_params={'provider_id': 'pk'},
|
||||
verbose_name=_('ASN Count')
|
||||
|
@ -3,10 +3,8 @@ from django.test import TestCase
|
||||
from circuits.choices import *
|
||||
from circuits.filtersets import *
|
||||
from circuits.models import *
|
||||
from dcim.choices import InterfaceTypeChoices, LocationStatusChoices
|
||||
from dcim.models import (
|
||||
Cable, Device, DeviceRole, DeviceType, Interface, Location, Manufacturer, Region, Site, SiteGroup
|
||||
)
|
||||
from dcim.choices import InterfaceTypeChoices
|
||||
from dcim.models import Cable, Device, DeviceRole, DeviceType, Interface, Manufacturer, Region, Site, SiteGroup
|
||||
from ipam.models import ASN, RIR
|
||||
from netbox.choices import DistanceUnitChoices
|
||||
from tenancy.models import Tenant, TenantGroup
|
||||
@ -227,17 +225,6 @@ class CircuitTestCase(TestCase, ChangeLoggedFilterSetTests):
|
||||
)
|
||||
ProviderNetwork.objects.bulk_create(provider_networks)
|
||||
|
||||
locations = (
|
||||
Location.objects.create(
|
||||
site=sites[0], name='Test Location 1', slug='test-location-1',
|
||||
status=LocationStatusChoices.STATUS_ACTIVE,
|
||||
),
|
||||
Location.objects.create(
|
||||
site=sites[1], name='Test Location 2', slug='test-location-2',
|
||||
status=LocationStatusChoices.STATUS_ACTIVE,
|
||||
),
|
||||
)
|
||||
|
||||
circuits = (
|
||||
Circuit(
|
||||
provider=providers[0],
|
||||
@ -318,9 +305,7 @@ class CircuitTestCase(TestCase, ChangeLoggedFilterSetTests):
|
||||
|
||||
circuit_terminations = ((
|
||||
CircuitTermination(circuit=circuits[0], termination=sites[0], term_side='A'),
|
||||
CircuitTermination(circuit=circuits[0], termination=locations[0], term_side='Z'),
|
||||
CircuitTermination(circuit=circuits[1], termination=sites[1], term_side='A'),
|
||||
CircuitTermination(circuit=circuits[1], termination=locations[1], term_side='Z'),
|
||||
CircuitTermination(circuit=circuits[2], termination=sites[2], term_side='A'),
|
||||
CircuitTermination(circuit=circuits[3], termination=provider_networks[0], term_side='A'),
|
||||
CircuitTermination(circuit=circuits[4], termination=provider_networks[1], term_side='A'),
|
||||
@ -410,11 +395,6 @@ class CircuitTestCase(TestCase, ChangeLoggedFilterSetTests):
|
||||
params = {'site': [sites[0].slug, sites[1].slug]}
|
||||
self.assertEqual(self.filterset(params, self.queryset).qs.count(), 2)
|
||||
|
||||
def test_location(self):
|
||||
location_ids = Location.objects.values_list('id', flat=True)[:2]
|
||||
params = {'location_id': location_ids}
|
||||
self.assertEqual(self.filterset(params, self.queryset).qs.count(), 2)
|
||||
|
||||
def test_tenant(self):
|
||||
tenants = Tenant.objects.all()[:2]
|
||||
params = {'tenant_id': [tenants[0].pk, tenants[1].pk]}
|
||||
|
@ -4,7 +4,6 @@ from django.shortcuts import get_object_or_404, redirect, render
|
||||
from django.utils.translation import gettext_lazy as _
|
||||
|
||||
from dcim.views import PathTraceView
|
||||
from ipam.models import ASN
|
||||
from netbox.views import generic
|
||||
from tenancy.views import ObjectContactsView
|
||||
from utilities.forms import ConfirmationForm
|
||||
@ -21,8 +20,7 @@ from .models import *
|
||||
@register_model_view(Provider, 'list', path='', detail=False)
|
||||
class ProviderListView(generic.ObjectListView):
|
||||
queryset = Provider.objects.annotate(
|
||||
count_circuits=count_related(Circuit, 'provider'),
|
||||
asn_count=count_related(ASN, 'providers'),
|
||||
count_circuits=count_related(Circuit, 'provider')
|
||||
)
|
||||
filterset = filtersets.ProviderFilterSet
|
||||
filterset_form = forms.ProviderFilterForm
|
||||
|
@ -81,10 +81,8 @@ class JobIntervalChoices(ChoiceSet):
|
||||
CHOICES = (
|
||||
(INTERVAL_MINUTELY, _('Minutely')),
|
||||
(INTERVAL_HOURLY, _('Hourly')),
|
||||
(INTERVAL_HOURLY * 12, _('12 hours')),
|
||||
(INTERVAL_DAILY, _('Daily')),
|
||||
(INTERVAL_WEEKLY, _('Weekly')),
|
||||
(INTERVAL_DAILY * 30, _('30 days')),
|
||||
)
|
||||
|
||||
|
||||
|
@ -62,7 +62,6 @@ class DataFileFilterForm(NetBoxModelFilterSetForm):
|
||||
|
||||
|
||||
class JobFilterForm(SavedFiltersMixin, FilterForm):
|
||||
model = Job
|
||||
fieldsets = (
|
||||
FieldSet('q', 'filter_id'),
|
||||
FieldSet('object_type', 'status', name=_('Attributes')),
|
||||
@ -163,7 +162,6 @@ class ObjectChangeFilterForm(SavedFiltersMixin, FilterForm):
|
||||
|
||||
|
||||
class ConfigRevisionFilterForm(SavedFiltersMixin, FilterForm):
|
||||
model = ConfigRevision
|
||||
fieldsets = (
|
||||
FieldSet('q', 'filter_id'),
|
||||
)
|
||||
|
@ -66,7 +66,6 @@ class Plugin:
|
||||
release_recent_history: list[PluginVersion] = field(default_factory=list)
|
||||
is_local: bool = False # extra field for locally installed plugins
|
||||
is_installed: bool = False
|
||||
failed_to_load: bool = False
|
||||
installed_version: str = ''
|
||||
netbox_min_version: str = ''
|
||||
netbox_max_version: str = ''
|
||||
@ -87,13 +86,6 @@ def get_local_plugins(plugins=None):
|
||||
if plugin_config.release_track:
|
||||
installed_version = f'{installed_version}-{plugin_config.release_track}'
|
||||
|
||||
if plugin_config.author:
|
||||
author = PluginAuthor(
|
||||
name=plugin_config.author,
|
||||
)
|
||||
else:
|
||||
author = None
|
||||
|
||||
local_plugins[plugin_config.name] = Plugin(
|
||||
config_name=plugin_config.name,
|
||||
title_short=plugin_config.verbose_name,
|
||||
@ -102,8 +94,6 @@ def get_local_plugins(plugins=None):
|
||||
description_short=plugin_config.description,
|
||||
is_local=True,
|
||||
is_installed=plugin_name in registry['plugins']['installed'],
|
||||
failed_to_load=plugin_name not in registry['plugins']['installed'],
|
||||
author=author,
|
||||
installed_version=installed_version,
|
||||
netbox_min_version=plugin_config.min_version,
|
||||
netbox_max_version=plugin_config.max_version,
|
||||
|
@ -166,7 +166,7 @@ class DataFileBulkDeleteView(generic.BulkDeleteView):
|
||||
|
||||
@register_model_view(Job, 'list', path='', detail=False)
|
||||
class JobListView(generic.ObjectListView):
|
||||
queryset = Job.objects.defer('data')
|
||||
queryset = Job.objects.all()
|
||||
filterset = filtersets.JobFilterSet
|
||||
filterset_form = forms.JobFilterForm
|
||||
table = tables.JobTable
|
||||
@ -183,12 +183,12 @@ class JobView(generic.ObjectView):
|
||||
|
||||
@register_model_view(Job, 'delete')
|
||||
class JobDeleteView(generic.ObjectDeleteView):
|
||||
queryset = Job.objects.defer('data')
|
||||
queryset = Job.objects.all()
|
||||
|
||||
|
||||
@register_model_view(Job, 'bulk_delete', path='delete', detail=False)
|
||||
class JobBulkDeleteView(generic.BulkDeleteView):
|
||||
queryset = Job.objects.defer('data')
|
||||
queryset = Job.objects.all()
|
||||
filterset = filtersets.JobFilterSet
|
||||
table = tables.JobTable
|
||||
|
||||
|
@ -1193,7 +1193,6 @@ class DeviceFilterSet(
|
||||
return queryset
|
||||
return queryset.filter(
|
||||
Q(name__icontains=value) |
|
||||
Q(virtual_chassis__name__icontains=value) |
|
||||
Q(serial__icontains=value.strip()) |
|
||||
Q(inventoryitems__serial__icontains=value.strip()) |
|
||||
Q(asset_tag__icontains=value.strip()) |
|
||||
|
@ -1411,7 +1411,7 @@ class InterfaceBulkEditForm(
|
||||
form_from_model(Interface, [
|
||||
'label', 'type', 'parent', 'bridge', 'lag', 'speed', 'duplex', 'wwn', 'mtu', 'mgmt_only', 'mark_connected',
|
||||
'description', 'mode', 'rf_role', 'rf_channel', 'rf_channel_frequency', 'rf_channel_width', 'tx_power',
|
||||
'wireless_lans', 'vlan_translation_policy'
|
||||
'wireless_lans'
|
||||
])
|
||||
):
|
||||
enabled = forms.NullBooleanField(
|
||||
@ -1564,9 +1564,7 @@ class InterfaceBulkEditForm(
|
||||
FieldSet('vdcs', 'mtu', 'tx_power', 'enabled', 'mgmt_only', 'mark_connected', name=_('Operation')),
|
||||
FieldSet('poe_mode', 'poe_type', name=_('PoE')),
|
||||
FieldSet('parent', 'bridge', 'lag', name=_('Related Interfaces')),
|
||||
FieldSet(
|
||||
'mode', 'vlan_group', 'untagged_vlan', 'qinq_svlan', 'vlan_translation_policy', name=_('802.1Q Switching')
|
||||
),
|
||||
FieldSet('mode', 'vlan_group', 'untagged_vlan', 'qinq_svlan', name=_('802.1Q Switching')),
|
||||
FieldSet(
|
||||
TabbedGroups(
|
||||
FieldSet('tagged_vlans', name=_('Assignment')),
|
||||
@ -1581,7 +1579,7 @@ class InterfaceBulkEditForm(
|
||||
nullable_fields = (
|
||||
'module', 'label', 'parent', 'bridge', 'lag', 'speed', 'duplex', 'wwn', 'vdcs', 'mtu', 'description',
|
||||
'poe_mode', 'poe_type', 'mode', 'rf_channel', 'rf_channel_frequency', 'rf_channel_width', 'tx_power',
|
||||
'untagged_vlan', 'tagged_vlans', 'qinq_svlan', 'vrf', 'wireless_lans', 'vlan_translation_policy',
|
||||
'untagged_vlan', 'tagged_vlans', 'qinq_svlan', 'vrf', 'wireless_lans'
|
||||
)
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
|
@ -303,7 +303,7 @@ class RackTypeFilterForm(RackBaseFilterForm):
|
||||
model = RackType
|
||||
fieldsets = (
|
||||
FieldSet('q', 'filter_id', 'tag'),
|
||||
FieldSet('manufacturer_id', 'form_factor', 'width', 'u_height', name=_('Rack Type')),
|
||||
FieldSet('form_factor', 'width', 'u_height', name=_('Rack Type')),
|
||||
FieldSet('starting_unit', 'desc_units', name=_('Numbering')),
|
||||
FieldSet('weight', 'max_weight', 'weight_unit', name=_('Weight')),
|
||||
)
|
||||
|
@ -802,10 +802,14 @@ class Device(
|
||||
verbose_name_plural = _('devices')
|
||||
|
||||
def __str__(self):
|
||||
if self.label and self.asset_tag:
|
||||
return f'{self.label} ({self.asset_tag})'
|
||||
elif self.label:
|
||||
return self.label
|
||||
if self.name and self.asset_tag:
|
||||
return f'{self.name} ({self.asset_tag})'
|
||||
elif self.name:
|
||||
return self.name
|
||||
elif self.virtual_chassis and self.asset_tag:
|
||||
return f'{self.virtual_chassis.name}:{self.vc_position} ({self.asset_tag})'
|
||||
elif self.virtual_chassis:
|
||||
return f'{self.virtual_chassis.name}:{self.vc_position} ({self.pk})'
|
||||
elif self.device_type and self.asset_tag:
|
||||
return f'{self.device_type.manufacturer} {self.device_type.model} ({self.asset_tag})'
|
||||
elif self.device_type:
|
||||
@ -1069,22 +1073,14 @@ class Device(
|
||||
device.location = self.location
|
||||
device.save()
|
||||
|
||||
@property
|
||||
def label(self):
|
||||
"""
|
||||
Return the device name if set; otherwise return a generated name if available.
|
||||
"""
|
||||
if self.name:
|
||||
return self.name
|
||||
if self.virtual_chassis:
|
||||
return f'{self.virtual_chassis.name}:{self.vc_position}'
|
||||
|
||||
@property
|
||||
def identifier(self):
|
||||
"""
|
||||
Return the device name if set; otherwise return the Device's primary key as {pk}
|
||||
"""
|
||||
return self.label or '{{{}}}'.format(self.pk)
|
||||
if self.name is not None:
|
||||
return self.name
|
||||
return '{{{}}}'.format(self.pk)
|
||||
|
||||
@property
|
||||
def primary_ip(self):
|
||||
@ -1302,7 +1298,6 @@ class Module(PrimaryModel, ConfigContextModel):
|
||||
else:
|
||||
# ModuleBays must be saved individually for MPTT
|
||||
for instance in create_instances:
|
||||
instance.name = instance.name.replace(MODULE_TOKEN, str(self.module_bay.position))
|
||||
instance.save()
|
||||
|
||||
update_fields = ['module']
|
||||
|
@ -44,7 +44,6 @@ class DeviceIndex(SearchIndex):
|
||||
('asset_tag', 50),
|
||||
('serial', 60),
|
||||
('name', 100),
|
||||
('virtual_chassis', 200),
|
||||
('description', 500),
|
||||
('comments', 5000),
|
||||
)
|
||||
|
@ -30,8 +30,10 @@ STROKE_RESERVED = '#4d4dff'
|
||||
|
||||
|
||||
def get_device_name(device):
|
||||
if device.label:
|
||||
name = device.label
|
||||
if device.virtual_chassis:
|
||||
name = f'{device.virtual_chassis.name}:{device.vc_position}'
|
||||
elif device.name:
|
||||
name = device.name
|
||||
else:
|
||||
name = str(device.device_type)
|
||||
if device.devicebay_count:
|
||||
|
@ -143,7 +143,6 @@ class PlatformTable(NetBoxTable):
|
||||
class DeviceTable(TenancyColumnsMixin, ContactsColumnMixin, NetBoxTable):
|
||||
name = tables.TemplateColumn(
|
||||
verbose_name=_('Name'),
|
||||
accessor=Accessor('label'),
|
||||
template_code=DEVICE_LINK,
|
||||
linkify=True
|
||||
)
|
||||
@ -672,7 +671,7 @@ class InterfaceTable(BaseInterfaceTable, ModularDeviceComponentTable, PathEndpoi
|
||||
'rf_role', 'rf_channel', 'rf_channel_frequency', 'rf_channel_width', 'tx_power', 'description',
|
||||
'mark_connected', 'cable', 'cable_color', 'wireless_link', 'wireless_lans', 'link_peer', 'connection',
|
||||
'tags', 'vdcs', 'vrf', 'l2vpn', 'tunnel', 'ip_addresses', 'fhrp_groups', 'untagged_vlan', 'tagged_vlans',
|
||||
'qinq_svlan', 'inventory_items', 'created', 'last_updated', 'vlan_translation_policy'
|
||||
'qinq_svlan', 'inventory_items', 'created', 'last_updated',
|
||||
)
|
||||
default_columns = ('pk', 'name', 'device', 'label', 'enabled', 'type', 'description')
|
||||
|
||||
|
@ -31,11 +31,6 @@ class ManufacturerTable(ContactsColumnMixin, NetBoxTable):
|
||||
verbose_name=_('Name'),
|
||||
linkify=True
|
||||
)
|
||||
racktype_count = columns.LinkedCountColumn(
|
||||
viewname='dcim:racktype_list',
|
||||
url_params={'manufacturer_id': 'pk'},
|
||||
verbose_name=_('Rack Types')
|
||||
)
|
||||
devicetype_count = columns.LinkedCountColumn(
|
||||
viewname='dcim:devicetype_list',
|
||||
url_params={'manufacturer_id': 'pk'},
|
||||
@ -63,12 +58,12 @@ class ManufacturerTable(ContactsColumnMixin, NetBoxTable):
|
||||
class Meta(NetBoxTable.Meta):
|
||||
model = models.Manufacturer
|
||||
fields = (
|
||||
'pk', 'id', 'name', 'racktype_count', 'devicetype_count', 'moduletype_count', 'inventoryitem_count',
|
||||
'platform_count', 'description', 'slug', 'tags', 'contacts', 'actions', 'created', 'last_updated',
|
||||
'pk', 'id', 'name', 'devicetype_count', 'moduletype_count', 'inventoryitem_count', 'platform_count',
|
||||
'description', 'slug', 'tags', 'contacts', 'actions', 'created', 'last_updated',
|
||||
)
|
||||
default_columns = (
|
||||
'pk', 'name', 'racktype_count', 'devicetype_count', 'moduletype_count', 'inventoryitem_count',
|
||||
'platform_count', 'description', 'slug',
|
||||
'pk', 'name', 'devicetype_count', 'moduletype_count', 'inventoryitem_count', 'platform_count',
|
||||
'description', 'slug',
|
||||
)
|
||||
|
||||
|
||||
|
@ -94,6 +94,7 @@ class SiteTable(TenancyColumnsMixin, ContactsColumnMixin, NetBoxTable):
|
||||
verbose_name=_('ASNs')
|
||||
)
|
||||
asn_count = columns.LinkedCountColumn(
|
||||
accessor=tables.A('asns__count'),
|
||||
viewname='ipam:asn_list',
|
||||
url_params={'site_id': 'pk'},
|
||||
verbose_name=_('ASN Count')
|
||||
|
@ -159,8 +159,8 @@ CONSOLEPORT_BUTTONS = """
|
||||
</span>
|
||||
{% endif %}
|
||||
{% elif perms.dcim.add_cable %}
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-lan-connect" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-lan-connect" aria-hidden="true"></i></a>
|
||||
<span class="dropdown">
|
||||
<button type="button" class="btn btn-success btn-sm dropdown-toggle" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
|
||||
<span class="mdi mdi-ethernet-cable" aria-hidden="true"></span>
|
||||
@ -172,7 +172,7 @@ CONSOLEPORT_BUTTONS = """
|
||||
</ul>
|
||||
</span>
|
||||
{% else %}
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-ethernet-cable" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-ethernet-cable" aria-hidden="true"></i></a>
|
||||
{% endif %}
|
||||
"""
|
||||
|
||||
@ -209,8 +209,8 @@ CONSOLESERVERPORT_BUTTONS = """
|
||||
</span>
|
||||
{% endif %}
|
||||
{% elif perms.dcim.add_cable %}
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-lan-connect" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-lan-connect" aria-hidden="true"></i></a>
|
||||
<span class="dropdown">
|
||||
<button type="button" class="btn btn-success btn-sm dropdown-toggle" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
|
||||
<span class="mdi mdi-ethernet-cable" aria-hidden="true"></span>
|
||||
@ -222,7 +222,7 @@ CONSOLESERVERPORT_BUTTONS = """
|
||||
</ul>
|
||||
</span>
|
||||
{% else %}
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-ethernet-cable" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-ethernet-cable" aria-hidden="true"></i></a>
|
||||
{% endif %}
|
||||
"""
|
||||
|
||||
@ -259,8 +259,8 @@ POWERPORT_BUTTONS = """
|
||||
</span>
|
||||
{% endif %}
|
||||
{% elif perms.dcim.add_cable %}
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-lan-connect" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-lan-connect" aria-hidden="true"></i></a>
|
||||
<span class="dropdown">
|
||||
<button type="button" class="btn btn-success btn-sm dropdown-toggle" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
|
||||
<span class="mdi mdi-ethernet-cable" aria-hidden="true"></span>
|
||||
@ -271,7 +271,7 @@ POWERPORT_BUTTONS = """
|
||||
</ul>
|
||||
</span>
|
||||
{% else %}
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-ethernet-cable" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-ethernet-cable" aria-hidden="true"></i></a>
|
||||
{% endif %}
|
||||
"""
|
||||
|
||||
@ -308,14 +308,14 @@ POWEROUTLET_BUTTONS = """
|
||||
</span>
|
||||
{% endif %}
|
||||
{% elif perms.dcim.add_cable %}
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-lan-connect" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-lan-connect" aria-hidden="true"></i></a>
|
||||
{% if not record.mark_connected %}
|
||||
<a href="{% url 'dcim:cable_add' %}?a_terminations_type=dcim.poweroutlet&a_terminations={{ record.pk }}&b_terminations_type=dcim.powerport&termination_b_site={{ object.site.pk }}&termination_b_rack={{ object.rack.pk }}&return_url={% url 'dcim:device_poweroutlets' pk=object.pk %}" title="Connect" class="btn btn-success btn-sm">
|
||||
<i class="mdi mdi-ethernet-cable" aria-hidden="true"></i>
|
||||
</a>
|
||||
{% else %}
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-ethernet-cable" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-ethernet-cable" aria-hidden="true"></i></a>
|
||||
{% endif %}
|
||||
{% endif %}
|
||||
"""
|
||||
@ -402,8 +402,8 @@ INTERFACE_BUTTONS = """
|
||||
</a>
|
||||
{% endif %}
|
||||
{% elif record.is_wired and perms.dcim.add_cable %}
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-lan-connect" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-lan-connect" aria-hidden="true"></i></a>
|
||||
{% if not record.mark_connected %}
|
||||
<span class="dropdown">
|
||||
<button type="button" class="btn btn-success btn-sm dropdown-toggle" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false" title="Connect cable">
|
||||
@ -417,7 +417,7 @@ INTERFACE_BUTTONS = """
|
||||
</ul>
|
||||
</span>
|
||||
{% else %}
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-ethernet-cable" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-ethernet-cable" aria-hidden="true"></i></a>
|
||||
{% endif %}
|
||||
{% elif record.is_wireless and perms.wireless.add_wirelesslink %}
|
||||
<a href="{% url 'wireless:wirelesslink_add' %}?site_a={{ record.device.site.pk }}&location_a={{ record.device.location.pk }}&device_a={{ record.device_id }}&interface_a={{ record.pk }}&site_b={{ record.device.site.pk }}&location_b={{ record.device.location.pk }}" class="btn btn-success btn-sm">
|
||||
@ -459,8 +459,8 @@ FRONTPORT_BUTTONS = """
|
||||
</span>
|
||||
{% endif %}
|
||||
{% elif perms.dcim.add_cable %}
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-lan-connect" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-lan-connect" aria-hidden="true"></i></a>
|
||||
{% if not record.mark_connected %}
|
||||
<span class="dropdown">
|
||||
<button type="button" class="btn btn-success btn-sm dropdown-toggle" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
|
||||
@ -476,7 +476,7 @@ FRONTPORT_BUTTONS = """
|
||||
</ul>
|
||||
</span>
|
||||
{% else %}
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-ethernet-cable" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-ethernet-cable" aria-hidden="true"></i></a>
|
||||
{% endif %}
|
||||
{% endif %}
|
||||
"""
|
||||
@ -514,8 +514,8 @@ REARPORT_BUTTONS = """
|
||||
</span>
|
||||
{% endif %}
|
||||
{% elif perms.dcim.add_cable %}
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-lan-connect" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-transit-connection-variant" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-lan-connect" aria-hidden="true"></i></a>
|
||||
{% if not record.mark_connected %}
|
||||
<span class="dropdown">
|
||||
<button type="button" class="btn btn-success btn-sm dropdown-toggle" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
|
||||
@ -531,7 +531,7 @@ REARPORT_BUTTONS = """
|
||||
</ul>
|
||||
</span>
|
||||
{% else %}
|
||||
<a href="#" class="btn btn-outline-secondary btn-sm disabled"><i class="mdi mdi-ethernet-cable" aria-hidden="true"></i></a>
|
||||
<a href="#" class="btn btn-outline-dark btn-sm disabled"><i class="mdi mdi-ethernet-cable" aria-hidden="true"></i></a>
|
||||
{% endif %}
|
||||
{% endif %}
|
||||
"""
|
||||
|
@ -590,32 +590,6 @@ class DeviceTestCase(TestCase):
|
||||
device2.full_clean()
|
||||
device2.save()
|
||||
|
||||
def test_device_label(self):
|
||||
device1 = Device(
|
||||
site=Site.objects.first(),
|
||||
device_type=DeviceType.objects.first(),
|
||||
role=DeviceRole.objects.first(),
|
||||
name=None,
|
||||
)
|
||||
self.assertEqual(device1.label, None)
|
||||
|
||||
device1.name = 'Test Device 1'
|
||||
self.assertEqual(device1.label, 'Test Device 1')
|
||||
|
||||
virtual_chassis = VirtualChassis.objects.create(name='VC 1')
|
||||
device2 = Device(
|
||||
site=Site.objects.first(),
|
||||
device_type=DeviceType.objects.first(),
|
||||
role=DeviceRole.objects.first(),
|
||||
name=None,
|
||||
virtual_chassis=virtual_chassis,
|
||||
vc_position=2,
|
||||
)
|
||||
self.assertEqual(device2.label, 'VC 1:2')
|
||||
|
||||
device2.name = 'Test Device 2'
|
||||
self.assertEqual(device2.label, 'Test Device 2')
|
||||
|
||||
def test_device_mismatched_site_cluster(self):
|
||||
cluster_type = ClusterType.objects.create(name='Cluster Type 1', slug='cluster-type-1')
|
||||
Cluster.objects.create(name='Cluster 1', type=cluster_type)
|
||||
|
@ -4,15 +4,17 @@ from django.core.paginator import EmptyPage, PageNotAnInteger
|
||||
from django.db import transaction
|
||||
from django.db.models import Prefetch
|
||||
from django.forms import ModelMultipleChoiceField, MultipleHiddenInput, modelformset_factory
|
||||
from django.http import HttpResponse
|
||||
from django.shortcuts import get_object_or_404, redirect, render
|
||||
from django.urls import reverse
|
||||
from django.utils.html import escape
|
||||
from django.utils.safestring import mark_safe
|
||||
from django.utils.translation import gettext_lazy as _
|
||||
from django.views.generic import View
|
||||
from jinja2.exceptions import TemplateError
|
||||
|
||||
from circuits.models import Circuit, CircuitTermination
|
||||
from extras.views import ObjectConfigContextView, ObjectRenderConfigView
|
||||
from extras.views import ObjectConfigContextView
|
||||
from ipam.models import ASN, IPAddress, Prefix, VLANGroup
|
||||
from ipam.tables import InterfaceVLANTable, VLANTranslationRuleTable
|
||||
from netbox.constants import DEFAULT_ACTION_PERMISSIONS
|
||||
@ -422,8 +424,7 @@ class SiteGroupContactsView(ObjectContactsView):
|
||||
@register_model_view(Site, 'list', path='', detail=False)
|
||||
class SiteListView(generic.ObjectListView):
|
||||
queryset = Site.objects.annotate(
|
||||
device_count=count_related(Device, 'site'),
|
||||
asn_count=count_related(ASN, 'sites')
|
||||
device_count=count_related(Device, 'site')
|
||||
)
|
||||
filterset = filtersets.SiteFilterSet
|
||||
filterset_form = forms.SiteFilterForm
|
||||
@ -965,7 +966,6 @@ class RackReservationBulkDeleteView(generic.BulkDeleteView):
|
||||
@register_model_view(Manufacturer, 'list', path='', detail=False)
|
||||
class ManufacturerListView(generic.ObjectListView):
|
||||
queryset = Manufacturer.objects.annotate(
|
||||
racktype_count=count_related(RackType, 'manufacturer'),
|
||||
devicetype_count=count_related(DeviceType, 'manufacturer'),
|
||||
moduletype_count=count_related(ModuleType, 'manufacturer'),
|
||||
inventoryitem_count=count_related(InventoryItem, 'manufacturer'),
|
||||
@ -2253,14 +2253,54 @@ class DeviceConfigContextView(ObjectConfigContextView):
|
||||
|
||||
|
||||
@register_model_view(Device, 'render-config')
|
||||
class DeviceRenderConfigView(ObjectRenderConfigView):
|
||||
class DeviceRenderConfigView(generic.ObjectView):
|
||||
queryset = Device.objects.all()
|
||||
base_template = 'dcim/device/base.html'
|
||||
template_name = 'dcim/device/render_config.html'
|
||||
tab = ViewTab(
|
||||
label=_('Render Config'),
|
||||
weight=2100,
|
||||
weight=2100
|
||||
)
|
||||
|
||||
def get(self, request, **kwargs):
|
||||
instance = self.get_object(**kwargs)
|
||||
context = self.get_extra_context(request, instance)
|
||||
|
||||
# If a direct export has been requested, return the rendered template content as a
|
||||
# downloadable file.
|
||||
if request.GET.get('export'):
|
||||
content = context['rendered_config'] or context['error_message']
|
||||
response = HttpResponse(content, content_type='text')
|
||||
filename = f"{instance.name or 'config'}.txt"
|
||||
response['Content-Disposition'] = f'attachment; filename="{filename}"'
|
||||
return response
|
||||
|
||||
return render(request, self.get_template_name(), {
|
||||
'object': instance,
|
||||
'tab': self.tab,
|
||||
**context,
|
||||
})
|
||||
|
||||
def get_extra_context(self, request, instance):
|
||||
# Compile context data
|
||||
context_data = instance.get_config_context()
|
||||
context_data.update({'device': instance})
|
||||
|
||||
# Render the config template
|
||||
rendered_config = None
|
||||
error_message = None
|
||||
if config_template := instance.get_config_template():
|
||||
try:
|
||||
rendered_config = config_template.render(context=context_data)
|
||||
except TemplateError as e:
|
||||
error_message = _("An error occurred while rendering the template: {error}").format(error=e)
|
||||
|
||||
return {
|
||||
'config_template': config_template,
|
||||
'context_data': context_data,
|
||||
'rendered_config': rendered_config,
|
||||
'error_message': error_message,
|
||||
}
|
||||
|
||||
|
||||
@register_model_view(Device, 'virtual-machines')
|
||||
class DeviceVirtualMachinesView(generic.ObjectChildrenView):
|
||||
|
@ -155,6 +155,7 @@ class JournalEntryKindChoices(ChoiceSet):
|
||||
class LogLevelChoices(ChoiceSet):
|
||||
|
||||
LOG_DEBUG = 'debug'
|
||||
LOG_DEFAULT = 'default'
|
||||
LOG_INFO = 'info'
|
||||
LOG_SUCCESS = 'success'
|
||||
LOG_WARNING = 'warning'
|
||||
@ -162,15 +163,16 @@ class LogLevelChoices(ChoiceSet):
|
||||
|
||||
CHOICES = (
|
||||
(LOG_DEBUG, _('Debug'), 'teal'),
|
||||
(LOG_DEFAULT, _('Default'), 'gray'),
|
||||
(LOG_INFO, _('Info'), 'cyan'),
|
||||
(LOG_SUCCESS, _('Success'), 'green'),
|
||||
(LOG_WARNING, _('Warning'), 'yellow'),
|
||||
(LOG_FAILURE, _('Failure'), 'red'),
|
||||
|
||||
)
|
||||
|
||||
SYSTEM_LEVELS = {
|
||||
LOG_DEBUG: logging.DEBUG,
|
||||
LOG_DEFAULT: logging.INFO,
|
||||
LOG_INFO: logging.INFO,
|
||||
LOG_SUCCESS: logging.INFO,
|
||||
LOG_WARNING: logging.WARNING,
|
||||
@ -178,6 +180,17 @@ class LogLevelChoices(ChoiceSet):
|
||||
}
|
||||
|
||||
|
||||
class DurationChoices(ChoiceSet):
|
||||
|
||||
CHOICES = (
|
||||
(60, _('Hourly')),
|
||||
(720, _('12 hours')),
|
||||
(1440, _('Daily')),
|
||||
(10080, _('Weekly')),
|
||||
(43200, _('30 days')),
|
||||
)
|
||||
|
||||
|
||||
#
|
||||
# Webhooks
|
||||
#
|
||||
|
@ -138,8 +138,9 @@ DEFAULT_DASHBOARD = [
|
||||
|
||||
LOG_LEVEL_RANK = {
|
||||
LogLevelChoices.LOG_DEBUG: 0,
|
||||
LogLevelChoices.LOG_INFO: 1,
|
||||
LogLevelChoices.LOG_SUCCESS: 2,
|
||||
LogLevelChoices.LOG_WARNING: 3,
|
||||
LogLevelChoices.LOG_FAILURE: 4,
|
||||
LogLevelChoices.LOG_DEFAULT: 1,
|
||||
LogLevelChoices.LOG_INFO: 2,
|
||||
LogLevelChoices.LOG_SUCCESS: 3,
|
||||
LogLevelChoices.LOG_WARNING: 4,
|
||||
LogLevelChoices.LOG_FAILURE: 5,
|
||||
}
|
||||
|
@ -37,7 +37,6 @@ __all__ = (
|
||||
|
||||
|
||||
class CustomFieldFilterForm(SavedFiltersMixin, FilterForm):
|
||||
model = CustomField
|
||||
fieldsets = (
|
||||
FieldSet('q', 'filter_id'),
|
||||
FieldSet(
|
||||
@ -116,7 +115,6 @@ class CustomFieldFilterForm(SavedFiltersMixin, FilterForm):
|
||||
|
||||
|
||||
class CustomFieldChoiceSetFilterForm(SavedFiltersMixin, FilterForm):
|
||||
model = CustomFieldChoiceSet
|
||||
fieldsets = (
|
||||
FieldSet('q', 'filter_id'),
|
||||
FieldSet('base_choices', 'choice', name=_('Choices')),
|
||||
@ -131,7 +129,6 @@ class CustomFieldChoiceSetFilterForm(SavedFiltersMixin, FilterForm):
|
||||
|
||||
|
||||
class CustomLinkFilterForm(SavedFiltersMixin, FilterForm):
|
||||
model = CustomLink
|
||||
fieldsets = (
|
||||
FieldSet('q', 'filter_id'),
|
||||
FieldSet('object_type', 'enabled', 'new_window', 'weight', name=_('Attributes')),
|
||||
@ -162,7 +159,6 @@ class CustomLinkFilterForm(SavedFiltersMixin, FilterForm):
|
||||
|
||||
|
||||
class ExportTemplateFilterForm(SavedFiltersMixin, FilterForm):
|
||||
model = ExportTemplate
|
||||
fieldsets = (
|
||||
FieldSet('q', 'filter_id'),
|
||||
FieldSet('data_source_id', 'data_file_id', name=_('Data')),
|
||||
@ -204,7 +200,6 @@ class ExportTemplateFilterForm(SavedFiltersMixin, FilterForm):
|
||||
|
||||
|
||||
class ImageAttachmentFilterForm(SavedFiltersMixin, FilterForm):
|
||||
model = ImageAttachment
|
||||
fieldsets = (
|
||||
FieldSet('q', 'filter_id'),
|
||||
FieldSet('object_type_id', 'name', name=_('Attributes')),
|
||||
@ -221,7 +216,6 @@ class ImageAttachmentFilterForm(SavedFiltersMixin, FilterForm):
|
||||
|
||||
|
||||
class SavedFilterFilterForm(SavedFiltersMixin, FilterForm):
|
||||
model = SavedFilter
|
||||
fieldsets = (
|
||||
FieldSet('q', 'filter_id'),
|
||||
FieldSet('object_type', 'enabled', 'shared', 'weight', name=_('Attributes')),
|
||||
@ -320,7 +314,6 @@ class TagFilterForm(SavedFiltersMixin, FilterForm):
|
||||
|
||||
|
||||
class ConfigContextFilterForm(SavedFiltersMixin, FilterForm):
|
||||
model = ConfigContext
|
||||
fieldsets = (
|
||||
FieldSet('q', 'filter_id', 'tag_id'),
|
||||
FieldSet('data_source_id', 'data_file_id', name=_('Data')),
|
||||
@ -410,7 +403,6 @@ class ConfigContextFilterForm(SavedFiltersMixin, FilterForm):
|
||||
|
||||
|
||||
class ConfigTemplateFilterForm(SavedFiltersMixin, FilterForm):
|
||||
model = ConfigTemplate
|
||||
fieldsets = (
|
||||
FieldSet('q', 'filter_id', 'tag'),
|
||||
FieldSet('data_source_id', 'data_file_id', name=_('Data')),
|
||||
@ -477,7 +469,6 @@ class JournalEntryFilterForm(NetBoxModelFilterSetForm):
|
||||
|
||||
|
||||
class NotificationGroupFilterForm(SavedFiltersMixin, FilterForm):
|
||||
model = NotificationGroup
|
||||
user_id = DynamicModelMultipleChoiceField(
|
||||
queryset=User.objects.all(),
|
||||
required=False,
|
||||
|
@ -1,7 +1,7 @@
|
||||
from django import forms
|
||||
from django.utils.translation import gettext_lazy as _
|
||||
|
||||
from core.choices import JobIntervalChoices
|
||||
from extras.choices import DurationChoices
|
||||
from utilities.forms.widgets import DateTimePicker, NumberWithOptions
|
||||
from utilities.datetime import local_now
|
||||
|
||||
@ -22,7 +22,7 @@ class ReportForm(forms.Form):
|
||||
min_value=1,
|
||||
label=_("Recurs every"),
|
||||
widget=NumberWithOptions(
|
||||
options=JobIntervalChoices
|
||||
options=DurationChoices
|
||||
),
|
||||
help_text=_("Interval at which this report is re-run (in minutes)")
|
||||
)
|
||||
|
@ -1,7 +1,7 @@
|
||||
from django import forms
|
||||
from django.utils.translation import gettext_lazy as _
|
||||
|
||||
from core.choices import JobIntervalChoices
|
||||
from extras.choices import DurationChoices
|
||||
from utilities.forms.widgets import DateTimePicker, NumberWithOptions
|
||||
from utilities.datetime import local_now
|
||||
|
||||
@ -28,7 +28,7 @@ class ScriptForm(forms.Form):
|
||||
min_value=1,
|
||||
label=_("Recurs every"),
|
||||
widget=NumberWithOptions(
|
||||
options=JobIntervalChoices
|
||||
options=DurationChoices
|
||||
),
|
||||
help_text=_("Interval at which this script is re-run (in minutes)")
|
||||
)
|
||||
|
@ -81,17 +81,12 @@ class Command(BaseCommand):
|
||||
logger.error(f'\t{field}: {error.get("message")}')
|
||||
raise CommandError()
|
||||
|
||||
# Remove extra fields from ScriptForm before passng data to script
|
||||
form.cleaned_data.pop('_schedule_at')
|
||||
form.cleaned_data.pop('_interval')
|
||||
form.cleaned_data.pop('_commit')
|
||||
|
||||
# Execute the script.
|
||||
job = ScriptJob.enqueue(
|
||||
instance=script_obj,
|
||||
user=user,
|
||||
immediate=True,
|
||||
data=form.cleaned_data,
|
||||
data=data,
|
||||
request=NetBoxFakeRequest({
|
||||
'META': {},
|
||||
'POST': data,
|
||||
|
@ -15,7 +15,7 @@ class Report(BaseScript):
|
||||
|
||||
# There is no generic log() equivalent on BaseScript
|
||||
def log(self, message):
|
||||
self._log(message, None, level=LogLevelChoices.LOG_INFO)
|
||||
self._log(message, None, level=LogLevelChoices.LOG_DEFAULT)
|
||||
|
||||
def log_success(self, obj=None, message=None):
|
||||
super().log_success(message, obj)
|
||||
|
@ -460,7 +460,7 @@ class BaseScript:
|
||||
# Logging
|
||||
#
|
||||
|
||||
def _log(self, message, obj=None, level=LogLevelChoices.LOG_INFO):
|
||||
def _log(self, message, obj=None, level=LogLevelChoices.LOG_DEFAULT):
|
||||
"""
|
||||
Log a message. Do not call this method directly; use one of the log_* wrappers below.
|
||||
"""
|
||||
|
@ -1118,7 +1118,6 @@ class TagTestCase(TestCase, ChangeLoggedFilterSetTests):
|
||||
'devicerole',
|
||||
'devicetype',
|
||||
'dummymodel', # From dummy_plugin
|
||||
'dummynetboxmodel', # From dummy_plugin
|
||||
'eventrule',
|
||||
'fhrpgroup',
|
||||
'frontport',
|
||||
|
@ -75,11 +75,8 @@ urlpatterns = [
|
||||
path('scripts/add/', views.ScriptModuleCreateView.as_view(), name='scriptmodule_add'),
|
||||
path('scripts/results/<int:job_pk>/', views.ScriptResultView.as_view(), name='script_result'),
|
||||
path('scripts/<int:pk>/', views.ScriptView.as_view(), name='script'),
|
||||
path('scripts/<str:module>.<str:name>/', views.ScriptView.as_view(), name='script'),
|
||||
path('scripts/<int:pk>/source/', views.ScriptSourceView.as_view(), name='script_source'),
|
||||
path('scripts/<str:module>.<str:name>/source/', views.ScriptSourceView.as_view(), name='script_source'),
|
||||
path('scripts/<int:pk>/jobs/', views.ScriptJobsView.as_view(), name='script_jobs'),
|
||||
path('scripts/<str:module>.<str:name>/jobs/', views.ScriptJobsView.as_view(), name='script_jobs'),
|
||||
path('script-modules/<int:pk>/', include(get_model_urls('extras', 'scriptmodule'))),
|
||||
|
||||
# Markdown
|
||||
|
@ -10,7 +10,6 @@ from django.utils import timezone
|
||||
from django.utils.module_loading import import_string
|
||||
from django.utils.translation import gettext as _
|
||||
from django.views.generic import View
|
||||
from jinja2.exceptions import TemplateError
|
||||
|
||||
from core.choices import ManagedFileRootPathChoices
|
||||
from core.forms import ManagedFileForm
|
||||
@ -886,61 +885,6 @@ class ConfigTemplateBulkSyncDataView(generic.BulkSyncDataView):
|
||||
queryset = ConfigTemplate.objects.all()
|
||||
|
||||
|
||||
class ObjectRenderConfigView(generic.ObjectView):
|
||||
base_template = None
|
||||
template_name = 'extras/object_render_config.html'
|
||||
|
||||
def get(self, request, **kwargs):
|
||||
instance = self.get_object(**kwargs)
|
||||
context = self.get_extra_context(request, instance)
|
||||
|
||||
# If a direct export has been requested, return the rendered template content as a
|
||||
# downloadable file.
|
||||
if request.GET.get('export'):
|
||||
content = context['rendered_config'] or context['error_message']
|
||||
response = HttpResponse(content, content_type='text')
|
||||
filename = f"{instance.name or 'config'}.txt"
|
||||
response['Content-Disposition'] = f'attachment; filename="{filename}"'
|
||||
return response
|
||||
|
||||
return render(
|
||||
request,
|
||||
self.get_template_name(),
|
||||
{
|
||||
'object': instance,
|
||||
'tab': self.tab,
|
||||
**context,
|
||||
},
|
||||
)
|
||||
|
||||
def get_extra_context_data(self, request, instance):
|
||||
return {
|
||||
f'{instance._meta.model_name}': instance,
|
||||
}
|
||||
|
||||
def get_extra_context(self, request, instance):
|
||||
# Compile context data
|
||||
context_data = instance.get_config_context()
|
||||
context_data.update(self.get_extra_context_data(request, instance))
|
||||
|
||||
# Render the config template
|
||||
rendered_config = None
|
||||
error_message = None
|
||||
if config_template := instance.get_config_template():
|
||||
try:
|
||||
rendered_config = config_template.render(context=context_data)
|
||||
except TemplateError as e:
|
||||
error_message = _("An error occurred while rendering the template: {error}").format(error=e)
|
||||
|
||||
return {
|
||||
'base_template': self.base_template,
|
||||
'config_template': config_template,
|
||||
'context_data': context_data,
|
||||
'rendered_config': rendered_config,
|
||||
'error_message': error_message,
|
||||
}
|
||||
|
||||
|
||||
#
|
||||
# Image attachments
|
||||
#
|
||||
@ -1251,14 +1195,6 @@ class ScriptListView(ContentTypePermissionRequiredMixin, View):
|
||||
class BaseScriptView(generic.ObjectView):
|
||||
queryset = Script.objects.all()
|
||||
|
||||
def get_object(self, **kwargs):
|
||||
if pk := kwargs.get('pk', False):
|
||||
return get_object_or_404(self.queryset, pk=pk)
|
||||
elif (module := kwargs.get('module')) and (name := kwargs.get('name', False)):
|
||||
return get_object_or_404(self.queryset, module__file_path=f'{module}.py', name=name)
|
||||
else:
|
||||
raise Http404
|
||||
|
||||
def _get_script_class(self, script):
|
||||
"""
|
||||
Return an instance of the Script's Python class
|
||||
@ -1379,9 +1315,9 @@ class ScriptResultView(TableMixin, generic.ObjectView):
|
||||
index = 0
|
||||
|
||||
try:
|
||||
log_threshold = LOG_LEVEL_RANK[request.GET.get('log_threshold', LogLevelChoices.LOG_INFO)]
|
||||
log_threshold = LOG_LEVEL_RANK[request.GET.get('log_threshold', LogLevelChoices.LOG_DEBUG)]
|
||||
except KeyError:
|
||||
log_threshold = LOG_LEVEL_RANK[LogLevelChoices.LOG_INFO]
|
||||
log_threshold = LOG_LEVEL_RANK[LogLevelChoices.LOG_DEBUG]
|
||||
if job.data:
|
||||
|
||||
if 'log' in job.data:
|
||||
@ -1389,7 +1325,7 @@ class ScriptResultView(TableMixin, generic.ObjectView):
|
||||
tests = job.data['tests']
|
||||
|
||||
for log in job.data['log']:
|
||||
log_level = LOG_LEVEL_RANK.get(log.get('status'), LogLevelChoices.LOG_INFO)
|
||||
log_level = LOG_LEVEL_RANK.get(log.get('status'), LogLevelChoices.LOG_DEFAULT)
|
||||
if log_level >= log_threshold:
|
||||
index += 1
|
||||
result = {
|
||||
@ -1412,7 +1348,7 @@ class ScriptResultView(TableMixin, generic.ObjectView):
|
||||
for method, test_data in tests.items():
|
||||
if 'log' in test_data:
|
||||
for time, status, obj, url, message in test_data['log']:
|
||||
log_level = LOG_LEVEL_RANK.get(status, LogLevelChoices.LOG_INFO)
|
||||
log_level = LOG_LEVEL_RANK.get(status, LogLevelChoices.LOG_DEFAULT)
|
||||
if log_level >= log_threshold:
|
||||
index += 1
|
||||
result = {
|
||||
@ -1438,9 +1374,9 @@ class ScriptResultView(TableMixin, generic.ObjectView):
|
||||
if job.completed:
|
||||
table = self.get_table(job, request, bulk_actions=False)
|
||||
|
||||
log_threshold = request.GET.get('log_threshold', LogLevelChoices.LOG_INFO)
|
||||
log_threshold = request.GET.get('log_threshold', LogLevelChoices.LOG_DEBUG)
|
||||
if log_threshold not in LOG_LEVEL_RANK:
|
||||
log_threshold = LogLevelChoices.LOG_INFO
|
||||
log_threshold = LogLevelChoices.LOG_DEBUG
|
||||
|
||||
context = {
|
||||
'script': job.object,
|
||||
|
@ -212,7 +212,7 @@ class PrefixForm(TenancyForm, ScopedForm, NetBoxModelForm):
|
||||
required=False,
|
||||
selector=True,
|
||||
query_params={
|
||||
'available_at_site': '$scope',
|
||||
'available_at_site': '$site',
|
||||
},
|
||||
label=_('VLAN'),
|
||||
)
|
||||
@ -240,14 +240,6 @@ class PrefixForm(TenancyForm, ScopedForm, NetBoxModelForm):
|
||||
'tenant', 'description', 'comments', 'tags',
|
||||
]
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
super().__init__(*args, **kwargs)
|
||||
|
||||
# #18605: only filter VLAN select list if scope field is a Site
|
||||
if scope_field := self.fields.get('scope', None):
|
||||
if scope_field.queryset.model is not Site:
|
||||
self.fields['vlan'].widget.attrs.pop('data-dynamic-params', None)
|
||||
|
||||
|
||||
class IPRangeForm(TenancyForm, NetBoxModelForm):
|
||||
vrf = DynamicModelChoiceField(
|
||||
|
@ -868,7 +868,6 @@ class IPAddressEditView(generic.ObjectEditView):
|
||||
return {'interface': request.GET['interface']}
|
||||
elif 'vminterface' in request.GET:
|
||||
return {'vminterface': request.GET['vminterface']}
|
||||
return {}
|
||||
|
||||
|
||||
# TODO: Standardize or remove this view
|
||||
|
@ -169,6 +169,15 @@ class NetBoxModelFilterSetForm(CustomFieldsMixin, SavedFiltersMixin, forms.Form)
|
||||
|
||||
selector_fields = ('filter_id', 'q')
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
super().__init__(*args, **kwargs)
|
||||
|
||||
# Limit saved filters to those applicable to the form's model
|
||||
object_type = ObjectType.objects.get_for_model(self.model)
|
||||
self.fields['filter_id'].widget.add_query_params({
|
||||
'object_type_id': object_type.pk,
|
||||
})
|
||||
|
||||
def _get_custom_fields(self, content_type):
|
||||
return super()._get_custom_fields(content_type).exclude(
|
||||
Q(filter_logic=CustomFieldFilterLogicChoices.FILTER_DISABLED) |
|
||||
|
@ -73,16 +73,6 @@ class SavedFiltersMixin(forms.Form):
|
||||
}
|
||||
)
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
super().__init__(*args, **kwargs)
|
||||
|
||||
# Limit saved filters to those applicable to the form's model
|
||||
if hasattr(self, 'model'):
|
||||
object_type = ObjectType.objects.get_for_model(self.model)
|
||||
self.fields['filter_id'].widget.add_query_params({
|
||||
'object_type_id': object_type.pk,
|
||||
})
|
||||
|
||||
|
||||
class TagsMixin(forms.Form):
|
||||
tags = DynamicModelMultipleChoiceField(
|
||||
|
@ -10,7 +10,6 @@ from mptt.models import MPTTModel, TreeForeignKey
|
||||
from netbox.models.features import *
|
||||
from utilities.mptt import TreeManager
|
||||
from utilities.querysets import RestrictedQuerySet
|
||||
from utilities.views import get_viewname
|
||||
|
||||
|
||||
__all__ = (
|
||||
@ -43,7 +42,7 @@ class NetBoxFeatureSet(
|
||||
return f'{settings.STATIC_URL}docs/models/{self._meta.app_label}/{self._meta.model_name}/'
|
||||
|
||||
def get_absolute_url(self):
|
||||
return reverse(get_viewname(self), args=[self.pk])
|
||||
return reverse(f'{self._meta.app_label}:{self._meta.model_name}', args=[self.pk])
|
||||
|
||||
|
||||
#
|
||||
|
@ -814,8 +814,6 @@ for plugin_name in PLUGINS:
|
||||
)
|
||||
|
||||
# Validate version compatibility and user-provided configuration settings and assign defaults
|
||||
if plugin_name not in PLUGINS_CONFIG:
|
||||
PLUGINS_CONFIG[plugin_name] = {}
|
||||
try:
|
||||
plugin_config.validate(PLUGINS_CONFIG.get(plugin_name, {}), RELEASE.version)
|
||||
except IncompatiblePluginError as e:
|
||||
|
@ -719,7 +719,7 @@ class PluginActiveColumn(BooleanColumn):
|
||||
super().__init__(*args, **kwargs)
|
||||
|
||||
def render(self, value, record, table, **kwargs):
|
||||
if record.failed_to_load and self.false_mark:
|
||||
if not value and self.false_mark:
|
||||
tooltip = (
|
||||
f'Could not load due to NetBox version incompatibility. '
|
||||
f'Min version: {record.netbox_min_version}, max version: {record.netbox_max_version}'
|
||||
|
@ -1,7 +1,5 @@
|
||||
from django.db import models
|
||||
|
||||
from netbox.models import NetBoxModel
|
||||
|
||||
|
||||
class DummyModel(models.Model):
|
||||
name = models.CharField(
|
||||
@ -13,7 +11,3 @@ class DummyModel(models.Model):
|
||||
|
||||
class Meta:
|
||||
ordering = ['name']
|
||||
|
||||
|
||||
class DummyNetBoxModel(NetBoxModel):
|
||||
pass
|
||||
|
@ -6,6 +6,4 @@ from . import views
|
||||
urlpatterns = (
|
||||
path('models/', views.DummyModelsView.as_view(), name='dummy_model_list'),
|
||||
path('models/add/', views.DummyModelAddView.as_view(), name='dummy_model_add'),
|
||||
|
||||
path('netboxmodel/<int:pk>/', views.DummyNetBoxModelView.as_view(), name='dummynetboxmodel'),
|
||||
)
|
||||
|
@ -5,17 +5,12 @@ from django.http import HttpResponse
|
||||
from django.views.generic import View
|
||||
|
||||
from dcim.models import Site
|
||||
from netbox.views import generic
|
||||
from utilities.views import register_model_view
|
||||
from .models import DummyModel, DummyNetBoxModel
|
||||
from .models import DummyModel
|
||||
# Trigger registration of custom column
|
||||
from .tables import mycol # noqa: F401
|
||||
|
||||
|
||||
#
|
||||
# DummyModel
|
||||
#
|
||||
|
||||
class DummyModelsView(View):
|
||||
|
||||
def get(self, request):
|
||||
@ -37,18 +32,6 @@ class DummyModelAddView(View):
|
||||
return HttpResponse("Instance created")
|
||||
|
||||
|
||||
#
|
||||
# DummyNetBoxModel
|
||||
#
|
||||
|
||||
class DummyNetBoxModelView(generic.ObjectView):
|
||||
queryset = DummyNetBoxModel.objects.all()
|
||||
|
||||
|
||||
#
|
||||
# API
|
||||
#
|
||||
|
||||
@register_model_view(Site, 'extra', path='other-stuff')
|
||||
class ExtraCoreModelView(View):
|
||||
|
||||
|
@ -166,7 +166,7 @@ class ObjectJobsView(ConditionalLoginRequiredMixin, View):
|
||||
|
||||
def get_jobs(self, instance):
|
||||
object_type = ContentType.objects.get_for_model(instance)
|
||||
return Job.objects.defer('data').filter(
|
||||
return Job.objects.filter(
|
||||
object_type=object_type,
|
||||
object_id=instance.id
|
||||
)
|
||||
|
BIN
netbox/project-static/dist/netbox.js
vendored
BIN
netbox/project-static/dist/netbox.js
vendored
Binary file not shown.
BIN
netbox/project-static/dist/netbox.js.map
vendored
BIN
netbox/project-static/dist/netbox.js.map
vendored
Binary file not shown.
@ -30,8 +30,8 @@
|
||||
"gridstack": "11.3.0",
|
||||
"htmx.org": "1.9.12",
|
||||
"query-string": "9.1.1",
|
||||
"sass": "1.85.0",
|
||||
"tom-select": "2.4.3",
|
||||
"sass": "1.83.4",
|
||||
"tom-select": "2.4.2",
|
||||
"typeface-inter": "3.18.1",
|
||||
"typeface-roboto-mono": "1.1.13"
|
||||
},
|
||||
@ -53,6 +53,5 @@
|
||||
},
|
||||
"resolutions": {
|
||||
"@types/bootstrap/**/@popperjs/core": "^2.11.6"
|
||||
},
|
||||
"packageManager": "yarn@1.22.22+sha512.a6b2f7906b721bba3d67d4aff083df04dad64c399707841b7acf00f6b133b7ac24255f2652fa22ae3534329dc6180534e98d17432037ff6fd140556e2bb3137e"
|
||||
}
|
||||
}
|
||||
|
@ -43,9 +43,7 @@ function toggleCheckboxRange(
|
||||
const typedElement = element as HTMLInputElement;
|
||||
//Change loop's current checkbox state to eventTargetElement checkbox state
|
||||
if (changePkCheckboxState === true) {
|
||||
if (!typedElement.closest('tr')?.classList.contains('d-none')) {
|
||||
typedElement.checked = eventTargetElement.checked;
|
||||
}
|
||||
typedElement.checked = eventTargetElement.checked;
|
||||
}
|
||||
//The previously clicked checkbox was above the shift clicked checkbox
|
||||
if (element === previousStateElement) {
|
||||
@ -54,9 +52,7 @@ function toggleCheckboxRange(
|
||||
return;
|
||||
}
|
||||
changePkCheckboxState = true;
|
||||
if (!typedElement.closest('tr')?.classList.contains('d-none')) {
|
||||
typedElement.checked = eventTargetElement.checked;
|
||||
}
|
||||
typedElement.checked = eventTargetElement.checked;
|
||||
}
|
||||
//The previously clicked checkbox was below the shift clicked checkbox
|
||||
if (element === eventTargetElement) {
|
||||
|
@ -1,6 +1,5 @@
|
||||
import { initForms } from './forms';
|
||||
import { initButtons } from './buttons';
|
||||
import { initClipboard } from './clipboard';
|
||||
import { initClipboard } from './clipboard'
|
||||
import { initSelects } from './select';
|
||||
import { initObjectSelector } from './objectSelector';
|
||||
import { initBootstrap } from './bs';
|
||||
@ -10,7 +9,6 @@ import { initQuickAdd } from './quickAdd';
|
||||
function initDepedencies(): void {
|
||||
initButtons();
|
||||
initClipboard();
|
||||
initForms();
|
||||
initSelects();
|
||||
initObjectSelector();
|
||||
initQuickAdd();
|
||||
|
@ -1,3 +1,3 @@
|
||||
version: "4.2.4"
|
||||
version: "4.2.3"
|
||||
edition: "Community"
|
||||
published: "2025-02-21"
|
||||
published: "2025-02-04"
|
||||
|
75
netbox/templates/dcim/device/render_config.html
Normal file
75
netbox/templates/dcim/device/render_config.html
Normal file
@ -0,0 +1,75 @@
|
||||
{% extends 'dcim/device/base.html' %}
|
||||
{% load static %}
|
||||
{% load i18n %}
|
||||
|
||||
{% block title %}{{ object }} - {% trans "Config" %}{% endblock %}
|
||||
|
||||
{% block content %}
|
||||
<div class="row">
|
||||
<div class="col-5">
|
||||
<div class="card">
|
||||
<h2 class="card-header">{% trans "Config Template" %}</h2>
|
||||
<table class="table table-hover attr-table">
|
||||
<tr>
|
||||
<th scope="row">{% trans "Config Template" %}</th>
|
||||
<td>{{ config_template|linkify|placeholder }}</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">{% trans "Data Source" %}</th>
|
||||
<td>{{ config_template.data_file.source|linkify|placeholder }}</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">{% trans "Data File" %}</th>
|
||||
<td>{{ config_template.data_file|linkify|placeholder }}</td>
|
||||
</tr>
|
||||
</table>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-7">
|
||||
<div class="card">
|
||||
<div class="accordion accordion-flush" id="renderConfig">
|
||||
<div class="card-body">
|
||||
<div class="accordion-item">
|
||||
<h2 class="accordion-header" id="renderConfigHeading">
|
||||
<button class="accordion-button collapsed" type="button" data-bs-toggle="collapse" data-bs-target="#collapsedRenderConfig" aria-expanded="false" aria-controls="collapsedRenderConfig">
|
||||
{% trans "Context Data" %}
|
||||
</button>
|
||||
</h2>
|
||||
<div id="collapsedRenderConfig" class="accordion-collapse collapse" aria-labelledby="renderConfigHeading" data-bs-parent="#renderConfig">
|
||||
<div class="accordion-body">
|
||||
<pre class="card-body">{{ context_data|pprint }}</pre>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="row">
|
||||
<div class="col">
|
||||
{% if config_template %}
|
||||
{% if rendered_config %}
|
||||
<div class="card">
|
||||
<h2 class="card-header d-flex justify-content-between">
|
||||
{% trans "Rendered Config" %}
|
||||
<a href="?export=True" class="btn btn-primary lh-1" role="button">
|
||||
<i class="mdi mdi-download" aria-hidden="true"></i> {% trans "Download" %}
|
||||
</a>
|
||||
</h2>
|
||||
<pre class="card-body">{{ rendered_config }}</pre>
|
||||
</div>
|
||||
{% else %}
|
||||
<div class="alert alert-warning">
|
||||
<h4 class="alert-title mb-1">{% trans "Error rendering template" %}</h4>
|
||||
{% trans error_message %}
|
||||
</div>
|
||||
{% endif %}
|
||||
{% else %}
|
||||
<div class="alert alert-info">
|
||||
{% trans "No configuration template has been assigned for this device." %}
|
||||
</div>
|
||||
{% endif %}
|
||||
</div>
|
||||
</div>
|
||||
{% endblock %}
|
@ -1,4 +1,4 @@
|
||||
<div class="btn-group btn-group-sm" role="group">
|
||||
<a href="?format=json" type="button" class="btn {% if format == 'json' %}btn-primary{% else %}btn-outline-secondary{% endif %}">JSON</a>
|
||||
<a href="?format=yaml" type="button" class="btn {% if format == 'yaml' %}btn-primary{% else %}btn-outline-secondary{% endif %}">YAML</a>
|
||||
<a href="?format=json" type="button" class="btn btn-outline-dark{% if format == 'json' %} active{% endif %}">JSON</a>
|
||||
<a href="?format=yaml" type="button" class="btn btn-outline-dark{% if format == 'yaml' %} active{% endif %}">YAML</a>
|
||||
</div>
|
||||
|
@ -53,7 +53,7 @@
|
||||
<div class="dropdown-menu">
|
||||
{% for level, name in log_levels.items %}
|
||||
<a class="dropdown-item d-flex justify-content-between" href="{% url 'extras:script_result' job_pk=job.pk %}?log_threshold={{ level }}">
|
||||
{{ name }}{% if forloop.counter == 1 %} ({% trans "All" %}){% elif forloop.counter == 2 %} ({% trans "Default" %}){% endif %}
|
||||
{{ name }}{% if forloop.first %} ({% trans "All" %}){% endif %}
|
||||
{% if level == log_threshold %}<span class="badge bg-green ms-auto"></span>{% endif %}
|
||||
</a>
|
||||
{% endfor %}
|
||||
|
@ -55,23 +55,22 @@
|
||||
</div>
|
||||
<div class="card">
|
||||
<h2 class="card-header">{% trans "Tagged Item Types" %}</h2>
|
||||
<ul class="list-group list-group-flush" role="presentation">
|
||||
<table class="table table-hover attr-table">
|
||||
{% for object_type in object_types %}
|
||||
{% with viewname=object_type.content_type.model_class|validated_viewname:"list" %}
|
||||
{% if viewname %}
|
||||
<a href="{% url viewname %}?tag={{ object.slug }}" class="list-group-item list-group-item-action d-flex justify-content-between">
|
||||
{{ object_type.content_type.name|bettertitle }}
|
||||
<span class="badge text-bg-primary rounded-pill">{{ object_type.item_count }}</span>
|
||||
</a>
|
||||
{% else %}
|
||||
<li class="list-group-item list-group-item-action d-flex justify-content-between">
|
||||
{{ object_type.content_type.name|bettertitle }}
|
||||
<span class="badge text-bg-primary rounded-pill">{{ object_type.item_count }}</span>
|
||||
</li>
|
||||
{% endif %}
|
||||
{% endwith %}
|
||||
<tr>
|
||||
<td>{{ object_type.content_type.name|bettertitle }}</td>
|
||||
<td>
|
||||
{% with viewname=object_type.content_type.model_class|validated_viewname:"list" %}
|
||||
{% if viewname %}
|
||||
<a href="{% url viewname %}?tag={{ object.slug }}">{{ object_type.item_count }}</a>
|
||||
{% else %}
|
||||
{{ object_type.item_count }}
|
||||
{% endif %}
|
||||
{% endwith %}
|
||||
</td>
|
||||
</tr>
|
||||
{% endfor %}
|
||||
</ul>
|
||||
</table>
|
||||
</div>
|
||||
{% plugin_right_page object %}
|
||||
</div>
|
||||
@ -80,7 +79,7 @@
|
||||
<div class="col col-md-12">
|
||||
<div class="card">
|
||||
<h2 class="card-header">{% trans "Tagged Objects" %}</h2>
|
||||
<div class="table-responsive">
|
||||
<div class="card-body table-responsive">
|
||||
{% render_table taggeditem_table 'inc/table.html' %}
|
||||
{% include 'inc/paginator.html' with paginator=taggeditem_table.paginator page=taggeditem_table.page %}
|
||||
</div>
|
||||
|
@ -19,8 +19,6 @@
|
||||
</a>
|
||||
{% endif %}
|
||||
{% endwith %}
|
||||
{% empty %}
|
||||
<span class="list-group-item text-muted">{% trans "None" %}</span>
|
||||
{% endfor %}
|
||||
</ul>
|
||||
</div>
|
||||
|
@ -0,0 +1,75 @@
|
||||
{% extends 'virtualization/virtualmachine/base.html' %}
|
||||
{% load static %}
|
||||
{% load i18n %}
|
||||
|
||||
{% block title %}{{ object }} - {% trans "Config" %}{% endblock %}
|
||||
|
||||
{% block content %}
|
||||
<div class="row">
|
||||
<div class="col-5">
|
||||
<div class="card">
|
||||
<h2 class="card-header">{% trans "Config Template" %}</h2>
|
||||
<table class="table table-hover attr-table">
|
||||
<tr>
|
||||
<th scope="row">{% trans "Config Template" %}</th>
|
||||
<td>{{ config_template|linkify|placeholder }}</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">{% trans "Data Source" %}</th>
|
||||
<td>{{ config_template.data_file.source|linkify|placeholder }}</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">{% trans "Data File" %}</th>
|
||||
<td>{{ config_template.data_file|linkify|placeholder }}</td>
|
||||
</tr>
|
||||
</table>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-7">
|
||||
<div class="card">
|
||||
<div class="accordion accordion-flush" id="renderConfig">
|
||||
<div class="card-body">
|
||||
<div class="accordion-item">
|
||||
<h2 class="accordion-header" id="renderConfigHeading">
|
||||
<button class="accordion-button collapsed" type="button" data-bs-toggle="collapse" data-bs-target="#collapsedRenderConfig" aria-expanded="false" aria-controls="collapsedRenderConfig">
|
||||
{% trans "Context Data" %}
|
||||
</button>
|
||||
</h2>
|
||||
<div id="collapsedRenderConfig" class="accordion-collapse collapse" aria-labelledby="renderConfigHeading" data-bs-parent="#renderConfig">
|
||||
<div class="accordion-body">
|
||||
<pre class="card-body">{{ context_data|pprint }}</pre>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="row">
|
||||
<div class="col">
|
||||
{% if config_template %}
|
||||
{% if rendered_config %}
|
||||
<div class="card">
|
||||
<h2 class="card-header d-flex justify-content-between">
|
||||
{% trans "Rendered Config" %}
|
||||
<a href="?export=True" class="btn btn-primary lh-1" role="button">
|
||||
<i class="mdi mdi-download" aria-hidden="true"></i> {% trans "Download" %}
|
||||
</a>
|
||||
</h2>
|
||||
<pre class="card-body">{{ rendered_config }}</pre>
|
||||
</div>
|
||||
{% else %}
|
||||
<div class="alert alert-warning">
|
||||
<h4 class="alert-title mb-1">{% trans "Error rendering template" %}</h4>
|
||||
{% trans error_message %}
|
||||
</div>
|
||||
{% endif %}
|
||||
{% else %}
|
||||
<div class="alert alert-info">
|
||||
{% trans "No configuration template has been assigned for this virtual machine." %}
|
||||
</div>
|
||||
{% endif %}
|
||||
</div>
|
||||
</div>
|
||||
{% endblock %}
|
Binary file not shown.
@ -4,10 +4,10 @@
|
||||
# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
|
||||
#
|
||||
# Translators:
|
||||
# czarnian, 2024
|
||||
# Jeremy Stretch, 2024
|
||||
# Pavel Valach, 2024
|
||||
# Matěj Gordon, 2025
|
||||
# czarnian, 2025
|
||||
# Jeremy Stretch, 2025
|
||||
#
|
||||
#, fuzzy
|
||||
msgid ""
|
||||
@ -16,7 +16,7 @@ msgstr ""
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2025-01-04 05:02+0000\n"
|
||||
"PO-Revision-Date: 2023-10-30 17:48+0000\n"
|
||||
"Last-Translator: Jeremy Stretch, 2025\n"
|
||||
"Last-Translator: Matěj Gordon, 2025\n"
|
||||
"Language-Team: Czech (https://app.transifex.com/netbox-community/teams/178115/cs/)\n"
|
||||
"MIME-Version: 1.0\n"
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
@ -64,7 +64,7 @@ msgstr "Naposledy použitý"
|
||||
#: netbox/templates/users/token.html:47 netbox/users/forms/bulk_edit.py:122
|
||||
#: netbox/users/forms/model_forms.py:124
|
||||
msgid "Allowed IPs"
|
||||
msgstr "Povolené adresy IP"
|
||||
msgstr "Povolené IP adresy"
|
||||
|
||||
#: netbox/account/views.py:114
|
||||
#, python-brace-format
|
||||
@ -179,7 +179,7 @@ msgstr "Region (zkratka)"
|
||||
#: netbox/ipam/filtersets.py:974 netbox/virtualization/filtersets.py:58
|
||||
#: netbox/virtualization/filtersets.py:186
|
||||
msgid "Site group (ID)"
|
||||
msgstr "Skupina míst (ID)"
|
||||
msgstr "Skupina stránek (ID)"
|
||||
|
||||
#: netbox/circuits/filtersets.py:51 netbox/circuits/filtersets.py:218
|
||||
#: netbox/dcim/filtersets.py:135 netbox/dcim/filtersets.py:232
|
||||
@ -191,7 +191,7 @@ msgstr "Skupina míst (ID)"
|
||||
#: netbox/virtualization/filtersets.py:65
|
||||
#: netbox/virtualization/filtersets.py:193
|
||||
msgid "Site group (slug)"
|
||||
msgstr "Skupina míst (zkratka)"
|
||||
msgstr "Skupina stránek (slug)"
|
||||
|
||||
#: netbox/circuits/filtersets.py:56 netbox/circuits/forms/bulk_edit.py:188
|
||||
#: netbox/circuits/forms/bulk_edit.py:216
|
||||
@ -252,7 +252,7 @@ msgstr "Skupina míst (zkratka)"
|
||||
#: netbox/vpn/forms/filtersets.py:266 netbox/wireless/forms/model_forms.py:76
|
||||
#: netbox/wireless/forms/model_forms.py:118
|
||||
msgid "Site"
|
||||
msgstr "Místo"
|
||||
msgstr "Stránky"
|
||||
|
||||
#: netbox/circuits/filtersets.py:62 netbox/circuits/filtersets.py:229
|
||||
#: netbox/circuits/filtersets.py:274 netbox/dcim/filtersets.py:242
|
||||
@ -262,7 +262,7 @@ msgstr "Místo"
|
||||
#: netbox/virtualization/filtersets.py:75
|
||||
#: netbox/virtualization/filtersets.py:203 netbox/vpn/filtersets.py:363
|
||||
msgid "Site (slug)"
|
||||
msgstr "Místo (zkratka)"
|
||||
msgstr "Místo (slug)"
|
||||
|
||||
#: netbox/circuits/filtersets.py:67
|
||||
msgid "ASN (ID)"
|
||||
@ -316,7 +316,7 @@ msgstr "Typ okruhu (URL zkratka)"
|
||||
#: netbox/ipam/filtersets.py:985 netbox/virtualization/filtersets.py:69
|
||||
#: netbox/virtualization/filtersets.py:197 netbox/vpn/filtersets.py:368
|
||||
msgid "Site (ID)"
|
||||
msgstr "Místo (ID)"
|
||||
msgstr "Stránky (ID)"
|
||||
|
||||
#: netbox/circuits/filtersets.py:233 netbox/circuits/filtersets.py:237
|
||||
msgid "Termination A (ID)"
|
||||
@ -371,15 +371,15 @@ msgstr "Síť poskytovatele (ID)"
|
||||
|
||||
#: netbox/circuits/filtersets.py:335
|
||||
msgid "Circuit (ID)"
|
||||
msgstr "Okruh (ID)"
|
||||
msgstr "Obvod (ID)"
|
||||
|
||||
#: netbox/circuits/filtersets.py:341
|
||||
msgid "Circuit (CID)"
|
||||
msgstr "Okruh (CID)"
|
||||
msgstr "Obvod (CID)"
|
||||
|
||||
#: netbox/circuits/filtersets.py:345
|
||||
msgid "Circuit group (ID)"
|
||||
msgstr "Skupina okruhů (ID)"
|
||||
msgstr "Skupina obvodů (ID)"
|
||||
|
||||
#: netbox/circuits/filtersets.py:351
|
||||
msgid "Circuit group (slug)"
|
||||
@ -804,7 +804,7 @@ msgstr "Datum ukončení"
|
||||
#: netbox/circuits/forms/bulk_edit.py:158
|
||||
#: netbox/circuits/forms/filtersets.py:186
|
||||
msgid "Commit rate (Kbps)"
|
||||
msgstr "Smluvní rychlost (Kbps)"
|
||||
msgstr "Rychlost odevzdání (Kbps)"
|
||||
|
||||
#: netbox/circuits/forms/bulk_edit.py:173
|
||||
#: netbox/circuits/forms/model_forms.py:112
|
||||
@ -1042,7 +1042,7 @@ msgstr "Region"
|
||||
#: netbox/virtualization/forms/filtersets.py:138
|
||||
#: netbox/virtualization/forms/model_forms.py:98
|
||||
msgid "Site group"
|
||||
msgstr "Skupina míst"
|
||||
msgstr "Skupina stránek"
|
||||
|
||||
#: netbox/circuits/forms/filtersets.py:65
|
||||
#: netbox/circuits/forms/filtersets.py:83
|
||||
@ -1160,19 +1160,19 @@ msgstr "barva"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:36
|
||||
msgid "circuit type"
|
||||
msgstr "typ okruhu"
|
||||
msgstr "typ obvodu"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:37
|
||||
msgid "circuit types"
|
||||
msgstr "typy okruhů"
|
||||
msgstr "typy obvodů"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:48
|
||||
msgid "circuit ID"
|
||||
msgstr "ID okruhu"
|
||||
msgstr "ID obvodu"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:49
|
||||
msgid "Unique circuit ID"
|
||||
msgstr "Jedinečné ID okruhu"
|
||||
msgstr "Jedinečné ID obvodu"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:69 netbox/core/models/data.py:52
|
||||
#: netbox/core/models/jobs.py:85 netbox/dcim/models/cables.py:49
|
||||
@ -1194,11 +1194,11 @@ msgstr "nainstalován"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:89
|
||||
msgid "terminates"
|
||||
msgstr "končí"
|
||||
msgstr "ukončí"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:94
|
||||
msgid "commit rate (Kbps)"
|
||||
msgstr "smluvní rychlost (Kbps)"
|
||||
msgstr "rychlost odevzdání (Kbps)"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:95
|
||||
msgid "Committed rate"
|
||||
@ -1214,11 +1214,11 @@ msgstr "okruhy"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:170
|
||||
msgid "circuit group"
|
||||
msgstr "skupina okruhů"
|
||||
msgstr "skupina obvodů"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:171
|
||||
msgid "circuit groups"
|
||||
msgstr "skupiny okruhů"
|
||||
msgstr "skupiny obvodů"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:195 netbox/ipam/models/fhrp.py:93
|
||||
#: netbox/tenancy/models/contacts.py:134
|
||||
@ -1227,7 +1227,7 @@ msgstr "přednost"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:213
|
||||
msgid "Circuit group assignment"
|
||||
msgstr "Přiřazení skupiny okruhů"
|
||||
msgstr "Přiřazení skupiny obvodů"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:214
|
||||
msgid "Circuit group assignments"
|
||||
@ -1235,7 +1235,7 @@ msgstr "Přiřazení skupin obvodů"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:240
|
||||
msgid "termination"
|
||||
msgstr ""
|
||||
msgstr "zakončení"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:257
|
||||
msgid "port speed (Kbps)"
|
||||
@ -1297,11 +1297,14 @@ msgstr "zakončení okruhů"
|
||||
msgid ""
|
||||
"A circuit termination must attach to either a site or a provider network."
|
||||
msgstr ""
|
||||
"Zakončení okruhu se musí připojit buď k místu, nebo k síti poskytovatele."
|
||||
|
||||
#: netbox/circuits/models/circuits.py:310
|
||||
msgid ""
|
||||
"A circuit termination cannot attach to both a site and a provider network."
|
||||
msgstr ""
|
||||
"Zakončení okruhu se nemůže připojit jak k síti webu, tak k síti "
|
||||
"poskytovatele."
|
||||
|
||||
#: netbox/circuits/models/providers.py:22
|
||||
#: netbox/circuits/models/providers.py:66
|
||||
@ -1531,7 +1534,7 @@ msgstr "Strana Z"
|
||||
#: netbox/circuits/tables/circuits.py:77
|
||||
#: netbox/templates/circuits/circuit.html:55
|
||||
msgid "Commit Rate"
|
||||
msgstr "Smluvní rychlost"
|
||||
msgstr "Míra odevzdání"
|
||||
|
||||
#: netbox/circuits/tables/circuits.py:80
|
||||
#: netbox/circuits/tables/providers.py:48
|
||||
@ -1560,7 +1563,7 @@ msgstr "Smluvní rychlost"
|
||||
#: netbox/vpn/tables/tunnels.py:61 netbox/wireless/tables/wirelesslan.py:27
|
||||
#: netbox/wireless/tables/wirelesslan.py:58
|
||||
msgid "Comments"
|
||||
msgstr "Komentáře"
|
||||
msgstr "Komentář"
|
||||
|
||||
#: netbox/circuits/tables/circuits.py:86
|
||||
#: netbox/templates/tenancy/contact.html:84
|
||||
@ -1583,12 +1586,12 @@ msgstr "Počet ASN"
|
||||
#: netbox/circuits/views.py:331
|
||||
#, python-brace-format
|
||||
msgid "No terminations have been defined for circuit {circuit}."
|
||||
msgstr "Pro okruh {circuit} nebyla definována žádná zakončení ."
|
||||
msgstr "Pro obvod nebyla definována žádná zakončení {circuit}."
|
||||
|
||||
#: netbox/circuits/views.py:380
|
||||
#, python-brace-format
|
||||
msgid "Swapped terminations for circuit {circuit}."
|
||||
msgstr "Vyměněná zakončení pro okruh {circuit}."
|
||||
msgstr "Vyměněné zakončení pro obvod {circuit}."
|
||||
|
||||
#: netbox/core/api/views.py:39
|
||||
msgid "This user does not have permission to synchronize this data source."
|
||||
@ -1617,7 +1620,7 @@ msgstr "Dokončeno"
|
||||
#: netbox/dcim/choices.py:187 netbox/dcim/choices.py:239
|
||||
#: netbox/dcim/choices.py:1609 netbox/virtualization/choices.py:47
|
||||
msgid "Failed"
|
||||
msgstr "Selhalo"
|
||||
msgstr "Neuspěl"
|
||||
|
||||
#: netbox/core/choices.py:35 netbox/netbox/navigation/menu.py:335
|
||||
#: netbox/netbox/navigation/menu.py:339
|
||||
@ -1644,7 +1647,7 @@ msgstr "Naplánováno"
|
||||
|
||||
#: netbox/core/choices.py:56
|
||||
msgid "Running"
|
||||
msgstr "Běží"
|
||||
msgstr "Běh"
|
||||
|
||||
#: netbox/core/choices.py:58
|
||||
msgid "Errored"
|
||||
@ -1653,7 +1656,7 @@ msgstr "Chyba"
|
||||
#: netbox/core/choices.py:87 netbox/core/tables/plugins.py:63
|
||||
#: netbox/templates/generic/object.html:61
|
||||
msgid "Updated"
|
||||
msgstr "Aktualizováno"
|
||||
msgstr "aktualizováno"
|
||||
|
||||
#: netbox/core/choices.py:88
|
||||
msgid "Deleted"
|
||||
@ -1722,7 +1725,7 @@ msgstr "Tajný přístupový klíč AWS"
|
||||
|
||||
#: netbox/core/events.py:27
|
||||
msgid "Object created"
|
||||
msgstr "Objekt vytvořen"
|
||||
msgstr "Vytvořený objekt"
|
||||
|
||||
#: netbox/core/events.py:28
|
||||
msgid "Object updated"
|
||||
@ -1734,7 +1737,7 @@ msgstr "Objekt odstraněn"
|
||||
|
||||
#: netbox/core/events.py:30
|
||||
msgid "Job started"
|
||||
msgstr "Úloha zahájena"
|
||||
msgstr "Práce byla zahájena"
|
||||
|
||||
#: netbox/core/events.py:31
|
||||
msgid "Job completed"
|
||||
@ -1847,7 +1850,7 @@ msgstr "Vytvořeno po"
|
||||
|
||||
#: netbox/core/forms/filtersets.py:89
|
||||
msgid "Created before"
|
||||
msgstr "Vytvořeno před"
|
||||
msgstr "Vytvořeno dříve"
|
||||
|
||||
#: netbox/core/forms/filtersets.py:94
|
||||
msgid "Scheduled after"
|
||||
@ -1855,7 +1858,7 @@ msgstr "Naplánováno po"
|
||||
|
||||
#: netbox/core/forms/filtersets.py:99
|
||||
msgid "Scheduled before"
|
||||
msgstr "Naplánováno před"
|
||||
msgstr "Naplánováno dříve"
|
||||
|
||||
#: netbox/core/forms/filtersets.py:104
|
||||
msgid "Started after"
|
||||
@ -1863,7 +1866,7 @@ msgstr "Začalo po"
|
||||
|
||||
#: netbox/core/forms/filtersets.py:109
|
||||
msgid "Started before"
|
||||
msgstr "Začalo před"
|
||||
msgstr "Začalo dříve"
|
||||
|
||||
#: netbox/core/forms/filtersets.py:114
|
||||
msgid "Completed after"
|
||||
@ -1902,7 +1905,7 @@ msgstr "Po"
|
||||
|
||||
#: netbox/core/forms/filtersets.py:144 netbox/extras/forms/filtersets.py:450
|
||||
msgid "Before"
|
||||
msgstr "Před"
|
||||
msgstr "Dříve"
|
||||
|
||||
#: netbox/core/forms/filtersets.py:148 netbox/core/tables/change_logging.py:29
|
||||
#: netbox/extras/forms/model_forms.py:396
|
||||
@ -1938,7 +1941,7 @@ msgstr ""
|
||||
#: netbox/core/forms/model_forms.py:153
|
||||
#: netbox/templates/dcim/rack_elevation_list.html:6
|
||||
msgid "Rack Elevations"
|
||||
msgstr "Přehled stojanů"
|
||||
msgstr "Výšky stojanů"
|
||||
|
||||
#: netbox/core/forms/model_forms.py:157 netbox/dcim/choices.py:1520
|
||||
#: netbox/dcim/forms/bulk_edit.py:984 netbox/dcim/forms/bulk_edit.py:1372
|
||||
@ -2256,16 +2259,16 @@ msgstr "ID úlohy"
|
||||
|
||||
#: netbox/core/models/jobs.py:112
|
||||
msgid "job"
|
||||
msgstr "úloha"
|
||||
msgstr "práce"
|
||||
|
||||
#: netbox/core/models/jobs.py:113
|
||||
msgid "jobs"
|
||||
msgstr "úlohy"
|
||||
msgstr "pracovní místa"
|
||||
|
||||
#: netbox/core/models/jobs.py:136
|
||||
#, python-brace-format
|
||||
msgid "Jobs cannot be assigned to this object type ({type})."
|
||||
msgstr "K tomuto typu objektu ({type}) nelze přiřadit úlohy."
|
||||
msgstr "K tomuto typu objektu nelze přiřadit úlohy ({type})."
|
||||
|
||||
#: netbox/core/models/jobs.py:190
|
||||
#, python-brace-format
|
||||
@ -2275,7 +2278,7 @@ msgstr "Neplatný stav pro ukončení úlohy. Možnosti jsou: {choices}"
|
||||
#: netbox/core/models/jobs.py:221
|
||||
msgid ""
|
||||
"enqueue() cannot be called with values for both schedule_at and immediate."
|
||||
msgstr "enqueue() nelze volat s hodnotami pro schedule_at a ihned zároveň."
|
||||
msgstr "enqueue () nelze volat s hodnotami pro schedule_at a instant."
|
||||
|
||||
#: netbox/core/signals.py:126
|
||||
#, python-brace-format
|
||||
@ -2393,7 +2396,7 @@ msgstr "Hostitel"
|
||||
|
||||
#: netbox/core/tables/tasks.py:50 netbox/ipam/forms/filtersets.py:535
|
||||
msgid "Port"
|
||||
msgstr "Port"
|
||||
msgstr "Přístav"
|
||||
|
||||
#: netbox/core/tables/tasks.py:54
|
||||
msgid "DB"
|
||||
@ -2442,7 +2445,7 @@ msgstr "Nebyli nalezeni žádní pracovníci"
|
||||
#: netbox/core/views.py:90
|
||||
#, python-brace-format
|
||||
msgid "Queued job #{id} to sync {datasource}"
|
||||
msgstr "Úloha #{id} k synchronizaci {datasource} zařazena do fronty."
|
||||
msgstr "Úloha ve frontě #{id} synchronizovat {datasource}"
|
||||
|
||||
#: netbox/core/views.py:319
|
||||
#, python-brace-format
|
||||
@ -2452,12 +2455,12 @@ msgstr "Obnovená revize konfigurace #{id}"
|
||||
#: netbox/core/views.py:412 netbox/core/views.py:455 netbox/core/views.py:531
|
||||
#, python-brace-format
|
||||
msgid "Job {job_id} not found"
|
||||
msgstr "Úloha {job_id} nenalezena"
|
||||
msgstr "Práce {job_id} nenalezeno"
|
||||
|
||||
#: netbox/core/views.py:463
|
||||
#, python-brace-format
|
||||
msgid "Job {id} has been deleted."
|
||||
msgstr "Úloha {id} byla vymazána."
|
||||
msgstr "Práce {id} byl vymazán."
|
||||
|
||||
#: netbox/core/views.py:465
|
||||
#, python-brace-format
|
||||
@ -2467,22 +2470,22 @@ msgstr "Chyba při mazání úlohy {id}: {error}"
|
||||
#: netbox/core/views.py:478 netbox/core/views.py:496
|
||||
#, python-brace-format
|
||||
msgid "Job {id} not found."
|
||||
msgstr "Úloha {id} nenalezena."
|
||||
msgstr "Práce {id} nenalezeno."
|
||||
|
||||
#: netbox/core/views.py:484
|
||||
#, python-brace-format
|
||||
msgid "Job {id} has been re-enqueued."
|
||||
msgstr "Úloha {id} byla znovu zařazena do fronty."
|
||||
msgstr "Práce {id} byla znovu zařazena do fronty."
|
||||
|
||||
#: netbox/core/views.py:519
|
||||
#, python-brace-format
|
||||
msgid "Job {id} has been enqueued."
|
||||
msgstr "Úloha {id} byla zařazena do fronty."
|
||||
msgstr "Práce {id} byl zařazen do fronty."
|
||||
|
||||
#: netbox/core/views.py:538
|
||||
#, python-brace-format
|
||||
msgid "Job {id} has been stopped."
|
||||
msgstr "Úloha {id} byla zastavena."
|
||||
msgstr "Práce {id} byl zastaven."
|
||||
|
||||
#: netbox/core/views.py:540
|
||||
#, python-brace-format
|
||||
@ -2532,7 +2535,7 @@ msgstr "4-sloupový rám"
|
||||
|
||||
#: netbox/dcim/choices.py:67
|
||||
msgid "4-post cabinet"
|
||||
msgstr "4-sloupová skříň"
|
||||
msgstr "4-sloupová skříňka"
|
||||
|
||||
#: netbox/dcim/choices.py:68
|
||||
msgid "Wall-mounted frame"
|
||||
@ -2544,7 +2547,7 @@ msgstr "Nástěnný rám (vertikální)"
|
||||
|
||||
#: netbox/dcim/choices.py:70
|
||||
msgid "Wall-mounted cabinet"
|
||||
msgstr "Nástěnná skříň"
|
||||
msgstr "Nástěnná skříňka"
|
||||
|
||||
#: netbox/dcim/choices.py:71
|
||||
msgid "Wall-mounted cabinet (vertical)"
|
||||
@ -2579,7 +2582,7 @@ msgstr "Milimetry"
|
||||
|
||||
#: netbox/dcim/choices.py:115 netbox/dcim/choices.py:1555
|
||||
msgid "Inches"
|
||||
msgstr "Palce"
|
||||
msgstr "palce"
|
||||
|
||||
#: netbox/dcim/choices.py:136 netbox/dcim/choices.py:207
|
||||
#: netbox/dcim/choices.py:254
|
||||
@ -2676,12 +2679,12 @@ msgstr "Zdola nahoru"
|
||||
|
||||
#: netbox/dcim/choices.py:214
|
||||
msgid "Top to bottom"
|
||||
msgstr "Shora dolů"
|
||||
msgstr "Nahoru dolů"
|
||||
|
||||
#: netbox/dcim/choices.py:215 netbox/dcim/choices.py:259
|
||||
#: netbox/dcim/choices.py:1305
|
||||
msgid "Passive"
|
||||
msgstr "Pasivní"
|
||||
msgstr "pasivní"
|
||||
|
||||
#: netbox/dcim/choices.py:216
|
||||
msgid "Mixed"
|
||||
@ -2799,17 +2802,17 @@ msgstr "Auto"
|
||||
|
||||
#: netbox/dcim/choices.py:1265
|
||||
msgid "Access"
|
||||
msgstr "Přístupový"
|
||||
msgstr "Přístup"
|
||||
|
||||
#: netbox/dcim/choices.py:1266 netbox/ipam/tables/vlans.py:172
|
||||
#: netbox/ipam/tables/vlans.py:217
|
||||
#: netbox/templates/dcim/inc/interface_vlans_table.html:7
|
||||
msgid "Tagged"
|
||||
msgstr "Značkovaný"
|
||||
msgstr "Označeno"
|
||||
|
||||
#: netbox/dcim/choices.py:1267
|
||||
msgid "Tagged (All)"
|
||||
msgstr "Značkovaný (Vše)"
|
||||
msgstr "Označeno (Vše)"
|
||||
|
||||
#: netbox/dcim/choices.py:1296
|
||||
msgid "IEEE Standard"
|
||||
@ -2885,7 +2888,7 @@ msgstr "Gramy"
|
||||
#: netbox/dcim/choices.py:1572 netbox/templates/dcim/device.html:328
|
||||
#: netbox/templates/dcim/rack.html:108
|
||||
msgid "Pounds"
|
||||
msgstr "Libry"
|
||||
msgstr "libry"
|
||||
|
||||
#: netbox/dcim/choices.py:1573
|
||||
msgid "Ounces"
|
||||
@ -2893,7 +2896,7 @@ msgstr "Unce"
|
||||
|
||||
#: netbox/dcim/choices.py:1620
|
||||
msgid "Redundant"
|
||||
msgstr "Zdvojený"
|
||||
msgstr "Redundantní"
|
||||
|
||||
#: netbox/dcim/choices.py:1641
|
||||
msgid "Single phase"
|
||||
@ -2919,15 +2922,15 @@ msgstr "Nadřazená oblast (ID)"
|
||||
|
||||
#: netbox/dcim/filtersets.py:92
|
||||
msgid "Parent region (slug)"
|
||||
msgstr "Nadřazená oblast (zkratka)"
|
||||
msgstr "Nadřazená oblast (URL zkratka)"
|
||||
|
||||
#: netbox/dcim/filtersets.py:116
|
||||
msgid "Parent site group (ID)"
|
||||
msgstr "Nadřazená skupina míst (ID)"
|
||||
msgstr "Nadřazená skupina webů (ID)"
|
||||
|
||||
#: netbox/dcim/filtersets.py:122
|
||||
msgid "Parent site group (slug)"
|
||||
msgstr "Nadřazená skupina míst (zkratka)"
|
||||
msgstr "Nadřazená skupina stránek (slimák)"
|
||||
|
||||
#: netbox/dcim/filtersets.py:164 netbox/extras/filtersets.py:364
|
||||
#: netbox/ipam/filtersets.py:843 netbox/ipam/filtersets.py:995
|
||||
@ -4228,7 +4231,7 @@ msgstr "Šířka musí být nastavena, pokud není zadán typ stojanu."
|
||||
|
||||
#: netbox/dcim/forms/bulk_import.py:326
|
||||
msgid "U height must be set if not specifying a rack type."
|
||||
msgstr "Pokud není zadán typ stojanu, musí být nastavena výška U."
|
||||
msgstr ""
|
||||
|
||||
#: netbox/dcim/forms/bulk_import.py:334
|
||||
msgid "Parent site"
|
||||
@ -4887,11 +4890,6 @@ msgid ""
|
||||
"present, will be automatically replaced with the position value when "
|
||||
"creating a new module."
|
||||
msgstr ""
|
||||
"Pro hromadné vytváření jsou podporovány alfanumerické rozsahy. Smíšené "
|
||||
"případy a typy v rámci jednoho rozsahu nejsou podporovány (příklad: "
|
||||
"<code>[ge, xe] -0/0/ [0-9]</code>). Žeton <code>{module}</code>, pokud je "
|
||||
"přítomen, bude automaticky nahrazen hodnotou pozice při vytváření nového "
|
||||
"modulu."
|
||||
|
||||
#: netbox/dcim/forms/model_forms.py:1094
|
||||
msgid "Console port template"
|
||||
@ -9597,11 +9595,11 @@ msgstr "Nastavte to jako primární IP pro přiřazené zařízení"
|
||||
|
||||
#: netbox/ipam/forms/bulk_import.py:330
|
||||
msgid "Is out-of-band"
|
||||
msgstr "Je mimo pásmo"
|
||||
msgstr ""
|
||||
|
||||
#: netbox/ipam/forms/bulk_import.py:331
|
||||
msgid "Designate this as the out-of-band IP address for the assigned device"
|
||||
msgstr "Určete tuto adresu jako mimopásmovou IP adresu přiřazeného zařízení"
|
||||
msgstr ""
|
||||
|
||||
#: netbox/ipam/forms/bulk_import.py:371
|
||||
msgid "No device or virtual machine specified; cannot set as primary IP"
|
||||
@ -9611,11 +9609,11 @@ msgstr ""
|
||||
|
||||
#: netbox/ipam/forms/bulk_import.py:375
|
||||
msgid "No device specified; cannot set as out-of-band IP"
|
||||
msgstr "Není určeno žádné zařízení; nelze nastavit jako IP mimo pásmo"
|
||||
msgstr ""
|
||||
|
||||
#: netbox/ipam/forms/bulk_import.py:379
|
||||
msgid "Cannot set out-of-band IP for virtual machines"
|
||||
msgstr "Nelze nastavit IP mimo pásmo pro virtuální počítače"
|
||||
msgstr ""
|
||||
|
||||
#: netbox/ipam/forms/bulk_import.py:383
|
||||
msgid "No interface specified; cannot set as primary IP"
|
||||
@ -9623,7 +9621,7 @@ msgstr "Není určeno žádné rozhraní; nelze nastavit jako primární IP"
|
||||
|
||||
#: netbox/ipam/forms/bulk_import.py:387
|
||||
msgid "No interface specified; cannot set as out-of-band IP"
|
||||
msgstr "Není určeno žádné rozhraní; nelze nastavit jako IP mimo pásmo"
|
||||
msgstr ""
|
||||
|
||||
#: netbox/ipam/forms/bulk_import.py:422
|
||||
msgid "Auth type"
|
||||
@ -9782,7 +9780,7 @@ msgstr "Řada ASN"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:231
|
||||
msgid "Site/VLAN Assignment"
|
||||
msgstr ""
|
||||
msgstr "Přiřazení webu/VLAN"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:259 netbox/templates/ipam/iprange.html:10
|
||||
msgid "IP Range"
|
||||
@ -9800,7 +9798,7 @@ msgstr "Nastavte z něj primární IP pro zařízení/virtuální počítač"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:314
|
||||
msgid "Make this the out-of-band IP for the device"
|
||||
msgstr "Nastavte z tohoto pole IP mimo pásmo zařízení"
|
||||
msgstr ""
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:329
|
||||
msgid "NAT IP (Inside)"
|
||||
@ -9813,12 +9811,10 @@ msgstr "IP adresu lze přiřadit pouze jednomu objektu."
|
||||
#: netbox/ipam/forms/model_forms.py:398
|
||||
msgid "Cannot reassign primary IP address for the parent device/VM"
|
||||
msgstr ""
|
||||
"Nelze znovu přiřadit primární adresu IP pro nadřazené zařízení/virtuální "
|
||||
"počítač"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:402
|
||||
msgid "Cannot reassign out-of-Band IP address for the parent device"
|
||||
msgstr "Nelze znovu přiřadit IP adresu mimo pásmo pro nadřazené zařízení"
|
||||
msgstr ""
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:412
|
||||
msgid ""
|
||||
@ -9831,8 +9827,6 @@ msgid ""
|
||||
"Only IP addresses assigned to a device interface can be designated as the "
|
||||
"out-of-band IP for a device."
|
||||
msgstr ""
|
||||
"Pouze IP adresy přiřazené k rozhraní zařízení mohou být označeny jako IP "
|
||||
"adresy mimo pásmo zařízení."
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:508
|
||||
msgid "Virtual IP Address"
|
||||
@ -10226,12 +10220,12 @@ msgstr "Nelze nastavit scope_id bez scope_type."
|
||||
#: netbox/ipam/models/vlans.py:105
|
||||
#, python-brace-format
|
||||
msgid "Starting VLAN ID in range ({value}) cannot be less than {minimum}"
|
||||
msgstr "Spuštění VLAN ID v dosahu ({value}) nemůže být menší než {minimum}"
|
||||
msgstr ""
|
||||
|
||||
#: netbox/ipam/models/vlans.py:111
|
||||
#, python-brace-format
|
||||
msgid "Ending VLAN ID in range ({value}) cannot exceed {maximum}"
|
||||
msgstr "Ukončení VLAN ID v rozsahu ({value}) nesmí překročit {maximum}"
|
||||
msgstr ""
|
||||
|
||||
#: netbox/ipam/models/vlans.py:118
|
||||
#, python-brace-format
|
||||
@ -10239,8 +10233,6 @@ msgid ""
|
||||
"Ending VLAN ID in range must be greater than or equal to the starting VLAN "
|
||||
"ID ({range})"
|
||||
msgstr ""
|
||||
"Koncové ID VLAN v rozsahu musí být větší nebo roven počátečnímu ID VLAN "
|
||||
"({range})"
|
||||
|
||||
#: netbox/ipam/models/vlans.py:124
|
||||
msgid "Ranges cannot overlap."
|
||||
@ -12595,7 +12587,7 @@ msgstr "Chyba při vykreslování šablony"
|
||||
|
||||
#: netbox/templates/dcim/device/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this device."
|
||||
msgstr ""
|
||||
msgstr "Pro toto zařízení nebyla přiřazena žádná konfigurační šablona."
|
||||
|
||||
#: netbox/templates/dcim/device_edit.html:44
|
||||
msgid "Parent Bay"
|
||||
@ -13860,7 +13852,7 @@ msgstr "Centrum nápovědy"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:41
|
||||
msgid "Django Admin"
|
||||
msgstr ""
|
||||
msgstr "Správce Django"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:61
|
||||
msgid "Log Out"
|
||||
@ -14274,6 +14266,7 @@ msgstr "Přidat virtuální disk"
|
||||
#: netbox/templates/virtualization/virtualmachine/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this virtual machine."
|
||||
msgstr ""
|
||||
"Pro tento virtuální počítač nebyla přiřazena žádná konfigurační šablona."
|
||||
|
||||
#: netbox/templates/vpn/ikepolicy.html:10
|
||||
#: netbox/templates/vpn/ipsecprofile.html:33 netbox/vpn/tables/crypto.py:166
|
||||
@ -15372,6 +15365,7 @@ msgid ""
|
||||
"{device} belongs to a different site ({device_site}) than the cluster "
|
||||
"({cluster_site})"
|
||||
msgstr ""
|
||||
"{device} patří k jinému webu ({device_site}) než cluster ({cluster_site})"
|
||||
|
||||
#: netbox/virtualization/forms/model_forms.py:192
|
||||
msgid "Optionally pin this VM to a specific host device within the cluster"
|
||||
@ -16104,7 +16098,7 @@ msgstr "bezdrátové spoje"
|
||||
|
||||
#: netbox/wireless/models.py:236
|
||||
msgid "Must specify a unit when setting a wireless distance"
|
||||
msgstr ""
|
||||
msgstr "Při nastavování bezdrátové vzdálenosti je nutné zadat jednotku"
|
||||
|
||||
#: netbox/wireless/models.py:242 netbox/wireless/models.py:248
|
||||
#, python-brace-format
|
||||
|
Binary file not shown.
@ -6,7 +6,7 @@
|
||||
# Translators:
|
||||
# Jeff Gehlbach, 2024
|
||||
# ch, 2024
|
||||
# Frederik Spang <fst@progras.dk>, 2024
|
||||
# Frederik Spang Thomsen <frederik@progras.dk>, 2024
|
||||
# Jeremy Stretch, 2025
|
||||
#
|
||||
#, fuzzy
|
||||
@ -1235,7 +1235,7 @@ msgstr "Kredsløbsgruppeopgaver"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:240
|
||||
msgid "termination"
|
||||
msgstr ""
|
||||
msgstr "opsigelse"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:257
|
||||
msgid "port speed (Kbps)"
|
||||
@ -1297,11 +1297,15 @@ msgstr "kredsløbsafslutninger"
|
||||
msgid ""
|
||||
"A circuit termination must attach to either a site or a provider network."
|
||||
msgstr ""
|
||||
"En kredsløbsafslutning skal tilsluttes enten et websted eller et "
|
||||
"udbydernetværk."
|
||||
|
||||
#: netbox/circuits/models/circuits.py:310
|
||||
msgid ""
|
||||
"A circuit termination cannot attach to both a site and a provider network."
|
||||
msgstr ""
|
||||
"En kredsløbsafslutning kan ikke knyttes til både et websted og et "
|
||||
"udbydernetværk."
|
||||
|
||||
#: netbox/circuits/models/providers.py:22
|
||||
#: netbox/circuits/models/providers.py:66
|
||||
@ -9799,7 +9803,7 @@ msgstr "ASN-rækkevidde"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:231
|
||||
msgid "Site/VLAN Assignment"
|
||||
msgstr ""
|
||||
msgstr "Websted/VLAN-tildeling"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:259 netbox/templates/ipam/iprange.html:10
|
||||
msgid "IP Range"
|
||||
@ -12631,7 +12635,7 @@ msgstr "Fejl ved gengivelse af skabelon"
|
||||
|
||||
#: netbox/templates/dcim/device/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this device."
|
||||
msgstr ""
|
||||
msgstr "Der er ikke tildelt nogen konfigurationsskabelon til denne enhed."
|
||||
|
||||
#: netbox/templates/dcim/device_edit.html:44
|
||||
msgid "Parent Bay"
|
||||
@ -13899,7 +13903,7 @@ msgstr "Hjælpecenter"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:41
|
||||
msgid "Django Admin"
|
||||
msgstr ""
|
||||
msgstr "Django Admin"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:61
|
||||
msgid "Log Out"
|
||||
@ -14313,6 +14317,8 @@ msgstr "Tilføj virtuel disk"
|
||||
#: netbox/templates/virtualization/virtualmachine/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this virtual machine."
|
||||
msgstr ""
|
||||
"Der er ikke tildelt nogen konfigurationsskabelon til denne virtuelle "
|
||||
"maskine."
|
||||
|
||||
#: netbox/templates/vpn/ikepolicy.html:10
|
||||
#: netbox/templates/vpn/ipsecprofile.html:33 netbox/vpn/tables/crypto.py:166
|
||||
@ -15415,6 +15421,7 @@ msgid ""
|
||||
"{device} belongs to a different site ({device_site}) than the cluster "
|
||||
"({cluster_site})"
|
||||
msgstr ""
|
||||
"{device} tilhører et andet sted ({device_site}) end klyngen ({cluster_site})"
|
||||
|
||||
#: netbox/virtualization/forms/model_forms.py:192
|
||||
msgid "Optionally pin this VM to a specific host device within the cluster"
|
||||
@ -16144,7 +16151,7 @@ msgstr "trådløse links"
|
||||
|
||||
#: netbox/wireless/models.py:236
|
||||
msgid "Must specify a unit when setting a wireless distance"
|
||||
msgstr ""
|
||||
msgstr "Skal angive en enhed, når du indstiller en trådløs afstand"
|
||||
|
||||
#: netbox/wireless/models.py:242 netbox/wireless/models.py:248
|
||||
#, python-brace-format
|
||||
|
Binary file not shown.
@ -5,13 +5,13 @@
|
||||
#
|
||||
# Translators:
|
||||
# Martin R, 2024
|
||||
# Niklas, 2024
|
||||
# fepilins, 2024
|
||||
# Steffen, 2024
|
||||
# haagehan, 2024
|
||||
# Jeremy Stretch, 2024
|
||||
# Robin Reinhardt, 2024
|
||||
# Jeremy Stretch, 2025
|
||||
# chbally, 2025
|
||||
# Niklas, 2025
|
||||
#
|
||||
#, fuzzy
|
||||
msgid ""
|
||||
@ -20,7 +20,7 @@ msgstr ""
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2025-01-04 05:02+0000\n"
|
||||
"PO-Revision-Date: 2023-10-30 17:48+0000\n"
|
||||
"Last-Translator: Niklas, 2025\n"
|
||||
"Last-Translator: chbally, 2025\n"
|
||||
"Language-Team: German (https://app.transifex.com/netbox-community/teams/178115/de/)\n"
|
||||
"MIME-Version: 1.0\n"
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
@ -1240,7 +1240,7 @@ msgstr "Transportnetzzuweisungen"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:240
|
||||
msgid "termination"
|
||||
msgstr ""
|
||||
msgstr "Abschlusspunkt"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:257
|
||||
msgid "port speed (Kbps)"
|
||||
@ -1303,11 +1303,15 @@ msgstr "Transportnetzabschlusspunkte"
|
||||
msgid ""
|
||||
"A circuit termination must attach to either a site or a provider network."
|
||||
msgstr ""
|
||||
"Ein Leitungsabschluss muss entweder an einen Standort oder an ein "
|
||||
"Providernetzwerk angeschlossen werden."
|
||||
|
||||
#: netbox/circuits/models/circuits.py:310
|
||||
msgid ""
|
||||
"A circuit termination cannot attach to both a site and a provider network."
|
||||
msgstr ""
|
||||
"Ein Leitungsabschluss kann nicht sowohl an einen Standort als auch an ein "
|
||||
"Providernetzwerk angeschlossen werden."
|
||||
|
||||
#: netbox/circuits/models/providers.py:22
|
||||
#: netbox/circuits/models/providers.py:66
|
||||
@ -8434,7 +8438,8 @@ msgstr "Gewicht anzeigen"
|
||||
|
||||
#: netbox/extras/models/customfields.py:173
|
||||
msgid "Fields with higher weights appear lower in a form."
|
||||
msgstr "Höher gewichtete Felder werden im Formular weiter unten angezeigt."
|
||||
msgstr ""
|
||||
"Felder mit höheren Gewichten werden in einem Formular niedriger angezeigt."
|
||||
|
||||
#: netbox/extras/models/customfields.py:178
|
||||
msgid "minimum value"
|
||||
@ -9526,7 +9531,7 @@ msgstr "Dienst (ID)"
|
||||
|
||||
#: netbox/ipam/filtersets.py:675
|
||||
msgid "NAT inside IP address (ID)"
|
||||
msgstr "NAT inside IP-Adresse (ID)"
|
||||
msgstr "NAT innerhalb der IP-Adresse (ID)"
|
||||
|
||||
#: netbox/ipam/filtersets.py:1043 netbox/ipam/forms/bulk_import.py:322
|
||||
msgid "Assigned interface"
|
||||
@ -9954,7 +9959,7 @@ msgstr "Ziel der Route"
|
||||
#: netbox/templates/ipam/aggregate.html:11
|
||||
#: netbox/templates/ipam/prefix.html:38
|
||||
msgid "Aggregate"
|
||||
msgstr "Aggregieren"
|
||||
msgstr "Aggregat"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:135 netbox/templates/ipam/asnrange.html:12
|
||||
msgid "ASN Range"
|
||||
@ -9962,7 +9967,7 @@ msgstr "ASN-Bereich"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:231
|
||||
msgid "Site/VLAN Assignment"
|
||||
msgstr ""
|
||||
msgstr "Standort-/VLAN-Zuweisung"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:259 netbox/templates/ipam/iprange.html:10
|
||||
msgid "IP Range"
|
||||
@ -10090,7 +10095,9 @@ msgstr "ASN-Bereiche"
|
||||
#: netbox/ipam/models/asns.py:72
|
||||
#, python-brace-format
|
||||
msgid "Starting ASN ({start}) must be lower than ending ASN ({end})."
|
||||
msgstr "Der ASN ({start}) muss niedriger sein als das letzte ASN ({end})."
|
||||
msgstr ""
|
||||
"ASN wird gestartet ({start}) muss niedriger sein als das Ende der ASN "
|
||||
"({end})."
|
||||
|
||||
#: netbox/ipam/models/asns.py:104
|
||||
msgid "Regional Internet Registry responsible for this AS number space"
|
||||
@ -10164,7 +10171,7 @@ msgstr "Aggregat"
|
||||
|
||||
#: netbox/ipam/models/ip.py:116
|
||||
msgid "aggregates"
|
||||
msgstr "aggregiert"
|
||||
msgstr "Aggregate"
|
||||
|
||||
#: netbox/ipam/models/ip.py:132
|
||||
msgid "Cannot create aggregate with /0 mask."
|
||||
@ -10220,8 +10227,7 @@ msgstr "ist ein Pool"
|
||||
#: netbox/ipam/models/ip.py:267
|
||||
msgid "All IP addresses within this prefix are considered usable"
|
||||
msgstr ""
|
||||
"Alle IP-Adressen (inklusive Netzwerk- und Broadcast-Adresse) innerhalb "
|
||||
"dieses Prefixes werden als nutzbar betrachtet"
|
||||
"Alle IP-Adressen innerhalb dieses Prefixes werden als nutzbar betrachtet"
|
||||
|
||||
#: netbox/ipam/models/ip.py:270 netbox/ipam/models/ip.py:537
|
||||
msgid "mark utilized"
|
||||
@ -10497,7 +10503,7 @@ msgstr "einzigartigen Raum erzwingen"
|
||||
|
||||
#: netbox/ipam/models/vrfs.py:43
|
||||
msgid "Prevent duplicate prefixes/IP addresses within this VRF"
|
||||
msgstr "Vermeiden Sie doppelte Präfixe/IP-Adressen in dieser VRF"
|
||||
msgstr "Vermeiden Sie doppelte Präfixe/IP-Adressen in diesem VRF"
|
||||
|
||||
#: netbox/ipam/models/vrfs.py:63 netbox/netbox/navigation/menu.py:186
|
||||
#: netbox/netbox/navigation/menu.py:188
|
||||
@ -10518,7 +10524,7 @@ msgstr "Routenziele"
|
||||
|
||||
#: netbox/ipam/tables/asn.py:52
|
||||
msgid "ASDOT"
|
||||
msgstr "ASDOT"
|
||||
msgstr "ALS PUNKT"
|
||||
|
||||
#: netbox/ipam/tables/asn.py:57
|
||||
msgid "Site Count"
|
||||
@ -11546,7 +11552,7 @@ msgstr ""
|
||||
#: netbox/netbox/registry.py:14
|
||||
#, python-brace-format
|
||||
msgid "Invalid store: {key}"
|
||||
msgstr "Ungültiger Store: {key}"
|
||||
msgstr "Ungültiger Shop: {key}"
|
||||
|
||||
#: netbox/netbox/registry.py:17
|
||||
msgid "Cannot add stores to registry after initialization"
|
||||
@ -12425,7 +12431,7 @@ msgstr "Warteschlange"
|
||||
|
||||
#: netbox/templates/core/rq_task.html:65
|
||||
msgid "Timeout"
|
||||
msgstr "Timeout"
|
||||
msgstr "Auszeit"
|
||||
|
||||
#: netbox/templates/core/rq_task.html:69
|
||||
msgid "Result TTL"
|
||||
@ -12495,7 +12501,7 @@ msgstr "Anzahl fehlgeschlagener Jobs"
|
||||
|
||||
#: netbox/templates/core/rq_worker.html:75
|
||||
msgid "Total working time"
|
||||
msgstr "Gesamtlaufzeit"
|
||||
msgstr "Gesamtarbeitszeit"
|
||||
|
||||
#: netbox/templates/core/rq_worker.html:76
|
||||
msgid "seconds"
|
||||
@ -12821,7 +12827,7 @@ msgstr "Fehler beim Rendern der Vorlage"
|
||||
|
||||
#: netbox/templates/dcim/device/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this device."
|
||||
msgstr ""
|
||||
msgstr "Diesem Gerät wurde keine Konfigurationsvorlage zugewiesen."
|
||||
|
||||
#: netbox/templates/dcim/device_edit.html:44
|
||||
msgid "Parent Bay"
|
||||
@ -14092,7 +14098,7 @@ msgstr "Hilfecenter"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:41
|
||||
msgid "Django Admin"
|
||||
msgstr ""
|
||||
msgstr "Django-Administrator"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:61
|
||||
msgid "Log Out"
|
||||
@ -14507,6 +14513,7 @@ msgstr "Virtuelles Laufwerk hinzufügen"
|
||||
#: netbox/templates/virtualization/virtualmachine/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this virtual machine."
|
||||
msgstr ""
|
||||
"Für diese virtuelle Maschine wurde keine Konfigurationsvorlage zugewiesen."
|
||||
|
||||
#: netbox/templates/vpn/ikepolicy.html:10
|
||||
#: netbox/templates/vpn/ipsecprofile.html:33 netbox/vpn/tables/crypto.py:166
|
||||
@ -14533,11 +14540,11 @@ msgstr "Secret anzeigen"
|
||||
#: netbox/vpn/forms/model_forms.py:316 netbox/vpn/forms/model_forms.py:352
|
||||
#: netbox/vpn/tables/crypto.py:68 netbox/vpn/tables/crypto.py:134
|
||||
msgid "Proposals"
|
||||
msgstr "Proposals"
|
||||
msgstr "Vorschläge"
|
||||
|
||||
#: netbox/templates/vpn/ikeproposal.html:10
|
||||
msgid "IKE Proposal"
|
||||
msgstr "IKE- Proposal"
|
||||
msgstr "IKE-Vorschlag"
|
||||
|
||||
#: netbox/templates/vpn/ikeproposal.html:21 netbox/vpn/forms/bulk_edit.py:97
|
||||
#: netbox/vpn/forms/bulk_import.py:145 netbox/vpn/forms/filtersets.py:101
|
||||
@ -14568,7 +14575,7 @@ msgstr "DH-Gruppe"
|
||||
#: netbox/templates/vpn/ipsecproposal.html:29
|
||||
#: netbox/vpn/forms/bulk_edit.py:182 netbox/vpn/models/crypto.py:146
|
||||
msgid "SA lifetime (seconds)"
|
||||
msgstr "SA-Gültigkeitsdauer (Sekunden)"
|
||||
msgstr "SA-Lebensdauer (Sekunden)"
|
||||
|
||||
#: netbox/templates/vpn/ipsecpolicy.html:10
|
||||
#: netbox/templates/vpn/ipsecprofile.html:66 netbox/vpn/tables/crypto.py:170
|
||||
@ -14653,7 +14660,7 @@ msgstr "Peer-Abschlusspunkt"
|
||||
|
||||
#: netbox/templates/wireless/inc/authentication_attrs.html:12
|
||||
msgid "Cipher"
|
||||
msgstr "Verschlüsselungsalgorithmus"
|
||||
msgstr "Chiffre"
|
||||
|
||||
#: netbox/templates/wireless/inc/authentication_attrs.html:16
|
||||
msgid "PSK"
|
||||
@ -15631,6 +15638,8 @@ msgid ""
|
||||
"{device} belongs to a different site ({device_site}) than the cluster "
|
||||
"({cluster_site})"
|
||||
msgstr ""
|
||||
"{device} gehört zu einer anderen Seite ({device_site}) als der Cluster "
|
||||
"({cluster_site})"
|
||||
|
||||
#: netbox/virtualization/forms/model_forms.py:192
|
||||
msgid "Optionally pin this VM to a specific host device within the cluster"
|
||||
@ -15968,7 +15977,7 @@ msgstr "SA-Lebendauer"
|
||||
#: netbox/wireless/forms/filtersets.py:64
|
||||
#: netbox/wireless/forms/filtersets.py:98
|
||||
msgid "Pre-shared key"
|
||||
msgstr "Vorab geteilter Schlüssel (PSK)"
|
||||
msgstr "Vorab geteilter Schlüssel (Pre-shared key)"
|
||||
|
||||
#: netbox/vpn/forms/bulk_edit.py:237 netbox/vpn/forms/bulk_import.py:239
|
||||
#: netbox/vpn/forms/filtersets.py:199 netbox/vpn/forms/model_forms.py:370
|
||||
@ -15984,7 +15993,7 @@ msgstr "IPSec-Richtlinie"
|
||||
|
||||
#: netbox/vpn/forms/bulk_import.py:50
|
||||
msgid "Tunnel encapsulation"
|
||||
msgstr "Tunnel Encapsulation"
|
||||
msgstr "Tunnelkapselung"
|
||||
|
||||
#: netbox/vpn/forms/bulk_import.py:83
|
||||
msgid "Operational role"
|
||||
@ -16131,7 +16140,7 @@ msgstr "Vorschläge"
|
||||
|
||||
#: netbox/vpn/models/crypto.py:91 netbox/wireless/models.py:39
|
||||
msgid "pre-shared key"
|
||||
msgstr "vorab geteilter Schlüssel (PSK)"
|
||||
msgstr "vorab geteilter Schlüssel"
|
||||
|
||||
#: netbox/vpn/models/crypto.py:105
|
||||
msgid "IKE policies"
|
||||
@ -16264,7 +16273,7 @@ msgstr "SA-Lebensdauer"
|
||||
|
||||
#: netbox/vpn/tables/crypto.py:71
|
||||
msgid "Pre-shared Key"
|
||||
msgstr "Vorab geteilter Schlüssel (PSK)"
|
||||
msgstr "Vorab geteilter Schlüssel"
|
||||
|
||||
#: netbox/vpn/tables/crypto.py:103
|
||||
msgid "SA Lifetime (Seconds)"
|
||||
@ -16381,6 +16390,7 @@ msgstr "Funkverbindungen"
|
||||
#: netbox/wireless/models.py:236
|
||||
msgid "Must specify a unit when setting a wireless distance"
|
||||
msgstr ""
|
||||
"Beim Einstellen einer Funkreichweite muss eine Einheit angegeben werden"
|
||||
|
||||
#: netbox/wireless/models.py:242 netbox/wireless/models.py:248
|
||||
#, python-brace-format
|
||||
|
File diff suppressed because it is too large
Load Diff
Binary file not shown.
@ -25,7 +25,7 @@ msgstr ""
|
||||
#: netbox/templates/users/token.html:17 netbox/users/forms/bulk_import.py:39
|
||||
#: netbox/users/forms/model_forms.py:112
|
||||
msgid "Key"
|
||||
msgstr "Clave"
|
||||
msgstr "Llave"
|
||||
|
||||
#: netbox/account/tables.py:31 netbox/users/forms/filtersets.py:132
|
||||
msgid "Write Enabled"
|
||||
@ -61,7 +61,7 @@ msgstr "Utilizado por última vez"
|
||||
#: netbox/templates/users/token.html:47 netbox/users/forms/bulk_edit.py:122
|
||||
#: netbox/users/forms/model_forms.py:124
|
||||
msgid "Allowed IPs"
|
||||
msgstr "IP permitidas"
|
||||
msgstr "IPs permitidas"
|
||||
|
||||
#: netbox/account/views.py:114
|
||||
#, python-brace-format
|
||||
@ -117,7 +117,7 @@ msgstr "Activo"
|
||||
#: netbox/dcim/choices.py:1659 netbox/virtualization/choices.py:24
|
||||
#: netbox/virtualization/choices.py:43
|
||||
msgid "Offline"
|
||||
msgstr "Fuera de línea"
|
||||
msgstr "Desconectado"
|
||||
|
||||
#: netbox/circuits/choices.py:25
|
||||
msgid "Deprovisioning"
|
||||
@ -125,7 +125,7 @@ msgstr "Desaprovisionamiento"
|
||||
|
||||
#: netbox/circuits/choices.py:26
|
||||
msgid "Decommissioned"
|
||||
msgstr "Retirado"
|
||||
msgstr "Desmantelado"
|
||||
|
||||
#: netbox/circuits/choices.py:90 netbox/dcim/choices.py:1619
|
||||
#: netbox/tenancy/choices.py:17
|
||||
@ -167,7 +167,7 @@ msgstr "Región (ID)"
|
||||
#: netbox/ipam/filtersets.py:968 netbox/virtualization/filtersets.py:52
|
||||
#: netbox/virtualization/filtersets.py:180 netbox/vpn/filtersets.py:353
|
||||
msgid "Region (slug)"
|
||||
msgstr "Región (babosa)"
|
||||
msgstr "Región (slug)"
|
||||
|
||||
#: netbox/circuits/filtersets.py:44 netbox/circuits/filtersets.py:211
|
||||
#: netbox/dcim/filtersets.py:128 netbox/dcim/filtersets.py:225
|
||||
@ -261,7 +261,7 @@ msgstr "Sitio"
|
||||
#: netbox/virtualization/filtersets.py:75
|
||||
#: netbox/virtualization/filtersets.py:203 netbox/vpn/filtersets.py:363
|
||||
msgid "Site (slug)"
|
||||
msgstr "Sitio (slug)"
|
||||
msgstr "Sitio (babosa)"
|
||||
|
||||
#: netbox/circuits/filtersets.py:67
|
||||
msgid "ASN (ID)"
|
||||
@ -284,7 +284,7 @@ msgstr "Proveedor (ID)"
|
||||
#: netbox/circuits/filtersets.py:162 netbox/circuits/filtersets.py:289
|
||||
#: netbox/circuits/filtersets.py:331 netbox/ipam/filtersets.py:251
|
||||
msgid "Provider (slug)"
|
||||
msgstr "Proveedor (slug)"
|
||||
msgstr "Proveedor (babosa)"
|
||||
|
||||
#: netbox/circuits/filtersets.py:167
|
||||
msgid "Provider account (ID)"
|
||||
@ -394,7 +394,7 @@ msgstr "Grupo de circuitos (slug)"
|
||||
#: netbox/netbox/navigation/menu.py:172 netbox/netbox/navigation/menu.py:175
|
||||
#: netbox/templates/circuits/provider.html:23
|
||||
msgid "ASNs"
|
||||
msgstr "ASN"
|
||||
msgstr "ASNs"
|
||||
|
||||
#: netbox/circuits/forms/bulk_edit.py:34 netbox/circuits/forms/bulk_edit.py:56
|
||||
#: netbox/circuits/forms/bulk_edit.py:83
|
||||
@ -1234,7 +1234,7 @@ msgstr "Asignaciones de grupos de circuitos"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:240
|
||||
msgid "termination"
|
||||
msgstr ""
|
||||
msgstr "terminación"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:257
|
||||
msgid "port speed (Kbps)"
|
||||
@ -1296,11 +1296,15 @@ msgstr "terminaciones de circuitos"
|
||||
msgid ""
|
||||
"A circuit termination must attach to either a site or a provider network."
|
||||
msgstr ""
|
||||
"Una terminación de circuito debe conectarse a un sitio o a una red de "
|
||||
"proveedores."
|
||||
|
||||
#: netbox/circuits/models/circuits.py:310
|
||||
msgid ""
|
||||
"A circuit termination cannot attach to both a site and a provider network."
|
||||
msgstr ""
|
||||
"Una terminación de circuito no puede conectarse tanto a un sitio como a una "
|
||||
"red de proveedores."
|
||||
|
||||
#: netbox/circuits/models/providers.py:22
|
||||
#: netbox/circuits/models/providers.py:66
|
||||
@ -9909,7 +9913,7 @@ msgstr "Gama ASN"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:231
|
||||
msgid "Site/VLAN Assignment"
|
||||
msgstr ""
|
||||
msgstr "Asignación de sitio/VLAN"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:259 netbox/templates/ipam/iprange.html:10
|
||||
msgid "IP Range"
|
||||
@ -12765,6 +12769,7 @@ msgstr "Error al renderizar la plantilla"
|
||||
#: netbox/templates/dcim/device/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this device."
|
||||
msgstr ""
|
||||
"No se ha asignado ninguna plantilla de configuración para este dispositivo."
|
||||
|
||||
#: netbox/templates/dcim/device_edit.html:44
|
||||
msgid "Parent Bay"
|
||||
@ -14034,7 +14039,7 @@ msgstr "Centro de ayuda"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:41
|
||||
msgid "Django Admin"
|
||||
msgstr ""
|
||||
msgstr "Administrador de Django"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:61
|
||||
msgid "Log Out"
|
||||
@ -14449,6 +14454,8 @@ msgstr "Agregar disco virtual"
|
||||
#: netbox/templates/virtualization/virtualmachine/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this virtual machine."
|
||||
msgstr ""
|
||||
"No se ha asignado ninguna plantilla de configuración para esta máquina "
|
||||
"virtual."
|
||||
|
||||
#: netbox/templates/vpn/ikepolicy.html:10
|
||||
#: netbox/templates/vpn/ipsecprofile.html:33 netbox/vpn/tables/crypto.py:166
|
||||
@ -15569,6 +15576,8 @@ msgid ""
|
||||
"{device} belongs to a different site ({device_site}) than the cluster "
|
||||
"({cluster_site})"
|
||||
msgstr ""
|
||||
"{device} pertenece a un sitio diferente ({device_site}) que el clúster "
|
||||
"({cluster_site})"
|
||||
|
||||
#: netbox/virtualization/forms/model_forms.py:192
|
||||
msgid "Optionally pin this VM to a specific host device within the cluster"
|
||||
@ -16308,7 +16317,7 @@ msgstr "enlaces inalámbricos"
|
||||
|
||||
#: netbox/wireless/models.py:236
|
||||
msgid "Must specify a unit when setting a wireless distance"
|
||||
msgstr ""
|
||||
msgstr "Debe especificar una unidad al configurar una distancia inalámbrica"
|
||||
|
||||
#: netbox/wireless/models.py:242 netbox/wireless/models.py:248
|
||||
#, python-brace-format
|
||||
|
Binary file not shown.
@ -11,10 +11,8 @@
|
||||
# Jean Benoit <jean@unistra.fr>, 2024
|
||||
# thomas rivemale, 2024
|
||||
# Jeff Gehlbach, 2024
|
||||
# Jeremy Stretch, 2024
|
||||
# marcpaulchand <paul@u129.fr>, 2025
|
||||
# Jeremy Stretch, 2025
|
||||
# Mathieu, 2025
|
||||
# Étienne Brunel, 2025
|
||||
#
|
||||
#, fuzzy
|
||||
msgid ""
|
||||
@ -23,7 +21,7 @@ msgstr ""
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2025-01-04 05:02+0000\n"
|
||||
"PO-Revision-Date: 2023-10-30 17:48+0000\n"
|
||||
"Last-Translator: Étienne Brunel, 2025\n"
|
||||
"Last-Translator: marcpaulchand <paul@u129.fr>, 2025\n"
|
||||
"Language-Team: French (https://app.transifex.com/netbox-community/teams/178115/fr/)\n"
|
||||
"MIME-Version: 1.0\n"
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
@ -937,7 +935,7 @@ msgstr "État opérationnel"
|
||||
#: netbox/vpn/forms/bulk_import.py:63 netbox/wireless/forms/bulk_import.py:59
|
||||
#: netbox/wireless/forms/bulk_import.py:101
|
||||
msgid "Assigned tenant"
|
||||
msgstr "Entité associée"
|
||||
msgstr "Locataire associé"
|
||||
|
||||
#: netbox/circuits/forms/bulk_import.py:120
|
||||
#: netbox/templates/circuits/inc/circuit_termination.html:6
|
||||
@ -1244,7 +1242,7 @@ msgstr "Assignations de groupes de circuits"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:240
|
||||
msgid "termination"
|
||||
msgstr ""
|
||||
msgstr "résiliation"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:257
|
||||
msgid "port speed (Kbps)"
|
||||
@ -1306,11 +1304,15 @@ msgstr "terminaisons de circuits"
|
||||
msgid ""
|
||||
"A circuit termination must attach to either a site or a provider network."
|
||||
msgstr ""
|
||||
"Une terminaison de circuit doit être connectée à un site ou à un réseau "
|
||||
"fournisseur."
|
||||
|
||||
#: netbox/circuits/models/circuits.py:310
|
||||
msgid ""
|
||||
"A circuit termination cannot attach to both a site and a provider network."
|
||||
msgstr ""
|
||||
"Une terminaison de circuit ne peut pas être connectée à la fois à un site et"
|
||||
" à un réseau fournisseur."
|
||||
|
||||
#: netbox/circuits/models/providers.py:22
|
||||
#: netbox/circuits/models/providers.py:66
|
||||
@ -3203,7 +3205,7 @@ msgstr "Est un membre virtuel du châssis"
|
||||
|
||||
#: netbox/dcim/filtersets.py:1164
|
||||
msgid "OOB IP (ID)"
|
||||
msgstr "GESTION HORS BANDE (ID)"
|
||||
msgstr "ASTUCE SUR L'EMPLOI (ID)"
|
||||
|
||||
#: netbox/dcim/filtersets.py:1168
|
||||
msgid "Has virtual device context"
|
||||
@ -3332,7 +3334,7 @@ msgstr "VRF (RD)"
|
||||
#: netbox/dcim/filtersets.py:1624 netbox/ipam/filtersets.py:1032
|
||||
#: netbox/vpn/filtersets.py:342
|
||||
msgid "L2VPN (ID)"
|
||||
msgstr "L2VPN (ID)"
|
||||
msgstr "L2VPN (IDENTIFIANT)"
|
||||
|
||||
#: netbox/dcim/filtersets.py:1630 netbox/dcim/forms/filtersets.py:1433
|
||||
#: netbox/dcim/tables/devices.py:570 netbox/ipam/filtersets.py:1038
|
||||
@ -3378,7 +3380,7 @@ msgstr "Contexte du périphérique virtuel"
|
||||
|
||||
#: netbox/dcim/filtersets.py:1719
|
||||
msgid "Virtual Device Context (Identifier)"
|
||||
msgstr "Contexte du périphérique virtuel (Identifiant)"
|
||||
msgstr "Contexte du périphérique virtuel (identifiant)"
|
||||
|
||||
#: netbox/dcim/filtersets.py:1730
|
||||
#: netbox/templates/wireless/wirelesslan.html:11
|
||||
@ -3416,12 +3418,12 @@ msgstr "Master (nom)"
|
||||
|
||||
#: netbox/dcim/filtersets.py:1939 netbox/tenancy/filtersets.py:245
|
||||
msgid "Tenant (ID)"
|
||||
msgstr "Entité (ID)"
|
||||
msgstr "Locataire (ID)"
|
||||
|
||||
#: netbox/dcim/filtersets.py:1945 netbox/extras/filtersets.py:618
|
||||
#: netbox/tenancy/filtersets.py:251
|
||||
msgid "Tenant (slug)"
|
||||
msgstr "Entité (slug)"
|
||||
msgstr "Locataire (slug)"
|
||||
|
||||
#: netbox/dcim/filtersets.py:1981 netbox/dcim/forms/filtersets.py:1077
|
||||
msgid "Unterminated"
|
||||
@ -3472,7 +3474,7 @@ msgstr "Téléphone de contact"
|
||||
|
||||
#: netbox/dcim/forms/bulk_edit.py:144
|
||||
msgid "Contact E-mail"
|
||||
msgstr "Adresse mail de contact"
|
||||
msgstr "Adresse électronique de contact"
|
||||
|
||||
#: netbox/dcim/forms/bulk_edit.py:147 netbox/dcim/forms/bulk_import.py:123
|
||||
#: netbox/dcim/forms/model_forms.py:128
|
||||
@ -3689,7 +3691,7 @@ msgstr "Étiquette d'actif"
|
||||
#: netbox/templates/dcim/moduletype.html:41 netbox/templates/dcim/rack.html:65
|
||||
#: netbox/templates/dcim/racktype.html:28
|
||||
msgid "Airflow"
|
||||
msgstr "Flux d'air"
|
||||
msgstr "Débit d'air"
|
||||
|
||||
#: netbox/dcim/forms/bulk_edit.py:446 netbox/dcim/forms/bulk_edit.py:925
|
||||
#: netbox/dcim/forms/bulk_import.py:344 netbox/dcim/forms/bulk_import.py:347
|
||||
@ -3730,7 +3732,7 @@ msgstr "Plateforme par défaut"
|
||||
#: netbox/dcim/forms/bulk_edit.py:511 netbox/dcim/forms/bulk_edit.py:570
|
||||
#: netbox/dcim/forms/filtersets.py:502 netbox/dcim/forms/filtersets.py:622
|
||||
msgid "Part number"
|
||||
msgstr "Référence de pièce"
|
||||
msgstr "Numéro de pièce"
|
||||
|
||||
#: netbox/dcim/forms/bulk_edit.py:515
|
||||
msgid "U height"
|
||||
@ -4231,7 +4233,7 @@ msgstr "Unité de poids de la baie"
|
||||
|
||||
#: netbox/dcim/forms/bulk_import.py:245
|
||||
msgid "Name of assigned tenant"
|
||||
msgstr "Nom de l'entité associée"
|
||||
msgstr "Nom du locataire associé"
|
||||
|
||||
#: netbox/dcim/forms/bulk_import.py:257
|
||||
msgid "Name of assigned role"
|
||||
@ -4248,11 +4250,11 @@ msgstr "Direction du flux d'air"
|
||||
|
||||
#: netbox/dcim/forms/bulk_import.py:324
|
||||
msgid "Width must be set if not specifying a rack type."
|
||||
msgstr "La largeur doit être définie si aucun type de rack n'est spécifié."
|
||||
msgstr ""
|
||||
|
||||
#: netbox/dcim/forms/bulk_import.py:326
|
||||
msgid "U height must be set if not specifying a rack type."
|
||||
msgstr "La hauteur U doit être définie si aucun type de rack n'est spécifié."
|
||||
msgstr ""
|
||||
|
||||
#: netbox/dcim/forms/bulk_import.py:334
|
||||
msgid "Parent site"
|
||||
@ -4338,7 +4340,7 @@ msgstr "Baie attribuée (le cas échéant)"
|
||||
|
||||
#: netbox/dcim/forms/bulk_import.py:582
|
||||
msgid "Face"
|
||||
msgstr "Orientation"
|
||||
msgstr "Visage"
|
||||
|
||||
#: netbox/dcim/forms/bulk_import.py:585
|
||||
msgid "Mounted rack face"
|
||||
@ -4425,11 +4427,11 @@ msgstr "Interface pour les parents"
|
||||
#: netbox/virtualization/forms/bulk_import.py:162
|
||||
#: netbox/virtualization/forms/model_forms.py:313
|
||||
msgid "Bridged interface"
|
||||
msgstr "Interface switchée"
|
||||
msgstr "Interface pontée"
|
||||
|
||||
#: netbox/dcim/forms/bulk_import.py:869
|
||||
msgid "Lag"
|
||||
msgstr "Lag"
|
||||
msgstr "Retard"
|
||||
|
||||
#: netbox/dcim/forms/bulk_import.py:873
|
||||
msgid "Parent LAG interface"
|
||||
@ -4458,7 +4460,7 @@ msgstr "Mode PoE"
|
||||
|
||||
#: netbox/dcim/forms/bulk_import.py:901
|
||||
msgid "Poe type"
|
||||
msgstr "Type de POE"
|
||||
msgstr "Type de poteau"
|
||||
|
||||
#: netbox/dcim/forms/bulk_import.py:910
|
||||
#: netbox/virtualization/forms/bulk_import.py:168
|
||||
@ -4917,11 +4919,6 @@ msgid ""
|
||||
"present, will be automatically replaced with the position value when "
|
||||
"creating a new module."
|
||||
msgstr ""
|
||||
"Les plages alphanumériques sont prises en charge pour la création en masse. "
|
||||
"Les mélanges de casses ou de types au sein d'une même plage ne sont pas pris"
|
||||
" en charge (exemple : <code>[ge,xe]-0/0/[0-9]</code>). Le jeton "
|
||||
"<code>{module}</code>, s'il est présent, sera automatiquement remplacé par "
|
||||
"la valeur de position lors de la création d'un nouveau module."
|
||||
|
||||
#: netbox/dcim/forms/model_forms.py:1094
|
||||
msgid "Console port template"
|
||||
@ -7627,7 +7624,7 @@ msgstr "Type de cluster (slug)"
|
||||
#: netbox/extras/filtersets.py:601 netbox/tenancy/forms/forms.py:16
|
||||
#: netbox/tenancy/forms/forms.py:39
|
||||
msgid "Tenant group"
|
||||
msgstr "Groupe d'entitées"
|
||||
msgstr "Groupe de locataires"
|
||||
|
||||
#: netbox/extras/filtersets.py:607 netbox/tenancy/filtersets.py:188
|
||||
#: netbox/tenancy/filtersets.py:208
|
||||
@ -7991,7 +7988,7 @@ msgstr "Clusters"
|
||||
#: netbox/extras/forms/filtersets.py:391
|
||||
#: netbox/extras/forms/model_forms.py:557
|
||||
msgid "Tenant groups"
|
||||
msgstr "Groupes d'entitées"
|
||||
msgstr "Groupes de locataires"
|
||||
|
||||
#: netbox/extras/forms/model_forms.py:49
|
||||
msgid "The type(s) of object that have this custom field"
|
||||
@ -8152,7 +8149,7 @@ msgstr "Groupe de notifications"
|
||||
#: netbox/extras/forms/model_forms.py:562 netbox/netbox/navigation/menu.py:26
|
||||
#: netbox/tenancy/tables/tenants.py:22
|
||||
msgid "Tenants"
|
||||
msgstr "Entité"
|
||||
msgstr "Locataires"
|
||||
|
||||
#: netbox/extras/forms/model_forms.py:606
|
||||
msgid "Data is populated from the remote source selected below."
|
||||
@ -8437,8 +8434,8 @@ msgid ""
|
||||
msgstr ""
|
||||
"Expression régulière à appliquer aux valeurs des champs de texte. Utilisez ^"
|
||||
" et $ pour forcer la mise en correspondance de la chaîne entière. Par "
|
||||
"exemple, <code>^[A-Z]{3}$</code> limitera les valeurs à exactement trois "
|
||||
"lettres majuscules."
|
||||
"exemple, <code>^ [DE A À Z]{3}$</code> limitera les valeurs à exactement "
|
||||
"trois lettres majuscules."
|
||||
|
||||
#: netbox/extras/models/customfields.py:201
|
||||
msgid "choice set"
|
||||
@ -8743,9 +8740,10 @@ msgid ""
|
||||
msgstr ""
|
||||
"Modèle Jinja2 pour un corps de requête personnalisé. Si ce champ est vide, "
|
||||
"un objet JSON représentant la modification sera inclus. Les données "
|
||||
"contextuelles disponibles incluent : <code>event</code>, <code>model</code>,"
|
||||
" <code>timestamp</code>, <code>username</code>, <code>request_id</code>, et "
|
||||
"<code>data</code>."
|
||||
"contextuelles disponibles incluent : <code>événement</code>, "
|
||||
"<code>modèle</code>, <code>horodatage</code>, <code>nom "
|
||||
"d'utilisateur</code>, <code>identifiant_demande</code>, et "
|
||||
"<code>données</code>."
|
||||
|
||||
#: netbox/extras/models/models.py:204
|
||||
msgid "secret"
|
||||
@ -8757,10 +8755,10 @@ msgid ""
|
||||
"header containing a HMAC hex digest of the payload body using the secret as "
|
||||
"the key. The secret is not transmitted in the request."
|
||||
msgstr ""
|
||||
"Lorsqu'elle sera fournie, la demande comprendra un <code>X-Hook-"
|
||||
"Signature</code> en-tête contenant un condensé hexadécimal HMAC du corps de "
|
||||
"la charge utile en utilisant le secret comme clé. Le secret n'est pas "
|
||||
"transmis dans la demande."
|
||||
"Lorsqu'elle sera fournie, la demande comprendra un <code>Signature "
|
||||
"X-Hook</code> en-tête contenant un condensé hexadécimal HMAC du corps de la "
|
||||
"charge utile en utilisant le secret comme clé. Le secret n'est pas transmis "
|
||||
"dans la demande."
|
||||
|
||||
#: netbox/extras/models/models.py:215
|
||||
msgid "Enable SSL certificate verification. Disable with caution!"
|
||||
@ -8843,11 +8841,13 @@ msgid ""
|
||||
"context variable named <code>queryset</code>."
|
||||
msgstr ""
|
||||
"Code du modèle Jinja2. La liste des objets exportés est transmise sous forme"
|
||||
" de variable de contexte nommée <code>queryset</code>."
|
||||
" de variable de contexte nommée <code>ensemble de requêtes</code>."
|
||||
|
||||
#: netbox/extras/models/models.py:410
|
||||
msgid "Defaults to <code>text/plain; charset=utf-8</code>"
|
||||
msgstr "La valeur par défaut est <code>text/plain; charset=utf-8</code>"
|
||||
msgstr ""
|
||||
"La valeur par défaut est <code>texte/plain ; jeu de caractères = "
|
||||
"utf-8</code>"
|
||||
|
||||
#: netbox/extras/models/models.py:413
|
||||
msgid "file extension"
|
||||
@ -9743,11 +9743,11 @@ msgstr "Faites-en l'adresse IP principale de l'appareil attribué"
|
||||
|
||||
#: netbox/ipam/forms/bulk_import.py:330
|
||||
msgid "Is out-of-band"
|
||||
msgstr "Est hors bande"
|
||||
msgstr ""
|
||||
|
||||
#: netbox/ipam/forms/bulk_import.py:331
|
||||
msgid "Designate this as the out-of-band IP address for the assigned device"
|
||||
msgstr "Désignez-le comme adresse IP hors bande pour l'appareil attribué"
|
||||
msgstr ""
|
||||
|
||||
#: netbox/ipam/forms/bulk_import.py:371
|
||||
msgid "No device or virtual machine specified; cannot set as primary IP"
|
||||
@ -9758,13 +9758,10 @@ msgstr ""
|
||||
#: netbox/ipam/forms/bulk_import.py:375
|
||||
msgid "No device specified; cannot set as out-of-band IP"
|
||||
msgstr ""
|
||||
"Aucun appareil n'a été spécifié ; impossible de le définir comme IP hors "
|
||||
"bande"
|
||||
|
||||
#: netbox/ipam/forms/bulk_import.py:379
|
||||
msgid "Cannot set out-of-band IP for virtual machines"
|
||||
msgstr ""
|
||||
"Impossible de définir une adresse IP hors bande pour les machines virtuelles"
|
||||
|
||||
#: netbox/ipam/forms/bulk_import.py:383
|
||||
msgid "No interface specified; cannot set as primary IP"
|
||||
@ -9775,7 +9772,6 @@ msgstr ""
|
||||
#: netbox/ipam/forms/bulk_import.py:387
|
||||
msgid "No interface specified; cannot set as out-of-band IP"
|
||||
msgstr ""
|
||||
"Aucune interface spécifiée ; impossible de définir comme IP hors bande"
|
||||
|
||||
#: netbox/ipam/forms/bulk_import.py:422
|
||||
msgid "Auth type"
|
||||
@ -9934,7 +9930,7 @@ msgstr "Plage ASN"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:231
|
||||
msgid "Site/VLAN Assignment"
|
||||
msgstr ""
|
||||
msgstr "Affectation de site/VLAN"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:259 netbox/templates/ipam/iprange.html:10
|
||||
msgid "IP Range"
|
||||
@ -9953,7 +9949,7 @@ msgstr ""
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:314
|
||||
msgid "Make this the out-of-band IP for the device"
|
||||
msgstr "Choisissez cette adresse IP hors bande pour l'appareil"
|
||||
msgstr ""
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:329
|
||||
msgid "NAT IP (Inside)"
|
||||
@ -9966,12 +9962,10 @@ msgstr "Une adresse IP ne peut être attribuée qu'à un seul objet."
|
||||
#: netbox/ipam/forms/model_forms.py:398
|
||||
msgid "Cannot reassign primary IP address for the parent device/VM"
|
||||
msgstr ""
|
||||
"Impossible de réattribuer l'adresse IP principale à l'appareil parent/à la "
|
||||
"machine virtuelle"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:402
|
||||
msgid "Cannot reassign out-of-Band IP address for the parent device"
|
||||
msgstr "Impossible de réattribuer l'adresse IP hors bande à l'appareil parent"
|
||||
msgstr ""
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:412
|
||||
msgid ""
|
||||
@ -9985,8 +9979,6 @@ msgid ""
|
||||
"Only IP addresses assigned to a device interface can be designated as the "
|
||||
"out-of-band IP for a device."
|
||||
msgstr ""
|
||||
"Seules les adresses IP attribuées à l'interface d'un appareil peuvent être "
|
||||
"désignées comme IP hors bande pour un appareil."
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:508
|
||||
msgid "Virtual IP Address"
|
||||
@ -10397,14 +10389,11 @@ msgstr "Impossible de définir scope_id sans scope_type."
|
||||
#, python-brace-format
|
||||
msgid "Starting VLAN ID in range ({value}) cannot be less than {minimum}"
|
||||
msgstr ""
|
||||
"ID de VLAN de démarrage dans la plage ({value}) ne peut pas être inférieur à"
|
||||
" {minimum}"
|
||||
|
||||
#: netbox/ipam/models/vlans.py:111
|
||||
#, python-brace-format
|
||||
msgid "Ending VLAN ID in range ({value}) cannot exceed {maximum}"
|
||||
msgstr ""
|
||||
"Fin de l'ID VLAN dans la plage ({value}) ne peut pas dépasser {maximum}"
|
||||
|
||||
#: netbox/ipam/models/vlans.py:118
|
||||
#, python-brace-format
|
||||
@ -10412,8 +10401,6 @@ msgid ""
|
||||
"Ending VLAN ID in range must be greater than or equal to the starting VLAN "
|
||||
"ID ({range})"
|
||||
msgstr ""
|
||||
"L'ID VLAN final dans la plage doit être supérieur ou égal à l'ID VLAN de "
|
||||
"départ ({range})"
|
||||
|
||||
#: netbox/ipam/models/vlans.py:124
|
||||
msgid "Ranges cannot overlap."
|
||||
@ -12800,7 +12787,7 @@ msgstr "Télécharger"
|
||||
#: netbox/templates/dcim/device/render_config.html:64
|
||||
#: netbox/templates/virtualization/virtualmachine/render_config.html:64
|
||||
msgid "Error rendering template"
|
||||
msgstr "Erreur lors du rendu du modèle"
|
||||
msgstr ""
|
||||
|
||||
#: netbox/templates/dcim/device/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this device."
|
||||
@ -13335,8 +13322,8 @@ msgstr ""
|
||||
"installation de NetBox. Ces paquets sont répertoriés dans "
|
||||
"<code>requirements.txt</code> et <code>local_requirements.txt</code>, et "
|
||||
"sont normalement installés dans le cadre du processus d'installation ou de "
|
||||
"mise à jour. Pour vérifier les paquets installés, exécutez <code>pip "
|
||||
"freeze</code> depuis la console et comparez la sortie à la liste des paquets"
|
||||
"mise à jour. Pour vérifier les paquets installés, exécutez <code>Pip "
|
||||
"Freeze</code> depuis la console et comparez la sortie à la liste des paquets"
|
||||
" requis."
|
||||
|
||||
#: netbox/templates/exceptions/import_error.html:20
|
||||
@ -13674,7 +13661,7 @@ msgstr "Exécutez à nouveau"
|
||||
#: netbox/templates/extras/script_list.html:133
|
||||
#, python-format
|
||||
msgid "Could not load scripts from module %(module)s"
|
||||
msgstr "Impossible de charger les scripts depuis le module %(module)s"
|
||||
msgstr ""
|
||||
|
||||
#: netbox/templates/extras/script_list.html:141
|
||||
msgid "No Scripts Found"
|
||||
@ -14076,7 +14063,7 @@ msgstr "Centre d'aide"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:41
|
||||
msgid "Django Admin"
|
||||
msgstr ""
|
||||
msgstr "Administrateur Django"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:61
|
||||
msgid "Log Out"
|
||||
@ -14913,7 +14900,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Réseaux IPv4/IPv6 autorisés à partir desquels le jeton peut être utilisé. "
|
||||
"Laissez ce champ vide pour éviter toute restriction. Exemple : "
|
||||
"<code>10.1.1.0/24,192.168.10.16/32,2001:db8:1::/64</code>"
|
||||
"<code>10.1.1.0/24 192.168.10,16/32 2001 : db 8:1 : /64</code>"
|
||||
|
||||
#: netbox/users/forms/model_forms.py:175
|
||||
msgid "Confirm password"
|
||||
@ -15205,7 +15192,7 @@ msgid ""
|
||||
"<code>1-5,20-30</code>"
|
||||
msgstr ""
|
||||
"Spécifiez une ou plusieurs plages numériques séparées par des virgules. "
|
||||
"Exemple : <code>1-5,20-30</code>"
|
||||
"Exemple : <code>1 à 5, 20 à 30</code>"
|
||||
|
||||
#: netbox/utilities/forms/fields/array.py:47
|
||||
#, python-brace-format
|
||||
@ -15607,6 +15594,8 @@ msgid ""
|
||||
"{device} belongs to a different site ({device_site}) than the cluster "
|
||||
"({cluster_site})"
|
||||
msgstr ""
|
||||
"{device} appartient à un autre site ({device_site}) puis le cluster "
|
||||
"({cluster_site})"
|
||||
|
||||
#: netbox/virtualization/forms/model_forms.py:192
|
||||
msgid "Optionally pin this VM to a specific host device within the cluster"
|
||||
@ -16349,6 +16338,7 @@ msgstr "liaisons sans fil"
|
||||
#: netbox/wireless/models.py:236
|
||||
msgid "Must specify a unit when setting a wireless distance"
|
||||
msgstr ""
|
||||
"Vous devez spécifier une unité lors du réglage d'une distance sans fil"
|
||||
|
||||
#: netbox/wireless/models.py:242 netbox/wireless/models.py:248
|
||||
#, python-brace-format
|
||||
|
Binary file not shown.
@ -1237,7 +1237,7 @@ msgstr "Assegnazioni di gruppi di circuiti"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:240
|
||||
msgid "termination"
|
||||
msgstr ""
|
||||
msgstr "fine"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:257
|
||||
msgid "port speed (Kbps)"
|
||||
@ -1299,11 +1299,15 @@ msgstr "terminazioni del circuito"
|
||||
msgid ""
|
||||
"A circuit termination must attach to either a site or a provider network."
|
||||
msgstr ""
|
||||
"Una terminazione di circuito deve essere collegata a un sito o alla rete di "
|
||||
"un provider."
|
||||
|
||||
#: netbox/circuits/models/circuits.py:310
|
||||
msgid ""
|
||||
"A circuit termination cannot attach to both a site and a provider network."
|
||||
msgstr ""
|
||||
"Una terminazione di circuito non può essere collegata sia a un sito che alla"
|
||||
" rete di un provider."
|
||||
|
||||
#: netbox/circuits/models/providers.py:22
|
||||
#: netbox/circuits/models/providers.py:66
|
||||
@ -9932,7 +9936,7 @@ msgstr "Gamma ASN"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:231
|
||||
msgid "Site/VLAN Assignment"
|
||||
msgstr ""
|
||||
msgstr "Assegnazione sito/VLAN"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:259 netbox/templates/ipam/iprange.html:10
|
||||
msgid "IP Range"
|
||||
@ -12793,6 +12797,8 @@ msgstr "Errore nel rendering del modello"
|
||||
#: netbox/templates/dcim/device/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this device."
|
||||
msgstr ""
|
||||
"Non è stato assegnato alcun modello di configurazione per questo "
|
||||
"dispositivo."
|
||||
|
||||
#: netbox/templates/dcim/device_edit.html:44
|
||||
msgid "Parent Bay"
|
||||
@ -14064,7 +14070,7 @@ msgstr "Centro assistenza"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:41
|
||||
msgid "Django Admin"
|
||||
msgstr ""
|
||||
msgstr "Amministratore Django"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:61
|
||||
msgid "Log Out"
|
||||
@ -14479,6 +14485,8 @@ msgstr "Aggiungi disco virtuale"
|
||||
#: netbox/templates/virtualization/virtualmachine/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this virtual machine."
|
||||
msgstr ""
|
||||
"Non è stato assegnato alcun modello di configurazione per questa macchina "
|
||||
"virtuale."
|
||||
|
||||
#: netbox/templates/vpn/ikepolicy.html:10
|
||||
#: netbox/templates/vpn/ipsecprofile.html:33 netbox/vpn/tables/crypto.py:166
|
||||
@ -15592,6 +15600,8 @@ msgid ""
|
||||
"{device} belongs to a different site ({device_site}) than the cluster "
|
||||
"({cluster_site})"
|
||||
msgstr ""
|
||||
"{device} appartiene a un sito diverso ({device_site}) rispetto al cluster "
|
||||
"({cluster_site})"
|
||||
|
||||
#: netbox/virtualization/forms/model_forms.py:192
|
||||
msgid "Optionally pin this VM to a specific host device within the cluster"
|
||||
@ -16334,6 +16344,7 @@ msgstr "collegamenti wireless"
|
||||
#: netbox/wireless/models.py:236
|
||||
msgid "Must specify a unit when setting a wireless distance"
|
||||
msgstr ""
|
||||
"È necessario specificare un'unità quando si imposta una distanza wireless"
|
||||
|
||||
#: netbox/wireless/models.py:242 netbox/wireless/models.py:248
|
||||
#, python-brace-format
|
||||
|
Binary file not shown.
@ -5,8 +5,8 @@
|
||||
#
|
||||
# Translators:
|
||||
# Tatsuya Ueda <ml@tatsuya.info>, 2024
|
||||
# Jeremy Stretch, 2024
|
||||
# teapot, 2025
|
||||
# teapot, 2024
|
||||
# Jeremy Stretch, 2025
|
||||
#
|
||||
#, fuzzy
|
||||
msgid ""
|
||||
@ -15,7 +15,7 @@ msgstr ""
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2025-01-04 05:02+0000\n"
|
||||
"PO-Revision-Date: 2023-10-30 17:48+0000\n"
|
||||
"Last-Translator: teapot, 2025\n"
|
||||
"Last-Translator: Jeremy Stretch, 2025\n"
|
||||
"Language-Team: Japanese (https://app.transifex.com/netbox-community/teams/178115/ja/)\n"
|
||||
"MIME-Version: 1.0\n"
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
@ -1234,7 +1234,7 @@ msgstr "割当回線グループ"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:240
|
||||
msgid "termination"
|
||||
msgstr ""
|
||||
msgstr "終了"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:257
|
||||
msgid "port speed (Kbps)"
|
||||
@ -1295,12 +1295,12 @@ msgstr "回線終端"
|
||||
#: netbox/circuits/models/circuits.py:308
|
||||
msgid ""
|
||||
"A circuit termination must attach to either a site or a provider network."
|
||||
msgstr ""
|
||||
msgstr "回線終端は、サイトまたはプロバイダーネットワークに接続する必要があります。"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:310
|
||||
msgid ""
|
||||
"A circuit termination cannot attach to both a site and a provider network."
|
||||
msgstr ""
|
||||
msgstr "回線終端をサイトとプロバイダーネットワークの両方に接続することはできません。"
|
||||
|
||||
#: netbox/circuits/models/providers.py:22
|
||||
#: netbox/circuits/models/providers.py:66
|
||||
@ -1565,7 +1565,7 @@ msgstr "コメント"
|
||||
#: netbox/templates/tenancy/contact.html:84
|
||||
#: netbox/tenancy/tables/contacts.py:73
|
||||
msgid "Assignments"
|
||||
msgstr "割当"
|
||||
msgstr "アサイメント"
|
||||
|
||||
#: netbox/circuits/tables/providers.py:23
|
||||
msgid "Accounts"
|
||||
@ -1660,7 +1660,7 @@ msgstr "削除"
|
||||
|
||||
#: netbox/core/constants.py:19 netbox/core/tables/tasks.py:30
|
||||
msgid "Finished"
|
||||
msgstr "終了済"
|
||||
msgstr "終了しました"
|
||||
|
||||
#: netbox/core/constants.py:21 netbox/core/tables/jobs.py:38
|
||||
#: netbox/templates/core/job.html:82
|
||||
@ -1670,15 +1670,15 @@ msgstr "開始日時"
|
||||
|
||||
#: netbox/core/constants.py:22 netbox/core/tables/tasks.py:26
|
||||
msgid "Deferred"
|
||||
msgstr "延期済"
|
||||
msgstr "延期"
|
||||
|
||||
#: netbox/core/constants.py:24
|
||||
msgid "Stopped"
|
||||
msgstr "停止済"
|
||||
msgstr "停止しました"
|
||||
|
||||
#: netbox/core/constants.py:25
|
||||
msgid "Cancelled"
|
||||
msgstr "キャンセル済"
|
||||
msgstr "キャンセルされました"
|
||||
|
||||
#: netbox/core/data_backends.py:32 netbox/core/tables/plugins.py:51
|
||||
#: netbox/templates/core/plugin.html:88
|
||||
@ -1923,7 +1923,7 @@ msgstr "バックエンド設定"
|
||||
|
||||
#: netbox/core/forms/model_forms.py:96
|
||||
msgid "File Upload"
|
||||
msgstr "アップロード"
|
||||
msgstr "ファイルのアップロード"
|
||||
|
||||
#: netbox/core/forms/model_forms.py:108
|
||||
msgid "Cannot upload a file and sync from an existing file"
|
||||
@ -1972,7 +1972,7 @@ msgstr "ページネーション"
|
||||
#: netbox/extras/forms/model_forms.py:129
|
||||
#: netbox/templates/core/inc/config_data.html:93
|
||||
msgid "Validation"
|
||||
msgstr "検証"
|
||||
msgstr "バリデーション"
|
||||
|
||||
#: netbox/core/forms/model_forms.py:164
|
||||
#: netbox/templates/account/preferences.html:6
|
||||
@ -2045,7 +2045,7 @@ msgstr "このオブジェクトタイプ ({type}) では変更ログはサポ
|
||||
#: netbox/extras/models/notifications.py:186
|
||||
#: netbox/netbox/models/features.py:53 netbox/users/models/tokens.py:32
|
||||
msgid "created"
|
||||
msgstr "作成"
|
||||
msgstr "作成日時"
|
||||
|
||||
#: netbox/core/models/config.py:22
|
||||
msgid "comment"
|
||||
@ -2380,7 +2380,7 @@ msgstr "最も古いタスク"
|
||||
|
||||
#: netbox/core/tables/tasks.py:42 netbox/templates/core/rq_worker_list.html:39
|
||||
msgid "Workers"
|
||||
msgstr "ワーカー"
|
||||
msgstr "労働者"
|
||||
|
||||
#: netbox/core/tables/tasks.py:46 netbox/vpn/tables/tunnels.py:88
|
||||
msgid "Host"
|
||||
@ -2939,7 +2939,7 @@ msgstr "AS (ID)"
|
||||
|
||||
#: netbox/dcim/filtersets.py:246
|
||||
msgid "Parent location (ID)"
|
||||
msgstr "親のロケーション (ID)"
|
||||
msgstr "親の場所 (ID)"
|
||||
|
||||
#: netbox/dcim/filtersets.py:252
|
||||
msgid "Parent location (slug)"
|
||||
@ -3052,7 +3052,7 @@ msgstr "電源コンセントがある"
|
||||
#: netbox/dcim/filtersets.py:1147 netbox/dcim/forms/filtersets.py:559
|
||||
#: netbox/dcim/forms/filtersets.py:655 netbox/dcim/forms/filtersets.py:876
|
||||
msgid "Has interfaces"
|
||||
msgstr "インタフェースを持つ"
|
||||
msgstr "インタフェースがある"
|
||||
|
||||
#: netbox/dcim/filtersets.py:587 netbox/dcim/filtersets.py:708
|
||||
#: netbox/dcim/filtersets.py:1151 netbox/dcim/forms/filtersets.py:566
|
||||
@ -3121,7 +3121,7 @@ msgstr "サイト名 (slug)"
|
||||
|
||||
#: netbox/dcim/filtersets.py:1067
|
||||
msgid "Parent bay (ID)"
|
||||
msgstr "親ベイ (ID)"
|
||||
msgstr "ペアレントベイ (ID)"
|
||||
|
||||
#: netbox/dcim/filtersets.py:1071
|
||||
msgid "VM cluster (ID)"
|
||||
@ -3368,11 +3368,11 @@ msgstr "親モジュールベイ (ID)"
|
||||
|
||||
#: netbox/dcim/filtersets.py:1808
|
||||
msgid "Installed module (ID)"
|
||||
msgstr "インストール済モジュール (ID)"
|
||||
msgstr "インストール済みモジュール (ID)"
|
||||
|
||||
#: netbox/dcim/filtersets.py:1819
|
||||
msgid "Installed device (ID)"
|
||||
msgstr "インストール済デバイス (ID)"
|
||||
msgstr "インストール済みデバイス (ID)"
|
||||
|
||||
#: netbox/dcim/filtersets.py:1825
|
||||
msgid "Installed device (name)"
|
||||
@ -4728,7 +4728,7 @@ msgstr "クラスタグループ"
|
||||
|
||||
#: netbox/dcim/forms/filtersets.py:1210
|
||||
msgid "Cabled"
|
||||
msgstr "配線済"
|
||||
msgstr "ケーブル接続済"
|
||||
|
||||
#: netbox/dcim/forms/filtersets.py:1217
|
||||
msgid "Occupied"
|
||||
@ -6820,7 +6820,7 @@ msgstr "奥行きをすべて利用する"
|
||||
|
||||
#: netbox/dcim/tables/devicetypes.py:98
|
||||
msgid "U Height"
|
||||
msgstr "ユニット数"
|
||||
msgstr "U 高さ"
|
||||
|
||||
#: netbox/dcim/tables/devicetypes.py:113 netbox/dcim/tables/modules.py:26
|
||||
#: netbox/dcim/tables/racks.py:89
|
||||
@ -7895,7 +7895,7 @@ msgstr "テンプレートコード"
|
||||
#: netbox/extras/forms/model_forms.py:247
|
||||
#: netbox/templates/extras/exporttemplate.html:12
|
||||
msgid "Export Template"
|
||||
msgstr "エクスポートテンプレート"
|
||||
msgstr "テンプレートをエクスポート"
|
||||
|
||||
#: netbox/extras/forms/model_forms.py:249
|
||||
msgid "Rendering"
|
||||
@ -8204,7 +8204,7 @@ msgstr "最大許容値 (数値フィールド用)"
|
||||
|
||||
#: netbox/extras/models/customfields.py:191
|
||||
msgid "validation regex"
|
||||
msgstr "検証正規表現"
|
||||
msgstr "バリデーション正規表現"
|
||||
|
||||
#: netbox/extras/models/customfields.py:193
|
||||
#, python-brace-format
|
||||
@ -9071,11 +9071,11 @@ msgstr "スタンダード"
|
||||
|
||||
#: netbox/ipam/choices.py:120
|
||||
msgid "CheckPoint"
|
||||
msgstr "CheckPoint"
|
||||
msgstr "チェックポイント"
|
||||
|
||||
#: netbox/ipam/choices.py:123
|
||||
msgid "Cisco"
|
||||
msgstr "Cisco"
|
||||
msgstr "シスコ"
|
||||
|
||||
#: netbox/ipam/choices.py:137
|
||||
msgid "Plaintext"
|
||||
@ -9295,7 +9295,7 @@ msgstr "重複を禁止する"
|
||||
|
||||
#: netbox/ipam/forms/bulk_edit.py:88
|
||||
msgid "Is private"
|
||||
msgstr "非公開"
|
||||
msgstr "非公開です"
|
||||
|
||||
#: netbox/ipam/forms/bulk_edit.py:109 netbox/ipam/forms/bulk_edit.py:138
|
||||
#: netbox/ipam/forms/bulk_edit.py:163 netbox/ipam/forms/bulk_import.py:89
|
||||
@ -9472,7 +9472,7 @@ msgstr "割当インタフェースの親VM (存在する場合)"
|
||||
|
||||
#: netbox/ipam/forms/bulk_import.py:325
|
||||
msgid "Is primary"
|
||||
msgstr "プライマリ"
|
||||
msgstr "プライマリか"
|
||||
|
||||
#: netbox/ipam/forms/bulk_import.py:326
|
||||
msgid "Make this the primary IP for the assigned device"
|
||||
@ -9663,7 +9663,7 @@ msgstr "ASN レンジ"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:231
|
||||
msgid "Site/VLAN Assignment"
|
||||
msgstr ""
|
||||
msgstr "サイト/VLAN 割り当て"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:259 netbox/templates/ipam/iprange.html:10
|
||||
msgid "IP Range"
|
||||
@ -10243,7 +10243,7 @@ msgstr "NAT (アウトサイド)"
|
||||
|
||||
#: netbox/ipam/tables/ip.py:393
|
||||
msgid "Assigned"
|
||||
msgstr "割当済"
|
||||
msgstr "割当済み"
|
||||
|
||||
#: netbox/ipam/tables/ip.py:429 netbox/templates/vpn/l2vpntermination.html:16
|
||||
#: netbox/vpn/forms/filtersets.py:240
|
||||
@ -10498,7 +10498,7 @@ msgstr "グローバルテーブル内で一意の IP アドレスを強制す
|
||||
#: netbox/netbox/config/parameters.py:75
|
||||
#: netbox/templates/core/inc/config_data.html:44
|
||||
msgid "Prefer IPv4"
|
||||
msgstr "IPv4 を優先"
|
||||
msgstr "IPv4 を優先する"
|
||||
|
||||
#: netbox/netbox/config/parameters.py:77
|
||||
msgid "Prefer IPv4 addresses over IPv6"
|
||||
@ -10982,7 +10982,7 @@ msgstr "エクスポートテンプレート"
|
||||
|
||||
#: netbox/netbox/navigation/menu.py:329
|
||||
msgid "Saved Filters"
|
||||
msgstr "保存済フィルタ"
|
||||
msgstr "保存済みフィルタ"
|
||||
|
||||
#: netbox/netbox/navigation/menu.py:331
|
||||
msgid "Image Attachments"
|
||||
@ -11006,7 +11006,7 @@ msgstr "イベントルール"
|
||||
|
||||
#: netbox/netbox/navigation/menu.py:357
|
||||
msgid "Webhooks"
|
||||
msgstr "Webhooks"
|
||||
msgstr "ウェブフック"
|
||||
|
||||
#: netbox/netbox/navigation/menu.py:361 netbox/netbox/navigation/menu.py:365
|
||||
#: netbox/netbox/views/generic/feature_views.py:153
|
||||
@ -11201,7 +11201,7 @@ msgstr "デンマーク語"
|
||||
|
||||
#: netbox/netbox/settings.py:762
|
||||
msgid "German"
|
||||
msgstr "ドイツ語"
|
||||
msgstr "ドイツ人"
|
||||
|
||||
#: netbox/netbox/settings.py:763
|
||||
msgid "English"
|
||||
@ -11899,7 +11899,7 @@ msgstr "ユーザープリファレンス"
|
||||
|
||||
#: netbox/templates/core/inc/config_data.html:141
|
||||
msgid "Job retention"
|
||||
msgstr "ジョブの維持"
|
||||
msgstr "仕事の維持"
|
||||
|
||||
#: netbox/templates/core/job.html:35 netbox/templates/core/rq_task.html:12
|
||||
#: netbox/templates/core/rq_task.html:49 netbox/templates/core/rq_task.html:58
|
||||
@ -11959,7 +11959,7 @@ msgstr "警告:非アトミックな変更と以前の変更レコードの比
|
||||
|
||||
#: netbox/templates/core/objectchange.html:131
|
||||
msgid "Post-Change Data"
|
||||
msgstr "変更後データ"
|
||||
msgstr "変更後のデータ"
|
||||
|
||||
#: netbox/templates/core/objectchange.html:162
|
||||
#, python-format
|
||||
@ -12144,11 +12144,11 @@ msgstr "システムステータス"
|
||||
|
||||
#: netbox/templates/core/system.html:31
|
||||
msgid "NetBox release"
|
||||
msgstr "NetBoxリリース"
|
||||
msgstr "ネットボックスリリース"
|
||||
|
||||
#: netbox/templates/core/system.html:44
|
||||
msgid "Django version"
|
||||
msgstr "Djangoバージョン"
|
||||
msgstr "ジャンゴバージョン"
|
||||
|
||||
#: netbox/templates/core/system.html:48
|
||||
msgid "PostgreSQL version"
|
||||
@ -12313,7 +12313,7 @@ msgstr "用の NAT"
|
||||
#: netbox/templates/virtualization/virtualmachine.html:59
|
||||
#: netbox/templates/virtualization/virtualmachine.html:75
|
||||
msgid "NAT"
|
||||
msgstr "NAT"
|
||||
msgstr "ナット"
|
||||
|
||||
#: netbox/templates/dcim/device.html:252 netbox/templates/dcim/rack.html:73
|
||||
msgid "Power Utilization"
|
||||
@ -12441,11 +12441,11 @@ msgstr "エラーレンダリングテンプレート"
|
||||
|
||||
#: netbox/templates/dcim/device/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this device."
|
||||
msgstr ""
|
||||
msgstr "このデバイスには設定テンプレートが割り当てられていません。"
|
||||
|
||||
#: netbox/templates/dcim/device_edit.html:44
|
||||
msgid "Parent Bay"
|
||||
msgstr "親ベイ"
|
||||
msgstr "ペアレントベイ"
|
||||
|
||||
#: netbox/templates/dcim/device_edit.html:48
|
||||
#: netbox/utilities/templates/form_helpers/render_field.html:22
|
||||
@ -12475,7 +12475,7 @@ msgstr "デバイスベイ"
|
||||
|
||||
#: netbox/templates/dcim/devicebay.html:43
|
||||
msgid "Installed Device"
|
||||
msgstr "取付済デバイス"
|
||||
msgstr "取付済みデバイス"
|
||||
|
||||
#: netbox/templates/dcim/devicebay_depopulate.html:6
|
||||
#, python-format
|
||||
@ -12561,15 +12561,15 @@ msgstr "B サイド"
|
||||
|
||||
#: netbox/templates/dcim/inc/cable_termination.html:65
|
||||
msgid "No termination"
|
||||
msgstr "未終端"
|
||||
msgstr "終了なし"
|
||||
|
||||
#: netbox/templates/dcim/inc/cable_toggle_buttons.html:3
|
||||
msgid "Mark Planned"
|
||||
msgstr "計画中とマークする"
|
||||
msgstr "マーク・プランド"
|
||||
|
||||
#: netbox/templates/dcim/inc/cable_toggle_buttons.html:6
|
||||
msgid "Mark Installed"
|
||||
msgstr "取付済とマークする"
|
||||
msgstr "取付済みとマークする"
|
||||
|
||||
#: netbox/templates/dcim/inc/connection_endpoints.html:13
|
||||
msgid "Path Status"
|
||||
@ -12688,7 +12688,7 @@ msgstr "チャンネル幅"
|
||||
#: netbox/wireless/forms/filtersets.py:80 netbox/wireless/models.py:82
|
||||
#: netbox/wireless/models.py:156 netbox/wireless/tables/wirelesslan.py:44
|
||||
msgid "SSID"
|
||||
msgstr "SSID"
|
||||
msgstr "言った"
|
||||
|
||||
#: netbox/templates/dcim/interface.html:305
|
||||
msgid "LAG Members"
|
||||
@ -13273,7 +13273,7 @@ msgstr "スクリプトはソースファイルに存在しなくなりました
|
||||
|
||||
#: netbox/templates/extras/script_list.html:47
|
||||
msgid "Last Run"
|
||||
msgstr "最終実行"
|
||||
msgstr "ラストラン"
|
||||
|
||||
#: netbox/templates/extras/script_list.html:62
|
||||
msgid "Script is no longer present in the source file"
|
||||
@ -13285,7 +13285,7 @@ msgstr "決して"
|
||||
|
||||
#: netbox/templates/extras/script_list.html:85
|
||||
msgid "Run Again"
|
||||
msgstr "再実行"
|
||||
msgstr "もう一度実行"
|
||||
|
||||
#: netbox/templates/extras/script_list.html:133
|
||||
#, python-format
|
||||
@ -13317,7 +13317,7 @@ msgstr "ログ閾値"
|
||||
|
||||
#: netbox/templates/extras/script_result.html:56
|
||||
msgid "All"
|
||||
msgstr "すべて"
|
||||
msgstr "[すべて]"
|
||||
|
||||
#: netbox/templates/extras/tag.html:32
|
||||
msgid "Tagged Items"
|
||||
@ -13557,7 +13557,7 @@ msgstr "新しいリリースが入手可能"
|
||||
|
||||
#: netbox/templates/home.html:16
|
||||
msgid "is available"
|
||||
msgstr "利用可能"
|
||||
msgstr "利用可能です"
|
||||
|
||||
#: netbox/templates/home.html:18
|
||||
msgctxt "Document title"
|
||||
@ -13570,7 +13570,7 @@ msgstr "ダッシュボードのロック解除"
|
||||
|
||||
#: netbox/templates/home.html:49
|
||||
msgid "Lock Dashboard"
|
||||
msgstr "ダッシュボードのロック"
|
||||
msgstr "ロックダッシュボード"
|
||||
|
||||
#: netbox/templates/home.html:60
|
||||
msgid "Add Widget"
|
||||
@ -13685,7 +13685,7 @@ msgstr "ヘルプセンター"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:41
|
||||
msgid "Django Admin"
|
||||
msgstr ""
|
||||
msgstr "ジャンゴ管理者"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:61
|
||||
msgid "Log Out"
|
||||
@ -14094,7 +14094,7 @@ msgstr "仮想ディスクを追加"
|
||||
|
||||
#: netbox/templates/virtualization/virtualmachine/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this virtual machine."
|
||||
msgstr ""
|
||||
msgstr "このVMには構成テンプレートが割り当てられていません。"
|
||||
|
||||
#: netbox/templates/vpn/ikepolicy.html:10
|
||||
#: netbox/templates/vpn/ipsecprofile.html:33 netbox/vpn/tables/crypto.py:166
|
||||
@ -14251,7 +14251,7 @@ msgstr "PSK"
|
||||
#: netbox/templates/wireless/inc/wirelesslink_interface.html:45
|
||||
msgctxt "Abbreviation for megahertz"
|
||||
msgid "MHz"
|
||||
msgstr "MHz"
|
||||
msgstr "メガヘルツ"
|
||||
|
||||
#: netbox/templates/wireless/wirelesslan.html:57
|
||||
msgid "Attached Interfaces"
|
||||
@ -14454,7 +14454,7 @@ msgstr "通知グループ (ID)"
|
||||
|
||||
#: netbox/users/forms/bulk_edit.py:26
|
||||
msgid "First name"
|
||||
msgstr "名前"
|
||||
msgstr "ファーストネーム"
|
||||
|
||||
#: netbox/users/forms/bulk_edit.py:31
|
||||
msgid "Last name"
|
||||
@ -14474,11 +14474,11 @@ msgstr "キーが指定されていない場合は、キーが自動的に生成
|
||||
|
||||
#: netbox/users/forms/filtersets.py:51 netbox/users/tables.py:42
|
||||
msgid "Is Staff"
|
||||
msgstr "スタッフ"
|
||||
msgstr "スタッフですか"
|
||||
|
||||
#: netbox/users/forms/filtersets.py:58 netbox/users/tables.py:45
|
||||
msgid "Is Superuser"
|
||||
msgstr "スーパーユーザ"
|
||||
msgstr "スーパーユーザですか"
|
||||
|
||||
#: netbox/users/forms/filtersets.py:91 netbox/users/tables.py:86
|
||||
msgid "Can View"
|
||||
@ -15156,7 +15156,7 @@ msgstr "シリアル番号"
|
||||
msgid ""
|
||||
"{device} belongs to a different site ({device_site}) than the cluster "
|
||||
"({cluster_site})"
|
||||
msgstr ""
|
||||
msgstr "{device} 別のサイトに属している ({device_site}) よりもクラスタ ({cluster_site})"
|
||||
|
||||
#: netbox/virtualization/forms/model_forms.py:192
|
||||
msgid "Optionally pin this VM to a specific host device within the cluster"
|
||||
@ -15572,11 +15572,11 @@ msgstr "トンネルインターフェイス"
|
||||
|
||||
#: netbox/vpn/forms/model_forms.py:150
|
||||
msgid "First Termination"
|
||||
msgstr "1 回目の終端"
|
||||
msgstr "1 回目の解約"
|
||||
|
||||
#: netbox/vpn/forms/model_forms.py:153
|
||||
msgid "Second Termination"
|
||||
msgstr "2 回目の終端"
|
||||
msgstr "2 回目の終了"
|
||||
|
||||
#: netbox/vpn/forms/model_forms.py:197
|
||||
msgid "This parameter is required when defining a termination."
|
||||
@ -15605,7 +15605,7 @@ msgstr "認証アルゴリズム"
|
||||
|
||||
#: netbox/vpn/models/crypto.py:44
|
||||
msgid "Diffie-Hellman group ID"
|
||||
msgstr "Diffie-Hellmanグループ ID"
|
||||
msgstr "ディフィー・ヘルマングループ ID"
|
||||
|
||||
#: netbox/vpn/models/crypto.py:50
|
||||
msgid "Security association lifetime (in seconds)"
|
||||
@ -15613,11 +15613,11 @@ msgstr "セキュリティアソシエーションの有効期間 (秒単位)"
|
||||
|
||||
#: netbox/vpn/models/crypto.py:59
|
||||
msgid "IKE proposal"
|
||||
msgstr "IKEプロポザール"
|
||||
msgstr "イケアの提案"
|
||||
|
||||
#: netbox/vpn/models/crypto.py:60
|
||||
msgid "IKE proposals"
|
||||
msgstr "IKEプロポザール"
|
||||
msgstr "IKEの提案"
|
||||
|
||||
#: netbox/vpn/models/crypto.py:76
|
||||
msgid "version"
|
||||
@ -15875,7 +15875,7 @@ msgstr "無線リンク"
|
||||
|
||||
#: netbox/wireless/models.py:236
|
||||
msgid "Must specify a unit when setting a wireless distance"
|
||||
msgstr ""
|
||||
msgstr "ワイヤレス距離を設定するときは単位を指定する必要があります"
|
||||
|
||||
#: netbox/wireless/models.py:242 netbox/wireless/models.py:248
|
||||
#, python-brace-format
|
||||
|
Binary file not shown.
@ -8,8 +8,8 @@
|
||||
# deku_m, 2024
|
||||
# Peter Mulder <mistermulder+transifex@protonmail.com>, 2024
|
||||
# Sebastian Berm, 2024
|
||||
# Jeremy Stretch, 2025
|
||||
# Jorg de Jong, 2025
|
||||
# Jeremy Stretch, 2025
|
||||
#
|
||||
#, fuzzy
|
||||
msgid ""
|
||||
@ -18,7 +18,7 @@ msgstr ""
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2025-01-04 05:02+0000\n"
|
||||
"PO-Revision-Date: 2023-10-30 17:48+0000\n"
|
||||
"Last-Translator: Jorg de Jong, 2025\n"
|
||||
"Last-Translator: Jeremy Stretch, 2025\n"
|
||||
"Language-Team: Dutch (https://app.transifex.com/netbox-community/teams/178115/nl/)\n"
|
||||
"MIME-Version: 1.0\n"
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
@ -1239,7 +1239,7 @@ msgstr "Circuitgroeptoewijzingen"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:240
|
||||
msgid "termination"
|
||||
msgstr ""
|
||||
msgstr "beëindiging"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:257
|
||||
msgid "port speed (Kbps)"
|
||||
@ -1301,11 +1301,15 @@ msgstr "circuitafsluitingen"
|
||||
msgid ""
|
||||
"A circuit termination must attach to either a site or a provider network."
|
||||
msgstr ""
|
||||
"Een circuitafsluiting moet verbonden zijn met een site of een netwerk van "
|
||||
"een provider."
|
||||
|
||||
#: netbox/circuits/models/circuits.py:310
|
||||
msgid ""
|
||||
"A circuit termination cannot attach to both a site and a provider network."
|
||||
msgstr ""
|
||||
"Een circuitafsluiting kan niet worden aangesloten op zowel een site als een "
|
||||
"netwerk van een provider."
|
||||
|
||||
#: netbox/circuits/models/providers.py:22
|
||||
#: netbox/circuits/models/providers.py:66
|
||||
@ -7740,7 +7744,7 @@ msgstr "CA-bestandspad"
|
||||
#: netbox/extras/forms/bulk_edit.py:253 netbox/extras/forms/bulk_import.py:192
|
||||
#: netbox/extras/forms/model_forms.py:377
|
||||
msgid "Event types"
|
||||
msgstr "Soorten gebeurtenis"
|
||||
msgstr "Soorten evenementen"
|
||||
|
||||
#: netbox/extras/forms/bulk_edit.py:293
|
||||
msgid "Is active"
|
||||
@ -7831,7 +7835,7 @@ msgstr ""
|
||||
|
||||
#: netbox/extras/forms/bulk_import.py:193
|
||||
msgid "The event type(s) which will trigger this rule"
|
||||
msgstr "Het (de) gebeurtenistype (s) dat deze regel activeert"
|
||||
msgstr "Het (de) evenementtype (s) dat deze regel activeert"
|
||||
|
||||
#: netbox/extras/forms/bulk_import.py:196
|
||||
msgid "Action object"
|
||||
@ -7923,7 +7927,7 @@ msgstr "HTTP-inhoudstype"
|
||||
|
||||
#: netbox/extras/forms/filtersets.py:286
|
||||
msgid "Event type"
|
||||
msgstr "Soort gebeurtenis"
|
||||
msgstr "Soort evenement"
|
||||
|
||||
#: netbox/extras/forms/filtersets.py:291
|
||||
msgid "Action type"
|
||||
@ -8676,7 +8680,7 @@ msgstr "regel van het evenement"
|
||||
|
||||
#: netbox/extras/models/models.py:117
|
||||
msgid "event rules"
|
||||
msgstr "regels voor gebeurtenissen"
|
||||
msgstr "regels voor evenementen"
|
||||
|
||||
#: netbox/extras/models/models.py:166
|
||||
msgid ""
|
||||
@ -8727,8 +8731,11 @@ msgid ""
|
||||
"<code>event</code>, <code>model</code>, <code>timestamp</code>, "
|
||||
"<code>username</code>, <code>request_id</code>, and <code>data</code>."
|
||||
msgstr ""
|
||||
"Jinja2-sjabloon voor een aangepaste hoofdtekst van de aanvraag. Indien leeg, wordt een JSON-object toegevoegd dat de wijziging voorstelt. De beschikbare contextgegevens omvatten: <code>gebeurtenis\n"
|
||||
"</code>, <code>model-</code>, <code>tijdstempel</code>, <code>gebruikersnaam</code>, <code>aanvraag_id</code>, en <code>gegevens</code>."
|
||||
"Jinja2-sjabloon voor een aangepaste hoofdtekst van de aanvraag. Indien leeg,"
|
||||
" wordt een JSON-object toegevoegd dat de wijziging voorstelt. De beschikbare"
|
||||
" contextgegevens omvatten: <code>evenement</code>, <code>model-</code>, "
|
||||
"<code>tijdstempel</code>, <code>gebruikersnaam</code>, "
|
||||
"<code>aanvraag_id</code>, en <code>gegevens</code>."
|
||||
|
||||
#: netbox/extras/models/models.py:204
|
||||
msgid "secret"
|
||||
@ -8942,7 +8949,7 @@ msgstr "lezen"
|
||||
|
||||
#: netbox/extras/models/notifications.py:66
|
||||
msgid "event"
|
||||
msgstr "gebeurtenis"
|
||||
msgstr "evenement"
|
||||
|
||||
#: netbox/extras/models/notifications.py:84
|
||||
msgid "notification"
|
||||
@ -9173,7 +9180,7 @@ msgstr "SSL-validatie"
|
||||
#: netbox/extras/tables/tables.py:418
|
||||
#: netbox/templates/extras/eventrule.html:37
|
||||
msgid "Event Types"
|
||||
msgstr "Soorten gebeurtenissen"
|
||||
msgstr "Soorten evenementen"
|
||||
|
||||
#: netbox/extras/tables/tables.py:535 netbox/netbox/navigation/menu.py:77
|
||||
#: netbox/templates/dcim/devicerole.html:8
|
||||
@ -9912,7 +9919,7 @@ msgstr "ASN-assortiment"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:231
|
||||
msgid "Site/VLAN Assignment"
|
||||
msgstr ""
|
||||
msgstr "Site/VLAN-toewijzing"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:259 netbox/templates/ipam/iprange.html:10
|
||||
msgid "IP Range"
|
||||
@ -12765,7 +12772,7 @@ msgstr "Sjabloon voor weergave van fouten"
|
||||
|
||||
#: netbox/templates/dcim/device/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this device."
|
||||
msgstr ""
|
||||
msgstr "Er is geen configuratiesjabloon toegewezen voor dit apparaat."
|
||||
|
||||
#: netbox/templates/dcim/device_edit.html:44
|
||||
msgid "Parent Bay"
|
||||
@ -14037,7 +14044,7 @@ msgstr "Helpcentrum"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:41
|
||||
msgid "Django Admin"
|
||||
msgstr ""
|
||||
msgstr "Django-beheerder"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:61
|
||||
msgid "Log Out"
|
||||
@ -14452,6 +14459,7 @@ msgstr "Virtuele schijf toevoegen"
|
||||
#: netbox/templates/virtualization/virtualmachine/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this virtual machine."
|
||||
msgstr ""
|
||||
"Er is geen configuratiesjabloon toegewezen voor deze virtuele machine."
|
||||
|
||||
#: netbox/templates/vpn/ikepolicy.html:10
|
||||
#: netbox/templates/vpn/ipsecprofile.html:33 netbox/vpn/tables/crypto.py:166
|
||||
@ -15566,6 +15574,8 @@ msgid ""
|
||||
"{device} belongs to a different site ({device_site}) than the cluster "
|
||||
"({cluster_site})"
|
||||
msgstr ""
|
||||
"{device} behoort tot een andere site ({device_site}) dan het cluster "
|
||||
"({cluster_site})"
|
||||
|
||||
#: netbox/virtualization/forms/model_forms.py:192
|
||||
msgid "Optionally pin this VM to a specific host device within the cluster"
|
||||
@ -16307,6 +16317,7 @@ msgstr "draadloze verbindingen"
|
||||
#: netbox/wireless/models.py:236
|
||||
msgid "Must specify a unit when setting a wireless distance"
|
||||
msgstr ""
|
||||
"Moet een eenheid specificeren bij het instellen van een draadloze afstand"
|
||||
|
||||
#: netbox/wireless/models.py:242 netbox/wireless/models.py:248
|
||||
#, python-brace-format
|
||||
|
Binary file not shown.
@ -1237,7 +1237,7 @@ msgstr "Przydziały grup obwodowych"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:240
|
||||
msgid "termination"
|
||||
msgstr ""
|
||||
msgstr "wypowiedzenie"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:257
|
||||
msgid "port speed (Kbps)"
|
||||
@ -1298,12 +1298,14 @@ msgstr "zakończenia obwodu"
|
||||
#: netbox/circuits/models/circuits.py:308
|
||||
msgid ""
|
||||
"A circuit termination must attach to either a site or a provider network."
|
||||
msgstr ""
|
||||
msgstr "Zakończenie obwodu musi być podłączone do witryny lub sieci dostawcy."
|
||||
|
||||
#: netbox/circuits/models/circuits.py:310
|
||||
msgid ""
|
||||
"A circuit termination cannot attach to both a site and a provider network."
|
||||
msgstr ""
|
||||
"Zakończenie obwodu nie może połączyć się zarówno z witryną, jak i siecią "
|
||||
"dostawcy."
|
||||
|
||||
#: netbox/circuits/models/providers.py:22
|
||||
#: netbox/circuits/models/providers.py:66
|
||||
@ -9844,7 +9846,7 @@ msgstr "Zakres ASN"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:231
|
||||
msgid "Site/VLAN Assignment"
|
||||
msgstr ""
|
||||
msgstr "Przypisanie witryny/sieci VLAN"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:259 netbox/templates/ipam/iprange.html:10
|
||||
msgid "IP Range"
|
||||
@ -12684,7 +12686,7 @@ msgstr "Szablon renderowania błędu"
|
||||
|
||||
#: netbox/templates/dcim/device/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this device."
|
||||
msgstr ""
|
||||
msgstr "Dla tego urządzenia nie przypisano szablonu konfiguracji."
|
||||
|
||||
#: netbox/templates/dcim/device_edit.html:44
|
||||
msgid "Parent Bay"
|
||||
@ -13952,7 +13954,7 @@ msgstr "Centrum pomocy"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:41
|
||||
msgid "Django Admin"
|
||||
msgstr ""
|
||||
msgstr "Administrator Django"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:61
|
||||
msgid "Log Out"
|
||||
@ -14366,7 +14368,7 @@ msgstr "Dodaj dysk wirtualny"
|
||||
|
||||
#: netbox/templates/virtualization/virtualmachine/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this virtual machine."
|
||||
msgstr ""
|
||||
msgstr "Dla tej maszyny wirtualnej nie przypisano szablonu konfiguracji."
|
||||
|
||||
#: netbox/templates/vpn/ikepolicy.html:10
|
||||
#: netbox/templates/vpn/ipsecprofile.html:33 netbox/vpn/tables/crypto.py:166
|
||||
@ -15478,6 +15480,7 @@ msgid ""
|
||||
"{device} belongs to a different site ({device_site}) than the cluster "
|
||||
"({cluster_site})"
|
||||
msgstr ""
|
||||
"{device} należy do innej strony ({device_site}) niż klaster ({cluster_site})"
|
||||
|
||||
#: netbox/virtualization/forms/model_forms.py:192
|
||||
msgid "Optionally pin this VM to a specific host device within the cluster"
|
||||
@ -16214,6 +16217,7 @@ msgstr "łącza bezprzewodowe"
|
||||
#: netbox/wireless/models.py:236
|
||||
msgid "Must specify a unit when setting a wireless distance"
|
||||
msgstr ""
|
||||
"Należy określić jednostkę podczas ustawiania odległości bezprzewodowej"
|
||||
|
||||
#: netbox/wireless/models.py:242 netbox/wireless/models.py:248
|
||||
#, python-brace-format
|
||||
|
Binary file not shown.
@ -6,8 +6,8 @@
|
||||
# Translators:
|
||||
# Renato Almeida de Oliveira, 2023
|
||||
# Fer22f <Fer22f@gmail.com>, 2024
|
||||
# Jeremy Stretch, 2024
|
||||
# Fabricio Maciel, 2024
|
||||
# Jeremy Stretch, 2025
|
||||
# Fabricio Maciel, 2025
|
||||
#
|
||||
#, fuzzy
|
||||
msgid ""
|
||||
@ -16,7 +16,7 @@ msgstr ""
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2025-01-04 05:02+0000\n"
|
||||
"PO-Revision-Date: 2023-10-30 17:48+0000\n"
|
||||
"Last-Translator: Fabricio Maciel, 2024\n"
|
||||
"Last-Translator: Fabricio Maciel, 2025\n"
|
||||
"Language-Team: Portuguese (https://app.transifex.com/netbox-community/teams/178115/pt/)\n"
|
||||
"MIME-Version: 1.0\n"
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
@ -1237,7 +1237,7 @@ msgstr "Atribuições do grupo de circuitos"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:240
|
||||
msgid "termination"
|
||||
msgstr ""
|
||||
msgstr "terminação"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:257
|
||||
msgid "port speed (Kbps)"
|
||||
@ -1299,11 +1299,15 @@ msgstr "terminações dos circuitos"
|
||||
msgid ""
|
||||
"A circuit termination must attach to either a site or a provider network."
|
||||
msgstr ""
|
||||
"Uma terminação de circuito deve ser conectada a um site ou a uma rede de "
|
||||
"provedor."
|
||||
|
||||
#: netbox/circuits/models/circuits.py:310
|
||||
msgid ""
|
||||
"A circuit termination cannot attach to both a site and a provider network."
|
||||
msgstr ""
|
||||
"Uma terminação de circuito não pode ser conectada a um site e a uma rede de "
|
||||
"provedor ao mesmo tempo."
|
||||
|
||||
#: netbox/circuits/models/providers.py:22
|
||||
#: netbox/circuits/models/providers.py:66
|
||||
@ -9882,7 +9886,7 @@ msgstr "Intervalo de ASN"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:231
|
||||
msgid "Site/VLAN Assignment"
|
||||
msgstr ""
|
||||
msgstr "Atribuição de site/VLAN"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:259 netbox/templates/ipam/iprange.html:10
|
||||
msgid "IP Range"
|
||||
@ -12715,7 +12719,7 @@ msgstr "Erro ao renderizar o modelo"
|
||||
|
||||
#: netbox/templates/dcim/device/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this device."
|
||||
msgstr ""
|
||||
msgstr "Nenhum modelo de configuração foi atribuído para este dispositivo."
|
||||
|
||||
#: netbox/templates/dcim/device_edit.html:44
|
||||
msgid "Parent Bay"
|
||||
@ -13984,7 +13988,7 @@ msgstr "Centro de ajuda"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:41
|
||||
msgid "Django Admin"
|
||||
msgstr ""
|
||||
msgstr "Administrador do Django"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:61
|
||||
msgid "Log Out"
|
||||
@ -14398,6 +14402,7 @@ msgstr "Adicionar Disco Virtual"
|
||||
#: netbox/templates/virtualization/virtualmachine/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this virtual machine."
|
||||
msgstr ""
|
||||
"Nenhum modelo de configuração foi atribuído para esta máquina virtual."
|
||||
|
||||
#: netbox/templates/vpn/ikepolicy.html:10
|
||||
#: netbox/templates/vpn/ipsecprofile.html:33 netbox/vpn/tables/crypto.py:166
|
||||
@ -15507,6 +15512,8 @@ msgid ""
|
||||
"{device} belongs to a different site ({device_site}) than the cluster "
|
||||
"({cluster_site})"
|
||||
msgstr ""
|
||||
"{device} pertence a um site diferente ({device_site}) do que o cluster "
|
||||
"({cluster_site})"
|
||||
|
||||
#: netbox/virtualization/forms/model_forms.py:192
|
||||
msgid "Optionally pin this VM to a specific host device within the cluster"
|
||||
@ -16241,7 +16248,7 @@ msgstr "links wireless"
|
||||
|
||||
#: netbox/wireless/models.py:236
|
||||
msgid "Must specify a unit when setting a wireless distance"
|
||||
msgstr ""
|
||||
msgstr "É necessário especificar uma unidade ao definir uma distância sem fio"
|
||||
|
||||
#: netbox/wireless/models.py:242 netbox/wireless/models.py:248
|
||||
#, python-brace-format
|
||||
|
Binary file not shown.
@ -11,9 +11,9 @@
|
||||
# stavr666, 2024
|
||||
# Alexander Ryazanov (alryaz) <alryaz@xavux.com>, 2024
|
||||
# Vladyslav V. Prodan, 2024
|
||||
# Jeremy Stretch, 2024
|
||||
# Artem Kotik, 2025
|
||||
# Michail Tatarinov, 2025
|
||||
# Jeremy Stretch, 2025
|
||||
#
|
||||
#, fuzzy
|
||||
msgid ""
|
||||
@ -22,7 +22,7 @@ msgstr ""
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2025-01-04 05:02+0000\n"
|
||||
"PO-Revision-Date: 2023-10-30 17:48+0000\n"
|
||||
"Last-Translator: Jeremy Stretch, 2025\n"
|
||||
"Last-Translator: Michail Tatarinov, 2025\n"
|
||||
"Language-Team: Russian (https://app.transifex.com/netbox-community/teams/178115/ru/)\n"
|
||||
"MIME-Version: 1.0\n"
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
@ -64,7 +64,7 @@ msgstr "Истекает"
|
||||
|
||||
#: netbox/account/tables.py:42 netbox/users/forms/filtersets.py:141
|
||||
msgid "Last Used"
|
||||
msgstr "Последний раз использованный"
|
||||
msgstr "Последнее использование"
|
||||
|
||||
#: netbox/account/tables.py:45 netbox/templates/account/token.html:55
|
||||
#: netbox/templates/users/token.html:47 netbox/users/forms/bulk_edit.py:122
|
||||
@ -75,7 +75,7 @@ msgstr "Разрешенные IP-адреса"
|
||||
#: netbox/account/views.py:114
|
||||
#, python-brace-format
|
||||
msgid "Logged in as {user}."
|
||||
msgstr "Вошел в систему как {user}."
|
||||
msgstr "Вошел(-ла) в систему как {user}."
|
||||
|
||||
#: netbox/account/views.py:164
|
||||
msgid "You have logged out."
|
||||
@ -83,13 +83,11 @@ msgstr "Вы вышли из системы."
|
||||
|
||||
#: netbox/account/views.py:216
|
||||
msgid "Your preferences have been updated."
|
||||
msgstr "Ваши предпочтения обновлены."
|
||||
msgstr "Ваши настройки были обновлены."
|
||||
|
||||
#: netbox/account/views.py:239
|
||||
msgid "LDAP-authenticated user credentials cannot be changed within NetBox."
|
||||
msgstr ""
|
||||
"Учетные данные пользователя, аутентифицированные по протоколу LDAP, нельзя "
|
||||
"изменить в NetBox."
|
||||
msgstr "Учетные данные доменных пользователей нельзя изменить в NetBox."
|
||||
|
||||
#: netbox/account/views.py:254
|
||||
msgid "Your password has been changed successfully."
|
||||
@ -106,7 +104,7 @@ msgstr "Запланировано"
|
||||
|
||||
#: netbox/circuits/choices.py:22 netbox/netbox/navigation/menu.py:305
|
||||
msgid "Provisioning"
|
||||
msgstr "Выделение ресурсов"
|
||||
msgstr "Эксплутация"
|
||||
|
||||
#: netbox/circuits/choices.py:23 netbox/core/tables/tasks.py:22
|
||||
#: netbox/dcim/choices.py:22 netbox/dcim/choices.py:103
|
||||
@ -126,11 +124,11 @@ msgstr "Активный"
|
||||
#: netbox/dcim/choices.py:1659 netbox/virtualization/choices.py:24
|
||||
#: netbox/virtualization/choices.py:43
|
||||
msgid "Offline"
|
||||
msgstr "Не в сети"
|
||||
msgstr "Оффлайн"
|
||||
|
||||
#: netbox/circuits/choices.py:25
|
||||
msgid "Deprovisioning"
|
||||
msgstr "Выделение резервов"
|
||||
msgstr "Вывод из эксплуатации"
|
||||
|
||||
#: netbox/circuits/choices.py:26
|
||||
msgid "Decommissioned"
|
||||
@ -139,7 +137,7 @@ msgstr "Списан"
|
||||
#: netbox/circuits/choices.py:90 netbox/dcim/choices.py:1619
|
||||
#: netbox/tenancy/choices.py:17
|
||||
msgid "Primary"
|
||||
msgstr "Начальное"
|
||||
msgstr "Основной"
|
||||
|
||||
#: netbox/circuits/choices.py:91 netbox/ipam/choices.py:90
|
||||
#: netbox/tenancy/choices.py:18
|
||||
@ -148,7 +146,7 @@ msgstr "Вторичный"
|
||||
|
||||
#: netbox/circuits/choices.py:92 netbox/tenancy/choices.py:19
|
||||
msgid "Tertiary"
|
||||
msgstr "Высшее образование"
|
||||
msgstr "Третичный"
|
||||
|
||||
#: netbox/circuits/choices.py:93 netbox/tenancy/choices.py:20
|
||||
msgid "Inactive"
|
||||
@ -176,7 +174,7 @@ msgstr "Регион (ID)"
|
||||
#: netbox/ipam/filtersets.py:968 netbox/virtualization/filtersets.py:52
|
||||
#: netbox/virtualization/filtersets.py:180 netbox/vpn/filtersets.py:353
|
||||
msgid "Region (slug)"
|
||||
msgstr "Регион (пуля)"
|
||||
msgstr "Регион (подстрока)"
|
||||
|
||||
#: netbox/circuits/filtersets.py:44 netbox/circuits/filtersets.py:211
|
||||
#: netbox/dcim/filtersets.py:128 netbox/dcim/filtersets.py:225
|
||||
@ -199,7 +197,7 @@ msgstr "Группа сайтов (ID)"
|
||||
#: netbox/virtualization/filtersets.py:65
|
||||
#: netbox/virtualization/filtersets.py:193
|
||||
msgid "Site group (slug)"
|
||||
msgstr "Группа сайтов (слизень)"
|
||||
msgstr "Группа сайтов (подстрока)"
|
||||
|
||||
#: netbox/circuits/filtersets.py:56 netbox/circuits/forms/bulk_edit.py:188
|
||||
#: netbox/circuits/forms/bulk_edit.py:216
|
||||
@ -1243,7 +1241,7 @@ msgstr "Назначения групп каналов связи"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:240
|
||||
msgid "termination"
|
||||
msgstr ""
|
||||
msgstr "завершение"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:257
|
||||
msgid "port speed (Kbps)"
|
||||
@ -1305,11 +1303,15 @@ msgstr "точки подключения канала связи"
|
||||
msgid ""
|
||||
"A circuit termination must attach to either a site or a provider network."
|
||||
msgstr ""
|
||||
"Оконечное устройство канала должно быть подключено либо к узлу, либо к сети "
|
||||
"провайдера."
|
||||
|
||||
#: netbox/circuits/models/circuits.py:310
|
||||
msgid ""
|
||||
"A circuit termination cannot attach to both a site and a provider network."
|
||||
msgstr ""
|
||||
"Терминатор канала не может быть подключен как к сайту, так и к сети "
|
||||
"поставщика."
|
||||
|
||||
#: netbox/circuits/models/providers.py:22
|
||||
#: netbox/circuits/models/providers.py:66
|
||||
@ -9861,7 +9863,7 @@ msgstr "Диапазон ASN"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:231
|
||||
msgid "Site/VLAN Assignment"
|
||||
msgstr ""
|
||||
msgstr "Назначение сайта/VLAN"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:259 netbox/templates/ipam/iprange.html:10
|
||||
msgid "IP Range"
|
||||
@ -12702,7 +12704,7 @@ msgstr "Ошибка при отображении шаблона"
|
||||
|
||||
#: netbox/templates/dcim/device/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this device."
|
||||
msgstr ""
|
||||
msgstr "Для этого устройства не назначен шаблон конфигурации."
|
||||
|
||||
#: netbox/templates/dcim/device_edit.html:44
|
||||
msgid "Parent Bay"
|
||||
@ -13971,7 +13973,7 @@ msgstr "Справочный центр"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:41
|
||||
msgid "Django Admin"
|
||||
msgstr ""
|
||||
msgstr "Администратор Джанго"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:61
|
||||
msgid "Log Out"
|
||||
@ -14383,7 +14385,7 @@ msgstr "Добавить виртуальный диск"
|
||||
|
||||
#: netbox/templates/virtualization/virtualmachine/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this virtual machine."
|
||||
msgstr ""
|
||||
msgstr "Для этой виртуальной машины не назначен шаблон конфигурации."
|
||||
|
||||
#: netbox/templates/vpn/ikepolicy.html:10
|
||||
#: netbox/templates/vpn/ipsecprofile.html:33 netbox/vpn/tables/crypto.py:166
|
||||
@ -15495,6 +15497,8 @@ msgid ""
|
||||
"{device} belongs to a different site ({device_site}) than the cluster "
|
||||
"({cluster_site})"
|
||||
msgstr ""
|
||||
"{device} принадлежит другому сайту ({device_site}), чем кластер "
|
||||
"({cluster_site})"
|
||||
|
||||
#: netbox/virtualization/forms/model_forms.py:192
|
||||
msgid "Optionally pin this VM to a specific host device within the cluster"
|
||||
@ -16230,6 +16234,7 @@ msgstr "беспроводные соединения"
|
||||
#: netbox/wireless/models.py:236
|
||||
msgid "Must specify a unit when setting a wireless distance"
|
||||
msgstr ""
|
||||
"При настройке беспроводного расстояния необходимо указать единицу измерения"
|
||||
|
||||
#: netbox/wireless/models.py:242 netbox/wireless/models.py:248
|
||||
#, python-brace-format
|
||||
|
Binary file not shown.
@ -1236,7 +1236,7 @@ msgstr "Devre grubu atamaları"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:240
|
||||
msgid "termination"
|
||||
msgstr ""
|
||||
msgstr "sonlandırma"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:257
|
||||
msgid "port speed (Kbps)"
|
||||
@ -1298,11 +1298,12 @@ msgstr "devre sonlandırmaları"
|
||||
msgid ""
|
||||
"A circuit termination must attach to either a site or a provider network."
|
||||
msgstr ""
|
||||
"Bir devre sonlandırma, bir siteye veya bir sağlayıcı ağına bağlanmalıdır."
|
||||
|
||||
#: netbox/circuits/models/circuits.py:310
|
||||
msgid ""
|
||||
"A circuit termination cannot attach to both a site and a provider network."
|
||||
msgstr ""
|
||||
msgstr "Devre sonlandırma hem siteye hem de sağlayıcı ağına bağlanamaz."
|
||||
|
||||
#: netbox/circuits/models/providers.py:22
|
||||
#: netbox/circuits/models/providers.py:66
|
||||
@ -9793,7 +9794,7 @@ msgstr "ASN Aralığı"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:231
|
||||
msgid "Site/VLAN Assignment"
|
||||
msgstr ""
|
||||
msgstr "Site/VLAN Ataması"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:259 netbox/templates/ipam/iprange.html:10
|
||||
msgid "IP Range"
|
||||
@ -12616,7 +12617,7 @@ msgstr "Hata oluşturma şablonu"
|
||||
|
||||
#: netbox/templates/dcim/device/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this device."
|
||||
msgstr ""
|
||||
msgstr "Bu aygıt için herhangi bir yapılandırma şablonu atanmadı."
|
||||
|
||||
#: netbox/templates/dcim/device_edit.html:44
|
||||
msgid "Parent Bay"
|
||||
@ -13882,7 +13883,7 @@ msgstr "Yardım Merkezi"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:41
|
||||
msgid "Django Admin"
|
||||
msgstr ""
|
||||
msgstr "Django Yöneticisi"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:61
|
||||
msgid "Log Out"
|
||||
@ -14295,7 +14296,7 @@ msgstr "Sanal Disk Ekle"
|
||||
|
||||
#: netbox/templates/virtualization/virtualmachine/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this virtual machine."
|
||||
msgstr ""
|
||||
msgstr "Bu sanal makine için herhangi bir yapılandırma şablonu atanmadı."
|
||||
|
||||
#: netbox/templates/vpn/ikepolicy.html:10
|
||||
#: netbox/templates/vpn/ipsecprofile.html:33 netbox/vpn/tables/crypto.py:166
|
||||
@ -15392,6 +15393,7 @@ msgid ""
|
||||
"{device} belongs to a different site ({device_site}) than the cluster "
|
||||
"({cluster_site})"
|
||||
msgstr ""
|
||||
"{device} farklı bir siteye aittir ({device_site}) kümeden ({cluster_site})"
|
||||
|
||||
#: netbox/virtualization/forms/model_forms.py:192
|
||||
msgid "Optionally pin this VM to a specific host device within the cluster"
|
||||
@ -16123,7 +16125,7 @@ msgstr "kablosuz bağlantılar"
|
||||
|
||||
#: netbox/wireless/models.py:236
|
||||
msgid "Must specify a unit when setting a wireless distance"
|
||||
msgstr ""
|
||||
msgstr "Kablosuz mesafeyi ayarlarken bir birim belirtmelisiniz"
|
||||
|
||||
#: netbox/wireless/models.py:242 netbox/wireless/models.py:248
|
||||
#, python-brace-format
|
||||
|
Binary file not shown.
@ -5,8 +5,8 @@
|
||||
#
|
||||
# Translators:
|
||||
# Volodymyr Pidgornyi, 2024
|
||||
# Jeremy Stretch, 2024
|
||||
# Vladyslav V. Prodan, 2024
|
||||
# Jeremy Stretch, 2025
|
||||
#
|
||||
#, fuzzy
|
||||
msgid ""
|
||||
@ -15,7 +15,7 @@ msgstr ""
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2025-01-04 05:02+0000\n"
|
||||
"PO-Revision-Date: 2023-10-30 17:48+0000\n"
|
||||
"Last-Translator: Vladyslav V. Prodan, 2024\n"
|
||||
"Last-Translator: Jeremy Stretch, 2025\n"
|
||||
"Language-Team: Ukrainian (https://app.transifex.com/netbox-community/teams/178115/uk/)\n"
|
||||
"MIME-Version: 1.0\n"
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
@ -1235,7 +1235,7 @@ msgstr "Призначення групи каналів зв'язку"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:240
|
||||
msgid "termination"
|
||||
msgstr ""
|
||||
msgstr "припинення"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:257
|
||||
msgid "port speed (Kbps)"
|
||||
@ -1298,11 +1298,14 @@ msgstr "кінці каналу зв'язку"
|
||||
msgid ""
|
||||
"A circuit termination must attach to either a site or a provider network."
|
||||
msgstr ""
|
||||
"Припинення схеми повинно приєднатися або до сайту, або до мережі провайдера."
|
||||
|
||||
#: netbox/circuits/models/circuits.py:310
|
||||
msgid ""
|
||||
"A circuit termination cannot attach to both a site and a provider network."
|
||||
msgstr ""
|
||||
"Припинення схеми не може приєднатися як до сайту, так і до мережі "
|
||||
"провайдера."
|
||||
|
||||
#: netbox/circuits/models/providers.py:22
|
||||
#: netbox/circuits/models/providers.py:66
|
||||
@ -9859,7 +9862,7 @@ msgstr "Діапазон ASN"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:231
|
||||
msgid "Site/VLAN Assignment"
|
||||
msgstr ""
|
||||
msgstr "Призначення сайту/VLAN"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:259 netbox/templates/ipam/iprange.html:10
|
||||
msgid "IP Range"
|
||||
@ -12689,7 +12692,7 @@ msgstr "Помилка візуалізації шаблону"
|
||||
|
||||
#: netbox/templates/dcim/device/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this device."
|
||||
msgstr ""
|
||||
msgstr "Для цього пристрою не призначено жодного шаблону конфігурації."
|
||||
|
||||
#: netbox/templates/dcim/device_edit.html:44
|
||||
msgid "Parent Bay"
|
||||
@ -13955,7 +13958,7 @@ msgstr "Довідковий центр"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:41
|
||||
msgid "Django Admin"
|
||||
msgstr ""
|
||||
msgstr "Джанго Адміністратор"
|
||||
|
||||
#: netbox/templates/inc/user_menu.html:61
|
||||
msgid "Log Out"
|
||||
@ -14368,7 +14371,7 @@ msgstr "Додати віртуальний диск"
|
||||
|
||||
#: netbox/templates/virtualization/virtualmachine/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this virtual machine."
|
||||
msgstr ""
|
||||
msgstr "Жоден шаблон конфігурації не призначено для цієї віртуальної машини."
|
||||
|
||||
#: netbox/templates/vpn/ikepolicy.html:10
|
||||
#: netbox/templates/vpn/ipsecprofile.html:33 netbox/vpn/tables/crypto.py:166
|
||||
@ -15475,6 +15478,8 @@ msgid ""
|
||||
"{device} belongs to a different site ({device_site}) than the cluster "
|
||||
"({cluster_site})"
|
||||
msgstr ""
|
||||
"{device} належить до іншого сайту ({device_site}) ніж кластер "
|
||||
"({cluster_site})"
|
||||
|
||||
#: netbox/virtualization/forms/model_forms.py:192
|
||||
msgid "Optionally pin this VM to a specific host device within the cluster"
|
||||
@ -16213,7 +16218,7 @@ msgstr "бездротові канали зв'язку"
|
||||
|
||||
#: netbox/wireless/models.py:236
|
||||
msgid "Must specify a unit when setting a wireless distance"
|
||||
msgstr ""
|
||||
msgstr "Необхідно вказати одиницю при установці бездротової відстані"
|
||||
|
||||
#: netbox/wireless/models.py:242 netbox/wireless/models.py:248
|
||||
#, python-brace-format
|
||||
|
Binary file not shown.
@ -15,7 +15,6 @@
|
||||
# 闻寄云, 2024
|
||||
# luo jiyin, 2024
|
||||
# Jeremy Stretch, 2025
|
||||
# yawei jia, 2025
|
||||
#
|
||||
#, fuzzy
|
||||
msgid ""
|
||||
@ -24,7 +23,7 @@ msgstr ""
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2025-01-04 05:02+0000\n"
|
||||
"PO-Revision-Date: 2023-10-30 17:48+0000\n"
|
||||
"Last-Translator: yawei jia, 2025\n"
|
||||
"Last-Translator: Jeremy Stretch, 2025\n"
|
||||
"Language-Team: Chinese (https://app.transifex.com/netbox-community/teams/178115/zh/)\n"
|
||||
"MIME-Version: 1.0\n"
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
@ -1243,7 +1242,7 @@ msgstr "电路组分配"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:240
|
||||
msgid "termination"
|
||||
msgstr "终端"
|
||||
msgstr "终止"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:257
|
||||
msgid "port speed (Kbps)"
|
||||
@ -1304,12 +1303,12 @@ msgstr "线路接入"
|
||||
#: netbox/circuits/models/circuits.py:308
|
||||
msgid ""
|
||||
"A circuit termination must attach to either a site or a provider network."
|
||||
msgstr "电路终端必须连接到站点或服务提供商网络。"
|
||||
msgstr "电路终端必须连接到站点或提供商网络。"
|
||||
|
||||
#: netbox/circuits/models/circuits.py:310
|
||||
msgid ""
|
||||
"A circuit termination cannot attach to both a site and a provider network."
|
||||
msgstr "电路终端不能同时连接到站点和服务提供商网络。"
|
||||
msgstr "电路终端不能同时连接到站点和提供商网络。"
|
||||
|
||||
#: netbox/circuits/models/providers.py:22
|
||||
#: netbox/circuits/models/providers.py:66
|
||||
@ -1742,11 +1741,11 @@ msgstr "对象已删除"
|
||||
|
||||
#: netbox/core/events.py:30
|
||||
msgid "Job started"
|
||||
msgstr "作业已开始"
|
||||
msgstr "工作已开始"
|
||||
|
||||
#: netbox/core/events.py:31
|
||||
msgid "Job completed"
|
||||
msgstr "作业已完成"
|
||||
msgstr "任务已完成"
|
||||
|
||||
#: netbox/core/events.py:32
|
||||
msgid "Job failed"
|
||||
@ -9639,7 +9638,7 @@ msgstr "ASN范围"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:231
|
||||
msgid "Site/VLAN Assignment"
|
||||
msgstr "站点/VLAN 关联"
|
||||
msgstr "站点/VLAN 分配"
|
||||
|
||||
#: netbox/ipam/forms/model_forms.py:259 netbox/templates/ipam/iprange.html:10
|
||||
msgid "IP Range"
|
||||
@ -12415,7 +12414,7 @@ msgstr "渲染模板时出错"
|
||||
|
||||
#: netbox/templates/dcim/device/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this device."
|
||||
msgstr "尚未为该设备分配配置模板。"
|
||||
msgstr "尚未为此设备分配任何配置模板。"
|
||||
|
||||
#: netbox/templates/dcim/device_edit.html:44
|
||||
msgid "Parent Bay"
|
||||
@ -14052,7 +14051,7 @@ msgstr "增加虚拟硬盘"
|
||||
|
||||
#: netbox/templates/virtualization/virtualmachine/render_config.html:70
|
||||
msgid "No configuration template has been assigned for this virtual machine."
|
||||
msgstr "尚未为该虚拟机分配配置模板。"
|
||||
msgstr "尚未为此虚拟机分配任何配置模板。"
|
||||
|
||||
#: netbox/templates/vpn/ikepolicy.html:10
|
||||
#: netbox/templates/vpn/ipsecprofile.html:33 netbox/vpn/tables/crypto.py:166
|
||||
@ -15101,7 +15100,7 @@ msgstr "序列号"
|
||||
msgid ""
|
||||
"{device} belongs to a different site ({device_site}) than the cluster "
|
||||
"({cluster_site})"
|
||||
msgstr "{device} 属于与集群 ({cluster_site}) 不同的站点 ({device_site})"
|
||||
msgstr "{device} 属于另一个站点 ({device_site}) 而不是集群 ({cluster_site})"
|
||||
|
||||
#: netbox/virtualization/forms/model_forms.py:192
|
||||
msgid "Optionally pin this VM to a specific host device within the cluster"
|
||||
|
@ -29,7 +29,7 @@ def serialize_object(obj, resolve_tags=True, extra=None, exclude=None):
|
||||
exclude = exclude or []
|
||||
|
||||
# Include custom_field_data as "custom_fields"
|
||||
if 'custom_field_data' in data:
|
||||
if hasattr(obj, 'custom_field_data'):
|
||||
data['custom_fields'] = data.pop('custom_field_data')
|
||||
|
||||
# Resolve any assigned tags to their names. Check for tags cached on the instance;
|
||||
|
@ -196,10 +196,7 @@ class GetRelatedModelsMixin:
|
||||
]
|
||||
related_models.extend(extra)
|
||||
|
||||
return sorted(
|
||||
filter(lambda qs: qs[0].exists(), related_models),
|
||||
key=lambda qs: qs[0].model._meta.verbose_name.lower(),
|
||||
)
|
||||
return sorted(related_models, key=lambda x: x[0].model._meta.verbose_name.lower())
|
||||
|
||||
|
||||
class ViewTab:
|
||||
|
@ -38,7 +38,6 @@ class VirtualMachineStatusChoices(ChoiceSet):
|
||||
STATUS_STAGED = 'staged'
|
||||
STATUS_FAILED = 'failed'
|
||||
STATUS_DECOMMISSIONING = 'decommissioning'
|
||||
STATUS_PAUSED = 'paused'
|
||||
|
||||
CHOICES = [
|
||||
(STATUS_OFFLINE, _('Offline'), 'gray'),
|
||||
@ -47,5 +46,4 @@ class VirtualMachineStatusChoices(ChoiceSet):
|
||||
(STATUS_STAGED, _('Staged'), 'blue'),
|
||||
(STATUS_FAILED, _('Failed'), 'red'),
|
||||
(STATUS_DECOMMISSIONING, _('Decommissioning'), 'yellow'),
|
||||
(STATUS_PAUSED, _('Paused'), 'orange'),
|
||||
]
|
||||
|
@ -6,7 +6,7 @@ from dcim.constants import INTERFACE_MTU_MAX, INTERFACE_MTU_MIN
|
||||
from dcim.forms.mixins import ScopedBulkEditForm
|
||||
from dcim.models import Device, DeviceRole, Platform, Site
|
||||
from extras.models import ConfigTemplate
|
||||
from ipam.models import VLAN, VLANGroup, VLANTranslationPolicy, VRF
|
||||
from ipam.models import VLAN, VLANGroup, VRF
|
||||
from netbox.forms import NetBoxModelBulkEditForm
|
||||
from tenancy.models import Tenant
|
||||
from utilities.forms import BulkRenameForm, add_blank_choice
|
||||
@ -242,23 +242,15 @@ class VMInterfaceBulkEditForm(NetBoxModelBulkEditForm):
|
||||
required=False,
|
||||
label=_('VRF')
|
||||
)
|
||||
vlan_translation_policy = DynamicModelChoiceField(
|
||||
queryset=VLANTranslationPolicy.objects.all(),
|
||||
required=False,
|
||||
label=_('VLAN Translation Policy')
|
||||
)
|
||||
|
||||
model = VMInterface
|
||||
fieldsets = (
|
||||
FieldSet('mtu', 'enabled', 'vrf', 'description'),
|
||||
FieldSet('parent', 'bridge', name=_('Related Interfaces')),
|
||||
FieldSet(
|
||||
'mode', 'vlan_group', 'untagged_vlan', 'tagged_vlans', 'vlan_translation_policy',
|
||||
name=_('802.1Q Switching')
|
||||
),
|
||||
FieldSet('mode', 'vlan_group', 'untagged_vlan', 'tagged_vlans', name=_('802.1Q Switching')),
|
||||
)
|
||||
nullable_fields = (
|
||||
'parent', 'bridge', 'mtu', 'vrf', 'description', 'vlan_translation_policy',
|
||||
'parent', 'bridge', 'mtu', 'vrf', 'description',
|
||||
)
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
|
@ -122,7 +122,7 @@ class VMInterfaceTable(BaseInterfaceTable):
|
||||
fields = (
|
||||
'pk', 'id', 'name', 'virtual_machine', 'enabled', 'mtu', 'mode', 'description', 'tags', 'vrf',
|
||||
'primary_mac_address', 'l2vpn', 'tunnel', 'ip_addresses', 'fhrp_groups', 'untagged_vlan', 'tagged_vlans',
|
||||
'qinq_svlan', 'created', 'last_updated', 'vlan_translation_policy',
|
||||
'qinq_svlan', 'created', 'last_updated',
|
||||
)
|
||||
default_columns = ('pk', 'name', 'virtual_machine', 'enabled', 'description')
|
||||
|
||||
|
@ -1,15 +1,17 @@
|
||||
from django.contrib import messages
|
||||
from django.db import transaction
|
||||
from django.db.models import Prefetch, Sum
|
||||
from django.http import HttpResponse
|
||||
from django.shortcuts import get_object_or_404, redirect, render
|
||||
from django.urls import reverse
|
||||
from django.utils.translation import gettext_lazy as _
|
||||
from jinja2.exceptions import TemplateError
|
||||
|
||||
from dcim.filtersets import DeviceFilterSet
|
||||
from dcim.forms import DeviceFilterForm
|
||||
from dcim.models import Device
|
||||
from dcim.tables import DeviceTable
|
||||
from extras.views import ObjectConfigContextView, ObjectRenderConfigView
|
||||
from extras.views import ObjectConfigContextView
|
||||
from ipam.models import IPAddress
|
||||
from ipam.tables import InterfaceVLANTable, VLANTranslationRuleTable
|
||||
from netbox.constants import DEFAULT_ACTION_PERMISSIONS
|
||||
@ -425,14 +427,54 @@ class VirtualMachineConfigContextView(ObjectConfigContextView):
|
||||
|
||||
|
||||
@register_model_view(VirtualMachine, 'render-config')
|
||||
class VirtualMachineRenderConfigView(ObjectRenderConfigView):
|
||||
class VirtualMachineRenderConfigView(generic.ObjectView):
|
||||
queryset = VirtualMachine.objects.all()
|
||||
base_template = 'virtualization/virtualmachine/base.html'
|
||||
template_name = 'virtualization/virtualmachine/render_config.html'
|
||||
tab = ViewTab(
|
||||
label=_('Render Config'),
|
||||
weight=2100,
|
||||
weight=2100
|
||||
)
|
||||
|
||||
def get(self, request, **kwargs):
|
||||
instance = self.get_object(**kwargs)
|
||||
context = self.get_extra_context(request, instance)
|
||||
|
||||
# If a direct export has been requested, return the rendered template content as a
|
||||
# downloadable file.
|
||||
if request.GET.get('export'):
|
||||
content = context['rendered_config'] or context['error_message']
|
||||
response = HttpResponse(content, content_type='text')
|
||||
filename = f"{instance.name or 'config'}.txt"
|
||||
response['Content-Disposition'] = f'attachment; filename="{filename}"'
|
||||
return response
|
||||
|
||||
return render(request, self.get_template_name(), {
|
||||
'object': instance,
|
||||
'tab': self.tab,
|
||||
**context,
|
||||
})
|
||||
|
||||
def get_extra_context(self, request, instance):
|
||||
# Compile context data
|
||||
context_data = instance.get_config_context()
|
||||
context_data.update({'virtualmachine': instance})
|
||||
|
||||
# Render the config template
|
||||
rendered_config = None
|
||||
error_message = None
|
||||
if config_template := instance.get_config_template():
|
||||
try:
|
||||
rendered_config = config_template.render(context=context_data)
|
||||
except TemplateError as e:
|
||||
error_message = _("An error occurred while rendering the template: {error}").format(error=e)
|
||||
|
||||
return {
|
||||
'config_template': config_template,
|
||||
'context_data': context_data,
|
||||
'rendered_config': rendered_config,
|
||||
'error_message': error_message,
|
||||
}
|
||||
|
||||
|
||||
@register_model_view(VirtualMachine, 'add', detail=False)
|
||||
@register_model_view(VirtualMachine, 'edit')
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user