GitHunt
II

iinuwa/oso

Oso is a batteries-included framework for building authorization in your application.

Oso

Development
GitHub release (latest SemVer)
Go version
Maven version
NPM version
PyPI version
RubyGems version
Crates.io version
Slack

What is Oso?

Oso is a batteries-included framework for building authorization in your application.

With Oso, you can:

  • Model: Set up common permissions patterns like role-based access control (RBAC) and relationships using Oso’s built-in primitives. Extend them however you need with Oso’s declarative policy language, Polar.
  • Filter: Go beyond yes/no authorization questions. Implement authorization over collections too - e.g., “Show me only the records that Juno can see.”
  • Test: Write unit tests over your authorization logic now that you have a single interface for it. Use the Oso debugger or REPL to track down unexpected behavior.

Oso offers libraries for Node.js,
Python, Go,
Rust, Ruby, and
Java.

Documentation

Community & Support

If you have any questions on Oso or authorization more generally, you can join our engineering team & hundreds of other developers using Oso in our community Slack:

Button

Share your story

We'd love to hear about your use case and experience with Oso. Share your story in our Success Stories issue or fill out this form for some Oso swag.

Development

Core

Oso's Rust core is developed against Rust's latest stable
release
.

Language libraries

Oso's language libraries can be developed without touching the Rust core, but
you will still need the Rust stable toolchain installed in order to build the
core.

To build the WebAssembly core for the Node.js library, you will need to have
wasm-pack installed and available on your system PATH.

Language requirements

To work on a language library, you will need to meet the following version
requirements:

  • Java: 10+
    • Maven: 3.6+
  • Node.js: 12.20.0+
    • Yarn 1.22+
  • Python: 3.6+
  • Ruby: 2.4+
    • Bundler 2.1.4+
  • Rust: 1.46+
  • Go: 1.12+

Contributing

See: CONTRIBUTING.md.

License

See: LICENSE.

Languages

Rust45.6%Python19.3%TypeScript8.8%Ruby8.2%Go7.0%C#5.3%Java5.0%Makefile0.6%C0.2%JavaScript0.1%Shell0.0%
Apache License 2.0
Created January 7, 2022
Updated April 9, 2022