Try it at: https://valour.gg/
Valour is designed to be as flexible as possible - with a client built atop an official API for use in bots and applications. Valour is open-source, and your personal client can be as creative as your imagination allows. We believe in an open ecosystem for Valour - and hold bot authors to follow in our transparency to respect user data and privacy.
Valour's client allows you to open multiple chats at once - even across several communities. Valour's flexible in-built window system allows you to multitask, and for moderation teams to keep an eye on the action. Every chat window is dynamic and responsive, allowing you to resize and space your chats how you want. It's your client, after all.
Planets are the communities of Valour, allowing you to build your ideas and foster strong interactions. With role management and per-channel permissions, you can ensure that your community is managed how you see fit.
Planets can deploy a currency and economic system in two clicks. Why? Don't bother managing 20 different 'coins' and 'xp' from different bots, and use one built-in system to handle user value tracking. Users can send your currency to each other in the community, and even trade it for community-defined items. You can even hook the API into your own systems, allowing your community members to pay for custom perks and be rewarded for anything!
Valour Nodes are designed to be able to run independantly of any central server or service. One node failing has no effect on other nodes, allowing Valour to scale safely and efficiently. Our logical-server based system, rather than depending on cloud services, also allows us to be provider-agnostic, hosting Valour across different providers and giving us the ability to dedicate resources to large communities that need it.
To contribute to Valour, getting a mock server environment set up is crucial. Here's a simple walkthough:
- Install .Net 8 at https://dotnet.microsoft.com/en-us/download/dotnet/8.0
- We suggest using Rider or Visual Studio, but any IDE supporting dotnet should work. Make sure it supports .Net 8
- Open the .sln file in the root project folder with your IDE. Open the terminal and run
dotnet workload restore
- Now we can run Valour, but it will immediately crash because required services are missing.
- Install locally or deploy PostreSQL to a server https://www.postgresql.org/
- There are two database schemas in the project you should use on this postgres server. Both are named
definitions.sql
and when run will create all the necessary tables. One is located inValour.Database/Context
and the other is atValour.Server/Cdn/definitions.sql
. The first is critical to make Valour function, and the second is needed for uploading media. - You will also need to deploy or run locally a redis instance https://redis.com/
- Edit appsettings.json to reflect your services and their locations.
- (OPTIONAL) For the media system to work, you will need an s3-compliant bucket. Cloudflare provides these for free with Cloudflare R2 with very generous limitations
- (OPTIONAL) You will need to verify emails manually in the database unless you create a sendgrid account https://sendgrid.com/ and use an API key
- (OPTIONAL) To make notifications work, you will need a valid vapid key and details.
- There is a
appsettings.helper.json
file to help you - Also note that we release docker images for every merge, which you can find here on github. You will still need supporting services to run these images and valid appsettings. We run Valour on kubernetes ourselves.
- Important note: When developing locally, change the
BaseAddress
inValourClient.cs
, otherwise nothing will function. And to just test the client, point it tohttps://app.valour.gg
and it will use the official Valour servers.
Building a platform is hard work. You can directly support Valour at the following:
- Patreon
- Solana:
- FUJypRAafs4nZ6uTLh4zVoh9g8Hd5XS8Q3At99baYFKJ (Ecosystem & Development Fund)
- 3TpmRtdR6NYoiCGvXVKm5HGUoM3fnztQteaxF56dJbqB (Community Governed Fund)
The name "Valour" is a trademark of Valour Software LLC, and a trademark application is pending. While the project is open-source, use of the trademark must not imply endorsement by Valour Software LLC or mislead others regarding the origin of the project.
Forks or derivative projects may not use the name "Valour" or related branding without prior written permission from Valour Software LLC. Any use of the trademark outside the scope of this project requires explicit permission.
While use of the trademark is not permitted for forks of the project itself, use of the mark is allowed for Valour bots, plugins, or integrations. If you are unsure, contact us!