django-rest-framework/docs/topics/funding.md

368 lines
14 KiB
Markdown
Raw Normal View History

<script>
// Imperfect, but easier to fit in with the existing docs build.
// Hyperlinks should point directly to the "fund." subdomain, but this'll
// handle the nav bar links without requiring any docs build changes for the moment.
if (window.location.hostname == "www.django-rest-framework.org") {
window.location.replace("https://fund.django-rest-framework.org/topics/funding/");
}
</script>
2015-08-13 16:17:27 +03:00
<style>
2016-05-26 13:48:15 +03:00
.promo li a {
float: left;
width: 130px;
height: 20px;
text-align: center;
margin: 10px 30px;
padding: 150px 0 0 0;
background-position: 0 50%;
background-size: 130px auto;
background-repeat: no-repeat;
font-size: 120%;
color: black;
}
.promo li {
list-style: none;
}
2015-08-13 16:17:27 +03:00
.chart {
2015-08-14 14:34:47 +03:00
background-color: #e3e3e3;
background: -webkit-linear-gradient(top, #fff 0, #e3e3e3 100%);
2015-08-13 16:17:27 +03:00
border: 1px solid #E6E6E6;
border-radius: 5px;
box-shadow: 0px 0px 2px 0px rgba(181, 181, 181, 0.3);
padding: 40px 0px 5px;
position: relative;
text-align: center;
width: 97%;
min-height: 255px;
position: relative;
2015-08-14 14:34:47 +03:00
top: 37px;
margin-bottom: 20px }
2015-08-13 16:17:27 +03:00
.quantity {
2015-08-14 14:34:47 +03:00
text-align: center }
2015-08-13 16:17:27 +03:00
.dollar {
font-size: 19px;
position: relative;
top: -18px;
}
.price {
font-size: 49px; }
.period {
font-size: 17px;
position: relative;
top: -8px;
margin-left: 4px; }
.plan-name {
2016-05-26 13:48:15 +03:00
text-align: center;
2015-08-13 16:17:27 +03:00
font-size: 20px;
font-weight: 400;
color: #777;
border-bottom: 1px solid #d5d5d5;
padding-bottom: 15px;
width: 90%;
margin: 0 auto;
margin-top: 8px; }
.specs {
2016-05-26 13:48:15 +03:00
margin-top: 20px; min-height: 130px;
}
.specs.freelancer {
min-height: 0px;
}
2015-08-13 16:17:27 +03:00
.spec {
2015-08-14 14:34:47 +03:00
font-size: 15px;
2015-08-13 16:17:27 +03:00
color: #474747;
text-align: center;
font-weight: 300;
margin-bottom: 13px; }
.variable {
2015-08-14 14:34:47 +03:00
color: #1FBEE7;
2015-08-13 16:17:27 +03:00
font-weight: 400; }
form.signup {
2015-08-14 14:34:47 +03:00
margin-top: 35px }
2015-08-13 16:17:27 +03:00
.clear-promo {
2015-08-14 14:34:47 +03:00
padding-top: 30px }
#main-content h1:first-of-type {
margin: 0 0 50px;
font-size: 60px;
font-weight: 200;
text-align: center
}
#main-content {
padding-top: 10px; line-height: 23px
}
#main-content li {
line-height: 23px
}
2015-08-13 16:17:27 +03:00
</style>
2015-08-19 14:16:00 +03:00
# Funding
2015-08-13 16:17:27 +03:00
If you use REST framework commercially we strongly encourage you to invest in its continued development by signing up for a paid plan.
2016-05-26 13:48:15 +03:00
**We believe that collaboratively funded software can offer outstanding returns on investment, by encouraging our users to collectively share the cost of development.**
2015-08-13 16:17:27 +03:00
Signing up for a paid plan will:
2016-05-26 13:48:15 +03:00
* Directly contribute to faster releases, more features, and higher quality software.
* Allow more time to be invested in documentation, issue triage, and community support.
2015-08-13 16:17:27 +03:00
* Safeguard the future development of REST framework.
2016-05-26 13:48:15 +03:00
REST framework continues to be open-source and permissively licensed, but we firmly believe it is in the commercial best-interest for users of the project to invest in its ongoing development.
2015-08-14 14:34:47 +03:00
---
2017-03-10 08:30:31 +03:00
## What funding has enabled so far
2015-08-14 14:34:47 +03:00
2017-03-10 08:30:31 +03:00
* The [3.4](http://www.django-rest-framework.org/topics/3.4-announcement/) and [3.5](http://www.django-rest-framework.org/topics/3.5-announcement/) releases, including schema generation for both Swagger and RAML, a Python client library, a Command Line client, and addressing of a large number of outstanding issues.
* The [3.6](http://www.django-rest-framework.org/topics/3.6-announcement/) release, including JavaScript client library, and API documentation, complete with auto-generated code samples.
* Tom Christie, the creator of Django REST framework, working on the project full-time.
2017-03-11 01:06:01 +03:00
* Around 80-90 issues and pull requests closed per month since Tom Christie started working on the project full-time.
2017-03-10 08:30:31 +03:00
* A community & operations manager position part-time for 4 months, helping mature the business and grow sponsorship.
* Contracting development time for the work on the JavaScript client library and API documentation tooling.
2015-08-14 14:34:47 +03:00
2017-03-10 08:30:31 +03:00
---
2015-08-14 14:34:47 +03:00
2017-03-10 08:30:31 +03:00
## What future funding will enable
2015-08-14 14:34:47 +03:00
2017-03-10 08:30:31 +03:00
* Realtime API support, using WebSockets. This will consist of documentation and support for using REST framework together with Django Channels, plus integrating WebSocket support into the client libraries.
2017-03-11 01:06:01 +03:00
* Better authentication defaults, possibly bringing JWT & CORs support into the core package.
2017-03-10 08:30:31 +03:00
* Securing the community & operations manager position long-term.
* Opening up and securing a part-time position to focus on ticket triage and resolution.
* Paying for development time on building API client libraries in a range of programming languages. These would be integrated directly into the upcoming API documentation.
2015-08-14 14:34:47 +03:00
2016-05-26 13:48:15 +03:00
Sign up for a paid plan today, and help ensure that REST framework becomes a sustainable, full-time funded project.
2015-08-13 16:17:27 +03:00
---
2017-03-10 08:30:31 +03:00
## What our sponsors and users say
2015-08-13 16:17:27 +03:00
2017-03-10 08:30:31 +03:00
> As a developer, Django REST framework feels like an obvious and natural extension to all the great things that make up Django and it's community. Getting started is easy while providing simple abstractions which makes it flexible and customizable. Contributing and supporting Django REST framework helps ensure its future and one way or another it also helps Django, and the Python ecosystem.
>
2017-03-11 01:06:01 +03:00
> &mdash; José Padilla, Django REST framework contributor
2015-08-13 16:17:27 +03:00
&nbsp;
2017-03-10 08:30:31 +03:00
> The number one feature of the Python programming language is its community. Such a community is only possible because of the Open Source nature of the language and all the culture that comes from it. Building great Open Source projects require great minds. Given that, we at Vinta are not only proud to sponsor the team behind DRF but we also recognize the ROI that comes from it.
>
> &mdash; Filipe Ximenes, Vinta Software
&nbsp;
2017-03-10 08:30:31 +03:00
> It's really awesome that this project continues to endure. The code base is top notch and the maintainers are committed to the highest level of quality.
DRF is one of the core reasons why Django is top choice among web frameworks today. In my opinion, it sets the standard for rest frameworks for the development community at large.
>
> &mdash; Andrew Conti, Django REST framework user
2017-03-10 08:30:31 +03:00
---
## Individual plan
This subscription is recommended for individuals with an interest in seeing REST framework continue to&nbsp;improve.
If you are using REST framework as a full-time employee, consider recommending that your company takes out a [corporate&nbsp;plan](#corporate-plans).
2015-08-13 16:17:27 +03:00
<div class="pricing">
<div class="span4">
<div class="chart first">
<div class="quantity">
2016-05-26 13:48:15 +03:00
<span class="dollar">{{ symbol }}</span>
<span class="price">{{ rates.personal1 }}</span>
<span class="period">/month{% if vat %} +VAT{% endif %}</span>
2015-08-13 16:17:27 +03:00
</div>
2017-03-10 08:30:31 +03:00
<div class="plan-name">Individual</div>
2016-05-26 13:48:15 +03:00
<div class="specs freelancer">
2015-08-13 16:17:27 +03:00
<div class="spec">
Support ongoing development
</div>
<div class="spec">
Credited on the site
</div>
</div>
2016-05-28 12:23:59 +03:00
<form class="signup" action="/signup/{{ currency }}-{{ rates.personal1 }}/" method="POST">
2015-08-13 16:17:27 +03:00
<script
src="https://checkout.stripe.com/checkout.js" class="stripe-button"
2015-08-20 12:10:06 +03:00
data-key="{{ stripe_public }}"
2016-05-26 13:48:15 +03:00
data-amount="{{ stripe_amounts.personal1 }}"
2015-08-13 16:17:27 +03:00
data-name="Django REST framework"
data-description="Individual"
2016-05-26 13:48:15 +03:00
data-currency="{{ currency }}"
2015-08-13 16:17:27 +03:00
data-allow-remember-me=false
data-billing-address=true
2015-08-13 16:17:27 +03:00
data-label='Sign up'
2015-08-20 12:10:06 +03:00
data-panel-label='Sign up - {% verbatim %}{{amount}}{% endverbatim %}/mo'>
2015-08-13 16:17:27 +03:00
</script>
</form>
</div>
</div>
</div>
2015-08-14 14:34:47 +03:00
<div style="clear: both; padding-top: 50px"></div>
*Billing is monthly and you can cancel at any time.*
2015-08-13 16:17:27 +03:00
---
## Corporate plans
These subscriptions are recommended for companies and organizations using REST framework either publicly or privately.
In exchange for funding you'll also receive advertising space on our site, allowing you to **promote your company or product to many tens of thousands of developers worldwide**.
2015-08-14 14:34:47 +03:00
Our professional and premium plans also include **priority support**. At any time your engineers can escalate an issue or discussion group thread, and we'll ensure it gets a guaranteed response within the next working day.
2015-08-13 16:17:27 +03:00
<div class="pricing">
<div class="span4">
<div class="chart first">
<div class="quantity">
2016-05-26 13:48:15 +03:00
<span class="dollar">{{ symbol }}</span>
<span class="price">{{ rates.corporate1 }}</span>
<span class="period">/month{% if vat %} +VAT{% endif %}</span>
2015-08-13 16:17:27 +03:00
</div>
2015-08-14 14:34:47 +03:00
<div class="plan-name">Basic</div>
2015-08-13 16:17:27 +03:00
<div class="specs startup">
<div class="spec">
Support ongoing development
</div>
<div class="spec">
<span class="variable">Funding page</span> ad placement
</div>
</div>
2016-05-28 12:23:59 +03:00
<form class="signup" action="/signup/{{ currency }}-{{ rates.corporate1 }}/" method="POST">
2015-08-13 16:17:27 +03:00
<script
src="https://checkout.stripe.com/checkout.js" class="stripe-button"
2015-08-20 12:10:06 +03:00
data-key="{{ stripe_public }}"
2016-05-26 13:48:15 +03:00
data-amount="{{ stripe_amounts.corporate1 }}"
2015-08-13 16:17:27 +03:00
data-name="Django REST framework"
2015-08-14 14:34:47 +03:00
data-description="Basic"
2016-05-26 13:48:15 +03:00
data-currency="{{ currency }}"
2015-08-13 16:17:27 +03:00
data-allow-remember-me=false
data-billing-address=true
2015-08-13 16:17:27 +03:00
data-label='Sign up'
2015-08-20 12:10:06 +03:00
data-panel-label='Sign up - {% verbatim %}{{amount}}{% endverbatim %}/mo'>
2015-08-13 16:17:27 +03:00
</script>
</form>
</div>
</div>
<div class="span4">
<div class="chart">
<div class="quantity">
2016-05-26 13:48:15 +03:00
<span class="dollar">{{ symbol }}</span>
<span class="price">{{ rates.corporate2 }}</span>
<span class="period">/month{% if vat %} +VAT{% endif %}</span>
2015-08-13 16:17:27 +03:00
</div>
<div class="plan-name">Professional</div>
<div class="specs">
2016-05-26 13:48:15 +03:00
<div class="spec">
Support ongoing development
</div>
2015-08-13 16:17:27 +03:00
<div class="spec">
2016-05-26 13:48:15 +03:00
<span class="variable">Sidebar</span> ad placement
2015-08-13 16:17:27 +03:00
</div>
<div class="spec">
<span class="variable">Priority support</span> for your engineers
</div>
</div>
2016-05-28 12:23:59 +03:00
<form class="signup" action="/signup/{{ currency }}-{{ rates.corporate2 }}/" method="POST">
2015-08-13 16:17:27 +03:00
<script
src="https://checkout.stripe.com/checkout.js" class="stripe-button"
2015-08-20 12:10:06 +03:00
data-key="{{ stripe_public }}"
2016-05-26 13:48:15 +03:00
data-amount="{{ stripe_amounts.corporate2 }}"
2015-08-13 16:17:27 +03:00
data-name="Django REST framework"
data-description="Professional"
2016-05-26 13:48:15 +03:00
data-currency="{{ currency }}"
2015-08-13 16:17:27 +03:00
data-allow-remember-me=false
data-billing-address=true
2015-08-13 16:17:27 +03:00
data-label='Sign up'
2015-08-20 12:10:06 +03:00
data-panel-label='Sign up - {% verbatim %}{{amount}}{% endverbatim %}/mo'>
2015-08-13 16:17:27 +03:00
</script>
</form>
</div>
</div>
<div class="span4">
<div class="chart last">
<div class="quantity">
2016-05-26 13:48:15 +03:00
<span class="dollar">{{ symbol }}</span>
<span class="price">{{ rates.corporate3 }}</span>
<span class="period">/month{% if vat %} +VAT{% endif %}</span>
2015-08-13 16:17:27 +03:00
</div>
<div class="plan-name">Premium</div>
<div class="specs">
2016-05-26 13:48:15 +03:00
<div class="spec">
Support ongoing development
</div>
2015-08-13 16:17:27 +03:00
<div class="spec">
2016-05-26 13:48:15 +03:00
<span class="variable">Homepage</span> ad placement
2015-08-13 16:17:27 +03:00
</div>
<div class="spec">
2016-05-26 13:48:15 +03:00
<span class="variable">Sidebar</span> ad placement
2015-08-13 16:17:27 +03:00
</div>
<div class="spec">
<span class="variable">Priority support</span> for your engineers
</div>
</div>
2016-05-28 12:23:59 +03:00
<form class="signup" action="/signup/{{ currency }}-{{ rates.corporate3 }}/" method="POST">
2015-08-13 16:17:27 +03:00
<script
src="https://checkout.stripe.com/checkout.js" class="stripe-button"
2015-08-20 12:10:06 +03:00
data-key="{{ stripe_public }}"
2016-05-26 13:48:15 +03:00
data-amount="{{ stripe_amounts.corporate3 }}"
2015-08-13 16:17:27 +03:00
data-name="Django REST framework"
data-description="Premium"
2016-05-26 13:48:15 +03:00
data-currency="{{ currency }}"
2015-08-13 16:17:27 +03:00
data-allow-remember-me=false
data-billing-address=true
2015-08-13 16:17:27 +03:00
data-label='Sign up'
2015-08-20 12:10:06 +03:00
data-panel-label='Sign up - {% verbatim %}{{amount}}{% endverbatim %}/mo'>
2015-08-13 16:17:27 +03:00
</script>
</form>
</div>
</div>
</div>
2015-08-14 14:34:47 +03:00
<div style="clear: both; padding-top: 50px"></div>
*Billing is monthly and you can cancel at any time.*
2015-08-13 16:17:27 +03:00
2017-03-11 01:06:01 +03:00
Once you've signed up, we will contact you via email and arrange your ad placements on the site.
2015-08-13 16:17:27 +03:00
For further enquires please contact <a href=mailto:funding@django-rest-framework.org>funding@django-rest-framework.org</a>.
2015-08-13 16:17:27 +03:00
---
2016-05-26 13:48:15 +03:00
## Accountability
2017-03-10 08:30:31 +03:00
In an effort to keep the project as transparent as possible, we are releasing [monthly progress reports](http://www.encode.io/reports/february-2017) and regularly include financial reports and cost breakdowns.
2016-05-26 13:48:15 +03:00
<!-- Begin MailChimp Signup Form -->
<link href="//cdn-images.mailchimp.com/embedcode/classic-10_7.css" rel="stylesheet" type="text/css">
<style type="text/css">
#mc_embed_signup{background:#fff; clear:left; font:14px Helvetica,Arial,sans-serif; }
/* Add your own MailChimp form style overrides in your site stylesheet or in this style block.
We recommend moving this block and the preceding CSS link to the HEAD of your HTML file. */
</style>
<div id="mc_embed_signup">
<form action="//encode.us13.list-manage.com/subscribe/post?u=b6b66bb5e4c7cb484a85c8dd7&amp;id=e382ef68ef" method="post" id="mc-embedded-subscribe-form" name="mc-embedded-subscribe-form" class="validate" target="_blank" novalidate>
<div id="mc_embed_signup_scroll">
<h2>Stay up to date, with our monthly progress reports...</h2>
<div class="mc-field-group">
<label for="mce-EMAIL">Email Address </label>
<input type="email" value="" name="EMAIL" class="required email" id="mce-EMAIL">
</div>
<div id="mce-responses" class="clear">
<div class="response" id="mce-error-response" style="display:none"></div>
<div class="response" id="mce-success-response" style="display:none"></div>
</div> <!-- real people should not fill this in and expect good things - do not remove this or risk form bot signups-->
<div style="position: absolute; left: -5000px;" aria-hidden="true"><input type="text" name="b_b6b66bb5e4c7cb484a85c8dd7_e382ef68ef" tabindex="-1" value=""></div>
<div class="clear"><input type="submit" value="Subscribe" name="subscribe" id="mc-embedded-subscribe" class="button"></div>
</div>
</form>
</div>
<script type='text/javascript' src='//s3.amazonaws.com/downloads.mailchimp.com/js/mc-validate.js'></script><script type='text/javascript'>(function($) {window.fnames = new Array(); window.ftypes = new Array();fnames[0]='EMAIL';ftypes[0]='email';fnames[1]='FNAME';ftypes[1]='text';fnames[2]='LNAME';ftypes[2]='text';}(jQuery));var $mcj = jQuery.noConflict(true);</script>
<!--End mc_embed_signup-->
---
## Our sponsors
<div id="fundingInclude"></div>
<script src="https://fund.django-rest-framework.org/funding_include.js"></script>