• Intro Headers Instructions Macros Commands
Fork me on GitHub
    • Getting Started
      • Introduction
      • How to install bnd
      • Guided Tour Workspace & Projects
      • bnd / bndlib Features and JAR Wrapping Techniques
      • FAQ - Frequently Asked Questions
    • Concepts and Practices
      • Concepts
      • Background
      • Best practices
    • Build and Development
      • Build
      • Generating JARs
      • Versioning
      • Baselining
      • Service Components
      • Metatype
      • Contracts
      • Bundle Annotations
      • Accessor Properties
      • SPI Annotations
    • Dependency and Launching
      • Resolving Dependencies
      • Launching
      • Startlevels
    • Testing
      • Testing
      • Testing with Launchpad
    • Packaging and Distribution
      • Packaging Applications
      • JPMS Libraries
      • Wrapping Libraries to OSGi Bundles
    • Documentation and Tools
      • Generating Documentation
      • bnd CLI Commands
      • For Developers
      • Templates for Workspaces
      • Tips for Windows users
      • Tools bound to bnd
    • Reference Material
      • Reference
      • Headers
      • Instruction Reference
      • Instruction Index
      • Macro Reference
      • Macro Index
      • Plugins
      • External Plugins
    • Configuration and Troubleshooting
      • Settings
      • Errors
      • Warnings
  • permissions (';' ( 'packages' | 'admin' | 'permissions' ) )+

    Prev Next
    Builder
    Generate OSGi permission declarations for the bundle

    Summary

    The permissions macro generates OSGi permission declarations in the format required for the OSGi permissions resource (OSGI-INF/permissions.perm). It can generate package permissions and admin permissions.

    Syntax

    ${permissions[;<type>...]}
    

    Parameters

    • type (optional) - One or more permission types:
      • packages - Generate PackagePermission for imports and exports
      • admin - Generate AdminPermission
      • all - Generate all permission types
      • permissions - No-op marker

    Behavior

    • Generates permission declarations in OSGi format
    • packages: Creates import and export PackagePermissions for all bundle packages (except java.* packages)
    • admin: Adds AdminPermission
    • all: Equivalent to both packages and admin
    • Returns formatted permission strings

    Examples

    Generate package permissions:

    ${permissions;packages}
    # Returns:
    # (org.osgi.framework.PackagePermission "com.example.api" "import")
    # (org.osgi.framework.PackagePermission "com.example.impl" "export")
    

    Generate admin permissions:

    ${permissions;admin}
    # Returns: (org.osgi.framework.AdminPermission)
    

    Generate all permissions:

    ${permissions;all}
    

    Use in permissions file:

    # In OSGI-INF/permissions.perm
    ${permissions;packages}
    ${permissions;admin}
    

    Use Cases

    • Generating OSGi permissions resource files
    • Security policy configuration
    • Java security manager setup
    • Signed bundle permissions
    • OSGi security specifications
    • Fine-grained access control

    Notes

    • Follows OSGi permissions specification format
    • PackagePermissions exclude java.* packages
    • Use in OSGI-INF/permissions.perm resource
    • Part of OSGi security framework
    • Useful for signed bundles requiring explicit permissions

    TODO Needs review - AI Generated content


    See test cases in MacroTestsForDocsExamples.java

Prev Next
Search
    • Home