Alexander Minkin
76dedd6b82
* build(js): remove yarn.lock Yarn had changed its methods of packaging long ago and it hasn't been supported ever since. It's much better and easier to just use the original NPM. * fix(docker): change yarn to npm command * doc(README): change yarn mentions to npm * fix(docker): use npm ci instead of npm install * build(package-lock): update js dependencies * build(docker): use node:20 image when building |
||
---|---|---|
.github | ||
CLI | ||
data | ||
install | ||
locales | ||
misc | ||
ServiceAPI | ||
storage | ||
themepacks | ||
tmp/api-storage | ||
VKAPI | ||
Web | ||
.gitignore | ||
bootstrap.php | ||
CODE_OF_CONFLICT.md | ||
CODE_STYLE.md | ||
composer.json | ||
composer.lock | ||
COPYING | ||
crowdin.yml | ||
DBEntity.updated.php | ||
manifest.yml | ||
openvk-example.yml | ||
openvkctl | ||
quirks.yml | ||
README.md | ||
README_RU.md | ||
Vagrantfile |
OpenVK
OpenVK is an attempt to create a simple CMS that cosplays imitates old VKontakte. Code provided here is not stable yet.
VKontakte belongs to Pavel Durov and VK Group.
To be honest, we don't know whether if it even works. However, this version is maintained and we will be happy to accept your bugreports in our bug tracker. You should also be able to submit them using ticketing system (you will need an OpenVK account for this).
When's the release?
We will release OpenVK as soon as it's ready. As for now, you can:
git clone
this repo's master branch (usegit pull
to update)- Grab a prebuilt OpenVK distro from GitHub artifacts
Instances
A list of instances can be found in our wiki of this repository.
Can I create my own OpenVK instance?
Yes! And you are very welcome to.
However, OVK makes use of Chandler Application Server. This software requires extensions, that may not be provided by your hosting provider (namely, sodium and yaml. these extensions are available on most of ISPManager hostings).
If you want, you can add your instance to the list above so that people can register there.
System requirements
Here is our minimum hardware recommendation:
- CPU: Recent (AMD Zen2 or equivalent) quad-core 2GHz+ CPU
- RAM: At least 2GB RAM (we recommend 6GB or 8GB for OpenVK with Kafka)
- Minimum database space: 10GB
Installation procedure
- Install PHP 7.4, web-server, Composer, Node.js, NPM and Chandler
- PHP 8 is still being tested; the functionality of the engine on this version of PHP is not yet guaranteed.
- Install MySQL-compatible database.
- We recommend using Percona Server, but any MySQL-compatible server should work too.
- Server should be compatible with at least MySQL 5.6, MySQL 8.0+ is recommended.
- Support for MySQL 4.1+ is WIP, replace
utf8mb4
andutf8mb4_unicode_520_ci
withutf8
andutf8_unicode_ci
in SQLs.
- Install commitcaptcha and OpenVK as Chandler extensions like this:
git clone https://github.com/openvk/openvk /path/to/chandler/extensions/available/openvk
git clone https://github.com/openvk/commitcaptcha /path/to/chandler/extensions/available/commitcaptcha
- And enable them:
ln -s /path/to/chandler/extensions/available/commitcaptcha /path/to/chandler/extensions/enabled/
ln -s /path/to/chandler/extensions/available/openvk /path/to/chandler/extensions/enabled/
- Import
install/init-static-db.sql
to the same database you installed Chandler to and import all sqls frominstall/sqls
to the same database - Import
install/init-event-db.sql
to a separate database (Yandex.Clickhouse can also be used, highly recommended) - Copy
openvk-example.yml
toopenvk.yml
and change options to your liking - Run
composer install
in OpenVK directory - Run
composer install
in commitcaptcha directory - Move to
Web/static/js
and executenpm install
- Set
openvk
as your root app inchandler.yml
Once you are done, you can login as a system administrator on the network itself (no registration required):
- Login:
admin@localhost.localdomain6
- Password:
admin
- It is recommended to change the password of the built-in account or disable it.
💡 Confused? Full installation walkthrough is available here (CentOS 8 and family).
Looking for Docker or Kubernetes deployment?
See install/automated/docker/README.md
and install/automated/kubernetes/README.md
for Docker and Kubernetes deployment instructions.
If my website uses OpenVK, should I release its sources?
It depends. You can keep the sources to yourself if you do not plan to distribute your website binaries. If your website software must be distributed, it can stay non-OSS provided the OpenVK is not used as a primary application and is not modified. If you modified OpenVK for your needs or your work is based on it and you are planning to redistribute this, then you should license it under terms of any LGPL-compatible license (like OSL, GPL, LGPL etc).
Where can I get assistance?
You may reach out to us via:
- Bug Tracker
- Ticketing System
- Telegram Chat: Go to our channel and open discussion in our channel menu.
- GitHub Discussions
- Matrix Chat: #openvk:matrix.org
Attention: bug tracker, board, Telegram and Matrix chat are public places, ticketing system is being served by volunteers. If you need to report something that should not be immediately disclosed to general public (for instance, a vulnerability), please contact us directly via this email: openvk [at] tutanota [dot] com