Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
.. image:: https://cfl.dropboxstatic.com/static/images/sdk/stone_banner.png :target: https://github.com/dropbox/stone
.. image:: https://img.shields.io/pypi/pyversions/stone.svg :target: https://pypi.python.org/pypi/stone
.. image:: https://img.shields.io/pypi/v/stone.svg :target: https://pypi.python.org/pypi/stone
.. image:: https://codecov.io/gh/dropbox/stone/branch/main/graph/badge.svg :target: https://codecov.io/gh/dropbox/stone
The Official Api Spec Language for Dropbox.
Documentation
_ can be found on GitHub
Install stone using pip
::
$ pip install --user stone
This will install a script stone
to your PATH that can be run from the
command line::
$ stone -h
Stone requires Python 3.
If you choose not to install stone
using the method above, you will need
to ensure that you have the Python packages ply
and six
, which can be
installed through pip
::
$ pip install "ply>=3.4" "six>=1.3.0" "typing>=3.5.2"
If the stone
package is in your PYTHONPATH, you can replace stone
with python -m stone.cli
as follows::
$ python -m stone.cli -h
If you have the stone
package on your machine, but did not install it or
add its location to your PYTHONPATH, you can use the following::
$ PYTHONPATH=path/to/stone python -m stone.cli -h
After installation, follow one of our Examples
_ or read the Documentation
_.
Define an API once in Stone. Use backends, i.e. code generators, to translate your specification into objects and functions in the programming languages of your choice.
Language Reference <https://github.com/dropbox/stone/blob/main/docs/lang_ref.rst>
_Builtin Backends <https://github.com/dropbox/stone/blob/main/docs/builtin_backends.rst>
_Managing Specs <https://github.com/dropbox/stone/blob/main/docs/managing_specs.rst>
_Evolving a Spec <https://github.com/dropbox/stone/blob/main/docs/evolve_spec.rst>
_Backend Reference <https://github.com/dropbox/stone/blob/main/docs/backend_ref.rst>
_JSON Serializer <https://github.com/dropbox/stone/blob/main/docs/json_serializer.rst>
_Network Protocol <https://github.com/dropbox/stone/blob/main/docs/network_protocol.rst>
_Warning: The documentation is undergoing a rewrite.
.. image:: docs/overview.png
Stone is made up of several components:
A language for writing API specifications, "specs" for short.
The CLI (stone
) generates code based on the provided specs, backend,
and additional arguments.
There are builtin backends that come with Stone: Javascript, Python, Obj-C, Swift, and Typescript.
There are other backends we've written that aren't part of the Stone package because they aren't sufficiently general, and can't realistically be re-used for non-Dropbox APIs: Go and Java.
Stone includes a Python interface for defining new backends based on its intermediate representation of specs. This gives you the freedom to generate to any target.
Stone defines a JSON-compatible serialization scheme.
Stone was birthed at Dropbox at a time when it was becoming clear that API development needed to be scaled beyond a single team. The company was undergoing a large expansion in the number of product groups, and it wasn't scalable for the API team, which traditionally dealt with core file operations, to learn the intricacies of each product and build corresponding APIs.
Stone's chief goal is to decentralize API development and ownership at Dropbox. To be successful, it needed to do several things:
Decouple APIs from SDKS: Dropbox has first-party clients for our mobile apps, desktop client, and website. Each of these is implemented in a different language. Moreover, we wanted to continue providing SDKs to third-parties, over half of whom use our SDKs. It's untenable to ask product groups that build APIs to also implement these endpoints in a half-dozen different language-specific SDKs. Without decoupling, as was the case in our v1 API, the SDKs will inevitably fall behind. Our solution is to have our SDKs automatically generated.
Improve Visibility into our APIs: These days, APIs aren't just in the domain of engineering. Product managers, product specialists, partnerships, sales, and services groups all need to have clear and accurate specifications of our APIs. After all, APIs define Dropbox's data models and functionality. Before Stone, API design documents obseleted by changes during implementation were the source of truth.
Consistency and Predictability: Consistency ranging from documentation tense to API patterns are important for making an API predictable and therefore easier to use. We needed an easy way to make and enforce patterns.
JSON: To make consumption easier for third parties, we wanted our data
types to map to JSON. For cases where serialization efficiency
(space and time) are important, you can try using msgpack (alpha support
available in the Python generator). It's possible also to define your own
serialization scheme, but at that point, you may consider using something like
Protobuf <https://github.com/google/protobuf>
_.
Stone is in active use for the Dropbox v2 API <http://www.dropbox.com/developers>
_.
Stone makes no assumptions about the protocol layer being used to make API requests and return responses; its first use case is the Dropbox v2 API which operates over HTTP. Stone does not come with nor enforce any particular RPC framework.
Stone makes some assumptions about the data types supported in target programming languages. It's assumed that there is a capacity for representing dictionaries (unordered string keys -> value), lists, numeric types, and strings.
Stone assumes that a route (or API endpoint) can have its argument and result types defined without relation to each other. In other words, the type of response does not change based on the input to the endpoint. An exception to this rule is afforded for error responses.
We provide Examples
_ to help get you started with a lot of the basic functionality of Stone.
If you find a bug, please see CONTRIBUTING.md
_ for information on how to report it.
If you need help that is not specific to Stone, please reach out to Dropbox Support
_.
Stone is distributed under the MIT license, please see LICENSE
_ for more information.
.. _logo: {logo_link}
.. _repo: https://github.com/dropbox/stone
.. _Documentation
: https://github.com/dropbox/stone/tree/main/docs
.. _Examples
: https://github.com/dropbox/stone/tree/main/example/backend
.. _LICENSE: https://github.com/dropbox/stone/blob/main/LICENSE
.. _CONTRIBUTING.md: https://github.com/dropbox/stone/blob/main/CONTRIBUTING.md
.. _Dropbox Support
: https://www.dropbox.com/developers/contact
FAQs
Stone is an interface description language (IDL) for APIs.
We found that stone demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.