Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Enterprise licensing #3624

Merged
merged 47 commits into from
Dec 3, 2024
Merged

feat: Enterprise licensing #3624

merged 47 commits into from
Dec 3, 2024

Conversation

matthewelwell
Copy link
Contributor

@matthewelwell matthewelwell commented Mar 15, 2024

Changes

This PR sets up licensing work to enable us to digitally sign licensing agreements and enable them to be evaluated towards the enterprise's limits.

A few management commands have been added to allow us to create signatures and to digitally sign licensing agreements.

To create a private key (which has been done for production already, stored in Bitwarden) run:

poetry run python manage.py create_licensing_private_key

To create a public key (which has been done for production already, added to the settings file) run:

poetry run python manage.py create_licensing_public_key

To create and sign a licence agreement run:

poetry run python manage.py create_signed_licence \
--organisation-name "Some Org" \
--plan-id "SomePlanID" \
--num-seats 20 \ 
--num-projects 10 \
--num-api-calls 2000000

Which will output the JSON file for the license and an cryptographic blob which is the licence signature.

To add a licence to a Flagsmith organisation upload via PUT the two files, one the license doc and the other the licence signature to the following URL path:

/api/v1/organisations/:organisation_id/licence

How did you test this code?

New tests were added as well as manually verifying that the management commands could work.

@matthewelwell matthewelwell changed the title feat: WIP: licensing feat: WIP - licensing Mar 15, 2024
Copy link

vercel bot commented Mar 15, 2024

The latest updates on your projects. Learn more about Vercel for Git ↗︎

3 Skipped Deployments
Name Status Preview Comments Updated (UTC)
docs ⬜️ Ignored (Inspect) Visit Preview Nov 28, 2024 2:07pm
flagsmith-frontend-preview ⬜️ Ignored (Inspect) Visit Preview Nov 28, 2024 2:07pm
flagsmith-frontend-staging ⬜️ Ignored (Inspect) Visit Preview Nov 28, 2024 2:07pm

Copy link
Contributor

github-actions bot commented May 16, 2024

Uffizzi Preview deployment-57790 was deleted.

@github-actions github-actions bot added the feature New feature or request label Oct 30, 2024
@github-actions github-actions bot added feature New feature or request and removed feature New feature or request labels Oct 30, 2024
@github-actions github-actions bot removed the feature New feature or request label Oct 31, 2024
@github-actions github-actions bot added feature New feature or request and removed feature New feature or request labels Nov 11, 2024
@github-actions github-actions bot added feature New feature or request and removed feature New feature or request labels Nov 11, 2024
Copy link
Contributor Author

@matthewelwell matthewelwell left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@zachaysan approving via comment since it's my PR. Can you approve (but let's hold off on merging until next week)?

@matthewelwell matthewelwell merged commit fbd1a13 into main Dec 3, 2024
8 checks passed
@matthewelwell matthewelwell deleted the feat/licence-keys branch December 3, 2024 14:05
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
api Issue related to the REST API feature New feature or request
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Enterprise Licence Management
2 participants