* enhancement: add more kql spec tests and simplify ast normalization * enhancement: kql parser error if query starts with AND * enhancement: add kql docs and support for date and time only dateTimeRestriction queries * enhancement: add the ability to decide how kql nodes get connected connecting nodes (with edges) seem straight forward when not using group, the default connection for nodes with the same node is always OR. THis only applies for first level nodes, for grouped nodes it is defined differently. The KQL docs are saying, nodes inside a grouped node, with the same key are connected by a AND edge. * enhancement: explicit error handling for falsy group nodes and queries with leading binary operator * enhancement: use optimized grammar for kql parser and toolify pigeon * enhancement: simplify error handling * fix: kql implicit 'AND' and 'OR' follows the ms html spec instead of the pdf spec * enhancement: add support for natural language kql date queries * enhancement: structure kql parser tests into logical clusters * fix: time-range error naming
ownCloud Infinite Scale
- Introduction
- Overview
- Important Readings
- Run ownCloud Infinite Scale
- Documentation
- Security
- Contributing
- Copyright
Introduction
ownCloud Infinite Scale (oCIS) is the new file sync & share platform that will be the foundation of your data management platform.
Make sure to download the latest released version today!
Overview
Clients
Infinite Scale allows the following ownCloud clients:
to synchronize and share file spaces with a scalable server backend based on reva using open and well defined APIs like WebDAV and CS3.
Web Office Applications
Infinite Scale can integrate web office applications such as:
Collaborative editing is supported by the WOPI application gateway.
Authentication
Users are authenticated via OpenID Connect using either an external IdP like Keycloak or the embedded LibreGraph Connect identity provider.
Installation
With focus on easy install and operation, Infinite Scale is delivered as single binary or container that allows scaling from a Raspberry Pi to a Kubernetes cluster by changing the configuration and starting multiple services as needed. The multiservice architecture allows tailoring the functionality to your needs and reusing services that may already be in place like when using Keycloak. See the details below for various installation options.
Important Readings
Before starting to set up an instance, we highly recommend reading the Prerequisites, the Deployment section and especially the General Information page describing and explaining information that is valid for all deployment types.
Run ownCloud Infinite Scale
Use the Official Documentation
See the Quick Guide or the Binary Setup for a single-node bare-metal deployment starting with a Raspberry Pi or single server, the Container Setup for classic container environments like docker or learn how to deploy to Kubernetes.
Use the ocis Repo as Source
Use this method to run an instance with the latest code. This is only recommended for development purposes. The minimum go version required is 1.20. Note that you need as prerequisite a C compile environment installed because some dependences like reva have components that require c-go libraries/tool-chains. The command installing for debian based systems is: sudo apt install build-essentials. To build and run a local instance with demo users:
# get the source
git clone git@github.com:owncloud/ocis.git
# enter the ocis dir
cd ocis
# generate assets
make generate
# build the binary
make -C ocis build
# initialize a minimal oCIS configuration
./ocis/bin/ocis init
# run with demo users
IDM_CREATE_DEMO_USERS=true ./ocis/bin/ocis server
All batteries included: no external database, no external IDP needed!
Documentation
Admin Documentation
Refer to the Admin Documentation - Introduction to Infinite Scale to get started with running oCIS in production.
Development Documentation
See the Development Documentation - Getting Started to get an overview of Requirements, the repository structure and other starting points.
Security
See the Security Aspects for a general overview of security related topics. If you find a security issue, please contact security@owncloud.com first.
Contributing
We are very happy that oCIS does not require a Contributor License Agreement (CLA) as it is Apache 2.0 licensed. We hope this will make it easier to contribute code. If you want to get in touch, most of the developers hang out in our rocket chat channel or reach out to the ownCloud central forum.
Infinite Scale is carefully internationalized so that everyone, no matter what language they speak, has a great experience. To achieve this we rely on the help of volunteer translators. If you want to help, you can find the projects behind the following links:
Transifex for ownCloud web and Transifex for ownCloud (Select the resource by filtering for ocis-).
Please always refer to our Contribution Guidelines.
End User License Agreement
Some builds of stable ownCloud Infinite Scale releases provided by ownCloud GmbH are subject to an End User License Agreement.
Copyright
Copyright (c) 2020-2023 ownCloud GmbH <https://owncloud.com>