Skip to main content

ASN.1 editor framework with support for encoding and decoding various codecs.

Project description

Build Coverage Status Maintainability Documentation Status

asn1editor

Python based ASN.1 editor

This project contains a generic editor to view and edit ASN.1 encoded data. It can load and save data encoded in various ASN.1 formats. It uses asn1tools to parse ASN.1 specifications and read and write encoded data.

The controller part of the editor is written independently of the used GUI framework. A view implementation with wxPython is provided.

Screenshot

Usage

To start the wxPython based editor, install asn1editor via pip:

pip install asn1editor

Then you can run asn1editor from the shell

asn1editor [-h] [-type TYPE] [-data DATA] [asn1spec]

The ASN.1 specification to be loaded can be passed as an (optional) argument. The type inside the ASN.1 specification can be selected using the syntax < Module name >.< Type name >. Finally, a data file can be passed as well that contains data encoded in the ASN.1 specification.

Features

Supported types

The editor supports a large variety of ASN.1 data types:

  • INTEGER
  • REAL
  • ENUMERATED
  • BOOLEAN
  • OCTET STRING, VisibleString, UTF8String, GeneralString, IA5String, OBJECT IDENTIFIER
  • BIT STRING
  • SEQUENCE, SET
  • SEQUENCE OF, SET OF
  • CHOICE
  • DATE, TIME-OF-DAY, DATE-TIME, GeneralizedTime, UTCTime

Supported encodings

The following encodings are supported for reading and writing data:

  • JER
  • OER
  • XER
  • DER
  • BER
  • PER
  • UPER

GUI features

  • Load and save encoded data
  • View the data in a tree view or as groups

Screenshot

  • See limits of numeric values and texts as tooltips
  • Edit octet strings as ASCII or hex
  • List of recently opened specifications for quick access

IMPORTS

IMPORT references are automatically resolved if the ASN1 files containing the imported types reside in the same directory and have the extension ".asn".

Extending asn1editor

If you want to extend asn1editor with custom functionality, you can pass a plugin object to the WxPythonMainWindow object. The plugin object needs to inherit from asn1editor.Plugin.

Example:

import wx
from asn1editor import WxPythonMainWindow, Plugin

class MyPlugin(Plugin):
    # Implementation of abstract functions goes here
    pass

app = wx.App()

frame = WxPythonMainWindow([MyPlugin()])

frame.Show()

app.MainLoop()

Plugin interface

In order to use custom data formats or to work with the data, plugins can be used. These plugins need to inherit from the Plugin.Plugin class and can use the PluginInterface.PluginInterface class to interact with the main application. A list of plugins can be passed to the constructor of the main editor class and is then automatically embedded in the application.

An example application is if a custom header is added to an ASN.1 encoded data. Then the plugin can decode the header, choose the appropriate ASN.1 specification, load it, decode the data and display it.

Type augmenter

The editor can be customized to modify the display of certain fields. This customization is provided via a class that implements the TypeAugmenter interface. The editor will query additional information for every field via this interface. Currently, a field can be augmented by providing a help text and a style IntEnum. The help text will be shown in the tooltip of each field and the style flag modifies the way how a field is displayed. A field can be hidden or be declared as read-only.

The editor comes with a default implementation of this augmenter that uses a .style file to customize the way fields are displayed in asn1editor.

If an ASN.1 file is opened, asn1editor looks for an equally named file with a .style extension in the same directory. If it is found, it is loaded and used to refine the layout of the specification. A style file is in JSON format and contains the name of the ASN.1 field as a key, and the layout specifier as value. The specifiers are named "read_only" and "hidden".

Example:

{
"firstField": "read_only",
"secondField": "hidden"
}

Tests

Apart from unit tests in the source folder, there is a project on testquality.com that contains a number of manual tests to qualify an asn1editor release here. You can log in using the credentials futsch1@fehlbar.de/readonly to view the test cases and test results.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

asn1editor-0.8.0.tar.gz (45.4 kB view details)

Uploaded Source

Built Distribution

asn1editor-0.8.0-py3-none-any.whl (62.6 kB view details)

Uploaded Python 3

File details

Details for the file asn1editor-0.8.0.tar.gz.

File metadata

  • Download URL: asn1editor-0.8.0.tar.gz
  • Upload date:
  • Size: 45.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.17

File hashes

Hashes for asn1editor-0.8.0.tar.gz
Algorithm Hash digest
SHA256 0b4110947a712a13b7ebc8dba46cc57e8254ea3f305443a1139c5a130ae568b7
MD5 d3dcb60a6428547fbe84c2ef2f3c7624
BLAKE2b-256 fa62981b94d13fd11a6faf7eb1d8222b93a5b87add162877c8e493af72e277cb

See more details on using hashes here.

File details

Details for the file asn1editor-0.8.0-py3-none-any.whl.

File metadata

  • Download URL: asn1editor-0.8.0-py3-none-any.whl
  • Upload date:
  • Size: 62.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.17

File hashes

Hashes for asn1editor-0.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 59fc62f513a7b37481f4490d55b461b242191ba069736f61eed05e45e22589c2
MD5 908347d25918d9d685e1174c1397b135
BLAKE2b-256 26d1289af59dab24e1662cf46d9c74e7b3f65e74da5c755dd441d3577793d4fe

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page