Download the PHP package butschster/proto-parser without Composer
On this page you can find all versions of the php package butschster/proto-parser. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download butschster/proto-parser
More information about butschster/proto-parser
Files in butschster/proto-parser
Package proto-parser
Short Description Proto parser is a library for parsing Protocol Buffers files into AST
License MIT
Informations about the package proto-parser
PHP Protocol Buffer Parser
A powerful and flexible Protocol Buffers parser for PHP, capable of generating an Abstract Syntax Tree (AST) from
.proto files. This package provides a robust foundation for working with Protocol Buffers in PHP projects.
Key Features
- Full support for Protocol Buffer syntax (proto3)
- Parses messages, enums, services, and RPC definitions
- Handles imports, packages, and options
- Preserves comments for documentation purposes
- Generates an Abstract Syntax Tree (AST) for easy manipulation
- Built with PHP 8.3
Use Cases
- Generating code from protobuf definitions
- Analyzing and validating protobuf schemas
- Building tools for working with protocol buffers
- Integrating protobuf support into existing PHP applications
Installation
Install the package via Composer:
Usage
Here's a quick example of how to use the Proto Parser:
Understanding AST (Abstract Syntax Tree)
An Abstract Syntax Tree (AST) is a tree representation of the abstract syntactic structure of source code. In the context of this package, the AST represents the structure of a Protocol Buffer definition file.
Here's an example of what an AST looks like for a simple .proto file:
The corresponding AST would look something like this:
Each node in the AST corresponds to a specific element in the Protocol Buffer definition. This structure allows for easy traversal and manipulation of the Protocol Buffer structure programmatically.
AST Class Diagram
The following class diagram provides an overview of the AST node classes available in the Protobuf parser. This diagram shows the relationships between different node classes and their properties.
Detailed Usage Examples
Parsing Messages
Parsing Services
Handling Imports and Options
Example: Generating DTO Classes
One powerful use case for the AST is generating Data Transfer Object (DTO) classes from Protocol Buffer definitions. You
can use a code generator (like nette/php-generator) to create PHP classes based on the AST.
Here's an example of how you might use the AST to generate a PHP class:
This would generate a PHP class like this:
There are many possibilities for code generation using the AST. More use cases:
-
Generate DTOs with Validation Attributes: You can use the AST to generate DTOs with built-in validation using Symfony Validator attributes.
-
Generate OpenAPI Schema: By parsing the service RPC options, you can automatically generate OpenAPI (Swagger) schema documentation for your API endpoints, keeping your API documentation in sync with your protobuf definitions.
-
Generate Clean JSON-Serializable DTOs: Create DTOs that are optimized for JSON serialization, ensuring efficient data transfer between your PHP application and other systems or frontends.
-
Static Analysis Tool Integration: Use the AST to create custom PHPStan or Psalm rules that can analyze your protobuf usage within your PHP codebase, enhancing type safety and catching potential issues early.
- Code Migration Assistance: Leverage the AST to help automate code migrations when your protobuf definitions change, ensuring that your PHP code stays in sync with evolving protobuf schemas.
AST Node Classes
This document provides an overview of the available node classes in the Protobuf parser. These classes represent different elements of a Protobuf definition file.
ProtoNode
Represents the root node of a Protobuf file.
$syntax: The syntax declaration of the Protobuf file.$imports: An array ofImportDeclNodeobjects representing imported files.$package: An optionalPackageDeclNoderepresenting the package declaration.$options: An array ofOptionDeclNodeobjects representing file-level options.$topLevelDefs: An array of top-level definitions (messages, enums, services).
SyntaxDeclNode
Represents the syntax declaration of a Protobuf file.
$syntax: The syntax version (e.g., "proto3").$comments: An array ofCommentNodeobjects associated with the syntax declaration.
ImportDeclNode
Represents an import statement in a Protobuf file.
$path: The path of the imported file.$modifier: An optionalImportModifierenum value (Weak or Public).$comments: An array ofCommentNodeobjects associated with the import statement.
PackageDeclNode
Represents a package declaration in a Protobuf file.
$name: The name of the package.$comments: An array ofCommentNodeobjects associated with the package declaration.
OptionDeclNode
Represents an option declaration in a Protobuf file.
$name: The name of the option.$comments: An array ofCommentNodeobjects associated with the option.$options: An array ofOptionNodeobjects representing nested options.
MessageDefNode
Represents a message definition in a Protobuf file.
$name: The name of the message.$fields: An array ofFieldDeclNodeobjects representing the message fields.$messages: An array of nestedMessageDefNodeobjects.$enums: An array ofEnumDefNodeobjects defined within the message.$comments: An array ofCommentNodeobjects associated with the message.
FieldDeclNode
Represents a field declaration within a message.
$type: AFieldTypeobject representing the type of the field.$name: The name of the field.$number: The field number.$modifier: An optionalFieldModifierenum value (Required, Optional, or Repeated).$options: An array ofOptionDeclNodeobjects representing field options.$comments: An array ofCommentNodeobjects associated with the field.
EnumDefNode
Represents an enum definition in a Protobuf file.
$name: The name of the enum.$fields: An array ofEnumFieldNodeobjects representing the enum values.$comments: An array ofCommentNodeobjects associated with the enum.
EnumFieldNode
Represents a field within an enum definition.
$name: The name of the enum value.$number: The numeric value associated with the enum field.$options: An array ofOptionDeclNodeobjects representing field options.$comments: An array ofCommentNodeobjects associated with the enum field.
ServiceDefNode
Represents a service definition in a Protobuf file.
$name: The name of the service.$methods: An array ofRpcDeclNodeobjects representing the service methods.$options: An array ofOptionDeclNodeobjects representing service options.$comments: An array ofCommentNodeobjects associated with the service.
RpcDeclNode
Represents an RPC (Remote Procedure Call) declaration within a service.
$name: The name of the RPC method.$inputType: AnRpcMessageTypeobject representing the input message type.$outputType: AnRpcMessageTypeobject representing the output message type.$options: An array ofOptionDeclNodeobjects representing RPC options.$comments: An array ofCommentNodeobjects associated with the RPC.
MapFieldDeclNode
Represents a map field declaration within a message.
$keyType: AFieldTypeobject representing the key type of the map.$valueType: AFieldTypeobject representing the value type of the map.$name: The name of the map field.$number: The field number.$options: An array ofOptionDeclNodeobjects representing field options.$comments: An array ofCommentNodeobjects associated with the map field.
OneofFieldNode
Represents a field within a oneof group.
$type: AFieldTypeobject representing the type of the field.$name: The name of the field.$number: The field number.$options: An array ofOptionDeclNodeobjects representing field options.
CommentNode
Represents a comment in the Protobuf file.
$text: The text content of the comment.
ReservedNode
Represents a reserved statement in a message or enum.
$ranges: An array ofReservedRangeorReservedNumberobjects representing the reserved fields or numbers.
OptionNode
Represents an individual option within an option declaration.
$name: The name of the option.$value: The value of the option (can be a mixed type or anotherOptionDeclNode).$comments: An array ofCommentNodeobjects associated with the option.
Contributing
Contributions are welcome! Please follow these guidelines when contributing to the project:
- Fork the repository and create your branch from
master. - Ensure that your code follows the PSR-12 coding standard.
- If you're modifying the parser grammar:
- Edit the
ebnf.pp2file to make your changes. - Run the unit tests to regenerate the
src/grammar.phpfile. - Ensure that all existing tests pass and add new tests to cover your changes.
- Edit the
- Update the documentation in the README if you're adding or changing functionality.
- Write clear and concise commit messages.
- Submit a pull request with a detailed description of your changes.
License
This project is licensed under the MIT License.