forked from vikunja/vikunja
Compare commits
47 Commits
c45ad112a2
...
7d8c42ab98
Author | SHA1 | Date | |
---|---|---|---|
7d8c42ab98 | |||
9c66b473dd | |||
0000f83592 | |||
eedc84b5a0 | |||
0c4464ae1e | |||
7d78fddeeb | |||
f3fb369e6b | |||
c74bf0d33e | |||
414d827533 | |||
a3dd9db54d | |||
f50b0b342a | |||
0c3d2d4bf1 | |||
bd046d98ba | |||
7ad256f6cd | |||
0a6bbc2efd | |||
efa1dc3106 | |||
aa43127e52 | |||
10f71c29b2 | |||
2dad404217 | |||
b961119517 | |||
|
a16fd67b51 | ||
6816f041a1 | |||
aaa0593289 | |||
|
6cbaf5bbf9 | ||
1e73462f79 | |||
|
8d7825171f | ||
eb3b4e9ed9 | |||
5856f21f31 | |||
9bf535d06f | |||
4decbf9fc4 | |||
d372f0a23c | |||
d7ef00fb85 | |||
aae8c677c9 | |||
cfed1f073d | |||
6a836658d7 | |||
b1da03f7d9 | |||
55956f2b52 | |||
47e42238ef | |||
1c83b7b3c0 | |||
|
cca430810d | ||
f76bb2b4a9 | |||
7ada82ea92 | |||
cd90db3117 | |||
b6d5605ef6 | |||
ac377a7a5d | |||
22f89c1ccc | |||
|
848f596636 |
|
@ -518,7 +518,7 @@ steps:
|
||||||
|
|
||||||
# Build os packages and push it to our bucket
|
# Build os packages and push it to our bucket
|
||||||
- name: build-os-packages-unstable
|
- name: build-os-packages-unstable
|
||||||
image: goreleaser/nfpm:v2.27.1
|
image: goreleaser/nfpm:v2.28.0
|
||||||
pull: always
|
pull: always
|
||||||
commands:
|
commands:
|
||||||
- apk add git go
|
- apk add git go
|
||||||
|
@ -534,7 +534,7 @@ steps:
|
||||||
depends_on: [ after-build-compress ]
|
depends_on: [ after-build-compress ]
|
||||||
|
|
||||||
- name: build-os-packages-version
|
- name: build-os-packages-version
|
||||||
image: goreleaser/nfpm:v2.27.1
|
image: goreleaser/nfpm:v2.28.0
|
||||||
pull: always
|
pull: always
|
||||||
commands:
|
commands:
|
||||||
- apk add git go
|
- apk add git go
|
||||||
|
@ -743,6 +743,6 @@ steps:
|
||||||
- failure
|
- failure
|
||||||
---
|
---
|
||||||
kind: signature
|
kind: signature
|
||||||
hmac: 1fae38b149582b7b164b40a0c5e491bd36bf42302f0d14ca558de521f9569767
|
hmac: 7bade2fc44072cf5730f7f15b5be18058ce47d216853c8c39c692f967c640e20
|
||||||
|
|
||||||
...
|
...
|
||||||
|
|
|
@ -165,7 +165,7 @@ All releases can be found on https://code.vikunja.io/api/releases.
|
||||||
|
|
||||||
* *(background)* Add Last-Modified header (#1376)
|
* *(background)* Add Last-Modified header (#1376)
|
||||||
* *(caldav)* Add support for repeating tasks
|
* *(caldav)* Add support for repeating tasks
|
||||||
* *(caldav)* Export Labels to Caldav (#1409)
|
* *(caldav)* Export Labels to CalDAV (#1409)
|
||||||
* *(caldav)* Import caldav categories as Labels (#1413)
|
* *(caldav)* Import caldav categories as Labels (#1413)
|
||||||
* *(migrators)* Remove wunderlist (#1346)
|
* *(migrators)* Remove wunderlist (#1346)
|
||||||
* *(release)* Use compressed binaries for package releases
|
* *(release)* Use compressed binaries for package releases
|
||||||
|
@ -1427,7 +1427,7 @@ All releases can be found on https://code.vikunja.io/api/releases.
|
||||||
* Add option to disable totp for everyone
|
* Add option to disable totp for everyone
|
||||||
* Add plausible to docs
|
* Add plausible to docs
|
||||||
* Add restarting commands to all example docker compose files
|
* Add restarting commands to all example docker compose files
|
||||||
* Add seperate docker pipeline for amd64 and arm
|
* Add separate docker pipeline for amd64 and arm
|
||||||
* Add test mail command (#571)
|
* Add test mail command (#571)
|
||||||
* Add todoist migrator to available migrators in info endpoint if it is enabled
|
* Add todoist migrator to available migrators in info endpoint if it is enabled
|
||||||
* Add unsplash image proxy for images and thumbnails
|
* Add unsplash image proxy for images and thumbnails
|
||||||
|
@ -1620,7 +1620,7 @@ All releases can be found on https://code.vikunja.io/api/releases.
|
||||||
* Update Renovate Configuration (#161)
|
* Update Renovate Configuration (#161)
|
||||||
* Update src.techknowlogick.com/xgo commit hash to bb0faa3 (#279)
|
* Update src.techknowlogick.com/xgo commit hash to bb0faa3 (#279)
|
||||||
* Update src.techknowlogick.com/xgo commit hash to c43d4c4 (#224)
|
* Update src.techknowlogick.com/xgo commit hash to c43d4c4 (#224)
|
||||||
* Update xorm redis cacher to use the xorm logger instead of a special seperate one
|
* Update xorm redis cacher to use the xorm logger instead of a special separate one
|
||||||
* Update xorm to v1 (#323)
|
* Update xorm to v1 (#323)
|
||||||
|
|
||||||
## [0.12] - 2020-04-04
|
## [0.12] - 2020-04-04
|
||||||
|
@ -1761,7 +1761,7 @@ All releases can be found on https://code.vikunja.io/api/releases.
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
|
|
||||||
* Better Caldav support (#73)
|
* Better CalDAV support (#73)
|
||||||
* Added settings for max open/idle connections and max connection lifetime (#74)
|
* Added settings for max open/idle connections and max connection lifetime (#74)
|
||||||
* /info endpoint (#85)
|
* /info endpoint (#85)
|
||||||
* Added http endpoint to list all users on a list (#87)
|
* Added http endpoint to list all users on a list (#87)
|
||||||
|
|
|
@ -3,7 +3,7 @@ service:
|
||||||
# Default is a random token which will be generated at each startup of vikunja.
|
# Default is a random token which will be generated at each startup of vikunja.
|
||||||
# (This means all already issued tokens will be invalid once you restart vikunja)
|
# (This means all already issued tokens will be invalid once you restart vikunja)
|
||||||
JWTSecret: "<jwt-secret>"
|
JWTSecret: "<jwt-secret>"
|
||||||
# The duration of the issed JWT tokens in seconds.
|
# The duration of the issued JWT tokens in seconds.
|
||||||
# The default is 259200 seconds (3 Days).
|
# The default is 259200 seconds (3 Days).
|
||||||
jwtttl: 259200
|
jwtttl: 259200
|
||||||
# The duration of the "remember me" time in seconds. When the login request is made with
|
# The duration of the "remember me" time in seconds. When the login request is made with
|
||||||
|
@ -46,7 +46,7 @@ service:
|
||||||
sentrydsn: ''
|
sentrydsn: ''
|
||||||
# If not empty, this will enable `/test/{table}` endpoints which allow to put any content in the database.
|
# If not empty, this will enable `/test/{table}` endpoints which allow to put any content in the database.
|
||||||
# Used to reset the db before frontend tests. Because this is quite a dangerous feature allowing for lots of harm,
|
# Used to reset the db before frontend tests. Because this is quite a dangerous feature allowing for lots of harm,
|
||||||
# each request made to this endpoint neefs to provide an `Authorization: <token>` header with the token from below. <br/>
|
# each request made to this endpoint needs to provide an `Authorization: <token>` header with the token from below. <br/>
|
||||||
# **You should never use this unless you know exactly what you're doing**
|
# **You should never use this unless you know exactly what you're doing**
|
||||||
testingtoken: ''
|
testingtoken: ''
|
||||||
# If enabled, vikunja will send an email to everyone who is either assigned to a task or created it when a task reminder
|
# If enabled, vikunja will send an email to everyone who is either assigned to a task or created it when a task reminder
|
||||||
|
@ -77,7 +77,7 @@ database:
|
||||||
maxopenconnections: 100
|
maxopenconnections: 100
|
||||||
# Sets the maximum number of idle connections to the db.
|
# Sets the maximum number of idle connections to the db.
|
||||||
maxidleconnections: 50
|
maxidleconnections: 50
|
||||||
# The maximum lifetime of a single db connection in miliseconds.
|
# The maximum lifetime of a single db connection in milliseconds.
|
||||||
maxconnectionlifetime: 10000
|
maxconnectionlifetime: 10000
|
||||||
# Secure connection mode. Only used with postgres.
|
# Secure connection mode. Only used with postgres.
|
||||||
# (see https://pkg.go.dev/github.com/lib/pq?tab=doc#hdr-Connection_String_Parameters)
|
# (see https://pkg.go.dev/github.com/lib/pq?tab=doc#hdr-Connection_String_Parameters)
|
||||||
|
@ -96,7 +96,7 @@ cache:
|
||||||
enabled: false
|
enabled: false
|
||||||
# Cache type. Possible values are "keyvalue", "memory" or "redis".
|
# Cache type. Possible values are "keyvalue", "memory" or "redis".
|
||||||
# When choosing "keyvalue" this setting follows the one configured in the "keyvalue" section.
|
# When choosing "keyvalue" this setting follows the one configured in the "keyvalue" section.
|
||||||
# When choosing "redis" you will need to configure the redis connection seperately.
|
# When choosing "redis" you will need to configure the redis connection separately.
|
||||||
type: keyvalue
|
type: keyvalue
|
||||||
# When using memory this defines the maximum size an element can take
|
# When using memory this defines the maximum size an element can take
|
||||||
maxelementsize: 1000
|
maxelementsize: 1000
|
||||||
|
@ -106,14 +106,14 @@ redis:
|
||||||
enabled: false
|
enabled: false
|
||||||
# The host of the redis server including its port.
|
# The host of the redis server including its port.
|
||||||
host: 'localhost:6379'
|
host: 'localhost:6379'
|
||||||
# The password used to authenicate against the redis server
|
# The password used to authenticate against the redis server
|
||||||
password: ''
|
password: ''
|
||||||
# 0 means default database
|
# 0 means default database
|
||||||
db: 0
|
db: 0
|
||||||
|
|
||||||
cors:
|
cors:
|
||||||
# Whether to enable or disable cors headers.
|
# Whether to enable or disable cors headers.
|
||||||
# Note: If you want to put the frontend and the api on seperate domains or ports, you will need to enable this.
|
# Note: If you want to put the frontend and the api on separate domains or ports, you will need to enable this.
|
||||||
# Otherwise the frontend won't be able to make requests to the api through the browser.
|
# Otherwise the frontend won't be able to make requests to the api through the browser.
|
||||||
enable: true
|
enable: true
|
||||||
# A list of origins which may access the api. These need to include the protocol (`http://` or `https://`) and port, if any.
|
# A list of origins which may access the api. These need to include the protocol (`http://` or `https://`) and port, if any.
|
||||||
|
@ -210,7 +210,7 @@ migration:
|
||||||
# Note that the vikunja frontend expects this to be /migrate/todoist
|
# Note that the vikunja frontend expects this to be /migrate/todoist
|
||||||
redirecturl: <frontend url>/migrate/todoist
|
redirecturl: <frontend url>/migrate/todoist
|
||||||
trello:
|
trello:
|
||||||
# Wheter to enable the trello migrator or not
|
# Whether to enable the trello migrator or not
|
||||||
enable: false
|
enable: false
|
||||||
# The client id, required for making requests to the trello api
|
# The client id, required for making requests to the trello api
|
||||||
# You need to register your vikunja instance at https://trello.com/app-key (log in before you visit that link) to get this
|
# You need to register your vikunja instance at https://trello.com/app-key (log in before you visit that link) to get this
|
||||||
|
@ -226,7 +226,7 @@ migration:
|
||||||
enable: false
|
enable: false
|
||||||
# The client id, required for making requests to the microsoft graph api
|
# The client id, required for making requests to the microsoft graph api
|
||||||
# See https://docs.microsoft.com/en-us/azure/active-directory/develop/quickstart-register-app#register-an-application
|
# See https://docs.microsoft.com/en-us/azure/active-directory/develop/quickstart-register-app#register-an-application
|
||||||
# for information about how to register your vikuinja instance.
|
# for information about how to register your Vikunja instance.
|
||||||
clientid:
|
clientid:
|
||||||
# The client secret, also required for making requests to the microsoft graph api
|
# The client secret, also required for making requests to the microsoft graph api
|
||||||
clientsecret:
|
clientsecret:
|
||||||
|
@ -269,7 +269,7 @@ legal:
|
||||||
# Key Value Storage settings
|
# Key Value Storage settings
|
||||||
# The Key Value Storage is used for different kinds of things like metrics and a few cache systems.
|
# The Key Value Storage is used for different kinds of things like metrics and a few cache systems.
|
||||||
keyvalue:
|
keyvalue:
|
||||||
# The type of the storage backend. Can be either "memory" or "redis". If "redis" is chosen it needs to be configured seperately.
|
# The type of the storage backend. Can be either "memory" or "redis". If "redis" is chosen it needs to be configured separately.
|
||||||
type: "memory"
|
type: "memory"
|
||||||
|
|
||||||
auth:
|
auth:
|
||||||
|
@ -284,7 +284,7 @@ auth:
|
||||||
# If the email is not public in those cases, authenticating will fail.
|
# If the email is not public in those cases, authenticating will fail.
|
||||||
# **Note 2:** The frontend expects to be redirected after authentication by the third party
|
# **Note 2:** The frontend expects to be redirected after authentication by the third party
|
||||||
# to <frontend-url>/auth/openid/<auth key>. Please make sure to configure the redirect url with your third party
|
# to <frontend-url>/auth/openid/<auth key>. Please make sure to configure the redirect url with your third party
|
||||||
# auth service accordingy if you're using the default vikunja frontend.
|
# auth service accordingly if you're using the default vikunja frontend.
|
||||||
# Take a look at the [default config file](https://kolaente.dev/vikunja/api/src/branch/main/config.yml.sample) for more information about how to configure openid authentication.
|
# Take a look at the [default config file](https://kolaente.dev/vikunja/api/src/branch/main/config.yml.sample) for more information about how to configure openid authentication.
|
||||||
openid:
|
openid:
|
||||||
# Enable or disable OpenID Connect authentication
|
# Enable or disable OpenID Connect authentication
|
||||||
|
|
|
@ -54,3 +54,10 @@ menu:
|
||||||
- name: Get it Hosted
|
- name: Get it Hosted
|
||||||
url: https://vikunja.cloud/?utm_source=io&utm_medium=io&utm_campaign=menu
|
url: https://vikunja.cloud/?utm_source=io&utm_medium=io&utm_campaign=menu
|
||||||
weight: 70
|
weight: 70
|
||||||
|
sidebar:
|
||||||
|
- name: setup
|
||||||
|
weight: 10
|
||||||
|
- name: usage
|
||||||
|
weight: 20
|
||||||
|
- name: development
|
||||||
|
weight: 30
|
|
@ -22,4 +22,4 @@ and [available configuration options]({{< ref "./setup/config.md">}}).
|
||||||
|
|
||||||
## Developing
|
## Developing
|
||||||
|
|
||||||
If you want to start contributing to Vikunja, take a look at [the development docs]({{< ref "./development/development.md">}}).
|
If you want to start contributing to Vikunja, take a look at [the development docs]({{< ref "./development/development.md">}}).
|
||||||
|
|
|
@ -12,10 +12,10 @@ menu:
|
||||||
|
|
||||||
All cli-related functions are located in `pkg/cmd`.
|
All cli-related functions are located in `pkg/cmd`.
|
||||||
Each cli command usually calls a function in another package.
|
Each cli command usually calls a function in another package.
|
||||||
For example, the `vikunja migrate` command calls `migration.Migrate()`.
|
For example, the `vikunja migrate` command calls `migration.Migrate()`.
|
||||||
|
|
||||||
Vikunja uses the amazing [cobra](https://github.com/spf13/cobra) library for its cli.
|
Vikunja uses the amazing [cobra](https://github.com/spf13/cobra) library for its cli.
|
||||||
Please refer to its documentation for informations about how to use flags etc.
|
Please refer to its documentation for information about how to use flags etc.
|
||||||
|
|
||||||
To add a new cli command, add something like the following:
|
To add a new cli command, add something like the following:
|
||||||
|
|
||||||
|
|
|
@ -29,7 +29,7 @@ Then run `mage generate-docs` to generate the configuration docs from the sample
|
||||||
|
|
||||||
## Getting Configuration Values
|
## Getting Configuration Values
|
||||||
|
|
||||||
To retreive a configured value call the key with a getter for the type you need.
|
To retrieve a configured value call the key with a getter for the type you need.
|
||||||
For example:
|
For example:
|
||||||
|
|
||||||
{{< highlight golang >}}
|
{{< highlight golang >}}
|
||||||
|
|
|
@ -12,9 +12,7 @@ menu:
|
||||||
Cron jobs are tasks which run on a predefined schedule.
|
Cron jobs are tasks which run on a predefined schedule.
|
||||||
Vikunja uses these through a light wrapper package around the excellent [github.com/robfig/cron](https://github.com/robfig/cron) package.
|
Vikunja uses these through a light wrapper package around the excellent [github.com/robfig/cron](https://github.com/robfig/cron) package.
|
||||||
|
|
||||||
The package exposes a `cron.Schedule` method with two arguments: The first one to define the schedule when the cron task
|
The package exposes a `cron.Schedule` method with two arguments: The first one to define the schedule when the cron task should run, and the second one with the actual function to run at the schedule. You would then create a new function to register your the actual cron task in your package.
|
||||||
should run, and the second one with the actual function to run at the schedule.
|
|
||||||
You would then create a new function to register your the actual cron task in your package.
|
|
||||||
|
|
||||||
A basic function to register a cron task looks like this:
|
A basic function to register a cron task looks like this:
|
||||||
|
|
||||||
|
|
|
@ -26,8 +26,7 @@ To add a new table to the database, create the struct and [add a migration for i
|
||||||
|
|
||||||
To learn more about how to configure your struct to create "good" tables, refer to [the xorm documentaion](https://xorm.io/docs/).
|
To learn more about how to configure your struct to create "good" tables, refer to [the xorm documentaion](https://xorm.io/docs/).
|
||||||
|
|
||||||
In most cases you will also need to implement the `TableName() string` method on the new struct to make sure the table
|
In most cases you will also need to implement the `TableName() string` method on the new struct to make sure the table name matches the rest of the tables - plural.
|
||||||
name matches the rest of the tables - plural.
|
|
||||||
|
|
||||||
## Adding data to test fixtures
|
## Adding data to test fixtures
|
||||||
|
|
||||||
|
@ -36,5 +35,4 @@ Adding data for test fixtures can be done via `yaml` files in `pkg/models/fixtur
|
||||||
The name of the yaml file should match the table name in the database.
|
The name of the yaml file should match the table name in the database.
|
||||||
Adding values to it is done via array definition inside it.
|
Adding values to it is done via array definition inside it.
|
||||||
|
|
||||||
**Note**: Table and column names need to be in snake_case as that's what is used internally in the database
|
**Note**: Table and column names need to be in snake_case as that's what is used internally in the database and for mapping values from the database to xorm so your structs can use it.
|
||||||
and for mapping values from the database to xorm so your structs can use it.
|
|
|
@ -25,7 +25,7 @@ All migrations are stored in `pkg/migrations` and files should have the same nam
|
||||||
Each migration should have a function to apply and roll it back, as well as a numeric id (the datetime)
|
Each migration should have a function to apply and roll it back, as well as a numeric id (the datetime)
|
||||||
and a more in-depth description of what the migration actually does.
|
and a more in-depth description of what the migration actually does.
|
||||||
|
|
||||||
To easily get a new id, run the following on any unix system:
|
To easily get a new id, run the following on any unix system:
|
||||||
|
|
||||||
{{< highlight bash >}}
|
{{< highlight bash >}}
|
||||||
date +%Y%m%d%H%M%S
|
date +%Y%m%d%H%M%S
|
||||||
|
@ -75,4 +75,4 @@ func init() {
|
||||||
}
|
}
|
||||||
{{< /highlight >}}
|
{{< /highlight >}}
|
||||||
|
|
||||||
You should always copy the changed parts of the struct you're changing when adding migraitons.
|
You should always copy the changed parts of the struct you're changing when adding migrations.
|
||||||
|
|
|
@ -48,7 +48,7 @@ A release gets tagged from the main branch with the version name as tag name.
|
||||||
|
|
||||||
Backports and point-releases should go to a `release/version` branch, based on the tag they are building on top of.
|
Backports and point-releases should go to a `release/version` branch, based on the tag they are building on top of.
|
||||||
|
|
||||||
## Conventional commits
|
## Conventional Commits
|
||||||
|
|
||||||
We're using [Conventional Commits](https://www.conventionalcommits.org/en/v1.0.0/) because they greatly simplify generating release notes.
|
We're using [Conventional Commits](https://www.conventionalcommits.org/en/v1.0.0/) because they greatly simplify generating release notes.
|
||||||
|
|
||||||
|
|
|
@ -13,14 +13,14 @@ menu:
|
||||||
All custom errors are defined in `pkg/models/errors.go`.
|
All custom errors are defined in `pkg/models/errors.go`.
|
||||||
You should add new ones in this file.
|
You should add new ones in this file.
|
||||||
|
|
||||||
Custom errors usually have fields for the http return code, a [vikunja-specific error code]({{< ref "../usage/errors.md">}})
|
Custom errors usually have fields for the http return code, a [Vikunja-specific error code]({{< ref "../usage/errors.md">}})
|
||||||
and a human-readable error message about what went wrong.
|
and a human-readable error message about what went wrong.
|
||||||
|
|
||||||
An error consists of multiple functions and definitions:
|
An error consists of multiple functions and definitions:
|
||||||
|
|
||||||
{{< highlight golang >}}
|
{{< highlight golang >}}
|
||||||
// This struct holds any information about this specific error.
|
// This struct holds any information about this specific error.
|
||||||
// In this case, it contains the user ID of a nonexistand user.
|
// In this case, it contains the user ID of a nonexistent user.
|
||||||
// This type should always be a struct, even if it has no values in it.
|
// This type should always be a struct, even if it has no values in it.
|
||||||
|
|
||||||
// ErrUserDoesNotExist represents a "UserDoesNotExist" kind of error.
|
// ErrUserDoesNotExist represents a "UserDoesNotExist" kind of error.
|
||||||
|
@ -44,21 +44,21 @@ func (err ErrUserDoesNotExist) Error() string {
|
||||||
return fmt.Sprintf("User does not exist [user id: %d]", err.UserID)
|
return fmt.Sprintf("User does not exist [user id: %d]", err.UserID)
|
||||||
}
|
}
|
||||||
|
|
||||||
// This const holds the vikunja error code used to be able to identify this error without having to
|
// This const holds the Vikunja error code used to be able to identify this error without having to
|
||||||
// rely on an error string.
|
// rely on an error string.
|
||||||
// This needs to be unique, so you should check whether the error code exists or not.
|
// This needs to be unique, so you should check whether the error code exists or not.
|
||||||
// The general convention for error codes is as follows:
|
// The general convention for error codes is as follows:
|
||||||
// * Every "group" errors lives in a thousend something. For example all user issues are 1000-something, all
|
// * Every "group" errors lives in a thousend something. For example all user issues are 1000-something, all
|
||||||
// project errors are 3000-something and so on.
|
// project errors are 3000-something and so on.
|
||||||
// * New error codes should be the current max error code + 1. Don't take free numbers to prevent old errors
|
// * New error codes should be the current max error code + 1. Don't take free numbers to prevent old errors
|
||||||
// which are depricated and removed from being "new ones". For example, if there are error codes 1001, 1002, 1004,
|
// which are deprecated and removed from being "new ones". For example, if there are error codes 1001, 1002, 1004,
|
||||||
// a new error should be 1005 and not 1003.
|
// a new error should be 1005 and not 1003.
|
||||||
|
|
||||||
// ErrCodeUserDoesNotExist holds the unique world-error code of this error
|
// ErrCodeUserDoesNotExist holds the unique world-error code of this error
|
||||||
const ErrCodeUserDoesNotExist = 1005
|
const ErrCodeUserDoesNotExist = 1005
|
||||||
|
|
||||||
// This is the implementation which returns an http error which is then passed to the client.
|
// This is the implementation which returns an http error which is then passed to the client.
|
||||||
// Here you define the http status code with which one the error will be returned, the vikunja error code and
|
// Here you define the http status code with which one the error will be returned, the Vikunja error code and
|
||||||
// a human-readable error message.
|
// a human-readable error message.
|
||||||
|
|
||||||
// HTTPError holds the http error description
|
// HTTPError holds the http error description
|
||||||
|
|
|
@ -42,7 +42,7 @@ You then get the event with all its data back in the listener, see below.
|
||||||
#### Naming Convention
|
#### Naming Convention
|
||||||
|
|
||||||
Event names should roughly have the entity they're dealing with on the left and the action on the right of the name, separated by `.`.
|
Event names should roughly have the entity they're dealing with on the left and the action on the right of the name, separated by `.`.
|
||||||
There's no limit to how "deep" or specifig an event name can be.
|
There's no limit to how "deep" or specific an event name can be.
|
||||||
|
|
||||||
The name should have the most general concept it's describing at the left, getting more specific on the right of it.
|
The name should have the most general concept it's describing at the left, getting more specific on the right of it.
|
||||||
|
|
||||||
|
@ -104,7 +104,7 @@ func createTask(s *xorm.Session, t *Task, a web.Auth, updateAssignees bool) (err
|
||||||
}
|
}
|
||||||
{{< /highlight >}}
|
{{< /highlight >}}
|
||||||
|
|
||||||
As you can see, the curent task and doer are injected into it.
|
As you can see, the current task and doer are injected into it.
|
||||||
|
|
||||||
### Special Events
|
### Special Events
|
||||||
|
|
||||||
|
@ -133,7 +133,7 @@ type Listener interface {
|
||||||
The `Handle` method is executed when the event this listener listens on is dispatched.
|
The `Handle` method is executed when the event this listener listens on is dispatched.
|
||||||
* As the single parameter, it gets the payload of the event, which is the event struct when it was dispatched decoded as json object and passed as a slice of bytes.
|
* As the single parameter, it gets the payload of the event, which is the event struct when it was dispatched decoded as json object and passed as a slice of bytes.
|
||||||
To use it you'll need to unmarshal it. Unfortunately there's no way to pass an already populated event object to the function because we would not know what type it has when parsing it.
|
To use it you'll need to unmarshal it. Unfortunately there's no way to pass an already populated event object to the function because we would not know what type it has when parsing it.
|
||||||
* If the handler returns an error, the listener is retried 5 times, with an exponentional back-off period in between retries.
|
* If the handler returns an error, the listener is retried 5 times, with an exponential back-off period in between retries.
|
||||||
If it still fails after the fifth retry, the event is nack'd and it's up to the event dispatcher to resend it.
|
If it still fails after the fifth retry, the event is nack'd and it's up to the event dispatcher to resend it.
|
||||||
You can learn more about this mechanism in the [watermill documentation](https://watermill.io/docs/middlewares/#retry).
|
You can learn more about this mechanism in the [watermill documentation](https://watermill.io/docs/middlewares/#retry).
|
||||||
|
|
||||||
|
@ -148,7 +148,7 @@ The easiest way to create a new listener for an event is with mage:
|
||||||
mage dev:make-listener <listener-name> <event-name> <package>
|
mage dev:make-listener <listener-name> <event-name> <package>
|
||||||
```
|
```
|
||||||
|
|
||||||
This will create a new listener type in the `pkg/<package>/listners.go` file and implement the `Handle` and `Name` methods.
|
This will create a new listener type in the `pkg/<package>/listeners.go` file and implement the `Handle` and `Name` methods.
|
||||||
It will also pre-generate some boilerplate code to unmarshal the event from the payload.
|
It will also pre-generate some boilerplate code to unmarshal the event from the payload.
|
||||||
|
|
||||||
Furthermore, it will register the listener for its event in the `RegisterListeners()` method of the same file.
|
Furthermore, it will register the listener for its event in the `RegisterListeners()` method of the same file.
|
||||||
|
@ -157,7 +157,7 @@ This function is called at startup and has to contain all events you want to lis
|
||||||
### Listening for Events
|
### Listening for Events
|
||||||
|
|
||||||
To listen for an event, you need to register the listener for the event it should be called for.
|
To listen for an event, you need to register the listener for the event it should be called for.
|
||||||
This usually happens in the `RegisterListeners()` method in `pkg/<package>/listners.go` which is called at start up.
|
This usually happens in the `RegisterListeners()` method in `pkg/<package>/listeners.go` which is called at start up.
|
||||||
|
|
||||||
The listener will never be executed if it hasn't been registered.
|
The listener will never be executed if it hasn't been registered.
|
||||||
|
|
||||||
|
@ -179,7 +179,7 @@ func (s *IncreaseTaskCounter) Name() string {
|
||||||
return "task.counter.increase"
|
return "task.counter.increase"
|
||||||
}
|
}
|
||||||
|
|
||||||
// Hanlde is executed when the event IncreaseTaskCounter listens on is fired
|
// Handle is executed when the event IncreaseTaskCounter listens on is fired
|
||||||
func (s *IncreaseTaskCounter) Handle(payload message.Payload) (err error) {
|
func (s *IncreaseTaskCounter) Handle(payload message.Payload) (err error) {
|
||||||
return keyvalue.IncrBy(metrics.TaskCountKey, 1)
|
return keyvalue.IncrBy(metrics.TaskCountKey, 1)
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,7 +31,7 @@ go install github.com/magefile/mage
|
||||||
There are multiple categories of subcommands in the magefile:
|
There are multiple categories of subcommands in the magefile:
|
||||||
|
|
||||||
* `build`: Contains commands to build a single binary
|
* `build`: Contains commands to build a single binary
|
||||||
* `check`: Contains commands to statically check the source code
|
* `check`: Contains commands to statically check the source code
|
||||||
* `release`: Contains commands to release Vikunja with everything that's required
|
* `release`: Contains commands to release Vikunja with everything that's required
|
||||||
* `test`: Contains commands to run all kinds of tests
|
* `test`: Contains commands to run all kinds of tests
|
||||||
* `dev`: Contains commands to run development tasks
|
* `dev`: Contains commands to run development tasks
|
||||||
|
@ -114,7 +114,7 @@ binary to be able to use it.
|
||||||
* `mage release:check` creates sha256 checksums for each binary which will be included in the zip file
|
* `mage release:check` creates sha256 checksums for each binary which will be included in the zip file
|
||||||
* `mage release:os-package` bundles a binary with the `sha256` checksum file, a sample `config.yml` and a copy of the license in a folder for each architecture
|
* `mage release:os-package` bundles a binary with the `sha256` checksum file, a sample `config.yml` and a copy of the license in a folder for each architecture
|
||||||
* `mage release:compress` compresses all build binaries with `upx` to save space
|
* `mage release:compress` compresses all build binaries with `upx` to save space
|
||||||
* `mage release:zip` paclages a zip file for the files created by `release:os-package`
|
* `mage release:zip` packages a zip file for the files created by `release:os-package`
|
||||||
|
|
||||||
### Build os packages
|
### Build os packages
|
||||||
|
|
||||||
|
@ -168,7 +168,7 @@ Runs all integration tests.
|
||||||
mage dev:create-migration
|
mage dev:create-migration
|
||||||
{{< /highlight >}}
|
{{< /highlight >}}
|
||||||
|
|
||||||
Creates a new migration with the current date.
|
Creates a new migration with the current date.
|
||||||
Will ask for the name of the struct you want to create a migration for.
|
Will ask for the name of the struct you want to create a migration for.
|
||||||
|
|
||||||
See also [migration docs]({{< ref "mage.md" >}}).
|
See also [migration docs]({{< ref "mage.md" >}}).
|
||||||
|
|
|
@ -34,14 +34,13 @@ promauto.NewGaugeFunc(prometheus.GaugeOpts{
|
||||||
})
|
})
|
||||||
{{< /highlight >}}
|
{{< /highlight >}}
|
||||||
|
|
||||||
Then you'll need to set the metrics initial value on every startup of vikunja.
|
Then you'll need to set the metrics initial value on every startup of Vikunja.
|
||||||
This is done in `pkg/routes/routes.go` to avoid cyclic imports.
|
This is done in `pkg/routes/routes.go` to avoid cyclic imports.
|
||||||
If metrics are enabled, it checks if a redis connection is available and then sets the initial values.
|
If metrics are enabled, it checks if a redis connection is available and then sets the initial values.
|
||||||
A convenience function is available if the metric is based on a database struct.
|
A convenience function is available if the metric is based on a database struct.
|
||||||
|
|
||||||
Because metrics are stored in redis, you are responsible to increase or decrease these based on criteria you define.
|
Because metrics are stored in redis, you are responsible to increase or decrease these based on criteria you define.
|
||||||
To do this, use `metrics.UpdateCount(value, key)` where `value` is the amount you want to cange it (you can pass
|
To do this, use `metrics.UpdateCount(value, key)` where `value` is the amount you want to change it (you can pass negative values to decrease it) and `key` it the redis key used to define the metric.
|
||||||
negative values to decrease it) and `key` it the redis key used to define the metric.
|
|
||||||
|
|
||||||
## Using it
|
## Using it
|
||||||
|
|
||||||
|
|
|
@ -17,12 +17,9 @@ In general, each migrator implements a migrator interface which is then called f
|
||||||
The interface makes it possible to use helper methods which handle http and focus only on the implementation of the migrator itself.
|
The interface makes it possible to use helper methods which handle http and focus only on the implementation of the migrator itself.
|
||||||
|
|
||||||
There are two ways of migrating data from another service:
|
There are two ways of migrating data from another service:
|
||||||
1. Through the auth-based flow where the user gives you access to their data at the third-party service through an
|
|
||||||
oauth flow. You can then call the service's api on behalf of your user to get all the data.
|
1. Through the auth-based flow where the user gives you access to their data at the third-party service through an oauth flow. You can then call the service's api on behalf of your user to get all the data. The Todoist, Trello and Microsoft To-Do Migrators use this pattern.
|
||||||
The Todoist, Trello and Microsoft To-Do Migrators use this pattern.
|
2. A file migration where the user uploads a file obtained from some third-party service. In your migrator, you need to parse the file and create the projects, tasks etc. The Vikunja File Import uses this pattern.
|
||||||
2. A file migration where the user uploads a file obtained from some third-party service. In your migrator, you need
|
|
||||||
to parse the file and create the projects, tasks etc.
|
|
||||||
The Vikunja File Import uses this pattern.
|
|
||||||
|
|
||||||
To differentiate the two, there are two different interfaces you must implement.
|
To differentiate the two, there are two different interfaces you must implement.
|
||||||
|
|
||||||
|
@ -43,7 +40,7 @@ type Migrator interface {
|
||||||
// Name holds the name of the migration.
|
// Name holds the name of the migration.
|
||||||
// This is used to show the name to users and to keep track of users who already migrated.
|
// This is used to show the name to users and to keep track of users who already migrated.
|
||||||
Name() string
|
Name() string
|
||||||
// Migrate is the interface used to migrate a user's tasks from another platform to vikunja.
|
// Migrate is the interface used to migrate a user's tasks from another platform to Vikunja.
|
||||||
// The user object is the user who's tasks will be migrated.
|
// The user object is the user who's tasks will be migrated.
|
||||||
Migrate(user *models.User) error
|
Migrate(user *models.User) error
|
||||||
// AuthURL returns a url for clients to authenticate against.
|
// AuthURL returns a url for clients to authenticate against.
|
||||||
|
@ -61,7 +58,7 @@ type FileMigrator interface {
|
||||||
// Name holds the name of the migration.
|
// Name holds the name of the migration.
|
||||||
// This is used to show the name to users and to keep track of users who already migrated.
|
// This is used to show the name to users and to keep track of users who already migrated.
|
||||||
Name() string
|
Name() string
|
||||||
// Migrate is the interface used to migrate a user's tasks, projects and other things from a file to vikunja.
|
// Migrate is the interface used to migrate a user's tasks, projects and other things from a file to Vikunja.
|
||||||
// The user object is the user who's tasks will be migrated.
|
// The user object is the user who's tasks will be migrated.
|
||||||
Migrate(user *user.User, file io.ReaderAt, size int64) error
|
Migrate(user *user.User, file io.ReaderAt, size int64) error
|
||||||
}
|
}
|
||||||
|
@ -102,35 +99,32 @@ You should also document the routes with [swagger annotations]({{< ref "swagger-
|
||||||
|
|
||||||
## Insertion helper method
|
## Insertion helper method
|
||||||
|
|
||||||
There is a method available in the `migration` package which takes a fully nested Vikunja structure and creates it with all relations.
|
There is a method available in the `migration` package which takes a fully nested Vikunja structure and creates it with all relations.
|
||||||
This means you start by adding a namespace, then add projects inside that namespace, then tasks in the lists and so on.
|
This means you start by adding a namespace, then add projects inside that namespace, then tasks in the lists and so on.
|
||||||
|
|
||||||
The root structure must be present as `[]*models.NamespaceWithProjectsAndTasks`. It allows to represent all of Vikunja's
|
The root structure must be present as `[]*models.NamespaceWithProjectsAndTasks`. It allows to represent all of Vikunja's hierarchy as a single data structure.
|
||||||
hierachie as a single data structure.
|
|
||||||
|
|
||||||
Then call the method like so:
|
Then call the method like so:
|
||||||
|
|
||||||
```go
|
```go
|
||||||
fullVikunjaHierachie, err := convertWunderlistToVikunja(wContent)
|
fullVikunjaHierarchy, err := convertWunderlistToVikunja(wContent)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
err = migration.InsertFromStructure(fullVikunjaHierachie, user)
|
err = migration.InsertFromStructure(fullVikunjaHierarchy, user)
|
||||||
```
|
```
|
||||||
|
|
||||||
## Configuration
|
## Configuration
|
||||||
|
|
||||||
If your migrator is an oauth-based one, you should add at least an option to enable or disable it.
|
If your migrator is an oauth-based one, you should add at least an option to enable or disable it.
|
||||||
Chances are, you'll need some more options for things like client ID and secret
|
Chances are, you'll need some more options for things like client ID and secret (if the other service uses oAuth as an authentication flow).
|
||||||
(if the other service uses oAuth as an authentication flow).
|
|
||||||
|
|
||||||
The easiest way to implement an on/off switch is to check whether your migration service is enabled or not when
|
The easiest way to implement an on/off switch is to check whether your migration service is enabled or not when registering the routes, and then simply don't registering the routes in case it is disabled.
|
||||||
registering the routes, and then simply don't registering the routes in case it is disabled.
|
|
||||||
|
|
||||||
File based migrators can always be enabled.
|
File based migrators can always be enabled.
|
||||||
|
|
||||||
### Making the migrator public in `/info`
|
### Making the migrator public in `/info`
|
||||||
|
|
||||||
You should make your migrator available in the `/info` endpoint so that frontends can display options to enable them or not.
|
You should make your migrator available in the `/info` endpoint so that frontends can display options to enable them or not.
|
||||||
To do this, add an entry to the `AvailableMigrators` field in `pkg/routes/api/v1/info.go`.
|
To do this, add an entry to the `AvailableMigrators` field in `pkg/routes/api/v1/info.go`.
|
||||||
|
|
|
@ -10,7 +10,7 @@ menu:
|
||||||
|
|
||||||
# Notifications
|
# Notifications
|
||||||
|
|
||||||
Vikunjs provides a simple abstraction to send notifications per mail and in the database.
|
Vikunja provides a simple abstraction to send notifications per mail and in the database.
|
||||||
|
|
||||||
{{< table_of_contents >}}
|
{{< table_of_contents >}}
|
||||||
|
|
||||||
|
@ -39,7 +39,7 @@ A list of chainable functions is available to compose a mail:
|
||||||
mail := NewMail().
|
mail := NewMail().
|
||||||
// The optional sender of the mail message.
|
// The optional sender of the mail message.
|
||||||
From("test@example.com").
|
From("test@example.com").
|
||||||
// The optional receipient of the mail message. Uses the mail address of the notifiable if omitted.
|
// The optional recipient of the mail message. Uses the mail address of the notifiable if omitted.
|
||||||
To("test@otherdomain.com").
|
To("test@otherdomain.com").
|
||||||
// The subject of the mail to send.
|
// The subject of the mail to send.
|
||||||
Subject("Testmail").
|
Subject("Testmail").
|
||||||
|
@ -49,7 +49,7 @@ mail := NewMail().
|
||||||
Line("This is a line of text").
|
Line("This is a line of text").
|
||||||
// An action can contain a title and a url. It gets rendered as a big button in the mail.
|
// An action can contain a title and a url. It gets rendered as a big button in the mail.
|
||||||
// Note that you can have only one action per mail.
|
// Note that you can have only one action per mail.
|
||||||
// All lines added before an action will appearr in the mail before the button, all lines
|
// All lines added before an action will appear in the mail before the button, all lines
|
||||||
// added afterwards will appear after it.
|
// added afterwards will appear after it.
|
||||||
Action("The Action", "https://example.com").
|
Action("The Action", "https://example.com").
|
||||||
// Another line of text.
|
// Another line of text.
|
||||||
|
@ -60,8 +60,7 @@ If not provided, the `from` field of the mail contains the value configured in [
|
||||||
|
|
||||||
### Database notifications
|
### Database notifications
|
||||||
|
|
||||||
All data returned from the `ToDB()` method is serialized to json and saved into the database, along with the id of the
|
All data returned from the `ToDB()` method is serialized to json and saved into the database, along with the id of the notifiable, the name of the notification and a time stamp.
|
||||||
notifiable, the name of the notification and a time stamp.
|
|
||||||
If you don't use the database notification, the `Name()` function can return an empty string.
|
If you don't use the database notification, the `Name()` function can return an empty string.
|
||||||
|
|
||||||
## Creating a new notification
|
## Creating a new notification
|
||||||
|
|
|
@ -12,10 +12,10 @@ menu:
|
||||||
This checklist is a collection of all steps usually involved when releasing a new version of Vikunja.
|
This checklist is a collection of all steps usually involved when releasing a new version of Vikunja.
|
||||||
Not all steps are necessary for every release.
|
Not all steps are necessary for every release.
|
||||||
|
|
||||||
* Website update :
|
* Website update
|
||||||
* New Features: If there are new features worth mentioning the feature page should be updated.
|
* New Features: If there are new features worth mentioning the feature page should be updated.
|
||||||
* New Screenshots: If an overhaul of an existing feature happend so that it now looks different from the existing screenshot, a new one is required.
|
* New Screenshots: If an overhaul of an existing feature happened so that it now looks different from the existing screenshot, a new one is required.
|
||||||
* Generate changelogs: (with git-cliff)
|
* Generate changelogs (with git-cliff)
|
||||||
* Frontend
|
* Frontend
|
||||||
* API
|
* API
|
||||||
* Desktop
|
* Desktop
|
||||||
|
@ -23,11 +23,11 @@ Not all steps are necessary for every release.
|
||||||
* Frontend
|
* Frontend
|
||||||
* API
|
* API
|
||||||
* Desktop
|
* Desktop
|
||||||
* Once built: Prune the cloudflare cache so that the new versions show up at dl.vikunja.io
|
* Once built: Prune the cloudflare cache so that the new versions show up at [dl.vikunja.io](https://dl.vikunja.io/)
|
||||||
* Release Highlights Blogpost:
|
* Release Highlights Blogpost
|
||||||
* Include a section about Vikunja in general (totally fine to copy one from the earlier blog posts)
|
* Include a section about Vikunja in general (totally fine to copy one from the earlier blog posts)
|
||||||
* New Features & Improvements: Mention bigger features, potentially with screenshots. Things like refactoring are sometimes also worth mentioneing.
|
* New Features & Improvements: Mention bigger features, potentially with screenshots. Things like refactoring are sometimes also worth mentioning.
|
||||||
* Publish:
|
* Publish
|
||||||
* Reddit
|
* Reddit
|
||||||
* Twitter
|
* Twitter
|
||||||
* Mastodon
|
* Mastodon
|
||||||
|
@ -36,4 +36,3 @@ Not all steps are necessary for every release.
|
||||||
* Forum
|
* Forum
|
||||||
* If features in the release were sponsored, send an email to relevant stakeholders
|
* If features in the release were sponsored, send an email to relevant stakeholders
|
||||||
* Update Vikunja Cloud version and other instances
|
* Update Vikunja Cloud version and other instances
|
||||||
|
|
||||||
|
|
|
@ -64,7 +64,7 @@ See [integration tests]({{< ref "test.md" >}}#integration-tests) for more detail
|
||||||
|
|
||||||
### log
|
### log
|
||||||
|
|
||||||
Similar to `config`, this will set up the logging, based on differen logging backends.
|
Similar to `config`, this will set up the logging, based on different logging backends.
|
||||||
This init is called in `main.go` after the config init is done.
|
This init is called in `main.go` after the config init is done.
|
||||||
|
|
||||||
### mail
|
### mail
|
||||||
|
@ -126,7 +126,7 @@ See [writing a migrator]({{< ref "migration.md" >}}).
|
||||||
### red (redis)
|
### red (redis)
|
||||||
|
|
||||||
This package initializes a connection to a redis server.
|
This package initializes a connection to a redis server.
|
||||||
This inizialization is automatically done at the startup of vikunja.
|
This initialization is automatically done at the startup of Vikunja.
|
||||||
|
|
||||||
It also has a function (`GetRedis()`) which returns a redis client object you can then use in your package
|
It also has a function (`GetRedis()`) which returns a redis client object you can then use in your package
|
||||||
to talk to redis.
|
to talk to redis.
|
||||||
|
@ -138,7 +138,7 @@ In most cases, using the `keyvalue` package is a better fit.
|
||||||
|
|
||||||
### routes
|
### routes
|
||||||
|
|
||||||
This package defines all routes which are available for vikunja clients to use.
|
This package defines all routes which are available for Vikunja clients to use.
|
||||||
To add a new route, see [adding a new route]({{< ref "feature.md">}}).
|
To add a new route, see [adding a new route]({{< ref "feature.md">}}).
|
||||||
|
|
||||||
#### api/v1
|
#### api/v1
|
||||||
|
@ -162,10 +162,9 @@ A small package, containing some helper functions:
|
||||||
* `MakeRandomString`: Generates a random string of a given length.
|
* `MakeRandomString`: Generates a random string of a given length.
|
||||||
* `Sha256`: Calculates a sha256 hash from a given string.
|
* `Sha256`: Calculates a sha256 hash from a given string.
|
||||||
|
|
||||||
See their function definitions for instructions on how to use them.
|
See their function definitions for instructions on how to use them.
|
||||||
|
|
||||||
### version
|
### version
|
||||||
|
|
||||||
The single purpouse of this package is to hold the current vikunja version which gets overridden through build flags
|
The single purpose of this package is to hold the current Vikunja version which gets overridden through build flags each time `mage release` or `mage build` is run.
|
||||||
each time `mage release` or `mage build` is run.
|
It is a separate package to avoid import cycles with other packages.
|
||||||
It is a seperate package to avoid import cycles with other packages.
|
|
||||||
|
|
|
@ -54,7 +54,7 @@ type Project struct {
|
||||||
IsFavorite bool `xorm:"-" json:"is_favorite"`
|
IsFavorite bool `xorm:"-" json:"is_favorite"`
|
||||||
|
|
||||||
// The subscription status for the user reading this project. You can only read this property, use the subscription endpoints to modify it.
|
// The subscription status for the user reading this project. You can only read this property, use the subscription endpoints to modify it.
|
||||||
// Will only returned when retreiving one project.
|
// Will only returned when retrieving one project.
|
||||||
Subscription *Subscription `xorm:"-" json:"subscription,omitempty"`
|
Subscription *Subscription `xorm:"-" json:"subscription,omitempty"`
|
||||||
|
|
||||||
// The position this project has when querying all projects. See the tasks.position property on how to use this.
|
// The position this project has when querying all projects. See the tasks.position property on how to use this.
|
||||||
|
|
|
@ -46,10 +46,10 @@ To run integration tests, use `mage test:integration`.
|
||||||
|
|
||||||
### Running tests with config
|
### Running tests with config
|
||||||
|
|
||||||
You can run tests with all available config variables if you want, enabeling you to run tests for a lot of scenarios.
|
You can run tests with all available config variables if you want, enabling you to run tests for a lot of scenarios.
|
||||||
We use this in CI to run all tests with different databases.
|
We use this in CI to run all tests with different databases.
|
||||||
|
|
||||||
To use the normal config set the enviroment variable `VIKUNJA_TESTS_USE_CONFIG=1`.
|
To use the normal config set the environment variable `VIKUNJA_TESTS_USE_CONFIG=1`.
|
||||||
|
|
||||||
### Showing sql queries
|
### Showing sql queries
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,7 @@ Currently, only the frontend (and by extension, the desktop app) is translatable
|
||||||
|
|
||||||
## Translation Instructions
|
## Translation Instructions
|
||||||
|
|
||||||
> These are the instructions for translating Vikunja in another language.
|
> These are the instructions for translating Vikunja in another language.
|
||||||
> For information about how to add new translation strings, see below.
|
> For information about how to add new translation strings, see below.
|
||||||
|
|
||||||
For all languages these translation guidelines should be applied when translating:
|
For all languages these translation guidelines should be applied when translating:
|
||||||
|
@ -44,7 +44,7 @@ Instead, translate it to reflect the original meaning in the translated string b
|
||||||
|
|
||||||
All translation strings are stored in `src/i18n/lang/`.
|
All translation strings are stored in `src/i18n/lang/`.
|
||||||
New strings should be added only in the `en.json` file.
|
New strings should be added only in the `en.json` file.
|
||||||
Strings in other languages will be synced through weblate and should not be added directly as a PR/commit in the frontend repo.
|
Strings in other languages will be synced through [crowdin](https://crowdin.com/project/vikunja) and should not be added directly as a PR/commit in the frontend repo.
|
||||||
|
|
||||||
## Requesting a new language
|
## Requesting a new language
|
||||||
|
|
||||||
|
|
|
@ -56,4 +56,4 @@ For more information, please visit the [relevant PostgreSQL documentation](https
|
||||||
|
|
||||||
### SQLite
|
### SQLite
|
||||||
|
|
||||||
To back up sqllite databases, it is enough to copy the [database file]({{< ref "config.md" >}}#path) to somwhere else.
|
To back up sqllite databases, it is enough to copy the [database file]({{< ref "config.md" >}}#path) to somewhere else.
|
||||||
|
|
|
@ -10,8 +10,7 @@ menu:
|
||||||
|
|
||||||
# Configuration options
|
# Configuration options
|
||||||
|
|
||||||
You can either use a `config.yml` file in the root directory of vikunja or set almost all config option with
|
You can either use a `config.yml` file in the root directory of vikunja or set almost all config option with environment variables. If you have both, the value set in the config file is used.
|
||||||
environment variables. If you have both, the value set in the config file is used.
|
|
||||||
Right now it is not possible to configure openid authentication via environment variables.
|
Right now it is not possible to configure openid authentication via environment variables.
|
||||||
|
|
||||||
Variables are nested in the `config.yml`, these nested variables become `VIKUNJA_FIRST_CHILD` when configuring via
|
Variables are nested in the `config.yml`, these nested variables become `VIKUNJA_FIRST_CHILD` when configuring via
|
||||||
|
@ -31,7 +30,7 @@ first:
|
||||||
# Formats
|
# Formats
|
||||||
|
|
||||||
Vikunja supports using `toml`, `yaml`, `hcl`, `ini`, `json`, envfile, env variables and Java Properties files.
|
Vikunja supports using `toml`, `yaml`, `hcl`, `ini`, `json`, envfile, env variables and Java Properties files.
|
||||||
We reccomend yaml or toml, but you're free to use whatever you want.
|
We recommend yaml or toml, but you're free to use whatever you want.
|
||||||
|
|
||||||
Vikunja provides a default [`config.yml`](https://kolaente.dev/vikunja/api/src/branch/main/config.yml.sample) file which you can use as a starting point.
|
Vikunja provides a default [`config.yml`](https://kolaente.dev/vikunja/api/src/branch/main/config.yml.sample) file which you can use as a starting point.
|
||||||
|
|
||||||
|
@ -56,7 +55,7 @@ If you don't provide a value in your config file, their default will be used.
|
||||||
Most config variables are nested under some "higher-level" key.
|
Most config variables are nested under some "higher-level" key.
|
||||||
For example, the `interface` config variable is a child of the `service` key.
|
For example, the `interface` config variable is a child of the `service` key.
|
||||||
|
|
||||||
The docs below aim to reflect that leveling, but please also have a lookt at [the default config](https://code.vikunja.io/api/src/branch/main/config.yml.sample) file
|
The docs below aim to reflect that leveling, but please also have a look at [the default config](https://code.vikunja.io/api/src/branch/main/config.yml.sample) file
|
||||||
to better grasp how the nesting looks like.
|
to better grasp how the nesting looks like.
|
||||||
|
|
||||||
<!-- Generated config will be injected here -->
|
<!-- Generated config will be injected here -->
|
||||||
|
@ -82,7 +81,7 @@ Environment path: `VIKUNJA_SERVICE_JWTSECRET`
|
||||||
|
|
||||||
### jwtttl
|
### jwtttl
|
||||||
|
|
||||||
The duration of the issed JWT tokens in seconds.
|
The duration of the issued JWT tokens in seconds.
|
||||||
The default is 259200 seconds (3 Days).
|
The default is 259200 seconds (3 Days).
|
||||||
|
|
||||||
Default: `259200`
|
Default: `259200`
|
||||||
|
@ -287,7 +286,7 @@ Environment path: `VIKUNJA_SERVICE_SENTRYDSN`
|
||||||
|
|
||||||
If not empty, this will enable `/test/{table}` endpoints which allow to put any content in the database.
|
If not empty, this will enable `/test/{table}` endpoints which allow to put any content in the database.
|
||||||
Used to reset the db before frontend tests. Because this is quite a dangerous feature allowing for lots of harm,
|
Used to reset the db before frontend tests. Because this is quite a dangerous feature allowing for lots of harm,
|
||||||
each request made to this endpoint neefs to provide an `Authorization: <token>` header with the token from below. <br/>
|
each request made to this endpoint needs to provide an `Authorization: <token>` header with the token from below. <br/>
|
||||||
**You should never use this unless you know exactly what you're doing**
|
**You should never use this unless you know exactly what you're doing**
|
||||||
|
|
||||||
Default: `<empty>`
|
Default: `<empty>`
|
||||||
|
@ -430,7 +429,7 @@ Environment path: `VIKUNJA_DATABASE_MAXIDLECONNECTIONS`
|
||||||
|
|
||||||
### maxconnectionlifetime
|
### maxconnectionlifetime
|
||||||
|
|
||||||
The maximum lifetime of a single db connection in miliseconds.
|
The maximum lifetime of a single db connection in milliseconds.
|
||||||
|
|
||||||
Default: `10000`
|
Default: `10000`
|
||||||
|
|
||||||
|
@ -516,7 +515,7 @@ Environment path: `VIKUNJA_CACHE_ENABLED`
|
||||||
|
|
||||||
Cache type. Possible values are "keyvalue", "memory" or "redis".
|
Cache type. Possible values are "keyvalue", "memory" or "redis".
|
||||||
When choosing "keyvalue" this setting follows the one configured in the "keyvalue" section.
|
When choosing "keyvalue" this setting follows the one configured in the "keyvalue" section.
|
||||||
When choosing "redis" you will need to configure the redis connection seperately.
|
When choosing "redis" you will need to configure the redis connection separately.
|
||||||
|
|
||||||
Default: `keyvalue`
|
Default: `keyvalue`
|
||||||
|
|
||||||
|
@ -566,7 +565,7 @@ Environment path: `VIKUNJA_REDIS_HOST`
|
||||||
|
|
||||||
### password
|
### password
|
||||||
|
|
||||||
The password used to authenicate against the redis server
|
The password used to authenticate against the redis server
|
||||||
|
|
||||||
Default: `<empty>`
|
Default: `<empty>`
|
||||||
|
|
||||||
|
@ -595,7 +594,7 @@ Environment path: `VIKUNJA_REDIS_DB`
|
||||||
### enable
|
### enable
|
||||||
|
|
||||||
Whether to enable or disable cors headers.
|
Whether to enable or disable cors headers.
|
||||||
Note: If you want to put the frontend and the api on seperate domains or ports, you will need to enable this.
|
Note: If you want to put the frontend and the api on separate domains or ports, you will need to enable this.
|
||||||
Otherwise the frontend won't be able to make requests to the api through the browser.
|
Otherwise the frontend won't be able to make requests to the api through the browser.
|
||||||
|
|
||||||
Default: `true`
|
Default: `true`
|
||||||
|
@ -1099,7 +1098,7 @@ The Key Value Storage is used for different kinds of things like metrics and a f
|
||||||
|
|
||||||
### type
|
### type
|
||||||
|
|
||||||
The type of the storage backend. Can be either "memory" or "redis". If "redis" is chosen it needs to be configured seperately.
|
The type of the storage backend. Can be either "memory" or "redis". If "redis" is chosen it needs to be configured separately.
|
||||||
|
|
||||||
Default: `memory`
|
Default: `memory`
|
||||||
|
|
||||||
|
@ -1134,7 +1133,7 @@ The provider needs to support the `openid`, `profile` and `email` scopes.<br/>
|
||||||
If the email is not public in those cases, authenticating will fail.
|
If the email is not public in those cases, authenticating will fail.
|
||||||
**Note 2:** The frontend expects to be redirected after authentication by the third party
|
**Note 2:** The frontend expects to be redirected after authentication by the third party
|
||||||
to <frontend-url>/auth/openid/<auth key>. Please make sure to configure the redirect url with your third party
|
to <frontend-url>/auth/openid/<auth key>. Please make sure to configure the redirect url with your third party
|
||||||
auth service accordingy if you're using the default vikunja frontend.
|
auth service accordingly if you're using the default vikunja frontend.
|
||||||
Take a look at the [default config file](https://kolaente.dev/vikunja/api/src/branch/main/config.yml.sample) for more information about how to configure openid authentication.
|
Take a look at the [default config file](https://kolaente.dev/vikunja/api/src/branch/main/config.yml.sample) for more information about how to configure openid authentication.
|
||||||
|
|
||||||
Default: `<empty>`
|
Default: `<empty>`
|
||||||
|
|
|
@ -16,7 +16,7 @@ It uses an nginx container or traefik on the host to proxy backend and frontend
|
||||||
For all available configuration options, see [configuration]({{< ref "config.md">}}).
|
For all available configuration options, see [configuration]({{< ref "config.md">}}).
|
||||||
|
|
||||||
<div class="notification is-warning">
|
<div class="notification is-warning">
|
||||||
<b>NOTE:</b> If you intend to run Vikunja with mysql and/or to use non-latin characters
|
<b>NOTE:</b> If you intend to run Vikunja with mysql and/or to use non-latin characters
|
||||||
<a href="{{< ref "utf-8.md">}}">make sure your db is utf-8 compatible</a>.<br/>
|
<a href="{{< ref "utf-8.md">}}">make sure your db is utf-8 compatible</a>.<br/>
|
||||||
All examples on this page already reflect this and do not require additional work.
|
All examples on this page already reflect this and do not require additional work.
|
||||||
</div>
|
</div>
|
||||||
|
@ -25,8 +25,7 @@ All examples on this page already reflect this and do not require additional wor
|
||||||
|
|
||||||
## Redis
|
## Redis
|
||||||
|
|
||||||
While Vikunja has support to use redis as a caching backend, you'll probably not need it unless you're using Vikunja
|
While Vikunja has support to use redis as a caching backend, you'll probably not need it unless you're using Vikunja with more than a handful of users.
|
||||||
with more than a handful of users.
|
|
||||||
|
|
||||||
To use redis, you'll need to add this to the config examples below:
|
To use redis, you'll need to add this to the config examples below:
|
||||||
|
|
||||||
|
@ -66,19 +65,45 @@ db:
|
||||||
You'll also need to change the `VIKUNJA_DATABASE_TYPE` to `postgres` on the api container declaration.
|
You'll also need to change the `VIKUNJA_DATABASE_TYPE` to `postgres` on the api container declaration.
|
||||||
|
|
||||||
<div class="notification is-warning">
|
<div class="notification is-warning">
|
||||||
<b>NOTE:</b> The mariadb container can sometimes take a while to initialize, especially on the first run.
|
<b>NOTE:</b> The mariadb container can sometimes take a while to initialize, especially on the first run. During this time, the api container will fail to start at all. It will automatically restart every few seconds.
|
||||||
During this time, the api container will fail to start at all. It will automatically restart every few seconds.
|
</div>
|
||||||
|
|
||||||
|
## Sqlite
|
||||||
|
|
||||||
|
Vikunja supports postgres, mysql and sqlite as a database backend. The examples on this page use mysql with a mariadb container.
|
||||||
|
To use sqlite as a database backend, change the `api` section of the examples to this:
|
||||||
|
|
||||||
|
{{< highlight yaml >}}
|
||||||
|
api:
|
||||||
|
image: vikunja/api
|
||||||
|
environment:
|
||||||
|
VIKUNJA_SERVICE_JWTSECRET: <a super secure random secret>
|
||||||
|
VIKUNJA_SERVICE_FRONTENDURL: http://<your public frontend url with slash>/
|
||||||
|
# Note the default path is /app/vikunja/vikunja.db This moves to a different folder so you can use a volume and store this outside of the container so state is persisted even if container destroyed.
|
||||||
|
VIKUNJA_DATABASE_PATH: /db/vikunja.db
|
||||||
|
ports:
|
||||||
|
- 3456:3456
|
||||||
|
volumes:
|
||||||
|
- ./files:/app/vikunja/files
|
||||||
|
- ./db:/db
|
||||||
|
restart: unless-stopped
|
||||||
|
{{< /highlight >}}
|
||||||
|
|
||||||
|
The default path Vikunja uses for sqlite is relative to the binary, which in the docker container would be `/app/vikunja/vikunja.db`. This config moves to a different folder using `VIKUNJA_DATABASE_PATH` so you can use a volume at `/db` and store this outside of the container so state is persisted even if container destroyed.
|
||||||
|
|
||||||
|
You'll also need to remove or change the `VIKUNJA_DATABASE_TYPE` to `sqlite` on the api container declaration.
|
||||||
|
|
||||||
|
You can also remove the db section.
|
||||||
|
|
||||||
|
<div class="notification is-warning">
|
||||||
|
<b>NOTE:</b> If you'll use your instance with more than a handful of users, we recommend using mysql or postgres.
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
## Example without any proxy
|
## Example without any proxy
|
||||||
|
|
||||||
This example lets you host Vikunja without any reverse proxy in front of it. This is the absolute minimum configuration
|
This example lets you host Vikunja without any reverse proxy in front of it. This is the absolute minimum configuration you need to get something up and running. If you want to host Vikunja on one single port instead of two different ones or need tls termination, check out one of the other examples.
|
||||||
you need to get something up and running. If you want to host Vikunja on one single port instead of two different ones
|
|
||||||
or need tls termination, check out one of the other examples.
|
|
||||||
|
|
||||||
Note that you need to change the `VIKUNJA_API_URL` environment variable to the ip (the docker host you're running this on)
|
Note that you need to change the `VIKUNJA_API_URL` environment variable to the ip (the docker host you're running this on) is reachable at. Because the browser you'll use to access the Vikunja frontend uses that url to make the requests, it has to be able to reach that ip + port from the outside. Putting everything in a private network won't work.
|
||||||
is reachable at. Because the browser you'll use to access the Vikunja frontend uses that url to make the requests, it
|
|
||||||
has to be able to reach that ip + port from the outside. Putting everything in a private network won't work.
|
|
||||||
|
|
||||||
{{< highlight yaml >}}
|
{{< highlight yaml >}}
|
||||||
version: '3'
|
version: '3'
|
||||||
|
@ -235,7 +260,7 @@ services:
|
||||||
image: mariadb:10
|
image: mariadb:10
|
||||||
command: --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
|
command: --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
|
||||||
environment:
|
environment:
|
||||||
MYSQL_ROOT_PASSWORD: supersupersecret
|
MYSQL_ROOT_PASSWORD: supersupersecret
|
||||||
MYSQL_USER: vikunja
|
MYSQL_USER: vikunja
|
||||||
MYSQL_PASSWORD: supersecret
|
MYSQL_PASSWORD: supersecret
|
||||||
MYSQL_DATABASE: vikunja
|
MYSQL_DATABASE: vikunja
|
||||||
|
@ -343,7 +368,7 @@ services:
|
||||||
image: mariadb:10
|
image: mariadb:10
|
||||||
command: --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
|
command: --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
|
||||||
environment:
|
environment:
|
||||||
MYSQL_ROOT_PASSWORD: supersecret
|
MYSQL_ROOT_PASSWORD: supersecret
|
||||||
MYSQL_USER: vikunja
|
MYSQL_USER: vikunja
|
||||||
MYSQL_PASSWORD: secret
|
MYSQL_PASSWORD: secret
|
||||||
MYSQL_DATABASE: vikunja
|
MYSQL_DATABASE: vikunja
|
||||||
|
@ -360,7 +385,7 @@ services:
|
||||||
VIKUNJA_DATABASE_DATABASE: vikunja
|
VIKUNJA_DATABASE_DATABASE: vikunja
|
||||||
VIKUNJA_SERVICE_JWTSECRET: <a super secure random secret>
|
VIKUNJA_SERVICE_JWTSECRET: <a super secure random secret>
|
||||||
VIKUNJA_SERVICE_FRONTENDURL: https://<your public frontend url with slash>/
|
VIKUNJA_SERVICE_FRONTENDURL: https://<your public frontend url with slash>/
|
||||||
volumes:
|
volumes:
|
||||||
- ./files:/app/vikunja/files
|
- ./files:/app/vikunja/files
|
||||||
depends_on:
|
depends_on:
|
||||||
- db
|
- db
|
||||||
|
@ -406,8 +431,8 @@ To do that, you can
|
||||||
* without activating SSH as a "custom script" (go to Control Panel / Task Scheduler / Create / Scheduled Task / User-defined script)
|
* without activating SSH as a "custom script" (go to Control Panel / Task Scheduler / Create / Scheduled Task / User-defined script)
|
||||||
* without activating SSH, by using Portainer (you have to install first, check out [this tutorial](https://www.portainer.io/blog/how-to-install-portainer-on-a-synology-nas) for exmple):
|
* without activating SSH, by using Portainer (you have to install first, check out [this tutorial](https://www.portainer.io/blog/how-to-install-portainer-on-a-synology-nas) for exmple):
|
||||||
1. Go to **Dashboard / Stacks** click the button **"Add Stack"**
|
1. Go to **Dashboard / Stacks** click the button **"Add Stack"**
|
||||||
2. Give it the name Vikunja and paste the adapted docker compose file
|
2. Give it the name Vikunja and paste the adapted docker compose file
|
||||||
3. Deploy the Stack with the "Deploy Stack" button:
|
3. Deploy the Stack with the "Deploy Stack" button:
|
||||||
|
|
||||||
![Portainer Stack deploy](/docs/synology-proxy-2.png)
|
![Portainer Stack deploy](/docs/synology-proxy-2.png)
|
||||||
|
|
||||||
|
@ -459,4 +484,3 @@ You may want to change the volumes to match the rest of your setup.
|
||||||
Once deployed, you might want to change the [`PUID` and `GUID` settings]({{< ref "install-backend.md">}}#setting-user-and-group-id-of-the-user-running-vikunja) or [set the time zone]({{< ref "config.md">}}#timezone).
|
Once deployed, you might want to change the [`PUID` and `GUID` settings]({{< ref "install-backend.md">}}#setting-user-and-group-id-of-the-user-running-vikunja) or [set the time zone]({{< ref "config.md">}}#timezone).
|
||||||
|
|
||||||
After registering all your users, you might also want to [disable the user registration]({{<ref "config.md">}}#enableregistration).
|
After registering all your users, you might also want to [disable the user registration]({{<ref "config.md">}}#enableregistration).
|
||||||
|
|
||||||
|
|
|
@ -102,7 +102,7 @@ It will automatically run all necessary database migrations.
|
||||||
|
|
||||||
## Docker
|
## Docker
|
||||||
|
|
||||||
(Note: this assumes some familarity with docker)
|
(Note: this assumes some familiarity with docker)
|
||||||
|
|
||||||
Usage with docker is pretty straightforward:
|
Usage with docker is pretty straightforward:
|
||||||
|
|
||||||
|
@ -119,7 +119,7 @@ You can mount a local configuration like so:
|
||||||
docker run -p 3456:3456 -v /path/to/config/on/host.yml:/app/vikunja/config.yml:ro vikunja/api
|
docker run -p 3456:3456 -v /path/to/config/on/host.yml:/app/vikunja/config.yml:ro vikunja/api
|
||||||
{{< /highlight >}}
|
{{< /highlight >}}
|
||||||
|
|
||||||
Though it is recommended to use eviroment variables or `.env` files to configure Vikunja in docker.
|
Though it is recommended to use environment variables or `.env` files to configure Vikunja in docker.
|
||||||
See [config]({{< ref "config.md">}}) for a list of available configuration options.
|
See [config]({{< ref "config.md">}}) for a list of available configuration options.
|
||||||
|
|
||||||
### Files volume
|
### Files volume
|
||||||
|
@ -129,7 +129,7 @@ You should mount the volume somewhere to the host to permanently store the files
|
||||||
|
|
||||||
### Setting user and group id of the user running vikunja
|
### Setting user and group id of the user running vikunja
|
||||||
|
|
||||||
You can set the user and group id of the user running vikunja with the `PUID` and `PGID` evironment variables.
|
You can set the user and group id of the user running vikunja with the `PUID` and `PGID` environment variables.
|
||||||
This follows the pattern used by [the linuxserver.io](https://docs.linuxserver.io/general/understanding-puid-and-pgid) docker images.
|
This follows the pattern used by [the linuxserver.io](https://docs.linuxserver.io/general/understanding-puid-and-pgid) docker images.
|
||||||
|
|
||||||
This is useful to solve general permission problems when host-mounting volumes such as the volume used for task attachments.
|
This is useful to solve general permission problems when host-mounting volumes such as the volume used for task attachments.
|
||||||
|
@ -164,7 +164,7 @@ services:
|
||||||
- ./db:/var/lib/mysql
|
- ./db:/var/lib/mysql
|
||||||
{{< /highlight >}}
|
{{< /highlight >}}
|
||||||
|
|
||||||
See [full docker example]({{< ref "full-docker-example.md">}}) for more varations of this config.
|
See [full docker example]({{< ref "full-docker-example.md">}}) for more variations of this config.
|
||||||
|
|
||||||
## Debian packages
|
## Debian packages
|
||||||
|
|
||||||
|
|
|
@ -24,8 +24,7 @@ You also need to configure a rewrite condition to internally redirect all reques
|
||||||
By default, the frontend assumes it can reach the api at `/api/v1` relative to the frontend url.
|
By default, the frontend assumes it can reach the api at `/api/v1` relative to the frontend url.
|
||||||
This means that if you make the frontend available at, say `https://vikunja.example.com`, it tries to reach the api
|
This means that if you make the frontend available at, say `https://vikunja.example.com`, it tries to reach the api
|
||||||
at `https://vikunja.example.com/api/v1`.
|
at `https://vikunja.example.com/api/v1`.
|
||||||
In this scenario it is not possible for the frontend and the api to live on seperate servers or even just seperate
|
In this scenario it is not possible for the frontend and the api to live on separate servers or even just separate ports on the same server with [the use of a reverse proxy]({{< ref "reverse-proxies.md">}}).
|
||||||
ports on the same server with [the use of a reverse proxy]({{< ref "reverse-proxies.md">}}).
|
|
||||||
|
|
||||||
To make configurations like this possible, the api url can be set in the `index.html` file of the frontend releases.
|
To make configurations like this possible, the api url can be set in the `index.html` file of the frontend releases.
|
||||||
Just open the file with a text editor - there are comments which will explain how to set the url.
|
Just open the file with a text editor - there are comments which will explain how to set the url.
|
||||||
|
@ -45,7 +44,7 @@ docker run -p 80:80 vikunja/frontend
|
||||||
|
|
||||||
which will run the docker image and expose port 80 on the host.
|
which will run the docker image and expose port 80 on the host.
|
||||||
|
|
||||||
See [full docker example]({{< ref "full-docker-example.md">}}) for more varations of this config.
|
See [full docker example]({{< ref "full-docker-example.md">}}) for more variations of this config.
|
||||||
|
|
||||||
The docker container runs as an unprivileged user and does not mount anything.
|
The docker container runs as an unprivileged user and does not mount anything.
|
||||||
|
|
||||||
|
|
|
@ -8,8 +8,15 @@ menu:
|
||||||
parent: "setup"
|
parent: "setup"
|
||||||
---
|
---
|
||||||
|
|
||||||
|
# Hosting Vikunja with k8s
|
||||||
|
|
||||||
|
We have an official Helm Chart for Vikunja.
|
||||||
|
|
||||||
|
Check out [the repo](https://kolaente.dev/vikunja/helm-chart/) for more information about how to use it.
|
||||||
|
|
||||||
|
## Third-party Helm Charts
|
||||||
|
|
||||||
There are two third-party Helm-Charts which can be used to host Vikunja with k8s:
|
There are two third-party Helm-Charts which can be used to host Vikunja with k8s:
|
||||||
|
|
||||||
* [Truecharts](https://truecharts.org/charts/stable/vikunja/)
|
* [Truecharts](https://truecharts.org/charts/stable/vikunja/)
|
||||||
* [k8s at Home](https://github.com/k8s-at-home/charts)
|
* [k8s at Home](https://github.com/k8s-at-home/charts)
|
||||||
|
|
||||||
|
|
|
@ -61,8 +61,8 @@ openid:
|
||||||
|
|
||||||
Google config:
|
Google config:
|
||||||
|
|
||||||
- Navigate to https://console.cloud.google.com/apis/credentials in the target project
|
- Navigate to `https://console.cloud.google.com/apis/credentials` in the target project
|
||||||
- Create a new OAuth client ID
|
- Create a new OAuth client ID
|
||||||
- Configure an authorized redirect URI of https://vikunja.mydomain.com/auth/openid/google
|
- Configure an authorized redirect URI of `https://vikunja.mydomain.com/auth/openid/google`
|
||||||
|
|
||||||
Note that there currently seems to be no way to stop creation of new users, even when enableregistration is false in the configuration. This means that this approach works well only with an "Internal Organization" app for Google Workspace, which limits the allowed users to organizational accounts only. External / public applications will potentially allow every Google user to register.
|
Note that there currently seems to be no way to stop creation of new users, even when `enableregistration` is `false` in the configuration. This means that this approach works well only with an "Internal Organization" app for Google Workspace, which limits the allowed users to organizational accounts only. External / public applications will potentially allow every Google user to register.
|
||||||
|
|
|
@ -86,15 +86,15 @@ server {
|
||||||
2. Verify that the page will pull up in your browser. (Do not bother trying to log in. It won't work. Trust me.)
|
2. Verify that the page will pull up in your browser. (Do not bother trying to log in. It won't work. Trust me.)
|
||||||
3. Now, we'll work with the NPM container, so you need to identify the container name for your NPM installation. e.g. NGINX-PM
|
3. Now, we'll work with the NPM container, so you need to identify the container name for your NPM installation. e.g. NGINX-PM
|
||||||
4. From the command line, enter `sudo docker exec -it [NGINX-PM container name] /bin/bash` and navigate to the proxy hosts folder where the `.conf` files are stashed. Probably `/data/nginx/proxy_host`. (This folder is a persistent folder created in the NPM container and mounted by NPM.)
|
4. From the command line, enter `sudo docker exec -it [NGINX-PM container name] /bin/bash` and navigate to the proxy hosts folder where the `.conf` files are stashed. Probably `/data/nginx/proxy_host`. (This folder is a persistent folder created in the NPM container and mounted by NPM.)
|
||||||
5. Locate the `.conf` file where the server_name inside the file matches your Vikunja Proxy Host. Once found, add the following code, unchanged, just above the existing location block in that file. (They are listed by number, not name.)
|
5. Locate the `.conf` file where the server_name inside the file matches your Vikunja Proxy Host. Once found, add the following code, unchanged, just above the existing location block in that file. (They are listed by number, not name.)
|
||||||
```
|
```nginx
|
||||||
location ~* ^/(api|dav|\.well-known)/ {
|
location ~* ^/(api|dav|\.well-known)/ {
|
||||||
proxy_pass http://api:3456;
|
proxy_pass http://api:3456;
|
||||||
client_max_body_size 20M;
|
client_max_body_size 20M;
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
6. After saving the edited file, return to NPM's UI browser window and refresh the page to verify your Proxy Host for Vikunja is still online.
|
6. After saving the edited file, return to NPM's UI browser window and refresh the page to verify your Proxy Host for Vikunja is still online.
|
||||||
7. Now, switch over to your Vikunja browswer window and hit refresh. If you configured your URL correctly in original Vikunja container, you should be all set and the browser will correctly show Vikunja. If not, you'll need to adjust the address in the top of the login subscreen to match your proxy address.
|
7. Now, switch over to your Vikunja browser window and hit refresh. If you configured your URL correctly in original Vikunja container, you should be all set and the browser will correctly show Vikunja. If not, you'll need to adjust the address in the top of the login subscreen to match your proxy address.
|
||||||
|
|
||||||
## Apache
|
## Apache
|
||||||
|
|
||||||
|
|
|
@ -11,11 +11,9 @@ menu:
|
||||||
# UTF-8 Settings
|
# UTF-8 Settings
|
||||||
|
|
||||||
Vikunja itself is always fully capable of handling utf-8 characters.
|
Vikunja itself is always fully capable of handling utf-8 characters.
|
||||||
However, your database might be not.
|
However, your database might be not. Vikunja itself will work just fine until you want to use non-latin characters in your tasks/projects/etc.
|
||||||
Vikunja itself will work just fine until you want to use non-latin characters in your tasks/projects/etc.
|
|
||||||
|
|
||||||
On this page, you will find information about how to fully ensure non-latin characters like aüäß or emojis work
|
On this page, you will find information about how to fully ensure non-latin characters like *aüäß* or emojis work with your installation.
|
||||||
with your installation.
|
|
||||||
|
|
||||||
{{< table_of_contents >}}
|
{{< table_of_contents >}}
|
||||||
|
|
||||||
|
@ -57,8 +55,7 @@ Before attempting any conversion, please [back up your database]({{< ref "backup
|
||||||
|
|
||||||
### 1. Create a pre-conversion script
|
### 1. Create a pre-conversion script
|
||||||
|
|
||||||
Copy the following sql statements in a file called `preAlterTables.sql` and replace all occurences of `vikunja` with
|
Copy the following sql statements in a file called `preAlterTables.sql` and replace all occurrences of `vikunja` with the name of your database:
|
||||||
the name of your database:
|
|
||||||
|
|
||||||
{{< highlight sql >}}
|
{{< highlight sql >}}
|
||||||
use information_schema;
|
use information_schema;
|
||||||
|
|
|
@ -19,7 +19,7 @@ The Vikunja api and frontend are available in two different release flavors.
|
||||||
Stable releases have a fixed version number like `0.18.2` and are published at irregular intervals whenever a new version is ready.
|
Stable releases have a fixed version number like `0.18.2` and are published at irregular intervals whenever a new version is ready.
|
||||||
They receive few bugfixes and security patches.
|
They receive few bugfixes and security patches.
|
||||||
|
|
||||||
We use [Semantic Versioning](#) for these releases.
|
We use [Semantic Versioning](https://semver.org) for these releases.
|
||||||
|
|
||||||
## Unstable
|
## Unstable
|
||||||
|
|
||||||
|
|
|
@ -10,10 +10,10 @@ menu:
|
||||||
|
|
||||||
# API Documentation
|
# API Documentation
|
||||||
|
|
||||||
You can find the api docs under `http://vikunja.tld/api/v1/docs` of your instance.
|
You can find the api docs under `http://vikunja.tld/api/v1/docs` of your instance.<br />
|
||||||
A public instance is available on [try.vikunja.io](https://try.vikunja.io/api/v1/docs).
|
A public instance is available on [try.vikunja.io](https://try.vikunja.io/api/v1/docs).
|
||||||
|
|
||||||
These docs are autgenerated from annotations in the code with swagger.
|
These docs are autogenerated from annotations in the code with swagger.
|
||||||
|
|
||||||
The specification is hosted at `http://vikunja.tld/api/v1/docs.json`.
|
The specification is hosted at `http://vikunja.tld/api/v1/docs.json`.
|
||||||
You can use this to embed it into other openapi compatible applications if you want.
|
You can use this to embed it into other OpenAPI compatible applications if you want.
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
---
|
---
|
||||||
date: "2019-05-12:00:00+01:00"
|
date: "2019-05-12:00:00+01:00"
|
||||||
title: "Caldav"
|
title: "CalDAV"
|
||||||
draft: false
|
draft: false
|
||||||
type: "doc"
|
type: "doc"
|
||||||
menu:
|
menu:
|
||||||
|
@ -8,9 +8,9 @@ menu:
|
||||||
parent: "usage"
|
parent: "usage"
|
||||||
---
|
---
|
||||||
|
|
||||||
# Caldav
|
# CalDAV
|
||||||
|
|
||||||
> **Warning:** The caldav integration is in an early alpha stage and has bugs.
|
> **Warning:** The CalDAV integration is in an early alpha stage and has bugs.
|
||||||
> It works well with some clients while having issues with others.
|
> It works well with some clients while having issues with others.
|
||||||
> If you encounter issues, please [report them](https://code.vikunja.io/api/issues/new?body=[caldav])
|
> If you encounter issues, please [report them](https://code.vikunja.io/api/issues/new?body=[caldav])
|
||||||
|
|
||||||
|
@ -39,13 +39,13 @@ Vikunja currently supports the following properties:
|
||||||
* `PRIORITY`
|
* `PRIORITY`
|
||||||
* `CATEGORIES`
|
* `CATEGORIES`
|
||||||
* `COMPLETED`
|
* `COMPLETED`
|
||||||
* `CREATED` (only Vikunja -> Client)
|
* `CREATED` (only Vikunja → Client)
|
||||||
* `DUE`
|
* `DUE`
|
||||||
* `DURATION`
|
* `DURATION`
|
||||||
* `DTSTAMP`
|
* `DTSTAMP`
|
||||||
* `DTSTART`
|
* `DTSTART`
|
||||||
* `LAST-MODIFIED` (only Vikunja -> Client)
|
* `LAST-MODIFIED` (only Vikunja → Client)
|
||||||
* `RRULE` (Recurrence) (only Vikunja -> Client)
|
* `RRULE` (Recurrence) (only Vikunja → Client)
|
||||||
* `VALARM` (Reminders)
|
* `VALARM` (Reminders)
|
||||||
|
|
||||||
Vikunja **currently does not** support these properties:
|
Vikunja **currently does not** support these properties:
|
||||||
|
@ -70,17 +70,17 @@ Vikunja **currently does not** support these properties:
|
||||||
### Working
|
### Working
|
||||||
|
|
||||||
* [Evolution](https://wiki.gnome.org/Apps/Evolution/)
|
* [Evolution](https://wiki.gnome.org/Apps/Evolution/)
|
||||||
* [OpenTasks](https://opentasks.app/) + [DAVx⁵](https://www.davx5.com/)
|
* [OpenTasks](https://opentasks.app/) & [DAVx⁵](https://www.davx5.com/)
|
||||||
* [Tasks (Android)](https://tasks.org/)
|
* [Tasks (Android)](https://tasks.org/)
|
||||||
|
|
||||||
### Not working
|
### Not working
|
||||||
|
|
||||||
* [Thunderbird (68)](https://www.thunderbird.net/)
|
* [Thunderbird (68)](https://www.thunderbird.net/)
|
||||||
* iOS calDAV Sync (See [#753](https://kolaente.dev/vikunja/api/issues/753))
|
* iOS CalDAV Sync (See [#753](https://kolaente.dev/vikunja/api/issues/753))
|
||||||
|
|
||||||
## Dev logs
|
## Dev logs
|
||||||
|
|
||||||
The whole thing is not optimized at all and probably pretty inefficent.
|
The whole thing is not optimized at all and probably pretty inefficient.
|
||||||
|
|
||||||
Request body and headers are logged if the debug output is enabled.
|
Request body and headers are logged if the debug output is enabled.
|
||||||
|
|
||||||
|
@ -141,6 +141,4 @@ Requests from the app:::
|
||||||
And then it just stops.
|
And then it just stops.
|
||||||
... and complains about not being able to find the home set
|
... and complains about not being able to find the home set
|
||||||
... without even requesting it...
|
... without even requesting it...
|
||||||
|
|
||||||
|
|
||||||
```
|
```
|
|
@ -10,7 +10,7 @@ menu:
|
||||||
|
|
||||||
# Command line interface
|
# Command line interface
|
||||||
|
|
||||||
You can interact with Vikunja using its `cli` interface.
|
You can interact with Vikunja using its `cli` interface.<br />
|
||||||
The following commands are available:
|
The following commands are available:
|
||||||
|
|
||||||
* [dump](#dump)
|
* [dump](#dump)
|
||||||
|
@ -31,7 +31,7 @@ All commands use the same standard [config file]({{< ref "../setup/config.md">}}
|
||||||
When running Vikunja in docker, you'll need to execute all commands in the `api` container.
|
When running Vikunja in docker, you'll need to execute all commands in the `api` container.
|
||||||
Instead of running the `vikunja` binary directly, run it like this:
|
Instead of running the `vikunja` binary directly, run it like this:
|
||||||
|
|
||||||
```
|
```sh
|
||||||
docker exec <name of the vikunja api container> /app/vikunja/vikunja <subcommand>
|
docker exec <name of the vikunja api container> /app/vikunja/vikunja <subcommand>
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -80,12 +80,12 @@ Roll migrations back until a certain point.
|
||||||
|
|
||||||
Usage:
|
Usage:
|
||||||
{{< highlight bash >}}
|
{{< highlight bash >}}
|
||||||
$ vikunja migrate rollback [flags]
|
$ vikunja migrate rollback [flags]
|
||||||
{{< /highlight >}}
|
{{< /highlight >}}
|
||||||
|
|
||||||
Flags:
|
Flags:
|
||||||
* `-n`, `--name` string: The id of the migration you want to roll back until.
|
* `-n`, `--name` string: The id of the migration you want to roll back until.
|
||||||
|
|
||||||
### `restore`
|
### `restore`
|
||||||
|
|
||||||
Restores a previously created dump from a zip file, see `dump`.
|
Restores a previously created dump from a zip file, see `dump`.
|
||||||
|
@ -138,9 +138,9 @@ Flags:
|
||||||
|
|
||||||
#### `user delete`
|
#### `user delete`
|
||||||
|
|
||||||
Start the user deletion process.
|
Start the user deletion process.
|
||||||
If called without the `--now` flag, this command will only trigger an email to the user in order for them to confirm and start the deletion process (this is the same behavoir as if the user requested their deletion via the web interface).
|
If called without the `--now` flag, this command will only trigger an email to the user in order for them to confirm and start the deletion process (this is the same behavoir as if the user requested their deletion via the web interface).
|
||||||
With the flag the user is deleted **immediately**.
|
With the flag the user is deleted **immediately**.
|
||||||
|
|
||||||
**USE WITH CAUTION.**
|
**USE WITH CAUTION.**
|
||||||
|
|
||||||
|
@ -194,7 +194,7 @@ This is either the semantic version (something like `0.7`) or version + git comm
|
||||||
|
|
||||||
Usage:
|
Usage:
|
||||||
{{< highlight bash >}}
|
{{< highlight bash >}}
|
||||||
$ vikunja version
|
$ vikunja version
|
||||||
{{< /highlight >}}
|
{{< /highlight >}}
|
||||||
|
|
||||||
### `web`
|
### `web`
|
||||||
|
@ -203,5 +203,5 @@ Starts Vikunja's REST api server.
|
||||||
|
|
||||||
Usage:
|
Usage:
|
||||||
{{< highlight bash >}}
|
{{< highlight bash >}}
|
||||||
$ vikunja web
|
$ vikunja web
|
||||||
{{< /highlight >}}
|
{{< /highlight >}}
|
||||||
|
|
|
@ -77,7 +77,7 @@ This document describes the different errors Vikunja can return.
|
||||||
| 4006 | 403 | The user tried to set a parent task as the task itself. |
|
| 4006 | 403 | The user tried to set a parent task as the task itself. |
|
||||||
| 4007 | 400 | The user tried to create a task relation with an invalid kind of relation. |
|
| 4007 | 400 | The user tried to create a task relation with an invalid kind of relation. |
|
||||||
| 4008 | 409 | The user tried to create a task relation which already exists. |
|
| 4008 | 409 | The user tried to create a task relation which already exists. |
|
||||||
| 4009 | 404 | The task relation does not exist. |
|
| 4009 | 404 | The task relation does not exist. |
|
||||||
| 4010 | 400 | Cannot relate a task with itself. |
|
| 4010 | 400 | Cannot relate a task with itself. |
|
||||||
| 4011 | 404 | The task attachment does not exist. |
|
| 4011 | 404 | The task attachment does not exist. |
|
||||||
| 4012 | 400 | The task attachment is too large. |
|
| 4012 | 400 | The task attachment is too large. |
|
||||||
|
@ -96,7 +96,7 @@ This document describes the different errors Vikunja can return.
|
||||||
|
|
||||||
| ErrorCode | HTTP Status Code | Description |
|
| ErrorCode | HTTP Status Code | Description |
|
||||||
|-----------|------------------|-------------|
|
|-----------|------------------|-------------|
|
||||||
| 5001 | 404 | The namspace does not exist. |
|
| 5001 | 404 | The namespace does not exist. |
|
||||||
| 5003 | 403 | The user does not have access to the specified namespace. |
|
| 5003 | 403 | The user does not have access to the specified namespace. |
|
||||||
| 5006 | 400 | The namespace name cannot be empty. |
|
| 5006 | 400 | The namespace name cannot be empty. |
|
||||||
| 5009 | 403 | The user needs to have namespace read access to perform that action. |
|
| 5009 | 403 | The user needs to have namespace read access to perform that action. |
|
||||||
|
@ -108,7 +108,7 @@ This document describes the different errors Vikunja can return.
|
||||||
|
|
||||||
| ErrorCode | HTTP Status Code | Description |
|
| ErrorCode | HTTP Status Code | Description |
|
||||||
|-----------|------------------|-------------|
|
|-----------|------------------|-------------|
|
||||||
| 6001 | 400 | The team name cannot be emtpy. |
|
| 6001 | 400 | The team name cannot be empty. |
|
||||||
| 6002 | 404 | The team does not exist. |
|
| 6002 | 404 | The team does not exist. |
|
||||||
| 6004 | 409 | The team already has access to that namespace or project. |
|
| 6004 | 409 | The team already has access to that namespace or project. |
|
||||||
| 6005 | 409 | The user is already a member of that team. |
|
| 6005 | 409 | The user is already a member of that team. |
|
||||||
|
@ -134,7 +134,7 @@ This document describes the different errors Vikunja can return.
|
||||||
|
|
||||||
| ErrorCode | HTTP Status Code | Description |
|
| ErrorCode | HTTP Status Code | Description |
|
||||||
|-----------|------------------|-------------|
|
|-----------|------------------|-------------|
|
||||||
| 9001 | 403 | The right is invalid. |
|
| 9001 | 403 | The right is invalid. |
|
||||||
|
|
||||||
## Kanban
|
## Kanban
|
||||||
|
|
||||||
|
@ -151,7 +151,7 @@ This document describes the different errors Vikunja can return.
|
||||||
| ErrorCode | HTTP Status Code | Description |
|
| ErrorCode | HTTP Status Code | Description |
|
||||||
|-----------|------------------|-------------|
|
|-----------|------------------|-------------|
|
||||||
| 11001 | 404 | The saved filter does not exist. |
|
| 11001 | 404 | The saved filter does not exist. |
|
||||||
| 11002 | 412 | Saved filters are not available for link shares. |
|
| 11002 | 412 | Saved filters are not available for link shares. |
|
||||||
|
|
||||||
## Subscriptions
|
## Subscriptions
|
||||||
|
|
||||||
|
@ -162,7 +162,8 @@ This document describes the different errors Vikunja can return.
|
||||||
|
|
||||||
## Link Shares
|
## Link Shares
|
||||||
|
|
||||||
| ErrorCode | HTTP Status Code | Description |
|
| ErrorCode | HTTP Status Code | Description |
|
||||||
|-----------|------------------|-------------|
|
|-----------|------------------|--------------------------------------------------------------------------------|
|
||||||
| 13001 | 412 | This link share requires a password for authentication, but none was provided. |
|
| 13001 | 412 | This link share requires a password for authentication, but none was provided. |
|
||||||
| 13002 | 403 | The provided link share password was invalid. |
|
| 13002 | 403 | The provided link share password is invalid. |
|
||||||
|
| 13003 | 400 | The provided link share token is invalid. |
|
||||||
|
|
|
@ -10,7 +10,7 @@ menu:
|
||||||
|
|
||||||
# Project and namespace rights for teams and users
|
# Project and namespace rights for teams and users
|
||||||
|
|
||||||
Whenever you share a project or namespace with a user or team, you can specify a `rights` parameter.
|
Whenever you share a project or namespace with a user or team, you can specify a `rights` parameter.
|
||||||
This parameter controls the rights that team or user is going to have (or has, if you request the current sharing status).
|
This parameter controls the rights that team or user is going to have (or has, if you request the current sharing status).
|
||||||
|
|
||||||
Rights are being specified using integers.
|
Rights are being specified using integers.
|
||||||
|
@ -20,10 +20,10 @@ The following values are possible:
|
||||||
| Right (int) | Meaning |
|
| Right (int) | Meaning |
|
||||||
|-------------|---------------------------------------------------------------------------------------------------------------|
|
|-------------|---------------------------------------------------------------------------------------------------------------|
|
||||||
| 0 (Default) | Read only. Anything which is shared with this right cannot be edited. |
|
| 0 (Default) | Read only. Anything which is shared with this right cannot be edited. |
|
||||||
| 1 | Read and write. Namespaces or projects shared with this right can be read and written to by the team or user. |
|
| 1 | Read and write. Namespaces or projects shared with this right can be read and written to by the team or user. |
|
||||||
| 2 | Admin. Can do anything like read and write, but can additionally manage sharing options. |
|
| 2 | Admin. Can do anything like read and write, but can additionally manage sharing options. |
|
||||||
|
|
||||||
## Team admins
|
## Team admins
|
||||||
|
|
||||||
When adding or querying a team, every member has an additional boolean value stating if it is admin or not.
|
When adding or querying a team, every member has an additional boolean value stating if it is admin or not.
|
||||||
A team admin can also add and remove team members and also change whether a user in the team is admin or not.
|
A team admin can also add and remove team members and also change whether a user in the team is admin or not.
|
||||||
|
|
54
go.mod
54
go.mod
|
@ -21,7 +21,7 @@ require (
|
||||||
gitea.com/xorm/xorm-redis-cache v0.2.0
|
gitea.com/xorm/xorm-redis-cache v0.2.0
|
||||||
github.com/ThreeDotsLabs/watermill v1.2.0
|
github.com/ThreeDotsLabs/watermill v1.2.0
|
||||||
github.com/adlio/trello v1.10.0
|
github.com/adlio/trello v1.10.0
|
||||||
github.com/arran4/golang-ical v0.0.0-20230318005454-19abf92700cc
|
github.com/arran4/golang-ical v0.0.0-20230425234049-f69e132f2b0c
|
||||||
github.com/asaskevich/govalidator v0.0.0-20200907205600-7a23bdc65eef
|
github.com/asaskevich/govalidator v0.0.0-20200907205600-7a23bdc65eef
|
||||||
github.com/bbrks/go-blurhash v1.1.1
|
github.com/bbrks/go-blurhash v1.1.1
|
||||||
github.com/c2h5oh/datasize v0.0.0-20220606134207-859f65c6625b
|
github.com/c2h5oh/datasize v0.0.0-20220606134207-859f65c6625b
|
||||||
|
@ -32,9 +32,9 @@ require (
|
||||||
github.com/dustinkirkland/golang-petname v0.0.0-20191129215211-8e5a1ed0cff0
|
github.com/dustinkirkland/golang-petname v0.0.0-20191129215211-8e5a1ed0cff0
|
||||||
github.com/gabriel-vasile/mimetype v1.4.2
|
github.com/gabriel-vasile/mimetype v1.4.2
|
||||||
github.com/getsentry/sentry-go v0.20.0
|
github.com/getsentry/sentry-go v0.20.0
|
||||||
github.com/go-sql-driver/mysql v1.7.0
|
github.com/go-sql-driver/mysql v1.7.1
|
||||||
github.com/go-testfixtures/testfixtures/v3 v3.8.1
|
github.com/go-testfixtures/testfixtures/v3 v3.9.0
|
||||||
github.com/gocarina/gocsv v0.0.0-20230325173030-9a18a846a479
|
github.com/gocarina/gocsv v0.0.0-20230406101422-6445c2b15027
|
||||||
github.com/golang-jwt/jwt/v4 v4.5.0
|
github.com/golang-jwt/jwt/v4 v4.5.0
|
||||||
github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0
|
github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0
|
||||||
github.com/google/uuid v1.3.0
|
github.com/google/uuid v1.3.0
|
||||||
|
@ -44,18 +44,18 @@ require (
|
||||||
github.com/labstack/echo-jwt/v4 v4.1.0
|
github.com/labstack/echo-jwt/v4 v4.1.0
|
||||||
github.com/labstack/echo/v4 v4.10.2
|
github.com/labstack/echo/v4 v4.10.2
|
||||||
github.com/labstack/gommon v0.4.0
|
github.com/labstack/gommon v0.4.0
|
||||||
github.com/lib/pq v1.10.7
|
github.com/lib/pq v1.10.9
|
||||||
github.com/magefile/mage v1.14.0
|
github.com/magefile/mage v1.14.0
|
||||||
github.com/mattn/go-sqlite3 v1.14.16
|
github.com/mattn/go-sqlite3 v1.14.16
|
||||||
github.com/olekukonko/tablewriter v0.0.5
|
github.com/olekukonko/tablewriter v0.0.5
|
||||||
github.com/op/go-logging v0.0.0-20160315200505-970db520ece7
|
github.com/op/go-logging v0.0.0-20160315200505-970db520ece7
|
||||||
github.com/pquerna/otp v1.4.0
|
github.com/pquerna/otp v1.4.0
|
||||||
github.com/prometheus/client_golang v1.14.0
|
github.com/prometheus/client_golang v1.15.1
|
||||||
github.com/redis/go-redis/v9 v9.0.3
|
github.com/redis/go-redis/v9 v9.0.4
|
||||||
github.com/robfig/cron/v3 v3.0.1
|
github.com/robfig/cron/v3 v3.0.1
|
||||||
github.com/samedi/caldav-go v3.0.0+incompatible
|
github.com/samedi/caldav-go v3.0.0+incompatible
|
||||||
github.com/spf13/afero v1.9.5
|
github.com/spf13/afero v1.9.5
|
||||||
github.com/spf13/cobra v1.6.1
|
github.com/spf13/cobra v1.7.0
|
||||||
github.com/spf13/viper v1.15.0
|
github.com/spf13/viper v1.15.0
|
||||||
github.com/stretchr/testify v1.8.2
|
github.com/stretchr/testify v1.8.2
|
||||||
github.com/swaggo/swag v1.8.12
|
github.com/swaggo/swag v1.8.12
|
||||||
|
@ -64,24 +64,27 @@ require (
|
||||||
github.com/vectordotdev/go-datemath v0.1.1-0.20220323213446-f3954d0b18ae
|
github.com/vectordotdev/go-datemath v0.1.1-0.20220323213446-f3954d0b18ae
|
||||||
github.com/wneessen/go-mail v0.3.9
|
github.com/wneessen/go-mail v0.3.9
|
||||||
github.com/yuin/goldmark v1.5.4
|
github.com/yuin/goldmark v1.5.4
|
||||||
golang.org/x/crypto v0.7.0
|
golang.org/x/crypto v0.8.0
|
||||||
golang.org/x/image v0.6.0
|
golang.org/x/image v0.7.0
|
||||||
golang.org/x/oauth2 v0.6.0
|
golang.org/x/oauth2 v0.7.0
|
||||||
golang.org/x/sync v0.1.0
|
golang.org/x/sync v0.2.0
|
||||||
golang.org/x/sys v0.6.0
|
golang.org/x/sys v0.8.0
|
||||||
golang.org/x/term v0.6.0
|
golang.org/x/term v0.8.0
|
||||||
gopkg.in/d4l3k/messagediff.v1 v1.2.1
|
gopkg.in/d4l3k/messagediff.v1 v1.2.1
|
||||||
gopkg.in/yaml.v3 v3.0.1
|
gopkg.in/yaml.v3 v3.0.1
|
||||||
src.techknowlogick.com/xgo v1.7.1-0.20230307171022-b60708668fc7
|
src.techknowlogick.com/xgo v1.7.1-0.20230502175921-52d704db7dce
|
||||||
src.techknowlogick.com/xormigrate v1.5.0
|
src.techknowlogick.com/xormigrate v1.5.0
|
||||||
xorm.io/builder v0.3.12
|
xorm.io/builder v0.3.12
|
||||||
xorm.io/xorm v1.3.2
|
xorm.io/xorm v1.3.2
|
||||||
)
|
)
|
||||||
|
|
||||||
require (
|
require (
|
||||||
|
github.com/ClickHouse/ch-go v0.55.0 // indirect
|
||||||
|
github.com/ClickHouse/clickhouse-go/v2 v2.9.1 // indirect
|
||||||
github.com/KyleBanks/depth v1.2.1 // indirect
|
github.com/KyleBanks/depth v1.2.1 // indirect
|
||||||
github.com/PuerkitoBio/purell v1.1.1 // indirect
|
github.com/PuerkitoBio/purell v1.1.1 // indirect
|
||||||
github.com/PuerkitoBio/urlesc v0.0.0-20170810143723-de5bf2ad4578 // indirect
|
github.com/PuerkitoBio/urlesc v0.0.0-20170810143723-de5bf2ad4578 // indirect
|
||||||
|
github.com/andybalholm/brotli v1.0.5 // indirect
|
||||||
github.com/beevik/etree v1.1.0 // indirect
|
github.com/beevik/etree v1.1.0 // indirect
|
||||||
github.com/beorn7/perks v1.0.1 // indirect
|
github.com/beorn7/perks v1.0.1 // indirect
|
||||||
github.com/boombuler/barcode v1.0.1-0.20190219062509-6c824513bacc // indirect
|
github.com/boombuler/barcode v1.0.1-0.20190219062509-6c824513bacc // indirect
|
||||||
|
@ -94,6 +97,8 @@ require (
|
||||||
github.com/garyburd/redigo v1.6.0 // indirect
|
github.com/garyburd/redigo v1.6.0 // indirect
|
||||||
github.com/ghodss/yaml v1.0.0 // indirect
|
github.com/ghodss/yaml v1.0.0 // indirect
|
||||||
github.com/go-chi/chi/v5 v5.0.8 // indirect
|
github.com/go-chi/chi/v5 v5.0.8 // indirect
|
||||||
|
github.com/go-faster/city v1.0.1 // indirect
|
||||||
|
github.com/go-faster/errors v0.6.1 // indirect
|
||||||
github.com/go-jose/go-jose/v3 v3.0.0 // indirect
|
github.com/go-jose/go-jose/v3 v3.0.0 // indirect
|
||||||
github.com/go-openapi/jsonpointer v0.19.5 // indirect
|
github.com/go-openapi/jsonpointer v0.19.5 // indirect
|
||||||
github.com/go-openapi/jsonreference v0.19.6 // indirect
|
github.com/go-openapi/jsonreference v0.19.6 // indirect
|
||||||
|
@ -101,14 +106,15 @@ require (
|
||||||
github.com/go-openapi/swag v0.19.15 // indirect
|
github.com/go-openapi/swag v0.19.15 // indirect
|
||||||
github.com/goccy/go-json v0.9.11 // indirect
|
github.com/goccy/go-json v0.9.11 // indirect
|
||||||
github.com/golang-jwt/jwt v3.2.2+incompatible // indirect
|
github.com/golang-jwt/jwt v3.2.2+incompatible // indirect
|
||||||
github.com/golang/protobuf v1.5.2 // indirect
|
github.com/golang/protobuf v1.5.3 // indirect
|
||||||
github.com/golang/snappy v0.0.4 // indirect
|
github.com/golang/snappy v0.0.4 // indirect
|
||||||
github.com/hashicorp/errwrap v1.1.0 // indirect
|
github.com/hashicorp/errwrap v1.1.0 // indirect
|
||||||
github.com/hashicorp/go-multierror v1.1.1 // indirect
|
github.com/hashicorp/go-multierror v1.1.1 // indirect
|
||||||
github.com/hashicorp/hcl v1.0.0 // indirect
|
github.com/hashicorp/hcl v1.0.0 // indirect
|
||||||
github.com/inconshreveable/mousetrap v1.0.1 // indirect
|
github.com/inconshreveable/mousetrap v1.1.0 // indirect
|
||||||
github.com/josharian/intern v1.0.0 // indirect
|
github.com/josharian/intern v1.0.0 // indirect
|
||||||
github.com/json-iterator/go v1.1.12 // indirect
|
github.com/json-iterator/go v1.1.12 // indirect
|
||||||
|
github.com/klauspost/compress v1.16.5 // indirect
|
||||||
github.com/laurent22/ical-go v0.1.1-0.20181107184520-7e5d6ade8eef // indirect
|
github.com/laurent22/ical-go v0.1.1-0.20181107184520-7e5d6ade8eef // indirect
|
||||||
github.com/lithammer/shortuuid/v3 v3.0.7 // indirect
|
github.com/lithammer/shortuuid/v3 v3.0.7 // indirect
|
||||||
github.com/magiconair/properties v1.8.7 // indirect
|
github.com/magiconair/properties v1.8.7 // indirect
|
||||||
|
@ -123,13 +129,17 @@ require (
|
||||||
github.com/oklog/ulid v1.3.1 // indirect
|
github.com/oklog/ulid v1.3.1 // indirect
|
||||||
github.com/onsi/ginkgo v1.16.4 // indirect
|
github.com/onsi/ginkgo v1.16.4 // indirect
|
||||||
github.com/onsi/gomega v1.16.0 // indirect
|
github.com/onsi/gomega v1.16.0 // indirect
|
||||||
|
github.com/paulmach/orb v0.9.0 // indirect
|
||||||
github.com/pelletier/go-toml/v2 v2.0.6 // indirect
|
github.com/pelletier/go-toml/v2 v2.0.6 // indirect
|
||||||
|
github.com/pierrec/lz4/v4 v4.1.17 // indirect
|
||||||
github.com/pkg/errors v0.9.1 // indirect
|
github.com/pkg/errors v0.9.1 // indirect
|
||||||
github.com/pmezard/go-difflib v1.0.0 // indirect
|
github.com/pmezard/go-difflib v1.0.0 // indirect
|
||||||
github.com/prometheus/client_model v0.3.0 // indirect
|
github.com/prometheus/client_model v0.3.0 // indirect
|
||||||
github.com/prometheus/common v0.39.0 // indirect
|
github.com/prometheus/common v0.42.0 // indirect
|
||||||
github.com/prometheus/procfs v0.9.0 // indirect
|
github.com/prometheus/procfs v0.9.0 // indirect
|
||||||
github.com/russross/blackfriday/v2 v2.1.0 // indirect
|
github.com/russross/blackfriday/v2 v2.1.0 // indirect
|
||||||
|
github.com/segmentio/asm v1.2.0 // indirect
|
||||||
|
github.com/shopspring/decimal v1.3.1 // indirect
|
||||||
github.com/spf13/cast v1.5.0 // indirect
|
github.com/spf13/cast v1.5.0 // indirect
|
||||||
github.com/spf13/jwalterweatherman v1.1.0 // indirect
|
github.com/spf13/jwalterweatherman v1.1.0 // indirect
|
||||||
github.com/spf13/pflag v1.0.5 // indirect
|
github.com/spf13/pflag v1.0.5 // indirect
|
||||||
|
@ -138,13 +148,15 @@ require (
|
||||||
github.com/urfave/cli/v2 v2.3.0 // indirect
|
github.com/urfave/cli/v2 v2.3.0 // indirect
|
||||||
github.com/valyala/bytebufferpool v1.0.0 // indirect
|
github.com/valyala/bytebufferpool v1.0.0 // indirect
|
||||||
github.com/valyala/fasttemplate v1.2.2 // indirect
|
github.com/valyala/fasttemplate v1.2.2 // indirect
|
||||||
|
go.opentelemetry.io/otel v1.15.0 // indirect
|
||||||
|
go.opentelemetry.io/otel/trace v1.15.0 // indirect
|
||||||
golang.org/x/mod v0.9.0 // indirect
|
golang.org/x/mod v0.9.0 // indirect
|
||||||
golang.org/x/net v0.8.0 // indirect
|
golang.org/x/net v0.9.0 // indirect
|
||||||
golang.org/x/text v0.8.0 // indirect
|
golang.org/x/text v0.9.0 // indirect
|
||||||
golang.org/x/time v0.3.0 // indirect
|
golang.org/x/time v0.3.0 // indirect
|
||||||
golang.org/x/tools v0.7.0 // indirect
|
golang.org/x/tools v0.7.0 // indirect
|
||||||
google.golang.org/appengine v1.6.7 // indirect
|
google.golang.org/appengine v1.6.7 // indirect
|
||||||
google.golang.org/protobuf v1.29.1 // indirect
|
google.golang.org/protobuf v1.30.0 // indirect
|
||||||
gopkg.in/ini.v1 v1.67.0 // indirect
|
gopkg.in/ini.v1 v1.67.0 // indirect
|
||||||
gopkg.in/yaml.v2 v2.4.0 // indirect
|
gopkg.in/yaml.v2 v2.4.0 // indirect
|
||||||
)
|
)
|
||||||
|
|
95
go.sum
95
go.sum
|
@ -49,6 +49,10 @@ gitea.com/xorm/xorm-redis-cache v0.2.0/go.mod h1:juYdjkmIKvLbPkdfBVKGVJ2daFQIJAg
|
||||||
gitee.com/travelliu/dm v1.8.11192/go.mod h1:DHTzyhCrM843x9VdKVbZ+GKXGRbKM2sJ4LxihRxShkE=
|
gitee.com/travelliu/dm v1.8.11192/go.mod h1:DHTzyhCrM843x9VdKVbZ+GKXGRbKM2sJ4LxihRxShkE=
|
||||||
github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU=
|
github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU=
|
||||||
github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802/go.mod h1:IVnqGOEym/WlBOVXweHU+Q+/VP0lqqI8lqeDx9IjBqo=
|
github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802/go.mod h1:IVnqGOEym/WlBOVXweHU+Q+/VP0lqqI8lqeDx9IjBqo=
|
||||||
|
github.com/ClickHouse/ch-go v0.55.0 h1:jw4Tpx887YXrkyL5DfgUome/po8MLz92nz2heOQ6RjQ=
|
||||||
|
github.com/ClickHouse/ch-go v0.55.0/go.mod h1:kQT2f+yp2p+sagQA/7kS6G3ukym+GQ5KAu1kuFAFDiU=
|
||||||
|
github.com/ClickHouse/clickhouse-go/v2 v2.9.1 h1:IeE2bwVvAba7Yw5ZKu98bKI4NpDmykEy6jUaQdJJCk8=
|
||||||
|
github.com/ClickHouse/clickhouse-go/v2 v2.9.1/go.mod h1:teXfZNM90iQ99Jnuht+dxQXCuhDZ8nvvMoTJOFrcmcg=
|
||||||
github.com/Knetic/govaluate v3.0.1-0.20171022003610-9aa49832a739+incompatible/go.mod h1:r7JcOSlj0wfOMncg0iLm8Leh48TZaKVeNIfJntJ2wa0=
|
github.com/Knetic/govaluate v3.0.1-0.20171022003610-9aa49832a739+incompatible/go.mod h1:r7JcOSlj0wfOMncg0iLm8Leh48TZaKVeNIfJntJ2wa0=
|
||||||
github.com/KyleBanks/depth v1.2.1 h1:5h8fQADFrWtarTdtDudMmGsC7GPbOAu6RVB3ffsVFHc=
|
github.com/KyleBanks/depth v1.2.1 h1:5h8fQADFrWtarTdtDudMmGsC7GPbOAu6RVB3ffsVFHc=
|
||||||
github.com/KyleBanks/depth v1.2.1/go.mod h1:jzSb9d0L43HxTQfT+oSA1EEp2q+ne2uh6XgeJcm8brE=
|
github.com/KyleBanks/depth v1.2.1/go.mod h1:jzSb9d0L43HxTQfT+oSA1EEp2q+ne2uh6XgeJcm8brE=
|
||||||
|
@ -70,6 +74,8 @@ github.com/alecthomas/template v0.0.0-20160405071501-a0175ee3bccc/go.mod h1:LOuy
|
||||||
github.com/alecthomas/template v0.0.0-20190718012654-fb15b899a751/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc=
|
github.com/alecthomas/template v0.0.0-20190718012654-fb15b899a751/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc=
|
||||||
github.com/alecthomas/units v0.0.0-20151022065526-2efee857e7cf/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0=
|
github.com/alecthomas/units v0.0.0-20151022065526-2efee857e7cf/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0=
|
||||||
github.com/alecthomas/units v0.0.0-20190717042225-c3de453c63f4/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0=
|
github.com/alecthomas/units v0.0.0-20190717042225-c3de453c63f4/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0=
|
||||||
|
github.com/andybalholm/brotli v1.0.5 h1:8uQZIdzKmjc/iuPu7O2ioW48L81FgatrcpfFmiq/cCs=
|
||||||
|
github.com/andybalholm/brotli v1.0.5/go.mod h1:fO7iG3H7G2nSZ7m0zPUDn85XEX2GTukHGRSepvi9Eig=
|
||||||
github.com/andybalholm/cascadia v1.1.0/go.mod h1:GsXiBklL0woXo1j/WYWtSYYC4ouU9PqHO0sqidkEA4Y=
|
github.com/andybalholm/cascadia v1.1.0/go.mod h1:GsXiBklL0woXo1j/WYWtSYYC4ouU9PqHO0sqidkEA4Y=
|
||||||
github.com/apache/thrift v0.12.0/go.mod h1:cp2SuWMxlEZw2r+iP2GNCdIi4C1qmUzdZFSVb+bacwQ=
|
github.com/apache/thrift v0.12.0/go.mod h1:cp2SuWMxlEZw2r+iP2GNCdIi4C1qmUzdZFSVb+bacwQ=
|
||||||
github.com/apache/thrift v0.13.0/go.mod h1:cp2SuWMxlEZw2r+iP2GNCdIi4C1qmUzdZFSVb+bacwQ=
|
github.com/apache/thrift v0.13.0/go.mod h1:cp2SuWMxlEZw2r+iP2GNCdIi4C1qmUzdZFSVb+bacwQ=
|
||||||
|
@ -80,6 +86,8 @@ github.com/arran4/golang-ical v0.0.0-20230213232137-07c6aad5e4f0 h1:VVPogIxPiZ6W
|
||||||
github.com/arran4/golang-ical v0.0.0-20230213232137-07c6aad5e4f0/go.mod h1:BSTTrYHuM12oAL8jDdcmPdw02SBThKYWNFHQlvEG6b0=
|
github.com/arran4/golang-ical v0.0.0-20230213232137-07c6aad5e4f0/go.mod h1:BSTTrYHuM12oAL8jDdcmPdw02SBThKYWNFHQlvEG6b0=
|
||||||
github.com/arran4/golang-ical v0.0.0-20230318005454-19abf92700cc h1:up1aDcTCZ3KrL2ukKxNqjMRx/CCaXyn9Wl6N7ea3EWc=
|
github.com/arran4/golang-ical v0.0.0-20230318005454-19abf92700cc h1:up1aDcTCZ3KrL2ukKxNqjMRx/CCaXyn9Wl6N7ea3EWc=
|
||||||
github.com/arran4/golang-ical v0.0.0-20230318005454-19abf92700cc/go.mod h1:BSTTrYHuM12oAL8jDdcmPdw02SBThKYWNFHQlvEG6b0=
|
github.com/arran4/golang-ical v0.0.0-20230318005454-19abf92700cc/go.mod h1:BSTTrYHuM12oAL8jDdcmPdw02SBThKYWNFHQlvEG6b0=
|
||||||
|
github.com/arran4/golang-ical v0.0.0-20230425234049-f69e132f2b0c h1:bmHPCBB1T8YZpQI+Ch0RuICrozVFmPAjiBQZvAjtpRI=
|
||||||
|
github.com/arran4/golang-ical v0.0.0-20230425234049-f69e132f2b0c/go.mod h1:BSTTrYHuM12oAL8jDdcmPdw02SBThKYWNFHQlvEG6b0=
|
||||||
github.com/aryann/difflib v0.0.0-20170710044230-e206f873d14a/go.mod h1:DAHtR1m6lCRdSC2Tm3DSWRPvIPr6xNKyeHdqDQSQT+A=
|
github.com/aryann/difflib v0.0.0-20170710044230-e206f873d14a/go.mod h1:DAHtR1m6lCRdSC2Tm3DSWRPvIPr6xNKyeHdqDQSQT+A=
|
||||||
github.com/asaskevich/govalidator v0.0.0-20200907205600-7a23bdc65eef h1:46PFijGLmAjMPwCCCo7Jf0W6f9slllCkkv7vyc1yOSg=
|
github.com/asaskevich/govalidator v0.0.0-20200907205600-7a23bdc65eef h1:46PFijGLmAjMPwCCCo7Jf0W6f9slllCkkv7vyc1yOSg=
|
||||||
github.com/asaskevich/govalidator v0.0.0-20200907205600-7a23bdc65eef/go.mod h1:WaHUgvxTVq04UNunO+XhnAqY/wQc+bxr74GqbsZ/Jqw=
|
github.com/asaskevich/govalidator v0.0.0-20200907205600-7a23bdc65eef/go.mod h1:WaHUgvxTVq04UNunO+XhnAqY/wQc+bxr74GqbsZ/Jqw=
|
||||||
|
@ -188,6 +196,10 @@ github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeME
|
||||||
github.com/go-chi/chi/v5 v5.0.8 h1:lD+NLqFcAi1ovnVZpsnObHGW4xb4J8lNmoYVfECH1Y0=
|
github.com/go-chi/chi/v5 v5.0.8 h1:lD+NLqFcAi1ovnVZpsnObHGW4xb4J8lNmoYVfECH1Y0=
|
||||||
github.com/go-chi/chi/v5 v5.0.8/go.mod h1:DslCQbL2OYiznFReuXYUmQ2hGd1aDpCnlMNITLSKoi8=
|
github.com/go-chi/chi/v5 v5.0.8/go.mod h1:DslCQbL2OYiznFReuXYUmQ2hGd1aDpCnlMNITLSKoi8=
|
||||||
github.com/go-errors/errors v1.4.2 h1:J6MZopCL4uSllY1OfXM374weqZFFItUbrImctkmUxIA=
|
github.com/go-errors/errors v1.4.2 h1:J6MZopCL4uSllY1OfXM374weqZFFItUbrImctkmUxIA=
|
||||||
|
github.com/go-faster/city v1.0.1 h1:4WAxSZ3V2Ws4QRDrscLEDcibJY8uf41H6AhXDrNDcGw=
|
||||||
|
github.com/go-faster/city v1.0.1/go.mod h1:jKcUJId49qdW3L1qKHH/3wPeUstCVpVSXTM6vO3VcTw=
|
||||||
|
github.com/go-faster/errors v0.6.1 h1:nNIPOBkprlKzkThvS/0YaX8Zs9KewLCOSFQS5BU06FI=
|
||||||
|
github.com/go-faster/errors v0.6.1/go.mod h1:5MGV2/2T9yvlrbhe9pD9LO5Z/2zCSq2T8j+Jpi2LAyY=
|
||||||
github.com/go-gl/glfw v0.0.0-20190409004039-e6da0acd62b1/go.mod h1:vR7hzQXu2zJy9AVAgeJqvqgH9Q5CA+iKCZ2gyEVpxRU=
|
github.com/go-gl/glfw v0.0.0-20190409004039-e6da0acd62b1/go.mod h1:vR7hzQXu2zJy9AVAgeJqvqgH9Q5CA+iKCZ2gyEVpxRU=
|
||||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20191125211704-12ad95a8df72/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20191125211704-12ad95a8df72/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
||||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20200222043503-6f7a984d4dc4/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20200222043503-6f7a984d4dc4/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
||||||
|
@ -215,14 +227,20 @@ github.com/go-sql-driver/mysql v1.5.0/go.mod h1:DCzpHaOWr8IXmIStZouvnhqoel9Qv2LB
|
||||||
github.com/go-sql-driver/mysql v1.6.0/go.mod h1:DCzpHaOWr8IXmIStZouvnhqoel9Qv2LBy8hT2VhHyBg=
|
github.com/go-sql-driver/mysql v1.6.0/go.mod h1:DCzpHaOWr8IXmIStZouvnhqoel9Qv2LBy8hT2VhHyBg=
|
||||||
github.com/go-sql-driver/mysql v1.7.0 h1:ueSltNNllEqE3qcWBTD0iQd3IpL/6U+mJxLkazJ7YPc=
|
github.com/go-sql-driver/mysql v1.7.0 h1:ueSltNNllEqE3qcWBTD0iQd3IpL/6U+mJxLkazJ7YPc=
|
||||||
github.com/go-sql-driver/mysql v1.7.0/go.mod h1:OXbVy3sEdcQ2Doequ6Z5BW6fXNQTmx+9S1MCJN5yJMI=
|
github.com/go-sql-driver/mysql v1.7.0/go.mod h1:OXbVy3sEdcQ2Doequ6Z5BW6fXNQTmx+9S1MCJN5yJMI=
|
||||||
|
github.com/go-sql-driver/mysql v1.7.1 h1:lUIinVbN1DY0xBg0eMOzmmtGoHwWBbvnWubQUrtU8EI=
|
||||||
|
github.com/go-sql-driver/mysql v1.7.1/go.mod h1:OXbVy3sEdcQ2Doequ6Z5BW6fXNQTmx+9S1MCJN5yJMI=
|
||||||
github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY=
|
github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY=
|
||||||
github.com/go-task/slim-sprig v0.0.0-20210107165309-348f09dbbbc0/go.mod h1:fyg7847qk6SyHyPtNmDHnmrv/HOrqktSC+C9fM+CJOE=
|
github.com/go-task/slim-sprig v0.0.0-20210107165309-348f09dbbbc0/go.mod h1:fyg7847qk6SyHyPtNmDHnmrv/HOrqktSC+C9fM+CJOE=
|
||||||
github.com/go-testfixtures/testfixtures/v3 v3.8.1 h1:uonwvepqRvSgddcrReZQhojTlWlmOlHkYAb9ZaOMWgU=
|
github.com/go-testfixtures/testfixtures/v3 v3.8.1 h1:uonwvepqRvSgddcrReZQhojTlWlmOlHkYAb9ZaOMWgU=
|
||||||
github.com/go-testfixtures/testfixtures/v3 v3.8.1/go.mod h1:Kdu7YeMC0KRXVHdaQ91Vmx3pcjoTF63h4f1qTJDdXLA=
|
github.com/go-testfixtures/testfixtures/v3 v3.8.1/go.mod h1:Kdu7YeMC0KRXVHdaQ91Vmx3pcjoTF63h4f1qTJDdXLA=
|
||||||
|
github.com/go-testfixtures/testfixtures/v3 v3.9.0 h1:938g5V+GWLVejm3Hc+nWCuEXRlcglZDDlN/t1gWzcSY=
|
||||||
|
github.com/go-testfixtures/testfixtures/v3 v3.9.0/go.mod h1:cdsKD2ApFBjdog9jRsz6EJqF+LClq/hrwE9K/1Dzo4s=
|
||||||
github.com/gocarina/gocsv v0.0.0-20230226133904-70c27cb2918a h1:/5o1ejt5M0fNAN2lU1NBLtPzUSZru689EWJq01ptr+E=
|
github.com/gocarina/gocsv v0.0.0-20230226133904-70c27cb2918a h1:/5o1ejt5M0fNAN2lU1NBLtPzUSZru689EWJq01ptr+E=
|
||||||
github.com/gocarina/gocsv v0.0.0-20230226133904-70c27cb2918a/go.mod h1:5YoVOkjYAQumqlV356Hj3xeYh4BdZuLE0/nRkf2NKkI=
|
github.com/gocarina/gocsv v0.0.0-20230226133904-70c27cb2918a/go.mod h1:5YoVOkjYAQumqlV356Hj3xeYh4BdZuLE0/nRkf2NKkI=
|
||||||
github.com/gocarina/gocsv v0.0.0-20230325173030-9a18a846a479 h1:KaCpc4e48emF9hYmMB9INyfpGJHAZxEAS9EqWFkpTig=
|
github.com/gocarina/gocsv v0.0.0-20230325173030-9a18a846a479 h1:KaCpc4e48emF9hYmMB9INyfpGJHAZxEAS9EqWFkpTig=
|
||||||
github.com/gocarina/gocsv v0.0.0-20230325173030-9a18a846a479/go.mod h1:5YoVOkjYAQumqlV356Hj3xeYh4BdZuLE0/nRkf2NKkI=
|
github.com/gocarina/gocsv v0.0.0-20230325173030-9a18a846a479/go.mod h1:5YoVOkjYAQumqlV356Hj3xeYh4BdZuLE0/nRkf2NKkI=
|
||||||
|
github.com/gocarina/gocsv v0.0.0-20230406101422-6445c2b15027 h1:LCGzZb4kMUUjMUzLxxqSJBwo9szUO0tK8cOxnEOT4Jc=
|
||||||
|
github.com/gocarina/gocsv v0.0.0-20230406101422-6445c2b15027/go.mod h1:5YoVOkjYAQumqlV356Hj3xeYh4BdZuLE0/nRkf2NKkI=
|
||||||
github.com/goccy/go-json v0.8.1/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MGFi0w8I=
|
github.com/goccy/go-json v0.8.1/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MGFi0w8I=
|
||||||
github.com/goccy/go-json v0.9.11 h1:/pAaQDLHEoCq/5FFmSKBswWmK6H0e8g4159Kc/X/nqk=
|
github.com/goccy/go-json v0.9.11 h1:/pAaQDLHEoCq/5FFmSKBswWmK6H0e8g4159Kc/X/nqk=
|
||||||
github.com/goccy/go-json v0.9.11/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MGFi0w8I=
|
github.com/goccy/go-json v0.9.11/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MGFi0w8I=
|
||||||
|
@ -232,6 +250,7 @@ github.com/gogo/googleapis v1.1.0/go.mod h1:gf4bu3Q80BeJ6H1S1vYPm8/ELATdvryBaNFG
|
||||||
github.com/gogo/protobuf v1.1.1/go.mod h1:r8qH/GZQm5c6nD/R0oafs1akxWv10x8SbQlK7atdtwQ=
|
github.com/gogo/protobuf v1.1.1/go.mod h1:r8qH/GZQm5c6nD/R0oafs1akxWv10x8SbQlK7atdtwQ=
|
||||||
github.com/gogo/protobuf v1.2.0/go.mod h1:r8qH/GZQm5c6nD/R0oafs1akxWv10x8SbQlK7atdtwQ=
|
github.com/gogo/protobuf v1.2.0/go.mod h1:r8qH/GZQm5c6nD/R0oafs1akxWv10x8SbQlK7atdtwQ=
|
||||||
github.com/gogo/protobuf v1.2.1/go.mod h1:hp+jE20tsWTFYpLwKvXlhS1hjn+gTNwPg2I6zVXpSg4=
|
github.com/gogo/protobuf v1.2.1/go.mod h1:hp+jE20tsWTFYpLwKvXlhS1hjn+gTNwPg2I6zVXpSg4=
|
||||||
|
github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q=
|
||||||
github.com/golang-jwt/jwt v3.2.2+incompatible h1:IfV12K8xAKAnZqdXVzCZ+TOjboZ2keLg81eXfW3O+oY=
|
github.com/golang-jwt/jwt v3.2.2+incompatible h1:IfV12K8xAKAnZqdXVzCZ+TOjboZ2keLg81eXfW3O+oY=
|
||||||
github.com/golang-jwt/jwt v3.2.2+incompatible/go.mod h1:8pz2t5EyA70fFQQSrl6XZXzqecmYZeUEB8OUGHkxJ+I=
|
github.com/golang-jwt/jwt v3.2.2+incompatible/go.mod h1:8pz2t5EyA70fFQQSrl6XZXzqecmYZeUEB8OUGHkxJ+I=
|
||||||
github.com/golang-jwt/jwt/v4 v4.5.0 h1:7cYmW1XlMY7h7ii7UhUyChSgS5wUJEnm9uZVTGqOWzg=
|
github.com/golang-jwt/jwt/v4 v4.5.0 h1:7cYmW1XlMY7h7ii7UhUyChSgS5wUJEnm9uZVTGqOWzg=
|
||||||
|
@ -270,6 +289,8 @@ github.com/golang/protobuf v1.4.3/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw
|
||||||
github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk=
|
github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk=
|
||||||
github.com/golang/protobuf v1.5.2 h1:ROPKBNFfQgOUMifHyP+KYbvpjbdoFNs+aK7DXlji0Tw=
|
github.com/golang/protobuf v1.5.2 h1:ROPKBNFfQgOUMifHyP+KYbvpjbdoFNs+aK7DXlji0Tw=
|
||||||
github.com/golang/protobuf v1.5.2/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY=
|
github.com/golang/protobuf v1.5.2/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY=
|
||||||
|
github.com/golang/protobuf v1.5.3 h1:KhyjKVUg7Usr/dYsdSqoFveMYd5ko72D+zANwlG1mmg=
|
||||||
|
github.com/golang/protobuf v1.5.3/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY=
|
||||||
github.com/golang/snappy v0.0.0-20180518054509-2e65f85255db/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
|
github.com/golang/snappy v0.0.0-20180518054509-2e65f85255db/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
|
||||||
github.com/golang/snappy v0.0.1/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
|
github.com/golang/snappy v0.0.1/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
|
||||||
github.com/golang/snappy v0.0.4 h1:yAGX7huGHXlcLOEtBnF4w7FQwA26wojNCwOYAEhLjQM=
|
github.com/golang/snappy v0.0.4 h1:yAGX7huGHXlcLOEtBnF4w7FQwA26wojNCwOYAEhLjQM=
|
||||||
|
@ -361,6 +382,8 @@ github.com/imdario/mergo v0.3.15/go.mod h1:WBLT9ZmE3lPoWsEzCh9LPo3TiwVN+ZKEjmz+h
|
||||||
github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8=
|
github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8=
|
||||||
github.com/inconshreveable/mousetrap v1.0.1 h1:U3uMjPSQEBMNp1lFxmllqCPM6P5u/Xq7Pgzkat/bFNc=
|
github.com/inconshreveable/mousetrap v1.0.1 h1:U3uMjPSQEBMNp1lFxmllqCPM6P5u/Xq7Pgzkat/bFNc=
|
||||||
github.com/inconshreveable/mousetrap v1.0.1/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw=
|
github.com/inconshreveable/mousetrap v1.0.1/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw=
|
||||||
|
github.com/inconshreveable/mousetrap v1.1.0 h1:wN+x4NVGpMsO7ErUn/mUI3vEoE6Jt13X2s0bqwp9tc8=
|
||||||
|
github.com/inconshreveable/mousetrap v1.1.0/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw=
|
||||||
github.com/influxdata/influxdb1-client v0.0.0-20191209144304-8bf82d3c094d/go.mod h1:qj24IKcXYK6Iy9ceXlo3Tc+vtHo9lIhSX5JddghvEPo=
|
github.com/influxdata/influxdb1-client v0.0.0-20191209144304-8bf82d3c094d/go.mod h1:qj24IKcXYK6Iy9ceXlo3Tc+vtHo9lIhSX5JddghvEPo=
|
||||||
github.com/jackc/chunkreader v1.0.0 h1:4s39bBR8ByfqH+DKm8rQA3E1LHZWB9XWcrz8fqaZbe0=
|
github.com/jackc/chunkreader v1.0.0 h1:4s39bBR8ByfqH+DKm8rQA3E1LHZWB9XWcrz8fqaZbe0=
|
||||||
github.com/jackc/chunkreader v1.0.0/go.mod h1:RT6O25fNZIuasFJRyZ4R/Y2BbhasbmZXF9QQ7T3kePo=
|
github.com/jackc/chunkreader v1.0.0/go.mod h1:RT6O25fNZIuasFJRyZ4R/Y2BbhasbmZXF9QQ7T3kePo=
|
||||||
|
@ -442,7 +465,11 @@ github.com/julienschmidt/httprouter v1.2.0/go.mod h1:SYymIcj16QtmaHHD7aYtjjsJG7V
|
||||||
github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51 h1:Z9n2FFNUXsshfwJMBgNA0RU6/i7WVaAegv3PtuIHPMs=
|
github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51 h1:Z9n2FFNUXsshfwJMBgNA0RU6/i7WVaAegv3PtuIHPMs=
|
||||||
github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51/go.mod h1:CzGEWj7cYgsdH8dAjBGEr58BoE7ScuLd+fwFZ44+/x8=
|
github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51/go.mod h1:CzGEWj7cYgsdH8dAjBGEr58BoE7ScuLd+fwFZ44+/x8=
|
||||||
github.com/kisielk/errcheck v1.1.0/go.mod h1:EZBBE59ingxPouuu3KfxchcWSUPOHkagtvWXihfKN4Q=
|
github.com/kisielk/errcheck v1.1.0/go.mod h1:EZBBE59ingxPouuu3KfxchcWSUPOHkagtvWXihfKN4Q=
|
||||||
|
github.com/kisielk/errcheck v1.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI2bnpBCr8=
|
||||||
github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck=
|
github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck=
|
||||||
|
github.com/klauspost/compress v1.13.6/go.mod h1:/3/Vjq9QcHkK5uEr5lBEmyoZ1iFhe47etQ6QUkpK6sk=
|
||||||
|
github.com/klauspost/compress v1.16.5 h1:IFV2oUNUzZaz+XyusxpLzpzS8Pt5rh0Z16For/djlyI=
|
||||||
|
github.com/klauspost/compress v1.16.5/go.mod h1:ntbaceVETuRiXiv4DpjP66DpAtAGkEQskQzEyD//IeE=
|
||||||
github.com/kolaente/caldav-go v3.0.1-0.20190524174923-9e5cd1688227+incompatible h1:PkEEpmbrFXlMul8cOplR8nkcIM/NDbx+H6fq2+vaKAA=
|
github.com/kolaente/caldav-go v3.0.1-0.20190524174923-9e5cd1688227+incompatible h1:PkEEpmbrFXlMul8cOplR8nkcIM/NDbx+H6fq2+vaKAA=
|
||||||
github.com/kolaente/caldav-go v3.0.1-0.20190524174923-9e5cd1688227+incompatible/go.mod h1:y1UhTNI4g0hVymJrI6yJ5/ohy09hNBeU8iJEZjgdDOw=
|
github.com/kolaente/caldav-go v3.0.1-0.20190524174923-9e5cd1688227+incompatible/go.mod h1:y1UhTNI4g0hVymJrI6yJ5/ohy09hNBeU8iJEZjgdDOw=
|
||||||
github.com/kolaente/caldav-go v3.0.1-0.20190610114120-2a4eb8b5dcc9+incompatible h1:q7DbyV+sFjEoTuuUdRDNl2nlyfztkZgxVVCV7JhzIkY=
|
github.com/kolaente/caldav-go v3.0.1-0.20190610114120-2a4eb8b5dcc9+incompatible h1:q7DbyV+sFjEoTuuUdRDNl2nlyfztkZgxVVCV7JhzIkY=
|
||||||
|
@ -476,6 +503,10 @@ github.com/lib/pq v1.7.0/go.mod h1:AlVN5x4E4T544tWzH6hKfbfQvm3HdbOxrmggDNAPY9o=
|
||||||
github.com/lib/pq v1.10.2/go.mod h1:AlVN5x4E4T544tWzH6hKfbfQvm3HdbOxrmggDNAPY9o=
|
github.com/lib/pq v1.10.2/go.mod h1:AlVN5x4E4T544tWzH6hKfbfQvm3HdbOxrmggDNAPY9o=
|
||||||
github.com/lib/pq v1.10.7 h1:p7ZhMD+KsSRozJr34udlUrhboJwWAgCg34+/ZZNvZZw=
|
github.com/lib/pq v1.10.7 h1:p7ZhMD+KsSRozJr34udlUrhboJwWAgCg34+/ZZNvZZw=
|
||||||
github.com/lib/pq v1.10.7/go.mod h1:AlVN5x4E4T544tWzH6hKfbfQvm3HdbOxrmggDNAPY9o=
|
github.com/lib/pq v1.10.7/go.mod h1:AlVN5x4E4T544tWzH6hKfbfQvm3HdbOxrmggDNAPY9o=
|
||||||
|
github.com/lib/pq v1.10.8 h1:3fdt97i/cwSU83+E0hZTC/Xpc9mTZxc6UWSCRcSbxiE=
|
||||||
|
github.com/lib/pq v1.10.8/go.mod h1:AlVN5x4E4T544tWzH6hKfbfQvm3HdbOxrmggDNAPY9o=
|
||||||
|
github.com/lib/pq v1.10.9 h1:YXG7RB+JIjhP29X+OtkiDnYaXQwpS4JEWq7dtCCRUEw=
|
||||||
|
github.com/lib/pq v1.10.9/go.mod h1:AlVN5x4E4T544tWzH6hKfbfQvm3HdbOxrmggDNAPY9o=
|
||||||
github.com/lightstep/lightstep-tracer-common/golang/gogo v0.0.0-20190605223551-bc2310a04743/go.mod h1:qklhhLq1aX+mtWk9cPHPzaBjWImj5ULL6C7HFJtXQMM=
|
github.com/lightstep/lightstep-tracer-common/golang/gogo v0.0.0-20190605223551-bc2310a04743/go.mod h1:qklhhLq1aX+mtWk9cPHPzaBjWImj5ULL6C7HFJtXQMM=
|
||||||
github.com/lightstep/lightstep-tracer-go v0.18.1/go.mod h1:jlF1pusYV4pidLvZ+XD0UBX0ZE6WURAspgAczcDHrL4=
|
github.com/lightstep/lightstep-tracer-go v0.18.1/go.mod h1:jlF1pusYV4pidLvZ+XD0UBX0ZE6WURAspgAczcDHrL4=
|
||||||
github.com/lithammer/shortuuid/v3 v3.0.7 h1:trX0KTHy4Pbwo/6ia8fscyHoGA+mf1jWbPJVuvyJQQ8=
|
github.com/lithammer/shortuuid/v3 v3.0.7 h1:trX0KTHy4Pbwo/6ia8fscyHoGA+mf1jWbPJVuvyJQQ8=
|
||||||
|
@ -540,6 +571,7 @@ github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742/go.mod h1:bx2lN
|
||||||
github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0=
|
github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0=
|
||||||
github.com/modern-go/reflect2 v1.0.2 h1:xBagoLtFs94CBntxluKeaWgTMpvLxC4ur3nMaC9Gz0M=
|
github.com/modern-go/reflect2 v1.0.2 h1:xBagoLtFs94CBntxluKeaWgTMpvLxC4ur3nMaC9Gz0M=
|
||||||
github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk=
|
github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk=
|
||||||
|
github.com/montanaflynn/stats v0.0.0-20171201202039-1bf9dbcd8cbe/go.mod h1:wL8QJuTMNUDYhXwkmfOly8iTdp5TEcJFWZD2D7SIkUc=
|
||||||
github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U=
|
github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U=
|
||||||
github.com/nats-io/jwt v0.3.0/go.mod h1:fRYCDE99xlTsqUzISS1Bi75UBJ6ljOJQOAAu5VglpSg=
|
github.com/nats-io/jwt v0.3.0/go.mod h1:fRYCDE99xlTsqUzISS1Bi75UBJ6ljOJQOAAu5VglpSg=
|
||||||
github.com/nats-io/jwt v0.3.2/go.mod h1:/euKqTS1ZD+zzjYrY7pseZrTtWQSjujC7xjPc8wL6eU=
|
github.com/nats-io/jwt v0.3.2/go.mod h1:/euKqTS1ZD+zzjYrY7pseZrTtWQSjujC7xjPc8wL6eU=
|
||||||
|
@ -581,12 +613,18 @@ github.com/openzipkin/zipkin-go v0.2.1/go.mod h1:NaW6tEwdmWMaCDZzg8sh+IBNOxHMPnh
|
||||||
github.com/openzipkin/zipkin-go v0.2.2/go.mod h1:NaW6tEwdmWMaCDZzg8sh+IBNOxHMPnhQw8ySjnjRyN4=
|
github.com/openzipkin/zipkin-go v0.2.2/go.mod h1:NaW6tEwdmWMaCDZzg8sh+IBNOxHMPnhQw8ySjnjRyN4=
|
||||||
github.com/pact-foundation/pact-go v1.0.4/go.mod h1:uExwJY4kCzNPcHRj+hCR/HBbOOIwwtUjcrb0b5/5kLM=
|
github.com/pact-foundation/pact-go v1.0.4/go.mod h1:uExwJY4kCzNPcHRj+hCR/HBbOOIwwtUjcrb0b5/5kLM=
|
||||||
github.com/pascaldekloe/goe v0.0.0-20180627143212-57f6aae5913c/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc=
|
github.com/pascaldekloe/goe v0.0.0-20180627143212-57f6aae5913c/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc=
|
||||||
|
github.com/paulmach/orb v0.9.0 h1:MwA1DqOKtvCgm7u9RZ/pnYejTeDJPnr0+0oFajBbJqk=
|
||||||
|
github.com/paulmach/orb v0.9.0/go.mod h1:SudmOk85SXtmXAB3sLGyJ6tZy/8pdfrV0o6ef98Xc30=
|
||||||
|
github.com/paulmach/protoscan v0.2.1/go.mod h1:SpcSwydNLrxUGSDvXvO0P7g7AuhJ7lcKfDlhJCDw2gY=
|
||||||
github.com/pborman/uuid v1.2.0/go.mod h1:X/NO0urCmaxf9VXbdlT7C2Yzkj2IKimNn4k+gtPdI/k=
|
github.com/pborman/uuid v1.2.0/go.mod h1:X/NO0urCmaxf9VXbdlT7C2Yzkj2IKimNn4k+gtPdI/k=
|
||||||
github.com/pelletier/go-toml/v2 v2.0.6 h1:nrzqCb7j9cDFj2coyLNLaZuJTLjWjlaz6nvTvIwycIU=
|
github.com/pelletier/go-toml/v2 v2.0.6 h1:nrzqCb7j9cDFj2coyLNLaZuJTLjWjlaz6nvTvIwycIU=
|
||||||
github.com/pelletier/go-toml/v2 v2.0.6/go.mod h1:eumQOmlWiOPt5WriQQqoM5y18pDHwha2N+QD+EUNTek=
|
github.com/pelletier/go-toml/v2 v2.0.6/go.mod h1:eumQOmlWiOPt5WriQQqoM5y18pDHwha2N+QD+EUNTek=
|
||||||
github.com/performancecopilot/speed v3.0.0+incompatible/go.mod h1:/CLtqpZ5gBg1M9iaPbIdPPGyKcA8hKdoy6hAWba7Yac=
|
github.com/performancecopilot/speed v3.0.0+incompatible/go.mod h1:/CLtqpZ5gBg1M9iaPbIdPPGyKcA8hKdoy6hAWba7Yac=
|
||||||
github.com/pierrec/lz4 v1.0.2-0.20190131084431-473cd7ce01a1/go.mod h1:3/3N9NVKO0jef7pBehbT1qWhCMrIgbYNnFAZCqQ5LRc=
|
github.com/pierrec/lz4 v1.0.2-0.20190131084431-473cd7ce01a1/go.mod h1:3/3N9NVKO0jef7pBehbT1qWhCMrIgbYNnFAZCqQ5LRc=
|
||||||
|
github.com/pierrec/lz4 v2.0.5+incompatible h1:2xWsjqPFWcplujydGg4WmhC/6fZqK42wMM8aXeqhl0I=
|
||||||
github.com/pierrec/lz4 v2.0.5+incompatible/go.mod h1:pdkljMzZIN41W+lC3N2tnIh5sFi+IEE17M5jbnwPHcY=
|
github.com/pierrec/lz4 v2.0.5+incompatible/go.mod h1:pdkljMzZIN41W+lC3N2tnIh5sFi+IEE17M5jbnwPHcY=
|
||||||
|
github.com/pierrec/lz4/v4 v4.1.17 h1:kV4Ip+/hUBC+8T6+2EgburRtkE9ef4nbY3f4dFhGjMc=
|
||||||
|
github.com/pierrec/lz4/v4 v4.1.17/go.mod h1:gZWDp/Ze/IJXGXf23ltt2EXimqmTUXEy0GFuRQyBid4=
|
||||||
github.com/pingcap/errors v0.11.4 h1:lFuQV/oaUMGcD2tqt+01ROSmJs75VG1ToEOkZIZ4nE4=
|
github.com/pingcap/errors v0.11.4 h1:lFuQV/oaUMGcD2tqt+01ROSmJs75VG1ToEOkZIZ4nE4=
|
||||||
github.com/pkg/errors v0.8.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
github.com/pkg/errors v0.8.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
||||||
github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
||||||
|
@ -605,6 +643,10 @@ github.com/prometheus/client_golang v1.0.0/go.mod h1:db9x61etRT2tGnBNRi70OPL5Fsn
|
||||||
github.com/prometheus/client_golang v1.3.0/go.mod h1:hJaj2vgQTGQmVCsAACORcieXFeDPbaTKGT+JTgUa3og=
|
github.com/prometheus/client_golang v1.3.0/go.mod h1:hJaj2vgQTGQmVCsAACORcieXFeDPbaTKGT+JTgUa3og=
|
||||||
github.com/prometheus/client_golang v1.14.0 h1:nJdhIvne2eSX/XRAFV9PcvFFRbrjbcTUj0VP62TMhnw=
|
github.com/prometheus/client_golang v1.14.0 h1:nJdhIvne2eSX/XRAFV9PcvFFRbrjbcTUj0VP62TMhnw=
|
||||||
github.com/prometheus/client_golang v1.14.0/go.mod h1:8vpkKitgIVNcqrRBWh1C4TIUQgYNtG/XQE4E/Zae36Y=
|
github.com/prometheus/client_golang v1.14.0/go.mod h1:8vpkKitgIVNcqrRBWh1C4TIUQgYNtG/XQE4E/Zae36Y=
|
||||||
|
github.com/prometheus/client_golang v1.15.0 h1:5fCgGYogn0hFdhyhLbw7hEsWxufKtY9klyvdNfFlFhM=
|
||||||
|
github.com/prometheus/client_golang v1.15.0/go.mod h1:e9yaBhRPU2pPNsZwE+JdQl0KEt1N9XgF6zxWmaC0xOk=
|
||||||
|
github.com/prometheus/client_golang v1.15.1 h1:8tXpTmJbyH5lydzFPoxSIJ0J46jdh3tylbvM1xCv0LI=
|
||||||
|
github.com/prometheus/client_golang v1.15.1/go.mod h1:e9yaBhRPU2pPNsZwE+JdQl0KEt1N9XgF6zxWmaC0xOk=
|
||||||
github.com/prometheus/client_model v0.0.0-20180712105110-5c3871d89910/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo=
|
github.com/prometheus/client_model v0.0.0-20180712105110-5c3871d89910/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo=
|
||||||
github.com/prometheus/client_model v0.0.0-20190115171406-56726106282f/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo=
|
github.com/prometheus/client_model v0.0.0-20190115171406-56726106282f/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo=
|
||||||
github.com/prometheus/client_model v0.0.0-20190129233127-fd36f4220a90/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA=
|
github.com/prometheus/client_model v0.0.0-20190129233127-fd36f4220a90/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA=
|
||||||
|
@ -617,6 +659,8 @@ github.com/prometheus/common v0.4.1/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y8
|
||||||
github.com/prometheus/common v0.7.0/go.mod h1:DjGbpBbp5NYNiECxcL/VnbXCCaQpKd3tt26CguLLsqA=
|
github.com/prometheus/common v0.7.0/go.mod h1:DjGbpBbp5NYNiECxcL/VnbXCCaQpKd3tt26CguLLsqA=
|
||||||
github.com/prometheus/common v0.39.0 h1:oOyhkDq05hPZKItWVBkJ6g6AtGxi+fy7F4JvUV8uhsI=
|
github.com/prometheus/common v0.39.0 h1:oOyhkDq05hPZKItWVBkJ6g6AtGxi+fy7F4JvUV8uhsI=
|
||||||
github.com/prometheus/common v0.39.0/go.mod h1:6XBZ7lYdLCbkAVhwRsWTZn+IN5AB9F/NXd5w0BbEX0Y=
|
github.com/prometheus/common v0.39.0/go.mod h1:6XBZ7lYdLCbkAVhwRsWTZn+IN5AB9F/NXd5w0BbEX0Y=
|
||||||
|
github.com/prometheus/common v0.42.0 h1:EKsfXEYo4JpWMHH5cg+KOUWeuJSov1Id8zGR8eeI1YM=
|
||||||
|
github.com/prometheus/common v0.42.0/go.mod h1:xBwqVerjNdUDjgODMpudtOMwlOwf2SaTr1yjz4b7Zbc=
|
||||||
github.com/prometheus/procfs v0.0.0-20181005140218-185b4288413d/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
|
github.com/prometheus/procfs v0.0.0-20181005140218-185b4288413d/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
|
||||||
github.com/prometheus/procfs v0.0.0-20190117184657-bf6a532e95b1/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
|
github.com/prometheus/procfs v0.0.0-20190117184657-bf6a532e95b1/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
|
||||||
github.com/prometheus/procfs v0.0.2/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsTZCD3I8kEA=
|
github.com/prometheus/procfs v0.0.2/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsTZCD3I8kEA=
|
||||||
|
@ -628,6 +672,8 @@ github.com/redis/go-redis/v9 v9.0.2 h1:BA426Zqe/7r56kCcvxYLWe1mkaz71LKF77GwgFzSx
|
||||||
github.com/redis/go-redis/v9 v9.0.2/go.mod h1:/xDTe9EF1LM61hek62Poq2nzQSGj0xSrEtEHbBQevps=
|
github.com/redis/go-redis/v9 v9.0.2/go.mod h1:/xDTe9EF1LM61hek62Poq2nzQSGj0xSrEtEHbBQevps=
|
||||||
github.com/redis/go-redis/v9 v9.0.3 h1:+7mmR26M0IvyLxGZUHxu4GiBkJkVDid0Un+j4ScYu4k=
|
github.com/redis/go-redis/v9 v9.0.3 h1:+7mmR26M0IvyLxGZUHxu4GiBkJkVDid0Un+j4ScYu4k=
|
||||||
github.com/redis/go-redis/v9 v9.0.3/go.mod h1:WqMKv5vnQbRuZstUwxQI195wHy+t4PuXDOjzMvcuQHk=
|
github.com/redis/go-redis/v9 v9.0.3/go.mod h1:WqMKv5vnQbRuZstUwxQI195wHy+t4PuXDOjzMvcuQHk=
|
||||||
|
github.com/redis/go-redis/v9 v9.0.4 h1:FC82T+CHJ/Q/PdyLW++GeCO+Ol59Y4T7R4jbgjvktgc=
|
||||||
|
github.com/redis/go-redis/v9 v9.0.4/go.mod h1:WqMKv5vnQbRuZstUwxQI195wHy+t4PuXDOjzMvcuQHk=
|
||||||
github.com/remyoudompheng/bigfft v0.0.0-20200410134404-eec4a21b6bb0 h1:OdAsTTz6OkFY5QxjkYwrChwuRruF69c169dPK26NUlk=
|
github.com/remyoudompheng/bigfft v0.0.0-20200410134404-eec4a21b6bb0 h1:OdAsTTz6OkFY5QxjkYwrChwuRruF69c169dPK26NUlk=
|
||||||
github.com/remyoudompheng/bigfft v0.0.0-20200410134404-eec4a21b6bb0/go.mod h1:qqbHyh8v60DhA7CoWK5oRCqLrMHRGoxYCSS9EjAz6Eo=
|
github.com/remyoudompheng/bigfft v0.0.0-20200410134404-eec4a21b6bb0/go.mod h1:qqbHyh8v60DhA7CoWK5oRCqLrMHRGoxYCSS9EjAz6Eo=
|
||||||
github.com/robfig/cron/v3 v3.0.1 h1:WdRxkvbJztn8LMz/QEvLN5sBU+xKpSqwwUO1Pjr4qDs=
|
github.com/robfig/cron/v3 v3.0.1 h1:WdRxkvbJztn8LMz/QEvLN5sBU+xKpSqwwUO1Pjr4qDs=
|
||||||
|
@ -645,10 +691,14 @@ github.com/ryanuber/columnize v0.0.0-20160712163229-9b3edd62028f/go.mod h1:sm1tb
|
||||||
github.com/samuel/go-zookeeper v0.0.0-20190923202752-2cc03de413da/go.mod h1:gi+0XIa01GRL2eRQVjQkKGqKF3SF9vZR/HnPullcV2E=
|
github.com/samuel/go-zookeeper v0.0.0-20190923202752-2cc03de413da/go.mod h1:gi+0XIa01GRL2eRQVjQkKGqKF3SF9vZR/HnPullcV2E=
|
||||||
github.com/satori/go.uuid v1.2.0/go.mod h1:dA0hQrYB0VpLJoorglMZABFdXlWrHn1NEOzdhQKdks0=
|
github.com/satori/go.uuid v1.2.0/go.mod h1:dA0hQrYB0VpLJoorglMZABFdXlWrHn1NEOzdhQKdks0=
|
||||||
github.com/sean-/seed v0.0.0-20170313163322-e2103e2c3529/go.mod h1:DxrIzT+xaE7yg65j358z/aeFdxmN0P9QXhEzd20vsDc=
|
github.com/sean-/seed v0.0.0-20170313163322-e2103e2c3529/go.mod h1:DxrIzT+xaE7yg65j358z/aeFdxmN0P9QXhEzd20vsDc=
|
||||||
|
github.com/segmentio/asm v1.2.0 h1:9BQrFxC+YOHJlTlHGkTrFWf59nbL3XnCoFLTwDCI7ys=
|
||||||
|
github.com/segmentio/asm v1.2.0/go.mod h1:BqMnlJP91P8d+4ibuonYZw9mfnzI9HfxselHZr5aAcs=
|
||||||
github.com/shopspring/decimal v0.0.0-20180709203117-cd690d0c9e24/go.mod h1:M+9NzErvs504Cn4c5DxATwIqPbtswREoFCre64PpcG4=
|
github.com/shopspring/decimal v0.0.0-20180709203117-cd690d0c9e24/go.mod h1:M+9NzErvs504Cn4c5DxATwIqPbtswREoFCre64PpcG4=
|
||||||
github.com/shopspring/decimal v0.0.0-20191009025716-f1972eb1d1f5/go.mod h1:M+9NzErvs504Cn4c5DxATwIqPbtswREoFCre64PpcG4=
|
github.com/shopspring/decimal v0.0.0-20191009025716-f1972eb1d1f5/go.mod h1:M+9NzErvs504Cn4c5DxATwIqPbtswREoFCre64PpcG4=
|
||||||
github.com/shopspring/decimal v0.0.0-20200227202807-02e2044944cc/go.mod h1:DKyhrW/HYNuLGql+MJL6WCR6knT2jwCFRcu2hWCYk4o=
|
github.com/shopspring/decimal v0.0.0-20200227202807-02e2044944cc/go.mod h1:DKyhrW/HYNuLGql+MJL6WCR6knT2jwCFRcu2hWCYk4o=
|
||||||
github.com/shopspring/decimal v1.2.0/go.mod h1:DKyhrW/HYNuLGql+MJL6WCR6knT2jwCFRcu2hWCYk4o=
|
github.com/shopspring/decimal v1.2.0/go.mod h1:DKyhrW/HYNuLGql+MJL6WCR6knT2jwCFRcu2hWCYk4o=
|
||||||
|
github.com/shopspring/decimal v1.3.1 h1:2Usl1nmF/WZucqkFZhnfFYxxxu8LG21F6nPQBE5gKV8=
|
||||||
|
github.com/shopspring/decimal v1.3.1/go.mod h1:DKyhrW/HYNuLGql+MJL6WCR6knT2jwCFRcu2hWCYk4o=
|
||||||
github.com/shurcooL/sanitized_anchor_name v1.0.0/go.mod h1:1NzhyTcUVG4SuEtjjoZeVRXNmyL/1OwPU0+IJeTBvfc=
|
github.com/shurcooL/sanitized_anchor_name v1.0.0/go.mod h1:1NzhyTcUVG4SuEtjjoZeVRXNmyL/1OwPU0+IJeTBvfc=
|
||||||
github.com/sirupsen/logrus v1.2.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo=
|
github.com/sirupsen/logrus v1.2.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo=
|
||||||
github.com/sirupsen/logrus v1.4.1/go.mod h1:ni0Sbl8bgC9z8RoU9G6nDWqqs/fq4eDPysMBDgk/93Q=
|
github.com/sirupsen/logrus v1.4.1/go.mod h1:ni0Sbl8bgC9z8RoU9G6nDWqqs/fq4eDPysMBDgk/93Q=
|
||||||
|
@ -666,6 +716,8 @@ github.com/spf13/cast v1.5.0/go.mod h1:SpXXQ5YoyJw6s3/6cMTQuxvgRl3PCJiyaX9p6b155
|
||||||
github.com/spf13/cobra v0.0.3/go.mod h1:1l0Ry5zgKvJasoi3XT1TypsSe7PqH0Sj9dhYf7v3XqQ=
|
github.com/spf13/cobra v0.0.3/go.mod h1:1l0Ry5zgKvJasoi3XT1TypsSe7PqH0Sj9dhYf7v3XqQ=
|
||||||
github.com/spf13/cobra v1.6.1 h1:o94oiPyS4KD1mPy2fmcYYHHfCxLqYjJOhGsCHFZtEzA=
|
github.com/spf13/cobra v1.6.1 h1:o94oiPyS4KD1mPy2fmcYYHHfCxLqYjJOhGsCHFZtEzA=
|
||||||
github.com/spf13/cobra v1.6.1/go.mod h1:IOw/AERYS7UzyrGinqmz6HLUo219MORXGxhbaJUqzrY=
|
github.com/spf13/cobra v1.6.1/go.mod h1:IOw/AERYS7UzyrGinqmz6HLUo219MORXGxhbaJUqzrY=
|
||||||
|
github.com/spf13/cobra v1.7.0 h1:hyqWnYt1ZQShIddO5kBpj3vu05/++x6tJ6dg8EC572I=
|
||||||
|
github.com/spf13/cobra v1.7.0/go.mod h1:uLxZILRyS/50WlhOIKD7W6V5bgeIt+4sICxh6uRMrb0=
|
||||||
github.com/spf13/jwalterweatherman v1.1.0 h1:ue6voC5bR5F8YxI5S67j9i582FU4Qvo2bmqnqMYADFk=
|
github.com/spf13/jwalterweatherman v1.1.0 h1:ue6voC5bR5F8YxI5S67j9i582FU4Qvo2bmqnqMYADFk=
|
||||||
github.com/spf13/jwalterweatherman v1.1.0/go.mod h1:aNWZUN0dPAAO/Ljvb5BEdw96iTZ0EXowPYD95IqWIGo=
|
github.com/spf13/jwalterweatherman v1.1.0/go.mod h1:aNWZUN0dPAAO/Ljvb5BEdw96iTZ0EXowPYD95IqWIGo=
|
||||||
github.com/spf13/pflag v1.0.1/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4=
|
github.com/spf13/pflag v1.0.1/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4=
|
||||||
|
@ -702,6 +754,7 @@ github.com/swaggo/swag v1.8.12 h1:pctzkNPu0AlQP2royqX3apjKCQonAnf7KGoxeO4y64w=
|
||||||
github.com/swaggo/swag v1.8.12/go.mod h1:lNfm6Gg+oAq3zRJQNEMBE66LIJKM44mxFqhEEgy2its=
|
github.com/swaggo/swag v1.8.12/go.mod h1:lNfm6Gg+oAq3zRJQNEMBE66LIJKM44mxFqhEEgy2its=
|
||||||
github.com/syndtr/goleveldb v1.0.0 h1:fBdIW9lB4Iz0n9khmH8w27SJ3QEJ7+IgjPEwGSZiFdE=
|
github.com/syndtr/goleveldb v1.0.0 h1:fBdIW9lB4Iz0n9khmH8w27SJ3QEJ7+IgjPEwGSZiFdE=
|
||||||
github.com/syndtr/goleveldb v1.0.0/go.mod h1:ZVVdQEZoIme9iO1Ch2Jdy24qqXrMMOU6lpPAyBWyWuQ=
|
github.com/syndtr/goleveldb v1.0.0/go.mod h1:ZVVdQEZoIme9iO1Ch2Jdy24qqXrMMOU6lpPAyBWyWuQ=
|
||||||
|
github.com/tidwall/pretty v1.0.0/go.mod h1:XNkn88O1ChpSDQmQeStsy+sBenx6DDtFZJxhVysOjyk=
|
||||||
github.com/tkuchiki/go-timezone v0.2.2 h1:MdHR65KwgVTwWFQrota4SKzc4L5EfuH5SdZZGtk/P2Q=
|
github.com/tkuchiki/go-timezone v0.2.2 h1:MdHR65KwgVTwWFQrota4SKzc4L5EfuH5SdZZGtk/P2Q=
|
||||||
github.com/tkuchiki/go-timezone v0.2.2/go.mod h1:oFweWxYl35C/s7HMVZXiA19Jr9Y0qJHMaG/J2TES4LY=
|
github.com/tkuchiki/go-timezone v0.2.2/go.mod h1:oFweWxYl35C/s7HMVZXiA19Jr9Y0qJHMaG/J2TES4LY=
|
||||||
github.com/tmc/grpc-websocket-proxy v0.0.0-20170815181823-89b8d40f7ca8/go.mod h1:ncp9v5uamzpCO7NfCPTXjqaC+bZgJeR0sMTm6dMHP7U=
|
github.com/tmc/grpc-websocket-proxy v0.0.0-20170815181823-89b8d40f7ca8/go.mod h1:ncp9v5uamzpCO7NfCPTXjqaC+bZgJeR0sMTm6dMHP7U=
|
||||||
|
@ -729,7 +782,11 @@ github.com/wneessen/go-mail v0.3.8 h1:ja5D/o/RVwrtRIYFlrO7GmtcjDNeMakGQuwQRZYv0J
|
||||||
github.com/wneessen/go-mail v0.3.8/go.mod h1:m25lkU2GYQnlVr6tdwK533/UXxo57V0kLOjaFYmub0E=
|
github.com/wneessen/go-mail v0.3.8/go.mod h1:m25lkU2GYQnlVr6tdwK533/UXxo57V0kLOjaFYmub0E=
|
||||||
github.com/wneessen/go-mail v0.3.9 h1:Q4DbCk3htT5DtDWKeMgNXCiHc4bBY/vv/XQPT6XDXzc=
|
github.com/wneessen/go-mail v0.3.9 h1:Q4DbCk3htT5DtDWKeMgNXCiHc4bBY/vv/XQPT6XDXzc=
|
||||||
github.com/wneessen/go-mail v0.3.9/go.mod h1:zxOlafWCP/r6FEhAaRgH4IC1vg2YXxO0Nar9u0IScZ8=
|
github.com/wneessen/go-mail v0.3.9/go.mod h1:zxOlafWCP/r6FEhAaRgH4IC1vg2YXxO0Nar9u0IScZ8=
|
||||||
|
github.com/xdg-go/pbkdf2 v1.0.0/go.mod h1:jrpuAogTd400dnrH08LKmI/xc1MbPOebTwRqcT5RDeI=
|
||||||
|
github.com/xdg-go/scram v1.1.1/go.mod h1:RaEWvsqvNKKvBPvcKeFjrG2cJqOkHTiyTpzz23ni57g=
|
||||||
|
github.com/xdg-go/stringprep v1.0.3/go.mod h1:W3f5j4i+9rC0kuIEJL0ky1VpHXQU3ocBgklLGvcBnW8=
|
||||||
github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2/go.mod h1:UETIi67q53MR2AWcXfiuqkDkRtnGDLqkBTpCHuJHxtU=
|
github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2/go.mod h1:UETIi67q53MR2AWcXfiuqkDkRtnGDLqkBTpCHuJHxtU=
|
||||||
|
github.com/youmark/pkcs8 v0.0.0-20181117223130-1be2e3e5546d/go.mod h1:rHwXgn7JulP+udvsHwJoVG1YGAP6VLg4y9I5dyZdqmA=
|
||||||
github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
||||||
github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
||||||
github.com/yuin/goldmark v1.1.32/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
github.com/yuin/goldmark v1.1.32/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
||||||
|
@ -741,6 +798,7 @@ github.com/zenazn/goji v0.9.0/go.mod h1:7S9M489iMyHBNxwZnk9/EHS098H4/F6TATF2mIxt
|
||||||
github.com/ziutek/mymysql v1.5.4/go.mod h1:LMSpPZ6DbqWFxNCHW77HeMg9I646SAhApZ/wKdgO/C0=
|
github.com/ziutek/mymysql v1.5.4/go.mod h1:LMSpPZ6DbqWFxNCHW77HeMg9I646SAhApZ/wKdgO/C0=
|
||||||
go.etcd.io/bbolt v1.3.3/go.mod h1:IbVyRI1SCnLcuJnV2u8VeU0CEYM7e686BmAb1XKL+uU=
|
go.etcd.io/bbolt v1.3.3/go.mod h1:IbVyRI1SCnLcuJnV2u8VeU0CEYM7e686BmAb1XKL+uU=
|
||||||
go.etcd.io/etcd v0.0.0-20191023171146-3cf2f69b5738/go.mod h1:dnLIgRNXwCJa5e+c6mIZCrds/GIG4ncV9HhK5PX7jPg=
|
go.etcd.io/etcd v0.0.0-20191023171146-3cf2f69b5738/go.mod h1:dnLIgRNXwCJa5e+c6mIZCrds/GIG4ncV9HhK5PX7jPg=
|
||||||
|
go.mongodb.org/mongo-driver v1.11.1/go.mod h1:s7p5vEtfbeR1gYi6pnj3c3/urpbLv2T5Sfd6Rp2HBB8=
|
||||||
go.opencensus.io v0.20.1/go.mod h1:6WKK9ahsWS3RSO+PY9ZHZUfv2irvY6gN279GOPZjmmk=
|
go.opencensus.io v0.20.1/go.mod h1:6WKK9ahsWS3RSO+PY9ZHZUfv2irvY6gN279GOPZjmmk=
|
||||||
go.opencensus.io v0.20.2/go.mod h1:6WKK9ahsWS3RSO+PY9ZHZUfv2irvY6gN279GOPZjmmk=
|
go.opencensus.io v0.20.2/go.mod h1:6WKK9ahsWS3RSO+PY9ZHZUfv2irvY6gN279GOPZjmmk=
|
||||||
go.opencensus.io v0.21.0/go.mod h1:mSImk1erAIZhrmZN+AvHh14ztQfjbGwt4TtuofqLduU=
|
go.opencensus.io v0.21.0/go.mod h1:mSImk1erAIZhrmZN+AvHh14ztQfjbGwt4TtuofqLduU=
|
||||||
|
@ -749,6 +807,10 @@ go.opencensus.io v0.22.2/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw=
|
||||||
go.opencensus.io v0.22.3/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw=
|
go.opencensus.io v0.22.3/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw=
|
||||||
go.opencensus.io v0.22.4/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw=
|
go.opencensus.io v0.22.4/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw=
|
||||||
go.opencensus.io v0.22.5/go.mod h1:5pWMHQbX5EPX2/62yrJeAkowc+lfs/XD7Uxpq3pI6kk=
|
go.opencensus.io v0.22.5/go.mod h1:5pWMHQbX5EPX2/62yrJeAkowc+lfs/XD7Uxpq3pI6kk=
|
||||||
|
go.opentelemetry.io/otel v1.15.0 h1:NIl24d4eiLJPM0vKn4HjLYM+UZf6gSfi9Z+NmCxkWbk=
|
||||||
|
go.opentelemetry.io/otel v1.15.0/go.mod h1:qfwLEbWhLPk5gyWrne4XnF0lC8wtywbuJbgfAE3zbek=
|
||||||
|
go.opentelemetry.io/otel/trace v1.15.0 h1:5Fwje4O2ooOxkfyqI/kJwxWotggDLix4BSAvpE1wlpo=
|
||||||
|
go.opentelemetry.io/otel/trace v1.15.0/go.mod h1:CUsmE2Ht1CRkvE8OsMESvraoZrrcgD1J2W8GV1ev0Y4=
|
||||||
go.uber.org/atomic v1.3.2/go.mod h1:gD2HeocX3+yG+ygLZcrzQJaqmWj9AIm7n08wl/qW/PE=
|
go.uber.org/atomic v1.3.2/go.mod h1:gD2HeocX3+yG+ygLZcrzQJaqmWj9AIm7n08wl/qW/PE=
|
||||||
go.uber.org/atomic v1.4.0/go.mod h1:gD2HeocX3+yG+ygLZcrzQJaqmWj9AIm7n08wl/qW/PE=
|
go.uber.org/atomic v1.4.0/go.mod h1:gD2HeocX3+yG+ygLZcrzQJaqmWj9AIm7n08wl/qW/PE=
|
||||||
go.uber.org/atomic v1.5.0/go.mod h1:sABNBOSYdrvTF6hTgEIbc7YasKWGhgEQZyfxyTvoXHQ=
|
go.uber.org/atomic v1.5.0/go.mod h1:sABNBOSYdrvTF6hTgEIbc7YasKWGhgEQZyfxyTvoXHQ=
|
||||||
|
@ -781,9 +843,12 @@ golang.org/x/crypto v0.0.0-20210421170649-83a5a9bb288b/go.mod h1:T9bdIzuCu7OtxOm
|
||||||
golang.org/x/crypto v0.0.0-20210616213533-5ff15b29337e/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc=
|
golang.org/x/crypto v0.0.0-20210616213533-5ff15b29337e/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc=
|
||||||
golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc=
|
golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc=
|
||||||
golang.org/x/crypto v0.0.0-20211108221036-ceb1ce70b4fa/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc=
|
golang.org/x/crypto v0.0.0-20211108221036-ceb1ce70b4fa/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc=
|
||||||
|
golang.org/x/crypto v0.0.0-20220622213112-05595931fe9d/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4=
|
||||||
golang.org/x/crypto v0.0.0-20220722155217-630584e8d5aa/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4=
|
golang.org/x/crypto v0.0.0-20220722155217-630584e8d5aa/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4=
|
||||||
golang.org/x/crypto v0.7.0 h1:AvwMYaRytfdeVt3u6mLaxYtErKYjxA2OXjJ1HHq6t3A=
|
golang.org/x/crypto v0.7.0 h1:AvwMYaRytfdeVt3u6mLaxYtErKYjxA2OXjJ1HHq6t3A=
|
||||||
golang.org/x/crypto v0.7.0/go.mod h1:pYwdfH91IfpZVANVyUOhSIPZaFoJGxTFbZhFTx+dXZU=
|
golang.org/x/crypto v0.7.0/go.mod h1:pYwdfH91IfpZVANVyUOhSIPZaFoJGxTFbZhFTx+dXZU=
|
||||||
|
golang.org/x/crypto v0.8.0 h1:pd9TJtTueMTVQXzk8E2XESSMQDj/U7OUu0PqJqPXQjQ=
|
||||||
|
golang.org/x/crypto v0.8.0/go.mod h1:mRqEX+O9/h5TFCrQhkgjo2yKi0yYA+9ecGkdQoHrywE=
|
||||||
golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA=
|
golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA=
|
||||||
golang.org/x/exp v0.0.0-20190306152737-a1d7652674e8/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA=
|
golang.org/x/exp v0.0.0-20190306152737-a1d7652674e8/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA=
|
||||||
golang.org/x/exp v0.0.0-20190510132918-efd6b22b2522/go.mod h1:ZjyILWgesfNpC6sMxTJOJm9Kp84zZh5NQWvqDGG3Qr8=
|
golang.org/x/exp v0.0.0-20190510132918-efd6b22b2522/go.mod h1:ZjyILWgesfNpC6sMxTJOJm9Kp84zZh5NQWvqDGG3Qr8=
|
||||||
|
@ -799,6 +864,8 @@ golang.org/x/image v0.0.0-20190802002840-cff245a6509b/go.mod h1:FeLwcggjj3mMvU+o
|
||||||
golang.org/x/image v0.0.0-20191009234506-e7c1f5e7dbb8/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0=
|
golang.org/x/image v0.0.0-20191009234506-e7c1f5e7dbb8/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0=
|
||||||
golang.org/x/image v0.6.0 h1:bR8b5okrPI3g/gyZakLZHeWxAR8Dn5CyxXv1hLH5g/4=
|
golang.org/x/image v0.6.0 h1:bR8b5okrPI3g/gyZakLZHeWxAR8Dn5CyxXv1hLH5g/4=
|
||||||
golang.org/x/image v0.6.0/go.mod h1:MXLdDR43H7cDJq5GEGXEVeeNhPgi+YYEQ2pC1byI1x0=
|
golang.org/x/image v0.6.0/go.mod h1:MXLdDR43H7cDJq5GEGXEVeeNhPgi+YYEQ2pC1byI1x0=
|
||||||
|
golang.org/x/image v0.7.0 h1:gzS29xtG1J5ybQlv0PuyfE3nmc6R4qB73m6LUUmvFuw=
|
||||||
|
golang.org/x/image v0.7.0/go.mod h1:nd/q4ef1AKKYl/4kft7g+6UyGbdiqWqTP1ZAbRoV7Rg=
|
||||||
golang.org/x/lint v0.0.0-20181026193005-c67002cb31c3/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE=
|
golang.org/x/lint v0.0.0-20181026193005-c67002cb31c3/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE=
|
||||||
golang.org/x/lint v0.0.0-20190227174305-5b3e6a55c961/go.mod h1:wehouNa3lNwaWXcvxsM5YxQ5yQlVC4a0KAMCusXpPoU=
|
golang.org/x/lint v0.0.0-20190227174305-5b3e6a55c961/go.mod h1:wehouNa3lNwaWXcvxsM5YxQ5yQlVC4a0KAMCusXpPoU=
|
||||||
golang.org/x/lint v0.0.0-20190301231843-5614ed5bae6f/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE=
|
golang.org/x/lint v0.0.0-20190301231843-5614ed5bae6f/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE=
|
||||||
|
@ -876,6 +943,8 @@ golang.org/x/net v0.4.0/go.mod h1:MBQ8lrhLObU/6UmLb4fmbmk5OcyYmqtbGd/9yIeKjEE=
|
||||||
golang.org/x/net v0.6.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs=
|
golang.org/x/net v0.6.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs=
|
||||||
golang.org/x/net v0.8.0 h1:Zrh2ngAOFYneWTAIAPethzeaQLuHwhuBkuV6ZiRnUaQ=
|
golang.org/x/net v0.8.0 h1:Zrh2ngAOFYneWTAIAPethzeaQLuHwhuBkuV6ZiRnUaQ=
|
||||||
golang.org/x/net v0.8.0/go.mod h1:QVkue5JL9kW//ek3r6jTKnTFis1tRmNAW2P1shuFdJc=
|
golang.org/x/net v0.8.0/go.mod h1:QVkue5JL9kW//ek3r6jTKnTFis1tRmNAW2P1shuFdJc=
|
||||||
|
golang.org/x/net v0.9.0 h1:aWJ/m6xSmxWBx+V0XRHTlrYrPG56jKsLdTFmsSsCzOM=
|
||||||
|
golang.org/x/net v0.9.0/go.mod h1:d48xBJpPfHeWQsugry2m+kC02ZBRGRgulfHnEXEuWns=
|
||||||
golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U=
|
golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U=
|
||||||
golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
|
golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
|
||||||
golang.org/x/oauth2 v0.0.0-20190604053449-0f29369cfe45/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
|
golang.org/x/oauth2 v0.0.0-20190604053449-0f29369cfe45/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
|
||||||
|
@ -888,6 +957,8 @@ golang.org/x/oauth2 v0.0.0-20210218202405-ba52d332ba99/go.mod h1:KelEdhl1UZF7XfJ
|
||||||
golang.org/x/oauth2 v0.3.0/go.mod h1:rQrIauxkUhJ6CuwEXwymO2/eh4xz2ZWF1nBkcxS+tGk=
|
golang.org/x/oauth2 v0.3.0/go.mod h1:rQrIauxkUhJ6CuwEXwymO2/eh4xz2ZWF1nBkcxS+tGk=
|
||||||
golang.org/x/oauth2 v0.6.0 h1:Lh8GPgSKBfWSwFvtuWOfeI3aAAnbXTSutYxJiOJFgIw=
|
golang.org/x/oauth2 v0.6.0 h1:Lh8GPgSKBfWSwFvtuWOfeI3aAAnbXTSutYxJiOJFgIw=
|
||||||
golang.org/x/oauth2 v0.6.0/go.mod h1:ycmewcwgD4Rpr3eZJLSB4Kyyljb3qDh40vJ8STE5HKw=
|
golang.org/x/oauth2 v0.6.0/go.mod h1:ycmewcwgD4Rpr3eZJLSB4Kyyljb3qDh40vJ8STE5HKw=
|
||||||
|
golang.org/x/oauth2 v0.7.0 h1:qe6s0zUXlPX80/dITx3440hWZ7GwMwgDDyrSGTPJG/g=
|
||||||
|
golang.org/x/oauth2 v0.7.0/go.mod h1:hPLQkd9LyjfXTiRohC/41GhcFqxisoUQ99sCUOHO9x4=
|
||||||
golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sync v0.0.0-20181221193216-37e7f081c4d4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20181221193216-37e7f081c4d4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
|
@ -898,9 +969,12 @@ golang.org/x/sync v0.0.0-20200317015054-43a5402ce75a/go.mod h1:RxMgew5VJxzue5/jJ
|
||||||
golang.org/x/sync v0.0.0-20200625203802-6e8e738ad208/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20200625203802-6e8e738ad208/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sync v0.0.0-20201207232520-09787c993a3a/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20201207232520-09787c993a3a/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
|
golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sync v0.1.0 h1:wsuoTGHzEhffawBOhz5CYhcrV4IdKZbEyZjBMuTp12o=
|
golang.org/x/sync v0.1.0 h1:wsuoTGHzEhffawBOhz5CYhcrV4IdKZbEyZjBMuTp12o=
|
||||||
golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
|
golang.org/x/sync v0.2.0 h1:PUR+T4wwASmuSTYdKjYHI5TD22Wy5ogLU5qZCOLxBrI=
|
||||||
|
golang.org/x/sync v0.2.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sys v0.0.0-20180823144017-11551d06cbcc/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
golang.org/x/sys v0.0.0-20180823144017-11551d06cbcc/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
||||||
golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
||||||
golang.org/x/sys v0.0.0-20180905080454-ebe1bf3edb33/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
golang.org/x/sys v0.0.0-20180905080454-ebe1bf3edb33/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
||||||
|
@ -971,6 +1045,10 @@ golang.org/x/sys v0.3.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
golang.org/x/sys v0.6.0 h1:MVltZSvRTcU2ljQOhs94SXPftV6DCNnZViHeQps87pQ=
|
golang.org/x/sys v0.6.0 h1:MVltZSvRTcU2ljQOhs94SXPftV6DCNnZViHeQps87pQ=
|
||||||
golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
|
golang.org/x/sys v0.7.0 h1:3jlCCIQZPdOYu1h8BkNvLz8Kgwtae2cagcG/VamtZRU=
|
||||||
|
golang.org/x/sys v0.7.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
|
golang.org/x/sys v0.8.0 h1:EBmGv8NaZBZTWvrbjNoL6HVt+IVy3QDQpJs7VRIw3tU=
|
||||||
|
golang.org/x/sys v0.8.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
golang.org/x/term v0.0.0-20201117132131-f5c789dd3221/go.mod h1:Nr5EML6q2oocZ2LXRh80K7BxOlk5/8JxuGnuhpl+muw=
|
golang.org/x/term v0.0.0-20201117132131-f5c789dd3221/go.mod h1:Nr5EML6q2oocZ2LXRh80K7BxOlk5/8JxuGnuhpl+muw=
|
||||||
golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo=
|
golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo=
|
||||||
golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8=
|
golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8=
|
||||||
|
@ -978,6 +1056,10 @@ golang.org/x/term v0.3.0/go.mod h1:q750SLmJuPmVoN1blW3UFBPREJfb1KmY3vwxfr+nFDA=
|
||||||
golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k=
|
golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k=
|
||||||
golang.org/x/term v0.6.0 h1:clScbb1cHjoCkyRbWwBEUZ5H/tIFu5TAXIqaZD0Gcjw=
|
golang.org/x/term v0.6.0 h1:clScbb1cHjoCkyRbWwBEUZ5H/tIFu5TAXIqaZD0Gcjw=
|
||||||
golang.org/x/term v0.6.0/go.mod h1:m6U89DPEgQRMq3DNkDClhWw02AUbt2daBVO4cn4Hv9U=
|
golang.org/x/term v0.6.0/go.mod h1:m6U89DPEgQRMq3DNkDClhWw02AUbt2daBVO4cn4Hv9U=
|
||||||
|
golang.org/x/term v0.7.0 h1:BEvjmm5fURWqcfbSKTdpkDXYBrUS1c0m8agp14W48vQ=
|
||||||
|
golang.org/x/term v0.7.0/go.mod h1:P32HKFT3hSsZrRxla30E9HqToFYAQPCMs/zFMBUFqPY=
|
||||||
|
golang.org/x/term v0.8.0 h1:n5xxQn2i3PC0yLAbjTpNT85q/Kgzcr2gIoX9OrJUols=
|
||||||
|
golang.org/x/term v0.8.0/go.mod h1:xPskH00ivmX89bAKVGSKKtLOWNx2+17Eiy94tnKShWo=
|
||||||
golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
||||||
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
||||||
golang.org/x/text v0.3.1-0.20180807135948-17ff2d5776d2/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
golang.org/x/text v0.3.1-0.20180807135948-17ff2d5776d2/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
||||||
|
@ -990,6 +1072,8 @@ golang.org/x/text v0.5.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8=
|
||||||
golang.org/x/text v0.7.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8=
|
golang.org/x/text v0.7.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8=
|
||||||
golang.org/x/text v0.8.0 h1:57P1ETyNKtuIjB4SRd15iJxuhj8Gc416Y78H3qgMh68=
|
golang.org/x/text v0.8.0 h1:57P1ETyNKtuIjB4SRd15iJxuhj8Gc416Y78H3qgMh68=
|
||||||
golang.org/x/text v0.8.0/go.mod h1:e1OnstbJyHTd6l/uOt8jFFHp6TRDWZR/bV3emEE/zU8=
|
golang.org/x/text v0.8.0/go.mod h1:e1OnstbJyHTd6l/uOt8jFFHp6TRDWZR/bV3emEE/zU8=
|
||||||
|
golang.org/x/text v0.9.0 h1:2sjJmO8cDvYveuX97RDLsxlyUxLl+GHoLxBiRdHllBE=
|
||||||
|
golang.org/x/text v0.9.0/go.mod h1:e1OnstbJyHTd6l/uOt8jFFHp6TRDWZR/bV3emEE/zU8=
|
||||||
golang.org/x/time v0.0.0-20180412165947-fbb02b2291d2/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
|
golang.org/x/time v0.0.0-20180412165947-fbb02b2291d2/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
|
||||||
golang.org/x/time v0.0.0-20181108054448-85acf8d2951c/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
|
golang.org/x/time v0.0.0-20181108054448-85acf8d2951c/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
|
||||||
golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
|
golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
|
||||||
|
@ -1043,6 +1127,7 @@ golang.org/x/tools v0.0.0-20200501065659-ab2804fb9c9d/go.mod h1:EkVYQZoAsY45+roY
|
||||||
golang.org/x/tools v0.0.0-20200512131952-2bc93b1c0c88/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
golang.org/x/tools v0.0.0-20200512131952-2bc93b1c0c88/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
||||||
golang.org/x/tools v0.0.0-20200515010526-7d3b6ebf133d/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
golang.org/x/tools v0.0.0-20200515010526-7d3b6ebf133d/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
||||||
golang.org/x/tools v0.0.0-20200618134242-20370b0cb4b2/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
golang.org/x/tools v0.0.0-20200618134242-20370b0cb4b2/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
||||||
|
golang.org/x/tools v0.0.0-20200619180055-7c47624df98f/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
||||||
golang.org/x/tools v0.0.0-20200729194436-6467de6f59a7/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA=
|
golang.org/x/tools v0.0.0-20200729194436-6467de6f59a7/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA=
|
||||||
golang.org/x/tools v0.0.0-20200804011535-6c149bb5ef0d/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA=
|
golang.org/x/tools v0.0.0-20200804011535-6c149bb5ef0d/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA=
|
||||||
golang.org/x/tools v0.0.0-20200825202427-b303f430e36d/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA=
|
golang.org/x/tools v0.0.0-20200825202427-b303f430e36d/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA=
|
||||||
|
@ -1053,6 +1138,7 @@ golang.org/x/tools v0.0.0-20201201161351-ac6f37ff4c2a/go.mod h1:emZCQorbCU4vsT4f
|
||||||
golang.org/x/tools v0.0.0-20201208233053-a543418bbed2/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
|
golang.org/x/tools v0.0.0-20201208233053-a543418bbed2/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
|
||||||
golang.org/x/tools v0.0.0-20201224043029-2b0845dc783e/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
|
golang.org/x/tools v0.0.0-20201224043029-2b0845dc783e/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
|
||||||
golang.org/x/tools v0.0.0-20210105154028-b0ab187a4818/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
|
golang.org/x/tools v0.0.0-20210105154028-b0ab187a4818/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
|
||||||
|
golang.org/x/tools v0.0.0-20210106214847-113979e3529a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
|
||||||
golang.org/x/tools v0.0.0-20210108195828-e2f9c7f1fc8e/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
|
golang.org/x/tools v0.0.0-20210108195828-e2f9c7f1fc8e/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
|
||||||
golang.org/x/tools v0.1.0/go.mod h1:xkSsbof2nBLbhDlRMhhhyNLN/zl3eTqcnHD5viDpcZ0=
|
golang.org/x/tools v0.1.0/go.mod h1:xkSsbof2nBLbhDlRMhhhyNLN/zl3eTqcnHD5viDpcZ0=
|
||||||
golang.org/x/tools v0.1.12/go.mod h1:hNGJHUnrk76NpqgfD5Aqm5Crs+Hm0VOH/i9J2+nxYbc=
|
golang.org/x/tools v0.1.12/go.mod h1:hNGJHUnrk76NpqgfD5Aqm5Crs+Hm0VOH/i9J2+nxYbc=
|
||||||
|
@ -1167,11 +1253,14 @@ google.golang.org/protobuf v1.24.0/go.mod h1:r/3tXBNzIEhYS9I1OUVjXDlt8tc493IdKGj
|
||||||
google.golang.org/protobuf v1.25.0/go.mod h1:9JNX74DMeImyA3h4bdi1ymwjUzf21/xIlbajtzgsN7c=
|
google.golang.org/protobuf v1.25.0/go.mod h1:9JNX74DMeImyA3h4bdi1ymwjUzf21/xIlbajtzgsN7c=
|
||||||
google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw=
|
google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw=
|
||||||
google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc=
|
google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc=
|
||||||
|
google.golang.org/protobuf v1.27.1/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc=
|
||||||
google.golang.org/protobuf v1.28.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
|
google.golang.org/protobuf v1.28.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
|
||||||
google.golang.org/protobuf v1.28.1 h1:d0NfwRgPtno5B1Wa6L2DAG+KivqkdutMf1UhdNx175w=
|
google.golang.org/protobuf v1.28.1 h1:d0NfwRgPtno5B1Wa6L2DAG+KivqkdutMf1UhdNx175w=
|
||||||
google.golang.org/protobuf v1.28.1/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
|
google.golang.org/protobuf v1.28.1/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
|
||||||
google.golang.org/protobuf v1.29.1 h1:7QBf+IK2gx70Ap/hDsOmam3GE0v9HicjfEdAxE62UoM=
|
google.golang.org/protobuf v1.29.1 h1:7QBf+IK2gx70Ap/hDsOmam3GE0v9HicjfEdAxE62UoM=
|
||||||
google.golang.org/protobuf v1.29.1/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
|
google.golang.org/protobuf v1.29.1/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
|
||||||
|
google.golang.org/protobuf v1.30.0 h1:kPPoIgf3TsEvrm0PFe15JQ+570QVxYzEvvHqChK+cng=
|
||||||
|
google.golang.org/protobuf v1.30.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
|
||||||
gopkg.in/alecthomas/kingpin.v2 v2.2.6/go.mod h1:FMv+mEhP44yOT+4EoQTLFTRgOQ1FBLkstjWtayDeSgw=
|
gopkg.in/alecthomas/kingpin.v2 v2.2.6/go.mod h1:FMv+mEhP44yOT+4EoQTLFTRgOQ1FBLkstjWtayDeSgw=
|
||||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||||
gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||||
|
@ -1332,6 +1421,12 @@ src.techknowlogick.com/xgo v1.7.1-0.20230214195350-44f7e66f9b20 h1:Wye8Ljlv2AZvY
|
||||||
src.techknowlogick.com/xgo v1.7.1-0.20230214195350-44f7e66f9b20/go.mod h1:31CE1YKtDOrKTk9PSnjTpe6YbO6W/0LTYZ1VskL09oU=
|
src.techknowlogick.com/xgo v1.7.1-0.20230214195350-44f7e66f9b20/go.mod h1:31CE1YKtDOrKTk9PSnjTpe6YbO6W/0LTYZ1VskL09oU=
|
||||||
src.techknowlogick.com/xgo v1.7.1-0.20230307171022-b60708668fc7 h1:nPPnMdR4wih62PSsnHK/SlYM1lOZk/St0k7DkJadMV4=
|
src.techknowlogick.com/xgo v1.7.1-0.20230307171022-b60708668fc7 h1:nPPnMdR4wih62PSsnHK/SlYM1lOZk/St0k7DkJadMV4=
|
||||||
src.techknowlogick.com/xgo v1.7.1-0.20230307171022-b60708668fc7/go.mod h1:31CE1YKtDOrKTk9PSnjTpe6YbO6W/0LTYZ1VskL09oU=
|
src.techknowlogick.com/xgo v1.7.1-0.20230307171022-b60708668fc7/go.mod h1:31CE1YKtDOrKTk9PSnjTpe6YbO6W/0LTYZ1VskL09oU=
|
||||||
|
src.techknowlogick.com/xgo v1.7.1-0.20230404174715-bff48e481f81 h1:GNyJiosmWbazA1OYNZ1yF+GWOjIW0ZfJmkwEJDiU18g=
|
||||||
|
src.techknowlogick.com/xgo v1.7.1-0.20230404174715-bff48e481f81/go.mod h1:31CE1YKtDOrKTk9PSnjTpe6YbO6W/0LTYZ1VskL09oU=
|
||||||
|
src.techknowlogick.com/xgo v1.7.1-0.20230426011930-e65295a11a0f h1:4/OzEYNoSOP1s3v0cBolS7uSR/AceOtwXcZ1Iqusrbw=
|
||||||
|
src.techknowlogick.com/xgo v1.7.1-0.20230426011930-e65295a11a0f/go.mod h1:31CE1YKtDOrKTk9PSnjTpe6YbO6W/0LTYZ1VskL09oU=
|
||||||
|
src.techknowlogick.com/xgo v1.7.1-0.20230502175921-52d704db7dce h1:gxVOs4LYBv+/gGImaYvs8p14kOTbVLl6835JYKAzUaw=
|
||||||
|
src.techknowlogick.com/xgo v1.7.1-0.20230502175921-52d704db7dce/go.mod h1:31CE1YKtDOrKTk9PSnjTpe6YbO6W/0LTYZ1VskL09oU=
|
||||||
src.techknowlogick.com/xormigrate v1.5.0 h1:6mWTh8d0sWjMTLUgJqiLe0e0Teu+1j+RgI7ErAeOEV0=
|
src.techknowlogick.com/xormigrate v1.5.0 h1:6mWTh8d0sWjMTLUgJqiLe0e0Teu+1j+RgI7ErAeOEV0=
|
||||||
src.techknowlogick.com/xormigrate v1.5.0/go.mod h1:QOCnBeWralVncPn9eZlM4w/rglFK8o1vYpemzPenkBM=
|
src.techknowlogick.com/xormigrate v1.5.0/go.mod h1:QOCnBeWralVncPn9eZlM4w/rglFK8o1vYpemzPenkBM=
|
||||||
xorm.io/builder v0.3.7/go.mod h1:aUW0S9eb9VCaPohFCH3j7czOx1PMW3i1HrSzbLYGBSE=
|
xorm.io/builder v0.3.7/go.mod h1:aUW0S9eb9VCaPohFCH3j7czOx1PMW3i1HrSzbLYGBSE=
|
||||||
|
|
|
@ -177,6 +177,9 @@ func init() {
|
||||||
// Some variables have external dependencies (like git) which may not always be available.
|
// Some variables have external dependencies (like git) which may not always be available.
|
||||||
func initVars() {
|
func initVars() {
|
||||||
Tags = os.Getenv("TAGS")
|
Tags = os.Getenv("TAGS")
|
||||||
|
if !strings.Contains(Tags, "swagger") {
|
||||||
|
Tags += " swagger"
|
||||||
|
}
|
||||||
setVersion()
|
setVersion()
|
||||||
setBinLocation()
|
setBinLocation()
|
||||||
setPkgVersion()
|
setPkgVersion()
|
||||||
|
|
|
@ -315,7 +315,7 @@ func TestGetCaldavTodosForTasks(t *testing.T) {
|
||||||
wantCaldav string
|
wantCaldav string
|
||||||
}{
|
}{
|
||||||
{
|
{
|
||||||
name: "Format single Task as Caldav",
|
name: "Format single Task as CalDAV",
|
||||||
args: args{
|
args: args{
|
||||||
list: &models.ProjectWithTasksAndBuckets{
|
list: &models.ProjectWithTasksAndBuckets{
|
||||||
Project: models.Project{
|
Project: models.Project{
|
||||||
|
|
|
@ -23,15 +23,14 @@ import (
|
||||||
"os/signal"
|
"os/signal"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"code.vikunja.io/api/pkg/cron"
|
|
||||||
|
|
||||||
"code.vikunja.io/api/pkg/config"
|
"code.vikunja.io/api/pkg/config"
|
||||||
|
"code.vikunja.io/api/pkg/cron"
|
||||||
"code.vikunja.io/api/pkg/initialize"
|
"code.vikunja.io/api/pkg/initialize"
|
||||||
"code.vikunja.io/api/pkg/log"
|
"code.vikunja.io/api/pkg/log"
|
||||||
"code.vikunja.io/api/pkg/routes"
|
"code.vikunja.io/api/pkg/routes"
|
||||||
"code.vikunja.io/api/pkg/swagger"
|
|
||||||
"code.vikunja.io/api/pkg/utils"
|
"code.vikunja.io/api/pkg/utils"
|
||||||
"code.vikunja.io/api/pkg/version"
|
"code.vikunja.io/api/pkg/version"
|
||||||
|
|
||||||
"github.com/labstack/echo/v4"
|
"github.com/labstack/echo/v4"
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
)
|
)
|
||||||
|
@ -76,9 +75,6 @@ var webCmd = &cobra.Command{
|
||||||
// Version notification
|
// Version notification
|
||||||
log.Infof("Vikunja version %s", version.Version)
|
log.Infof("Vikunja version %s", version.Version)
|
||||||
|
|
||||||
// Additional swagger information
|
|
||||||
swagger.SwaggerInfo.Version = version.Version
|
|
||||||
|
|
||||||
// Start the webserver
|
// Start the webserver
|
||||||
e := routes.NewEcho()
|
e := routes.NewEcho()
|
||||||
routes.RegisterRoutes(e)
|
routes.RegisterRoutes(e)
|
||||||
|
|
|
@ -112,11 +112,16 @@ func RegisterTableStructsForCache(val interface{}) {
|
||||||
func initMysqlEngine() (engine *xorm.Engine, err error) {
|
func initMysqlEngine() (engine *xorm.Engine, err error) {
|
||||||
// We're using utf8mb here instead of just utf8 because we want to use non-BMP characters.
|
// We're using utf8mb here instead of just utf8 because we want to use non-BMP characters.
|
||||||
// See https://stackoverflow.com/a/30074553/10924593 for more info.
|
// See https://stackoverflow.com/a/30074553/10924593 for more info.
|
||||||
|
host := fmt.Sprintf("tcp(%s)", config.DatabaseHost.GetString())
|
||||||
|
if config.DatabaseHost.GetString()[0] == '/' { // looks like a unix socket
|
||||||
|
host = fmt.Sprintf("unix(%s)", config.DatabaseHost.GetString())
|
||||||
|
}
|
||||||
|
|
||||||
connStr := fmt.Sprintf(
|
connStr := fmt.Sprintf(
|
||||||
"%s:%s@tcp(%s)/%s?charset=utf8mb4&parseTime=true&tls=%s",
|
"%s:%s@%s/%s?charset=utf8mb4&parseTime=true&tls=%s",
|
||||||
config.DatabaseUser.GetString(),
|
config.DatabaseUser.GetString(),
|
||||||
config.DatabasePassword.GetString(),
|
config.DatabasePassword.GetString(),
|
||||||
config.DatabaseHost.GetString(),
|
host,
|
||||||
config.DatabaseDatabase.GetString(),
|
config.DatabaseDatabase.GetString(),
|
||||||
config.DatabaseTLS.GetString())
|
config.DatabaseTLS.GetString())
|
||||||
engine, err = xorm.NewEngine("mysql", connStr)
|
engine, err = xorm.NewEngine("mysql", connStr)
|
||||||
|
|
|
@ -27,6 +27,7 @@ import (
|
||||||
"code.vikunja.io/api/pkg/mail"
|
"code.vikunja.io/api/pkg/mail"
|
||||||
"code.vikunja.io/api/pkg/migration"
|
"code.vikunja.io/api/pkg/migration"
|
||||||
"code.vikunja.io/api/pkg/models"
|
"code.vikunja.io/api/pkg/models"
|
||||||
|
"code.vikunja.io/api/pkg/modules/auth/openid"
|
||||||
"code.vikunja.io/api/pkg/modules/keyvalue"
|
"code.vikunja.io/api/pkg/modules/keyvalue"
|
||||||
migrator "code.vikunja.io/api/pkg/modules/migration"
|
migrator "code.vikunja.io/api/pkg/modules/migration"
|
||||||
"code.vikunja.io/api/pkg/notifications"
|
"code.vikunja.io/api/pkg/notifications"
|
||||||
|
@ -98,6 +99,7 @@ func FullInit() {
|
||||||
user.RegisterDeletionNotificationCron()
|
user.RegisterDeletionNotificationCron()
|
||||||
models.RegisterUserDeletionCron()
|
models.RegisterUserDeletionCron()
|
||||||
models.RegisterOldExportCleanupCron()
|
models.RegisterOldExportCleanupCron()
|
||||||
|
openid.CleanupSavedOpenIDProviders()
|
||||||
|
|
||||||
// Start processing events
|
// Start processing events
|
||||||
go func() {
|
go func() {
|
||||||
|
|
|
@ -1709,3 +1709,29 @@ func (err ErrLinkSharePasswordInvalid) HTTPError() web.HTTPError {
|
||||||
Message: "The provided link share password is invalid.",
|
Message: "The provided link share password is invalid.",
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ErrLinkShareTokenInvalid represents an error where a link share token is invalid
|
||||||
|
type ErrLinkShareTokenInvalid struct {
|
||||||
|
}
|
||||||
|
|
||||||
|
// IsErrLinkShareTokenInvalid checks if an error is ErrLinkShareTokenInvalid.
|
||||||
|
func IsErrLinkShareTokenInvalid(err error) bool {
|
||||||
|
_, ok := err.(*ErrLinkShareTokenInvalid)
|
||||||
|
return ok
|
||||||
|
}
|
||||||
|
|
||||||
|
func (err *ErrLinkShareTokenInvalid) Error() string {
|
||||||
|
return "Provided Link Share Token is invalid"
|
||||||
|
}
|
||||||
|
|
||||||
|
// ErrCodeLinkShareTokenInvalid holds the unique world-error code of this error
|
||||||
|
const ErrCodeLinkShareTokenInvalid = 13003
|
||||||
|
|
||||||
|
// HTTPError holds the http error description
|
||||||
|
func (err ErrLinkShareTokenInvalid) HTTPError() web.HTTPError {
|
||||||
|
return web.HTTPError{
|
||||||
|
HTTPCode: http.StatusBadRequest,
|
||||||
|
Code: ErrCodeLinkShareTokenInvalid,
|
||||||
|
Message: "The provided link share token is invalid.",
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -86,10 +86,15 @@ func (share *LinkSharing) GetID() int64 {
|
||||||
|
|
||||||
// GetLinkShareFromClaims builds a link sharing object from jwt claims
|
// GetLinkShareFromClaims builds a link sharing object from jwt claims
|
||||||
func GetLinkShareFromClaims(claims jwt.MapClaims) (share *LinkSharing, err error) {
|
func GetLinkShareFromClaims(claims jwt.MapClaims) (share *LinkSharing, err error) {
|
||||||
|
projectID, is := claims["project_id"].(float64)
|
||||||
|
if !is {
|
||||||
|
return nil, &ErrLinkShareTokenInvalid{}
|
||||||
|
}
|
||||||
|
|
||||||
share = &LinkSharing{}
|
share = &LinkSharing{}
|
||||||
share.ID = int64(claims["id"].(float64))
|
share.ID = int64(claims["id"].(float64))
|
||||||
share.Hash = claims["hash"].(string)
|
share.Hash = claims["hash"].(string)
|
||||||
share.ProjectID = int64(claims["project_id"].(float64))
|
share.ProjectID = int64(projectID)
|
||||||
share.Right = Right(claims["right"].(float64))
|
share.Right = Right(claims["right"].(float64))
|
||||||
share.SharedByID = int64(claims["sharedByID"].(float64))
|
share.SharedByID = int64(claims["sharedByID"].(float64))
|
||||||
return
|
return
|
||||||
|
|
|
@ -150,10 +150,13 @@ func (tf *TaskCollection) ReadAll(s *xorm.Session, a web.Auth, search string, pa
|
||||||
return nil, 0, 0, err
|
return nil, 0, 0, err
|
||||||
}
|
}
|
||||||
|
|
||||||
sf.Filters.SortByArr = tf.SortByArr
|
sf.Filters.SortByArr = append(sf.Filters.SortByArr, tf.SortByArr...)
|
||||||
sf.Filters.SortBy = tf.SortBy
|
sf.Filters.SortBy = append(sf.Filters.SortBy, tf.SortBy...)
|
||||||
|
if len(sf.Filters.OrderBy) > len(sf.Filters.SortBy) {
|
||||||
|
sf.Filters.OrderBy = sf.Filters.OrderBy[:len(sf.Filters.SortBy)]
|
||||||
|
}
|
||||||
|
sf.Filters.OrderBy = append(sf.Filters.OrderBy, tf.OrderBy...)
|
||||||
sf.Filters.OrderByArr = tf.OrderByArr
|
sf.Filters.OrderByArr = tf.OrderByArr
|
||||||
sf.Filters.OrderBy = tf.OrderBy
|
|
||||||
|
|
||||||
return sf.getTaskCollection().ReadAll(s, a, search, page, perPage)
|
return sf.getTaskCollection().ReadAll(s, a, search, page, perPage)
|
||||||
}
|
}
|
||||||
|
|
|
@ -213,12 +213,12 @@ func (rel *TaskRelation) Create(s *xorm.Session, a web.Auth) error {
|
||||||
// @Param relation body models.TaskRelation true "The relation object"
|
// @Param relation body models.TaskRelation true "The relation object"
|
||||||
// @Param taskID path int true "Task ID"
|
// @Param taskID path int true "Task ID"
|
||||||
// @Param relationKind path string true "The kind of the relation. See the TaskRelation type for more info."
|
// @Param relationKind path string true "The kind of the relation. See the TaskRelation type for more info."
|
||||||
// @Param otherTaskId path int true "The id of the other task."
|
// @Param otherTaskID path int true "The id of the other task."
|
||||||
// @Success 200 {object} models.Message "The task relation was successfully deleted."
|
// @Success 200 {object} models.Message "The task relation was successfully deleted."
|
||||||
// @Failure 400 {object} web.HTTPError "Invalid task relation object provided."
|
// @Failure 400 {object} web.HTTPError "Invalid task relation object provided."
|
||||||
// @Failure 404 {object} web.HTTPError "The task relation was not found."
|
// @Failure 404 {object} web.HTTPError "The task relation was not found."
|
||||||
// @Failure 500 {object} models.Message "Internal error"
|
// @Failure 500 {object} models.Message "Internal error"
|
||||||
// @Router /tasks/{taskID}/relations/{relationKind}/{otherTaskId} [delete]
|
// @Router /tasks/{taskID}/relations/{relationKind}/{otherTaskID} [delete]
|
||||||
func (rel *TaskRelation) Delete(s *xorm.Session, a web.Auth) error {
|
func (rel *TaskRelation) Delete(s *xorm.Session, a web.Auth) error {
|
||||||
|
|
||||||
cond := builder.Or(
|
cond := builder.Or(
|
||||||
|
|
|
@ -93,7 +93,7 @@ type Task struct {
|
||||||
// The task index, calculated per project
|
// The task index, calculated per project
|
||||||
Index int64 `xorm:"bigint not null default 0" json:"index"`
|
Index int64 `xorm:"bigint not null default 0" json:"index"`
|
||||||
|
|
||||||
// The UID is currently not used for anything other than caldav, which is why we don't expose it over json
|
// The UID is currently not used for anything other than CalDAV, which is why we don't expose it over json
|
||||||
UID string `xorm:"varchar(250) null" json:"-"`
|
UID string `xorm:"varchar(250) null" json:"-"`
|
||||||
|
|
||||||
// All related tasks, grouped by their relation kind
|
// All related tasks, grouped by their relation kind
|
||||||
|
@ -109,7 +109,7 @@ type Task struct {
|
||||||
IsFavorite bool `xorm:"-" json:"is_favorite"`
|
IsFavorite bool `xorm:"-" json:"is_favorite"`
|
||||||
|
|
||||||
// The subscription status for the user reading this task. You can only read this property, use the subscription endpoints to modify it.
|
// The subscription status for the user reading this task. You can only read this property, use the subscription endpoints to modify it.
|
||||||
// Will only returned when retreiving one task.
|
// Will only returned when retrieving one task.
|
||||||
Subscription *Subscription `xorm:"-" json:"subscription,omitempty"`
|
Subscription *Subscription `xorm:"-" json:"subscription,omitempty"`
|
||||||
|
|
||||||
// A timestamp when this task was created. You cannot change this value.
|
// A timestamp when this task was created. You cannot change this value.
|
||||||
|
@ -187,7 +187,7 @@ type taskOptions struct {
|
||||||
// @Param page query int false "The page number. Used for pagination. If not provided, the first page of results is returned."
|
// @Param page query int false "The page number. Used for pagination. If not provided, the first page of results is returned."
|
||||||
// @Param per_page query int false "The maximum number of items per page. Note this parameter is limited by the configured maximum of items per page."
|
// @Param per_page query int false "The maximum number of items per page. Note this parameter is limited by the configured maximum of items per page."
|
||||||
// @Param s query string false "Search tasks by task text."
|
// @Param s query string false "Search tasks by task text."
|
||||||
// @Param sort_by query string false "The sorting parameter. You can pass this multiple times to get the tasks ordered by multiple different parametes, along with `order_by`. Possible values to sort by are `id`, `title`, `description`, `done`, `done_at`, `due_date`, `created_by_id`, `project_id`, `repeat_after`, `priority`, `start_date`, `end_date`, `hex_color`, `percent_done`, `uid`, `created`, `updated`. Default is `id`."
|
// @Param sort_by query string false "The sorting parameter. You can pass this multiple times to get the tasks ordered by multiple different parameters, along with `order_by`. Possible values to sort by are `id`, `title`, `description`, `done`, `done_at`, `due_date`, `created_by_id`, `project_id`, `repeat_after`, `priority`, `start_date`, `end_date`, `hex_color`, `percent_done`, `uid`, `created`, `updated`. Default is `id`."
|
||||||
// @Param order_by query string false "The ordering parameter. Possible values to order by are `asc` or `desc`. Default is `asc`."
|
// @Param order_by query string false "The ordering parameter. Possible values to order by are `asc` or `desc`. Default is `asc`."
|
||||||
// @Param filter_by query string false "The name of the field to filter by. Allowed values are all task properties. Task properties which are their own object require passing in the id of that entity. Accepts an array for multiple filters which will be chanied together, all supplied filter must match."
|
// @Param filter_by query string false "The name of the field to filter by. Allowed values are all task properties. Task properties which are their own object require passing in the id of that entity. Accepts an array for multiple filters which will be chanied together, all supplied filter must match."
|
||||||
// @Param filter_value query string false "The value to filter for."
|
// @Param filter_value query string false "The value to filter for."
|
||||||
|
@ -290,7 +290,7 @@ func getRawTasksForProjects(s *xorm.Session, projects []*Project, a web.Auth, op
|
||||||
projectIDs = append(projectIDs, l.ID)
|
projectIDs = append(projectIDs, l.ID)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add the id parameter as the last parameter to sorty by default, but only if it is not already passed as the last parameter.
|
// Add the id parameter as the last parameter to sortby by default, but only if it is not already passed as the last parameter.
|
||||||
if len(opts.sortby) == 0 ||
|
if len(opts.sortby) == 0 ||
|
||||||
len(opts.sortby) > 0 && opts.sortby[len(opts.sortby)-1].sortBy != taskPropertyID {
|
len(opts.sortby) > 0 && opts.sortby[len(opts.sortby)-1].sortBy != taskPropertyID {
|
||||||
opts.sortby = append(opts.sortby, &sortParam{
|
opts.sortby = append(opts.sortby, &sortParam{
|
||||||
|
@ -1005,13 +1005,13 @@ func createTask(s *xorm.Session, t *Task, a web.Auth, updateAssignees bool) (err
|
||||||
// @Accept json
|
// @Accept json
|
||||||
// @Produce json
|
// @Produce json
|
||||||
// @Security JWTKeyAuth
|
// @Security JWTKeyAuth
|
||||||
// @Param id path int true "Task ID"
|
// @Param ID path int true "The Task ID"
|
||||||
// @Param task body models.Task true "The task object"
|
// @Param task body models.Task true "The task object"
|
||||||
// @Success 200 {object} models.Task "The updated task object."
|
// @Success 200 {object} models.Task "The updated task object."
|
||||||
// @Failure 400 {object} web.HTTPError "Invalid task object provided."
|
// @Failure 400 {object} web.HTTPError "Invalid task object provided."
|
||||||
// @Failure 403 {object} web.HTTPError "The user does not have access to the task (aka its project)"
|
// @Failure 403 {object} web.HTTPError "The user does not have access to the task (aka its project)"
|
||||||
// @Failure 500 {object} models.Message "Internal error"
|
// @Failure 500 {object} models.Message "Internal error"
|
||||||
// @Router /tasks/{id} [post]
|
// @Router /tasks/{ID} [post]
|
||||||
//
|
//
|
||||||
//nolint:gocyclo
|
//nolint:gocyclo
|
||||||
func (t *Task) Update(s *xorm.Session, a web.Auth) (err error) {
|
func (t *Task) Update(s *xorm.Session, a web.Auth) (err error) {
|
||||||
|
@ -1613,12 +1613,12 @@ func updateTaskLastUpdated(s *xorm.Session, task *Task) error {
|
||||||
// @tags task
|
// @tags task
|
||||||
// @Produce json
|
// @Produce json
|
||||||
// @Security JWTKeyAuth
|
// @Security JWTKeyAuth
|
||||||
// @Param id path int true "Task ID"
|
// @Param ID path int true "Task ID"
|
||||||
// @Success 200 {object} models.Message "The created task object."
|
// @Success 200 {object} models.Message "The created task object."
|
||||||
// @Failure 400 {object} web.HTTPError "Invalid task ID provided."
|
// @Failure 400 {object} web.HTTPError "Invalid task ID provided."
|
||||||
// @Failure 403 {object} web.HTTPError "The user does not have access to the project"
|
// @Failure 403 {object} web.HTTPError "The user does not have access to the project"
|
||||||
// @Failure 500 {object} models.Message "Internal error"
|
// @Failure 500 {object} models.Message "Internal error"
|
||||||
// @Router /tasks/{id} [delete]
|
// @Router /tasks/{ID} [delete]
|
||||||
func (t *Task) Delete(s *xorm.Session, a web.Auth) (err error) {
|
func (t *Task) Delete(s *xorm.Session, a web.Auth) (err error) {
|
||||||
|
|
||||||
if _, err = s.ID(t.ID).Delete(Task{}); err != nil {
|
if _, err = s.ID(t.ID).Delete(Task{}); err != nil {
|
||||||
|
@ -1692,12 +1692,12 @@ func (t *Task) Delete(s *xorm.Session, a web.Auth) (err error) {
|
||||||
// @tags task
|
// @tags task
|
||||||
// @Accept json
|
// @Accept json
|
||||||
// @Produce json
|
// @Produce json
|
||||||
// @Param ID path int true "The task ID"
|
// @Param id path int true "The task ID"
|
||||||
// @Security JWTKeyAuth
|
// @Security JWTKeyAuth
|
||||||
// @Success 200 {object} models.Task "The task"
|
// @Success 200 {object} models.Task "The task"
|
||||||
// @Failure 404 {object} models.Message "Task not found"
|
// @Failure 404 {object} models.Message "Task not found"
|
||||||
// @Failure 500 {object} models.Message "Internal error"
|
// @Failure 500 {object} models.Message "Internal error"
|
||||||
// @Router /tasks/{ID} [get]
|
// @Router /tasks/{id} [get]
|
||||||
func (t *Task) ReadOne(s *xorm.Session, a web.Auth) (err error) {
|
func (t *Task) ReadOne(s *xorm.Session, a web.Auth) (err error) {
|
||||||
|
|
||||||
*t, err = GetTaskByIDSimple(s, t.ID)
|
*t, err = GetTaskByIDSimple(s, t.ID)
|
||||||
|
|
|
@ -161,3 +161,7 @@ func getProviderFromMap(pi map[string]interface{}) (provider *Provider, err erro
|
||||||
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func CleanupSavedOpenIDProviders() {
|
||||||
|
_ = keyvalue.Del("openid_providers")
|
||||||
|
}
|
||||||
|
|
|
@ -267,7 +267,7 @@ func checkProjectBackgroundRights(s *xorm.Session, c echo.Context) (project *mod
|
||||||
// @Produce octet-stream
|
// @Produce octet-stream
|
||||||
// @Param id path int true "Project ID"
|
// @Param id path int true "Project ID"
|
||||||
// @Security JWTKeyAuth
|
// @Security JWTKeyAuth
|
||||||
// @Success 200 {} string "The project background file."
|
// @Success 200 {file} blob "The project background file."
|
||||||
// @Failure 403 {object} models.Message "No access to this project."
|
// @Failure 403 {object} models.Message "No access to this project."
|
||||||
// @Failure 404 {object} models.Message "The project does not exist."
|
// @Failure 404 {object} models.Message "The project does not exist."
|
||||||
// @Failure 500 {object} models.Message "Internal error"
|
// @Failure 500 {object} models.Message "Internal error"
|
||||||
|
|
|
@ -49,7 +49,7 @@ func unsplashImage(url string, c echo.Context) error {
|
||||||
// @Produce octet-stream
|
// @Produce octet-stream
|
||||||
// @Param image path int true "Unsplash Image ID"
|
// @Param image path int true "Unsplash Image ID"
|
||||||
// @Security JWTKeyAuth
|
// @Security JWTKeyAuth
|
||||||
// @Success 200 {} string "The image"
|
// @Success 200 {file} blob "The image"
|
||||||
// @Failure 404 {object} models.Message "The image does not exist."
|
// @Failure 404 {object} models.Message "The image does not exist."
|
||||||
// @Failure 500 {object} models.Message "Internal error"
|
// @Failure 500 {object} models.Message "Internal error"
|
||||||
// @Router /backgrounds/unsplash/image/{image} [get]
|
// @Router /backgrounds/unsplash/image/{image} [get]
|
||||||
|
@ -69,7 +69,7 @@ func ProxyUnsplashImage(c echo.Context) error {
|
||||||
// @Produce octet-stream
|
// @Produce octet-stream
|
||||||
// @Param image path int true "Unsplash Image ID"
|
// @Param image path int true "Unsplash Image ID"
|
||||||
// @Security JWTKeyAuth
|
// @Security JWTKeyAuth
|
||||||
// @Success 200 {} string "The thumbnail"
|
// @Success 200 {file} blob "The thumbnail"
|
||||||
// @Failure 404 {object} models.Message "The image does not exist."
|
// @Failure 404 {object} models.Message "The image does not exist."
|
||||||
// @Failure 500 {object} models.Message "Internal error"
|
// @Failure 500 {object} models.Message "Internal error"
|
||||||
// @Router /backgrounds/unsplash/image/{image}/thumb [get]
|
// @Router /backgrounds/unsplash/image/{image}/thumb [get]
|
||||||
|
|
|
@ -52,7 +52,6 @@ type label struct {
|
||||||
Name string `json:"name"`
|
Name string `json:"name"`
|
||||||
Color string `json:"color"`
|
Color string `json:"color"`
|
||||||
ItemOrder int64 `json:"item_order"`
|
ItemOrder int64 `json:"item_order"`
|
||||||
IsDeleted bool `json:"is_deleted"`
|
|
||||||
IsFavorite bool `json:"is_favorite"`
|
IsFavorite bool `json:"is_favorite"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -93,7 +92,6 @@ type item struct {
|
||||||
AssignedByUID string `json:"assigned_by_uid"`
|
AssignedByUID string `json:"assigned_by_uid"`
|
||||||
ResponsibleUID string `json:"responsible_uid"`
|
ResponsibleUID string `json:"responsible_uid"`
|
||||||
Checked bool `json:"checked"`
|
Checked bool `json:"checked"`
|
||||||
IsDeleted bool `json:"is_deleted"`
|
|
||||||
DateAdded time.Time `json:"added_at"`
|
DateAdded time.Time `json:"added_at"`
|
||||||
HasMoreNotes bool `json:"has_more_notes"`
|
HasMoreNotes bool `json:"has_more_notes"`
|
||||||
DateCompleted time.Time `json:"completed_at"`
|
DateCompleted time.Time `json:"completed_at"`
|
||||||
|
@ -130,7 +128,6 @@ type note struct {
|
||||||
ItemID string `json:"item_id"`
|
ItemID string `json:"item_id"`
|
||||||
Content string `json:"content"`
|
Content string `json:"content"`
|
||||||
FileAttachment *fileAttachment `json:"file_attachment"`
|
FileAttachment *fileAttachment `json:"file_attachment"`
|
||||||
IsDeleted bool `json:"is_deleted"`
|
|
||||||
Posted time.Time `json:"posted_at"`
|
Posted time.Time `json:"posted_at"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -138,19 +135,17 @@ type projectNote struct {
|
||||||
Content string `json:"content"`
|
Content string `json:"content"`
|
||||||
FileAttachment *fileAttachment `json:"file_attachment"`
|
FileAttachment *fileAttachment `json:"file_attachment"`
|
||||||
ID int64 `json:"id"`
|
ID int64 `json:"id"`
|
||||||
IsDeleted int64 `json:"is_deleted"`
|
|
||||||
Posted time.Time `json:"posted"`
|
Posted time.Time `json:"posted"`
|
||||||
ProjectID string `json:"project_id"`
|
ProjectID string `json:"project_id"`
|
||||||
UidsToNotify []int64 `json:"uids_to_notify"`
|
UidsToNotify []int64 `json:"uids_to_notify"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type reminder struct {
|
type reminder struct {
|
||||||
ID string `json:"id"`
|
ID string `json:"id"`
|
||||||
ItemID string `json:"item_id"`
|
ItemID string `json:"item_id"`
|
||||||
Type string `json:"type"`
|
Type string `json:"type"`
|
||||||
Due *dueDate `json:"due"`
|
Due *dueDate `json:"due"`
|
||||||
MmOffset int64 `json:"mm_offset"`
|
MmOffset int64 `json:"mm_offset"`
|
||||||
IsDeleted int64 `json:"is_deleted"`
|
|
||||||
}
|
}
|
||||||
|
|
||||||
type section struct {
|
type section struct {
|
||||||
|
|
|
@ -75,7 +75,7 @@ const mailTemplateHTML = `
|
||||||
|
|
||||||
{{ if .ActionURL }}
|
{{ if .ActionURL }}
|
||||||
<p style="color: #9CA3AF;font-size:12px;border-top: 1px solid #dbdbdb;margin-top:20px;padding-top:20px;">
|
<p style="color: #9CA3AF;font-size:12px;border-top: 1px solid #dbdbdb;margin-top:20px;padding-top:20px;">
|
||||||
If the button above doesn't work, copy the url below and paste it in your browsers address bar:<br/>
|
If the button above doesn't work, copy the url below and paste it in your browser's address bar:<br/>
|
||||||
{{ .ActionURL }}
|
{{ .ActionURL }}
|
||||||
</p>
|
</p>
|
||||||
{{ end }}
|
{{ end }}
|
||||||
|
|
|
@ -162,7 +162,7 @@ And one more, because why not?
|
||||||
|
|
||||||
|
|
||||||
<p style="color: #9CA3AF;font-size:12px;border-top: 1px solid #dbdbdb;margin-top:20px;padding-top:20px;">
|
<p style="color: #9CA3AF;font-size:12px;border-top: 1px solid #dbdbdb;margin-top:20px;padding-top:20px;">
|
||||||
If the button above doesn't work, copy the url below and paste it in your browsers address bar:<br/>
|
If the button above doesn't work, copy the url below and paste it in your browser's address bar:<br/>
|
||||||
https://example.com
|
https://example.com
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
|
|
|
@ -51,7 +51,7 @@ import (
|
||||||
// @Produce octet-stream
|
// @Produce octet-stream
|
||||||
// @Param username path string true "The username of the user who's avatar you want to get"
|
// @Param username path string true "The username of the user who's avatar you want to get"
|
||||||
// @Param size query int false "The size of the avatar you want to get. If bigger than the max configured size this will be adjusted to the maximum size."
|
// @Param size query int false "The size of the avatar you want to get. If bigger than the max configured size this will be adjusted to the maximum size."
|
||||||
// @Success 200 {} blob "The avatar"
|
// @Success 200 {file} blob "The avatar"
|
||||||
// @Failure 404 {object} models.Message "The user does not exist."
|
// @Failure 404 {object} models.Message "The user does not exist."
|
||||||
// @Failure 500 {object} models.Message "Internal error"
|
// @Failure 500 {object} models.Message "Internal error"
|
||||||
// @Router /{username}/avatar [get]
|
// @Router /{username}/avatar [get]
|
||||||
|
|
|
@ -36,13 +36,13 @@ import (
|
||||||
// @tags namespace
|
// @tags namespace
|
||||||
// @Accept json
|
// @Accept json
|
||||||
// @Produce json
|
// @Produce json
|
||||||
// @Param id path int true "Namespace ID"
|
// @Param namespaceID path int true "Namespace ID"
|
||||||
// @Security JWTKeyAuth
|
// @Security JWTKeyAuth
|
||||||
// @Success 200 {array} models.Project "The projects."
|
// @Success 200 {array} models.Project "The projects."
|
||||||
// @Failure 403 {object} models.Message "No access to that namespace."
|
// @Failure 403 {object} models.Message "No access to that namespace."
|
||||||
// @Failure 404 {object} models.Message "The namespace does not exist."
|
// @Failure 404 {object} models.Message "The namespace does not exist."
|
||||||
// @Failure 500 {object} models.Message "Internal error"
|
// @Failure 500 {object} models.Message "Internal error"
|
||||||
// @Router /namespaces/{id}/projects [get]
|
// @Router /namespaces/{namespaceID}/projects [get]
|
||||||
func GetProjectsByNamespaceID(c echo.Context) error {
|
func GetProjectsByNamespaceID(c echo.Context) error {
|
||||||
s := db.NewSession()
|
s := db.NewSession()
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
|
@ -116,7 +116,7 @@ func UploadTaskAttachment(c echo.Context) error {
|
||||||
// @Param id path int true "Task ID"
|
// @Param id path int true "Task ID"
|
||||||
// @Param attachmentID path int true "Attachment ID"
|
// @Param attachmentID path int true "Attachment ID"
|
||||||
// @Security JWTKeyAuth
|
// @Security JWTKeyAuth
|
||||||
// @Success 200 {} string "The attachment file."
|
// @Success 200 {file} blob "The attachment file."
|
||||||
// @Failure 403 {object} models.Message "No access to this task."
|
// @Failure 403 {object} models.Message "No access to this task."
|
||||||
// @Failure 404 {object} models.Message "The task does not exist."
|
// @Failure 404 {object} models.Message "The task does not exist."
|
||||||
// @Failure 500 {object} models.Message "Internal error"
|
// @Failure 500 {object} models.Message "Internal error"
|
||||||
|
|
|
@ -181,7 +181,7 @@ func UserTOTPDisable(c echo.Context) error {
|
||||||
// @Accept json
|
// @Accept json
|
||||||
// @Produce json
|
// @Produce json
|
||||||
// @Security JWTKeyAuth
|
// @Security JWTKeyAuth
|
||||||
// @Success 200 {} string "The qr code as jpeg image"
|
// @Success 200 {file} blob "The qr code as jpeg image"
|
||||||
// @Failure 500 {object} models.Message "Internal server error."
|
// @Failure 500 {object} models.Message "Internal server error."
|
||||||
// @Router /user/settings/totp/qrcode [get]
|
// @Router /user/settings/totp/qrcode [get]
|
||||||
func UserTOTPQrCode(c echo.Context) error {
|
func UserTOTPQrCode(c echo.Context) error {
|
||||||
|
|
|
@ -71,7 +71,6 @@ import (
|
||||||
vikunja_file "code.vikunja.io/api/pkg/modules/migration/vikunja-file"
|
vikunja_file "code.vikunja.io/api/pkg/modules/migration/vikunja-file"
|
||||||
apiv1 "code.vikunja.io/api/pkg/routes/api/v1"
|
apiv1 "code.vikunja.io/api/pkg/routes/api/v1"
|
||||||
"code.vikunja.io/api/pkg/routes/caldav"
|
"code.vikunja.io/api/pkg/routes/caldav"
|
||||||
_ "code.vikunja.io/api/pkg/swagger" // To generate swagger docs
|
|
||||||
"code.vikunja.io/api/pkg/version"
|
"code.vikunja.io/api/pkg/version"
|
||||||
"code.vikunja.io/web"
|
"code.vikunja.io/web"
|
||||||
"code.vikunja.io/web/handler"
|
"code.vikunja.io/web/handler"
|
||||||
|
|
|
@ -24,7 +24,7 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
// Change to deflate to gain better compression
|
// Change to deflate to gain better compression
|
||||||
// see http://golang.org/pkg/archive/zip/#pkg-constants
|
// see https://pkg.go.dev/archive/zip#pkg-constants
|
||||||
const CompressionUsed = zip.Deflate
|
const CompressionUsed = zip.Deflate
|
||||||
|
|
||||||
func WriteBytesToZip(filename string, data []byte, writer *zip.Writer) (err error) {
|
func WriteBytesToZip(filename string, data []byte, writer *zip.Writer) (err error) {
|
||||||
|
|
26
pkg/version/swagger.go
Normal file
26
pkg/version/swagger.go
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
// Vikunja is a to-do list application to facilitate your life.
|
||||||
|
// Copyright 2018-2023 Vikunja and contributors. All rights reserved.
|
||||||
|
//
|
||||||
|
// This program is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU Affero General Public Licensee as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// This program is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU Affero General Public Licensee for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU Affero General Public Licensee
|
||||||
|
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
//go:build swagger
|
||||||
|
// +build swagger
|
||||||
|
|
||||||
|
package version
|
||||||
|
|
||||||
|
import "code.vikunja.io/api/pkg/swagger"
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
// Additional swagger information
|
||||||
|
swagger.SwaggerInfo.Version = Version
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user