Skip to content

Secure, affordable, private digital spaces for work and play.

License

Notifications You must be signed in to change notification settings

KellyAH/convene

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Convene

Convene secure, affordable, always-available digital Spaces where anyone can (play || work || grow || be). 🎲 👩‍💻 🌱 🛋️

Overview

Convene is an Operating System for Community Owned Digital Infrastructure. Once deployed to a server, Convene is accessed by any web browser.

Convene serves as a community-owned, more ethical alternative to investor-owned online tools like SquareSpace, Etsy, Patreon, Zoom, Yelp, and more.

A Convene Deployment is a Neighborhood. People create Spaces in a Neighborhood, and fill those Spaces with Furniture to meet their collective digital needs. For example:

  • A Regional Co-operative network could provide their members with shared payments and video communication infrastructure.
  • A Farmer's Market could provide professionally designed websites and social media presences for their vendors.
  • A Co-operative Startup Incubator could keep capitalization tables, Patronage Records and other logistical records.

You can see more in the Zinc neighborhood.

We have two milestones we are working towards:

Using Convene

Zinc maintains a Convene Neighborhood at https://convene.zinc.coop. For people who want to run their own Neighborhood of Spaces, consider purchasing a Convene Operator License.

Purchasing a Convene Operator License.

Individuals and non-commercial organizations may run their own Convene deployment however they see fit without requiring payment.

However, if the person or organization engages in commerce, defined as taking currency in exchange for goods or services, then the organization must purchase a license to use Convene.

Pricing is determined on a case-by-case basis. Please reach out to [email protected] for licensing information.

Help and Support

Organizations and individuals who are comfortable relying on free Community Support are encouraged to start a discussion. Maintainers respond as they are available.

Paid support is available for $135 USD per hour1.

Contributing to Convene

We're always excited for new contributors! Read more in our guide to contributing, located in CONTRIBUTING.md

System Overview

The central piece of Convene is a Ruby on Rails server that is responsible for:

  • serving the Convene UI
  • managing users, spaces, rooms, permissions, etc

This high level view of our design shows the personas and segments we are focusing on initially with Convene. It also includes our current vision of the types of spaces, rooms and participants it serves and clarifies the design of privacy permissions.

The Convene UI is based on Rails standard templating system, with heavy use of:

  • Stimulus JS
    • the entry point for our JavaScript is in app/javascript/controllers/index.js, which loads all app/javascript/*_controllers.js files
  • Tailwind CSS to help speed up making good-looking UIs

Jitsi is Convene's video call infrastructure. The video_room_controller.js is the entry point where we load a Jitsi video call iframe into Convene's UI.

If you want to run Jitsi locally, see the configuration provided in infrastructure/jitsi-meet-local.

Architecture overview diagram

Last updated: April 2021

Original on Miro: https://miro.com/app/board/o9J_lLrbz1g=/

Configuring Your Development Machine

See Developer setup and documentation.

Debugger

To run pry or byebug, run bin/connect web.

Developing Mailers

Set SMTP_* environment variables to configure Action Mailer.

To preview mailers, visit http://localhost:3000/rails/mailers/

Testing Convene

The Convene interface is tested in two ways:

  1. Open-box unit and integration tests, which are defined in the spec folder
  2. Closed-box story tests, which are defined in the top level features folder

Many enhancements and fixes can be made without updating the story tests, while almost all changes will want updated unit or integration tests.

For story tests, we use Cucumber to encourage us to write tests as human-friendly documentation.

For unit and integration tests, we use RSpec. RSpec is a nice complement to Cucumber, in that it allows us to directly integrate with the underlying Ruby and Rails code without writing human or computer interfaces that require inter-process communication.

This helps us write small, focused tests that deal with 1~3 Ruby classes instead of having to spin up a working instance of the entire application.

Tests that need database access should require "rails_helper", and tests that can be executed without a database should require "spec_helper".

Overview of the features folder

Last updated: April 2021

Original on Miro: https://miro.com/app/board/o9J_lLrbz1g=/

About The Zinc Collective

Convene is maintained by a dedicated community of volunteer Contributors and Maintainers known as the Zinc Collective, a digital product and services cooperative.

We have a Pledge and Code of Conduct. And anyone can become a contributor and/or maintainer.

Footnotes

Paid Support

Our paid support rate is pegged to 3x the San Francisco Living Wage for a couple with a single worker raising three children.

This rate is negotiable for organizations that offer Zinc a patronage account or corresponding equity stake.

Paid support clients may also request a deferred payment program, with terms to be determined on a case-by-case basis.

About

Secure, affordable, private digital spaces for work and play.

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Ruby 54.0%
  • JavaScript 15.1%
  • Gherkin 13.3%
  • HTML 10.1%
  • Shell 3.4%
  • HCL 2.1%
  • Other 2.0%