Convene image

Convene

digital spaces

From GitHub

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

Categories

Readme from GitHub

Convene <!-- omit in toc -->

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](./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

See [Architecture](./CONTRIBUTING.md#11-architecture) for how Convene is architected.

Configuring Your Development Machine

See [Developer setup and documentation](./CONTRIBUTING.md#2-machine-setup).

Debugger

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

Developing Mailers

Set [SMTP_* environment variables to configure Action Mailer](.env.example).

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](./spec)
  2. Closed-box story tests, which are defined in the top level [features folder](./features)

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

[](./docs/features-overview.jpg)

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 <!-- omit in toc -->

Paid Support <!-- omit in toc -->

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.