Compare commits

..

41 Commits

Author SHA1 Message Date
6e0e452395 Bump version number
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/tag Build is passing
2019-08-28 20:21:56 +02:00
9e44731650 Merge pull request #50 from vbrandl/dependabot/cargo/reqwest-0.9.20
Bump reqwest from 0.9.19 to 0.9.20
2019-08-28 20:20:37 +02:00
f673d71387 Bump reqwest from 0.9.19 to 0.9.20
Bumps [reqwest](https://github.com/seanmonstar/reqwest) from 0.9.19 to 0.9.20.
- [Release notes](https://github.com/seanmonstar/reqwest/releases)
- [Changelog](https://github.com/seanmonstar/reqwest/blob/v0.9.20/CHANGELOG.md)
- [Commits](https://github.com/seanmonstar/reqwest/compare/v0.9.19...v0.9.20)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
2019-08-28 18:20:05 +00:00
eda1822dce Merge pull request #51 from vbrandl/dependabot/cargo/lazy_static-1.4.0
Bump lazy_static from 1.3.0 to 1.4.0
2019-08-28 20:18:56 +02:00
fb64af3456 Bump lazy_static from 1.3.0 to 1.4.0
Bumps [lazy_static](https://github.com/rust-lang-nursery/lazy-static.rs) from 1.3.0 to 1.4.0.
- [Release notes](https://github.com/rust-lang-nursery/lazy-static.rs/releases)
- [Commits](https://github.com/rust-lang-nursery/lazy-static.rs/compare/1.3.0...1.4.0)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
2019-08-28 18:18:32 +00:00
0837284798 Merge pull request #48 from vbrandl/dependabot/cargo/serde-1.0.99
Bump serde from 1.0.98 to 1.0.99
2019-08-28 20:18:24 +02:00
a7039f15b5 Merge pull request #52 from vbrandl/dependabot/cargo/spin-0.5.2
[Security] Bump spin from 0.5.0 to 0.5.2
2019-08-28 20:16:54 +02:00
b1be281982 [Security] Bump spin from 0.5.0 to 0.5.2
Bumps [spin](https://github.com/mvdnes/spin-rs) from 0.5.0 to 0.5.2. **This update includes a security fix.**
- [Release notes](https://github.com/mvdnes/spin-rs/releases)
- [Commits](https://github.com/mvdnes/spin-rs/commits)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
2019-08-28 17:22:32 +00:00
2795995f58 Bump serde from 1.0.98 to 1.0.99
Bumps [serde](https://github.com/serde-rs/serde) from 1.0.98 to 1.0.99.
- [Release notes](https://github.com/serde-rs/serde/releases)
- [Commits](https://github.com/serde-rs/serde/compare/v1.0.98...v1.0.99)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
2019-08-28 07:43:01 +00:00
913cc9dc75 Merge pull request #47 from vbrandl/dependabot/cargo/serde_derive-1.0.99
Bump serde_derive from 1.0.98 to 1.0.99
2019-08-28 09:27:35 +02:00
645d6e4a2b Bump serde_derive from 1.0.98 to 1.0.99
Bumps [serde_derive](https://github.com/serde-rs/serde) from 1.0.98 to 1.0.99.
- [Release notes](https://github.com/serde-rs/serde/releases)
- [Commits](https://github.com/serde-rs/serde/compare/v1.0.98...v1.0.99)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
2019-08-28 07:23:42 +00:00
e455a89de4 Fix Docker TLS certdir
All checks were successful
continuous-integration/drone/push Build is passing
2019-08-28 09:14:17 +02:00
f2cae46624 Update CI script for new docker version
All checks were successful
continuous-integration/drone/push Build is passing
2019-08-02 15:14:31 +02:00
f47cbbe81a Merge pull request #44 from vbrandl/dependabot/cargo/serde_derive-1.0.98
All checks were successful
continuous-integration/drone/push Build is passing
Bump serde_derive from 1.0.97 to 1.0.98
2019-08-02 15:01:12 +02:00
85f90c0bdb Bump serde_derive from 1.0.97 to 1.0.98
Bumps [serde_derive](https://github.com/serde-rs/serde) from 1.0.97 to 1.0.98.
- [Release notes](https://github.com/serde-rs/serde/releases)
- [Commits](https://github.com/serde-rs/serde/compare/v1.0.97...v1.0.98)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
2019-08-02 13:00:35 +00:00
9143e5dbf8 Merge pull request #45 from vbrandl/dependabot/cargo/serde-1.0.98
Bump serde from 1.0.97 to 1.0.98
2019-08-02 14:59:02 +02:00
865e3c7bbd Merge pull request #46 from vbrandl/dependabot/cargo/log-0.4.8
Bump log from 0.4.7 to 0.4.8
2019-08-02 14:58:53 +02:00
5ebdd4067c Bump version number
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/tag Build is passing
2019-07-29 21:50:21 +02:00
55a1405e71 Enable NormalizePath middleware
This allows double slashes in paths
2019-07-29 21:49:25 +02:00
1436336b6a Bump log from 0.4.7 to 0.4.8
Bumps [log](https://github.com/rust-lang/log) from 0.4.7 to 0.4.8.
- [Release notes](https://github.com/rust-lang/log/releases)
- [Changelog](https://github.com/rust-lang-nursery/log/blob/master/CHANGELOG.md)
- [Commits](https://github.com/rust-lang/log/commits)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
2019-07-29 04:34:22 +00:00
5a74306e49 Bump serde from 1.0.97 to 1.0.98
Bumps [serde](https://github.com/serde-rs/serde) from 1.0.97 to 1.0.98.
- [Release notes](https://github.com/serde-rs/serde/releases)
- [Commits](https://github.com/serde-rs/serde/compare/v1.0.97...v1.0.98)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
2019-07-29 04:33:55 +00:00
614e5a6da5 Bump version number
All checks were successful
continuous-integration/drone/tag Build is passing
continuous-integration/drone/push Build is passing
2019-07-22 22:27:19 +02:00
0128e267cc Use async client to check if a repo exists 2019-07-22 22:26:37 +02:00
c3dffac5da Use async client 2019-07-22 22:25:55 +02:00
aaaff22907 Merge pull request #42 from vbrandl/dependabot/cargo/reqwest-0.9.19
Bump reqwest from 0.9.17 to 0.9.19
2019-07-22 21:39:45 +02:00
ddfcbf11f1 Bump reqwest from 0.9.17 to 0.9.19
Bumps [reqwest](https://github.com/seanmonstar/reqwest) from 0.9.17 to 0.9.19.
- [Release notes](https://github.com/seanmonstar/reqwest/releases)
- [Changelog](https://github.com/seanmonstar/reqwest/blob/master/CHANGELOG.md)
- [Commits](https://github.com/seanmonstar/reqwest/compare/v0.9.17...v0.9.19)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
2019-07-22 04:28:01 +00:00
3bee454548 Bump version number
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/tag Build is passing
2019-07-19 17:03:24 +02:00
9cff6f1f13 Merge pull request #40 from vbrandl/dependabot/cargo/serde-1.0.97
Bump serde from 1.0.93 to 1.0.97
2019-07-19 16:43:35 +02:00
c946c5d0b4 Bump serde from 1.0.93 to 1.0.97
Bumps [serde](https://github.com/serde-rs/serde) from 1.0.93 to 1.0.97.
- [Release notes](https://github.com/serde-rs/serde/releases)
- [Commits](https://github.com/serde-rs/serde/compare/v1.0.93...v1.0.97)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
2019-07-19 14:41:50 +00:00
88ae90af95 Merge pull request #39 from vbrandl/dependabot/cargo/actix-web-1.0.5
Bump actix-web from 1.0.3 to 1.0.5
2019-07-19 16:40:36 +02:00
9f783dffa8 Merge pull request #41 from vbrandl/dependabot/cargo/ructe-0.7.0
Bump ructe from 0.6.4 to 0.7.0
2019-07-19 16:40:23 +02:00
2cdf64ed80 Bump ructe from 0.6.4 to 0.7.0
Bumps [ructe](https://github.com/kaj/ructe) from 0.6.4 to 0.7.0.
- [Release notes](https://github.com/kaj/ructe/releases)
- [Commits](https://github.com/kaj/ructe/compare/v0.6.4...v0.7.0)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
2019-07-19 14:40:13 +00:00
9e024b530e Merge pull request #38 from vbrandl/dependabot/cargo/serde_derive-1.0.97
Bump serde_derive from 1.0.94 to 1.0.97
2019-07-19 16:38:43 +02:00
0db7b26541 Bump actix-web from 1.0.3 to 1.0.5
Bumps [actix-web](https://github.com/actix/actix-web) from 1.0.3 to 1.0.5.
- [Release notes](https://github.com/actix/actix-web/releases)
- [Changelog](https://github.com/actix/actix-web/blob/master/CHANGES.md)
- [Commits](https://github.com/actix/actix-web/compare/web-v1.0.3...web-v1.0.5)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
2019-07-18 15:13:53 +00:00
009d2c4813 Bump serde_derive from 1.0.94 to 1.0.97
Bumps [serde_derive](https://github.com/serde-rs/serde) from 1.0.94 to 1.0.97.
- [Release notes](https://github.com/serde-rs/serde/releases)
- [Commits](https://github.com/serde-rs/serde/compare/v1.0.94...v1.0.97)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
2019-07-18 15:13:40 +00:00
f0ed6c2e23 Merge pull request #35 from vbrandl/dependabot/cargo/log-0.4.7
All checks were successful
continuous-integration/drone/push Build is passing
Bump log from 0.4.6 to 0.4.7
2019-07-14 14:25:47 +02:00
d16a21e74e Bump log from 0.4.6 to 0.4.7
Bumps [log](https://github.com/rust-lang/log) from 0.4.6 to 0.4.7.
- [Release notes](https://github.com/rust-lang/log/releases)
- [Changelog](https://github.com/rust-lang-nursery/log/blob/master/CHANGELOG.md)
- [Commits](https://github.com/rust-lang/log/compare/0.4.6...0.4.7)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
2019-07-11 06:35:54 +00:00
7e721ac212 Fork in for loop
[ci skip]
2019-07-07 21:01:57 +02:00
4eb5d06cd1 Fork in loop
[ci skip]
2019-07-07 20:33:08 +02:00
b71207ca51 Add helper scripts for finding and loading active repos (on github)
[ci skip]
2019-07-07 20:22:32 +02:00
f3902f800f Remove migration subcommand
All checks were successful
continuous-integration/drone/push Build is passing
2019-07-07 18:27:50 +02:00
8 changed files with 364 additions and 239 deletions

View File

@ -1,6 +1,6 @@
image: docker:stable
image: docker:19.03
services:
- docker:dind
- docker:19.03-dind
stages:
- build
@ -9,6 +9,8 @@ stages:
variables:
DOCKER_HOST: tcp://docker:2375
DOCKER_DRIVER: overlay2
# DOCKER_TLS_CERTDIR: "/certs"
DOCKER_TLS_CERTDIR: ""
CONTAINER_BUILDER_IMAGE: $CI_REGISTRY_IMAGE:builder-latest
CONTAINER_TEST_IMAGE: $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG
CONTAINER_RELEASE_IMAGE: $CI_REGISTRY_IMAGE:latest

480
Cargo.lock generated

File diff suppressed because it is too large Load Diff

View File

@ -1,27 +1,27 @@
[package]
name = "hoc"
version = "0.10.0"
version = "0.11.2"
authors = ["Valentin Brandl <vbrandl@riseup.net>"]
edition = "2018"
build = "build.rs"
[dependencies]
actix-web = "1.0.3"
actix-web = "1.0.5"
badge = "0.2.0"
bytes = "0.4.12"
futures = "0.1.28"
git2 = "0.9.1"
lazy_static = "1.3.0"
log = "0.4.6"
lazy_static = "1.4.0"
log = "0.4.8"
log4rs = "0.8.3"
number_prefix = "0.3.0"
openssl-probe = "0.1.2"
reqwest = "0.9.17"
serde = "1.0.93"
serde_derive = "1.0.94"
reqwest = "0.9.20"
serde = "1.0.99"
serde_derive = "1.0.99"
serde_json = "1.0.40"
structopt = "0.2.18"
[build-dependencies]
ructe = "0.6.4"
ructe = "0.7.0"
vergen = "3.0.4"

10
scripts/find-active.sh Executable file
View File

@ -0,0 +1,10 @@
#!/usr/bin/env sh
set -e
DIR=${1:-repos}
for url in $(./scripts/list.sh "${DIR}")
do
(curl "${url}" --silent | grep -q hitsofcode) && echo "${url}" &
done

21
scripts/load-active.sh Executable file
View File

@ -0,0 +1,21 @@
#!/usr/bin/env sh
set -e
ACTIVE=${1}
if [ -z "${ACTIVE}" ]
then
echo "Usage: $0 <list of active repos>"
exit 1
fi
while IFS= read -r url
do
imgs=$(curl "${url}" --silent | grep hitsofcode | grep -o -P 'https://camo.githubusercontent.com/[a-z0-9]+/[a-z0-9]+')
[ -z "${imgs}" ] || echo "${url}"
for img in ${imgs}
do
curl "$img" --silent > /dev/null &
done
done < "${ACTIVE}"

View File

@ -46,14 +46,6 @@ pub(crate) struct Opt {
)]
/// The logfile
pub(crate) logfile: PathBuf,
#[structopt(subcommand)]
pub(crate) migrate: Option<Migration>,
}
#[derive(StructOpt, Debug, Clone, Copy)]
pub(crate) enum Migration {
#[structopt(name = "migrate-commit-count")]
CacheCommitCount,
}
pub(crate) fn init() -> Result<()> {

View File

@ -18,7 +18,6 @@ mod statics;
use crate::{
cache::CacheState,
config::Migration,
error::{Error, Result},
service::{Bitbucket, FormService, GitHub, Gitlab, Service},
statics::{CLIENT, CSS, FAVICON, OPT, REPO_COUNT, VERSION_INFO},
@ -35,7 +34,7 @@ use git2::Repository;
use number_prefix::{NumberPrefix, Prefixed, Standalone};
use std::{
borrow::Cow,
fs::{create_dir_all, read_dir, rename},
fs::create_dir_all,
path::Path,
process::Command,
sync::atomic::Ordering,
@ -138,8 +137,12 @@ fn hoc(repo: &str, repo_dir: &str, cache_dir: &str) -> Result<(u64, String, u64)
Ok((cache.count, head, commits))
}
fn remote_exists(url: &str) -> Result<bool> {
Ok(CLIENT.head(url).send()?.status() == reqwest::StatusCode::OK)
fn remote_exists(url: &str) -> impl Future<Item = bool, Error = Error> {
CLIENT
.head(url)
.send()
.map(|resp| resp.status() == reqwest::StatusCode::OK)
.from_err()
}
enum HocResult {
@ -164,15 +167,15 @@ where
T: Service,
F: Fn(HocResult) -> Result<HttpResponse>,
{
futures::future::result(Ok(()))
.and_then(move |_| {
let repo = format!("{}/{}", data.0.to_lowercase(), data.1.to_lowercase());
let service_path = format!("{}/{}", T::domain(), repo);
let path = format!("{}/{}", state.repos, service_path);
let repo = format!("{}/{}", data.0.to_lowercase(), data.1.to_lowercase());
let service_path = format!("{}/{}", T::domain(), repo);
let path = format!("{}/{}", state.repos, service_path);
let url = format!("https://{}", service_path);
remote_exists(&url)
.and_then(move |remote_exists| {
let file = Path::new(&path);
let url = format!("https://{}", service_path);
if !file.exists() {
if !remote_exists(&url)? {
if !remote_exists {
warn!("Repository does not exist: {}", url);
return Ok(HocResult::NotFound);
}
@ -352,6 +355,7 @@ fn start_server() -> Result<()> {
App::new()
.data(state.clone())
.wrap(middleware::Logger::default())
.wrap(middleware::NormalizePath)
.service(index)
.service(css)
.service(favicon32)
@ -372,39 +376,7 @@ fn start_server() -> Result<()> {
.run()?)
}
fn migrate_cache() -> Result<()> {
let mut backup_cache = OPT.cachedir.clone();
backup_cache.set_extension("bak");
rename(&OPT.cachedir, backup_cache)?;
let outdir = OPT.outdir.display().to_string();
let cachedir = OPT.cachedir.display().to_string();
for service in read_dir(&OPT.outdir)? {
let service = service?;
for namespace in read_dir(service.path())? {
let namespace = namespace?;
for repo in read_dir(namespace.path())? {
let repo_path = repo?.path().display().to_string();
let repo_path: String =
repo_path
.split(&outdir)
.fold(String::new(), |mut acc, next| {
acc.push_str(next);
acc
});
println!("{}", repo_path);
hoc(&repo_path, &outdir, &cachedir)?;
}
}
}
Ok(())
}
fn main() -> Result<()> {
config::init()?;
match &OPT.migrate {
None => start_server(),
Some(migration) => match migration {
Migration::CacheCommitCount => migrate_cache(),
},
}
start_server()
}

View File

@ -15,7 +15,7 @@ pub(crate) const CSS: &str = include_str!("../static/tacit-css.min.css");
pub(crate) const FAVICON: &[u8] = include_bytes!("../static/favicon32.png");
lazy_static! {
pub(crate) static ref CLIENT: reqwest::Client = reqwest::Client::new();
pub(crate) static ref CLIENT: reqwest::r#async::Client = reqwest::r#async::Client::new();
pub(crate) static ref OPT: Opt = Opt::from_args();
pub(crate) static ref REPO_COUNT: AtomicUsize =
AtomicUsize::new(count_repositories(&OPT.outdir).unwrap());