From bb5a6ce5c4dab4f6a511913001471d5bd3b4bbf2 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Thu, 23 May 2024 21:13:13 +0200 Subject: [PATCH 01/32] migrated codebase to run with rust --- Cargo.toml | 16 +++++++++++ src/index.ts | 47 -------------------------------- src/main.rs | 75 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 91 insertions(+), 47 deletions(-) create mode 100644 Cargo.toml delete mode 100644 src/index.ts create mode 100644 src/main.rs diff --git a/Cargo.toml b/Cargo.toml new file mode 100644 index 0000000..73d13e9 --- /dev/null +++ b/Cargo.toml @@ -0,0 +1,16 @@ +[package] +name = "list-team-members" +version = "0.1.0" +edition = "2021" + +# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html + +[dependencies] +actions-core = "0.0.2" +anyhow = "1.0.86" +json = "0.12.4" +octocrab = "0.38.0" +serde = "1.0.202" +serde_derive = "1.0.202" +serde_json = "1.0.117" +tokio = { version = "1.37.0", features = ["macros", "rt-multi-thread"] } diff --git a/src/index.ts b/src/index.ts deleted file mode 100644 index 61f36da..0000000 --- a/src/index.ts +++ /dev/null @@ -1,47 +0,0 @@ -import { getInput, info, setFailed, setOutput } from "@actions/core"; -import { context, getOctokit } from "@actions/github"; -import { Context } from "@actions/github/lib/context"; -import { GitHub } from "@actions/github/lib/utils"; - -type UserData = { - username: string; - url: string; - avatar: string; -} - -async function fetchTeam(octokit: InstanceType, org: string, team: string): Promise { - const teamData = await octokit.rest.teams.listMembersInOrg({ - org, - team_slug: team, - }); - - return teamData.data.map(user => { - return { - username: user.login, - url: user.html_url, - avatar: user.avatar_url - } - }); -} - -async function runAction(ctx: Context) { - const token = getInput("ACCESS_TOKEN", { required: true }); - let organization = getInput("organization", { required: false }); - if (!organization) { - organization = ctx.repo.owner; - } - - const team = getInput("team", { required: true }); - - const octokit = getOctokit(token); - const teamData = await fetchTeam(octokit, organization, team); - if (teamData.length > 0) { - info(`Obtained data from ${teamData.length} users`); - setOutput("usernames", teamData.map(({ username }) => username).join(",")); - setOutput("team-data", JSON.stringify(teamData)); - } else { - setFailed(`No users were found when searching for the team ${team}`); - } -} - -runAction(context); diff --git a/src/main.rs b/src/main.rs new file mode 100644 index 0000000..3afbefc --- /dev/null +++ b/src/main.rs @@ -0,0 +1,75 @@ +use core::fmt; +use std::env; + +use actions_core::{set_output, LogLevel}; +use anyhow::Result; +use octocrab::Octocrab; + +#[tokio::main] +async fn main() { + let org_input = actions_core::input("organization"); + let org: String = match org_input { + Ok(v) => v, + Err(_) => env::var("GITHUB_REPOSITORY").unwrap(), + }; + + let team_name: String = actions_core::input("team") + .expect("Missing team name") + .parse() + .expect("Failed to parse team name"); + + let token: String = actions_core::input("ACCESS_TOKEN") + .expect("Missing access token") + .parse() + .expect("Failed to parse access token"); + + // println!("Token is {}", token); + + let crab = Octocrab::builder().personal_token(token).build(); + octocrab::initialise(crab.unwrap()); + println!("Hello, world!"); + let team = fetch_team(org, team_name).await.unwrap(); + + if team.is_empty() { + panic!( + "No users where found while searching for the team {}", + "opstooling" + ); + } + + actions_core::debug(format!("Obtained data from {} users", team.len())); + set_output( + "usernames", + team.clone() + .iter() + .map(|member| member.username.clone()) + .collect::>() + .join(","), + ); + set_output("team-data", serde_json::to_string(&team).unwrap()) +} + +#[derive(Debug, Clone, serde_derive::Serialize)] +struct UserData { + pub username: String, + pub url: String, + pub avatar: String, +} + +async fn fetch_team(org: String, team: String) -> Result> { + let team_data = octocrab::instance() + .teams(org) + .members(team) + .per_page(100) + .send() + .await?; + + Ok(team_data + .into_iter() + .map(|member| UserData { + username: member.login, + url: member.html_url.to_string(), + avatar: member.avatar_url.to_string(), + }) + .collect::>()) +} From c5fad410de951fceae010b044f4fc86b8577c1f1 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Thu, 23 May 2024 21:13:18 +0200 Subject: [PATCH 02/32] updated gitignore --- .gitignore | 104 ++++++----------------------------------------------- 1 file changed, 11 insertions(+), 93 deletions(-) diff --git a/.gitignore b/.gitignore index 6704566..456f43b 100644 --- a/.gitignore +++ b/.gitignore @@ -1,104 +1,22 @@ # Logs logs *.log -npm-debug.log* -yarn-debug.log* -yarn-error.log* -lerna-debug.log* - -# Diagnostic reports (https://nodejs.org/api/report.html) -report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json - -# Runtime data -pids -*.pid -*.seed -*.pid.lock - -# Directory for instrumented libs generated by jscoverage/JSCover -lib-cov - -# Coverage directory used by tools like istanbul -coverage -*.lcov - -# nyc test coverage -.nyc_output - -# Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) -.grunt - -# Bower dependency directory (https://bower.io/) -bower_components - -# node-waf configuration -.lock-wscript - -# Compiled binary addons (https://nodejs.org/api/addons.html) -build/Release - -# Dependency directories -node_modules/ -jspm_packages/ - -# TypeScript v1 declaration files -typings/ - -# TypeScript cache -*.tsbuildinfo - -# Optional npm cache directory -.npm - -# Optional eslint cache -.eslintcache - -# Microbundle cache -.rpt2_cache/ -.rts2_cache_cjs/ -.rts2_cache_es/ -.rts2_cache_umd/ - -# Optional REPL history -.node_repl_history - -# Output of 'npm pack' -*.tgz - -# Yarn Integrity file -.yarn-integrity # dotenv environment variables file .env .env.test -# parcel-bundler cache (https://parceljs.org/) -.cache - -# Next.js build output -.next - -# Nuxt.js build / generate output -.nuxt -dist - -# Gatsby files -.cache/ -# Comment in the public line in if your project uses Gatsby and *not* Next.js -# https://nextjs.org/blog/next-9-1#public-directory-support -# public - -# vuepress build output -.vuepress/dist - -# Serverless directories -.serverless/ +# Generated by Cargo +# will have compiled files and executables +debug/ +target/ -# FuseBox cache -.fusebox/ +# Remove Cargo.lock from gitignore if creating an executable, leave it for libraries +# More information here https://doc.rust-lang.org/cargo/guide/cargo-toml-vs-cargo-lock.html +Cargo.lock -# DynamoDB Local files -.dynamodb/ +# These are backup files generated by rustfmt +**/*.rs.bk -# TernJS port file -.tern-port +# MSVC Windows builds of rustc generate these, which store debugging information +*.pdb From 73a3fb83120caa875ddb57232f9bb1c71099de2a Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Thu, 23 May 2024 21:15:51 +0200 Subject: [PATCH 03/32] updated name of exported variable --- src/main.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main.rs b/src/main.rs index 3afbefc..132e035 100644 --- a/src/main.rs +++ b/src/main.rs @@ -46,7 +46,7 @@ async fn main() { .collect::>() .join(","), ); - set_output("team-data", serde_json::to_string(&team).unwrap()) + set_output("data", serde_json::to_string(&team).unwrap()) } #[derive(Debug, Clone, serde_derive::Serialize)] From fe8eb3a8216572ed707911d31ed9d40b13f8308c Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Thu, 23 May 2024 21:15:59 +0200 Subject: [PATCH 04/32] removed unused imports --- src/main.rs | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/src/main.rs b/src/main.rs index 132e035..19dc7ef 100644 --- a/src/main.rs +++ b/src/main.rs @@ -1,7 +1,6 @@ -use core::fmt; use std::env; -use actions_core::{set_output, LogLevel}; +use actions_core::set_output; use anyhow::Result; use octocrab::Octocrab; @@ -23,11 +22,9 @@ async fn main() { .parse() .expect("Failed to parse access token"); - // println!("Token is {}", token); - let crab = Octocrab::builder().personal_token(token).build(); octocrab::initialise(crab.unwrap()); - println!("Hello, world!"); + let team = fetch_team(org, team_name).await.unwrap(); if team.is_empty() { From 7ebda738d54ecbffe4ce0fe3c58a64023a8c892a Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Thu, 23 May 2024 21:16:23 +0200 Subject: [PATCH 05/32] Updated readme --- README.md | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 5efb6a3..5984aec 100644 --- a/README.md +++ b/README.md @@ -124,10 +124,11 @@ Because this project is intended to be used with a token we need to do an extra ``` ## Development + To work on this app, you require -- `Node 18.x` -- `yarn` -Use `yarn install` to set up the project. +- `Rust` + +Use `cargo run` to run the project. -`yarn build` compiles the TypeScript code to JavaScript. +`cargo build` compiles the Rust code to an executable. From 8b97be75b840d20689c7ac55a79abf38e17a6c70 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Thu, 23 May 2024 21:16:30 +0200 Subject: [PATCH 06/32] removed unused files --- package.json | 36 ---------- tsconfig.json | 15 ---- yarn.lock | 191 -------------------------------------------------- 3 files changed, 242 deletions(-) delete mode 100644 package.json delete mode 100644 tsconfig.json delete mode 100644 yarn.lock diff --git a/package.json b/package.json deleted file mode 100644 index a88450b..0000000 --- a/package.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "name": "list-team-members", - "version": "0.0.1", - "description": "Lists all the members of a GitHub Organization's team ", - "main": "src/index.ts", - "engines": { - "node": ">=18.0.0" - }, - "scripts": { - "build": "ncc build" - }, - "repository": { - "type": "git", - "url": "git+https://github.com/paritytech/list-team-members.git" - }, - "keywords": [ - "github", - "action", - "team", - "list" - ], - "author": "Javier Bullrich ", - "license": "MIT", - "bugs": { - "url": "https://github.com/paritytech/list-team-members/issues" - }, - "homepage": "https://github.com/paritytech/list-team-members#readme", - "devDependencies": { - "@vercel/ncc": "^0.36.1", - "typescript": "^5.0.3" - }, - "dependencies": { - "@actions/core": "^1.10.0", - "@actions/github": "^5.1.1" - } -} diff --git a/tsconfig.json b/tsconfig.json deleted file mode 100644 index 188cfa5..0000000 --- a/tsconfig.json +++ /dev/null @@ -1,15 +0,0 @@ -{ - "compilerOptions": { - "target": "es6", - "module": "commonjs", - "outDir": "./dist", - "rootDir": "./src", - "strict": true, - "noImplicitAny": true, - "esModuleInterop": true, - }, - "exclude": [ - "node_modules", - "**/*.test.ts" - ], -} diff --git a/yarn.lock b/yarn.lock deleted file mode 100644 index 58781e4..0000000 --- a/yarn.lock +++ /dev/null @@ -1,191 +0,0 @@ -# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. -# yarn lockfile v1 - - -"@actions/core@^1.10.0": - version "1.10.0" - resolved "https://registry.yarnpkg.com/@actions/core/-/core-1.10.0.tgz#44551c3c71163949a2f06e94d9ca2157a0cfac4f" - integrity sha512-2aZDDa3zrrZbP5ZYg159sNoLRb61nQ7awl5pSvIq5Qpj81vwDzdMRKzkWJGJuwVvWpvZKx7vspJALyvaaIQyug== - dependencies: - "@actions/http-client" "^2.0.1" - uuid "^8.3.2" - -"@actions/github@^5.1.1": - version "5.1.1" - resolved "https://registry.yarnpkg.com/@actions/github/-/github-5.1.1.tgz#40b9b9e1323a5efcf4ff7dadd33d8ea51651bbcb" - integrity sha512-Nk59rMDoJaV+mHCOJPXuvB1zIbomlKS0dmSIqPGxd0enAXBnOfn4VWF+CGtRCwXZG9Epa54tZA7VIRlJDS8A6g== - dependencies: - "@actions/http-client" "^2.0.1" - "@octokit/core" "^3.6.0" - "@octokit/plugin-paginate-rest" "^2.17.0" - "@octokit/plugin-rest-endpoint-methods" "^5.13.0" - -"@actions/http-client@^2.0.1": - version "2.1.0" - resolved "https://registry.yarnpkg.com/@actions/http-client/-/http-client-2.1.0.tgz#b6d8c3934727d6a50d10d19f00a711a964599a9f" - integrity sha512-BonhODnXr3amchh4qkmjPMUO8mFi/zLaaCeCAJZqch8iQqyDnVIkySjB38VHAC8IJ+bnlgfOqlhpyCUZHlQsqw== - dependencies: - tunnel "^0.0.6" - -"@octokit/auth-token@^2.4.4": - version "2.5.0" - resolved "https://registry.yarnpkg.com/@octokit/auth-token/-/auth-token-2.5.0.tgz#27c37ea26c205f28443402477ffd261311f21e36" - integrity sha512-r5FVUJCOLl19AxiuZD2VRZ/ORjp/4IN98Of6YJoJOkY75CIBuYfmiNHGrDwXr+aLGG55igl9QrxX3hbiXlLb+g== - dependencies: - "@octokit/types" "^6.0.3" - -"@octokit/core@^3.6.0": - version "3.6.0" - resolved "https://registry.yarnpkg.com/@octokit/core/-/core-3.6.0.tgz#3376cb9f3008d9b3d110370d90e0a1fcd5fe6085" - integrity sha512-7RKRKuA4xTjMhY+eG3jthb3hlZCsOwg3rztWh75Xc+ShDWOfDDATWbeZpAHBNRpm4Tv9WgBMOy1zEJYXG6NJ7Q== - dependencies: - "@octokit/auth-token" "^2.4.4" - "@octokit/graphql" "^4.5.8" - "@octokit/request" "^5.6.3" - "@octokit/request-error" "^2.0.5" - "@octokit/types" "^6.0.3" - before-after-hook "^2.2.0" - universal-user-agent "^6.0.0" - -"@octokit/endpoint@^6.0.1": - version "6.0.12" - resolved "https://registry.yarnpkg.com/@octokit/endpoint/-/endpoint-6.0.12.tgz#3b4d47a4b0e79b1027fb8d75d4221928b2d05658" - integrity sha512-lF3puPwkQWGfkMClXb4k/eUT/nZKQfxinRWJrdZaJO85Dqwo/G0yOC434Jr2ojwafWJMYqFGFa5ms4jJUgujdA== - dependencies: - "@octokit/types" "^6.0.3" - is-plain-object "^5.0.0" - universal-user-agent "^6.0.0" - -"@octokit/graphql@^4.5.8": - version "4.8.0" - resolved "https://registry.yarnpkg.com/@octokit/graphql/-/graphql-4.8.0.tgz#664d9b11c0e12112cbf78e10f49a05959aa22cc3" - integrity sha512-0gv+qLSBLKF0z8TKaSKTsS39scVKF9dbMxJpj3U0vC7wjNWFuIpL/z76Qe2fiuCbDRcJSavkXsVtMS6/dtQQsg== - dependencies: - "@octokit/request" "^5.6.0" - "@octokit/types" "^6.0.3" - universal-user-agent "^6.0.0" - -"@octokit/openapi-types@^12.11.0": - version "12.11.0" - resolved "https://registry.yarnpkg.com/@octokit/openapi-types/-/openapi-types-12.11.0.tgz#da5638d64f2b919bca89ce6602d059f1b52d3ef0" - integrity sha512-VsXyi8peyRq9PqIz/tpqiL2w3w80OgVMwBHltTml3LmVvXiphgeqmY9mvBw9Wu7e0QWk/fqD37ux8yP5uVekyQ== - -"@octokit/plugin-paginate-rest@^2.17.0": - version "2.21.3" - resolved "https://registry.yarnpkg.com/@octokit/plugin-paginate-rest/-/plugin-paginate-rest-2.21.3.tgz#7f12532797775640dbb8224da577da7dc210c87e" - integrity sha512-aCZTEf0y2h3OLbrgKkrfFdjRL6eSOo8komneVQJnYecAxIej7Bafor2xhuDJOIFau4pk0i/P28/XgtbyPF0ZHw== - dependencies: - "@octokit/types" "^6.40.0" - -"@octokit/plugin-rest-endpoint-methods@^5.13.0": - version "5.16.2" - resolved "https://registry.yarnpkg.com/@octokit/plugin-rest-endpoint-methods/-/plugin-rest-endpoint-methods-5.16.2.tgz#7ee8bf586df97dd6868cf68f641354e908c25342" - integrity sha512-8QFz29Fg5jDuTPXVtey05BLm7OB+M8fnvE64RNegzX7U+5NUXcOcnpTIK0YfSHBg8gYd0oxIq3IZTe9SfPZiRw== - dependencies: - "@octokit/types" "^6.39.0" - deprecation "^2.3.1" - -"@octokit/request-error@^2.0.5", "@octokit/request-error@^2.1.0": - version "2.1.0" - resolved "https://registry.yarnpkg.com/@octokit/request-error/-/request-error-2.1.0.tgz#9e150357831bfc788d13a4fd4b1913d60c74d677" - integrity sha512-1VIvgXxs9WHSjicsRwq8PlR2LR2x6DwsJAaFgzdi0JfJoGSO8mYI/cHJQ+9FbN21aa+DrgNLnwObmyeSC8Rmpg== - dependencies: - "@octokit/types" "^6.0.3" - deprecation "^2.0.0" - once "^1.4.0" - -"@octokit/request@^5.6.0", "@octokit/request@^5.6.3": - version "5.6.3" - resolved "https://registry.yarnpkg.com/@octokit/request/-/request-5.6.3.tgz#19a022515a5bba965ac06c9d1334514eb50c48b0" - integrity sha512-bFJl0I1KVc9jYTe9tdGGpAMPy32dLBXXo1dS/YwSCTL/2nd9XeHsY616RE3HPXDVk+a+dBuzyz5YdlXwcDTr2A== - dependencies: - "@octokit/endpoint" "^6.0.1" - "@octokit/request-error" "^2.1.0" - "@octokit/types" "^6.16.1" - is-plain-object "^5.0.0" - node-fetch "^2.6.7" - universal-user-agent "^6.0.0" - -"@octokit/types@^6.0.3", "@octokit/types@^6.16.1", "@octokit/types@^6.39.0", "@octokit/types@^6.40.0": - version "6.41.0" - resolved "https://registry.yarnpkg.com/@octokit/types/-/types-6.41.0.tgz#e58ef78d78596d2fb7df9c6259802464b5f84a04" - integrity sha512-eJ2jbzjdijiL3B4PrSQaSjuF2sPEQPVCPzBvTHJD9Nz+9dw2SGH4K4xeQJ77YfTq5bRQ+bD8wT11JbeDPmxmGg== - dependencies: - "@octokit/openapi-types" "^12.11.0" - -"@vercel/ncc@^0.36.1": - version "0.36.1" - resolved "https://registry.yarnpkg.com/@vercel/ncc/-/ncc-0.36.1.tgz#d4c01fdbbe909d128d1bf11c7f8b5431654c5b95" - integrity sha512-S4cL7Taa9yb5qbv+6wLgiKVZ03Qfkc4jGRuiUQMQ8HGBD5pcNRnHeYM33zBvJE4/zJGjJJ8GScB+WmTsn9mORw== - -before-after-hook@^2.2.0: - version "2.2.3" - resolved "https://registry.yarnpkg.com/before-after-hook/-/before-after-hook-2.2.3.tgz#c51e809c81a4e354084422b9b26bad88249c517c" - integrity sha512-NzUnlZexiaH/46WDhANlyR2bXRopNg4F/zuSA3OpZnllCUgRaOF2znDioDWrmbNVsuZk6l9pMquQB38cfBZwkQ== - -deprecation@^2.0.0, deprecation@^2.3.1: - version "2.3.1" - resolved "https://registry.yarnpkg.com/deprecation/-/deprecation-2.3.1.tgz#6368cbdb40abf3373b525ac87e4a260c3a700919" - integrity sha512-xmHIy4F3scKVwMsQ4WnVaS8bHOx0DmVwRywosKhaILI0ywMDWPtBSku2HNxRvF7jtwDRsoEwYQSfbxj8b7RlJQ== - -is-plain-object@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/is-plain-object/-/is-plain-object-5.0.0.tgz#4427f50ab3429e9025ea7d52e9043a9ef4159344" - integrity sha512-VRSzKkbMm5jMDoKLbltAkFQ5Qr7VDiTFGXxYFXXowVj387GeGNOCsOH6Msy00SGZ3Fp84b1Naa1psqgcCIEP5Q== - -node-fetch@^2.6.7: - version "2.6.9" - resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.9.tgz#7c7f744b5cc6eb5fd404e0c7a9fec630a55657e6" - integrity sha512-DJm/CJkZkRjKKj4Zi4BsKVZh3ValV5IR5s7LVZnW+6YMh0W1BfNA8XSs6DLMGYlId5F3KnA70uu2qepcR08Qqg== - dependencies: - whatwg-url "^5.0.0" - -once@^1.4.0: - version "1.4.0" - resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" - integrity sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w== - dependencies: - wrappy "1" - -tr46@~0.0.3: - version "0.0.3" - resolved "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a" - integrity sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw== - -tunnel@^0.0.6: - version "0.0.6" - resolved "https://registry.yarnpkg.com/tunnel/-/tunnel-0.0.6.tgz#72f1314b34a5b192db012324df2cc587ca47f92c" - integrity sha512-1h/Lnq9yajKY2PEbBadPXj3VxsDDu844OnaAo52UVmIzIvwwtBPIuNvkjuzBlTWpfJyUbG3ez0KSBibQkj4ojg== - -typescript@^5.0.3: - version "5.0.3" - resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.0.3.tgz#fe976f0c826a88d0a382007681cbb2da44afdedf" - integrity sha512-xv8mOEDnigb/tN9PSMTwSEqAnUvkoXMQlicOb0IUVDBSQCgBSaAAROUZYy2IcUy5qU6XajK5jjjO7TMWqBTKZA== - -universal-user-agent@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/universal-user-agent/-/universal-user-agent-6.0.0.tgz#3381f8503b251c0d9cd21bc1de939ec9df5480ee" - integrity sha512-isyNax3wXoKaulPDZWHQqbmIx1k2tb9fb3GGDBRxCscfYV2Ch7WxPArBsFEG8s/safwXTT7H4QGhaIkTp9447w== - -uuid@^8.3.2: - version "8.3.2" - resolved "https://registry.yarnpkg.com/uuid/-/uuid-8.3.2.tgz#80d5b5ced271bb9af6c445f21a1a04c606cefbe2" - integrity sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg== - -webidl-conversions@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-3.0.1.tgz#24534275e2a7bc6be7bc86611cc16ae0a5654871" - integrity sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ== - -whatwg-url@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-5.0.0.tgz#966454e8765462e37644d3626f6742ce8b70965d" - integrity sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw== - dependencies: - tr46 "~0.0.3" - webidl-conversions "^3.0.0" - -wrappy@1: - version "1.0.2" - resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" - integrity sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ== From 9570d99237a99294e25de5f317b86ac8c9162942 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Thu, 23 May 2024 21:32:02 +0200 Subject: [PATCH 07/32] updated docker image --- Dockerfile | 17 ++++------------- 1 file changed, 4 insertions(+), 13 deletions(-) diff --git a/Dockerfile b/Dockerfile index 52ee472..cea01bf 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,17 +1,8 @@ -FROM node:18 as Builder - -WORKDIR /action - -COPY package.json yarn.lock ./ - -RUN yarn install --frozen-lockfile +FROM rust:1.67 +WORKDIR /usr/src/action COPY . . -RUN yarn run build - -FROM node:18-slim - -COPY --from=Builder /action/dist /action +RUN cargo install --path . -ENTRYPOINT ["node", "/action/index.js"] +CMD ["action"] From 9a23b0be9e067842cc59cb69ad3550e11f214f6b Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Thu, 23 May 2024 21:32:09 +0200 Subject: [PATCH 08/32] added step to test CI --- .github/workflows/test.yml | 50 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100644 .github/workflows/test.yml diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml new file mode 100644 index 0000000..2d12023 --- /dev/null +++ b/.github/workflows/test.yml @@ -0,0 +1,50 @@ +on: [push, pull_request] + +name: Continuous integration + +jobs: + check: + name: Check + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v2 + - uses: actions-rs/toolchain@v1 + with: + profile: minimal + toolchain: stable + override: true + - uses: actions-rs/cargo@v1 + with: + command: check + + fmt: + name: Rustfmt + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v2 + - uses: actions-rs/toolchain@v1 + with: + profile: minimal + toolchain: stable + override: true + - run: rustup component add rustfmt + - uses: actions-rs/cargo@v1 + with: + command: fmt + args: --all -- --check + + clippy: + name: Clippy + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v2 + - uses: actions-rs/toolchain@v1 + with: + profile: minimal + toolchain: stable + override: true + - run: rustup component add clippy + - uses: actions-rs/cargo@v1 + with: + command: clippy + args: -- -D warnings From 5e4a2b568fec7540f0194a22e6710eb7cbc78941 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Thu, 23 May 2024 21:34:41 +0200 Subject: [PATCH 09/32] moved image to run in dockerfile --- action.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/action.yml b/action.yml index a10ad80..ab18ad7 100644 --- a/action.yml +++ b/action.yml @@ -22,4 +22,4 @@ outputs: runs: using: 'docker' - image: 'docker://ghcr.io/paritytech/list-team-members/action:0.0.1' + image: 'Dockerfile' From 41b501146980837804d84e00e1cf966c1f87cbba Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Thu, 23 May 2024 21:34:46 +0200 Subject: [PATCH 10/32] test action on itself --- .github/workflows/test-action.yml | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) create mode 100644 .github/workflows/test-action.yml diff --git a/.github/workflows/test-action.yml b/.github/workflows/test-action.yml new file mode 100644 index 0000000..7c23152 --- /dev/null +++ b/.github/workflows/test-action.yml @@ -0,0 +1,27 @@ +name: Find team members + +on: + pull_request: + +jobs: + get-team: + runs-on: ubuntu-latest + steps: + - name: Fetch team data + # We add the id to access to this step outputs + id: teams + uses: paritytech/list-team-members@rust/migration + with: + ACCESS_TOKEN: ${{ secrets.READ_ORG_PAT }} + team: opstooling + # optional, in case that it searches on a different organization + organization: paritytech + # example showing how to use the content + - name: Show data + run: | + echo "The users are $USERNAMES" + echo "Data: $DATA" + env: + USERNAMES: ${{ steps.teams.outputs.usernames }}" + # a json object + DATA: ${{ steps.teams.outputs.data }}" From 780c0245488d65dbb6dcee031edefcccd2dfaab5 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Thu, 23 May 2024 21:40:45 +0200 Subject: [PATCH 11/32] removed unused dependency --- Cargo.toml | 1 - 1 file changed, 1 deletion(-) diff --git a/Cargo.toml b/Cargo.toml index 73d13e9..78bb3d5 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -8,7 +8,6 @@ edition = "2021" [dependencies] actions-core = "0.0.2" anyhow = "1.0.86" -json = "0.12.4" octocrab = "0.38.0" serde = "1.0.202" serde_derive = "1.0.202" From cc6ae1476d5682615b9eee2364a3c8f2b204f050 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Thu, 23 May 2024 21:40:49 +0200 Subject: [PATCH 12/32] updated docker version --- Dockerfile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Dockerfile b/Dockerfile index cea01bf..f4587b7 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,4 +1,4 @@ -FROM rust:1.67 +FROM rust:1.78 WORKDIR /usr/src/action COPY . . From 0b037aa1fb9e748fbbb37e0454c4d4d50329f7dc Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Thu, 23 May 2024 21:46:16 +0200 Subject: [PATCH 13/32] unified tests into matrix --- .github/workflows/test.yml | 47 ++++++++++---------------------------- 1 file changed, 12 insertions(+), 35 deletions(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 2d12023..3384cdd 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -3,8 +3,16 @@ on: [push, pull_request] name: Continuous integration jobs: - check: - name: Check + test: + name: "Test" + strategy: + matrix: + cmd: [check, fmt,clippy] + include: + - cmd: fmt + args: "--all -- --check" + - cmd: clippy + arg: "-- -D warnings" runs-on: ubuntu-latest steps: - uses: actions/checkout@v2 @@ -15,36 +23,5 @@ jobs: override: true - uses: actions-rs/cargo@v1 with: - command: check - - fmt: - name: Rustfmt - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - uses: actions-rs/toolchain@v1 - with: - profile: minimal - toolchain: stable - override: true - - run: rustup component add rustfmt - - uses: actions-rs/cargo@v1 - with: - command: fmt - args: --all -- --check - - clippy: - name: Clippy - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - uses: actions-rs/toolchain@v1 - with: - profile: minimal - toolchain: stable - override: true - - run: rustup component add clippy - - uses: actions-rs/cargo@v1 - with: - command: clippy - args: -- -D warnings + command: ${{ matrix.cmd }} + args: ${{ matrix.arg }} From 70d0e16d929c70bde33b59145e572c0e41712dc5 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Thu, 23 May 2024 21:48:09 +0200 Subject: [PATCH 14/32] fixed version in test action --- .github/workflows/test.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 3384cdd..1f66213 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -10,12 +10,12 @@ jobs: cmd: [check, fmt,clippy] include: - cmd: fmt - args: "--all -- --check" + arg: "--all -- --check" - cmd: clippy arg: "-- -D warnings" runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v4 - uses: actions-rs/toolchain@v1 with: profile: minimal From 91a220b77043f052cf222b69b404d9707f7dc2a8 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Thu, 23 May 2024 21:54:21 +0200 Subject: [PATCH 15/32] fixed docker image not compiling --- Dockerfile | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/Dockerfile b/Dockerfile index f4587b7..3297241 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,8 +1,12 @@ -FROM rust:1.78 +FROM rust:latest WORKDIR /usr/src/action -COPY . . -RUN cargo install --path . +COPY Cargo.toml . +RUN mkdir src && echo "fn main() {}" > src/main.rs +RUN cargo build --release -CMD ["action"] +COPY src src +RUN touch src/main.rs + +CMD ["cargo", "run", "--release"] From 789a6d5762cf8d2444a66308df892116833b80a6 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Thu, 23 May 2024 21:57:38 +0200 Subject: [PATCH 16/32] removed push from test action --- .github/workflows/test.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 1f66213..1e1a972 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -1,4 +1,5 @@ -on: [push, pull_request] +on: + pull_request: name: Continuous integration From d9d0b90b912190a70f739a712ecda3fa5489fcf6 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Thu, 23 May 2024 22:00:48 +0200 Subject: [PATCH 17/32] removed unnecessary step in dockerimage --- Dockerfile | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/Dockerfile b/Dockerfile index 3297241..629527a 100644 --- a/Dockerfile +++ b/Dockerfile @@ -3,10 +3,9 @@ FROM rust:latest WORKDIR /usr/src/action COPY Cargo.toml . -RUN mkdir src && echo "fn main() {}" > src/main.rs -RUN cargo build --release COPY src src -RUN touch src/main.rs -CMD ["cargo", "run", "--release"] +RUN cargo build --release + +CMD ["/usr/src/action/target/release/list-team-members"] From 87addfb1fc18d57e7cddcb71630806f7cf65d6a7 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Fri, 24 May 2024 17:41:24 +0200 Subject: [PATCH 18/32] updated to use context library --- Cargo.toml | 1 + src/main.rs | 17 ++++++++--------- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 78bb3d5..21b43bd 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -7,6 +7,7 @@ edition = "2021" [dependencies] actions-core = "0.0.2" +actions-github = "0.0.2" anyhow = "1.0.86" octocrab = "0.38.0" serde = "1.0.202" diff --git a/src/main.rs b/src/main.rs index 19dc7ef..b0693f7 100644 --- a/src/main.rs +++ b/src/main.rs @@ -1,16 +1,15 @@ -use std::env; - use actions_core::set_output; +use actions_github::context::get_context; use anyhow::Result; use octocrab::Octocrab; #[tokio::main] async fn main() { - let org_input = actions_core::input("organization"); - let org: String = match org_input { - Ok(v) => v, - Err(_) => env::var("GITHUB_REPOSITORY").unwrap(), + let ctx = match get_context() { + Ok(context) => context, + Err(error) => panic!("{}", error) }; + let org: String = ctx.repo.owner; let team_name: String = actions_core::input("team") .expect("Missing team name") @@ -25,12 +24,12 @@ async fn main() { let crab = Octocrab::builder().personal_token(token).build(); octocrab::initialise(crab.unwrap()); - let team = fetch_team(org, team_name).await.unwrap(); + let team = fetch_team(org, &team_name).await.unwrap(); if team.is_empty() { panic!( "No users where found while searching for the team {}", - "opstooling" + &team_name ); } @@ -53,7 +52,7 @@ struct UserData { pub avatar: String, } -async fn fetch_team(org: String, team: String) -> Result> { +async fn fetch_team(org: String, team: &String) -> Result> { let team_data = octocrab::instance() .teams(org) .members(team) From e9276b033db7de95d1a8bd9c7c9c53b2e4b47f43 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Mon, 27 May 2024 10:27:04 +0200 Subject: [PATCH 19/32] updated library to version 0.0.3 This contains the `get_input` method --- Cargo.toml | 2 +- src/main.rs | 20 +++++++++++--------- 2 files changed, 12 insertions(+), 10 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 21b43bd..8cf0428 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -7,7 +7,7 @@ edition = "2021" [dependencies] actions-core = "0.0.2" -actions-github = "0.0.2" +actions-github = "0.0.3" anyhow = "1.0.86" octocrab = "0.38.0" serde = "1.0.202" diff --git a/src/main.rs b/src/main.rs index b0693f7..6771ed2 100644 --- a/src/main.rs +++ b/src/main.rs @@ -1,5 +1,6 @@ use actions_core::set_output; use actions_github::context::get_context; +use actions_github::core::get_input; use anyhow::Result; use octocrab::Octocrab; @@ -7,19 +8,13 @@ use octocrab::Octocrab; async fn main() { let ctx = match get_context() { Ok(context) => context, - Err(error) => panic!("{}", error) + Err(error) => panic!("{}", error), }; let org: String = ctx.repo.owner; - let team_name: String = actions_core::input("team") - .expect("Missing team name") - .parse() - .expect("Failed to parse team name"); + let team_name:String = get_variable("team", true); - let token: String = actions_core::input("ACCESS_TOKEN") - .expect("Missing access token") - .parse() - .expect("Failed to parse access token"); + let token:String = get_variable("ACCESS_TOKEN", true); let crab = Octocrab::builder().personal_token(token).build(); octocrab::initialise(crab.unwrap()); @@ -52,6 +47,13 @@ struct UserData { pub avatar: String, } +fn get_variable(var_name: &str, required:bool) -> String { + match get_input(var_name) { + Ok(variable) => return variable, + Err(err) => panic!("{}", err) + } +} + async fn fetch_team(org: String, team: &String) -> Result> { let team_data = octocrab::instance() .teams(org) From ffe7d07b5fcf173650cd9c35a4f2bcfcf8dd9e4c Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Mon, 27 May 2024 12:48:51 +0200 Subject: [PATCH 20/32] updated `actions-github` with `set_output` method --- Cargo.toml | 2 +- src/main.rs | 7 +++---- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 8cf0428..3423d60 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -7,7 +7,7 @@ edition = "2021" [dependencies] actions-core = "0.0.2" -actions-github = "0.0.3" +actions-github = "0.0.4" anyhow = "1.0.86" octocrab = "0.38.0" serde = "1.0.202" diff --git a/src/main.rs b/src/main.rs index 6771ed2..ce94a6f 100644 --- a/src/main.rs +++ b/src/main.rs @@ -1,6 +1,5 @@ -use actions_core::set_output; use actions_github::context::get_context; -use actions_github::core::get_input; +use actions_github::core::{get_input, set_output}; use anyhow::Result; use octocrab::Octocrab; @@ -35,9 +34,9 @@ async fn main() { .iter() .map(|member| member.username.clone()) .collect::>() - .join(","), + .join(",").as_str(), ); - set_output("data", serde_json::to_string(&team).unwrap()) + set_output("data", serde_json::to_string(&team).unwrap().as_str())? } #[derive(Debug, Clone, serde_derive::Serialize)] From 9f55e4719f125bd5608a55c5de437e35e85f03f0 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Mon, 27 May 2024 12:52:00 +0200 Subject: [PATCH 21/32] cleaned code issues --- src/main.rs | 31 ++++++++++++++++++++++--------- 1 file changed, 22 insertions(+), 9 deletions(-) diff --git a/src/main.rs b/src/main.rs index ce94a6f..aeb1be5 100644 --- a/src/main.rs +++ b/src/main.rs @@ -11,9 +11,9 @@ async fn main() { }; let org: String = ctx.repo.owner; - let team_name:String = get_variable("team", true); + let team_name: String = get_variable("team", true); - let token:String = get_variable("ACCESS_TOKEN", true); + let token: String = get_variable("ACCESS_TOKEN", true); let crab = Octocrab::builder().personal_token(token).build(); octocrab::initialise(crab.unwrap()); @@ -28,15 +28,22 @@ async fn main() { } actions_core::debug(format!("Obtained data from {} users", team.len())); - set_output( + if let Err(err) = set_output( "usernames", team.clone() .iter() .map(|member| member.username.clone()) .collect::>() - .join(",").as_str(), - ); - set_output("data", serde_json::to_string(&team).unwrap().as_str())? + .join(",") + .as_str(), + ) { + panic!("{:#?}", err); + } + + let data = serde_json::to_string(&team).unwrap(); + if let Err(err) = set_output("data", data.as_str()) { + panic!("{:#?}", err); + } } #[derive(Debug, Clone, serde_derive::Serialize)] @@ -46,10 +53,16 @@ struct UserData { pub avatar: String, } -fn get_variable(var_name: &str, required:bool) -> String { +fn get_variable(var_name: &str, required: bool) -> String { match get_input(var_name) { - Ok(variable) => return variable, - Err(err) => panic!("{}", err) + Ok(variable) => variable, + Err(err) => { + if required { + panic!("{}", err) + } else { + String::from("") + } + } } } From 1bdc9c8e05a551ccbaa5a511e36ca08c609974f2 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Mon, 27 May 2024 15:00:22 +0200 Subject: [PATCH 22/32] updated lib to 0.0.5 Updated the logger --- Cargo.toml | 3 +-- src/main.rs | 3 ++- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 3423d60..1353b75 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -6,8 +6,7 @@ edition = "2021" # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html [dependencies] -actions-core = "0.0.2" -actions-github = "0.0.4" +actions-github = "0.0.5" anyhow = "1.0.86" octocrab = "0.38.0" serde = "1.0.202" diff --git a/src/main.rs b/src/main.rs index aeb1be5..b44de2c 100644 --- a/src/main.rs +++ b/src/main.rs @@ -1,5 +1,6 @@ use actions_github::context::get_context; use actions_github::core::{get_input, set_output}; +use actions_github::logger; use anyhow::Result; use octocrab::Octocrab; @@ -27,7 +28,7 @@ async fn main() { ); } - actions_core::debug(format!("Obtained data from {} users", team.len())); + logger::debug_log(format!("Obtained data from {} users", team.len()).as_str()); if let Err(err) = set_output( "usernames", team.clone() From d31931627917b71c0913b5df6f0781a3f1f70083 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Mon, 27 May 2024 15:03:27 +0200 Subject: [PATCH 23/32] updated all tests --- .github/workflows/test.yml | 34 +++++++++++++++++++--------------- 1 file changed, 19 insertions(+), 15 deletions(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 1e1a972..d12f15d 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -1,5 +1,8 @@ on: pull_request: + push: + branches: + - main name: Continuous integration @@ -7,22 +10,23 @@ jobs: test: name: "Test" strategy: + fail-fast: true matrix: - cmd: [check, fmt,clippy] - include: - - cmd: fmt - arg: "--all -- --check" - - cmd: clippy - arg: "-- -D warnings" + cmd: + - check + - fmt --all -- --check + - clippy -- -D warnings + - doc + - test + - build --release runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - - uses: actions-rs/toolchain@v1 - with: - profile: minimal - toolchain: stable - override: true - - uses: actions-rs/cargo@v1 - with: - command: ${{ matrix.cmd }} - args: ${{ matrix.arg }} + - uses: dtolnay/rust-toolchain@stable + - run: cargo ${{ matrix.cmd }} + conclude: + runs-on: ubuntu-latest + name: All tests passed + needs: [test] + steps: + - run: echo '### Good job! All the tests passed 🚀' >> $GITHUB_STEP_SUMMARY \ No newline at end of file From fc0de69852331072fdc5d8f6e45cf5d0a73979fe Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Mon, 27 May 2024 15:06:19 +0200 Subject: [PATCH 24/32] added cargo.lock --- .gitignore | 4 - Cargo.lock | 1456 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 1456 insertions(+), 4 deletions(-) create mode 100644 Cargo.lock diff --git a/.gitignore b/.gitignore index 456f43b..cff470d 100644 --- a/.gitignore +++ b/.gitignore @@ -11,10 +11,6 @@ logs debug/ target/ -# Remove Cargo.lock from gitignore if creating an executable, leave it for libraries -# More information here https://doc.rust-lang.org/cargo/guide/cargo-toml-vs-cargo-lock.html -Cargo.lock - # These are backup files generated by rustfmt **/*.rs.bk diff --git a/Cargo.lock b/Cargo.lock new file mode 100644 index 0000000..de064e6 --- /dev/null +++ b/Cargo.lock @@ -0,0 +1,1456 @@ +# This file is automatically @generated by Cargo. +# It is not intended for manual editing. +version = 3 + +[[package]] +name = "actions-github" +version = "0.0.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6ee788866c235707df8c36a1a8e61b12da0b13ae3acc439c125af33090e42c3a" +dependencies = [ + "json", + "uuid", +] + +[[package]] +name = "addr2line" +version = "0.21.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8a30b2e23b9e17a9f90641c7ab1549cd9b44f296d3ccbf309d2863cfe398a0cb" +dependencies = [ + "gimli", +] + +[[package]] +name = "adler" +version = "1.0.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f26201604c87b1e01bd3d98f8d5d9a8fcbb815e8cedb41ffccbeb4bf593a35fe" + +[[package]] +name = "android-tzdata" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e999941b234f3131b00bc13c22d06e8c5ff726d1b6318ac7eb276997bbb4fef0" + +[[package]] +name = "android_system_properties" +version = "0.1.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "819e7219dbd41043ac279b19830f2efc897156490d7fd6ea916720117ee66311" +dependencies = [ + "libc", +] + +[[package]] +name = "anyhow" +version = "1.0.86" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b3d1d046238990b9cf5bcde22a3fb3584ee5cf65fb2765f454ed428c7a0063da" + +[[package]] +name = "arc-swap" +version = "1.7.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "69f7f8c3906b62b754cd5326047894316021dcfe5a194c8ea52bdd94934a3457" + +[[package]] +name = "async-trait" +version = "0.1.80" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c6fa2087f2753a7da8cc1c0dbfcf89579dd57458e36769de5ac750b4671737ca" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "autocfg" +version = "1.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0c4b4d0bd25bd0b74681c0ad21497610ce1b7c91b1022cd21c80c6fbdd9476b0" + +[[package]] +name = "backtrace" +version = "0.3.71" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "26b05800d2e817c8b3b4b54abd461726265fa9789ae34330622f2db9ee696f9d" +dependencies = [ + "addr2line", + "cc", + "cfg-if", + "libc", + "miniz_oxide", + "object", + "rustc-demangle", +] + +[[package]] +name = "base64" +version = "0.21.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9d297deb1925b89f2ccc13d7635fa0714f12c87adce1c75356b39ca9b7178567" + +[[package]] +name = "base64" +version = "0.22.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "72b3254f16251a8381aa12e40e3c4d2f0199f8c6508fbecb9d91f575e0fbb8c6" + +[[package]] +name = "bitflags" +version = "2.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "cf4b9d6a944f767f8e5e0db018570623c85f3d925ac718db4e06d0187adb21c1" + +[[package]] +name = "bumpalo" +version = "3.16.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "79296716171880943b8470b5f8d03aa55eb2e645a4874bdbb28adb49162e012c" + +[[package]] +name = "bytes" +version = "1.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "514de17de45fdb8dc022b1a7975556c53c86f9f0aa5f534b98977b171857c2c9" + +[[package]] +name = "cc" +version = "1.0.98" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "41c270e7540d725e65ac7f1b212ac8ce349719624d7bcff99f8e2e488e8cf03f" + +[[package]] +name = "cfg-if" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" + +[[package]] +name = "chrono" +version = "0.4.38" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a21f936df1771bf62b77f047b726c4625ff2e8aa607c01ec06e5a05bd8463401" +dependencies = [ + "android-tzdata", + "iana-time-zone", + "num-traits", + "serde", + "windows-targets 0.52.5", +] + +[[package]] +name = "core-foundation" +version = "0.9.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "91e195e091a93c46f7102ec7818a2aa394e1e1771c3ab4825963fa03e45afb8f" +dependencies = [ + "core-foundation-sys", + "libc", +] + +[[package]] +name = "core-foundation-sys" +version = "0.8.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "06ea2b9bc92be3c2baa9334a323ebca2d6f074ff852cd1d7b11064035cd3868f" + +[[package]] +name = "deranged" +version = "0.3.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b42b6fa04a440b495c8b04d0e71b707c585f83cb9cb28cf8cd0d976c315e31b4" +dependencies = [ + "powerfmt", +] + +[[package]] +name = "either" +version = "1.12.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3dca9240753cf90908d7e4aac30f630662b02aebaa1b58a3cadabdb23385b58b" + +[[package]] +name = "fnv" +version = "1.0.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3f9eec918d3f24069decb9af1554cad7c880e2da24a9afd88aca000531ab82c1" + +[[package]] +name = "form_urlencoded" +version = "1.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e13624c2627564efccf4934284bdd98cbaa14e79b0b5a141218e507b3a823456" +dependencies = [ + "percent-encoding", +] + +[[package]] +name = "futures" +version = "0.3.30" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "645c6916888f6cb6350d2550b80fb63e734897a8498abe35cfb732b6487804b0" +dependencies = [ + "futures-channel", + "futures-core", + "futures-executor", + "futures-io", + "futures-sink", + "futures-task", + "futures-util", +] + +[[package]] +name = "futures-channel" +version = "0.3.30" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "eac8f7d7865dcb88bd4373ab671c8cf4508703796caa2b1985a9ca867b3fcb78" +dependencies = [ + "futures-core", + "futures-sink", +] + +[[package]] +name = "futures-core" +version = "0.3.30" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dfc6580bb841c5a68e9ef15c77ccc837b40a7504914d52e47b8b0e9bbda25a1d" + +[[package]] +name = "futures-executor" +version = "0.3.30" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a576fc72ae164fca6b9db127eaa9a9dda0d61316034f33a0a0d4eda41f02b01d" +dependencies = [ + "futures-core", + "futures-task", + "futures-util", +] + +[[package]] +name = "futures-io" +version = "0.3.30" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a44623e20b9681a318efdd71c299b6b222ed6f231972bfe2f224ebad6311f0c1" + +[[package]] +name = "futures-macro" +version = "0.3.30" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "87750cf4b7a4c0625b1529e4c543c2182106e4dedc60a2a6455e00d212c489ac" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "futures-sink" +version = "0.3.30" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9fb8e00e87438d937621c1c6269e53f536c14d3fbd6a042bb24879e57d474fb5" + +[[package]] +name = "futures-task" +version = "0.3.30" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "38d84fa142264698cdce1a9f9172cf383a0c82de1bddcf3092901442c4097004" + +[[package]] +name = "futures-util" +version = "0.3.30" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3d6401deb83407ab3da39eba7e33987a73c3df0c82b4bb5813ee871c19c41d48" +dependencies = [ + "futures-channel", + "futures-core", + "futures-io", + "futures-macro", + "futures-sink", + "futures-task", + "memchr", + "pin-project-lite", + "pin-utils", + "slab", +] + +[[package]] +name = "getrandom" +version = "0.2.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c4567c8db10ae91089c99af84c68c38da3ec2f087c3f82960bcdbf3656b6f4d7" +dependencies = [ + "cfg-if", + "js-sys", + "libc", + "wasi", + "wasm-bindgen", +] + +[[package]] +name = "gimli" +version = "0.28.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4271d37baee1b8c7e4b708028c57d816cf9d2434acb33a549475f78c181f6253" + +[[package]] +name = "heck" +version = "0.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "95505c38b4572b2d910cecb0281560f54b440a19336cbbcb27bf6ce6adc6f5a8" + +[[package]] +name = "hermit-abi" +version = "0.3.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d231dfb89cfffdbc30e7fc41579ed6066ad03abda9e567ccafae602b97ec5024" + +[[package]] +name = "http" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "21b9ddb458710bc376481b842f5da65cdf31522de232c1ca8146abce2a358258" +dependencies = [ + "bytes", + "fnv", + "itoa", +] + +[[package]] +name = "http-body" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1cac85db508abc24a2e48553ba12a996e87244a0395ce011e62b37158745d643" +dependencies = [ + "bytes", + "http", +] + +[[package]] +name = "http-body-util" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0475f8b2ac86659c21b64320d5d653f9efe42acd2a4e560073ec61a155a34f1d" +dependencies = [ + "bytes", + "futures-core", + "http", + "http-body", + "pin-project-lite", +] + +[[package]] +name = "httparse" +version = "1.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d897f394bad6a705d5f4104762e116a75639e470d80901eed05a860a95cb1904" + +[[package]] +name = "hyper" +version = "1.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fe575dd17d0862a9a33781c8c4696a55c320909004a67a00fb286ba8b1bc496d" +dependencies = [ + "bytes", + "futures-channel", + "futures-util", + "http", + "http-body", + "httparse", + "itoa", + "pin-project-lite", + "smallvec", + "tokio", + "want", +] + +[[package]] +name = "hyper-rustls" +version = "0.26.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a0bea761b46ae2b24eb4aef630d8d1c398157b6fc29e6350ecf090a0b70c952c" +dependencies = [ + "futures-util", + "http", + "hyper", + "hyper-util", + "log", + "rustls", + "rustls-native-certs", + "rustls-pki-types", + "tokio", + "tokio-rustls", + "tower-service", +] + +[[package]] +name = "hyper-timeout" +version = "0.5.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3203a961e5c83b6f5498933e78b6b263e208c197b63e9c6c53cc82ffd3f63793" +dependencies = [ + "hyper", + "hyper-util", + "pin-project-lite", + "tokio", + "tower-service", +] + +[[package]] +name = "hyper-util" +version = "0.1.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ca38ef113da30126bbff9cd1705f9273e15d45498615d138b0c20279ac7a76aa" +dependencies = [ + "bytes", + "futures-channel", + "futures-util", + "http", + "http-body", + "hyper", + "pin-project-lite", + "socket2", + "tokio", + "tower", + "tower-service", + "tracing", +] + +[[package]] +name = "iana-time-zone" +version = "0.1.60" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e7ffbb5a1b541ea2561f8c41c087286cc091e21e556a4f09a8f6cbf17b69b141" +dependencies = [ + "android_system_properties", + "core-foundation-sys", + "iana-time-zone-haiku", + "js-sys", + "wasm-bindgen", + "windows-core", +] + +[[package]] +name = "iana-time-zone-haiku" +version = "0.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f31827a206f56af32e590ba56d5d2d085f558508192593743f16b2306495269f" +dependencies = [ + "cc", +] + +[[package]] +name = "idna" +version = "0.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "634d9b1461af396cad843f47fdba5597a4f9e6ddd4bfb6ff5d85028c25cb12f6" +dependencies = [ + "unicode-bidi", + "unicode-normalization", +] + +[[package]] +name = "iri-string" +version = "0.7.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7f5f6c2df22c009ac44f6f1499308e7a3ac7ba42cd2378475cc691510e1eef1b" +dependencies = [ + "memchr", + "serde", +] + +[[package]] +name = "itoa" +version = "1.0.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "49f1f14873335454500d59611f1cf4a4b0f786f9ac11f4312a78e4cf2566695b" + +[[package]] +name = "js-sys" +version = "0.3.69" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "29c15563dc2726973df627357ce0c9ddddbea194836909d655df6a75d2cf296d" +dependencies = [ + "wasm-bindgen", +] + +[[package]] +name = "json" +version = "0.12.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "078e285eafdfb6c4b434e0d31e8cfcb5115b651496faca5749b88fafd4f23bfd" + +[[package]] +name = "jsonwebtoken" +version = "9.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b9ae10193d25051e74945f1ea2d0b42e03cc3b890f7e4cc5faa44997d808193f" +dependencies = [ + "base64 0.21.7", + "js-sys", + "pem", + "ring", + "serde", + "serde_json", + "simple_asn1", +] + +[[package]] +name = "libc" +version = "0.2.155" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "97b3888a4aecf77e811145cadf6eef5901f4782c53886191b2f693f24761847c" + +[[package]] +name = "list-team-members" +version = "0.1.0" +dependencies = [ + "actions-github", + "anyhow", + "octocrab", + "serde", + "serde_derive", + "serde_json", + "tokio", +] + +[[package]] +name = "log" +version = "0.4.21" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "90ed8c1e510134f979dbc4f070f87d4313098b704861a105fe34231c70a3901c" + +[[package]] +name = "memchr" +version = "2.7.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6c8640c5d730cb13ebd907d8d04b52f55ac9a2eec55b440c8892f40d56c76c1d" + +[[package]] +name = "miniz_oxide" +version = "0.7.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "87dfd01fe195c66b572b37921ad8803d010623c0aca821bea2302239d155cdae" +dependencies = [ + "adler", +] + +[[package]] +name = "mio" +version = "0.8.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a4a650543ca06a924e8b371db273b2756685faae30f8487da1b56505a8f78b0c" +dependencies = [ + "libc", + "wasi", + "windows-sys 0.48.0", +] + +[[package]] +name = "num-bigint" +version = "0.4.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c165a9ab64cf766f73521c0dd2cfdff64f488b8f0b3e621face3462d3db536d7" +dependencies = [ + "num-integer", + "num-traits", +] + +[[package]] +name = "num-conv" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "51d515d32fb182ee37cda2ccdcb92950d6a3c2893aa280e540671c2cd0f3b1d9" + +[[package]] +name = "num-integer" +version = "0.1.46" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7969661fd2958a5cb096e56c8e1ad0444ac2bbcd0061bd28660485a44879858f" +dependencies = [ + "num-traits", +] + +[[package]] +name = "num-traits" +version = "0.2.19" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "071dfc062690e90b734c0b2273ce72ad0ffa95f0c74596bc250dcfd960262841" +dependencies = [ + "autocfg", +] + +[[package]] +name = "num_cpus" +version = "1.16.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4161fcb6d602d4d2081af7c3a45852d875a03dd337a6bfdd6e06407b61342a43" +dependencies = [ + "hermit-abi", + "libc", +] + +[[package]] +name = "object" +version = "0.32.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a6a622008b6e321afc04970976f62ee297fdbaa6f95318ca343e3eebb9648441" +dependencies = [ + "memchr", +] + +[[package]] +name = "octocrab" +version = "0.38.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "68a8a3df00728324ad654ecd1ed449a60157c55b7ff8c109af3a35989687c367" +dependencies = [ + "arc-swap", + "async-trait", + "base64 0.22.1", + "bytes", + "cfg-if", + "chrono", + "either", + "futures", + "futures-util", + "http", + "http-body", + "http-body-util", + "hyper", + "hyper-rustls", + "hyper-timeout", + "hyper-util", + "jsonwebtoken", + "once_cell", + "percent-encoding", + "pin-project", + "secrecy", + "serde", + "serde_json", + "serde_path_to_error", + "serde_urlencoded", + "snafu", + "tokio", + "tower", + "tower-http", + "tracing", + "url", +] + +[[package]] +name = "once_cell" +version = "1.19.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3fdb12b2476b595f9358c5161aa467c2438859caa136dec86c26fdd2efe17b92" + +[[package]] +name = "openssl-probe" +version = "0.1.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ff011a302c396a5197692431fc1948019154afc178baf7d8e37367442a4601cf" + +[[package]] +name = "pem" +version = "3.0.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8e459365e590736a54c3fa561947c84837534b8e9af6fc5bf781307e82658fae" +dependencies = [ + "base64 0.22.1", + "serde", +] + +[[package]] +name = "percent-encoding" +version = "2.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e3148f5046208a5d56bcfc03053e3ca6334e51da8dfb19b6cdc8b306fae3283e" + +[[package]] +name = "pin-project" +version = "1.1.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b6bf43b791c5b9e34c3d182969b4abb522f9343702850a2e57f460d00d09b4b3" +dependencies = [ + "pin-project-internal", +] + +[[package]] +name = "pin-project-internal" +version = "1.1.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2f38a4412a78282e09a2cf38d195ea5420d15ba0602cb375210efbc877243965" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "pin-project-lite" +version = "0.2.14" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bda66fc9667c18cb2758a2ac84d1167245054bcf85d5d1aaa6923f45801bdd02" + +[[package]] +name = "pin-utils" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8b870d8c151b6f2fb93e84a13146138f05d02ed11c7e7c54f8826aaaf7c9f184" + +[[package]] +name = "powerfmt" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "439ee305def115ba05938db6eb1644ff94165c5ab5e9420d1c1bcedbba909391" + +[[package]] +name = "proc-macro2" +version = "1.0.83" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0b33eb56c327dec362a9e55b3ad14f9d2f0904fb5a5b03b513ab5465399e9f43" +dependencies = [ + "unicode-ident", +] + +[[package]] +name = "quote" +version = "1.0.36" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0fa76aaf39101c457836aec0ce2316dbdc3ab723cdda1c6bd4e6ad4208acaca7" +dependencies = [ + "proc-macro2", +] + +[[package]] +name = "ring" +version = "0.17.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c17fa4cb658e3583423e915b9f3acc01cceaee1860e33d59ebae66adc3a2dc0d" +dependencies = [ + "cc", + "cfg-if", + "getrandom", + "libc", + "spin", + "untrusted", + "windows-sys 0.52.0", +] + +[[package]] +name = "rustc-demangle" +version = "0.1.24" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "719b953e2095829ee67db738b3bfa9fa368c94900df327b3f07fe6e794d2fe1f" + +[[package]] +name = "rustls" +version = "0.22.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bf4ef73721ac7bcd79b2b315da7779d8fc09718c6b3d2d1b2d94850eb8c18432" +dependencies = [ + "log", + "ring", + "rustls-pki-types", + "rustls-webpki", + "subtle", + "zeroize", +] + +[[package]] +name = "rustls-native-certs" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8f1fb85efa936c42c6d5fc28d2629bb51e4b2f4b8a5211e297d599cc5a093792" +dependencies = [ + "openssl-probe", + "rustls-pemfile", + "rustls-pki-types", + "schannel", + "security-framework", +] + +[[package]] +name = "rustls-pemfile" +version = "2.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "29993a25686778eb88d4189742cd713c9bce943bc54251a33509dc63cbacf73d" +dependencies = [ + "base64 0.22.1", + "rustls-pki-types", +] + +[[package]] +name = "rustls-pki-types" +version = "1.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "976295e77ce332211c0d24d92c0e83e50f5c5f046d11082cea19f3df13a3562d" + +[[package]] +name = "rustls-webpki" +version = "0.102.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ff448f7e92e913c4b7d4c6d8e4540a1724b319b4152b8aef6d4cf8339712b33e" +dependencies = [ + "ring", + "rustls-pki-types", + "untrusted", +] + +[[package]] +name = "ryu" +version = "1.0.18" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f3cb5ba0dc43242ce17de99c180e96db90b235b8a9fdc9543c96d2209116bd9f" + +[[package]] +name = "schannel" +version = "0.1.23" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fbc91545643bcf3a0bbb6569265615222618bdf33ce4ffbbd13c4bbd4c093534" +dependencies = [ + "windows-sys 0.52.0", +] + +[[package]] +name = "secrecy" +version = "0.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9bd1c54ea06cfd2f6b63219704de0b9b4f72dcc2b8fdef820be6cd799780e91e" +dependencies = [ + "zeroize", +] + +[[package]] +name = "security-framework" +version = "2.11.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c627723fd09706bacdb5cf41499e95098555af3c3c29d014dc3c458ef6be11c0" +dependencies = [ + "bitflags", + "core-foundation", + "core-foundation-sys", + "libc", + "security-framework-sys", +] + +[[package]] +name = "security-framework-sys" +version = "2.11.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "317936bbbd05227752583946b9e66d7ce3b489f84e11a94a510b4437fef407d7" +dependencies = [ + "core-foundation-sys", + "libc", +] + +[[package]] +name = "serde" +version = "1.0.202" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "226b61a0d411b2ba5ff6d7f73a476ac4f8bb900373459cd00fab8512828ba395" +dependencies = [ + "serde_derive", +] + +[[package]] +name = "serde_derive" +version = "1.0.202" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6048858004bcff69094cd972ed40a32500f153bd3be9f716b2eed2e8217c4838" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "serde_json" +version = "1.0.117" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "455182ea6142b14f93f4bc5320a2b31c1f266b66a4a5c858b013302a5d8cbfc3" +dependencies = [ + "itoa", + "ryu", + "serde", +] + +[[package]] +name = "serde_path_to_error" +version = "0.1.16" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "af99884400da37c88f5e9146b7f1fd0fbcae8f6eec4e9da38b67d05486f814a6" +dependencies = [ + "itoa", + "serde", +] + +[[package]] +name = "serde_urlencoded" +version = "0.7.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d3491c14715ca2294c4d6a88f15e84739788c1d030eed8c110436aafdaa2f3fd" +dependencies = [ + "form_urlencoded", + "itoa", + "ryu", + "serde", +] + +[[package]] +name = "simple_asn1" +version = "0.6.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "adc4e5204eb1910f40f9cfa375f6f05b68c3abac4b6fd879c8ff5e7ae8a0a085" +dependencies = [ + "num-bigint", + "num-traits", + "thiserror", + "time", +] + +[[package]] +name = "slab" +version = "0.4.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8f92a496fb766b417c996b9c5e57daf2f7ad3b0bebe1ccfca4856390e3d3bb67" +dependencies = [ + "autocfg", +] + +[[package]] +name = "smallvec" +version = "1.13.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3c5e1a9a646d36c3599cd173a41282daf47c44583ad367b8e6837255952e5c67" + +[[package]] +name = "snafu" +version = "0.8.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "75976f4748ab44f6e5332102be424e7c2dc18daeaf7e725f2040c3ebb133512e" +dependencies = [ + "snafu-derive", +] + +[[package]] +name = "snafu-derive" +version = "0.8.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b4b19911debfb8c2fb1107bc6cb2d61868aaf53a988449213959bb1b5b1ed95f" +dependencies = [ + "heck", + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "socket2" +version = "0.5.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ce305eb0b4296696835b71df73eb912e0f1ffd2556a501fcede6e0c50349191c" +dependencies = [ + "libc", + "windows-sys 0.52.0", +] + +[[package]] +name = "spin" +version = "0.9.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6980e8d7511241f8acf4aebddbb1ff938df5eebe98691418c4468d0b72a96a67" + +[[package]] +name = "subtle" +version = "2.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "81cdd64d312baedb58e21336b31bc043b77e01cc99033ce76ef539f78e965ebc" + +[[package]] +name = "syn" +version = "2.0.65" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d2863d96a84c6439701d7a38f9de935ec562c8832cc55d1dde0f513b52fad106" +dependencies = [ + "proc-macro2", + "quote", + "unicode-ident", +] + +[[package]] +name = "thiserror" +version = "1.0.61" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c546c80d6be4bc6a00c0f01730c08df82eaa7a7a61f11d656526506112cc1709" +dependencies = [ + "thiserror-impl", +] + +[[package]] +name = "thiserror-impl" +version = "1.0.61" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "46c3384250002a6d5af4d114f2845d37b57521033f30d5c3f46c4d70e1197533" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "time" +version = "0.3.36" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5dfd88e563464686c916c7e46e623e520ddc6d79fa6641390f2e3fa86e83e885" +dependencies = [ + "deranged", + "itoa", + "num-conv", + "powerfmt", + "serde", + "time-core", + "time-macros", +] + +[[package]] +name = "time-core" +version = "0.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ef927ca75afb808a4d64dd374f00a2adf8d0fcff8e7b184af886c3c87ec4a3f3" + +[[package]] +name = "time-macros" +version = "0.2.18" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3f252a68540fde3a3877aeea552b832b40ab9a69e318efd078774a01ddee1ccf" +dependencies = [ + "num-conv", + "time-core", +] + +[[package]] +name = "tinyvec" +version = "1.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "87cc5ceb3875bb20c2890005a4e226a4651264a5c75edb2421b52861a0a0cb50" +dependencies = [ + "tinyvec_macros", +] + +[[package]] +name = "tinyvec_macros" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20" + +[[package]] +name = "tokio" +version = "1.37.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1adbebffeca75fcfd058afa480fb6c0b81e165a0323f9c9d39c9697e37c46787" +dependencies = [ + "backtrace", + "libc", + "mio", + "num_cpus", + "pin-project-lite", + "socket2", + "tokio-macros", + "windows-sys 0.48.0", +] + +[[package]] +name = "tokio-macros" +version = "2.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5b8a1e28f2deaa14e508979454cb3a223b10b938b45af148bc0986de36f1923b" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "tokio-rustls" +version = "0.25.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "775e0c0f0adb3a2f22a00c4745d728b479985fc15ee7ca6a2608388c5569860f" +dependencies = [ + "rustls", + "rustls-pki-types", + "tokio", +] + +[[package]] +name = "tokio-util" +version = "0.7.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9cf6b47b3771c49ac75ad09a6162f53ad4b8088b76ac60e8ec1455b31a189fe1" +dependencies = [ + "bytes", + "futures-core", + "futures-sink", + "pin-project-lite", + "tokio", +] + +[[package]] +name = "tower" +version = "0.4.13" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b8fa9be0de6cf49e536ce1851f987bd21a43b771b09473c3549a6c853db37c1c" +dependencies = [ + "futures-core", + "futures-util", + "pin-project", + "pin-project-lite", + "tokio", + "tokio-util", + "tower-layer", + "tower-service", + "tracing", +] + +[[package]] +name = "tower-http" +version = "0.5.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1e9cd434a998747dd2c4276bc96ee2e0c7a2eadf3cae88e52be55a05fa9053f5" +dependencies = [ + "bitflags", + "bytes", + "futures-util", + "http", + "http-body", + "http-body-util", + "iri-string", + "pin-project-lite", + "tower", + "tower-layer", + "tower-service", + "tracing", +] + +[[package]] +name = "tower-layer" +version = "0.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c20c8dbed6283a09604c3e69b4b7eeb54e298b8a600d4d5ecb5ad39de609f1d0" + +[[package]] +name = "tower-service" +version = "0.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b6bc1c9ce2b5135ac7f93c72918fc37feb872bdc6a5533a8b85eb4b86bfdae52" + +[[package]] +name = "tracing" +version = "0.1.40" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c3523ab5a71916ccf420eebdf5521fcef02141234bbc0b8a49f2fdc4544364ef" +dependencies = [ + "log", + "pin-project-lite", + "tracing-attributes", + "tracing-core", +] + +[[package]] +name = "tracing-attributes" +version = "0.1.27" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "34704c8d6ebcbc939824180af020566b01a7c01f80641264eba0999f6c2b6be7" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "tracing-core" +version = "0.1.32" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c06d3da6113f116aaee68e4d601191614c9053067f9ab7f6edbcb161237daa54" +dependencies = [ + "once_cell", +] + +[[package]] +name = "try-lock" +version = "0.2.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e421abadd41a4225275504ea4d6566923418b7f05506fbc9c0fe86ba7396114b" + +[[package]] +name = "unicode-bidi" +version = "0.3.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "08f95100a766bf4f8f28f90d77e0a5461bbdb219042e7679bebe79004fed8d75" + +[[package]] +name = "unicode-ident" +version = "1.0.12" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b" + +[[package]] +name = "unicode-normalization" +version = "0.1.23" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a56d1686db2308d901306f92a263857ef59ea39678a5458e7cb17f01415101f5" +dependencies = [ + "tinyvec", +] + +[[package]] +name = "untrusted" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8ecb6da28b8a351d773b68d5825ac39017e680750f980f3a1a85cd8dd28a47c1" + +[[package]] +name = "url" +version = "2.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "31e6302e3bb753d46e83516cae55ae196fc0c309407cf11ab35cc51a4c2a4633" +dependencies = [ + "form_urlencoded", + "idna", + "percent-encoding", + "serde", +] + +[[package]] +name = "uuid" +version = "1.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a183cf7feeba97b4dd1c0d46788634f6221d87fa961b305bed08c851829efcc0" +dependencies = [ + "getrandom", +] + +[[package]] +name = "want" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bfa7760aed19e106de2c7c0b581b509f2f25d3dacaf737cb82ac61bc6d760b0e" +dependencies = [ + "try-lock", +] + +[[package]] +name = "wasi" +version = "0.11.0+wasi-snapshot-preview1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" + +[[package]] +name = "wasm-bindgen" +version = "0.2.92" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4be2531df63900aeb2bca0daaaddec08491ee64ceecbee5076636a3b026795a8" +dependencies = [ + "cfg-if", + "wasm-bindgen-macro", +] + +[[package]] +name = "wasm-bindgen-backend" +version = "0.2.92" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "614d787b966d3989fa7bb98a654e369c762374fd3213d212cfc0251257e747da" +dependencies = [ + "bumpalo", + "log", + "once_cell", + "proc-macro2", + "quote", + "syn", + "wasm-bindgen-shared", +] + +[[package]] +name = "wasm-bindgen-macro" +version = "0.2.92" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a1f8823de937b71b9460c0c34e25f3da88250760bec0ebac694b49997550d726" +dependencies = [ + "quote", + "wasm-bindgen-macro-support", +] + +[[package]] +name = "wasm-bindgen-macro-support" +version = "0.2.92" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e94f17b526d0a461a191c78ea52bbce64071ed5c04c9ffe424dcb38f74171bb7" +dependencies = [ + "proc-macro2", + "quote", + "syn", + "wasm-bindgen-backend", + "wasm-bindgen-shared", +] + +[[package]] +name = "wasm-bindgen-shared" +version = "0.2.92" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "af190c94f2773fdb3729c55b007a722abb5384da03bc0986df4c289bf5567e96" + +[[package]] +name = "windows-core" +version = "0.52.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "33ab640c8d7e35bf8ba19b884ba838ceb4fba93a4e8c65a9059d08afcfc683d9" +dependencies = [ + "windows-targets 0.52.5", +] + +[[package]] +name = "windows-sys" +version = "0.48.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "677d2418bec65e3338edb076e806bc1ec15693c5d0104683f2efe857f61056a9" +dependencies = [ + "windows-targets 0.48.5", +] + +[[package]] +name = "windows-sys" +version = "0.52.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d" +dependencies = [ + "windows-targets 0.52.5", +] + +[[package]] +name = "windows-targets" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9a2fa6e2155d7247be68c096456083145c183cbbbc2764150dda45a87197940c" +dependencies = [ + "windows_aarch64_gnullvm 0.48.5", + "windows_aarch64_msvc 0.48.5", + "windows_i686_gnu 0.48.5", + "windows_i686_msvc 0.48.5", + "windows_x86_64_gnu 0.48.5", + "windows_x86_64_gnullvm 0.48.5", + "windows_x86_64_msvc 0.48.5", +] + +[[package]] +name = "windows-targets" +version = "0.52.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6f0713a46559409d202e70e28227288446bf7841d3211583a4b53e3f6d96e7eb" +dependencies = [ + "windows_aarch64_gnullvm 0.52.5", + "windows_aarch64_msvc 0.52.5", + "windows_i686_gnu 0.52.5", + "windows_i686_gnullvm", + "windows_i686_msvc 0.52.5", + "windows_x86_64_gnu 0.52.5", + "windows_x86_64_gnullvm 0.52.5", + "windows_x86_64_msvc 0.52.5", +] + +[[package]] +name = "windows_aarch64_gnullvm" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8" + +[[package]] +name = "windows_aarch64_gnullvm" +version = "0.52.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7088eed71e8b8dda258ecc8bac5fb1153c5cffaf2578fc8ff5d61e23578d3263" + +[[package]] +name = "windows_aarch64_msvc" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc" + +[[package]] +name = "windows_aarch64_msvc" +version = "0.52.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9985fd1504e250c615ca5f281c3f7a6da76213ebd5ccc9561496568a2752afb6" + +[[package]] +name = "windows_i686_gnu" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e" + +[[package]] +name = "windows_i686_gnu" +version = "0.52.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "88ba073cf16d5372720ec942a8ccbf61626074c6d4dd2e745299726ce8b89670" + +[[package]] +name = "windows_i686_gnullvm" +version = "0.52.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "87f4261229030a858f36b459e748ae97545d6f1ec60e5e0d6a3d32e0dc232ee9" + +[[package]] +name = "windows_i686_msvc" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406" + +[[package]] +name = "windows_i686_msvc" +version = "0.52.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "db3c2bf3d13d5b658be73463284eaf12830ac9a26a90c717b7f771dfe97487bf" + +[[package]] +name = "windows_x86_64_gnu" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e" + +[[package]] +name = "windows_x86_64_gnu" +version = "0.52.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4e4246f76bdeff09eb48875a0fd3e2af6aada79d409d33011886d3e1581517d9" + +[[package]] +name = "windows_x86_64_gnullvm" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc" + +[[package]] +name = "windows_x86_64_gnullvm" +version = "0.52.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "852298e482cd67c356ddd9570386e2862b5673c85bd5f88df9ab6802b334c596" + +[[package]] +name = "windows_x86_64_msvc" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538" + +[[package]] +name = "windows_x86_64_msvc" +version = "0.52.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bec47e5bfd1bff0eeaf6d8b485cc1074891a197ab4225d504cb7a1ab88b02bf0" + +[[package]] +name = "zeroize" +version = "1.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "525b4ec142c6b68a2d10f01f7bbf6755599ca3f81ea53b8431b7dd348f5fdb2d" From c4fc61e6bb666b754fd684ebe47451f48035f57e Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Mon, 27 May 2024 15:06:35 +0200 Subject: [PATCH 25/32] added actions/cache to github action --- .github/workflows/test.yml | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index d12f15d..24a6e7d 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -23,6 +23,15 @@ jobs: steps: - uses: actions/checkout@v4 - uses: dtolnay/rust-toolchain@stable + - uses: actions/cache@v4 + with: + path: | + ~/.cargo/bin/ + ~/.cargo/registry/index/ + ~/.cargo/registry/cache/ + ~/.cargo/git/db/ + target/ + key: ${{ runner.os }}-cargo-${{ hashFiles('**/Cargo.lock') }} - run: cargo ${{ matrix.cmd }} conclude: runs-on: ubuntu-latest From af61e5f45d49bbe3f9a8cee14a7f5cdc9fd6ce3f Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Tue, 28 May 2024 11:07:02 +0200 Subject: [PATCH 26/32] applied code changes --- src/main.rs | 29 ++++++----------------------- 1 file changed, 6 insertions(+), 23 deletions(-) diff --git a/src/main.rs b/src/main.rs index b44de2c..c547518 100644 --- a/src/main.rs +++ b/src/main.rs @@ -6,15 +6,12 @@ use octocrab::Octocrab; #[tokio::main] async fn main() { - let ctx = match get_context() { - Ok(context) => context, - Err(error) => panic!("{}", error), - }; + let ctx = get_context().expect("Failed to resolve GHA context"); let org: String = ctx.repo.owner; - let team_name: String = get_variable("team", true); + let team_name: String = get_input("team").expect("Failed to get 'team' input"); - let token: String = get_variable("ACCESS_TOKEN", true); + let token: String = get_input("ACCESS_TOKEN").expect("Failed to get 'ACCESS_TOKEN' input"); let crab = Octocrab::builder().personal_token(token).build(); octocrab::initialise(crab.unwrap()); @@ -29,7 +26,7 @@ async fn main() { } logger::debug_log(format!("Obtained data from {} users", team.len()).as_str()); - if let Err(err) = set_output( + set_output( "usernames", team.clone() .iter() @@ -37,9 +34,8 @@ async fn main() { .collect::>() .join(",") .as_str(), - ) { - panic!("{:#?}", err); - } + ) + .expect("set_output failed"); let data = serde_json::to_string(&team).unwrap(); if let Err(err) = set_output("data", data.as_str()) { @@ -54,19 +50,6 @@ struct UserData { pub avatar: String, } -fn get_variable(var_name: &str, required: bool) -> String { - match get_input(var_name) { - Ok(variable) => variable, - Err(err) => { - if required { - panic!("{}", err) - } else { - String::from("") - } - } - } -} - async fn fetch_team(org: String, team: &String) -> Result> { let team_data = octocrab::instance() .teams(org) From a3bdb89a7a340f9df6fd3db50c0d4b9c363a2442 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Tue, 28 May 2024 11:31:46 +0200 Subject: [PATCH 27/32] removed clone from team --- src/main.rs | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/main.rs b/src/main.rs index c547518..d61e173 100644 --- a/src/main.rs +++ b/src/main.rs @@ -28,8 +28,7 @@ async fn main() { logger::debug_log(format!("Obtained data from {} users", team.len()).as_str()); set_output( "usernames", - team.clone() - .iter() + team.iter() .map(|member| member.username.clone()) .collect::>() .join(",") From e8bdcecc3443f1e0378496fc85b74e95503269ba Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Tue, 28 May 2024 14:00:41 +0200 Subject: [PATCH 28/32] updated CI to use crate instead of package --- .github/workflows/publish.yml | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/.github/workflows/publish.yml b/.github/workflows/publish.yml index dc8e837..d3b9f2d 100644 --- a/.github/workflows/publish.yml +++ b/.github/workflows/publish.yml @@ -12,17 +12,22 @@ jobs: test-image: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v3.3.0 + - uses: actions/checkout@v4 - name: Check that the image builds run: docker build . --file Dockerfile test-versions: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v3.3.0 - - name: Extract package.json version + - uses: actions/checkout@v4 + - name: Set up Python + uses: actions/setup-python@v2 + with: + python-version: 3.8 + - run: pip install toml-cli + - name: Extract crate version id: package_version - run: echo "VERSION=$(jq '.version' -r package.json)" >> $GITHUB_OUTPUT + run: echo "VERSION=$(toml get --toml-path Cargo.toml package.version)" >> $GITHUB_OUTPUT - name: Extract action.yml version uses: mikefarah/yq@master id: action_image From a8ac16f5d36c8429691268e73390e2f5c929364b Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Tue, 28 May 2024 14:08:44 +0200 Subject: [PATCH 29/32] updated CI to upload version --- .github/workflows/publish.yml | 122 ++++++++++++---------------------- 1 file changed, 43 insertions(+), 79 deletions(-) diff --git a/.github/workflows/publish.yml b/.github/workflows/publish.yml index d3b9f2d..5580a06 100644 --- a/.github/workflows/publish.yml +++ b/.github/workflows/publish.yml @@ -7,6 +7,7 @@ on: env: IMAGE_NAME: action + REGISTRY: ghcr.io jobs: test-image: @@ -16,98 +17,61 @@ jobs: - name: Check that the image builds run: docker build . --file Dockerfile - test-versions: + compare-versions: runs-on: ubuntu-latest + outputs: + version: ${{ steps.verification.outputs.VERSION }} + exists: ${{ steps.checkTag.outputs.exists }} steps: - uses: actions/checkout@v4 - - name: Set up Python - uses: actions/setup-python@v2 - with: - python-version: 3.8 - run: pip install toml-cli - name: Extract crate version id: package_version run: echo "VERSION=$(toml get --toml-path Cargo.toml package.version)" >> $GITHUB_OUTPUT - - name: Extract action.yml version - uses: mikefarah/yq@master - id: action_image - with: - cmd: yq '.runs.image' 'action.yml' - - name: Parse action.yml version - id: action_version - run: | - echo "IMAGE_VERSION=$(echo $IMAGE_URL | cut -d: -f3)" >> $GITHUB_OUTPUT - env: - IMAGE_URL: ${{ steps.action_image.outputs.result }} + # Compare that the versions contain the same name - name: Compare versions - run: | - echo "Verifying that $IMAGE_VERSION from action.yml is the same as $PACKAGE_VERSION from package.json" - [[ $IMAGE_VERSION == $PACKAGE_VERSION ]] - env: - IMAGE_VERSION: ${{ steps.action_version.outputs.IMAGE_VERSION }} - PACKAGE_VERSION: ${{ steps.package_version.outputs.VERSION }} + id: verification + uses: Bullrich/compare-version-on-action@main + with: + version: ${{ steps.package_version.outputs.VERSION }} + # Verifies if there is a tag with that version number + - uses: mukunku/tag-exists-action@v1.6.0 + if: steps.verification.outputs.VERSION + id: checkTag + with: + tag: v${{ steps.package_version.outputs.VERSION }} - tag: - if: github.event_name == 'push' - needs: [test-image, test-versions] + publish: + if: github.event_name == 'push' && needs.compare-versions.outputs.exists == 'false' + needs: [test-image, compare-versions] runs-on: ubuntu-latest permissions: contents: write - outputs: - tagcreated: ${{ steps.autotag.outputs.tagcreated }} - tagname: ${{ steps.autotag.outputs.tagname }} + packages: write steps: - - uses: actions/checkout@v3.3.0 + - uses: actions/checkout@v4 + - name: Tag version and create release + run: gh release create $VERSION --generate-notes + env: + VERSION: v${{ needs.compare-versions.outputs.version }} + GH_TOKEN: ${{ github.token }} + - name: Log in to the Container registry + uses: docker/login-action@v3.1.0 with: - fetch-depth: 0 - - uses: butlerlogic/action-autotag@stable - id: autotag + registry: ${{ env.REGISTRY }} + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + - name: Extract metadata (tags, labels) for Docker + id: meta + uses: docker/metadata-action@v5 with: - head_branch: master - tag_prefix: "v" - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - - name: Changelog - uses: Bullrich/generate-release-changelog@2.0.2 - id: Changelog - env: - REPO: ${{ github.repository }} - - name: Create Release - if: steps.autotag.outputs.tagname != '' - uses: actions/create-release@latest - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + images: ${{ env.REGISTRY }}/${{ github.repository }}/${{ env.IMAGE_NAME }} + tags: ${{ needs.compare-versions.outputs.version }} + - uses: actions/checkout@v4 + - name: Build and push Docker image + uses: docker/build-push-action@v5.3.0 with: - tag_name: ${{ steps.autotag.outputs.tagname }} - release_name: Release ${{ steps.autotag.outputs.tagname }} - body: | - ${{ steps.Changelog.outputs.changelog }} - publish: - runs-on: ubuntu-latest - permissions: - packages: write - needs: [tag] - if: needs.tag.outputs.tagname != '' - steps: - - uses: actions/checkout@v3 - - name: Build image - run: docker build . --file Dockerfile --tag $IMAGE_NAME - - name: Log into registry - run: echo "${{ secrets.GITHUB_TOKEN }}" | docker login docker.pkg.github.com -u ${{ github.actor }} --password-stdin - - name: Push image - run: | - IMAGE_ID=docker.pkg.github.com/${{ github.repository }}/$IMAGE_NAME - # Change all uppercase to lowercase - IMAGE_ID=$(echo $IMAGE_ID | tr '[A-Z]' '[a-z]') - # Strip git ref prefix from version - VERSION=$(echo "${{ github.ref }}" | sed -e 's,.*/\(.*\),\1,') - # Strip "v" prefix from tag name - [[ ! -z $TAG ]] && VERSION=$(echo $TAG | sed -e 's/^v//') - # Use Docker `latest` tag convention - [ "$VERSION" == "main" ] && VERSION=latest - echo IMAGE_ID=$IMAGE_ID - echo VERSION=$VERSION - docker tag $IMAGE_NAME $IMAGE_ID:$VERSION - docker push $IMAGE_ID:$VERSION - env: - TAG: ${{ needs.tag.outputs.tagname }} + context: . + push: true + tags: ${{ steps.meta.outputs.tags }} + labels: ${{ steps.meta.outputs.labels }} From df95400e44ac1c903ee2f91871e84987a8b083b3 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Tue, 28 May 2024 14:10:21 +0200 Subject: [PATCH 30/32] restored old action version --- action.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/action.yml b/action.yml index ab18ad7..a10ad80 100644 --- a/action.yml +++ b/action.yml @@ -22,4 +22,4 @@ outputs: runs: using: 'docker' - image: 'Dockerfile' + image: 'docker://ghcr.io/paritytech/list-team-members/action:0.0.1' From e9a1149c08937e0c24c311438ced0dc3d181f0df Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Tue, 28 May 2024 14:10:40 +0200 Subject: [PATCH 31/32] updated version to match cargo.toml --- action.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/action.yml b/action.yml index a10ad80..9fb8f3e 100644 --- a/action.yml +++ b/action.yml @@ -22,4 +22,4 @@ outputs: runs: using: 'docker' - image: 'docker://ghcr.io/paritytech/list-team-members/action:0.0.1' + image: 'docker://ghcr.io/paritytech/list-team-members/action:0.1.0' From f28f80e12785f0a4dbf12ce825fcc5de2e21c060 Mon Sep 17 00:00:00 2001 From: Javier Bullrich Date: Tue, 28 May 2024 14:13:02 +0200 Subject: [PATCH 32/32] updated test-action to point to main --- .github/workflows/test-action.yml | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/.github/workflows/test-action.yml b/.github/workflows/test-action.yml index 7c23152..e8957ae 100644 --- a/.github/workflows/test-action.yml +++ b/.github/workflows/test-action.yml @@ -2,6 +2,9 @@ name: Find team members on: pull_request: + push: + branches: + - main jobs: get-team: @@ -10,7 +13,7 @@ jobs: - name: Fetch team data # We add the id to access to this step outputs id: teams - uses: paritytech/list-team-members@rust/migration + uses: paritytech/list-team-members@main with: ACCESS_TOKEN: ${{ secrets.READ_ORG_PAT }} team: opstooling