diff --git a/404.html b/404.html index 6760cf9186..534cfc3431 100644 --- a/404.html +++ b/404.html @@ -17,8 +17,8 @@ - - + +
@@ -33,7 +33,7 @@ @packit@fosstodon.org (Mastodon)
- - + + \ No newline at end of file diff --git a/agile.html b/agile.html index 4800726d1f..e15602626d 100644 --- a/agile.html +++ b/agile.html @@ -17,8 +17,8 @@ - - + +
@@ -33,7 +33,7 @@ @packit@fosstodon.org (Mastodon)
- - + + \ No newline at end of file diff --git a/agile/kanban.html b/agile/kanban.html index 5f230a7e1e..044fe6721d 100644 --- a/agile/kanban.html +++ b/agile/kanban.html @@ -17,8 +17,8 @@ - - + +
@@ -36,7 +36,7 @@ @packit@fosstodon.org (Mastodon)
- - + + \ No newline at end of file diff --git a/agile/meetings.html b/agile/meetings.html index 6c64fcb7eb..ee82834e41 100644 --- a/agile/meetings.html +++ b/agile/meetings.html @@ -17,8 +17,8 @@ - - + +
@@ -35,7 +35,7 @@ @packit@fosstodon.org (Mastodon)
- - + + \ No newline at end of file diff --git a/agile/roles.html b/agile/roles.html index fdee39fd38..138e76e26d 100644 --- a/agile/roles.html +++ b/agile/roles.html @@ -17,8 +17,8 @@ - - + +
@@ -36,7 +36,7 @@ @packit@fosstodon.org (Mastodon)
- - + + \ No newline at end of file diff --git a/agile/weekly-roles.html b/agile/weekly-roles.html index 4dae726297..2d699f3e02 100644 --- a/agile/weekly-roles.html +++ b/agile/weekly-roles.html @@ -17,8 +17,8 @@ - - + +
@@ -37,7 +37,7 @@ @packit@fosstodon.org (Mastodon)
- - + + \ No newline at end of file diff --git a/assets/js/03d8c9c7.29867162.js b/assets/js/03d8c9c7.29867162.js new file mode 100644 index 0000000000..26daffd171 --- /dev/null +++ b/assets/js/03d8c9c7.29867162.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[3528],{3905:(e,t,r)=>{r.d(t,{Zo:()=>u,kt:()=>k});var a=r(67294);function n(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function i(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,a)}return r}function o(e){for(var t=1;t=0||(n[r]=e[r]);return n}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(n[r]=e[r])}return n}var c=a.createContext({}),p=function(e){var t=a.useContext(c),r=t;return e&&(r="function"==typeof e?e(t):o(o({},t),e)),r},u=function(e){var t=p(e.components);return a.createElement(c.Provider,{value:t},e.children)},s="mdxType",y={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},m=a.forwardRef((function(e,t){var r=e.components,n=e.mdxType,i=e.originalType,c=e.parentName,u=l(e,["components","mdxType","originalType","parentName"]),s=p(r),m=n,k=s["".concat(c,".").concat(m)]||s[m]||y[m]||i;return r?a.createElement(k,o(o({ref:t},u),{},{components:r})):a.createElement(k,o({ref:t},u))}));function k(e,t){var r=arguments,n=t&&t.mdxType;if("string"==typeof e||n){var i=r.length,o=new Array(i);o[0]=m;var l={};for(var c in t)hasOwnProperty.call(t,c)&&(l[c]=t[c]);l.originalType=e,l[s]="string"==typeof e?e:n,o[1]=l;for(var p=2;p{r.r(t),r.d(t,{assets:()=>c,contentTitle:()=>o,default:()=>y,frontMatter:()=>i,metadata:()=>l,toc:()=>p});var a=r(87462),n=(r(67294),r(3905));const i={title:"Week 1 in Packit",date:new Date("2025-01-06T00:00:00.000Z"),authors:"lbarczio",tags:["2025-January",2025,"January"]},o=void 0,l={permalink:"/posts/weekly/2025/week-1",editUrl:"https://github.com/packit/packit.dev/tree/main/weekly/2025/week-1.md",source:"@site/weekly/2025/week-1.md",title:"Week 1 in Packit",description:"Week 1 (January 2nd \u2013 January 6th)",date:"2025-01-06T00:00:00.000Z",formattedDate:"January 6, 2025",tags:[{label:"2025-January",permalink:"/posts/weekly/tags/2025-january"},{label:"2025",permalink:"/posts/weekly/tags/2025"},{label:"January",permalink:"/posts/weekly/tags/january"}],readingTime:.105,hasTruncateMarker:!1,authors:[{name:"Laura Barcziov\xe1",email:"lbarczio@redhat.com",url:"https://github.com/lbarcziova",imageURL:"https://github.com/lbarcziova.png",key:"lbarczio"}],frontMatter:{title:"Week 1 in Packit",date:"2025-01-06T00:00:00.000Z",authors:"lbarczio",tags:["2025-January","2025","January"]},prevItem:{title:"Week 2 in Packit",permalink:"/posts/weekly/2025/week-2"},nextItem:{title:"Week 50 in Packit",permalink:"/posts/weekly/2024/week-50"}},c={authorsImageUrls:[void 0]},p=[{value:"Week 1 (January 2nd \u2013 January 6th)",id:"week-1-january-2nd--january-6th",level:2}],u={toc:p},s="wrapper";function y(e){let{components:t,...r}=e;return(0,n.kt)(s,(0,a.Z)({},u,r,{components:t,mdxType:"MDXLayout"}),(0,n.kt)("h2",{id:"week-1-january-2nd--january-6th"},"Week 1 (January 2nd \u2013 January 6th)"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"We have improved fallback commit status reporting via comments in GitLab. (",(0,n.kt)("a",{parentName:"li",href:"https://github.com/packit/packit-service/pull/2686"},"packit-service#2686"),")")))}y.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/03d8c9c7.806bfc15.js b/assets/js/03d8c9c7.806bfc15.js deleted file mode 100644 index 5a98bf94ff..0000000000 --- a/assets/js/03d8c9c7.806bfc15.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[3528],{3905:(e,t,r)=>{r.d(t,{Zo:()=>p,kt:()=>k});var a=r(67294);function n(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function o(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,a)}return r}function i(e){for(var t=1;t=0||(n[r]=e[r]);return n}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(n[r]=e[r])}return n}var l=a.createContext({}),u=function(e){var t=a.useContext(l),r=t;return e&&(r="function"==typeof e?e(t):i(i({},t),e)),r},p=function(e){var t=u(e.components);return a.createElement(l.Provider,{value:t},e.children)},s="mdxType",y={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},m=a.forwardRef((function(e,t){var r=e.components,n=e.mdxType,o=e.originalType,l=e.parentName,p=c(e,["components","mdxType","originalType","parentName"]),s=u(r),m=n,k=s["".concat(l,".").concat(m)]||s[m]||y[m]||o;return r?a.createElement(k,i(i({ref:t},p),{},{components:r})):a.createElement(k,i({ref:t},p))}));function k(e,t){var r=arguments,n=t&&t.mdxType;if("string"==typeof e||n){var o=r.length,i=new Array(o);i[0]=m;var c={};for(var l in t)hasOwnProperty.call(t,l)&&(c[l]=t[l]);c.originalType=e,c[s]="string"==typeof e?e:n,i[1]=c;for(var u=2;u{r.r(t),r.d(t,{assets:()=>l,contentTitle:()=>i,default:()=>y,frontMatter:()=>o,metadata:()=>c,toc:()=>u});var a=r(87462),n=(r(67294),r(3905));const o={title:"Week 1 in Packit",date:new Date("2025-01-06T00:00:00.000Z"),authors:"lbarczio",tags:["2025-January",2025,"January"]},i=void 0,c={permalink:"/posts/weekly/2025/week-1",editUrl:"https://github.com/packit/packit.dev/tree/main/weekly/2025/week-1.md",source:"@site/weekly/2025/week-1.md",title:"Week 1 in Packit",description:"Week 1 (January 2nd \u2013 January 6th)",date:"2025-01-06T00:00:00.000Z",formattedDate:"January 6, 2025",tags:[{label:"2025-January",permalink:"/posts/weekly/tags/2025-january"},{label:"2025",permalink:"/posts/weekly/tags/2025"},{label:"January",permalink:"/posts/weekly/tags/january"}],readingTime:.105,hasTruncateMarker:!1,authors:[{name:"Laura Barcziov\xe1",email:"lbarczio@redhat.com",url:"https://github.com/lbarcziova",imageURL:"https://github.com/lbarcziova.png",key:"lbarczio"}],frontMatter:{title:"Week 1 in Packit",date:"2025-01-06T00:00:00.000Z",authors:"lbarczio",tags:["2025-January","2025","January"]},nextItem:{title:"Week 50 in Packit",permalink:"/posts/weekly/2024/week-50"}},l={authorsImageUrls:[void 0]},u=[{value:"Week 1 (January 2nd \u2013 January 6th)",id:"week-1-january-2nd--january-6th",level:2}],p={toc:u},s="wrapper";function y(e){let{components:t,...r}=e;return(0,n.kt)(s,(0,a.Z)({},p,r,{components:t,mdxType:"MDXLayout"}),(0,n.kt)("h2",{id:"week-1-january-2nd--january-6th"},"Week 1 (January 2nd \u2013 January 6th)"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"We have improved fallback commit status reporting via comments in GitLab. (",(0,n.kt)("a",{parentName:"li",href:"https://github.com/packit/packit-service/pull/2686"},"packit-service#2686"),")")))}y.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/13bad44f.2c9bddc7.js b/assets/js/13bad44f.39d2650c.js similarity index 76% rename from assets/js/13bad44f.2c9bddc7.js rename to assets/js/13bad44f.39d2650c.js index 520eae81f4..19e5b1604e 100644 --- a/assets/js/13bad44f.2c9bddc7.js +++ b/assets/js/13bad44f.39d2650c.js @@ -1 +1 @@ -"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[83227],{46546:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly/tags/january","page":1,"postsPerPage":10,"totalPages":1,"totalCount":5,"blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[83227],{46546:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly/tags/january","page":1,"postsPerPage":10,"totalPages":1,"totalCount":6,"blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file diff --git a/assets/js/1e2970af.02f12d88.js b/assets/js/1e2970af.63fc85d0.js similarity index 92% rename from assets/js/1e2970af.02f12d88.js rename to assets/js/1e2970af.63fc85d0.js index 91b5816b9b..65829a5aa1 100644 --- a/assets/js/1e2970af.02f12d88.js +++ b/assets/js/1e2970af.63fc85d0.js @@ -1 +1 @@ -"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[67574],{9891:e=>{e.exports=JSON.parse('[{"label":"2025-January","permalink":"/posts/weekly/tags/2025-january","count":1},{"label":"2025","permalink":"/posts/weekly/tags/2025","count":1},{"label":"January","permalink":"/posts/weekly/tags/january","count":5},{"label":"2024-December","permalink":"/posts/weekly/tags/2024-december","count":2},{"label":"2024","permalink":"/posts/weekly/tags/2024","count":48},{"label":"December","permalink":"/posts/weekly/tags/december","count":3},{"label":"2024-November","permalink":"/posts/weekly/tags/2024-november","count":4},{"label":"November","permalink":"/posts/weekly/tags/november","count":4},{"label":"2024-October","permalink":"/posts/weekly/tags/2024-october","count":5},{"label":"October","permalink":"/posts/weekly/tags/october","count":5},{"label":"2024-September","permalink":"/posts/weekly/tags/2024-september","count":4},{"label":"September","permalink":"/posts/weekly/tags/september","count":4},{"label":"2024-August","permalink":"/posts/weekly/tags/2024-august","count":4},{"label":"August","permalink":"/posts/weekly/tags/august","count":4},{"label":"2024-July","permalink":"/posts/weekly/tags/2024-july","count":4},{"label":"July","permalink":"/posts/weekly/tags/july","count":4},{"label":"2024-June","permalink":"/posts/weekly/tags/2024-june","count":3},{"label":"June","permalink":"/posts/weekly/tags/june","count":3},{"label":"2024-May","permalink":"/posts/weekly/tags/2024-may","count":4},{"label":"May","permalink":"/posts/weekly/tags/may","count":4},{"label":"2024-April","permalink":"/posts/weekly/tags/2024-april","count":5},{"label":"April","permalink":"/posts/weekly/tags/april","count":5},{"label":"2024-March","permalink":"/posts/weekly/tags/2024-march","count":4},{"label":"March","permalink":"/posts/weekly/tags/march","count":4},{"label":"2024-February","permalink":"/posts/weekly/tags/2024-february","count":5},{"label":"February","permalink":"/posts/weekly/tags/february","count":5},{"label":"2024-January","permalink":"/posts/weekly/tags/2024-january","count":4},{"label":"2023","permalink":"/posts/weekly/tags/2023","count":2},{"label":"2023-December","permalink":"/posts/weekly/tags/2023-december","count":1},{"label":"2022","permalink":"/posts/weekly/tags/2022","count":1},{"label":"2021","permalink":"/posts/weekly/tags/2021","count":1},{"label":"2020","permalink":"/posts/weekly/tags/2020","count":1},{"label":"2019","permalink":"/posts/weekly/tags/2019","count":1}]')}}]); \ No newline at end of file +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[67574],{9891:e=>{e.exports=JSON.parse('[{"label":"2025-January","permalink":"/posts/weekly/tags/2025-january","count":2},{"label":"2025","permalink":"/posts/weekly/tags/2025","count":2},{"label":"January","permalink":"/posts/weekly/tags/january","count":6},{"label":"2024-December","permalink":"/posts/weekly/tags/2024-december","count":2},{"label":"2024","permalink":"/posts/weekly/tags/2024","count":48},{"label":"December","permalink":"/posts/weekly/tags/december","count":3},{"label":"2024-November","permalink":"/posts/weekly/tags/2024-november","count":4},{"label":"November","permalink":"/posts/weekly/tags/november","count":4},{"label":"2024-October","permalink":"/posts/weekly/tags/2024-october","count":5},{"label":"October","permalink":"/posts/weekly/tags/october","count":5},{"label":"2024-September","permalink":"/posts/weekly/tags/2024-september","count":4},{"label":"September","permalink":"/posts/weekly/tags/september","count":4},{"label":"2024-August","permalink":"/posts/weekly/tags/2024-august","count":4},{"label":"August","permalink":"/posts/weekly/tags/august","count":4},{"label":"2024-July","permalink":"/posts/weekly/tags/2024-july","count":4},{"label":"July","permalink":"/posts/weekly/tags/july","count":4},{"label":"2024-June","permalink":"/posts/weekly/tags/2024-june","count":3},{"label":"June","permalink":"/posts/weekly/tags/june","count":3},{"label":"2024-May","permalink":"/posts/weekly/tags/2024-may","count":4},{"label":"May","permalink":"/posts/weekly/tags/may","count":4},{"label":"2024-April","permalink":"/posts/weekly/tags/2024-april","count":5},{"label":"April","permalink":"/posts/weekly/tags/april","count":5},{"label":"2024-March","permalink":"/posts/weekly/tags/2024-march","count":4},{"label":"March","permalink":"/posts/weekly/tags/march","count":4},{"label":"2024-February","permalink":"/posts/weekly/tags/2024-february","count":5},{"label":"February","permalink":"/posts/weekly/tags/february","count":5},{"label":"2024-January","permalink":"/posts/weekly/tags/2024-january","count":4},{"label":"2023","permalink":"/posts/weekly/tags/2023","count":2},{"label":"2023-December","permalink":"/posts/weekly/tags/2023-december","count":1},{"label":"2022","permalink":"/posts/weekly/tags/2022","count":1},{"label":"2021","permalink":"/posts/weekly/tags/2021","count":1},{"label":"2020","permalink":"/posts/weekly/tags/2020","count":1},{"label":"2019","permalink":"/posts/weekly/tags/2019","count":1}]')}}]); \ No newline at end of file diff --git a/assets/js/2bbe8192.aa9dc772.js b/assets/js/2bbe8192.d8dcb950.js similarity index 81% rename from assets/js/2bbe8192.aa9dc772.js rename to assets/js/2bbe8192.d8dcb950.js index b564bb8d5f..000b7c65ac 100644 --- a/assets/js/2bbe8192.aa9dc772.js +++ b/assets/js/2bbe8192.d8dcb950.js @@ -1 +1 @@ -"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[49564],{6162:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly/page/5","page":5,"postsPerPage":10,"totalPages":6,"totalCount":55,"previousPage":"/posts/weekly/page/4","nextPage":"/posts/weekly/page/6","blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[49564],{6162:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly/page/5","page":5,"postsPerPage":10,"totalPages":6,"totalCount":56,"previousPage":"/posts/weekly/page/4","nextPage":"/posts/weekly/page/6","blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file diff --git a/assets/js/2dd50e28.50905c94.js b/assets/js/2dd50e28.b70efb24.js similarity index 84% rename from assets/js/2dd50e28.50905c94.js rename to assets/js/2dd50e28.b70efb24.js index a504aebed1..104bd4bd58 100644 --- a/assets/js/2dd50e28.50905c94.js +++ b/assets/js/2dd50e28.b70efb24.js @@ -1 +1 @@ -"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[14150],{28472:e=>{e.exports=JSON.parse('{"label":"2025","permalink":"/posts/weekly/tags/2025","allTagsPath":"/posts/weekly/tags","count":1}')}}]); \ No newline at end of file +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[14150],{28472:e=>{e.exports=JSON.parse('{"label":"2025","permalink":"/posts/weekly/tags/2025","allTagsPath":"/posts/weekly/tags","count":2}')}}]); \ No newline at end of file diff --git a/assets/js/313a1f45.1a05e677.js b/assets/js/313a1f45.1a05e677.js new file mode 100644 index 0000000000..f9e48f20fb --- /dev/null +++ b/assets/js/313a1f45.1a05e677.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[686],{3905:(e,t,r)=>{r.d(t,{Zo:()=>u,kt:()=>f});var a=r(67294);function n(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function i(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,a)}return r}function o(e){for(var t=1;t=0||(n[r]=e[r]);return n}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(n[r]=e[r])}return n}var c=a.createContext({}),p=function(e){var t=a.useContext(c),r=t;return e&&(r="function"==typeof e?e(t):o(o({},t),e)),r},u=function(e){var t=p(e.components);return a.createElement(c.Provider,{value:t},e.children)},s="mdxType",m={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},y=a.forwardRef((function(e,t){var r=e.components,n=e.mdxType,i=e.originalType,c=e.parentName,u=l(e,["components","mdxType","originalType","parentName"]),s=p(r),y=n,f=s["".concat(c,".").concat(y)]||s[y]||m[y]||i;return r?a.createElement(f,o(o({ref:t},u),{},{components:r})):a.createElement(f,o({ref:t},u))}));function f(e,t){var r=arguments,n=t&&t.mdxType;if("string"==typeof e||n){var i=r.length,o=new Array(i);o[0]=y;var l={};for(var c in t)hasOwnProperty.call(t,c)&&(l[c]=t[c]);l.originalType=e,l[s]="string"==typeof e?e:n,o[1]=l;for(var p=2;p{r.r(t),r.d(t,{assets:()=>c,contentTitle:()=>o,default:()=>m,frontMatter:()=>i,metadata:()=>l,toc:()=>p});var a=r(87462),n=(r(67294),r(3905));const i={title:"Week 2 in Packit",date:new Date("2025-01-13T00:00:00.000Z"),authors:"flachman",tags:["2025-January",2025,"January"]},o=void 0,l={permalink:"/posts/weekly/2025/week-2",editUrl:"https://github.com/packit/packit.dev/tree/main/weekly/2025/week-2.md",source:"@site/weekly/2025/week-2.md",title:"Week 2 in Packit",description:"Week 2 (January 7th \u2013 January 13th)",date:"2025-01-13T00:00:00.000Z",formattedDate:"January 13, 2025",tags:[{label:"2025-January",permalink:"/posts/weekly/tags/2025-january"},{label:"2025",permalink:"/posts/weekly/tags/2025"},{label:"January",permalink:"/posts/weekly/tags/january"}],readingTime:.175,hasTruncateMarker:!1,authors:[{name:"Franti\u0161ek Lachman",email:"flachman@redhat.com",url:"https://github.com/lachmanfrantisek",imageURL:"https://github.com/lachmanfrantisek.png",key:"flachman"}],frontMatter:{title:"Week 2 in Packit",date:"2025-01-13T00:00:00.000Z",authors:"flachman",tags:["2025-January","2025","January"]},nextItem:{title:"Week 1 in Packit",permalink:"/posts/weekly/2025/week-1"}},c={authorsImageUrls:[void 0]},p=[{value:"Week 2 (January 7th \u2013 January 13th)",id:"week-2-january-7th--january-13th",level:2}],u={toc:p},s="wrapper";function m(e){let{components:t,...r}=e;return(0,n.kt)(s,(0,a.Z)({},u,r,{components:t,mdxType:"MDXLayout"}),(0,n.kt)("h2",{id:"week-2-january-7th--january-13th"},"Week 2 (January 7th \u2013 January 13th)"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"Fixed EVR regex used when parsing changelog entries in the ",(0,n.kt)("em",{parentName:"li"},"specfile")," library to not match email addresses with ",(0,n.kt)("inlineCode",{parentName:"li"},"-")," in them. (contributed by ",(0,n.kt)("a",{parentName:"li",href:"https://github.com/dcermak"},"Dan \u010cerm\xe1k"),", ",(0,n.kt)("a",{parentName:"li",href:"https://github.com/packit/specfile/pull/445"},"specfile#445"),")")))}m.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/33ef67ff.5b7cf86e.js b/assets/js/33ef67ff.7cdf573f.js similarity index 81% rename from assets/js/33ef67ff.5b7cf86e.js rename to assets/js/33ef67ff.7cdf573f.js index 24704c3123..d463ae1b23 100644 --- a/assets/js/33ef67ff.5b7cf86e.js +++ b/assets/js/33ef67ff.7cdf573f.js @@ -1 +1 @@ -"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[30749],{60377:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly/page/3","page":3,"postsPerPage":10,"totalPages":6,"totalCount":55,"previousPage":"/posts/weekly/page/2","nextPage":"/posts/weekly/page/4","blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[30749],{60377:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly/page/3","page":3,"postsPerPage":10,"totalPages":6,"totalCount":56,"previousPage":"/posts/weekly/page/2","nextPage":"/posts/weekly/page/4","blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file diff --git a/assets/js/5054467f.d96f5c47.js b/assets/js/5054467f.37f1b255.js similarity index 78% rename from assets/js/5054467f.d96f5c47.js rename to assets/js/5054467f.37f1b255.js index cd60a2d392..a1f10d0b6d 100644 --- a/assets/js/5054467f.d96f5c47.js +++ b/assets/js/5054467f.37f1b255.js @@ -1 +1 @@ -"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[88314],{91578:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly","page":1,"postsPerPage":10,"totalPages":6,"totalCount":55,"nextPage":"/posts/weekly/page/2","blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[88314],{91578:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly","page":1,"postsPerPage":10,"totalPages":6,"totalCount":56,"nextPage":"/posts/weekly/page/2","blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file diff --git a/assets/js/698688c0.4fccfa1d.js b/assets/js/698688c0.7b49d97c.js similarity index 76% rename from assets/js/698688c0.4fccfa1d.js rename to assets/js/698688c0.7b49d97c.js index 7b7fc80306..1989359fa9 100644 --- a/assets/js/698688c0.4fccfa1d.js +++ b/assets/js/698688c0.7b49d97c.js @@ -1 +1 @@ -"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[85958],{78405:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly/tags/2025","page":1,"postsPerPage":10,"totalPages":1,"totalCount":1,"blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[85958],{78405:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly/tags/2025","page":1,"postsPerPage":10,"totalPages":1,"totalCount":2,"blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file diff --git a/assets/js/7e7109f9.f1624811.js b/assets/js/7e7109f9.7252bc2e.js similarity index 80% rename from assets/js/7e7109f9.f1624811.js rename to assets/js/7e7109f9.7252bc2e.js index 2a46160d2c..f8ea8c778a 100644 --- a/assets/js/7e7109f9.f1624811.js +++ b/assets/js/7e7109f9.7252bc2e.js @@ -1 +1 @@ -"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[58047],{93849:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly/page/2","page":2,"postsPerPage":10,"totalPages":6,"totalCount":55,"previousPage":"/posts/weekly","nextPage":"/posts/weekly/page/3","blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[58047],{93849:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly/page/2","page":2,"postsPerPage":10,"totalPages":6,"totalCount":56,"previousPage":"/posts/weekly","nextPage":"/posts/weekly/page/3","blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file diff --git a/assets/js/90edf56d.d7d3b736.js b/assets/js/90edf56d.d7d3b736.js new file mode 100644 index 0000000000..08b818168e --- /dev/null +++ b/assets/js/90edf56d.d7d3b736.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[94911],{3905:(e,t,r)=>{r.d(t,{Zo:()=>u,kt:()=>k});var a=r(67294);function n(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function i(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,a)}return r}function o(e){for(var t=1;t=0||(n[r]=e[r]);return n}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(n[r]=e[r])}return n}var c=a.createContext({}),p=function(e){var t=a.useContext(c),r=t;return e&&(r="function"==typeof e?e(t):o(o({},t),e)),r},u=function(e){var t=p(e.components);return a.createElement(c.Provider,{value:t},e.children)},s="mdxType",y={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},m=a.forwardRef((function(e,t){var r=e.components,n=e.mdxType,i=e.originalType,c=e.parentName,u=l(e,["components","mdxType","originalType","parentName"]),s=p(r),m=n,k=s["".concat(c,".").concat(m)]||s[m]||y[m]||i;return r?a.createElement(k,o(o({ref:t},u),{},{components:r})):a.createElement(k,o({ref:t},u))}));function k(e,t){var r=arguments,n=t&&t.mdxType;if("string"==typeof e||n){var i=r.length,o=new Array(i);o[0]=m;var l={};for(var c in t)hasOwnProperty.call(t,c)&&(l[c]=t[c]);l.originalType=e,l[s]="string"==typeof e?e:n,o[1]=l;for(var p=2;p{r.r(t),r.d(t,{assets:()=>c,contentTitle:()=>o,default:()=>y,frontMatter:()=>i,metadata:()=>l,toc:()=>p});var a=r(87462),n=(r(67294),r(3905));const i={title:"Week 1 in Packit",date:new Date("2025-01-06T00:00:00.000Z"),authors:"lbarczio",tags:["2025-January",2025,"January"]},o=void 0,l={permalink:"/posts/weekly/2025/week-1",editUrl:"https://github.com/packit/packit.dev/tree/main/weekly/2025/week-1.md",source:"@site/weekly/2025/week-1.md",title:"Week 1 in Packit",description:"Week 1 (January 2nd \u2013 January 6th)",date:"2025-01-06T00:00:00.000Z",formattedDate:"January 6, 2025",tags:[{label:"2025-January",permalink:"/posts/weekly/tags/2025-january"},{label:"2025",permalink:"/posts/weekly/tags/2025"},{label:"January",permalink:"/posts/weekly/tags/january"}],readingTime:.105,hasTruncateMarker:!1,authors:[{name:"Laura Barcziov\xe1",email:"lbarczio@redhat.com",url:"https://github.com/lbarcziova",imageURL:"https://github.com/lbarcziova.png",key:"lbarczio"}],frontMatter:{title:"Week 1 in Packit",date:"2025-01-06T00:00:00.000Z",authors:"lbarczio",tags:["2025-January","2025","January"]},prevItem:{title:"Week 2 in Packit",permalink:"/posts/weekly/2025/week-2"},nextItem:{title:"Week 50 in Packit",permalink:"/posts/weekly/2024/week-50"}},c={authorsImageUrls:[void 0]},p=[{value:"Week 1 (January 2nd \u2013 January 6th)",id:"week-1-january-2nd--january-6th",level:2}],u={toc:p},s="wrapper";function y(e){let{components:t,...r}=e;return(0,n.kt)(s,(0,a.Z)({},u,r,{components:t,mdxType:"MDXLayout"}),(0,n.kt)("h2",{id:"week-1-january-2nd--january-6th"},"Week 1 (January 2nd \u2013 January 6th)"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"We have improved fallback commit status reporting via comments in GitLab. (",(0,n.kt)("a",{parentName:"li",href:"https://github.com/packit/packit-service/pull/2686"},"packit-service#2686"),")")))}y.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/90edf56d.fb77162b.js b/assets/js/90edf56d.fb77162b.js deleted file mode 100644 index 50fa0ea504..0000000000 --- a/assets/js/90edf56d.fb77162b.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[94911],{3905:(e,t,r)=>{r.d(t,{Zo:()=>p,kt:()=>k});var a=r(67294);function n(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function o(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,a)}return r}function i(e){for(var t=1;t=0||(n[r]=e[r]);return n}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(n[r]=e[r])}return n}var l=a.createContext({}),u=function(e){var t=a.useContext(l),r=t;return e&&(r="function"==typeof e?e(t):i(i({},t),e)),r},p=function(e){var t=u(e.components);return a.createElement(l.Provider,{value:t},e.children)},s="mdxType",y={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},m=a.forwardRef((function(e,t){var r=e.components,n=e.mdxType,o=e.originalType,l=e.parentName,p=c(e,["components","mdxType","originalType","parentName"]),s=u(r),m=n,k=s["".concat(l,".").concat(m)]||s[m]||y[m]||o;return r?a.createElement(k,i(i({ref:t},p),{},{components:r})):a.createElement(k,i({ref:t},p))}));function k(e,t){var r=arguments,n=t&&t.mdxType;if("string"==typeof e||n){var o=r.length,i=new Array(o);i[0]=m;var c={};for(var l in t)hasOwnProperty.call(t,l)&&(c[l]=t[l]);c.originalType=e,c[s]="string"==typeof e?e:n,i[1]=c;for(var u=2;u{r.r(t),r.d(t,{assets:()=>l,contentTitle:()=>i,default:()=>y,frontMatter:()=>o,metadata:()=>c,toc:()=>u});var a=r(87462),n=(r(67294),r(3905));const o={title:"Week 1 in Packit",date:new Date("2025-01-06T00:00:00.000Z"),authors:"lbarczio",tags:["2025-January",2025,"January"]},i=void 0,c={permalink:"/posts/weekly/2025/week-1",editUrl:"https://github.com/packit/packit.dev/tree/main/weekly/2025/week-1.md",source:"@site/weekly/2025/week-1.md",title:"Week 1 in Packit",description:"Week 1 (January 2nd \u2013 January 6th)",date:"2025-01-06T00:00:00.000Z",formattedDate:"January 6, 2025",tags:[{label:"2025-January",permalink:"/posts/weekly/tags/2025-january"},{label:"2025",permalink:"/posts/weekly/tags/2025"},{label:"January",permalink:"/posts/weekly/tags/january"}],readingTime:.105,hasTruncateMarker:!1,authors:[{name:"Laura Barcziov\xe1",email:"lbarczio@redhat.com",url:"https://github.com/lbarcziova",imageURL:"https://github.com/lbarcziova.png",key:"lbarczio"}],frontMatter:{title:"Week 1 in Packit",date:"2025-01-06T00:00:00.000Z",authors:"lbarczio",tags:["2025-January","2025","January"]},nextItem:{title:"Week 50 in Packit",permalink:"/posts/weekly/2024/week-50"}},l={authorsImageUrls:[void 0]},u=[{value:"Week 1 (January 2nd \u2013 January 6th)",id:"week-1-january-2nd--january-6th",level:2}],p={toc:u},s="wrapper";function y(e){let{components:t,...r}=e;return(0,n.kt)(s,(0,a.Z)({},p,r,{components:t,mdxType:"MDXLayout"}),(0,n.kt)("h2",{id:"week-1-january-2nd--january-6th"},"Week 1 (January 2nd \u2013 January 6th)"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"We have improved fallback commit status reporting via comments in GitLab. (",(0,n.kt)("a",{parentName:"li",href:"https://github.com/packit/packit-service/pull/2686"},"packit-service#2686"),")")))}y.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/a2b87eb6.f238428e.js b/assets/js/a2b87eb6.601f4979.js similarity index 81% rename from assets/js/a2b87eb6.f238428e.js rename to assets/js/a2b87eb6.601f4979.js index e40bbaa363..85e072778d 100644 --- a/assets/js/a2b87eb6.f238428e.js +++ b/assets/js/a2b87eb6.601f4979.js @@ -1 +1 @@ -"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[62281],{28079:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly/page/4","page":4,"postsPerPage":10,"totalPages":6,"totalCount":55,"previousPage":"/posts/weekly/page/3","nextPage":"/posts/weekly/page/5","blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[62281],{28079:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly/page/4","page":4,"postsPerPage":10,"totalPages":6,"totalCount":56,"previousPage":"/posts/weekly/page/3","nextPage":"/posts/weekly/page/5","blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file diff --git a/assets/js/ddfe5dc3.26080988.js b/assets/js/ddfe5dc3.7803faed.js similarity index 82% rename from assets/js/ddfe5dc3.26080988.js rename to assets/js/ddfe5dc3.7803faed.js index 83fe2424be..d35b3ed9c9 100644 --- a/assets/js/ddfe5dc3.26080988.js +++ b/assets/js/ddfe5dc3.7803faed.js @@ -1 +1 @@ -"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[49582],{85599:a=>{a.exports=JSON.parse('{"label":"January","permalink":"/posts/weekly/tags/january","allTagsPath":"/posts/weekly/tags","count":5}')}}]); \ No newline at end of file +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[49582],{85599:a=>{a.exports=JSON.parse('{"label":"January","permalink":"/posts/weekly/tags/january","allTagsPath":"/posts/weekly/tags","count":6}')}}]); \ No newline at end of file diff --git a/assets/js/e0b86265.c35af656.js b/assets/js/e0b86265.edee1f6f.js similarity index 79% rename from assets/js/e0b86265.c35af656.js rename to assets/js/e0b86265.edee1f6f.js index d8dc18aff5..3c7192b8cc 100644 --- a/assets/js/e0b86265.c35af656.js +++ b/assets/js/e0b86265.edee1f6f.js @@ -1 +1 @@ -"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[64956],{30696:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly/page/6","page":6,"postsPerPage":10,"totalPages":6,"totalCount":55,"previousPage":"/posts/weekly/page/5","blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[64956],{30696:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly/page/6","page":6,"postsPerPage":10,"totalPages":6,"totalCount":56,"previousPage":"/posts/weekly/page/5","blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file diff --git a/assets/js/e6339af7.65396d4b.js b/assets/js/e6339af7.65396d4b.js new file mode 100644 index 0000000000..b8cfc2674e --- /dev/null +++ b/assets/js/e6339af7.65396d4b.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[21907],{15062:e=>{e.exports=JSON.parse('{"title":"Recent posts","items":[{"title":"Week 2 in Packit","permalink":"/posts/weekly/2025/week-2"},{"title":"Week 1 in Packit","permalink":"/posts/weekly/2025/week-1"},{"title":"Week 50 in Packit","permalink":"/posts/weekly/2024/week-50"},{"title":"Week 49 in Packit","permalink":"/posts/weekly/2024/week-49"},{"title":"Week 48 in Packit","permalink":"/posts/weekly/2024/week-48"},{"title":"Week 47 in Packit","permalink":"/posts/weekly/2024/week-47"},{"title":"Week 46 in Packit","permalink":"/posts/weekly/2024/week-46"},{"title":"Week 45 in Packit","permalink":"/posts/weekly/2024/week-45"},{"title":"Week 44 in Packit","permalink":"/posts/weekly/2024/week-44"},{"title":"Week 43 in Packit","permalink":"/posts/weekly/2024/week-43"},{"title":"Week 42 in Packit","permalink":"/posts/weekly/2024/week-42"},{"title":"Week 41 in Packit","permalink":"/posts/weekly/2024/week-41"}]}')}}]); \ No newline at end of file diff --git a/assets/js/e6339af7.934177b0.js b/assets/js/e6339af7.934177b0.js deleted file mode 100644 index 4ad8e4f841..0000000000 --- a/assets/js/e6339af7.934177b0.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[21907],{15062:e=>{e.exports=JSON.parse('{"title":"Recent posts","items":[{"title":"Week 1 in Packit","permalink":"/posts/weekly/2025/week-1"},{"title":"Week 50 in Packit","permalink":"/posts/weekly/2024/week-50"},{"title":"Week 49 in Packit","permalink":"/posts/weekly/2024/week-49"},{"title":"Week 48 in Packit","permalink":"/posts/weekly/2024/week-48"},{"title":"Week 47 in Packit","permalink":"/posts/weekly/2024/week-47"},{"title":"Week 46 in Packit","permalink":"/posts/weekly/2024/week-46"},{"title":"Week 45 in Packit","permalink":"/posts/weekly/2024/week-45"},{"title":"Week 44 in Packit","permalink":"/posts/weekly/2024/week-44"},{"title":"Week 43 in Packit","permalink":"/posts/weekly/2024/week-43"},{"title":"Week 42 in Packit","permalink":"/posts/weekly/2024/week-42"},{"title":"Week 41 in Packit","permalink":"/posts/weekly/2024/week-41"},{"title":"Week 40 in Packit","permalink":"/posts/weekly/2024/week-40"}]}')}}]); \ No newline at end of file diff --git a/assets/js/e6722c50.153887c5.js b/assets/js/e6722c50.153887c5.js deleted file mode 100644 index e2ec2a5f16..0000000000 --- a/assets/js/e6722c50.153887c5.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[94488],{38516:e=>{e.exports=JSON.parse('{"blogPosts":[{"id":"/2025/week-1","metadata":{"permalink":"/posts/weekly/2025/week-1","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2025/week-1.md","source":"@site/weekly/2025/week-1.md","title":"Week 1 in Packit","description":"Week 1 (January 2nd \u2013 January 6th)","date":"2025-01-06T00:00:00.000Z","formattedDate":"January 6, 2025","tags":[{"label":"2025-January","permalink":"/posts/weekly/tags/2025-january"},{"label":"2025","permalink":"/posts/weekly/tags/2025"},{"label":"January","permalink":"/posts/weekly/tags/january"}],"readingTime":0.105,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 1 in Packit","date":"2025-01-06T00:00:00.000Z","authors":"lbarczio","tags":["2025-January","2025","January"]},"nextItem":{"title":"Week 50 in Packit","permalink":"/posts/weekly/2024/week-50"}},"content":"## Week 1 (January 2nd \u2013 January 6th)\\n\\n- We have improved fallback commit status reporting via comments in GitLab. ([packit-service#2686](https://github.com/packit/packit-service/pull/2686))"},{"id":"/2024/week-50","metadata":{"permalink":"/posts/weekly/2024/week-50","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-50.md","source":"@site/weekly/2024/week-50.md","title":"Week 50 in Packit","description":"Week 50 (December 10th \u2013 December 16th)","date":"2024-12-16T00:00:00.000Z","formattedDate":"December 16, 2024","tags":[{"label":"2024-December","permalink":"/posts/weekly/tags/2024-december"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"December","permalink":"/posts/weekly/tags/december"}],"readingTime":0.69,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 50 in Packit","date":"2024-12-16T00:00:00.000Z","authors":"mfocko","tags":["2024-December","2024","December"]},"prevItem":{"title":"Week 1 in Packit","permalink":"/posts/weekly/2025/week-1"},"nextItem":{"title":"Week 49 in Packit","permalink":"/posts/weekly/2024/week-49"}},"content":"## Week 50 (December 10th \u2013 December 16th)\\n\\n- We have added a `--resultdir` option for building in mock via our CLI\\n (`packit build in-mock`).\\n ([packit#2475](https://github.com/packit/packit/pull/2475))\\n- For our [specfile](https://github.com/packit/specfile) users, there is a new\\n convenience method `Sections.get_or_create()` that allows you to manipulate\\n a section without checking if it exists first. If a section doesn\'t exist, it\\n will be appended to the end. For example, this will work properly even on\\n spec files without `%changelog`:\\n\\n ```\\n with spec.sections() as sections:\\n changelog = sections.get_or_create(\\"changelog\\")\\n changelog[:] = [\\"%autochangelog\\"]\\n ```\\n\\n ([specfile#441](https://github.com/packit/specfile/pull/441))\\n\\n- We have also switched our base images from _CentOS 9 Stream_ to _Fedora 41_ to\\n allow you using the features from the latest _rpm 4.20_.\\n ([deployment#622](https://github.com/packit/deployment/pull/622))\\n- We have unified status names for VM Image builds.\\n ([packit-service#2679](https://github.com/packit/packit-service/pull/2679))\\n- We have started building [our container images](https://quay.io/organization/packit)\\n for alternative architectures.\\n ([packit-service#2675](https://github.com/packit/packit-service/pull/2675))"},{"id":"/2024/week-49","metadata":{"permalink":"/posts/weekly/2024/week-49","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-49.md","source":"@site/weekly/2024/week-49.md","title":"Week 49 in Packit","description":"Week 49 (December 3rd \u2013 December 9th)","date":"2024-12-09T00:00:00.000Z","formattedDate":"December 9, 2024","tags":[{"label":"2024-December","permalink":"/posts/weekly/tags/2024-december"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"December","permalink":"/posts/weekly/tags/december"}],"readingTime":0.35,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 49 in Packit","date":"2024-12-09T00:00:00.000Z","authors":"flachman","tags":["2024-December","2024","December"]},"prevItem":{"title":"Week 50 in Packit","permalink":"/posts/weekly/2024/week-50"},"nextItem":{"title":"Week 48 in Packit","permalink":"/posts/weekly/2024/week-48"}},"content":"## Week 49 (December 3rd \u2013 December 9th)\\n\\n- It\'s finally here! The team is planning to release Packit 1.0.0! We want to take this opportunity to clean up long-time deprecated config options and a related code.\\n To not let you alone in this, you can expect a pull request with required changes in case you are affected.\\n More information about this change can be found on [a separate page](https://packit.dev/posts/packit_1_0_0_action_required)."},{"id":"/2024/week-48","metadata":{"permalink":"/posts/weekly/2024/week-48","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-48.md","source":"@site/weekly/2024/week-48.md","title":"Week 48 in Packit","description":"Week 48 (November 26th \u2013 December 2nd)","date":"2024-12-02T00:00:00.000Z","formattedDate":"December 2, 2024","tags":[{"label":"2024-November","permalink":"/posts/weekly/tags/2024-november"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"November","permalink":"/posts/weekly/tags/november"}],"readingTime":0.57,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 48 in Packit","date":"2024-12-02T00:00:00.000Z","authors":"mmassari","tags":["2024-November","2024","November"]},"prevItem":{"title":"Week 49 in Packit","permalink":"/posts/weekly/2024/week-49"},"nextItem":{"title":"Week 47 in Packit","permalink":"/posts/weekly/2024/week-47"}},"content":"## Week 48 (November 26th \u2013 December 2nd)\\n\\n- There is a new action/hook, `post-modifications`, that is executed after all modifications to the spec file are done and in case of syncing release after all remote sources are downloaded and before uploading to lookaside cache. You can use it for example to construct an additional source that depends on the primary source (that may not yet be available in other actions). ([packit#2474](https://github.com/packit/packit/pull/2474))\\n- We have fixed `/packit retest-failed` which was retriggering also non failed tests. ([packit-service#2665](https://github.com/packit/packit-service/pull/2665))\\n- Packit now includes dashboard links when reporting errors for Koji builds and Bodhi updates. ([packit-service#2663](https://github.com/packit/packit-service/pull/2663))\\n- We have improved Koji builds and Bodhi updates errors displaying. ([dashboard#497](https://github.com/packit/dashboard/pull/497))"},{"id":"/2024/week-47","metadata":{"permalink":"/posts/weekly/2024/week-47","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-47.md","source":"@site/weekly/2024/week-47.md","title":"Week 47 in Packit","description":"Week 47 (November 19th \u2013 November 25th)","date":"2024-11-25T00:00:00.000Z","formattedDate":"November 25, 2024","tags":[{"label":"2024-November","permalink":"/posts/weekly/tags/2024-november"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"November","permalink":"/posts/weekly/tags/november"}],"readingTime":0.205,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 47 in Packit","date":"2024-11-25T00:00:00.000Z","authors":"nforro","tags":["2024-November","2024","November"]},"prevItem":{"title":"Week 48 in Packit","permalink":"/posts/weekly/2024/week-48"},"nextItem":{"title":"Week 46 in Packit","permalink":"/posts/weekly/2024/week-46"}},"content":"## Week 47 (November 19th \u2013 November 25th)\\n\\n- Packit now uses the `fedora-distro-aliases` library to expand Fedora aliases.\\n This is Packit\'s original code being improved and properly maintained by the Copr team.\\n For further suggestions about aliases, use github.com/rpm-software-management/fedora-distro-aliases.\\n ([packit#2470](https://github.com/packit/packit/pull/2470))"},{"id":"/2024/week-46","metadata":{"permalink":"/posts/weekly/2024/week-46","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-46.md","source":"@site/weekly/2024/week-46.md","title":"Week 46 in Packit","description":"Week 46 (November 12th \u2013 November 18th)","date":"2024-11-18T00:00:00.000Z","formattedDate":"November 18, 2024","tags":[{"label":"2024-November","permalink":"/posts/weekly/tags/2024-november"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"November","permalink":"/posts/weekly/tags/november"}],"readingTime":0.67,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 46 in Packit","date":"2024-11-18T00:00:00.000Z","authors":"lbarczio","tags":["2024-November","2024","November"]},"prevItem":{"title":"Week 47 in Packit","permalink":"/posts/weekly/2024/week-47"},"nextItem":{"title":"Week 45 in Packit","permalink":"/posts/weekly/2024/week-45"}},"content":"## Week 46 (November 12th \u2013 November 18th)\\n\\n- The Packit configuration file now supports a top-level placeholder key, `_`, which is ignored when parsing the file.\\n This is useful for storing YAML anchors in complex config files, e.g.:\\n\\n```yaml\\n_:\\n base-test: &base-test\\n job: tests\\n fmf_path: .distro\\njobs:\\n - <<: *base-test\\n trigger: pull_request\\n manual_trigger: true\\n - <<: *internal-test\\n trigger: commit\\n use_internal_tf: true\\n```\\n\\n([packit#2378](https://github.com/packit/packit/pull/2378))\\n\\n- You can now define `with_opts` and `without_opts` in target-specific configuration of `copr_build` job to build with `--with` and `--without` rpmbuild options. ([packit#2463](https://github.com/packit/packit/pull/2463))\\n- We have made several improvements to our dashboard:\\n - The Copr installation instructions have been updated. ([dashboard#487](https://github.com/packit/dashboard/pull/487))\\n - You can now view the number of new findings from OpenScanHub scans. ([dashboard#489](https://github.com/packit/dashboard/pull/489))\\n - Displaying of Copr builds in Testing Farm run views was improved as well. ([dashboard#481](https://github.com/packit/dashboard/pull/481))"},{"id":"/2024/week-45","metadata":{"permalink":"/posts/weekly/2024/week-45","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-45.md","source":"@site/weekly/2024/week-45.md","title":"Week 45 in Packit","description":"Week 45 (November 5th \u2013 November 11th)","date":"2024-11-11T00:00:00.000Z","formattedDate":"November 11, 2024","tags":[{"label":"2024-November","permalink":"/posts/weekly/tags/2024-november"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"November","permalink":"/posts/weekly/tags/november"}],"readingTime":0.15,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 45 in Packit","date":"2024-11-11T00:00:00.000Z","authors":"mfocko","tags":["2024-November","2024","November"]},"prevItem":{"title":"Week 46 in Packit","permalink":"/posts/weekly/2024/week-46"},"nextItem":{"title":"Week 44 in Packit","permalink":"/posts/weekly/2024/week-44"}},"content":"## Week 45 (November 5th \u2013 November 11th)\\n\\n- Packit now provides information about submitted scans via `/osh-scans` API endpoint. ([packit-service#2614](https://github.com/packit/packit-service/pull/2614))\\n- We have improved reporting of OpenScanHub results. ([packit-service#2622](https://github.com/packit/packit-service/pull/2622))"},{"id":"/2024/week-44","metadata":{"permalink":"/posts/weekly/2024/week-44","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-44.md","source":"@site/weekly/2024/week-44.md","title":"Week 44 in Packit","description":"Week 44 (October 29th \u2013 November 4th)","date":"2024-11-04T00:00:00.000Z","formattedDate":"November 4, 2024","tags":[{"label":"2024-October","permalink":"/posts/weekly/tags/2024-october"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"October","permalink":"/posts/weekly/tags/october"}],"readingTime":0.115,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 44 in Packit","date":"2024-11-04T00:00:00.000Z","authors":"flachman","tags":["2024-October","2024","October"]},"prevItem":{"title":"Week 45 in Packit","permalink":"/posts/weekly/2024/week-45"},"nextItem":{"title":"Week 43 in Packit","permalink":"/posts/weekly/2024/week-43"}},"content":"## Week 44 (October 29th \u2013 November 4th)\\n\\n- Packit now supports and defaults to `fast_forward_merge_into` syntax via `--dist-git-branches-mapping` in `dist-git init`. ([packit#2456](https://github.com/packit/packit/pull/2456))"},{"id":"/2024/week-43","metadata":{"permalink":"/posts/weekly/2024/week-43","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-43.md","source":"@site/weekly/2024/week-43.md","title":"Week 43 in Packit","description":"Week 43 (October 22nd \u2013 October 28th)","date":"2024-10-28T00:00:00.000Z","formattedDate":"October 28, 2024","tags":[{"label":"2024-October","permalink":"/posts/weekly/tags/2024-october"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"October","permalink":"/posts/weekly/tags/october"}],"readingTime":0.785,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 43 in Packit","date":"2024-10-28T00:00:00.000Z","authors":"mmassari","tags":["2024-October","2024","October"]},"prevItem":{"title":"Week 44 in Packit","permalink":"/posts/weekly/2024/week-44"},"nextItem":{"title":"Week 42 in Packit","permalink":"/posts/weekly/2024/week-42"}},"content":"## Week 43 (October 22nd \u2013 October 28th)\\n\\n- We have added support for retriggering jobs that are configured for `commit` and `release` trigger. Retriggering can be done via commit comments on the relevant commit, using the usual comments, such as `/packit build` or `/packit test`, but the branch or tag need to be specified like this (without the arguments, we will default to `commit` trigger for the default branch of the repository):\\n\\n ```\\n /packit build --commit \\n ```\\n\\n or\\n\\n ```\\n /packit build --release \\n ```\\n\\n ([packit-service#2589](https://github.com/packit/packit-service/pull/2589))\\n\\n- There is a new method for getting a single commit comment, supporting also retrieval and adding reactions in GitHub. ([ogr#865](https://github.com/packit/ogr/pull/865))\\n\\n- We have improved the feedback for the Open Scan Hub job. You can now see if the scan is in a `pending`, `running`, `canceled`, `failed`, or `successful` state.\\n A `failed` or `canceled` scan is shown as neutral and does not cause your pull request validation to fail. ([packit-service#2543](https://github.com/packit/packit-service/issues/2543))"},{"id":"/2024/week-42","metadata":{"permalink":"/posts/weekly/2024/week-42","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-42.md","source":"@site/weekly/2024/week-42.md","title":"Week 42 in Packit","description":"Week 42 (October 15th \u2013 October 21st)","date":"2024-10-21T00:00:00.000Z","formattedDate":"October 21, 2024","tags":[{"label":"2024-October","permalink":"/posts/weekly/tags/2024-october"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"October","permalink":"/posts/weekly/tags/october"}],"readingTime":0.14,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 42 in Packit","date":"2024-10-21T00:00:00.000Z","authors":"nforro","tags":["2024-October","2024","October"]},"prevItem":{"title":"Week 43 in Packit","permalink":"/posts/weekly/2024/week-43"},"nextItem":{"title":"Week 41 in Packit","permalink":"/posts/weekly/2024/week-41"}},"content":"## Week 42 (October 15th \u2013 October 21st)\\n\\n- Manual test trigger command (`/packit test`) now accepts `--env` option(s)\\n to override environment variables passed to Testing Farm.\\n ([packit-service#2583](https://github.com/packit/packit-service/pull/2583))"},{"id":"/2024/week-41","metadata":{"permalink":"/posts/weekly/2024/week-41","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-41.md","source":"@site/weekly/2024/week-41.md","title":"Week 41 in Packit","description":"Week 41 (October 8th \u2013 October 14th)","date":"2024-10-14T00:00:00.000Z","formattedDate":"October 14, 2024","tags":[{"label":"2024-October","permalink":"/posts/weekly/tags/2024-october"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"October","permalink":"/posts/weekly/tags/october"}],"readingTime":0.185,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 41 in Packit","date":"2024-10-14T00:00:00.000Z","authors":"lbarczio","tags":["2024-October","2024","October"]},"prevItem":{"title":"Week 42 in Packit","permalink":"/posts/weekly/2024/week-42"},"nextItem":{"title":"Week 40 in Packit","permalink":"/posts/weekly/2024/week-40"}},"content":"## Week 41 (October 8th \u2013 October 14th)\\n\\n- We have fixed an issue that was introduced during the unification of the interface for passing resolved Bugzillas / Jira tickets to the `sync-release` or `bodhi_update` jobs. ([packit#2442](https://github.com/packit/packit/pull/2442))"},{"id":"/2024/week-40","metadata":{"permalink":"/posts/weekly/2024/week-40","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-40.md","source":"@site/weekly/2024/week-40.md","title":"Week 40 in Packit","description":"Week 40 (October 1st \u2013 October 7th)","date":"2024-10-07T00:00:00.000Z","formattedDate":"October 7, 2024","tags":[{"label":"2024-October","permalink":"/posts/weekly/tags/2024-october"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"October","permalink":"/posts/weekly/tags/october"}],"readingTime":0.85,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 40 in Packit","date":"2024-10-07T00:00:00.000Z","authors":"mfocko","tags":["2024-October","2024","October"]},"prevItem":{"title":"Week 41 in Packit","permalink":"/posts/weekly/2024/week-41"},"nextItem":{"title":"Week 39 in Packit","permalink":"/posts/weekly/2024/week-39"}},"content":"## Week 40 (October 1st \u2013 October 7th)\\n\\n- `packit validate-config` now checks for the existence of the downstream package. ([packit#2436](https://github.com/packit/packit/pull/2436))\\n- Packit now allows building VM images via CLI without any Copr repository specified. ([packit#2434](https://github.com/packit/packit/pull/2434))\\n- We have unified interface of passing resolved bugs (e.g., Bugzillas as of now) to Packit CLI and via comments. Both CLI and comments now use `--resolve-bug` switch (comments accept comma-separated list of bugs, CLI accepts the switch multiple times (also `-b`)).\\n ([packit#2428](https://github.com/packit/packit/pull/2428) and [packit-service#2560](https://github.com/packit/packit-service/pull/2560))\\n- `packit init` now adds working directories that are used in `packit prepare-sources` into the `.gitignore` file in the same directory where Packit config resides. ([packit#2431](https://github.com/packit/packit/pull/2431))\\n- Before triggering the non-scratch Koji builds, we now check whether there is not already a build in progress or completed for the same NVR. ([packit-service#2559](https://github.com/packit/packit-service/pull/2559))\\n- We have improved the error reporting for failed downstream jobs. ([packit-service#2544](https://github.com/packit/packit-service/pull/2544))\\n- We have fixed an issue that caused inconsistencies with the expected behaviour stated by the documentation when adding duplicitous reactions to GitLab comments. ([ogr#861](https://github.com/packit/ogr/pull/861))"},{"id":"/2024/week-39","metadata":{"permalink":"/posts/weekly/2024/week-39","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-39.md","source":"@site/weekly/2024/week-39.md","title":"Week 39 in Packit","description":"Week 39 (September 24th \u2013 September 30th)","date":"2024-09-30T00:00:00.000Z","formattedDate":"September 30, 2024","tags":[{"label":"2024-September","permalink":"/posts/weekly/tags/2024-september"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"September","permalink":"/posts/weekly/tags/september"}],"readingTime":0.235,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 39 in Packit","date":"2024-09-30T00:00:00.000Z","authors":"flachman","tags":["2024-September","2024","September"]},"prevItem":{"title":"Week 40 in Packit","permalink":"/posts/weekly/2024/week-40"},"nextItem":{"title":"Week 38 in Packit","permalink":"/posts/weekly/2024/week-38"}},"content":"## Week 39 (September 24th \u2013 September 30th)\\n\\n- Check for `upstream_project_url` presence in the configuration when `pull_from_upstream` job is configured was removed from `validate-config`, as this is no longer required. ([packit#2423](https://github.com/packit/packit/pull/2423))\\n- We have added a note about retriggering `pull_from_upstream` job from dist-git pull requests. ([packit-service#2542](https://github.com/packit/packit-service/pull/2542))"},{"id":"/2024/week-38","metadata":{"permalink":"/posts/weekly/2024/week-38","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-38.md","source":"@site/weekly/2024/week-38.md","title":"Week 38 in Packit","description":"Week 38 (September 17th \u2013 September 23rd)","date":"2024-09-23T00:00:00.000Z","formattedDate":"September 23, 2024","tags":[{"label":"2024-September","permalink":"/posts/weekly/tags/2024-september"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"September","permalink":"/posts/weekly/tags/september"}],"readingTime":0.14,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 38 in Packit","date":"2024-09-23T00:00:00.000Z","authors":"mmassari","tags":["2024-September","2024","September"]},"prevItem":{"title":"Week 39 in Packit","permalink":"/posts/weekly/2024/week-39"},"nextItem":{"title":"Week 37 in Packit","permalink":"/posts/weekly/2024/week-37"}},"content":"## Week 38 (September 17th \u2013 September 23rd)\\n\\n- Packit now allows to configure mock bootstrap feature setup of Copr projects with a new `bootstrap` configuration option. ([packit#2411](https://github.com/packit/packit/pull/2411))"},{"id":"/2024/week-37","metadata":{"permalink":"/posts/weekly/2024/week-37","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-37.md","source":"@site/weekly/2024/week-37.md","title":"Week 37 in Packit","description":"Week 37 (September 10th \u2013 September 16th)","date":"2024-09-16T00:00:00.000Z","formattedDate":"September 16, 2024","tags":[{"label":"2024-September","permalink":"/posts/weekly/tags/2024-september"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"September","permalink":"/posts/weekly/tags/september"}],"readingTime":0.135,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 37 in Packit","date":"2024-09-16T00:00:00.000Z","authors":"nforro","tags":["2024-September","2024","September"]},"prevItem":{"title":"Week 38 in Packit","permalink":"/posts/weekly/2024/week-38"},"nextItem":{"title":"Week 36 in Packit","permalink":"/posts/weekly/2024/week-36"}},"content":"## Week 37 (September 10th \u2013 September 16th)\\n\\n- We have fixed showing of Bodhi updates that are triggered by non-Packit Koji builds on our dashboard.\\n ([packit-service#2528](https://github.com/packit/packit-service/pull/2528))"},{"id":"/2024/week-36","metadata":{"permalink":"/posts/weekly/2024/week-36","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-36.md","source":"@site/weekly/2024/week-36.md","title":"Week 36 in Packit","description":"Week 36 (September 3rd \u2013 September 9th)","date":"2024-09-09T00:00:00.000Z","formattedDate":"September 9, 2024","tags":[{"label":"2024-September","permalink":"/posts/weekly/tags/2024-september"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"September","permalink":"/posts/weekly/tags/september"}],"readingTime":0.445,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 36 in Packit","date":"2024-09-09T00:00:00.000Z","authors":"lbarczio","tags":["2024-September","2024","September"]},"prevItem":{"title":"Week 37 in Packit","permalink":"/posts/weekly/2024/week-37"},"nextItem":{"title":"Week 34 in Packit","permalink":"/posts/weekly/2024/week-34"}},"content":"## Week 36 (September 3rd \u2013 September 9th)\\n\\n- Packit now supports passing custom arguments to various static analyzers through `--csmock-args` CLI option and `csmock_args` configuration. ([packit#2402](https://github.com/packit/packit/pull/2402))\\n- When syncing a new release, Packit can now avoid diverging git branches by reusing the commit from one branch when opening pull requests into other branches. (These pull requests can be merged in fast-forward mode.)\\n Use the new syntax for `dist_git_branches` as in this example to utilise this functionality:\\n\\n```\\n{\\n \\"rawhide\\": {\\n \\"fast_forward_merge_into\\": [\\"f40\\"]\\n },\\n \\"fedora-stable\\": {}\\n}\\n```\\n\\n([packit-service#2478](https://github.com/packit/packit-service/pull/2478))"},{"id":"/2024/week-34","metadata":{"permalink":"/posts/weekly/2024/week-34","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-34.md","source":"@site/weekly/2024/week-34.md","title":"Week 34 in Packit","description":"Week 34 (August 20st \u2013 August 27th)","date":"2024-08-27T00:00:00.000Z","formattedDate":"August 27, 2024","tags":[{"label":"2024-August","permalink":"/posts/weekly/tags/2024-august"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"August","permalink":"/posts/weekly/tags/august"}],"readingTime":0.425,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 34 in Packit","date":"2024-08-27T00:00:00.000Z","authors":"flachman","tags":["2024-August","2024","August"]},"prevItem":{"title":"Week 36 in Packit","permalink":"/posts/weekly/2024/week-36"},"nextItem":{"title":"Week 33 in Packit","permalink":"/posts/weekly/2024/week-33"}},"content":"## Week 34 (August 20st \u2013 August 27th)\\n\\n- `pull-from-upstream` is now supported also without specifying `upstream_project_url` in the configuration. For such cases, the upstream repository will not be detected and cloned during release syncing. ([packit#2398](https://github.com/packit/packit/pull/2398))\\n- `dist-git init` command now allows `upstream-git-url` not to be specified. ([packit#2387](https://github.com/packit/packit/pull/2387))\\n- You can newly tag builds of a package into a sidetag group by using `/packit koji-tag` comment command. ([packit-service#2507](https://github.com/packit/packit-service/pull/2507))\\n- Thanks to [Cristian Le](https://github.com/LecrisUT), `epel-10` is now correctly mapped to a `centos-stream-10` when running tests. ([packit-service#2508](https://github.com/packit/packit-service/pull/2508))"},{"id":"/2024/week-33","metadata":{"permalink":"/posts/weekly/2024/week-33","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-33.md","source":"@site/weekly/2024/week-33.md","title":"Week 33 in Packit","description":"Week 33 (August 13th \u2013 August 19th)","date":"2024-08-19T00:00:00.000Z","formattedDate":"August 19, 2024","tags":[{"label":"2024-August","permalink":"/posts/weekly/tags/2024-august"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"August","permalink":"/posts/weekly/tags/august"}],"readingTime":0.125,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 33 in Packit","date":"2024-08-19T00:00:00.000Z","authors":"lbarczio","tags":["2024-August","2024","August"]},"prevItem":{"title":"Week 34 in Packit","permalink":"/posts/weekly/2024/week-34"},"nextItem":{"title":"Week 32 in Packit","permalink":"/posts/weekly/2024/week-32"}},"content":"## Week 33 (August 13th \u2013 August 19th)\\n\\n- Several internal, but also performance improvements were done on our dashboard, thanks to\\n [Freya Gustavsson](https://github.com/Venefilyn) ([packit/dashboard#435](https://github.com/packit/dashboard/pull/435))!"},{"id":"/2024/week-32","metadata":{"permalink":"/posts/weekly/2024/week-32","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-32.md","source":"@site/weekly/2024/week-32.md","title":"Week 32 in Packit","description":"Week 32 (August 6th \u2013 August 12th)","date":"2024-08-12T00:00:00.000Z","formattedDate":"August 12, 2024","tags":[{"label":"2024-August","permalink":"/posts/weekly/tags/2024-august"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"August","permalink":"/posts/weekly/tags/august"}],"readingTime":0.14,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 32 in Packit","date":"2024-08-12T00:00:00.000Z","authors":"nforro","tags":["2024-August","2024","August"]},"prevItem":{"title":"Week 33 in Packit","permalink":"/posts/weekly/2024/week-33"},"nextItem":{"title":"Week 31 in Packit","permalink":"/posts/weekly/2024/week-31"}},"content":"## Week 32 (August 6th \u2013 August 12th)\\n\\n- Packit now passes `PACKIT_TAG_NAME` to the Testing Farm run when it\'s triggered by a release event.\\n Thanks [@Frawless](https://github.com/Frawless).\\n ([packit-service#2494](https://github.com/packit/packit-service/pull/2494))"},{"id":"/2024/week-31","metadata":{"permalink":"/posts/weekly/2024/week-31","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-31.md","source":"@site/weekly/2024/week-31.md","title":"Week 31 in Packit","description":"Week 31 (July 30th \u2013 August 5th)","date":"2024-08-05T00:00:00.000Z","formattedDate":"August 5, 2024","tags":[{"label":"2024-August","permalink":"/posts/weekly/tags/2024-august"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"August","permalink":"/posts/weekly/tags/august"}],"readingTime":0.095,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 31 in Packit","date":"2024-08-05T00:00:00.000Z","authors":"lbarczio","tags":["2024-August","2024","August"]},"prevItem":{"title":"Week 32 in Packit","permalink":"/posts/weekly/2024/week-32"},"nextItem":{"title":"Week 30 in Packit","permalink":"/posts/weekly/2024/week-30"}},"content":"## Week 31 (July 30th \u2013 August 5th)\\n\\n- It is now possible to run tests for releases. ([packit/packit-service#2490](https://github.com/packit/packit-service/pull/2490))"},{"id":"/2024/week-30","metadata":{"permalink":"/posts/weekly/2024/week-30","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-30.md","source":"@site/weekly/2024/week-30.md","title":"Week 30 in Packit","description":"Week 30 (July 23rd \u2013 July 29th)","date":"2024-07-29T00:00:00.000Z","formattedDate":"July 29, 2024","tags":[{"label":"2024-July","permalink":"/posts/weekly/tags/2024-july"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"July","permalink":"/posts/weekly/tags/july"}],"readingTime":0.54,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 30 in Packit","date":"2024-07-29T00:00:00.000Z","authors":"mfocko","tags":["2024-July","2024","July"]},"prevItem":{"title":"Week 31 in Packit","permalink":"/posts/weekly/2024/week-31"},"nextItem":{"title":"Week 29 in Packit","permalink":"/posts/weekly/2024/week-29"}},"content":"## Week 30 (July 23rd \u2013 July 29th)\\n\\n- `packit pull-from-upstream` now allows omitting `upstream_project_url` in the configuration in which case the interaction with the upstream repository is skipped during release syncing. ([packit#2354](https://github.com/packit/packit/pull/2354))\\n- We have added the initial version of functionality for running scans in OpenScanHub. You can read more about this functionality\\n [here](https://packit.dev/docs/configuration#osh_diff_scan_after_copr_build). ([packit-service#2472](https://github.com/packit/packit-service/pull/2472))\\n- Added a new configuration option `sync_test_job_statuses_with_builds` that controls whether test job statuses are updated together with their corresponding build job statuses. When set to `false`, while tests jobs are waiting for their corresponding build jobs to finish, their statuses remain in pending state and only build job statuses are updated. ([packit-service#2470](https://github.com/packit/packit-service/pull/2470))"},{"id":"/2024/week-29","metadata":{"permalink":"/posts/weekly/2024/week-29","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-29.md","source":"@site/weekly/2024/week-29.md","title":"Week 29 in Packit","description":"Week 29 (July 16th \u2013 July 22nd)","date":"2024-07-22T00:00:00.000Z","formattedDate":"July 22, 2024","tags":[{"label":"2024-July","permalink":"/posts/weekly/tags/2024-july"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"July","permalink":"/posts/weekly/tags/july"}],"readingTime":0.375,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 29 in Packit","date":"2024-07-22T00:00:00.000Z","authors":"flachman","tags":["2024-July","2024","July"]},"prevItem":{"title":"Week 30 in Packit","permalink":"/posts/weekly/2024/week-30"},"nextItem":{"title":"Week 28 in Packit","permalink":"/posts/weekly/2024/week-28"}},"content":"## Week 29 (July 16th \u2013 July 22nd)\\n\\n- We have implemented a CLI support for Koji builds against CBS Koji instance. ([packit#2267](https://github.com/packit/packit/pull/2267))\\n- Added a new configuration option `sync_test_job_statuses_with_builds` that controls whether test job statuses are updated together with their corresponding build job statuses. When set to `false`, while tests jobs are waiting for their corresponding build jobs to finish, their statuses remain in pending state and only build job statuses are updated. ([packit-service#2470](https://github.com/packit/packit-service/pull/2470))"},{"id":"/2024/week-28","metadata":{"permalink":"/posts/weekly/2024/week-28","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-28.md","source":"@site/weekly/2024/week-28.md","title":"Week 28 in Packit","description":"Week 28 (July 9th \u2013 July 15th)","date":"2024-07-15T00:00:00.000Z","formattedDate":"July 15, 2024","tags":[{"label":"2024-July","permalink":"/posts/weekly/tags/2024-july"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"July","permalink":"/posts/weekly/tags/july"}],"readingTime":0.19,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 28 in Packit","date":"2024-07-15T00:00:00.000Z","authors":"nforro","tags":["2024-July","2024","July"]},"prevItem":{"title":"Week 29 in Packit","permalink":"/posts/weekly/2024/week-29"},"nextItem":{"title":"Week 27 in Packit","permalink":"/posts/weekly/2024/week-27"}},"content":"## Week 28 (July 9th \u2013 July 15th)\\n\\n- We have improved the babysitting of Testing Farm runs to better handle API outages.\\n ([packit-service#2464](https://github.com/packit/packit-service/pull/2464))\\n- We have adjusted commenting behaviour regarding Packit logs on release syncing PRs.\\n ([packit-service#2373](https://github.com/packit/packit-service/pull/2373))"},{"id":"/2024/week-27","metadata":{"permalink":"/posts/weekly/2024/week-27","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-27.md","source":"@site/weekly/2024/week-27.md","title":"Week 27 in Packit","description":"Week 27 (July 2nd \u2013 July 8th)","date":"2024-07-08T00:00:00.000Z","formattedDate":"July 8, 2024","tags":[{"label":"2024-July","permalink":"/posts/weekly/tags/2024-july"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"July","permalink":"/posts/weekly/tags/july"}],"readingTime":0.15,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 27 in Packit","date":"2024-07-08T00:00:00.000Z","authors":"mmassari","tags":["2024-July","2024","July"]},"prevItem":{"title":"Week 28 in Packit","permalink":"/posts/weekly/2024/week-28"},"nextItem":{"title":"Week 26 in Packit","permalink":"/posts/weekly/2024/week-26"}},"content":"## Week 27 (July 2nd \u2013 July 8th)\\n\\n- Packit now updates its own, not yet merged, pull requests instead of creating new ones when syncing new releases downstream. ([packit#2204](https://github.com/packit/packit/pull/2204))"},{"id":"/2024/week-26","metadata":{"permalink":"/posts/weekly/2024/week-26","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-26.md","source":"@site/weekly/2024/week-26.md","title":"Week 26 in Packit","description":"Week 26 (June 25th \u2013 July 1st)","date":"2024-07-01T00:00:00.000Z","formattedDate":"July 1, 2024","tags":[{"label":"2024-June","permalink":"/posts/weekly/tags/2024-june"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"June","permalink":"/posts/weekly/tags/june"}],"readingTime":0.175,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 26 in Packit","date":"2024-07-01T00:00:00.000Z","authors":"mfocko","tags":["2024-June","2024","June"]},"prevItem":{"title":"Week 27 in Packit","permalink":"/posts/weekly/2024/week-27"},"nextItem":{"title":"Week 25 in Packit","permalink":"/posts/weekly/2024/week-25"}},"content":"## Week 26 (June 25th \u2013 July 1st)\\n\\n- Enabled HTTP/2 for Packit service. ([packit-service#2450](https://github.com/packit/packit-service/pull/2450))\\n- It is now possible to disable reporting of `propose_downstream` failures by setting `notifications.failure_issue.create` in the configuration to `false`. ([packit-service#2451](https://github.com/packit/packit-service/pull/2451))"},{"id":"/2024/week-25","metadata":{"permalink":"/posts/weekly/2024/week-25","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-25.md","source":"@site/weekly/2024/week-25.md","title":"Week 25 in Packit","description":"Week 25 (June 18th \u2013 June 24th)","date":"2024-06-24T00:00:00.000Z","formattedDate":"June 24, 2024","tags":[{"label":"2024-June","permalink":"/posts/weekly/tags/2024-june"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"June","permalink":"/posts/weekly/tags/june"}],"readingTime":0.165,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 25 in Packit","date":"2024-06-24T00:00:00.000Z","authors":"nforro","tags":["2024-June","2024","June"]},"prevItem":{"title":"Week 26 in Packit","permalink":"/posts/weekly/2024/week-26"},"nextItem":{"title":"Week 24 in Packit","permalink":"/posts/weekly/2024/week-24"}},"content":"## Week 25 (June 18th \u2013 June 24th)\\n\\n- We have fixed an issue that has been introduced by another bug fix.\\n This issue has caused an outage of upstream Koji builds.\\n ([packit#2329](https://github.com/packit/packit/pull/2329))"},{"id":"/2024/week-24","metadata":{"permalink":"/posts/weekly/2024/week-24","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-24.md","source":"@site/weekly/2024/week-24.md","title":"Week 24 in Packit","description":"Week 24 (June 11th \u2013 June 17th)","date":"2024-06-18T00:00:00.000Z","formattedDate":"June 18, 2024","tags":[{"label":"2024-June","permalink":"/posts/weekly/tags/2024-june"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"June","permalink":"/posts/weekly/tags/june"}],"readingTime":0.27,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 24 in Packit","date":"2024-06-18T00:00:00.000Z","authors":"flachman","tags":["2024-June","2024","June"]},"prevItem":{"title":"Week 25 in Packit","permalink":"/posts/weekly/2024/week-25"},"nextItem":{"title":"Week 22 in Packit","permalink":"/posts/weekly/2024/week-22"}},"content":"## Week 24 (June 11th \u2013 June 17th)\\n\\n- We have fixed a bug that caused inconsistency between the promised environment variables (from the docs) and the environment that has been actually provided. Now you should have access to `PACKIT_UPSTREAM_REPO` and `PACKIT_DOWNSTREAM_REPO` (in case of `propose_downstream` and `pull_from_upstream` jobs), in the `post-upstream-clone` action. ([packit#2327](https://github.com/packit/packit/pull/2327))"},{"id":"/2024/week-22","metadata":{"permalink":"/posts/weekly/2024/week-22","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-22.md","source":"@site/weekly/2024/week-22.md","title":"Week 22 in Packit","description":"Week 22 (May 28th \u2013 June 3rd)","date":"2024-06-03T00:00:00.000Z","formattedDate":"June 3, 2024","tags":[{"label":"2024-May","permalink":"/posts/weekly/tags/2024-may"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"May","permalink":"/posts/weekly/tags/may"}],"readingTime":0.185,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 22 in Packit","date":"2024-06-03T00:00:00.000Z","authors":"lbarczio","tags":["2024-May","2024","May"]},"prevItem":{"title":"Week 24 in Packit","permalink":"/posts/weekly/2024/week-24"},"nextItem":{"title":"Week 21 in Packit","permalink":"/posts/weekly/2024/week-21"}},"content":"## Week 22 (May 28th \u2013 June 3rd)\\n\\n- Issue with pushing to CentOS Stream dist-git on GitLab is now resolved.\\n ([packit-service#2433](https://github.com/packit/packit-service/pull/2433))\\n- Check for `allowed_pr_authors`/`allowed_committers` configuration before running Koji production builds is now more reliable.\\n ([packit/packit-service#2435](https://github.com/packit/packit-service/pull/2435))"},{"id":"/2024/week-21","metadata":{"permalink":"/posts/weekly/2024/week-21","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-21.md","source":"@site/weekly/2024/week-21.md","title":"Week 21 in Packit","description":"Week 21 (May 21st \u2013 May 27th)","date":"2024-05-27T00:00:00.000Z","formattedDate":"May 27, 2024","tags":[{"label":"2024-May","permalink":"/posts/weekly/tags/2024-may"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"May","permalink":"/posts/weekly/tags/may"}],"readingTime":0.11,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 21 in Packit","date":"2024-05-27T00:00:00.000Z","authors":"mfocko","tags":["2024-May","2024","May"]},"prevItem":{"title":"Week 22 in Packit","permalink":"/posts/weekly/2024/week-22"},"nextItem":{"title":"Week 20 in Packit","permalink":"/posts/weekly/2024/week-20"}},"content":"## Week 21 (May 21st \u2013 May 27th)\\n\\n- We have fixed the syncing of ACLs for `propose-downtream` for CentOS Stream. ([packit#2318](https://github.com/packit/packit/pull/2318))"},{"id":"/2024/week-20","metadata":{"permalink":"/posts/weekly/2024/week-20","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-20.md","source":"@site/weekly/2024/week-20.md","title":"Week 20 in Packit","description":"Week 20 (May 14th \u2013 May 20th)","date":"2024-05-20T00:00:00.000Z","formattedDate":"May 20, 2024","tags":[{"label":"2024-May","permalink":"/posts/weekly/tags/2024-may"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"May","permalink":"/posts/weekly/tags/may"}],"readingTime":0.25,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 20 in Packit","date":"2024-05-20T00:00:00.000Z","authors":"mmassari","tags":["2024-May","2024","May"]},"prevItem":{"title":"Week 21 in Packit","permalink":"/posts/weekly/2024/week-21"},"nextItem":{"title":"Week 19 in Packit","permalink":"/posts/weekly/2024/week-19"}},"content":"## Week 20 (May 14th \u2013 May 20th)\\n\\n- When running `dist-git init` command from CLI, you can pass a command to specify the git URL of the project. ([packit#2308](https://github.com/packit/packit/pull/2308))\\n- We have fixed the incorrect displaying of the time it took for the jobs to run on dashboard. ([dashboard#408](https://github.com/packit/dashboard/pull/408))"},{"id":"/2024/week-19","metadata":{"permalink":"/posts/weekly/2024/week-19","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-19.md","source":"@site/weekly/2024/week-19.md","title":"Week 19 in Packit","description":"Week 19 (May 7th \u2013 May 13th)","date":"2024-05-13T00:00:00.000Z","formattedDate":"May 13, 2024","tags":[{"label":"2024-May","permalink":"/posts/weekly/tags/2024-may"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"May","permalink":"/posts/weekly/tags/may"}],"readingTime":0.215,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 19 in Packit","date":"2024-05-13T00:00:00.000Z","authors":"flachman","tags":["2024-May","2024","May"]},"prevItem":{"title":"Week 20 in Packit","permalink":"/posts/weekly/2024/week-20"},"nextItem":{"title":"Week 18 in Packit","permalink":"/posts/weekly/2024/week-18"}},"content":"## Week 19 (May 7th \u2013 May 13th)\\n\\n- Added a `scan-in-osh` subcommand in the CLI to perform a scan through OpenScanHub. By default it performs a full scan of the packages and a differential scan can be performed through `--base-srpm` option. ([packit#2301](https://github.com/packit/packit/pull/2301))"},{"id":"/2024/week-18","metadata":{"permalink":"/posts/weekly/2024/week-18","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-18.md","source":"@site/weekly/2024/week-18.md","title":"Week 18 in Packit","description":"Week 18 (April 30th \u2013 May 6th)","date":"2024-05-06T00:00:00.000Z","formattedDate":"May 6, 2024","tags":[{"label":"2024-April","permalink":"/posts/weekly/tags/2024-april"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"April","permalink":"/posts/weekly/tags/april"}],"readingTime":0.49,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 18 in Packit","date":"2024-05-06T00:00:00.000Z","authors":"nforro","tags":["2024-April","2024","April"]},"prevItem":{"title":"Week 19 in Packit","permalink":"/posts/weekly/2024/week-19"},"nextItem":{"title":"Week 17 in Packit","permalink":"/posts/weekly/2024/week-17"}},"content":"## Week 18 (April 30th \u2013 May 6th)\\n\\n- Packit will now upload to lookaside cache sources that are not specified by URLs\\n and are present in the dist-git repo during release sync. Additionally, all the actions\\n ran during syncing release will provide the `PACKIT_PROJECT_VERSION` environment variable.\\n ([packit#2297](https://github.com/packit/packit/pull/2297))\\n- We have introduced a new `status_name_template` option that allows you to configure\\n status name for a Packit job. For further details have a look at our\\n [docs](https://packit.dev/docs/configuration#status_name_template).\\n This feature is still experimental and at the moment it is not possible\\n to retry such jobs via GitHub Checks\' re-run.\\n ([packit-service#2402](https://github.com/packit/packit-service/pull/2402))"},{"id":"/2024/week-17","metadata":{"permalink":"/posts/weekly/2024/week-17","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-17.md","source":"@site/weekly/2024/week-17.md","title":"Week 17 in Packit","description":"Week 17 (April 23rd \u2013 April 29th)","date":"2024-04-29T00:00:00.000Z","formattedDate":"April 29, 2024","tags":[{"label":"2024-April","permalink":"/posts/weekly/tags/2024-april"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"April","permalink":"/posts/weekly/tags/april"}],"readingTime":0.48,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 17 in Packit","date":"2024-04-29T00:00:00.000Z","authors":"lbarczio","tags":["2024-April","2024","April"]},"prevItem":{"title":"Week 18 in Packit","permalink":"/posts/weekly/2024/week-18"},"nextItem":{"title":"Week 16 in Packit","permalink":"/posts/weekly/2024/week-16"}},"content":"## Week 17 (April 23rd \u2013 April 29th)\\n\\n- We have fixed the syncing of ACLs during CentOS Stream release syncing.\\n ([packit#2298](https://github.com/packit/packit/pull/2298))\\n- `koji_build` job has a new `sidetag_group` option that allows to perform a downstream Koji build in a sidetag.\\n A new sidetag will be created for each configured `dist_git_branch` if it doesn\'t already exist.\\n This represents the first step towards multi-package Bodhi updates. Stay tuned for further advancements!\\n ([packit-service#2409](https://github.com/packit/packit-service/pull/2409))\\n- We have fixed an issue when `copr_build` job status checks were sometimes wrongly updated with a misleading\\n message after a SRPM build failure. ([packit-service#2406](https://github.com/packit/packit-service/pull/2406))"},{"id":"/2024/week-16","metadata":{"permalink":"/posts/weekly/2024/week-16","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-16.md","source":"@site/weekly/2024/week-16.md","title":"Week 16 in Packit","description":"Week 16 (April 16th \u2013 April 22nd)","date":"2024-04-22T00:00:00.000Z","formattedDate":"April 22, 2024","tags":[{"label":"2024-April","permalink":"/posts/weekly/tags/2024-april"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"April","permalink":"/posts/weekly/tags/april"}],"readingTime":0.57,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 16 in Packit","date":"2024-04-22T00:00:00.000Z","authors":"mfocko","tags":["2024-April","2024","April"]},"prevItem":{"title":"Week 17 in Packit","permalink":"/posts/weekly/2024/week-17"},"nextItem":{"title":"Week 15 in Packit","permalink":"/posts/weekly/2024/week-15"}},"content":"## Week 16 (April 16th \u2013 April 22nd)\\n\\n- `packit dist-git init` now allows specifying `--version-update-mask` option and also any arbitrary top-level configuration options. ([packit#2288](https://github.com/packit/packit/pull/2288))\\n- We have fixed Packit auto-referencing Upstream Release Monitoring bug for release syncing to CentOS Stream. ([packit#2284](https://github.com/packit/packit/pull/2284))\\n- We have changed the behaviour of `/packit test` comment command: in case there is a missing build for some target, the build will not be triggered anymore, it will just be reported to the user. We needed to make this change as with the increased complexity of the configuration (multiple test jobs), the previous implementation was prone to race conditions leading to wasting of resources of Copr and Testing Farm. ([packit-service#2399](https://github.com/packit/packit-service/pull/2399))"},{"id":"/2024/week-15","metadata":{"permalink":"/posts/weekly/2024/week-15","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-15.md","source":"@site/weekly/2024/week-15.md","title":"Week 15 in Packit","description":"Week 15 (April 9th \u2013 April 15th)","date":"2024-04-15T00:00:00.000Z","formattedDate":"April 15, 2024","tags":[{"label":"2024-April","permalink":"/posts/weekly/tags/2024-april"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"April","permalink":"/posts/weekly/tags/april"}],"readingTime":0.145,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 15 in Packit","date":"2024-04-15T00:00:00.000Z","authors":"mmassari","tags":["2024-April","2024","April"]},"prevItem":{"title":"Week 16 in Packit","permalink":"/posts/weekly/2024/week-16"},"nextItem":{"title":"Week 14 in Packit","permalink":"/posts/weekly/2024/week-14"}},"content":"## Week 15 (April 9th \u2013 April 15th)\\n\\n- We have planned the work for the next quarter, curious about what will come next? You can find it [here](https://github.com/orgs/packit/projects/7/views/29)."},{"id":"/2024/week-14","metadata":{"permalink":"/posts/weekly/2024/week-14","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-14.md","source":"@site/weekly/2024/week-14.md","title":"Week 14 in Packit","description":"Week 14 (April 2nd \u2013 April 8th)","date":"2024-04-08T00:00:00.000Z","formattedDate":"April 8, 2024","tags":[{"label":"2024-April","permalink":"/posts/weekly/tags/2024-april"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"April","permalink":"/posts/weekly/tags/april"}],"readingTime":0.24,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 14 in Packit","date":"2024-04-08T00:00:00.000Z","authors":"flachman","tags":["2024-April","2024","April"]},"prevItem":{"title":"Week 15 in Packit","permalink":"/posts/weekly/2024/week-15"},"nextItem":{"title":"Week 13 in Packit","permalink":"/posts/weekly/2024/week-13"}},"content":"## Week 14 (April 2nd \u2013 April 8th)\\n\\n- We have fixed a race condition that could occur when multiple `copr_build` jobs sharing a Copr project but having different targets were running at the same time. ([packit#2274](https://github.com/packit/packit/pull/2274))\\n- We have fixed reporting of tests with `manual_trigger: True`. ([packit-service#2389](https://github.com/packit/packit-service/pull/2389))"},{"id":"/2024/week-13","metadata":{"permalink":"/posts/weekly/2024/week-13","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-13.md","source":"@site/weekly/2024/week-13.md","title":"Week 13 in Packit","description":"Week 13 (March 27th \u2013 April 2nd)","date":"2024-04-02T00:00:00.000Z","formattedDate":"April 2, 2024","tags":[{"label":"2024-March","permalink":"/posts/weekly/tags/2024-march"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"March","permalink":"/posts/weekly/tags/march"}],"readingTime":0.475,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 13 in Packit","date":"2024-04-02T00:00:00.000Z","authors":"nforro","tags":["2024-March","2024","March"]},"prevItem":{"title":"Week 14 in Packit","permalink":"/posts/weekly/2024/week-14"},"nextItem":{"title":"Week 12 in Packit","permalink":"/posts/weekly/2024/week-12"}},"content":"## Week 13 (March 27th \u2013 April 2nd)\\n\\n- The default behaviour of changelog entry generation has been changed to comply with Fedora Packaging Guidelines\\n (see the relevant Fedora Packaging Committee [discussion](https://pagure.io/packaging-committee/issue/1339)).\\n From now on, the default changelog entry is \\"- Update to version \\\\\\".\\n Users can still affect this behaviour using custom commands in the `changelog-entry` action\\n or with the `copy_upstream_release_description` configuration option.\\n ([packit#2253](https://github.com/packit/packit/pull/2253))\\n\\n- \\"[packit]\\" prefix has been removed from default dist-git commit message titles in order to prevent\\n unnecessary noise in autogenerated changelog. Users can override this using the `commit-message` action.\\n ([packit#2263](https://github.com/packit/packit/pull/2263))"},{"id":"/2024/week-12","metadata":{"permalink":"/posts/weekly/2024/week-12","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-12.md","source":"@site/weekly/2024/week-12.md","title":"Week 12 in Packit","description":"Week 12 (March 19th \u2013 March 25th)","date":"2024-03-25T00:00:00.000Z","formattedDate":"March 25, 2024","tags":[{"label":"2024-March","permalink":"/posts/weekly/tags/2024-march"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"March","permalink":"/posts/weekly/tags/march"}],"readingTime":0.35,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 12 in Packit","date":"2024-03-25T00:00:00.000Z","authors":"lbarczio","tags":["2024-March","2024","March"]},"prevItem":{"title":"Week 13 in Packit","permalink":"/posts/weekly/2024/week-13"},"nextItem":{"title":"Week 11 in Packit","permalink":"/posts/weekly/2024/week-11"}},"content":"## Week 12 (March 19th \u2013 March 25th)\\n\\n- Packit no longer shows status checks for not yet triggered manual tests.\\n ([packit-service#2375](https://github.com/packit/packit-service/pull/2375))\\n- `packit validate-config` now checks whether `upstream_project_url` is set if `pull_from_upstream` job is configured.\\n ([packit#2254](https://github.com/packit/packit/pull/2254))\\n- We have fixed an issue in `%prep` section processing. For instance, if the `%patches` macro appeared there,\\n it would have been converted to `%patch es`, causing failure when executing `%prep` later.\\n ([specfile#356](https://github.com/packit/specfile/pull/356))"},{"id":"/2024/week-11","metadata":{"permalink":"/posts/weekly/2024/week-11","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-11.md","source":"@site/weekly/2024/week-11.md","title":"Week 11 in Packit","description":"Week 11 (March 12th \u2013 March 18th)","date":"2024-03-18T00:00:00.000Z","formattedDate":"March 18, 2024","tags":[{"label":"2024-March","permalink":"/posts/weekly/tags/2024-march"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"March","permalink":"/posts/weekly/tags/march"}],"readingTime":0.31,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 11 in Packit","date":"2024-03-18T00:00:00.000Z","authors":"mfocko","tags":["2024-March","2024","March"]},"prevItem":{"title":"Week 12 in Packit","permalink":"/posts/weekly/2024/week-12"},"nextItem":{"title":"Week 10 in Packit","permalink":"/posts/weekly/2024/week-10"}},"content":"## Week 11 (March 12th \u2013 March 18th)\\n\\n- Don\'t have time to set up Packit? Or, do you want to see what it would look like on your package?\\n Starting now, you can [ask the Packit team](https://github.com/packit/packit-service/issues/new?assignees=&labels=onboarding&projects=&template=onboarding.yml&title=Onboard+%5Bmy+package%5D) to prepare a config file for you. ([packit-service#2369](https://github.com/packit/packit-service/pull/2369))\\n- A trailing newline is no longer added to spec files without one upon saving. ([specfile#353](https://github.com/packit/specfile/pull/353))"},{"id":"/2024/week-10","metadata":{"permalink":"/posts/weekly/2024/week-10","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-10.md","source":"@site/weekly/2024/week-10.md","title":"Week 10 in Packit","description":"Week 10 (March 5th \u2013 March 11th)","date":"2024-03-11T00:00:00.000Z","formattedDate":"March 11, 2024","tags":[{"label":"2024-March","permalink":"/posts/weekly/tags/2024-march"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"March","permalink":"/posts/weekly/tags/march"}],"readingTime":0.17,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 10 in Packit","date":"2024-03-11T00:00:00.000Z","authors":"mmassari","tags":["2024-March","2024","March"]},"prevItem":{"title":"Week 11 in Packit","permalink":"/posts/weekly/2024/week-11"},"nextItem":{"title":"Week 9 in Packit","permalink":"/posts/weekly/2024/week-9"}},"content":"## Week 10 (March 5th \u2013 March 11th)\\n\\n- You can now configure a list of Fedora accounts of users whose successful Koji builds will trigger automatic Bodhi updates (by default only `packit`). ([packit-service#2364](https://github.com/packit/packit-service/pull/2364))"},{"id":"/2024/week-9","metadata":{"permalink":"/posts/weekly/2024/week-9","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-9.md","source":"@site/weekly/2024/week-9.md","title":"Week 9 in Packit","description":"Week 9 (February 27th \u2013 March 4th)","date":"2024-03-04T00:00:00.000Z","formattedDate":"March 4, 2024","tags":[{"label":"2024-February","permalink":"/posts/weekly/tags/2024-february"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"February","permalink":"/posts/weekly/tags/february"}],"readingTime":0.315,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 9 in Packit","date":"2024-03-04T00:00:00.000Z","authors":"mfocko","tags":["2024-February","2024","February"]},"prevItem":{"title":"Week 10 in Packit","permalink":"/posts/weekly/2024/week-10"},"nextItem":{"title":"Week 8 in Packit","permalink":"/posts/weekly/2024/week-8"}},"content":"## Week 9 (February 27th \u2013 March 4th)\\n\\n- We have fixed the bug about Packit overwriting the final state of the build in case the build start is being processed later than the end of the build. ([packit-service#2358](https://github.com/packit/packit-service/pull/2358))\\n- We have improved the reporting of configuration errors in GitLab. ([packit-service#2357](https://github.com/packit/packit-service/pull/2357))\\n- `GitLabProject.get_file_content()` can now correctly handle file paths starting with `./`. ([ogr#844](https://github.com/packit/ogr/pull/844))"},{"id":"/2024/week-8","metadata":{"permalink":"/posts/weekly/2024/week-8","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-8.md","source":"@site/weekly/2024/week-8.md","title":"Week 8 in Packit","description":"Week 8 (February 20th \u2013 February 26th)","date":"2024-02-26T00:00:00.000Z","formattedDate":"February 26, 2024","tags":[{"label":"2024-February","permalink":"/posts/weekly/tags/2024-february"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"February","permalink":"/posts/weekly/tags/february"}],"readingTime":0.135,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 8 in Packit","date":"2024-02-26T00:00:00.000Z","authors":"flachman","tags":["2024-February","2024","February"]},"prevItem":{"title":"Week 9 in Packit","permalink":"/posts/weekly/2024/week-9"},"nextItem":{"title":"Week 7 in Packit","permalink":"/posts/weekly/2024/week-7"}},"content":"## Week 8 (February 20th \u2013 February 26th)\\n\\n- Packit now checks the version to propose against the version in specfile and doesn\'t create downgrade PRs. ([packit#2239](https://github.com/packit/packit/pull/2239))"},{"id":"/2024/week-7","metadata":{"permalink":"/posts/weekly/2024/week-7","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-7.md","source":"@site/weekly/2024/week-7.md","title":"Week 7 in Packit","description":"Week 7 (February 13th \u2013 February 19th)","date":"2024-02-19T00:00:00.000Z","formattedDate":"February 19, 2024","tags":[{"label":"2024-February","permalink":"/posts/weekly/tags/2024-february"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"February","permalink":"/posts/weekly/tags/february"}],"readingTime":0.565,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 7 in Packit","date":"2024-02-19T00:00:00.000Z","authors":"lbarczio","tags":["2024-February","2024","February"]},"prevItem":{"title":"Week 8 in Packit","permalink":"/posts/weekly/2024/week-8"},"nextItem":{"title":"Week 6 in Packit","permalink":"/posts/weekly/2024/week-6"}},"content":"## Week 7 (February 13th \u2013 February 19th)\\n\\n- Packit now supports special value `ignore` for `trigger` in jobs configuration that indicates not to execute the job at all.\\n This can be useful for templates or temporarily disabled jobs. ([packit#2234](https://github.com/packit/packit/pull/2234))\\n- We have fixed the caching of data for the usage API endpoint. ([packit-service#2350](https://github.com/packit/packit-service/pull/2350))\\n- We have fixed an issue that caused loading the same data multiple times on the dashboard within the project views. ([packit-service#2349](https://github.com/packit/packit-service/pull/2349))\\n- We have also fixed crashing of dashboard\'s `Usage` page in case of unsuccessful queries. ([dashboard#378](https://github.com/packit/dashboard/pull/378))\\n- We have fixed parsing of resolved Bugzillas in comments with multiple arguments specified,\\n e.g. `/packit pull-from-upstream --with-pr-config --resolved-bugs rhbz#123`. ([packit-service#2346](https://github.com/packit/packit-service/pull/2346))"},{"id":"/2024/week-6","metadata":{"permalink":"/posts/weekly/2024/week-6","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-6.md","source":"@site/weekly/2024/week-6.md","title":"Week 6 in Packit","description":"Week 6 (February 6th \u2013 February 12th)","date":"2024-02-12T00:00:00.000Z","formattedDate":"February 12, 2024","tags":[{"label":"2024-February","permalink":"/posts/weekly/tags/2024-february"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"February","permalink":"/posts/weekly/tags/february"}],"readingTime":0.555,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 6 in Packit","date":"2024-02-12T00:00:00.000Z","authors":"mmassari","tags":["2024-February","2024","February"]},"prevItem":{"title":"Week 7 in Packit","permalink":"/posts/weekly/2024/week-7"},"nextItem":{"title":"Week 5 in Packit","permalink":"/posts/weekly/2024/week-5"}},"content":"## Week 6 (February 6th \u2013 February 12th)\\n\\n- Packit now searches for bugzilla about new release created by Upstream Release Monitoring to reference each time it syncs the release downstream. ([packit#2229](https://github.com/packit/packit/pull/2229))\\n- We have introduced new CLI command `packit dist-git init` that initializes Packit configuration for release automation in dist-git repository. ([packit#2225](https://github.com/packit/packit/pull/2225))\\n- We have introduced new configuration options `require.label.present` and `require.label.absent`. By configuring these you can specify labels that need to be present or absent on a pull request for Packit to react on such PR. ([packit-service#2333](https://github.com/packit/packit-service/pull/2333))\\n- Interface for labels was unified and `labels` property for PullRequest and Issue now return list of PRLabel and IssueLabel respectively. ([ogr#839](https://github.com/packit/ogr/pull/839))"},{"id":"/2024/week-5","metadata":{"permalink":"/posts/weekly/2024/week-5","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-5.md","source":"@site/weekly/2024/week-5.md","title":"Week 5 in Packit","description":"Week 5 (January 30th \u2013 February 5th)","date":"2024-02-05T00:00:00.000Z","formattedDate":"February 5, 2024","tags":[{"label":"2024-February","permalink":"/posts/weekly/tags/2024-february"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"February","permalink":"/posts/weekly/tags/february"}],"readingTime":0.355,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 5 in Packit","date":"2024-02-05T00:00:00.000Z","authors":"mmassari","tags":["2024-February","2024","February"]},"prevItem":{"title":"Week 6 in Packit","permalink":"/posts/weekly/2024/week-6"},"nextItem":{"title":"Week 4 in Packit","permalink":"/posts/weekly/2024/week-4"}},"content":"## Week 5 (January 30th \u2013 February 5th)\\n\\n- `packit validate-config` now checks whether the Upstream Release Monitoring for the package is correctly configured if `pull_from_upstream` job is present in the configuration. ([packit#2226](https://github.com/packit/packit/pull/2226))\\n- There is a new global configuration option `parse_time_macros` that allows to configure macros to be explicitly defined or undefined at spec file parse time. ([packit#2222](https://github.com/packit/packit/pull/2222))\\n- We have added additional retries and improvements for task processing. ([packit-service#2326](https://github.com/packit/packit-service/pull/2326))"},{"id":"/2024/week-4","metadata":{"permalink":"/posts/weekly/2024/week-4","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-4.md","source":"@site/weekly/2024/week-4.md","title":"Week 4 in Packit","description":"Week 4 (January 23rd \u2013 January 29th)","date":"2024-01-29T00:00:00.000Z","formattedDate":"January 29, 2024","tags":[{"label":"2024-January","permalink":"/posts/weekly/tags/2024-january"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"January","permalink":"/posts/weekly/tags/january"}],"readingTime":0.505,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 4 in Packit","date":"2024-01-29T00:00:00.000Z","authors":"mfocko","tags":["2024-January","2024","January"]},"prevItem":{"title":"Week 5 in Packit","permalink":"/posts/weekly/2024/week-5"},"nextItem":{"title":"Week 3 in Packit","permalink":"/posts/weekly/2024/week-3"}},"content":"## Week 4 (January 23rd \u2013 January 29th)\\n\\n- `pull-from-upstream` and `propose-downstream` commands now have the `--sync-acls` option that enables syncing the ACLs between dits-git repo and fork. The default behaviour was, however, **changed to not sync** the ACLs. ([packit#2214](https://github.com/packit/packit/pull/2214))\\n- Packit now properly handles exceptions when syncing ACLs during release syncing. ([packit#2213](https://github.com/packit/packit/pull/2213))\\n- `allowed_pr_authors` and `allowed_committers` now allow specifying groups and also aliases `all_admins` and `all_committers` (corresponding to the access to the repository). ([packit-service#2320](https://github.com/packit/packit-service/pull/2320))\\n- ogr now supports 2 new methods for Pagure: one for getting users with specified access rights and one for getting members of a group. ([ogr#834](https://github.com/packit/ogr/pull/834))"},{"id":"/2024/week-3","metadata":{"permalink":"/posts/weekly/2024/week-3","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-3.md","source":"@site/weekly/2024/week-3.md","title":"Week 3 in Packit","description":"Week 3 (January 16th \u2013 January 22nd)","date":"2024-01-22T00:00:00.000Z","formattedDate":"January 22, 2024","tags":[{"label":"2024-January","permalink":"/posts/weekly/tags/2024-january"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"January","permalink":"/posts/weekly/tags/january"}],"readingTime":0.5,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 3 in Packit","date":"2024-01-22T00:00:00.000Z","authors":"flachman","tags":["2024-January","2024","January"]},"prevItem":{"title":"Week 4 in Packit","permalink":"/posts/weekly/2024/week-4"},"nextItem":{"title":"Week 2 in Packit","permalink":"/posts/weekly/2024/week-2"}},"content":"## Week 3 (January 16th \u2013 January 22nd)\\n\\n- Packit now properly handles exceptions when syncing ACLs during release syncing. ([packit#2213](https://github.com/packit/packit/pull/2213))\\n- We have fixed a bug in handling chroot-specific configuration once the chroots themselves are updated. ([packit#2194](https://github.com/packit/packit/pull/2194))\\n- We have increased the number of retries of Fedora release syncing for situations where the tarball is uploaded some time after the release happens. ([packit-service#2307](https://github.com/packit/packit-service/pull/2307))\\n- There is a new API endpoint `/bodhi-updates` for getting information about Bodhi updates submitted by Packit. ([packit-service#2310](https://github.com/packit/packit-service/pull/2310))\\n- For `/packit test` command, you can now also use `-i` and `--id` aliases for `--identifier` option. ([packit-service#2309](https://github.com/packit/packit-service/pull/2309))"},{"id":"/2024/week-2","metadata":{"permalink":"/posts/weekly/2024/week-2","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-2.md","source":"@site/weekly/2024/week-2.md","title":"Week 2 in Packit","description":"Week 2 (January 9th \u2013 January 15th)","date":"2024-01-15T00:00:00.000Z","formattedDate":"January 15, 2024","tags":[{"label":"2024-January","permalink":"/posts/weekly/tags/2024-january"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"January","permalink":"/posts/weekly/tags/january"}],"readingTime":0.195,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 2 in Packit","date":"2024-01-15T00:00:00.000Z","authors":"lbarczio","tags":["2024-January","2024","January"]},"prevItem":{"title":"Week 3 in Packit","permalink":"/posts/weekly/2024/week-3"},"nextItem":{"title":"Week 1 in Packit","permalink":"/posts/weekly/2024/week-1"}},"content":"## Week 2 (January 9th \u2013 January 15th)\\n\\n- We have fixed the behaviour of identifying the most recent git tag. This has previously caused issues\\n when building SRPMs for projects with different version tags in different branches.\\n ([packit-service#2302](https://github.com/packit/packit-service/pull/2302))"},{"id":"/2024/week-1","metadata":{"permalink":"/posts/weekly/2024/week-1","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-1.md","source":"@site/weekly/2024/week-1.md","title":"Week 1 in Packit","description":"Week 1 (January 2nd \u2013 January 8th)","date":"2024-01-08T00:00:00.000Z","formattedDate":"January 8, 2024","tags":[{"label":"2024-January","permalink":"/posts/weekly/tags/2024-january"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"January","permalink":"/posts/weekly/tags/january"}],"readingTime":0.28,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 1 in Packit","date":"2024-01-08T00:00:00.000Z","authors":"nforro","tags":["2024-January","2024","January"]},"prevItem":{"title":"Week 2 in Packit","permalink":"/posts/weekly/2024/week-2"},"nextItem":{"title":"2023","permalink":"/posts/weekly/2023"}},"content":"## Week 1 (January 2nd \u2013 January 8th)\\n\\n- We have changed the behaviour of loading Packit configuration for `koji_build` and `bodhi_update` jobs.\\n For both of them, the behaviour is the same as for `pull_from_upstream` - the configuration is taken\\n from the default branch of the dist-git repository (usually `rawhide`) and other branches are ignored.\\n ([packit-service#2295](https://github.com/packit/packit-service/pull/2295))"},{"id":"/2023","metadata":{"permalink":"/posts/weekly/2023","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2023.md","source":"@site/weekly/2023.md","title":"2023","description":"Let\'s see what happened in Packit in 2023.","date":"2024-01-01T00:00:00.000Z","formattedDate":"January 1, 2024","tags":[{"label":"2023","permalink":"/posts/weekly/tags/2023"}],"readingTime":19.78,"hasTruncateMarker":true,"authors":[],"frontMatter":{"title":"2023","date":"2024-01-01T00:00:00.000Z","tags":["2023"]},"prevItem":{"title":"Week 1 in Packit","permalink":"/posts/weekly/2024/week-1"},"nextItem":{"title":"Packit workshop - Fedora Community Edition","permalink":"/posts/weekly/2023/packit-workshop"}},"content":"Let\'s see what happened in Packit in 2023.\\n\\n\x3c!--truncate--\x3e\\n\\n## Week 0 \ud83c\udf04 (December 20th 2022 \u2013 January 2nd 2023)\\n\\n- ogr now raises `GitForgeInternalError` rather than `PagureAPIException` when\\n getting 50x response from the Pagure API. This should increase usability as\\n those tasks will be retried.\\n ([ogr#762](https://github.com/packit/ogr/pull/762))\\n- Packit now puts the correct release number into the changelog when the\\n Release tag is reset during propose-downstream.\\n ([packit#1816](https://github.com/packit/packit/pull/1816)))\\n\\n## Week 1 (January 3rd \u2013 January 9th)\\n\\n- SRPMs for projects that installed the GitHub App before September 6th and\\n don\'t have `srpm_build_deps` defined are now built in Copr as well.\\n ([packit-service#1822](https://github.com/packit/packit-service/pull/1822))\\n- We have fixed a bug in dashboard that linked `null` as a Copr build for\\n Testing Farm runs that do not require any Copr build.\\n ([dashboard#200](https://github.com/packit/dashboard/pull/200))\\n- All classes including `Specfile` itself can now be copied using the standard\\n `copy()` and `deepcopy()` functions from `copy` module.\\n ([specfile#176](https://github.com/packit/specfile/pull/176))\\n\\n## Week 2 (January 10th \u2013 January 16th)\\n\\n- When configuring Copr chroot (target in Packit terminology) specific configuration, make sure to specify additional_modules as a string: module names separated with a comma, example: \\"httpd:2.4,python:4\\". ([packit#1826](https://github.com/packit/packit/pull/1826))\\n- We have fixed a bug which caused long Copr build end reporting time on a few occurrences. ([packit-service#1838](https://github.com/packit/packit-service/pull/1838))\\n- A few fixes has been implemented to make it possible to use [`propose-downstream` job](https://packit.dev/docs/configuration/#propose_downstream) on GitLab. ([packit-service#1842](https://github.com/packit/packit-service/pull/1842), [packit-service#1844](https://github.com/packit/packit-service/pull/1844), [packit-service#1845](https://github.com/packit/packit-service/pull/1845), [packit-service#1846](https://github.com/packit/packit-service/pull/1846))\\n\\n## Week 3-4 (January 17th \u2013 January 30th)\\n\\n- Users can now re-trigger _bodhi_update_ and _koji_build_ jobs by `/packit create-update`\\n and `/packit koji-update` comments in an issue opened by Packit in the configured `issue_repository` if anything\\n went wrong during these jobs. ([packit-service#1796](https://github.com/packit/packit-service/pull/1796))\\n- All Copr projects created by Packit now default to `enable_net=False`: our documentation stated this, but it\\n wasn\'t the case. This is now corrected. ([packit#1825](https://github.com/packit/packit/pull/1825))\\n- You can now specify `update_release: false` in the configuration to tell Packit not to change the Version and\\n Release in the spec file. It works the same as `--no-update-release` (renamed from now deprecated `--no-bump`) in\\n the CLI. ([packit#1827](https://github.com/packit/packit/pull/1827))\\n- Packit now supports setting `module_hotfixes` for Copr projects.\\n ([packit#1829](https://github.com/packit/packit/pull/1829))\\n- Packit now also allows passing in free-form parameters to Testing Farm in order to support all of its\\n options immediately once they are added. The parameters can be passed through the `tf_extra_params` config option.\\n The free-form dictionary must follow the structure of Testing Farm POST requests. See [our documentation](https://packit.dev/docs/testing-farm/)\\n and examples for more information. ([packit-service#1853](https://github.com/packit/packit-service/pull/1853))\\n- Fixed a bug in section parsing that caused sections to be ignored when there were macro definitions spread\\n across the spec file and not cumulated at the top. ([specfile#191](https://github.com/packit/specfile/pull/191))\\n- Also fixed the infinite loop that occurred when section options were followed by whitespace.\\n ([specfile#197](https://github.com/packit/specfile/pull/197))\\n\\n## Weeks 5\u20136 (February 1st \u2013 February 13th)\\n\\n- You can now use `--srpm` option with the `packit build locally` CLI command. ([packit#1810](https://github.com/packit/packit/pull/1810))\\n- You will newly see news about Packit as a footer of the GitHub check runs summary. ([packit-service#1881](https://github.com/packit/packit-service/pull/1881))\\n- Packit now groups related builds and test runs (e.g. triggered by the same event, just different chroots) together. In the future, this will allow better presentation of the overall pipelines (e.g. in the dashboard). We now also create database entries before sending requests to external service (e.g. Testing Farm), therefore failures will be more visible in the dashboard. ([packit-service#1787](https://github.com/packit/packit-service/pull/1787))\\n\\n## Week 7 (February 14th \u2013 February 20th)\\n\\n- Packit now provides `PACKIT_PROJECT_VERSION` environment variable when running `changelog-entry` action. ([packit#1853](https://github.com/packit/packit/pull/1853))\\n- Packit CLI now requires bodhi in version 7.0.0 at minimum. ([packit#1844](https://github.com/packit/packit/pull/1844))\\n- You can now specify branches for a job triggered by a commit with a regex. ([packit-service#1909](https://github.com/packit/packit-service/pull/1909))\\n\\n## Week 8 (February 21st \u2013 February 27th)\\n\\n- `packit validate-config` CLI command now provides details about errors when it cannot parse the config file. ([packit#1861](https://github.com/packit/packit/pull/1861))\\n- `--update-release`/`--no-update-release` CLI flag now affects only `Release`, not `Version`. ([packit#1857](https://github.com/packit/packit/pull/1857))\\n- Packit does fewer API calls when searching for the package configuration file in remote repositories. ([packit#1846](https://github.com/packit/packit/pull/1846))\\n- Commit statuses/check names will now contain the name of the branch or release for the build and test jobs with `commit` or `release` trigger.\\n This will prevent the collision of the names. ([packit-service#1920](https://github.com/packit/packit-service/pull/1920))\\n\\n## Week 9 (February 28th \u2013 March 6th)\\n\\n- Aliases logic was updated to account for the upcoming Fedora release (Bodhi now marks such release as `frozen`). From now on, Fedora 38 updates will be created even when the release is frozen. ([packit#1863](https://github.com/packit/packit/pull/1863))\\n- `packit validate-config` now correctly checks glob-patterns in \'files_to_sync\' ([packit#1865](https://github.com/packit/packit/pull/1865)) and provides details about errors when it cannot parse a config file. ([packit#1861](https://github.com/packit/packit/pull/1861))\\n- Pull-from-upstream jobs are now displayed on our dashboard \ud83e\udd73 https://dashboard.packit.dev/jobs/pull-from-upstreams ([packit-service#1951](https://github.com/packit/packit-service/pull/1951), [packit-service#1939](https://github.com/packit/packit-service/pull/1939))\\n- Packit will no longer automatically request access to the forks on GitLab. This will prevent us from spamming one-time contributors with requesting the access, whereas the regular contributors can add Packit following the instructions from the comments on the MRs, so they can receive the results of Packit pipeline right from the commit statuses. ([packit-service#1946](https://github.com/packit/packit-service/pull/1946))\\n- Packit will retry tasks that are interrupted by a worker shutdown. This should improve throughput and reduce cases where there is no outcome, i.e. \\"builds should have been done but nothing happened\\". ([packit-service#1935](https://github.com/packit/packit-service/pull/1935))\\n- OGR now understands a few community-hosted GitLab instances that could not be determined automatically from the hostname. Thanks to that, you don\'t need to hardcode these instances to be mapped correctly. ([ogr#775](https://github.com/packit/ogr/pull/775))\\n\\nThank you, [@SpyTec](https://github.com/SpyTec) for so many [wonderful changes in our dasbhoard](https://github.com/packit/dashboard/pulls?q=is%3Apr+author%3ASpyTec).\\n\\n## Week 10 (March 7th \u2013 March 13th)\\n\\n- Parsing the spec file by RPM is now performed only if really necessary, greatly improving performance in certain scenarios. ([specfile#212](https://github.com/packit/specfile/pull/212))\\n\\n## Week 11 (March 14th \u2013 March 20th)\\n\\n- Packit now uses the `get_current_version` action defined by the user to retrieve version before updating the specfile %setup macro (if any). ([packit#1886](https://github.com/packit/packit/pull/1886))\\n\\n## Week 12 (March 21st \u2013 March 27th)\\n\\n- \'upstream_tag_template\' is now also used when looking for the latest version tag in Git.\\n This allows upstream repositories to mix different tag-patterns in the same repository,\\n but consider only one to tell the latest version.\\n ([packit#1891](https://github.com/packit/packit/pull/1891))\\n\\n## Week 13 (March 28th \u2013 April 3rd)\\n\\n- Packit now preserves `%autorelease` during `propose_downstream` and `pull_from_upstream`. ([packit#1904](https://github.com/packit/packit/pull/1904))\\n- Since in GitLab, it is not possible to overwrite the pending statuses, Packit now provides more generic descriptions and URLs when setting the first pending status. ([packit-service#1975](https://github.com/packit/packit-service/pull/1975))\\n\\n## Weeks 14\u201315 (April 3rd \u2013 April 17th)\\n\\n- `packit source-git` related commands can skip dist-git repos, where the git trailer is not found, when looking for the right dist-git dir where to work. ([packit#1938](https://github.com/packit/packit/pull/1938))\\n- Tmt tests can now be run with fmf root outside of git root ([packit#1936](https://github.com/packit/packit/pull/1936))\\n- Commits created by Packit no longer contain the \\"Signed-off-by\\" tag. ([packit#1934](https://github.com/packit/packit/pull/1934))\\n- Packit\'s source_git functionality installs/loads the `_packitpatch` script in a more reliable manner that doesn\'t rely on deprecated setuptools functionality. ([packit#1926](https://github.com/packit/packit/pull/1926))\\n- Packit now supports monorepo configuration in CLI ([packit#1864](https://github.com/packit/packit/pull/1864))\\n- Packit should now correctly catch the logs if any of the user actions fail during `propose_downstream`. ([packit#1939](https://github.com/packit/packit/pull/1939))\\n- Packit now resets `Release` field in dist-git spec file to 1 when the version in upstream spec file is not up-to-date with the release that triggered `propose_downstream`. ([packit#1940](https://github.com/packit/packit/pull/1940))\\n\\n## Week 16 (April 18th \u2013 April 24th)\\n\\n- Packit now complies with [PEP 621](https://peps.python.org/pep-0621/) and stores project metadata in `pyproject.toml`. ([packit#1913](https://github.com/packit/packit/pull/1913))\\n- Packit now properly respects `upstream_ref` for tags that start with \\"a\\", \\"b\\", \\"c\\", \\"e\\", \\"n\\", \\"r\\", \\"s\\". ([packit#1943](https://github.com/packit/packit/pull/1943))\\n- Packit Service now supports multi package configuration (a.k.a. monorepo configuration). ([packit-service#1982](https://github.com/packit/packit-service/pull/1982))\\n\\n## Week 17-18 (April 25th \u2013 May 3rd)\\n\\n- Detection of `%autorelease` usage in dist-git spec file during `propose-downstream` and `pull-from-upstream` has been improved and Packit will always preserve it. ([packit#1949](https://github.com/packit/packit/pull/1949))\\n- We have fixed an issue that prevented you from building in Copr and Koji on release in the GitLab upstream. ([packit-service#2027](https://github.com/packit/packit-service/pull/2027))\\n- TMT tests can now be run with FMF root outside of git root. ([packit-service#2007](https://github.com/packit/packit-service/pull/2007))\\n- When reacting to branch pushes, Packit now correctly checks whether the branch name matches the configuration for the test jobs with configured `commit` trigger. ([packit-service#2015](https://github.com/packit/packit-service/pull/2015))\\n- The `propose-downstream` job triggered by an issue comment now correctly loads the configuration from the upstream repository. ([packit-service#2021](https://github.com/packit/packit-service/pull/2021))\\n- Packit is newly on Mastodon. Or, more specifically, on Fosstodon.\\n Follow [@packit@fosstodon.org](https://fosstodon.org/@packit) and be one of the first to know about all the news!\\n\\n## Week 18 (May 4th - May 9th)\\n\\nWe have experienced issues with automatic Bodhi updates that we are investigating.\\nIn case you miss a Bodhi update, you can\\n[retrigger the job](https://packit.dev/docs/fedora-releases-guide/#retriggering-2) via `/packit create-update`\\ncomment in a dist-git pull request.\\nBesides that, during this short week (another Czech Republic public holiday) we didn\'t manage to implement\\nany significant new features.\\n\\n## Week 19 (May 9th \u2013 May 15th)\\n\\n- Packit now doesn\'t react to its own comments on Pagure and GitLab (on GitHub, this was already implemented).\\n ([packit-service#2048](https://github.com/packit/packit-service/pull/2048))\\n\\n## Week 20 (May 16th \u2013 May 22nd)\\n\\n- We have implemented a denylisting mechanism allowing us to denylist namespaces/projects to prevent misuse of our service. ([packit-service#2046](https://github.com/packit/packit-service/pull/2046))\\n- Packit will now additionally require for each test job requiring build a build job definition to be present in the Packit configuration file. ([packit-service#2012](https://github.com/packit/packit-service/pull/2012))\\n- Packit now checks whether the configured architecture for the test target is supported by Testing Farm and in case it\'s not supported, Packit doesn\'t submit these test requests. ([packit-service#2053](https://github.com/packit/packit-service/pull/2053))\\n\\n## Week 21 (May 23rd \u2013 May 29th)\\n\\n- Unsuccessful Image Builder requests now provide error details so you can fix the Image configuration. ([packit#1981](https://github.com/packit/packit/pull/1981))\\n- Copr projects created by Packit will not follow the Fedora branching from now. This decision has been made to lower the load on Copr from the temporary Copr projects created, mainly, for the PR builds. If you are releasing your packages to the Copr, please use the new setting `follow_fedora_branching`.\\n Already existing projects are not affected by this change and it is also not enforced with the custom Copr repositories. ([packit#1970](https://github.com/packit/packit/pull/1970))\\n- Additional artifact(s) passed as `artifacts` in the `tf_extra_params` dictionary will be now combined with the artifact passed by Packit instead of rewriting it. ([packit-service#2056](https://github.com/packit/packit-service/pull/2056))\\n- Specfile library now handles multiple `%changelog` sections. ([specfile#230](https://github.com/packit/specfile/pull/230))\\n\\n## Week 22 (May 30th \u2013 June 5th)\\n\\n- Packit will now filter the pull requests based on the target branch if the `branch` is specified in the particular job configuration. ([packit-service#2074](https://github.com/packit/packit-service/pull/2074))\\n- Packit now supports `manual_trigger` in the configuration that allows you to make jobs run only when explicitly triggered by a comment. ([packit-service#2069](https://github.com/packit/packit-service/pull/2069))\\n\\n## Week 23 (June 6th \u2013 June 12th)\\n\\n- Our dashboard now shows projects in a table instead of the cards.\\n ([dashboard#267](https://github.com/packit/dashboard/pull/267))\\n- `/packit test` command has two new options:\\n\\n With `--identifier` option, Testing Farm will trigger only jobs with that identifier.\\n ([packit-service#2079](https://github.com/packit/packit-service/pull/2079))\\n\\n Also, it is now possible to specify labels for a job and trigger tests based on labels\\n using a `--labels` option of the `/packit test` command.\\n ([packit#1988](https://github.com/packit/packit/pull/1988),\\n [packit-service#2088](https://github.com/packit/packit-service/pull/2088))\\n\\n- If the `vm_image_build job` doesn\'t have Copr project/owner configured,\\n Copr project used for the latest Copr build of the pull request will be now used.\\n ([packit-service#2080](https://github.com/packit/packit-service/pull/2080))\\n- Fixed filters in `files_to_sync` not being applied properly.\\n ([packit#1977](https://github.com/packit/packit/pull/1977))\\n- The issue that could\'ve caused inconsistencies when tests from a PR\\n were supposed to be merged during the test runs on the Testing Farm has been fixed.\\n ([packit-service#2090](https://github.com/packit/packit-service/pull/2090))\\n\\n## Week 24 (June 13th \u2013 June 19th)\\n\\n- Packit now includes dist-git branch in the title of the PRs for `propose-downstream` and `pull-from-upstream`.\\n ([packit#1996](https://github.com/packit/packit/pull/1996))\\n\\n- Many dashboard issues have been fixed during the\\n [Contribute to an Open Source Service](https://sched.co/1MvMM)\\n workshop at [DevConf.CZ](https://www.devconf.info/cz/).\\n [Stef Walter](https://github.com/stefwalter),\\n [Erik Gustavsson](https://github.com/SpyTec),\\n [Roman Braunstingl](https://github.com/RFJBraunstingl),\\n [Jaroslav Reznik](https://github.com/jreznik),\\n [Christophe de Dinechin](https://github.com/c3d),\\n [Gris Ge](https://github.com/cathay4t)\\n and [David Duncan](https://github.com/davdunc),\\n thank you for your contribution!\\n ([dashboard#291](https://github.com/packit/dashboard/pull/291),\\n [dashboard#292](https://github.com/packit/dashboard/pull/292),\\n [dashboard#293](https://github.com/packit/dashboard/pull/293),\\n [dashboard#294](https://github.com/packit/dashboard/pull/294),\\n [dashboard#295](https://github.com/packit/dashboard/pull/295))\\n\\n## Week 25 (June 21st \u2013 June 27th)\\n\\n- If you are interested about the manual triggering deployed two weeks ago, David Kornel and Jakub Stejskal published [a blog post](https://fedoramagazine.org/how-to-use-testing-farm-outside-of-rhel/) about this on fedoramagazine.org.\\n- Copr builds configured as a monorepo job will now be built in one Copr project together. The bug with overwriting the statuses for monorepo jobs has been fixed as well. ([packit-service#2097](https://github.com/packit/packit-service/pull/2097))\\n\\n## Week 26 (June 27th \u2013 July 3rd)\\n\\n- The bug which prevented errors on Testing Farm request submission from being\\n correctly propagated to the user was fixed.\\n ([packit-service#2103](https://github.com/packit/packit-service/pull/2103))\\n- `pull_from_upstream` jobs can now be retriggered with a comment\\n `/packit pull-from-upstream` in a dist-git pull request.\\n ([packit-service#2087](https://github.com/packit/packit-service/pull/2087))\\n\\n## Week 27 (July 4th \u2013 July 10th)\\n\\n- Packit now correctly reloads upstream specfile after running `pre-sync` action. ([packit#2006](https://github.com/packit/packit/pull/2006))\\n\\n## Week 28 (July 11th \u2013 July 17th)\\n\\n- Packit now includes instructions on how to checkout the dist-git PR locally when syncing the release.\\n ([packit-service#2116](https://github.com/packit/packit-service/pull/2116))\\n- We have fixed a bug in processing options of `%prep` macros in our `specfile` library. For instance, when a quoted\\n string appeared inside an expression expansion, it could lead to improper parsing, rendering the spec file invalid\\n after accessing the options. ([specfile#253](https://github.com/packit/specfile/pull/253))\\n- packit.dev has a new format! As the content has expanded a lot in the recent year, we decided to switch to using\\n [Docosaurus](https://docusaurus.io/):\\n now all the documentation is in one place and this format also enables additional features for our blog posts.\\n ([packit.dev#694](https://github.com/packit/packit.dev/pull/694))\\n\\n## Weeks 29\u201330 (July 18th \u2013 July 31st)\\n\\n- With plenty of team members on vacation, we didn\'t manage to implement any significant new features during these two weeks.\\n\\n## Week 31 (August 1st \u2013 August 7th)\\n\\n- Licenses in Packit specfiles are now confirmed to be SPDX-compatible. (example PR: [packit#2026](https://github.com/packit/packit/pull/2026))\\n If you are interested in more details, see a [talk](https://www.youtube.com/watch?v=Hjhe6jtx3Zw&t=8651s) from Flock 2023 by Mirek.\\n\\n## Week 32 (August 8th \u2013 August 14th)\\n\\n- Two new configuration options for filtering when getting latest upstream release tag were introduced: `upstream_tag_include` and `upstream_tag_exclude`. They should contain a Python regex that can be used as an argument in `re.match`. ([packit#2030](https://github.com/packit/packit/pull/2030), [packit-service#2138](https://github.com/packit/packit-service/pull/2138))\\n- Retriggering of `pull-from-upstream` via a comment will now use the correct configuration file from the default dist-git branch. ([packit-service#2140](https://github.com/packit/packit-service/pull/2140))\\n- The `pull-from-upstream` job can now be used with upstream repos that are not hosted on a supported git forge. ([packit-service#2137](https://github.com/packit/packit-service/pull/2137))\\n\\n## Week 34 (August 22nd \u2013 August 28th)\\n\\n- We have fixed a bug in `packit source-git init` caused by the changed behaviour in the newer version of rpmbuild. ([packit#2048](https://github.com/packit/packit/pull/2048))\\n- We have fixed an issue in our API endpoint that could cause DoS until manual intervention from our team. ([packit-service#2164](https://github.com/packit/packit-service/pull/2164))\\n- We have fixed a bug causing broken retriggering of Github checks. ([packit-service#2161](https://github.com/packit/packit-service/pull/2161))\\n- SRPM build commit statuses, for monorepos projects, are now being correctly updated. ([packit-service#2157](https://github.com/packit/packit-service/pull/2157))\\n- We have fixed the bug resulting in incorrect reporting for tests when retriggering a build of a different target that was not configured for tests. ([packit-service#2144](https://github.com/packit/packit-service/pull/2144))\\n- We have fixed an issue that caused retriggers of Testing Farm to fail, if you specified any labels in the comment and had one or more test job definitions without any labels specified. ([packit-service#2156](https://github.com/packit/packit-service/pull/2156))\\n- Macro definitions and tags gained a new `valid` attribute. A macro definition/tag is considered valid if it doesn\'t appear in a false branch of any condition appearing in the spec file. ([specfile#276](https://github.com/packit/specfile/pull/276))\\n\\n## Week 35 (August 29th \u2013 September 4th)\\n\\n- Now Packit exposes `PACKIT_PACKAGE_NAME`, `PACKIT_UPSTREAM_PACKAGE_NAME` and `PACKIT_DOWNSTREAM_PACKAGE_NAME` env variables to all the actions. ([packit#2061](https://github.com/packit/packit/pull/2061))\\n- Packit now sets `PACKIT_UPSTREAM_REPO` and `PACKIT_DOWNSTREAM_REPO` environment variables for release syncing actions. The variables represent paths where the respective git repositories are cloned ([packit-service#2166](https://github.com/packit/packit-service/pull/2166))\\n- We have fixed a bug causing issues with displaying some `Project` views on our dashboard. ([packit-service#2165](https://github.com/packit/packit-service/pull/2165))\\n\\n## Week 36 (September 5th \u2013 September 11th)\\n\\n- Packit now supports `commit-message` action that can be used to override the default commit message produced by Packit during `propose-downstream` or `pull-from-upstream`. Please pay attention to [our documentation](https://packit.dev/docs/configuration/actions#commit-message) with regards to the usage of this action. ([packit#2070](https://github.com/packit/packit/pull/2070))\\n- Packit CLI now supports testing the `pull-from-upstream` workflow.\\n Use the `packit pull-from-upstream` command from the `packit` RPM package. ([packit#2063](https://github.com/packit/packit/pull/2063))\\n- Packit now passes `initiator` context for tmt to the Testing Farm. You can use [this option](https://tmt.readthedocs.io/en/latest/spec/context.html#initiator) to run or skip certain tests when they\'re run by Packit. ([packit-service#2176](https://github.com/packit/packit-service/pull/2176))\\n- Testing Farm started additionally exposing regexes on top of the exact compose names in the /composes/ endpoints, and we now support this as well when checking the validity of compose. ([packit-service#2168](https://github.com/packit/packit-service/pull/2168))\\n- We have disabled the jitter for retrying Bodhi update tasks to prevent race conditions causing not created updates. ([packit-service#2170](https://github.com/packit/packit-service/pull/2170))\\n- We have fixed a bug in `get_fork` method for Pagure about checking the usernames for a match when going through existing forks. ([ogr#800](https://github.com/packit/ogr/pull/800))\\n\\n## Week 37 (September 12th \u2013 September 18th)\\n\\n- If you have concerns about Packit uploading new archives to lookaside cache before creating a pull request, you can newly set `upload_sources` to False to disable this. ([packit#2086](https://github.com/packit/packit/pull/2086))\\n- We have introduced a new configuration option `notifications.failure_comment.message` that enables notifying users on failure via a comment using the configured message. ([packit-service#2182](https://github.com/packit/packit-service/pull/2182))\\n\\n## Week 38 (September 19th \u2013 September 25th)\\n\\n- As part of the effort of implementing release syncing for CentOS Stream,\\n Packit now supports the `pkg_tool` option in the config\\n (at the top-level or with specific packages when using the monorepo syntax).\\n This option can be used for switching between `fedpkg` or `centpkg`.\\n ([packit#2085](https://github.com/packit/packit/pull/2085))\\n- When updating the `Version` tag during `propose_downstream` or `pull_from_upstream`,\\n Packit now tries to update referenced macros (if any) rather than overwriting the references.\\n ([packit#2087](https://github.com/packit/packit/pull/2087))\\n\\n## Week 39 (September 26th \u2013 October 2nd)\\n\\n- When using packit CLI you can now specify bugs resolved by an update by `-b` or `--resolve-bug` option for `propose-downstream` and `pull-from-upstream` commands. The values will be added by default to the changelog and commit message and provided in `commit-message` and `changelog-entry` actions as `PACKIT_RESOLVED_BUGS` env variable. ([packit#2094](https://github.com/packit/packit/pull/2094))\\n- Packit-service now automatically adds bugzilla created by Upstream Release Monitoring as `- Resolves {bugzilla} ` to the changelog (or commit if autochangelog is used) and provides the value in `commit-message` and `changelog-entry` actions as `PACKIT_RESOLVED_BUGS` env variable. When retriggering the `pull-from-upstream` from comment, one can also specify the bug(s) as `/packit pull-from-upstream --resolved-bugs rhbz#123,rhbz#125` and Packit will do the same. ([packit-service#2193](https://github.com/packit/packit-service/pull/2193))\\n- You can now configure `notifications.failure_comment.message` also for downstream jobs, where the configured message will be used as an extension of the comment added by default by Packit. ([packit-service#2199](https://github.com/packit/packit-service/pull/2199))\\n\\n## Week 40 (October 3rd \u2013 October 9th)\\n\\n- We have fixed an issue that you could encounter when running the Packit from the CLI that caused misinterpretation of the repository to be an upstream repo instead of a downstream. ([packit#2117](https://github.com/packit/packit/pull/2117))\\n- Packit now also detects resolved bugs in the default update notes (created from changelog diff) and assigns these when submitting the Bodhi updates. ([packit#2111](https://github.com/packit/packit/pull/2111))\\n- We have fixed an issue that prevented automated allowlisting in the Packit Service. ([packit#2113](https://github.com/packit/packit/pull/2113))\\n- Packit now exports `PACKIT_UPSTREAM_PACKAGE_NAME`, `PACKIT_DOWNSTREAM_PACKAGE_NAME` and `PACKIT_CONFIG_PACKAGE_NAME` also in the `changelog_entry` action. ([packit#2103](https://github.com/packit/packit/pull/2103))\\n- Packit now posts a comment with a link to the Packit dashboard to the pull requests created in Fedora dist-git when syncing the release. ([packit-service#2215](https://github.com/packit/packit-service/pull/2215))\\n\\n## Week 41 (October 10th \u2013 October 16th)\\n\\n- (_breaking_) Packit no longer accepts `packit.json` or `.packit.json` as a configuration file name.\\n ([packit#2123](https://github.com/packit/packit/pull/2123))\\n- We have implemented several improvements in syncing the release downstream:\\n - Packit now updates ACL of its own dist-git forks to allow users and groups with commit rights to the original\\n dist-git repo to push directly to a fork. ([packit#2112](https://github.com/packit/packit/pull/2112))\\n - Packit now also properly cleans up the branch after syncing the release which should prevent unwanted files\\n (e.g. tarballs) being committed to dist-git. ([packit#2125](https://github.com/packit/packit/pull/2125))\\n - We have adjusted the way how Packit includes the resolved bugzillas in the commit messages created when syncing the release\\n downstream so that the resolved bugzillas are included in changelog when using `%autochangelog`.\\n ([packit#2126](https://github.com/packit/packit/pull/2126))\\n- Packit now reacts to retriggering comments for downstream jobs by commenting on the same issue/PR and\\n providing information about the jobs. ([packit-service#2222](https://github.com/packit/packit-service/pull/2222))\\n- We have fixed an issue that prevented you from running the jobs on the GitLab.com due to failing resolution\\n of the upstream/downstream relationship for the cloned project. ([packit#2120](https://github.com/packit/packit/pull/2120))\\n- Packit now triggers the build for the `/packit test` comment command if the last build was not successful.\\n ([packit-service#2228](https://github.com/packit/packit-service/pull/2228))\\n\\nAnd special thanks to [@SpyTec](https://github.com/SpyTec)\\nfor multiple wonderful [dashboard improvements](https://github.com/packit/dashboard/pulls?q=is%3Apr+author%3ASpyTec+merged%3A2023-10-10..2023-10-16)!\\n\\n## Week 43 (October 24th \u2013 October 30th)\\n\\n- Packit no longer downloads sources excluded using spec file conditions. ([packit#2132](https://github.com/packit/packit/pull/2132))\\n\\n## Week 44 (October 31st \u2013 November 6th)\\n\\n- Dist tag (`%{?dist}`) is now enforced when updating release during SRPM creation. ([packit#2106](https://github.com/packit/packit/pull/2106))\\n\\n## Week 45 (November 7th \u2013 November 13th)\\n\\n- Now Packit allows `~^+` (special characters) in a tag (used for building the version string). ([packit#2154](https://github.com/packit/packit/pull/2154))\\n- Downstream Koji builds are now shown in a separate table in `/jobs/downstream-koji-builds` on dashboard and are also accessible via `/api/koji-builds` API endpoint. ([packit-service#2244](https://github.com/packit/packit-service/pull/2244), [packit-service#2249](https://github.com/packit/packit-service/pull/2249), [dashboard#354](https://github.com/packit/dashboard/pull/354))\\n\\n## Week 46 (November 14th \u2013 November 20th)\\n\\n- Packit now supports pre-release version in `propose_downstream` and `pull_from_upstream`.\\n A spec file update might be required, see [the documentation](/docs/pre-releases) for more details.\\n ([packit#2149](https://github.com/packit/packit/pull/2149))\\n - In relation to that, specfile library has a new method, `Specfile.update_version()`, that allows updating spec file\\n version even if it is a pre-release. ([specfile#317](https://github.com/packit/specfile/pull/317))\\n- Packit can now check, using the new `update_version_mask` configuration option, that the proposed version of new release\\n and the current version of the dist-git branch are compatible and sync the dist-git branch only in that case.\\n ([packit#2156](https://github.com/packit/packit/pull/2156))\\n- Packit is now able to get the version from spec file even if the `Version` tag is not present in the specfile directly,\\n but e.g. imported from another file. ([packit#2157](https://github.com/packit/packit/pull/2157))\\n- `PACKIT_COPR_PROJECT` env var that is exposed to Testing Farm now includes the Copr project of the additional build\\n specified in comment, if present. ([packit-service#2253](https://github.com/packit/packit-service/pull/2253))\\n\\n## Week 47 (November 21st \u2013 November 27th)\\n\\n- Packit now correctly sets the specfile content (e.g. changelog entry) even if it syncs the specfile from upstream for the first time. ([packit#2170](https://github.com/packit/packit/pull/2170))\\n\\n## Week 48 (November 28th \u2013 December 4th)\\n\\n- Packit now links the information related to upstream events in PRs opened when syncing a release.\\n ([packit#2173](https://github.com/packit/packit/pull/2173))\\n\\n- When accessing tags or macro definitions by name, specfile library now takes validity into account\\n when looking for the best match. For example if there are two instances of `Version` tag,\\n one in the true and one in the false branch of a condition, `Specfile.version` will always access\\n the one that is in the true branch.\\n This also applies to Packit when syncing a release and updating value of `Version` tag.\\n ([specfile#328](https://github.com/packit/specfile/pull/328))\\n\\n## Week 49 (December 5th \u2013 December 11th)\\n\\n- We have introduced new configuration options `test_command.default_labels` and `test_command.default_identifier` that are used by default when running `/packit test` comment command without any arguments (instead of specifying them via `--labels`/`--identifier`). ([packit-service#2270](https://github.com/packit/packit-service/pull/2270))\\n\\n- We have fixed a bug that GithubRelease.url returned an API URL. ([ogr#824](https://github.com/packit/ogr/pull/824))\\n\\n## Week 50 (December 12th \u2013 December 18th)\\n\\n- We have fixed a bug preventing a release from being synced downstream if the changelog to be set is empty.\\n ([packit#2183](https://github.com/packit/packit/pull/2183))\\n- We have fixed a bug of not running Koji builds for Packit dist-git PRs with multiple commits if the last commit\\n of the PR did not contain a spec file change.\\n ([packit-service#2275](https://github.com/packit/packit-service/pull/2275))\\n\\n## End of the year in Packit\\n\\n- We have hit some issues with the firewall rules on the new cluster hosting our production. We are waiting for the required fix that is done outside of our team which should be deployed around January 11th. We will keep you informed about the current status. At the moment we are aware of the issues related to the:\\n - `pull-from-upstream` jobs that have sources hosted at infradead.org, sourceforge.net and gitlab.gnome.org\\n - jobs running on the gitlab.gnome.org in general\\n- We have also fixed an issue that caused some Cockpit releases to fail, others might\'ve been affected too, though there are no reports."},{"id":"/2023/packit-workshop","metadata":{"permalink":"/posts/weekly/2023/packit-workshop","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2023/packit-workshop.md","source":"@site/weekly/2023/packit-workshop.md","title":"Packit workshop - Fedora Community Edition","description":"We, the packit team, are happy to invite you to our upcoming workshop about pulling upstream releases to Fedora using Packit.","date":"2023-12-05T00:00:00.000Z","formattedDate":"December 5, 2023","tags":[{"label":"2023-December","permalink":"/posts/weekly/tags/2023-december"},{"label":"2023","permalink":"/posts/weekly/tags/2023"},{"label":"December","permalink":"/posts/weekly/tags/december"}],"readingTime":0.965,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Packit workshop - Fedora Community Edition","date":"2023-12-05T00:00:00.000Z","authors":"mmassari","tags":["2023-December","2023","December"]},"prevItem":{"title":"2023","permalink":"/posts/weekly/2023"},"nextItem":{"title":"2022","permalink":"/posts/weekly/2022"}},"content":"We, the packit team, are happy to invite you to our upcoming workshop about pulling upstream releases to Fedora using Packit.\\n\\n**When: Wed, Jan 10, 9:30 AM - Wed, Jan 10, 12:30 PM (GMT+1)**\\n\\n**Where: Online!**\\n\\n**Who should attend:** Anyone who maintains a package in Fedora or EPEL and would like to automate syncing the upstream releases for it. The automation is most suitable for simple packages with straightforward update processes (e.g. without patches, or need to build in side-tags). It works without access to the upstream repository.\\n\\n**No package?** It\u2019s not an issue. The workshop can help you understand the Fedora release process and the services involved. During the workshop, you can help someone else automate their package or ask someone around if you can help with the maintenance (that\u2019s usually very welcome!). You can also bring an orphaned package back to life!\\n\\n**Can\u2019t make it this time?** You can also follow our [documentation](https://packit.dev/docs/fedora-releases-guide) and ask for help in case of any issue: #packit:fedora.im (Matrix).\\n\\n**If you want to join us please fill [this form](https://forms.gle/WnEN3KXnhRS2cf1E7) or contact us on Matrix, and we will send you further details!**\\n\\n**Looking forward to seeing you!**"},{"id":"/2022","metadata":{"permalink":"/posts/weekly/2022","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2022.md","source":"@site/weekly/2022.md","title":"2022","description":"Let\'s see what happened in Packit in 2022.","date":"2023-01-01T00:00:00.000Z","formattedDate":"January 1, 2023","tags":[{"label":"2022","permalink":"/posts/weekly/tags/2022"}],"readingTime":24.99,"hasTruncateMarker":true,"authors":[],"frontMatter":{"title":"2022","date":"2023-01-01T00:00:00.000Z","aliases":["/posts/weekly/january-2022","/posts/weekly/february-2022","/posts/weekly/march-2022","/posts/weekly/april-2022","/posts/weekly/may-2022","/posts/weekly/june-2022","/posts/weekly/july-2022","/posts/weekly/august-2022","/posts/weekly/september-2022","/posts/weekly/october-2022","/posts/weekly/november-2022","/posts/weekly/december-2022"],"tags":["2022"]},"prevItem":{"title":"Packit workshop - Fedora Community Edition","permalink":"/posts/weekly/2023/packit-workshop"},"nextItem":{"title":"2021","permalink":"/posts/weekly/2021"}},"content":"Let\'s see what happened in Packit in 2022.\\n\\n\x3c!--truncate--\x3e\\n\\n## Week 0 (December 13th - January 2nd)\\n\\n- Dashboard shows a message when the SRPM build logs are not present instead of\\n an empty page that might suggest logs are being loaded.\\n ([packit/dashboard#158](https://github.com/packit/dashboard/pull/158))\\n\\n## Week 1 (January 3rd - January 7th)\\n\\n- Packit service now discards old (currently, this means 3 months) SRPM builds logs.\\n ([packit/packit-service#1315](https://github.com/packit/packit-service/pull/1315))\\n- We have added `target_branch_head_commit` property to the `PullRequest` class in ogr that allows\\n you to get commit hash of the HEAD of the target branch (i.e. base, where the changes are merged to).\\n ([packit/ogr#671](https://github.com/packit/ogr/pull/671))\\n- Service now passes `PACKIT_TARGET_SHA` variable, which holds commit hash of the HEAD of the target\\n branch where the changes are supposed to be merged, to the Testing Farm environment. This should\\n help solving the issue of running tests from non-merged codebase on the Testing Farm side.\\n ([packit/packit-service#1319](https://github.com/packit/packit-service/pull/1319))\\n\\n## Week 2 (January 10th - January 14th)\\n\\n- Packit no longer ignores `--no-bump` and `--release-suffix` options for\\n source-git repos.\\n [packit/packit#1452](https://github.com/packit/packit/pull/1452)\\n- Packit now names local branch `pr/{pr_id}` when checking out a PR, even when\\n it\'s not being merged with the target branch. This results into NVR of the\\n build containing `pr{pr_id}` instead of `pr.changes{pr_id}`.\\n [packit/packit#1445](https://github.com/packit/packit/pull/1445)\\n\\n## Week 3 (January 17th - January 21st)\\n\\n- `%changelog` sections in dist-git using the `%autochangelog` macro [are\\n preserved](https://github.com/packit/packit/pull/1453) when running\\n `propose-downstream`, except when `sync_changelog` is set to `true`.\\n- When checking if directories hold a Git-tree, Packit now also allows [`.git`\\n to be a file with a `gitdir`](https://github.com/packit/packit/pull/1458)\\n reference, not only a directory.\\n\\n## Week 4 (January 25th - January 28th)\\n\\n- SRPM build view contains info about build start and finished time.\\n [packit/dashboard#163](https://github.com/packit/dashboard/pull/163)\\n- When submitting a distgit PR during `propose-downstream` job, we create\\n a `README.packit` file with some info about the sync the packit version used.\\n To avoid this you can add `create_sync_note: false` to conig file.\\n [packit/packit#1465](https://github.com/packit/packit/pull/1465)\\n\\n## Week 5 (January 31th - February 7th)\\n\\n- A new option `--no-require-autosetup` for `source-git init` command has been\\n introduced. Please note that source-git repositories not using `%autosetup` may\\n not be properly initialized. ([packit#1470](https://github.com/packit/packit/pull/1470))\\n- Packit-service now supports re-triggering against failed task using comment on\\n pull request `/packit rebuild-failed` and similarly for testing farm: `/packit retest-failed`.\\n ([packit-service#1303](https://github.com/packit/packit-service/pull/1303))\\n\\n## Week 6 (February 8th - February 14th)\\n\\n- Packit now correctly handles colons in git trailer values in source-git commits.\\n ([packit#1478](https://github.com/packit/packit/pull/1478))\\n\\n## Week 7 (February 14th\u2764\ufe0f - February 18th)\\n\\n- Synchronization of default files can now be disabled using a new config\\n `files_to_sync`. Key `sync_files` is now deprecated.\\n ([packit#1483](https://github.com/packit/packit/pull/1483))\\n ([packit.dev#390](https://github.com/packit/packit.dev/pull/390))\\n- `python3-setuptools_scm` is now available by default in the sandbox.\\n\\n## Week 8 (February 18th - February 28th)\\n\\n- Packit now allows specifying more test distros for one build target\\n to test on in Testing Farm in the configuration. The checks for the\\n test job will also contain the name of the actual test distro\\n (and not the build target as previously).\\n- A new option, `srpm_build_deps`, in the packit configuration file \\n can be used. Which is a list of RPM dependencies that are needed for\\n the actions to be run when building SRPM and is an indicator to build\\n the SRPMs in Copr.\\n\\n## Week 9 (March 1st - March 7th)\\n\\n- When a specfile is being generated, and both `specfile_path` and\\n `downstream_package_name` are not set, Packit now correctly resolves this\\n situation and sets `specfile_path` to the name of the upstream repo suffixed\\n with `\\".spec\\"`.\\n ([packit#1499](https://github.com/packit/packit/pull/1499))\\n- A new command `packit source-git status` has been introduced for checking\\n the synchronization of a source-git and a dist-git repository based on the\\n used git trailers. The command outputs a range of commits which need to be\\n synchronized from dist-git to source-git or the other way around. If possible,\\n the command also provides instructions on how to synchronize the repositories.\\n ([packit#1500](https://github.com/packit/packit/pull/1500))\\n- We have added a new `enable_net` configuration option for Copr builds that\\n allows you to disable network access during Copr builds. It is also complemented\\n by `--enable-net`/`--disable-net` CLI options if you use Packit locally.\\n ([packit#1504](https://github.com/packit/packit/pull/1504))\\n- Packit now adds \ud83d\udc40 instead of \ud83d\udc4d as a reaction to `/packit command`\\n ([packit-service#1372](https://github.com/packit/packit-service/pull/1372))\\n- Progress of propose-downstream is now saved in the database and is available\\n via API. Visualization in the dashboard is to follow next week, stay tuned.\\n ([packit-service#1292](https://github.com/packit/packit-service/pull/1292))\\n- When running tests for the pull-request job, we now expose environment\\n variables for commit hash, branch and URL both for pull-request source and\\n target. In the test environment, you can use the following variables:\\n `PACKIT_SOURCE_SHA`, `PACKIT_TARGET_SHA`, `PACKIT_SOURCE_BRANCH`,\\n `PACKIT_TARGET_BRANCH`, `PACKIT_SOURCE_URL` and `PACKIT_TARGET_URL`.\\n These variables are not set for test runs of releases and branch pushes.\\n ([packit-service#1382](https://github.com/packit/packit-service/pull/1382))\\n\\n## Week 10 (March 8th - March 14th)\\n\\n- You can view information about ongoing propose-downstream jobs via our dashboard.\\n ([dashboard#168](https://github.com/packit/dashboard/pull/168))\\n- We have switched the cache for dist-git branches and Copr targets to TTL cache\\n that gets discarded once in 12 hours, in case there is a change in targets, the\\n changes shall propagate to both of our deployments without the need to redeploy\\n within 12 hours. ([packit#1513](https://github.com/packit/packit/pull/1513))\\n- Packit now comments when it fails to find Copr project specified in the config.\\n ([packit#1395](https://github.com/packit/packit-service/pull/1395))\\n- Packit now reacts to dist-git pushes to either `rawhide` or `main` when configured\\n to do Koji builds for `rawhide`.\\n ([packit#1393](https://github.com/packit/packit-service/pull/1393))\\n- You can specify an identifier for your job to be able to configure one job multiple times.\\n For example, you can build multiple projects from one repository (known as monorepo concept)\\n or try multiple build options. Using identifiers allows Packit to avoid naming collisions\\n in commit statuses and default Copr project names.\\n ([packit-service#1385](https://github.com/packit/packit-service/pull/1385))\\n- Packit no longer provides a misleading comment when it fails to update a set of\\n targets on its own Copr projects.\\n ([packit-service#1397](https://github.com/packit/packit-service/pull/1397))\\n\\n## Week 11 (March 15th - March 21st)\\n\\n- When using Packit CLI for creating Bodhi updates,\\n you can now set `fas_username` and `fas_password` in your Packit user config\\n to not be asked about that when the command is executed.\\n Also, this allows Packit GitHub application to use this as well\\n so you can look forward to Bodhi updates created by Packit\\n (will be announced and described in a dedicated post).\\n ([packit#1517](https://github.com/packit/packit/pull/1517))\\n\\n## Week 12 (March 22nd - March 28th)\\n\\n- We have updated contact information to `Packit `.\\n ([packit-service#1410](https://github.com/packit/packit-service/pull/1410))\\n- Interactions with Bodhi should be now more reliable when creating Bodhi updates.\\n ([packit#1528](https://github.com/packit/packit/pull/1528))\\n- Packit will no longer error out when trying to create a new Copr repository\\n when it is already present.\\n ([packit#1527](https://github.com/packit/packit/pull/1527))\\n- There is a new `packit_instances` key that you can use to specify the Packit\\n instances you want to use for working on your jobs. Nothing will change for our\\n production users, but users of our stage instance need to use this key to\\n preserve the support of the stage instance -- they can set both stg and prod in\\n the `packit_instances` list to use both, or use just one. Just be careful with\\n the downstream jobs where both instances work with the same services.\\n This new option works like other Packit options so you can set it on the top\\n level and/or (re)define it on the job level.\\n More information about our staging instance can be found here:\\n [packit#1530](https://github.com/packit/packit/discussions/1530).\\n ([packit#1417](https://github.com/packit/packit-service/pull/1417))\\n\\n## Week 13 (March 29th - April 4th)\\n\\n- We have implemented `get_contributors` function in ogr that can be used for getting contributors to the project on GitHub (set of logins) and GitLab (set of authors).\\n ([ogr#692](https://github.com/packit/ogr/pull/692))\\n- When multiple propose downstream attempts for the same PR fail, the error messages are sent to to the same issue (as comments), instead of creating multiple new issues.\\n ([packit#1427](https://github.com/packit/packit-service/pull/1427))\\n- Downstream synchronization of the Packit configuration file (aka `packit.yaml`) is now working properly again.\\n ([packit#1532](https://github.com/packit/packit/pull/1532))\\n- `packit source-git update-dist-git` and `packit source-git update-source-git` now check the synchronization of source-git and dist-git repositories prior to doing the update. If the update can\'t be done, for example, because the histories have diverged, the command provides instructions on how to synchronize the repositories.\\n A `--force` option is available to try to update the destination repository anyway.\\n ([packit#1534](https://github.com/packit/packit/pull/1534))\\n- When using `post_upstream_clone` to generate your spec-file,\\n Packit now correctly checks out a release before the action is run.\\n ([packit#1542](https://github.com/packit/packit/pull/1542))\\n\\n## Week 14 (April 5th - April 11th)\\n\\n- We have introduced two new build and test target aliases: `fedora-latest-stable` resolves to the latest stable Fedora\\n Linux release, while `fedora-branched` resolves to all branched releases (all Fedora Linux release, except `rawhide`).\\n ([packit#1546](https://github.com/packit/packit/pull/1546))\\n- We have reverted the functionality of Packit that allowed you to have set **only** specific targets for Copr repositories.\\n This functionality was introduced a while ago and was found to be not very beneficial in cases of differently\\n configured Copr jobs building in parallel in the same Copr repository. This is an implementation detail in the end,\\n but Copr project chroots are now only added and never subtracted\\n (every build has precisely specified targets based on the copr_build job definition).\\n ([packit#1551](https://github.com/packit/packit/pull/1551))\\n- If you are using our stage instance, we make it listen only on `/packit-stg` comment commands so you can now differentiate\\n between the instances when commanding Packit via pull-request or issue comments.\\n For the production instance, you can continue using `/packit` prefix as you are used to.\\n ([packit-service#1432](https://github.com/packit/packit-service/pull/1432))\\n- A new configuration option `downstream_branch_name` has been added, which is meant to be used in source-git projects\\n and allows users to customize the name of the branch in dist-git which corresponds to the current source-git branch.\\n ([packit#1555](https://github.com/packit/packit/pull/1555))\\n- `revision-range` argument of the source-git `update-source-git` command is now optional. If not specified,\\n dist-git commits with no counterpart in source-git are synchronized.\\n ([packit#1547](https://github.com/packit/packit/pull/1547))\\n\\n## Week 15 (April 12th - April 14th)\\n\\n- We have implemented reporting of status for the propose-downstream job which means that you can now\\n see the progress of the job via check runs/commit statuses on the particular release commits.\\n ([packit-service#1435](https://github.com/packit/packit-service/pull/1435))\\n\\n## Week 16 (April 19th - April 25th)\\n\\n- The bug in our service about not setting GitHub and Gitlab statuses in case of lack of permissions was fixed.\\n ([packit/packit-service#1457](https://github.com/packit/packit-service/pull/1457))\\n- Packit\'s CLI `source-git update-*` commands now check whether the target repository is pristine and in case not raise an error.\\n ([packit/packit#1562](https://github.com/packit/packit/pull/1562))\\n\\n## Week 17 (April 26th - May 2th)\\n\\n- We have fixed an issue affecting Pipelines view on Dashboard. Currently you should be able to see pipelines again; we are also working on fixing empty rows for `propose-downstream` jobs.\\n ([packit-service#1461](https://github.com/packit/packit-service/pull/1461))\\n- Packit now shows the specific info when it does not have permissions to create a Bodhi update of your package.\\n When you configure `issue_repository` in your Packit config file, Packit will create an issue in that project and link the dist-git page where you can give _Packit FAS user_ the correct permissions.\\n ([packit-service#1465](https://github.com/packit/packit-service/pull/1465))\\n- Packit now exports `PACKIT_PR_ID` environment variable to the Testing Farm.\\n ([packit-service#1467](https://github.com/packit/packit-service/pull/1467))\\n- The bug in the Copr permission request is now fixed. (After the release of a new Copr client, Packit didn\'t catch that permission problem and didn\'t request the permissions to build in a custom Copr project.)\\n ([packit-service#1472](https://github.com/packit/packit-service/pull/1472))\\n- We have fixed a bug that caused Packit to fail when submitting Testing Farm on `commit` trigger.\\n ([packit-service#1474](https://github.com/packit/packit-service/pull/1472))\\n- Packit now builds RPMs in Copr triggered by `release` event with correct NVR (without the artificial release suffix). You can use it for distributing RPM packages via Copr. \\n ([packit-service#1478](https://github.com/packit/packit-service/pull/1478))\\n- From the security perspective, we have decided to disable the `create_pr` option for our service, from now on Packit will unconditionally create PRs when running `propose-downstream`.\\n We have also updated the `propose-downstream` CLI such that it is possible to use `create_pr` from configuration **or** override it via `--pr/--no-pr` options.\\n ([packit#1563](https://github.com/packit/packit/pull/1563))\\n- Packit now supports `release_suffix` configuration option that allows you to override the long release string provided by Packit that is used to ensure correct ordering and uniqueness of RPMs built in Copr.\\n ([packit#1568](https://github.com/packit/packit/pull/1568))\\n\\n## Week 18 (May 3rd - May 9th)\\n\\n- `packit source-git` commands learnt to replace [Git-trailers in commit messages](https://packit.dev/source-git/work-with-source-git/control-patch-generation/) if they already exist. ([packit#1577](https://github.com/packit/packit/pull/1577))\\n- When initializing source-git repos, the author of downstream commits created from patch files which are not in a git-am format is set to the original author of the patch-file in dist-git, instead of using the locally configured Git author. ([packit#1575](https://github.com/packit/packit/pull/1575))\\n- Packit now correctly inform users about downstream errors only on the last try. (Previously, Packit informed for all tries even the last try succeded.) ([packit-service#1485](https://github.com/packit/packit-service/pull/1485))\\n- Dashboard now also shows propose-downstream jobs in pipelines view. We have also merged all jobs to one column to minimize dead space on the page. ([dashboard#178](https://github.com/packit/dashboard/pull/178))\\n\\n## Week 19 (May 10th - May 16th)\\n\\n- Metadata dictionary is no longer required when specifying a job. Keys which used to belong to the yaml metadata dictionary are now keys of the job dictionary itself. ([packit#1569](https://github.com/packit/packit/pull/1569))\\n- Packit now correctly removes patches during `packit source-git init` when the preamble does not contain blank lines. ([packit#1582](https://github.com/packit/packit/pull/1582))\\n- Packit now supports `--release-suffix` parameter in all of the related CLI commands. Also we have added a support for the `release_suffix` option from configuration to the CLI. With regards to that we have introduced a new CLI switch `--default-release-suffix` that allows you to override the configuration option to Packit-generated default option that ensures correct NVR ordering of the RPMs. ([packit#1586](https://github.com/packit/packit/pull/1586))\\n- Resolved an SRPM build problem caused by a new version of git that refuses to fetch in a git repo when it\'s owned on the OS level by someone else. ([packit#1497](https://github.com/packit/packit-service/pull/1497))\\n- Packit now passes `PACKIT_COPR_PROJECT` and `PACKIT_COPR_RPMS` variables to the Testing Farm. `PACKIT_COPR_PROJECT` holds Copr project in format owner/project and `PACKIT_COPR_RPMS` space-separated RPMs that were built in Copr. ([packit-service#1486](https://github.com/packit/packit-service/pull/1486))\\n- Packit now builds only its own dist-git commits. Other commits are not being acted upon. For reasoning, see [packit-service#1490](https://github.com/packit/packit-service/issues/1490). ([packit-service#1498](https://github.com/packit/packit-service/pull/1498))\\n- We have automated our allowlisting process via a new Packit comment command `/packit verify-fas`. You can find more info in [our requirements](https://packit.dev/docs/guide/#2-approval). ([packit-service#1487](https://github.com/packit/packit-service/pull/1487))\\n\\n## Week 20 (May 17th - May 23rd)\\n\\n- We have fixed an issue with the handling of messages from Copr on release builds, which has resulted in not setting the correct statuses on commits. ([packit-service#1513](https://github.com/packit/packit-service/pull/1513))\\n- When doing an automatic FAS account verification, Packit now suggests the URL where the GitHub account needs to be set. ([packit-service#1508](https://github.com/packit/packit-service/pull/1508))\\n\\n## Week 21 (May 24th - May 30th)\\n\\n- Packit will not raise an exception anymore when creating a SRPM with dangling symlinks. ([packit#1592](https://github.com/packit/packit/pull/1592))\\n- You can now override which dist-git commits will be built in Koji by specifying FAS accounts of authors and committers using\\n `allowed_pr_authors` or `allowed_committers` in the job metadata (see [the documentation](https://packit.dev/docs/configuration/#koji_build)). ([packit-service#1520](https://github.com/packit/packit-service/pull/1520))\\n\\n## Week 22 (May 31st - June 6th)\\n\\n- Packit shows basic information about allowlisting in the status description\\n when your namespace is not allowed.\\n ([packit-service#1533](https://github.com/packit/packit-service/pull/1533))\\n\\n## Week 23 (June 7th - June 13th)\\n\\n- The creation of Bodhi updates should not time out anymore, because we no longer get the latest build of a package via Bodhi.\\n ([packit#1612](https://github.com/packit/packit/pull/1612))\\n- We have fixed a regression where string values for the `targets` and `dist_git_branches` configuration keys were not accepted.\\n ([packit#1608](https://github.com/packit/packit/pull/1608))\\n- We improved the reporting for the test job if we are not able to find any FMF metadata and the `skip_build` option is enabled.\\n ([packit-service#1539](https://github.com/packit/packit-service/pull/1539))\\n\\n## Week 24 (June 14th - June 21st)\\n\\n- Git ref name that Packit works with during `propose-downstream` is now made more obvious in logs.\\n ([packit#1626](https://github.com/packit/packit/pull/1626))\\n- Packit now correctly handles creation of custom archives in root while a specfile is in a subdirectory.\\n ([packit#1622](https://github.com/packit/packit/pull/1622))\\n- There is a new check for git projects that are allowed to use a custom Copr project.\\n There will be a better integration in the form of a new config field in Copr settings that Packit can use.\\n In the meantime, the mapping is defined and maintained by the Packit team.\\n Let us know if you need a project to be allowed.\\n ([packit-service#1556](https://github.com/packit/packit-service/pull/1556))\\n- A link to Copr build logs was updated: it now points to a place where logs are available once a build starts.\\n ([packit-service#1554](https://github.com/packit/packit-service/pull/1554))\\n\\n## Week 25 (June 21st - June 27th)\\n\\n- Packit Bash completion file is no longer needlessly executable. ([packit#1634](https://github.com/packit/packit/pull/1634))\\n- Packit now works with Bodhi 5 and Bodhi 6 authentication mechanism. ([packit#1629](https://github.com/packit/packit/pull/1629))\\n- Git ref name that Packit works with during `propose-downstream` is now made more obvious in logs. ([packit#1626](https://github.com/packit/packit/pull/1626))\\n- We have fixed the incorrect displaying of `propose downstream` results in our dashboard. ([packit-service#1553](https://github.com/packit/packit-service/pull/1553))\\n\\n## Weeks 26\u201327 (June 27th\u2013July 11th)\\n\\n- We adjusted the way we check the author of the PR for PRs related to\\n dist-git commits that trigger Koji build jobs. This should fix the race\\n condition causing not creating Koji builds in some cases.\\n ([packit-service#1573](https://github.com/packit/packit-service/pull/1573))\\n- Results from Testing Farm are now correctly reported when multiple jobs with\\n different identifier are defined.\\n ([packit-service#1565](https://github.com/packit/packit-service/pull/1565))\\n- On a Bodhi authentication error, Packit will retry the task multiple times\\n in ten-minute intervals to be able to fix the issue in the meantime.\\n ([packit-service#1564](https://github.com/packit/packit-service/pull/1564))\\n\\n## Week 28 (July 12th\u2013July 18th)\\n\\n- Packit now guides everyone better when a FAS account is private\\n and updates the internal information about installations correctly\\n when the app is reinstalled.\\n ([packit-service#1575](https://github.com/packit/packit-service/pull/1575))\\n- Packit can now correctly create Bodhi updates using the new Bodhi 6 client.\\n ([packit#1651](https://github.com/packit/packit/pull/1651))\\n- RPM build commands of Packit CLI have been merged into one build subcommand,\\n for more information see the updated [documentation](https://packit.dev/docs/cli/build/).\\n We have also introduced a new --srpm option to the new build subcommand\\n that can be used to trigger local, Copr or Koji build from an already built\\n SRPM rather than the one implicitly created by Packit.\\n ([packit#1611](https://github.com/packit/packit/pull/1611))\\n\\n## Week 29 (July 19th\u2013July 25th)\\n\\n- Packit now correctly supports `tmt_plan` and `tf_post_install_script` in the\\n configuration. ([packit#1659](https://github.com/packit/packit/pull/1659))\\n- We have reverted to Bodhi 5 client since Packit couldn\'t create bodhi updates\\n with the new version 6 client: [fedora-infra/bodhi#4660](https://github.com/fedora-infra/bodhi/issues/4660)\\n ([packit-service#1590](https://github.com/packit/packit-service/pull/1590)).\\n Packit also provides a more helpful error message when it hits this.\\n ([packit#1660](https://github.com/packit/packit/pull/1660))\\n- During creating Copr builds, on Copr errors, Packit will retry the task\\n multiple times in case there is a Copr outage.\\n ([packit-service#1579](https://github.com/packit/packit-service/pull/1579))\\n\\n## Week 30 (July 26th\u2013August 1st)\\n\\n- Packit has switched to `python-specfile` library for handling spec files. This may cause some issues to pop up. ([packit#1588](https://github.com/packit/packit/pull/1588))\\n- Packit CLI can now build RPMs in mock. For more information see https://packit.dev/docs/cli/build/mock ([packit#1662](https://github.com/packit/packit/pull/1662))\\n- When using Packit before being allowed, Packit newly links an approval issue where the self-approval can be performed. ([packit-service#1596](https://github.com/packit/packit-service/pull/1596))\\n- A downstream koji-build can now be re-triggered by adding a comment containing `/packit koji-build` into a dist-git pull request with target branch corresponding to the branch the build should be acted upon. ([packit-service#1586](https://github.com/packit/packit-service/pull/1586))\\n\\n## Week 31 (August 2nd \u2013 August 8th)\\n\\n- Action `fix_spec_file` can change a spec file - Packit now preserves that change.\\n ([packit#1679](https://github.com/packit/packit/pull/1679))\\n- BREAKING CHANGE: fixed an issue where the repo was searched for the specfile\\n before checking if `downstream_package_name` is set, and\\n `.spec` can be used as the `specfile_path`.\\n ([packit#1663](https://github.com/packit/packit/pull/1663))\\n\\n## Week 32 (August 9th \u2013 August 15th)\\n\\n- We have fixed an issue when propose downstream didn\'t retry to download sources that were not yet available at the time of the first attempt. ([packit-service#1609](https://github.com/packit/packit-service/pull/1609))\\n- When creating Copr builds, Packit will now retry multiple times in case there is a GitHub outage or an internal error. ([packit-service#1589](https://github.com/packit/packit-service/pull/1589))\\n\\n## Week 33 (August 16th \u2013 August 22nd)\\n\\n- Packit CLI can now submit VM images in [Red Hat Image Builder](https://console.redhat.com/insights/image-builder).\\n All build-related commands have now consistent `--wait` / `--no-wait` options.\\n ([packit#1666](https://github.com/packit/packit/pull/1666))\\n- Packit `prepare-sources` command now has a `--create-symlinks` / `--no-create-symlinks` option,\\n which enables copying the archive instead of symlinking. This will be used in the Copr environment,\\n where symlinking the archive previously caused issues.\\n ([packit#1682](https://github.com/packit/packit/pull/1682))\\n- We have fixed the handling of the situation when Packit lacks permission to update a Copr project.\\n ([packit#1684](https://github.com/packit/packit/pull/1684))\\n- Dashboard should now load data for [jobs](https://dashboard.packit.dev/jobs) faster because\\n the database querying has been improved and also queries are done only when needed.\\n ([packit-service#1617](https://github.com/packit/packit-service/pull/1617),\\n [dashboard#189](https://github.com/packit/dashboard/pull/189))\\n\\n## Week 34 (August 23rd \u2013 August 29th)\\n\\n- `packit propose-downstream` is now more informative when sources cannot be\\n downloaded. ([packit#1698](https://github.com/packit/packit/pull/1698))\\n- No more annoying issues will be created after a successful _propose\\n downstream_. ([packit#1693](https://github.com/packit/packit/pull/1693))\\n- We have fixed an issue with reporting results when multiple Testing Farm\\n jobs with identifiers are configured.\\n ([packit-service#1634](https://github.com/packit/packit-service/pull/1634))\\n\\n## Week 35 (August 30th \u2013 September 5th)\\n\\n- SRPMs for Copr builds are built in Copr by default for Packit GitHub app installations since September 6, 2022.\\n For older installations, you can set the `srpm_build_deps` config option to use Copr as a builder.\\n Let us know if you hit any issue with the new implementation. We are going to slowly decommission the old implementation\\n and are happy to help with the transition. ([packit-service#1636](https://github.com/packit/packit-service/pull/1636))\\n- More indexes added to the database have further improved API/dashboard response times. ([packit-service#1639](https://github.com/packit/packit-service/pull/1639))\\n- When submitting Testing Farm tests, Packit will now retry multiple times in case there is a failure.\\n ([packit-service#1605](https://github.com/packit/packit-service/pull/1605))\\n- We have implemented checking the available composes before submitting the tests for both internal and public Testing\\n Farm. ([packit-service#1628](https://github.com/packit/packit-service/pull/1628))\\n\\n## Week 36 (September 6th \u2013 September 12th)\\n\\n- When querying Bodhi for information about Fedora/EPEL releases to resolve aliases,\\n packit now correctly handles pagination of API results. This resolves an issue that caused\\n Fedora 37 not to be pointed to from any alias.\\n ([packit#1704](https://github.com/packit/packit/pull/1704))\\n\\n## Week 37 (September 13th \u2013 September 19th)\\n\\n- Added support for filenames specified in source URL fragments, for example: `https://example.com/foo/1.0/download.cgi#/%{name}-%{version}.tar.gz` ([specfile#100](https://github.com/packit/specfile/pull/100))\\n- Some more underlying improvements to our libraries and deployment.\\n\\n## Week 38 (September 20th \u2013 September 26th)\\n\\n- Propose downstream job now pushes changes even when it\'s not creating a new pull request. This allows updating existing pull requests. ([packit#1725](https://github.com/packit/packit/pull/1725))\\n- Packit now deduces Copr targets for Copr builds when you have set your custom Copr project to be used. ([packit-service#1673](https://github.com/packit/packit-service/pull/1673))\\n- Retriggering tasks via re-run button in Github commit checks when there are configured identifiers for jobs should now work correctly. ([packit-service#1671](https://github.com/packit/packit-service/pull/1671))\\n- Packit now reports a pending state rather than an error on Testing Farm runs in case the related copr build has not finished yet. ([packit-service#1669](https://github.com/packit/packit-service/pull/1669))\\n- Users can now **allow** building in a custom Copr project from a _git-forge_ project.\\n User has to add manually the _git-forge_ project reference to the Copr project settings.\\n As an example, we should add _github.com/packit/ogr_ to the list named _Packit forge project allowed_ in our _packit-dev_ Copr project settings: https://copr.fedorainfracloud.org/coprs/packit/packit-dev/edit#packit_forge_projects_allowed. ([packit-service#1638](https://github.com/packit/packit-service/pull/1638))\\n\\n## Week 39 (September 27th \u2013 October 3rd)\\n\\n- We have improved mapping of Testing Farm Composes, if you have set your own custom mapping and the TF Compose is available, it will be used as is without any additional modifications we do (version, etc.). ([packit-service#1675](https://github.com/packit/packit-service/pull/1675))\\n- We have added support for running the tests with Copr builds built by Packit in another pull request (in a different repository). You can read more about this feature in [our documentation](https://packit.dev/docs/testing-farm/#running-tests-with-builds-from-another-pull-request). ([packit-service#1658](https://github.com/packit/packit-service/pull/1658))\\n\\n## Week 40 (October 4th \u2013 October 10th)\\n\\n- Packit now correctly selects a Testing Farm compose when it\'s specified correctly in the configuration without an architecture suffix. ([packit-service#1689](https://github.com/packit/packit-service/pull/1689))\\n- We have fixed an issue that prevented Packit to work correctly on merge requests on GitLab instances. ([packit-service#1683](https://github.com/packit/packit-service/pull/1683))\\n- Packit Service will now replace invalid characters for the Copr projects using the default naming scheme. ([packit-service#1684](https://github.com/packit/packit-service/pull/1684))\\n- When we report to set `Packit allowed forge projects` in the Copr projects, the link for the group projects is now correct. ([packit-service#1680](https://github.com/packit/packit-service/pull/1680))\\n- It is now possible to filter changelog entries by specifying lower bound EVR, upper bound EVR or both. ([specfile#104](https://github.com/packit/specfile/pull/104))\\n\\n## Week 41 (October 11th \u2013 October 17th)\\n\\n- Packit now correctly authenticates with Bodhi 6 and therefore creates Bodhi updates. \ud83d\ude80 ([packit#1746](https://github.com/packit/packit/pull/1746), [packit-service#1704](https://github.com/packit/packit-service/pull/1704))\\n- There are two changes in the naming of the service jobs:\\n The `build` job type name has been deprecated. It aimed to be an alias when Packit supported just one build type.\\n There are currently more types of builds and just `build` can be misleading. Please, be explicit and use `copr_build` instead.\\n The `production_build` name for upstream Koji build is misleading because it is not used to run production/non-scratch\\n builds and because it can be confused with the `koji_build` job that is triggered for dist-git commits.\\n (The `koji_build` job can trigger both scratch and non-scratch/production builds.)\\n To be explicit, use `upstream_koji_build` for builds triggered in upstream and `koji_build` for builds triggered in downstream.\\n Users will get a neutral status describing the change when the old names are in use. The status will become a warning\\n starting in November and the old names will be removed by the end of the year. ([packit-service#1656](https://github.com/packit/packit-service/pull/1656))\\n- We\'ve fixed the Markdown table format in the GitHub checks page, which was broken when the user\'s repo was not allowed to use Packit. ([packit-service#1688](https://github.com/packit/packit-service/pull/1688))\\n\\n## Week 42 (October 17th \u2013 October 23rd)\\n\\n- Packit now won\'t repeatedly comment in pull requests about the need to migrate configuration of allowed forge projects to Copr. ([packit-service#1716](https://github.com/packit/packit-service/pull/1716))\\n\\n## Week 43 (October 25th \u2013 October 31th)\\n\\n- Fixed an issue with version and release in a spec file being updated even if `--no-bump` flag was specified.\\n Also fixed an issue when `None` appeared in release instead of a number.\\n ([packit#1753](https://github.com/packit/packit/pull/1753))\\n- We have improved the handling of test jobs which should fix related issues with reporting and triggering\\n that occurred when multiple test jobs were configured.\\n ([packit-service#1717](https://github.com/packit/packit-service/pull/1717))\\n\\n## Week 44 (November 1st \u2013 November 7th)\\n\\n- Fixed an issue due to which the repository was never searched for a specfile if `specfile_path` was not specified, and `specfile_path` was always set to `.spec`. ([packit#1758](https://github.com/packit/packit/pull/1758))\\n- Packit is now able to generate automatic Bodhi update notes including a changelog diff since the latest stable build of a package. ([packit#1747](https://github.com/packit/packit/pull/1747))\\n- Description of Bodhi updates now contains a changelog diff. ([packit-service#1713](https://github.com/packit/packit-service/pull/1713))\\n\\n## Week 45 (November 8th \u2013 November 14th)\\n\\n- You can re-trigger a Bodhi update via dist-git PR comment `/packit create-update`. ([packit-service#1729](https://github.com/packit/packit-service/pull/1729))\\n- Packit now correctly finds an SRPM when rpmbuild reports warnings while it parses a spec file. ([packit#1772](https://github.com/packit/packit/pull/1772))\\n- When packit.yaml is present in the repo but is empty, Packit now produces a better error message instead of an internal Python exception. ([packit#1769](https://github.com/packit/packit/pull/1769))\\n- Retriggering of tests when there is a build job and a test job with an identifier configured was fixed. ([packit-service#1731](https://github.com/packit/packit-service/pull/1731))\\n- Packit GitHub app will not modify a package version when `release_suffix` configuration option is empty. ([packit-service#1738](https://github.com/packit/packit-service/pull/1738))\\n- Our `specfile` parser now supports localized tags (e.g. `Summary(fr)`) and tags with qualifiers (e.g. `Requires(post)`). ([specfile#132](https://github.com/packit/specfile/pull/132))\\n- SRPM build logs are now deleted after 30 days instead of 90 days. This doesn\'t apply to SRPM builds done in Copr, which deletes the logs after 14 days. ([packit/packit-service#1745](https://github.com/packit/packit-service/pull/1745))\\n\\n## Week 46 (November 15th \u2013 November 21st)\\n\\n- `srpm_build_deps` can be now configured also on the job configuration level. ([packit-service#1757](https://github.com/packit/packit-service/pull/1757))\\n\\n## Week 47 (November 22nd \u2013 November 28th)\\n\\n- We have changed the limit for our [SLO1](https://packit.dev/docs/service-level-objectives/#slo1-changes-to-github-prs-receive-a-status-update-within-15-seconds-in-99-of-cases): it was increased from 15s to 30s to account for setting all statuses. ([packit-service#1776](https://github.com/packit/packit-service/pull/1776))\\n- The job names deprecated in October (`build` alias of `copr_build` and `production_build` replaced by `upstream_koji_build`) newly lead to an error state (was `neutral` ) of the deprecated status created by Packit.\\n The old names will be removed by the end of the year. ([packit-service#1777](https://github.com/packit/packit-service/pull/1777))\\n- The Copr build logs URL now points to logs that are available even while building. ([packit-service#1767](https://github.com/packit/packit-service/pull/1767))\\n- Fixed an issue that caused empty lines originally inside changelog entries to appear at the end. ([specfile#140](https://github.com/packit/specfile/pull/140))\\n\\n## Week 48 (November 29th \u2013 December 5th)\\n\\n- `packit propose-downstream` now uploads all remote sources (those specified as URLs) and the\\n source specified by `spec_source_id` (whether remote or not) to lookaside. Previously, only Source0\\n was uploaded. Source0 is no longer treated specially, but as `spec_source_id` is `Source0` by default,\\n Source0 is still being uploaded by default unless `spec_source_id` is overriden.\\n ([packit#1778](https://github.com/packit/packit/pull/1778))\\n- [A VM image build](/docs/configuration/upstream/vm_image_build) can be triggered inside a PR via a comment\\n command `/packit vm-image-build` (the job needs to be defined in the configuration).\\n This feature is experimental and is still being tested.\\n ([packit-service#1761](https://github.com/packit/packit-service/pull/1761))\\n- `Section` and `Tag` objects in `specfile` library now have `normalized_name` property for more convenient comparison.\\n There is a new method, `Specfile.get_active_macros()`, to get active macros in the context of the spec file.\\n The underlying `rpm.spec` instance is now exposed as `Specfile.rpm_spec` property.\\n There is a new utility class for parsing NEVRA strings. ([specfile#141](https://github.com/packit/specfile/pull/141))\\n\\n## Week 49 (December 6th \u2013 December 12th)\\n\\n- Packit now correctly handles a race condition when it tries to create bodhi\\n updates for builds that are not yet tagged properly. CLI exprience was also\\n improved for this case.\\n ([packit#1803](https://github.com/packit/packit/pull/1803))\\n- Packit now resets the `Release` tag during `propose-downstream` if the version\\n is updated and the `Release` tag has not explicitly been overridden in the\\n upstream specfile.\\n ([packit#1801](https://github.com/packit/packit/pull/1801))\\n- If you still don\'t build SRPMs in Copr you\'ll get a warning status that you\\n should use `srpm_build_deps` to be sure that we don\'t break your workflow once\\n we switch to building all SRPMs in Copr in January.\\n ([packit-service#1804](https://github.com/packit/packit-service/pull/1804))\\n- We\'ve increased internal task retry backoff time in Packit GitHub app from 3 to\\n 7 seconds. We hope this will increase success for network flakes and _random_\\n infrastructure issues. Creation of bodhi updates should be now more reliable too\\n as Packit will try more times (from 2 to 5).\\n ([packit-service#1800](https://github.com/packit/packit-service/pull/1800))\\n- Tags enclosed in conditional macro expansions are not ignored anymore.\\n ([specfile#156](https://github.com/packit/specfile/pull/156))\\n- Context managers (`Specfile.sections()`, `Specfile.tags()` etc.) can now be nested\\n and combined together (with one exception - `Specfile.macro_definitions()`), and\\n it is also possible to use tag properties (e.g. `Specfile.version`, `Specfile.license`)\\n inside them. It is also possible to access the data directly, avoiding the `with`\\n statement, by using the `content` property (e.g. `Specfile.tags().content`), but\\n be aware that no modifications done to such data will be preserved. You must use\\n `with` to make changes.\\n ([specfile#153](https://github.com/packit/specfile/pull/153))\\n\\n## Week 50 (December 13th \u2013 December 19th)\\n\\n- Context managers are no longer shared between `Specfile` instances, making it possible\\n to work with more than one `Specfile` instance at a time.\\n ([specfile#157](https://github.com/packit/specfile/pull/157))"},{"id":"/2021","metadata":{"permalink":"/posts/weekly/2021","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2021.md","source":"@site/weekly/2021.md","title":"2021","description":"Let\'s see what happened in Packit in 2021.","date":"2022-05-16T00:00:00.000Z","formattedDate":"May 16, 2022","tags":[{"label":"2021","permalink":"/posts/weekly/tags/2021"}],"readingTime":18.03,"hasTruncateMarker":true,"authors":[],"frontMatter":{"title":"2021","date":"2022-05-16T00:00:00.000Z","tags":["2021"]},"prevItem":{"title":"2022","permalink":"/posts/weekly/2022"},"nextItem":{"title":"2020","permalink":"/posts/weekly/2020"}},"content":"Let\'s see what happened in Packit in 2021.\\n\\n\x3c!--truncate--\x3e\\n\\n## Week 1 (January 4th - January 8th)\\n\\n- Name of the job/command/comment to propose update of downstream package has been synced\\n between CLI and service to `propose-downstream`.\\n `propose-update` is now deprecated. ([packit#1065](https://github.com/packit-service/packit/pull/1065), [packit-service#913](https://github.com/packit/packit-service/pull/913))\\n\\n## Week 2 (January 11th - January 15th)\\n\\n- Branch deletions are now correctly ignored. ([packit-service#919](https://github.com/packit/packit-service/pull/919))\\n- Multiple internal improvements have been done.\\n ([packit#1072](https://github.com/packit/packit/pull/1072),\\n [packit-service#922](https://github.com/packit/packit-service/pull/922),\\n [packit-service#923](https://github.com/packit/packit-service/pull/923))\\n\\n## Week 3 (January 18th - January 22th)\\n\\n- We have temporarily disabled the testing-farm support because the cluster with old runner has died and the new runner is not ready.\\n The tests are now skipped and you get `Testing farm is temporarily disabled.` status until we have the new runner available.\\n ([packit-service#929](https://github.com/packit/packit-service/pull/929))\\n\\n## Week 4 (January 25th - January 29th)\\n\\n- The CLI and the service now detect name of the default branch of a repository\\n instead of assuming it to be called `master`.\\n ([packit#1074](https://github.com/packit/packit/pull/1074),\\n [packit-service#924](https://github.com/packit/packit-service/pull/924))\\n- Build status page now points to the built SRPM uploaded to COPR.\\n ([packit-service#889](https://github.com/packit/packit-service/pull/889))\\n- `propose-downstream` on source-git repositories now always uses `--local-content`.\\n ([packit#1093](https://github.com/packit/packit/pull/1093))\\n- Hunor fixed bug [packit#1089](https://github.com/packit/packit/pull/1089)\\n which caused a wrong revision to be used for certain jobs in Packit Service.\\n- Tomas improved the reliability of our sandboxing service.\\n ([sandcastle#95](https://github.com/packit/sandcastle/pull/95))\\n- Default branches in all [our repositories](https://github.com/packit)\\n have been renamed from `master` to `main`.\\n\\n## Week 5 (February 1st - February 5th)\\n\\n- The service uses new Testing Farm ([API](https://api.testing-farm.io)).\\n We are still working on better user experience and fixing bugs.\\n ([packit-service#875](https://github.com/packit/packit-service/pull/875))\\n- MatejF refactored permission system on pull requests and issues comments and\\n renamed whitelist to allowlist. ([packit-service#936](https://github.com/packit/packit-service/pull/936))\\n- The service now retries failed tasks.\\n ([packit-service#931](https://github.com/packit/packit-service/pull/931))\\n- `--koji-target` option of the CLI\'s `build` command now accepts aliases.\\n ([packit#1052](https://github.com/packit/packit/pull/1052))\\n- The service runs on Fedora 33 now.\\n\\n## Week 6 (February 8th - February 12th)\\n\\n- `--dist-git-branches` option in the CLI\'s `propose-downstream` command was\\n fixed, it now respects set branches.\\n ([packit#1094](https://github.com/packit/packit/pull/1094))\\n- The way Packit adds patches to spec-file in source-git repo was improved, now\\n it shouldn\'t fail if patches are sparsely numbered.\\n ([packit#1100](https://github.com/packit/packit/pull/1100))\\n\\n## Week 7 (February 15th - February 19th)\\n\\n- The service now handles issue/MR comments on Gitlab.\\n ([packit-service#985](https://github.com/packit/packit-service/pull/985))\\n- `packit init` command now works with CentOS packages.\\n ([packit#1106](https://github.com/packit/packit/pull/1106))\\n\\n## Week 8 (February 22th - February 25th)\\n\\n- Sandcastle can run multiple commands in one sandbox, kudos to Tomas.\\n ([sandcastle#93](https://github.com/packit/sandcastle/pull/93))\\n- MatejF & MatejM improved CLI\'s `create-update` to work with EPEL and add password prompt.\\n ([packit#1122](https://github.com/packit/packit/pull/1122),\\n [packit#1127](https://github.com/packit/packit/pull/1127))\\n- Service runs builds for targets from `build` + `test` jobs, kudos to Laura.\\n ([packit-service#996](https://github.com/packit/packit-service/pull/996))\\n- MatejF did a lot of small fixes and improvements of packit-service.\\n ([packit-service#989](https://github.com/packit/packit-service/pull/989),\\n [packit-service#993](https://github.com/packit/packit-service/pull/993),\\n [packit-service#994](https://github.com/packit/packit-service/pull/994))\\n\\n## Week 9 (March 1st - March 5th)\\n\\n- Tomas improved the performance of sandcastle, all the user-defined actions now run in one sandbox.\\n This should also speed up the SRPM builds. ([packit#1129](https://github.com/packit/packit/pull/1129))\\n- You can view the results of jobs directly in our dashboard, kudos to Anchit. ([dashboard#73](https://github.com/packit/dashboard/pull/73))\\n- Jirka implemented setting of the [environment context](https://tmt.readthedocs.io/en/latest/spec/context.html)\\n when running the Testing farm tests. ([packit-service#1008](https://github.com/packit/packit-service/pull/1008))\\n- In Packit there is a new configuration option `sources` which overrides the URLs defined in specfiles.\\n ([packit#1131](https://github.com/packit/packit/pull/1131), [packit#1143](https://github.com/packit/packit/pull/1143))\\n\\n## Week 10 (March 8th - March 12th)\\n\\n- Jirka worked on setting up GitHub Workflows across all of the Packit\\n repositories to build the container images for Packit Service and push them\\n to Quay.io.\\n- Tom\xe1\u0161 fixed a bug in the linearization mechanism used when generating patch\\n files from a series of Git commits. ([packit#1144](https://github.com/packit/packit/pull/1144))\\n- Hunor implemented a way for `packit` to detect if patch-files generated from\\n Git are identical with the ones already in dist-git. This should help\\n avoiding superfluous changes done by `propose-downstream`. ([packit#1133](https://github.com/packit/packit/pull/1133))\\n- Jirka increased the delay (to 3 minutes in total) for Packit Service when\\n retrying downloading the sources during a `propose-downstream` job. This\\n should give more time for the sources to become available after a release is\\n created. ([packit-service#1019](https://github.com/packit/packit-service/pull/1019))\\n- Mat\u011bj fixed an ugly bug which caused Packit Service not to react to\\n installation events. ([packit-service#1018](https://github.com/packit/packit-service/pull/1018))\\n\\n## Week 11 (March 15th - March 19th)\\n\\n- Laura fixed a bug in the processing of GitHub App installations.\\n ([packit-service#1020](https://github.com/packit/packit-service/pull/1020))\\n- Jirka fixed a bug that caused improper numbering of patches for source-git.\\n ([packit#1164](https://github.com/packit/packit/pull/1164))\\n\\n## Week 12 (March 22th - March 26th)\\n\\n- Franta improved database schema. It will help us match builds and tests together more easily and solve some UX problems.\\n ([packit-service#954](https://github.com/packit/packit-service/pull/954))\\n- `packit init` CLI command has been updated to\\n - place downstream packaging files in a subdirectory `.distro` instead of `fedora`.\\n ([packit#1165](https://github.com/packit/packit/pull/1165))\\n - enable using Stream 9 dist-git as a source.\\n ([packit#1177](https://github.com/packit/packit/pull/1177))\\n- Laura reworked how specfiles are being synced from downstream dist-git repositories and we are running a PoC for packit\'s projects to test the new approach.\\n ([packit-service#1023](https://github.com/packit/packit-service/pull/1023))\\n- It\'s possible to specify a distinct test repository for tests in a test job.\\n ([packit#1155](https://github.com/packit/packit/pull/1155))\\n ([packit-service#1021](https://github.com/packit/packit-service/pull/1021))\\n- `centos-stream` target is temporarily resolved to `centos-stream-8` to reflect a change in Copr.\\n ([packit#1167](https://github.com/packit/packit/pull/1167))\\n\\n## Week 13 (March 29th - April 1st)\\n\\n- Jirka fixed a bug in `packit push-update`\\n ([packit#1191](https://github.com/packit/packit/pull/1191)).\\n- Mat\u011bj introduced the `fedora-latest` alias for build and test targets, which\\n resolves to the latest _branched_ Fedora Linux\\n ([packit#1187](https://github.com/packit/packit/pull/1187)).\\n- A custom path for the package config (aka `packit.yaml`) can be specified\\n using a new, top-level `-c, --config` option\\n ([packit#1184](https://github.com/packit/packit/pull/1184)).\\n\\n## Week 14 (April 4th - April 9th)\\n\\n- Honza converted packit\'s test suite from STI to FMF and configured packit to\\n synchronize the suite to Fedora dist-git\\n ([packit#1192](https://github.com/packit/packit/pull/1192)).\\n- Franta fixed a bug in packit which kept only appending targets to an existing\\n COPR project which is no longer a case - dropped targets are now being\\n removed\\n ([packit#1197](https://github.com/packit/packit/pull/1197)).\\n\\n## Week 15 (April 12th - April 16th)\\n\\n- Tom\xe1\u0161 fixed an issue in chaining variable definitions in the RPM macros used\\n to set up source-git repositories with `packit init`\\n ([packit#1206](https://github.com/packit/packit/pull/1206)).\\n- Jirka improved the error message Packit Service emits when the request to\\n start a test in Testing Farm fails\\n ([packit-service#1055](https://github.com/packit/packit-service/pull/1055)).\\n- Laura made Packit Service to set a status for jobs as soon as the requests\\n are received, and before starting any of the jobs\\n ([packit-service#1046](https://github.com/packit/packit-service/pull/1046)).\\n This way users will receive a more immediate feedback about the Service\\n handling their requests.\\n\\n## Week 16 (April 19th - April 23th)\\n\\n- The `current_version_command` and `create_tarball_command` config options are being deprecated\\n in favour of [actions](https://packit.dev/docs/configuration/actions/).\\n An issue will be created in the affected repositories if we find those options in use.\\n ([packit-service#1064](https://github.com/packit/packit-service/pull/1064))\\n- The result pages have been replaced by the views on our dashboard.\\n Let us know what do you think about that and what information do you want to see there.\\n You can expect more changes on this field.\\n - The result views have been implemented by [@IceWreck](https://github.com/IceWreck)\\n ([dashboard#73](https://github.com/packit/dashboard/pull/73)).\\n - The integration on packit-service side has been done by [Ma\u0165o](https://github.com/mfocko)\\n ([packit-service#1056](https://github.com/packit/packit-service/pull/1056),\\n [dashboard#95](https://github.com/packit/dashboard/pull/95)).\\n\\n## Week 17 (April 26th - April 30th)\\n\\n- When initiating a new source-git repo, packit adds info about sources to packit.yaml.\\n Also dist-git sources from the lookaside cache are not commited.\\n ([packit#1208](https://github.com/packit/packit/pull/1208),\\n [packit#1216](https://github.com/packit/packit/pull/1216)).\\n- Franta added support for git repository cache into packit. The service part is yet to be done\\n ([packit#1214](https://github.com/packit/packit/pull/1214)).\\n- Service reacts to `/packit` commands only when they appear alone on a line\\n ([packit-service#1065](https://github.com/packit/packit-service/pull/1065),\\n [packit-service#1083](https://github.com/packit/packit-service/pull/1083)).\\n- Service doesn\'t create duplicate issues when configuration is invalid\\n ([packit-service#1075](https://github.com/packit/packit-service/pull/1075)).\\n- We deprecated `current_version_command` and `create_tarball_command` in packit config\\n ([packit#1212](https://github.com/packit/packit/pull/1212)).\\n\\n## Week 18 (May 3rd - May 7th)\\n\\n- Laura fixed the problem with `fedora-latest` alias\\n ([packit#1222](https://github.com/packit/packit/pull/1222)).\\n- We now have separate workers for short and long running tasks. This should\\n lead to better responsiveness\\n ([packit-service#1059](https://github.com/packit/packit-service/pull/1059),\\n [deployment#202](https://github.com/packit/deployment/pull/202)).\\n\\n## Week 19 (May 10th - May 14th)\\n\\n- Jirka added support for creating Bugzilla bugs for newly created MRs on GitLab\\n ([packit-service#1087](https://github.com/packit/packit-service/pull/1087)).\\n- The installation instructions for failed or unfinished COPR builds are not\\n displayed on the results page ([dashboard#104](https://github.com/packit/dashboard/pull/104)).\\n\\n## Week 20 (May 17th - May 21st)\\n\\n- Hunor created an update-dist-git command\\n ([packit#1228](https://github.com/packit/packit/pull/1228)).\\n- Jan: use packit config as a place to create reference to tests\\n ([packit#1245](https://github.com/packit/packit/pull/1245)).\\n\\n## Week 21 (May 24th - May 28th)\\n\\n- Jirka added attribute for `update-dist-git` command to specify the packaging tool (e.g. `centpkg`).\\n By default, `fedpkg` is used.\\n ([packit#1257](https://github.com/packit/packit/pull/1257),\\n [packit-service#1105](https://github.com/packit/packit-service/pull/1105)).\\n- Tom\xe1\u0161 added support for `patch_id` in the metadata of source-git commits.\\n ([packit#1252](https://github.com/packit/packit/pull/1252))\\n- Hunor improved the strategy of checking Copr results\\n when we don\'t receive that information over message-bus.\\n ([packit-service#1104](https://github.com/packit/packit-service/pull/1104))\\n\\n## Week 22 (May 31st - June 4th)\\n\\n- We have a new [status page](https://status.packit.dev), kudos to Jirka!\\n- Franta fixed a bug that if some action during `propose-downstream` caused an upstream git repository to be dirty,\\n the sync for other branches failed. ([packit-service#1111](https://github.com/packit/packit-service/pull/1111))\\n- `packit generate` is not supported anymore. ([packit#1269](https://github.com/packit/packit/pull/1269))\\n- Tom\xe1\u0161 improved the patch ordering. ([packit#1263](https://github.com/packit/packit/pull/1263))\\n\\n## Week 23 (June 7th - June 11th)\\n\\n- Tom\xe1\u0161 improved the way changelog is passed from source-git repo to dist-git.\\n ([packit#1265](https://github.com/packit/packit/pull/1265))\\n- Hunor created a new subcommand `source-git` to group source-git related commands\\n `init` and `update-dist-git`. ([packit#1273](https://github.com/packit/packit/pull/1273))\\n- Franti\u0161ek improved API by adding `submitted_time` to the test result.\\n ([packit-service#1113](https://github.com/packit/packit-service/pull/1113))\\n\\n## Week 24 (June 14th - June 19th)\\n\\n- Franta started working on packit-service being able to submit test jobs to\\n internal testing farm so teams can test upstream changes against RHEL.\\n ([packit-service#1124](https://github.com/packit/packit-service/pull/1124)\\n [packit#1280](https://github.com/packit/packit/pull/1280))\\n- Hunor continues working on `packit source-git init`: CLI is now more\\n streamlined and simplified, and the command produces source-git repos\\n matching [our documentation]({{< ref \\"create-source-git.md\\" >}}).\\n ([packit#1277](https://github.com/packit/packit/pull/1277))\\n- Ma\u0165o Focko finished his refactoring of the `Upstream` class - should not have\\n impact on our users, but make the code easier to work with.\\n ([packit#1157](https://github.com/packit/packit/pull/1157))\\n\\n## Week 25 (June 21st - June 26th)\\n\\n- Hunor made several improvements to `source-git init`\'s CLI.\\n ([packit#1284](https://github.com/packit/packit/pull/1284))\\n- Thanks to Frantisek there is now one COPR project/repo used for all releases.\\n ([packit-service#1128](https://github.com/packit/packit-service/pull/1128))\\n- Laura fixed a bug in syncing downstream to upstream.\\n ([packit#1285](https://github.com/packit/packit/pull/1285))\\n\\n## Week 26+27 (June 28th - July 9th)\\n\\nSummer is here and vacations with it. Most of the work done in this sprint\\nis either internal (not user facing) or not finished yet.\\n\\n- Thanks to Ma\u0165ejM Packit Service now triggers a new Copr build if no\\n suitable build has been found. That fixes an issue that the service sometimes\\n did not react to `/packit test`.\\n ([packit-service#1132](https://github.com/packit/packit-service/pull/1132))\\n\\n## Week 28 (July 12th - July 16th)\\n\\n- We have a new API endpoint for obtaining projects of a given forge.\\n ([packit-service#1159](https://github.com/packit/packit-service/pull/1159))\\n- The bug causing that some projects couldn\'t be loaded in our dashboard was fixed.\\n ([packit-service#1161](https://github.com/packit/packit-service/pull/1161))\\n\\n## Week 29 (July 19th - July 23th)\\n\\n- Various improvements on our dashboard were done; mainly:\\n - Projects can be filtered by a forge.\\n ([dashboard#124](https://github.com/packit/dashboard/pull/124))\\n - Table with jobs was unified and cleaned.\\n ([dashboard#121](https://github.com/packit/dashboard/pull/121))\\n- Newly, we use the [Checks API](https://docs.github.com/en/rest/reference/checks) to show results on GitHub.\\n You can still see the results on the bottom of the pull-request page,\\n but also in the `Checks` tab.\\n This gives us more options like status with a neutral state\\n (e.g. currently, for permission errors) or a place for showing more details.\\n Don\'t forget to give our GitHub application permissions to use it.\\n You can expect more improvements in this field.\\n ([packit-service#1167](https://github.com/packit/packit-service/pull/1167))\\n\\n## Week 30 (July 26th - July 30th)\\n\\n- Source-git patch metadata: the `squash_commits` key is deprecated. Instead of using this,\\n set the same [`patch_name`](/development/patch-metadata#patch_name) in the commit\\n message of adjacent commits, which should end up in the same patch file.\\n ([packit#1309](https://github.com/packit/packit/pull/1309))\\n- `packit init` can now find a spec file inside of a git repository and set\\n it in `.packit.yaml`. ([packit#1313](https://github.com/packit/packit/pull/1313))\\n- A lot of work has been done on our dashboard:\\n - Status labels on dashboard have been reworked.\\n - New pipelines view for dashboard has been released, where you can see all builds and\\n tests that were recently run for your pull request, release or branch push. Each row\\n represents one pipeline of builds and tests from SRPM all the way to the Testing Farm. \\n ([dashboard#128](https://github.com/packit/dashboard/pull/128))\\n\\n## Week 31 (August 2nd - August 6th)\\n\\n- `sync_release` in API allows specifying a suffix for the newly created branch in a dist-git repo fork,\\n so that there can be more open update PRs for the same dist-git branch at the same time.\\n ([packit#1326](https://github.com/packit/packit/pull/1326))\\n- The behaviour of running tests triggered by `/packit test` comment was improved.\\n If there is no existing Copr build when the tests are triggered,\\n Packit service should now react and create a new build.\\n Also when the last Copr build status is failed,\\n tests are not submitted and users are informed about this.\\n ([packit-service#1188](https://github.com/packit/packit-service/pull/1188))\\n- You can use `oraclelinux-7`/`oraclelinux-8` chroots for build and test of your package on Oracle Linux.\\n ([packit-service#1186](https://github.com/packit/packit-service/pull/1186))\\n\\n## Week 32 (August 9th - August 13th)\\n\\n- `status` command of Packit\'s CLI has been refactored and now provides much cleaner output. ([packit#1329](https://github.com/packit/packit/pull/1329))\\n\\n## Week 33 (August 16th - August 20th)\\n\\n- When reacting to `/packit test`, Packit service sets a status before starting the job\\n to unify the behaviour with reacting to triggering builds. ([packit-service#1187](https://github.com/packit/packit-service/pull/1187))\\n- `packit validate-config` now checks also the value of the `specfile_path` configuration option\\n and shows warning if the specified file is not present in the repository. ([packit#1342](https://github.com/packit/packit/pull/1342))\\n\\n## Week 34 (August 23rd - August 27th)\\n\\n- Packit by default locally merges checked out pull requests into target branch.\\n Logging for checking out pull requests was improved to contain hashes and\\n summaries of last commit on both source and target branches.\\n ([packit#1344](https://github.com/packit/packit/pull/1344))\\n- Packit Service now runs Copr and Koji builds and following tests on Testing Farm\\n for pull requests on the code that would be a result of merging into the target branch.\\n In case merge conflicts occur during preparation of SRPM,\\n you can find more info in the SRPM logs.\\n ([packit-service#1206](https://github.com/packit/packit-service/pull/1206))\\n- Packit\'s CLI `source-git update-dist-git` now supports using Git trailers to define patch metadata,\\n which will control how patches are generated and added to the spec-file.\\n `source-git init` uses this format to capture patch metadata when setting up\\n a source-git repo, instead of the YAML one.\\n To maintain backwards compatibility, the YAML format is still parsed,\\n but only if none of the patches defines metadata using Git trailers.\\n ([packit#1336](https://github.com/packit/packit/pull/1336))\\n- These changes will be applied next week (not this week as usual).\\n\\n## Week 35 (August 30th - September 3rd)\\n\\n- A bug in Packit that caused purging or syncing upstream changelog\\n (when not configured) from specfile when running `propose-downstream` was fixed.\\n New behavior preserves downstream changelog and in case there are either\\n no entries or no %changelog section present, it is created with a new entry.\\n ([packit#1349](https://github.com/packit/packit/pull/1349))\\n\\n## Week 36 (September 6th - September 10th)\\n\\n- `packit source-git init` was updated to try to apply patches with `git am` first, and use `patch` only when this fails, in order to keep the commit message of Git-formatted (mbox) patch files in the source-git history. ([packit#1358](https://github.com/packit/packit/pull/1358))\\n\\n## Week 37 (September 13th - September 17th)\\n\\n- Now you can find URL pointing directly to testing farm results on GitHub Checks page. ([packit-service#1215](https://github.com/packit/packit-service/pull/1215))\\n- Ogr now supports reacting to the comment with a given reaction, getting them in list and deleting them (only when reaction is added by using ogr API). ([ogr#636](https://github.com/packit/ogr/pull/636))\\n- Packit now provides `PACKIT_RPMSPEC_RELEASE` environment variable in actions. ([packit#1363](https://github.com/packit/packit/pull/1363))\\n- Dashboard no longer shrinks Copr/Koji icons when being open in narrow view. ([dashboard#140](https://github.com/packit/dashboard/pull/140))\\n\\n## Week 38 (September 20th - September 24th)\\n\\n- [Dashboard](https://dashboard.packit.dev) now shows more readable format of time,\\n e.g. \\"just now\\", \\"a minute ago\\", etc. If you wish to see exact date-time of\\n the run, you can either hover over the time and tooltip with details appear.\\n In case of result pages more readable format is present in the tooltip rather\\n than by default. Also times are now shown in your local time zone. ([dashboard#142](https://github.com/packit/dashboard/pull/142))\\n- Packit can now read commit messages from a patch to support characters which cannot be encoded with UTF-8. ([packit#1372](https://github.com/packit/packit/pull/1372))\\n- EPEL targets are now being mapped to CentOS Linux inside the internal Testing Farm runs. ([packit-service#1225](https://github.com/packit/packit-service/pull/1225))\\n\\n## Week 39 (September 27th - October 1st)\\n\\n- Clicking on logo on [dashboard](https://dashboard.packit.dev/) no longer\\n opens a new page, but rather reloads the current one.\\n- We consider [Pipelines view](https://dashboard.packit.dev/pipelines) on\\n dashboard to be ready for production use. We\'re planning to improve the user\\n experience when using pipelines with easier navigation and filtering\\n options.\\n- Building the latest development versions of\\n [packit](https://github.com/packit/packit) and\\n [ogr](https://github.com/packit/ogr) was moved to the\\n [packit/packit-dev](https://copr.fedorainfracloud.org/coprs/packit/packit-dev/)\\n Copr repo.\\n\\n## Week 40 (October 4th - October 8th)\\n\\n- [A bug](https://github.com/packit/packit/issues/1255) in Packit causing\\n issues with local build when the branch was named with prefix `rpm` has been\\n fixed.\\n- To fulfill requests regarding updating targets on Copr repositories, Packit\\n Service will sync targets for the projects created by Packit Service (e.g.\\n pull requests, or non-set Copr repository for releases and branch builds)\\n and for Copr repositories **not owned by Packit** will try to extend the\\n list if necessary.\\n- If you trigger packit jobs with one of `/packit _` commands, our bot gives\\n you a \ud83d\udc4d reaction to let you know that we are working on it.\\n- Rerunning of failed tasks via GitHub Checks interface is now supported. You are now free to click those \\"Re-run\\" links.\\n- [ogr documentation](https://packit.github.io/ogr/) is converted to\\n Google-style docstrings. In case there are any discrepancies, missing docs\\n or docstrings in different format, please open an issue.\\n\\n## Week 41 (October 11th - October 15th)\\n\\n- We have added a new option to Packit CLI when creating Bodhi updates, you can\\n use `-b` or `--resolve- bugzillas` and specify IDs (separated by comma, e.g.\\n `-b 1` or `-b 1,2,3`) of bugzillas that are being closed by the update.\\n ([packit#1383](https://github.com/packit/packit/pull/1383))\\n- Packit will deduce the version for SRPM from the spec file, if there are no\\n git tags or action for acquiring current version defined.\\n ([packit#1388](https://github.com/packit/packit/pull/1388))\\n- It is possible to use `aarch64` architecture in the Testing Farm.\\n ([packit-service#1247](https://github.com/packit/packit-service/pull/1247))\\n- Running tests via Testing Farm now supports `centos-6` target.\\n ([packit-service#1244](https://github.com/packit/packit-service/pull/1244))\\n\\n## Week 42 (October 18th - October 22th)\\n\\n- We have introduced new options for generating SRPM packages:\\n ([packit#1396](https://github.com/packit/packit/pull/1396))\\n - `--no-bump` that prevents changing of the release in the SRPM,\\n which can be used for creating SRPMs on checked out tags/releases.\\n - `--release-suffix` that allows you to customize the suffix after the release number,\\n e.g. reference bugzilla or specific branch of the build.\\n- Copr build installation instructions now contain detailed info about\\n the built packages, so you can install the precise build from your pull request.\\n ([dashboard#149](https://github.com/packit/dashboard/pull/149))\\n\\n## Week 43 (October 25th - November 1st)\\n\\n- We have introduced a new configuration option `merge_pr_in_ci` that allows you to disable merging of PR into the base branch before creating SRPM in service. ([packit#1395](https://github.com/packit/packit/pull/1395), [packit-service#1261](https://github.com/packit/packit-service/pull/1261))\\n- If the upstream spec file is located in a subdirectory (such as\\n `packaging/fedora/pkg.spec`), it is now correctly synced to the root of\\n the downstream repository, since that\'s where rpmbuild will look\\n for it. ([packit#1402](https://github.com/packit/packit/pull/1402))\\n- The \\"Congratulations!\\" comment no longer has a disclaimer about our intentions to stop posting it by default. We have already made that move earlier this year, so the disclaimer is no longer relevant. ([packit-service#1260](https://github.com/packit/packit-service/pull/1260))\\n- Deprecated configuration options `current_version_command` and `create_tarball_command` have been removed and are no longer supported. They are superseded by actions `get-current-version` and `create-archive`. ([packit#1397](https://github.com/packit/packit/pull/1397))\\n\\n## Week 44 (November 1st - November 5th)\\n\\n- We have fixed several issues in packit when it\'s periodically checking\\n statuses of jobs. You should now reliably see up to date check statuses for\\n Copr RPM builds and Testing Farm runs.\\n ([packit-service#1267](https://github.com/packit/packit-service/pull/1267)),\\n ([packit-service#1265](https://github.com/packit/packit-service/pull/1265))\\n- Fixed an issue, which raised a `UnicodeEncodingError`, when working with\\n dist-git patch files with an encoding other than UTF-8.\\n ([packit#1406](https://github.com/packit/packit/pull/1406))\\n- Backup alias definitions now reflect the official release of Fedora 35.\\n ([packit#1405](https://github.com/packit/packit/pull/1405))\\n\\n## Week 45 (November 8th - November 12th)\\n\\n- You can now specify `skip_build` option in the test job metadata in the\\n Packit configuration file. This will cause no Copr build to be built and\\n installed into the testing environment, but only trigger the tests in\\n Testing Farm (the selected components to be installed should be part of the\\n TMT definitions).\\n ([packit-service#1256](https://github.com/packit/packit-service/pull/1256))\\n- Packit supports `changelog-entry` action that is used when creating SRPM.\\n The action is supposed to generate whole changelog entry (including `- ` at\\n the start of the lines) and has a priority over any other way we modify the\\n changelog with. ([packit#1367](https://github.com/packit/packit/pull/1367))\\n\\n## Week 46 (November 15th - November 19th)\\n\\n- A new `env` config option has been added for specifying environment variables,\\n which are then passed to Testing Farm along with some more pre-defined\\n variables (e.g. name of the project, URL, etc).\\n ([packit#1411](https://github.com/packit/packit/pull/1411))\\n ([packit-service#1275](https://github.com/packit/packit-service/pull/1275))\\n- The GitHub check run names are now shorter and easier to read.\\n ([packit-service#1281](https://github.com/packit/packit-service/pull/1281))\\n\\n## Week 47 (November 22th - November 26th)\\n\\n- You can set up a new `koji_build` job using the commit trigger to submit a\\n Koji build for a new commit in a dist-git branch. The configuration file\\n needs to be present in the dist-git for now\\n (the state for the new commit is used).\\n ([packit-service#1278](https://github.com/packit/packit-service/pull/1278))\\n\\n## Week 48 (November 29th - December 3rd)\\n\\n- External contributors can\'t trigger internal tests initially. Project\\n maintainers need to trigger the action via `/packit test` comment to run\\n the job.\\n ([packit-service#1302](https://github.com/packit/packit-service/pull/1302))\\n ([packit-service#1305](https://github.com/packit/packit-service/pull/1305))\\n- A new `packit prepare-sources` command has been implemented for preparing\\n sources for an SRPM build using the content of an upstream repository.\\n ([packit#1424](https://github.com/packit/packit/pull/1424))\\n- Packit now visibly informs about an ongoing cloning process to remove\\n potential confusion.\\n ([packit#1431](https://github.com/packit/packit/pull/1431))\\n- The `upstream_package_name` config option is now checked for illegal\\n characters and an error is thrown if it contains them.\\n ([packit#1434](https://github.com/packit/packit/pull/1434))\\n\\n## Week 49 (December 6th - December 12th)\\n\\n- Packit now correctly finds the release event if you don\'t use the version as a release title.\\n ([packit#1437](https://github.com/packit/packit/pull/1437))"},{"id":"/2020","metadata":{"permalink":"/posts/weekly/2020","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2020.md","source":"@site/weekly/2020.md","title":"2020","description":"Let\'s see what happened in Packit in 2020.","date":"2022-01-04T00:00:00.000Z","formattedDate":"January 4, 2022","tags":[{"label":"2020","permalink":"/posts/weekly/tags/2020"}],"readingTime":22.565,"hasTruncateMarker":true,"authors":[],"frontMatter":{"title":"2020","date":"2022-01-04T00:00:00.000Z","tags":["2020"]},"prevItem":{"title":"2021","permalink":"/posts/weekly/2021"},"nextItem":{"title":"2019","permalink":"/posts/weekly/2019"}},"content":"Let\'s see what happened in Packit in 2020.\\n\\n\x3c!--truncate--\x3e\\n\\n## Week 1\\n\\n### packit\\n\\n- Correctly updates version on srpm build. ([#642](https://github.com/packit-service/packit/pull/642))\\n- Downloads all URL sources before srpm build. ([#643](https://github.com/packit-service/packit/pull/643))\\n\\n### packit service\\n\\n- Runs on Fedora 31. ([#303](https://github.com/packit-service/packit-service/pull/303), [#304](https://github.com/packit-service/packit-service/pull/304))\\n- Correctly checks list of whitelisted repositories when issue comment is added. ([#309](https://github.com/packit-service/packit-service/pull/309))\\n\\n## Week 2\\n\\n### packit\\n\\n- Incorporates lots of SRPM related improvements. ([#646](https://github.com/packit-service/packit/pull/646), [#650](https://github.com/packit-service/packit/pull/650), [#651](https://github.com/packit-service/packit/pull/651), [#652](https://github.com/packit-service/packit/pull/652), [#653](https://github.com/packit-service/packit/pull/653))\\n- Better handles when Copr owner is not set. ([#648](https://github.com/packit-service/packit/pull/648))\\n\\n### packit service\\n\\n- Fixes SRPM exceptions/errors handling. ([#311](https://github.com/packit-service/packit-service/pull/311), [#317](https://github.com/packit-service/packit-service/pull/317))\\n- Has loading of config fixed. ([#318](https://github.com/packit-service/packit-service/pull/318))\\n\\n## Week 3\\n\\n### packit\\n\\n- Uses [Marshmallow](https://pypi.org/project/marshmallow) for configuration schema. ([#657](https://github.com/packit-service/packit/pull/657))\\n- Is able to build in [Koji](https://koji.fedoraproject.org) from upstream/source-git. ([#658](https://github.com/packit-service/packit/pull/658))\\n- Doesn\'t download remote sources when \\"sources\\" path exists in upstream. ([#659](https://github.com/packit-service/packit/pull/659))\\n- Configuration file allows list syntax in action commands. ([#663](https://github.com/packit-service/packit/pull/663))\\n- Configuration can use a new option to exclude paths from patching. ([#666](https://github.com/packit-service/packit/pull/666))\\n- Has few less bugs. ([#660](https://github.com/packit-service/packit/pull/660), [#661](https://github.com/packit-service/packit/pull/661), [#664](https://github.com/packit-service/packit/pull/664), [#667](https://github.com/packit-service/packit/pull/667))\\n\\n### packit service\\n\\n- Uses [Marshmallow](https://pypi.org/project/marshmallow) for configuration schema. ([#320](https://github.com/packit-service/packit-service/pull/320))\\n- Runs build for test job even when it\'s not explicitly configured. ([#324](https://github.com/packit-service/packit-service/pull/324))\\n- Reports invalid or missing packit config. ([#328](https://github.com/packit-service/packit-service/pull/328))\\n- Status workflow has been changed and simplified. ([#338](https://github.com/packit-service/packit-service/pull/338))\\n- Minor fixes. ([#323](https://github.com/packit-service/packit-service/pull/323), [#326](https://github.com/packit-service/packit-service/pull/326), [#329](https://github.com/packit-service/packit-service/pull/329), [#331](https://github.com/packit-service/packit-service/pull/331), [#335](https://github.com/packit-service/packit-service/pull/335), [#336](https://github.com/packit-service/packit-service/pull/336))\\n\\n## Week 4\\n\\n### packit\\n\\n- [0.8.1](https://pypi.org/project/packitos/0.8.1/) has been released.\\n- CLI has bash auto completion. ([#654](https://github.com/packit-service/packit/pull/654))\\n- Few bugs have been squashed. ([#668](https://github.com/packit-service/packit/pull/668), [#670](https://github.com/packit-service/packit/pull/670), [#676](https://github.com/packit-service/packit/pull/676), [#677](https://github.com/packit-service/packit/pull/677), [#678](https://github.com/packit-service/packit/pull/678), [#680](https://github.com/packit-service/packit/pull/680), [#682](https://github.com/packit-service/packit/pull/682))\\n\\n### packit service\\n\\n- More checks messages have been unified. ([#355](https://github.com/packit-service/packit-service/pull/355))\\n- One more testing-farm status is now shown before the tests are submitted. ([#343](https://github.com/packit-service/packit-service/pull/343))\\n- No-fmf scenario has better messages. ([#362](https://github.com/packit-service/packit-service/pull/362))\\n- Minor fixes and improvements. ([#339](https://github.com/packit-service/packit-service/pull/339), [#340](https://github.com/packit-service/packit-service/pull/340), [#342](https://github.com/packit-service/packit-service/pull/342), [#345](https://github.com/packit-service/packit-service/pull/345), [#346](https://github.com/packit-service/packit-service/pull/346), [#347](https://github.com/packit-service/packit-service/pull/347), [#348](https://github.com/packit-service/packit-service/pull/348), [#352](https://github.com/packit-service/packit-service/pull/352), [#353](https://github.com/packit-service/packit-service/pull/353), [#350](https://github.com/packit-service/packit-service/pull/350), [#357](https://github.com/packit-service/packit-service/pull/357), [#358](https://github.com/packit-service/packit-service/pull/358), [#361](https://github.com/packit-service/packit-service/pull/361), [#364](https://github.com/packit-service/packit-service/pull/364))\\n\\n## Week 5\\n\\n### packit\\n\\n- CLI has a new command for local build. ([#687](https://github.com/packit-service/packit/pull/687))\\n- Logs less. ([#685](https://github.com/packit-service/packit/pull/685))\\n\\n### packit service\\n\\n- Minor fixes and improvements. ([#365](https://github.com/packit-service/packit-service/pull/365), [#371](https://github.com/packit-service/packit-service/pull/371), [#373](https://github.com/packit-service/packit-service/pull/373), [#376](https://github.com/packit-service/packit-service/pull/376))\\n\\n## Week 6\\n\\nBoth Packit and Packit Service pre-commit hooks [were][1] [updated][2] to include\\n[prettier] and [setup-cfg-fmt], in order to have a more consistent formatting of\\nmarkup, YAML, JSON and `setup.cfg` files.\\n\\nIt became easier for developers to [build the Packit base image] locally, and\\ntests in Zuul [were configured] to run on Fedora 31.\\n\\nPackit learned [how to look for RPM spec files on its own], so specifying\\n`specfile_path` in the configuration is not mandatory anymore. Packit will\\nrecursively search the tree and use the first spec file found.\\n\\nThe Redis pod in Packit Service uses an up to date image now, [based on Fedora 31].\\nKudos to [hhorak] for the help!\\n\\n[1]: https://github.com/packit-service/packit/pull/697\\n[2]: https://github.com/packit-service/packit-service/pull/383\\n[prettier]: https://github.com/prettier/prettier\\n[setup-cfg-fmt]: https://github.com/asottile/setup-cfg-fmt\\n[build the packit base image]: https://github.com/packit-service/packit/pull/695\\n[were configured]: https://github.com/packit-service/packit/pull/694\\n[how to look for rpm spec files on its own]: https://github.com/packit-service/packit/pull/634\\n[based on fedora 31]: https://github.com/packit-service/deployment/pull/51\\n[hhorak]: https://github.com/hhorak\\n\\n## Week 7\\n\\nThe default configuration generated by Packit has [test jobs enabled] from now\\non. This should simplify configuring Packit in new repositories.\\n\\n[Fixed a bug] which was causing SRPM-build failures in Packit Service for projects\\nwhich had their spec files stored in a subdirectory.\\n\\nAs a result of [keys.fedoraproject.org] being turned off, Packit now [tries] a\\nlist of GPG keyservers when downloading keys to check commit signatures.\\n\\nWhen enabling Packit Service for new GitHub repositories, instead of checking\\nif the requester is a Fedora packager, we\'ll check if they [signed the Fedora\\nProject Contributor Agreement].\\n\\nWhile proposing an update to Fedora, Packit Service will [report a failure] now\\nwhen there are no releases found in the upstream GitHub repository.\\n\\nTest results became [serializable], we will not block when [no test results\\nare received], and Packit Service received [some initial code] to enable using\\nPostgreSQL as a data backend.\\n\\n[test jobs enabled]: https://github.com/packit-service/packit/pull/703\\n[fixed a bug]: https://github.com/packit-service/packit/pull/698\\n[tries]: https://github.com/packit-service/packit/pull/699\\n[keys.fedoraproject.org]: https://lists.fedoraproject.org/archives/list/devel@lists.fedoraproject.org/message/COEYWJBQDAWRSYNQW7Y7TD2EKEGBWOAY/\\n[signed the fedora project contributor agreement]: https://github.com/packit-service/packit-service/pull/403\\n[no test results are received]: https://github.com/packit-service/packit-service/pull/388\\n[some initial code]: https://github.com/packit-service/packit-service/pull/319\\n[report a failure]: https://github.com/packit-service/packit-service/pull/399\\n[serializable]: https://github.com/packit-service/packit-service/pull/391\\n\\n## Week 8\\n\\nPostgresql database was introduced in production environment to improve performance and enable implementation\\nof new features, e.g. storing logs to reduce amount of messages sent directly to pull request [(#406)], [(#420)].\\n\\nCleanup in configuration files was performed, so no longer needed values were removed from .packit.yaml [(#709)].\\nUser experience was improved by adding new `--upstrem-ref` option to `copr-build` command in command-line interface [(#718)]\\nand making error reporting more robust by adding new fedpkg clones related error message [(#714)].\\n\\nFollowing bugs were fixed:\\n\\n- bug in copr-build command fixed [(#713)]\\n- get_local_package_config() duplicate entries in \'directories\' bug fixed [(#715)]\\n\\n[(#709)]: https://github.com/packit-service/packit/pull/709\\n[(#718)]: https://github.com/packit-service/packit/pull/718\\n[(#714)]: https://github.com/packit-service/packit/pull/714\\n[(#713)]: https://github.com/packit-service/packit/pull/713\\n[(#715)]: https://github.com/packit-service/packit/pull/715\\n[(#406)]: https://github.com/packit-service/packit-service/pull/406\\n[(#420)]: https://github.com/packit-service/packit-service/pull/420\\n\\n## Week 9\\n\\n### packit\\n\\n- Dist-git patches are now applied in source-git repos with `-p1` to resolve an issue when they are generated with git and patch program fails to apply them [(#730)].\\n- Fedora 32 was added to \'fedora-all\' and \'fedora-development\' aliases [(#731)].\\n- We have put more links to our documentation (README, deprecation warning in packit) so that people can easily correct their configuration files [(#726)].\\n\\n### packit-service\\n\\n- `targets` key in copr job definition in the packit.yaml is no longer a required field (it defaults to `fedora-stable`) [(#431)].\\n- Builds are now correctly linked to their actual GitHub projects (this can be seen in the logs view) [(#441)].\\n\\n[(#730)]: https://github.com/packit-service/packit/pull/730\\n[(#731)]: https://github.com/packit-service/packit/pull/731\\n[(#726)]: https://github.com/packit-service/packit/pull/726\\n[(#431)]: https://github.com/packit-service/packit-service/pull/431\\n[(#441)]: https://github.com/packit-service/packit-service/pull/441\\n\\n## Week 10 (March 2nd - March 6th)\\n\\n### packit\\n\\n- The generate command is now deprecated in favour of the init command\\n [(#728)], contributed by [@shreyaspapi](https://github.com/shreyaspapi).\\n\\n### packit-service\\n\\n- When a non-collaborator creates a PR, packit says that only \\"Collaborators\\n can trigger packit-service\\" - this message has been improved to better match\\n the reality [(#445)].\\n- Packit service no longer posts comments on pull requests when a SRPM can\'t be\\n created - the logs should be now aviable in the service\'s logs view available\\n when clocking on the commit status check URL [(#447)].\\n- Commands to control packit service can now be embedded in a comment\\n (previously, the whole comment was treated as a command) - hence you can now\\n create a comment to give an update and also trigger packit [(#433)],\\n contributed by [@IceWreck](https://github.com/IceWreck).\\n- We have improved monitoring of packit-service by using more sentry.io\'s\\n features [(#458)].\\n- You can now disable the functionality when packit service comments on a PR\\n when it gets built for the first time (`notifications: {pull_request: {successful_build:: false}}` in your packit.yaml), hi\\n [Lars](https://github.com/larskarlitski)! [(#455)].\\n\\n[(#728)]: https://github.com/packit-service/packit/pull/728\\n[(#445)]: https://github.com/packit-service/packit-service/pull/445\\n[(#447)]: https://github.com/packit-service/packit-service/pull/447\\n[(#433)]: https://github.com/packit-service/packit-service/pull/433\\n[(#458)]: https://github.com/packit-service/packit-service/pull/458\\n[(#455)]: https://github.com/packit-service/packit-service/pull/455\\n\\n## Week 11 (March 9th - March 13th)\\n\\n### packit\\n\\n- We have changed how packit treats version and release in the spec file [(#748)].\\n - We handle the `git-describe` output better which should help when tags\\n contain dashes [(#759)].\\n- When packit adds source-git patches into a spec file it adds them outside\\n of rpm macros now [(#760)].\\n- In pull request pipelines we run the packit-service tests so that we are sure we\\n do not break the service [(#752)].\\n\\n### packit-service\\n\\n- Comments from packit-service about successful `propose-update` in the issue\\n which triggered the update now include the URL of the new pull-request in Fedora [(#472)].\\n- We have done some major refactoring how jobs are processed\\n [(#476)], [(#746)], [(#453)].\\n- Development and debugging of the packit-service should be easier now, we\\n documented how to run packit-service locally [(#473)].\\n\\n[(#746)]: https://github.com/packit-service/packit/pull/746\\n[(#748)]: https://github.com/packit-service/packit/pull/748\\n[(#752)]: https://github.com/packit-service/packit/pull/752\\n[(#759)]: https://github.com/packit-service/packit/pull/759\\n[(#760)]: https://github.com/packit-service/packit/pull/760\\n[(#472)]: https://github.com/packit-service/packit-service/pull/472\\n[(#473)]: https://github.com/packit-service/packit-service/pull/473\\n[(#476)]: https://github.com/packit-service/packit-service/pull/476\\n[(#453)]: https://github.com/packit-service/packit-service/pull/453\\n\\n## Week 12 (March 16th - March 20th)\\n\\n### packit\\n\\n- When you are executing `copr-build` command, you do not\\n need to set the project name if this value is defined in\\n the `copr_build` job in the configuration file [(#763)].\\n- All patches generated from a source-git repo are now prefixed with a number\\n so they are easy to sort [(#765)].\\n- We improved the behaviour when loading the authentication in the config file -\\n users are warned only if deprecated keys are used, no more confusing messages when\\n you do not have `authentication` key in the configuration [(#754)].\\n\\n### packit-service\\n\\n- We periodically check the status of the copr-build so that we do not need to rely\\n on the Fedora message bus. This should avoid failures in build status reporting [(#490)].\\n- `Propose-update` triggered by comment in GitHub now recognizes also pre-releases [(#498)].\\n- Several bugs in how we report results from Testing farm have been fixed and Testing\\n farm results should now appear correctly in commit status checks\\n [(#496)], [(#505)], [(#510)], [(#513)].\\n\\n[(#765)]: https://github.com/packit-service/packit/pull/765\\n[(#754)]: https://github.com/packit-service/packit/pull/754\\n[(#763)]: https://github.com/packit-service/packit/pull/763\\n[(#490)]: https://github.com/packit-service/packit-service/pull/490\\n[(#498)]: https://github.com/packit-service/packit-service/pull/498\\n[(#497)]: https://github.com/packit-service/packit-service/pull/497\\n[(#496)]: https://github.com/packit-service/packit-service/pull/496\\n[(#505)]: https://github.com/packit-service/packit-service/pull/505\\n[(#510)]: https://github.com/packit-service/packit-service/pull/510\\n[(#513)]: https://github.com/packit-service/packit-service/pull/513\\n\\n## Week 13 (March 23th - March 27th)\\n\\n- New Packit version 0.9.0 was released.\\n- Packit Service now mostly uses PostgreSQL instead of Redis as a backend,\\n which will result in more responsive API and Dashboard.\\n\\n## Week 14 (March 30th - April 3rd)\\n\\n### packit\\n\\n- Fix web URLs for Copr builds owned by groups [(#778)].\\n- Create downstream spec if it\'s not there (propose-update) - this used to happen when using packit on a newly created package in Fedora which did not have spec fille added yet. [(#779)]\\n- Packit no longer inspects archive extension set in `Source` and creates `.tar.gz` by default - this should be more flexible and prevent issues for \\"non-standard\\" archive names. [(#781)]\\n\\n### packit-service\\n\\n- Several fixes and improvements after switching data store from Redis to PostgreSQL.\\n- Use the configured COPR project when triggering Testing Farm (tests no longer fail for projects which are built in their own COPR namespace) [(#524)].\\n\\n[(#778)]: https://github.com/packit-service/packit/pull/778\\n[(#779)]: https://github.com/packit-service/packit/pull/779\\n[(#781)]: https://github.com/packit-service/packit/pull/781\\n[(#524)]: https://github.com/packit-service/packit-service/pull/524\\n\\n## Week 15 (March 6th - April 9th)\\n\\n### packit\\n\\n- [Tom\xe1\u0161] finished teaching `packit srpm` to [linearise extremely complex Git\\n histories], in order to get patches that can be applied when building the\\n SRPM.\\n- [Jirka] made the schema validation code [Marshmallow3 compatible]. This\\n enables building `packit` in Fedora 32 and Rawhide.\\n\\n### packit-service\\n\\n- [Franta] fixed an issue with [parsing release events].\\n- [Jirka] made code [Marshmallow3] compatible in this project, too.\\n\\n[tom\xe1\u0161]: https://github.com/TomasTomecek\\n[jirka]: https://github.com/jpopelka\\n[franta]: https://github.com/lachmanfrantisek\\n[linearise extremely complex git histories]: https://github.com/packit-service/packit/pull/766\\n[marshmallow3 compatible]: https://github.com/packit-service/packit/pull/775\\n[marshmallow3]: https://github.com/packit-service/packit-service/pull/538\\n[parsing release events]: https://github.com/packit-service/packit-service/issues/536\\n\\n## Week 16 (April 14th - April 17th)\\n\\n### packit & packit-service\\n\\n- Job metadata field `dist-git-branch` is now marked as deprecated, to be\\n replaced by `dist_git_branches` to match the naming of other metadata fields\\n and to accept multiple branch names where Packit should work. ([#797],\\n [#788] and [#564]).\\n- A great deal of refactoring, CI work and general code improvements which\\n will make Packit and Packit Service run smoother and development easier.\\n\\n[#797]: https://github.com/packit-service/packit/pull/797\\n[#788]: https://github.com/packit-service/packit/pull/788\\n[#564]: https://github.com/packit-service/packit-service/pull/564\\n\\n## Week 17 (April 20th - April 24th)\\n\\n### packit-service\\n\\nIn this week we mostly focused on CentOS Stream and\\nsome under the hood improvements,\\nnone of which are available for GitHub projects.\\n\\n- [Jano] did a lot of work on [initial CentOS Stream integration].\\n- [Hunor] added a Pagure build status reporting.\\n- [Anchit] added first API tests and improved build statuses given by the API.\\n- [Laura] and [Rishav] improved how data about Copr builds are stored in our db.\\n\\n[anchit]: https://github.com/IceWreck\\n[hunor]: https://github.com/csomh\\n[jano]: https://github.com/sakalosj\\n[laura]: https://github.com/lbarcziova\\n[rishav]: https://github.com/rishavanand\\n[initial centos stream integration]: https://github.com/packit-service/packit-service/pull/515\\n\\n## Week 18 (April 27th - April 30th)\\n\\n### packit-service\\n\\n- [Franta] did a great deal of service & worker refactoring related to CentOS ([#586])\\n and to forks usage in GitHub. ([#589])\\n- [Hunor] fixed confusing GitHub status messages while building in Copr. ([#588])\\n\\n[#586]: https://github.com/packit-service/packit-service/pull/586\\n[#588]: https://github.com/packit-service/packit-service/pull/588\\n[#589]: https://github.com/packit-service/packit-service/pull/589\\n\\n## Week 19 (May 4th - May 6th)\\n\\n### packit\\n\\n- The image now uses ogr from git master instead of from Fedora stable RPM.\\n\\n### packit-service\\n\\n- [Franta] Fixed a previous week introduced bug, which prevented users from being whitelisted. ([#599])\\n- [Hunor] Made improvements to avoid a race condition in getting app access token. ([#601])\\n\\n[franta]: https://github.com/lachmanfrantisek\\n[hunor]: https://github.com/csomh\\n[#599]: https://github.com/packit-service/packit-service/pull/599\\n[#601]: https://github.com/packit-service/packit-service/pull/601\\n\\n## Week 20+21 (May 11th - May 22th)\\n\\n### packit\\n\\n- The debug logs in the CLI are now much more consistent. ([#824])\\n- A bug in the `propose-update` causing problems with the synchronization of the spec-file content was fixed. ([#830])\\n- You can now use `epel-all` alias in the arguments and also in the configuration. ([#835])\\n\\n### packit-service\\n\\n- In job definition for packit-service you can use `epel-all` alias as well. ([#835])\\n\\n[#824]: https://github.com/packit-service/packit/pull/824\\n[#830]: https://github.com/packit-service/packit/pull/830\\n[#835]: https://github.com/packit-service/packit/pull/835\\n\\n## Week 22 (May 25th - May 29th)\\n\\n### packit\\n\\n- [The problem with kerberos initialization](https://github.com/packit-service/packit/issues/837)\\n was fixed. ([#838])\\n- We released a new version of the packit package. ([release 0.11.0])\\n- We have been also working on some smaller issues and preparation steps for our future work.\\n ([#841], [#843], [#846], [#847])\\n\\n[#838]: https://github.com/packit-service/packit/pull/838\\n[#841]: https://github.com/packit-service/packit/pull/841\\n[#843]: https://github.com/packit-service/packit/pull/843\\n[#846]: https://github.com/packit-service/packit/pull/846\\n[#847]: https://github.com/packit-service/packit/pull/847\\n[release 0.11.0]: https://github.com/packit-service/packit/releases/tag/0.11.0\\n\\n### packit-service\\n\\n- [Jirka] implemented creating a new bug in Bugzilla for CentOS Stream pull-requests ([#627]).\\n This will be triggered when the label \\"accepted\\" is added to a PR in the (near) future.\\n- You will be able to use aliases also for koji builds. ([packit:#839], [#632])\\n- [Laura] fixed [a problem](https://github.com/packit-service/packit-service/issues/535)\\n with missing builds when triggering Packit Service with `/packit test`.\\n Now, we trigger the build first if there are no builds for the pull-request yet. ([#631])\\n\\n[jirka]: https://github.com/jpopelka\\n[laura]: https://github.com/lbarcziova\\n[#627]: https://github.com/packit-service/packit-service/pull/627\\n[packit:#839]: https://github.com/packit-service/packit/pull/839\\n[#632]: https://github.com/packit-service/packit-service/pull/632\\n[#631]: https://github.com/packit-service/packit-service/pull/631\\n\\n## Week 23 (June 1st - June 5th)\\n\\nHello everyone, during this week we didn\'t manage to implement any significant new features - most of the work happened under the hood.\\n\\n### packit\\n\\n- We have fixed a formatting issue when packit prints installation instructions for using builds from a copr repo (by [@lachmanfrantisek](https://github.com/lachmanfrantisek), [#852](https://github.com/packit-service/packit/pulls/852)).\\n- You are able to set up builds when you push to a branch, we have set this up for master branch of packit, feel free to get inspired (by [@lachmanfrantisek](https://github.com/lachmanfrantisek), [#851](https://github.com/packit-service/packit/pulls/851)).\\n\\n### packit-as-a-service\\n\\n- We have run into multiple problems when you set up jobs for PRs and branch pushes - there were multiple fixes for this, packit-service wasn\'t able to work well with the fact that there are multiple jobs defined for the same job type - e.g. build.\\n\\n## Week 24 (June 8th - June 11th)\\n\\n### packit\\n\\n- [Tomas](https://github.com/TomasTomecek) re-implemented overriding of package config per job. This will enable overriding configuration for builds and releases once the corresponding changes are merged in Packit-as-a-Service. ([#858](https://github.com/packit-service/packit/pull/858), [#859](https://github.com/packit-service/packit/pull/859)).\\n\\n### packit-as-a-service\\n\\n- We are now parsing events from Koji about the progress of the builds and report them (by [Franta](https://github.com/lachmanfrantisek/), [#657](https://github.com/packit-service/packit-service/pull/657)).\\n- We are now able to listen to Gitlab hooks and parse the (comment & push) events (by [Shreyas](https://github.com/shreyaspapi), [#629](https://github.com/packit-service/packit-service/pull/629), [#671](https://github.com/packit-service/packit-service/pull/671)).\\n- Log pages have been restructured by linking SRPM build logs instead of including them (by [Hunor](https://github.com/csomh), [#641](https://github.com/packit-service/packit-service/pull/641)).\\n\\n## Week 25 (June 15th - June 19th)\\n\\n### packit\\n\\n- Packit logs more information for RebaseHelper errors (by [@csomh](https://github.com/csomh), [#865](https://github.com/packit-service/packit/pull/865)).\\n\\n### packit-as-a-service\\n\\n- Obtaining builds via packit [API endpoint](https://prod.packit.dev/api/copr-builds) is now significantly quicker (by [@IceWreck](https://github.com/IceWreck), [#674](https://github.com/packit-service/packit-service/pull/674)).\\n- We now have an API endpoint for obtaining results from testing farm (by [@IceWreck](https://github.com/IceWreck), [#678](https://github.com/packit-service/packit-service/pull/678)).\\n- We finished the implementation of the trigger to create bugs in Bugzilla. Therefore packit is now able to create bugzilla for accepted PR\'s in CentOS (by [@jpopelka](https://github.com/jpopelka), [#662](https://github.com/packit-service/packit-service/pull/662)).\\n\\n## Week 26 (June 22th - June 26th)\\n\\n### packit\\n\\n- packit now supports using custom repositories and packages when building in Copr and has options to preserve the project and to list it in on the Copr home page [@lachmanfrantisek](https://github.com/lachmanfrantisek), [#872](https://github.com/packit-service/packit/pull/872).\\n- Custom commands defined by user in packit config now are run in the shell, no more `bash -c` required (by [@TomasTomecek](https://github.com/TomasTomecek), [#871](https://github.com/packit-service/packit/pull/871)).\\n- packit now includes pull request ID in version of rpm. (by [@sturivny](https://github.com/sturivny) and [@TomasTomecek](https://github.com/TomasTomecek), [#870](https://github.com/packit-service/packit/pull/870)).\\n\\n### packit-as-a-service\\n\\n- We added support for copr builds in gitlab (by [@shreyaspapi](https://github.com/shreyaspapi), [#683](https://github.com/packit-service/packit-service/pull/683)).\\n- packit-service utilizes the new options introduced in packit (by [@lachmanfrantisek](https://github.com/lachmanfrantisek), [#694](https://github.com/packit-service/packit-service/pull/694)).\\n\\n## Week 27 (June 29th - July 3rd)\\n\\n### packit\\n\\n- We introduced a new command `packit validate-config` which validates the contect of a package configuration file in your project\\n (contributed by [@TomasJani](https://github.com/TomasJani), [#826](https://github.com/packit-service/packit/pull/826)).\\n\\n### packit-as-a-service\\n\\n- You are now able to override configuration for builds, releases and other jobs (by [@TomasTomecek](https://github.com/TomasTomecek), [#676](https://github.com/packit-service/packit-service/pull/676)).\\n Read more about this feature [here](/docs/configuration/#overriding-global-parameters).\\n\\n## Week 28 (July 6th - July 10th)\\n\\n### packit\\n\\n- Command `validate-config` works properly now and does not produce odd error messages, by [@TomasTomecek](https://github.com/TomasTomecek) and [@csomh](https://github.com/csomh), [#894](https://github.com/packit-service/packit/pull/894) and [#895](https://github.com/packit-service/packit/pull/895)\\n- You will now properly see git-describe metadata in the `%release` field in spec file when using `srpm` command, by [@TomasTomecek](https://github.com/TomasTomecek), [#894](https://github.com/packit-service/packit/pull/894)\\n- git-log is being used to get a list of commits between HEAD and latest tag to pick up commit messages and add those to %changelog, by [@TomasTomecek](https://github.com/TomasTomecek), [#889](https://github.com/packit-service/packit/pull/889)\\n- packit is now able to load metadata from commits of a source-git repo and utilize them when creating patch files, by [@lachmanfrantisek](https://github.com/lachmanfrantisek), [#875](https://github.com/packit-service/packit/pull/875)\\n\\n### packit-as-a-service\\n\\n- We now have a new API endpoint: [`/api/projects/`](https://prod.packit.dev/api/projects), by [@IceWreck](https://github.com/IceWreck), [#716](https://github.com/packit-service/packit-service/pull/716)\\n- Over the last few weeks, [@lbarcziova](https://github.com/lbarcziova) was very busy with refactoring how jobs and tasks are being executed in packit-service. This work is now complete which allows us to scale the deployment up while giving us better introspection in what\'s happening inside, by [@lbarcziova](https://github.com/lbarcziova), [#704](https://github.com/packit-service/packit-service/pull/704)\\n\\n## Week 29 (July 13th - July 17th)\\n\\n![Tatranska Lomnica](img/tatranska-lomnica-dhodovsk.jpg) Copyright (c) Dominika Hodovska. This work is licensed under a [Creative Commons Attribution 4.0 International License](http://creativecommons.org/licenses/by/4.0/).\\n\\n## Week 30 (July 20th - July 24th)\\n\\n- [Anchit] added [a few new API endpoints] to Packit-as-a-Service to retrieve\\n project information. This is used in the Dashboard, to provide [an overview\\n of the projects] served by Packit.\\n\\n[anchit]: https://github.com/IceWreck\\n[a few new api endpoints]: https://github.com/packit-service/packit-service/pull/746\\n[an overview of the projects]: https://dashboard.packit.dev/projects\\n\\n## Week 31 (July 27th - July 31st)\\n\\n- [Jano] did a lot of work on our deployment. The installation of all our dependencies is much simpler now.\\n ([packit-service#747](https://github.com/packit-service/packit-service/pull/747),\\n [packit-service#753](https://github.com/packit-service/packit-service/pull/753),\\n [packit-service#756](https://github.com/packit-service/packit-service/pull/756),\\n [packit-service#757](https://github.com/packit-service/packit-service/pull/757),\\n [packit#919](https://github.com/packit-service/packit/pull/919)),\\n- Packit now puts a link to our documentation in a pull request status when a contributor is not allowed to build the PR, thanks to [Tom\xe1\u0161].\\n ([packit-service#758](https://github.com/packit-service/packit-service/pull/758))\\n\\n[jano]: https://github.com/sakalosj\\n[tom\xe1\u0161]: https://github.com/TomasTomecek\\n\\n## Week 32 (August 3rd - August 7th) and 33 (August 10th - August 13th)\\n\\n- We renamed our GitHub organisation to `packit`.\\n That user had been inactive for a long time and [Hunor]\'s request was successful.\\n- The Copr project settings are now changed only if needed. If we can\'t edit the settings,\\n we ask for the admin access to the Copr project and the service shows you a table with\\n the changes if you want to do the edit manually.\\n ([packit#921](https://github.com/packit/packit/pull/921),\\n [packit-service#764](https://github.com/packit/packit-service/pull/764))\\n- [Matej] fixed an old bug with the custom command for creating archives.\\n The archive was not found when building SRPM because of the incorrect processing\\n of the paths from the command output.\\n ([packit#923](https://github.com/packit/packit/pull/923))\\n\\n[hunor]: https://github.com/csomh\\n[matej]: https://github.com/mfocko\\n\\n## Week 34 (August 17th - August 20th)\\n\\n- [Tomas] tought packit how to merge related commits, which were previously created\\n by git-am applying of a multiple commit patch. ([packit#933](https://github.com/packit/packit/pull/933))\\n- [Anchit] added new `/api/srpm-builds/` endpoint.\\n- Service now requests \'builder\' permission for custom projects if needed.\\n- [Franta] fixed a problem with only one job executed executed for 2 build definitions for the same trigger.\\n\\n[anchit]: https://github.com/IceWreck\\n[franta]: https://github.com/lachmanfrantisek\\n[tomas]: https://github.com/TomasTomecek\\n\\n## Week 35 (August 24th - August 28th)\\n\\n- [Tomas] improved logging of the Packit actions\' output. ([packit#950](https://github.com/packit/packit/pull/950))\\n- [Anchit] fixed and enhanced the `/api/srpm-builds` endpoint.\\n ([packit-service#788](https://github.com/packit/packit-service/pull/788))\\n\\n[tomas]: https://github.com/TomasTomecek\\n[anchit]: https://github.com/IceWreck\\n\\n## Week 36 (August 31th - September 4th)\\n\\n- We store the submission time of SRPM builds now ([packit-service#795](https://github.com/packit/packit-service/pull/795) by [Anchit]).\\n- [Shreyas] improved implementation of the build status reporting ([packit-service#740](https://github.com/packit/packit-service/pull/740)).\\n- [Anchit] enhanced the `/koji-builds` endpoint to be more consistent with `/copr-builds` endpoint ([packit-service#791](https://github.com/packit/packit-service/pull/791)).\\n\\n[anchit]: https://github.com/IceWreck\\n[shreyas]: https://github.com/shreyaspapi\\n\\n## Week 37 (September 7th - September 11th)\\n\\n- Stage now uses [Tokman](https://github.com/packit/tokman) to get access tokens for GitHub, which should resolve race condition when running parallel jobs\\n (Tokman by [Hunor], ogr integration by [Matej]).\\n- [Franta] has addressed problems with Testing-Farm cluster with custom response on PRs that links to more information ([pinned info](https://github.com/packit/packit-service/issues/803), [packit-service#798](https://github.com/packit/packit-service/pull/798)).\\n\\n[hunor]: https://github.com/csomh\\n[matej]: https://github.com/mfocko\\n[franta]: https://github.com/lachmanfrantisek\\n\\n## Week 38 (September 14th - September 18th)\\n\\n- The combination of the source-git patches with existing patches now works well\\n ([packit#963](https://github.com/packit/packit/pull/963)).\\n- Service now mostly supports also GitLab as you can see\\n [here](https://gitlab.com/packit-service/hello-world/-/merge_requests/10)\\n or [here](https://gitlab.com/packit-service/src/drpm/-/merge_requests/2).\\n A lot of small issues were fixed in the last week\\n ([packit-service#806](https://github.com/packit/packit-service/pull/806),\\n [packit-service#812](https://github.com/packit/packit-service/pull/812),\\n [packit-service#814](https://github.com/packit/packit-service/pull/814),\\n [packit-service#815](https://github.com/packit/packit-service/pull/815),\\n [packit-service#816](https://github.com/packit/packit-service/pull/816)\\n ).\\n- Created Copr projects are now prefixed with the hostname\\n for non-GitHub services and also support multipart namespaces\\n ([packit-service#819](https://github.com/packit/packit-service/pull/819)).\\n- [Laura] fixed two testing-farm related issues\\n ([packit-service#808](https://github.com/packit/packit-service/pull/808),\\n [packit-service#809](https://github.com/packit/packit-service/pull/809)).\\n You can now use `test` job also on Pagure and GitLab thanks to that.\\n\\n[laura]: https://github.com/lbarcziova\\n\\n## Week 39 (September 21st - September 25th)\\n\\n- Packit-service can be configured to work with private namespaces. This is plumbing work which we need right now for CentOS Stream. We are not planning to enable this for GitHub - packit-service will still work only for public repositories, private ones are ignored. [packit-service#831](https://github.com/packit/packit-service/pull/831)\\n- If git tag contains more information than just version (e.g. `pkg_name-v1.2.3`), it is possible to use upstream_tag_template to extract version from the tag, which will be used in a subsequent task. [doc](https://packit.dev/docs/configuration/#upstream_tag_template) [packit#959](https://github.com/packit/packit/pull/959)\\n- Added support for globbing pattern in upstream_ref. [doc](https://packit.dev/docs/configuration/#upstream_ref) [packit#960](https://github.com/packit/packit/pull/960)\\n- Packit `--remote` is global option now and available for all commands. Because of this `sync-from-downstream --remote` was renamed to `--remote-to-push`. Remote can now be specified in the user\'s config (via upstream_git_remote parameter). [packit#977](https://github.com/packit/packit/pull/977)\\n\\nFollowing bugs were fixed:\\n\\n- Packit dropping leading zeros in version. [packit#814](https://github.com/packit/packit/pull/814)\\n- Packit CLI issue caused by picking incorrect copr project name. [packit#971](https://github.com/packit/packit/pull/971)\\n\\n## Week 40 (September 28th - October 2nd)\\n\\n- Packit-service is now explicitly checking if requested copr-build targets exist and if not, the user is informed about it. [packit-service#835](https://github.com/packit/packit-service/pull/835)\\n- We have improved the way how packit updates `%setup` line in a spec file - you are now able to set content of `-n` option via archive_root_dir_template config option, it defaults to `{upstream-pkg-name}`. [doc](https://github.com/packit/packit.dev/pull/167) [packit#834](https://github.com/packit/packit-service/pull/834)\\n- Packit is able to generate a patch file with format-patch without leading a/ and b/ in the patch diff. Required for patches in dist-git which are applied with -p0.\\n- Contribution guidelines were updated, now we have one shared [link](https://github.com/packit/contributing).\\n\\n## Week 41 (October 5th - October 9th)\\n\\n- [franta] made triggering of jobs more reliable and in correct situations ([packit-service#837](https://github.com/packit/packit-service/pull/837))\\n\\n[franta]: https://github.com/lachmanfrantisek\\n\\n## Week 42 (October 12th - October 16th)\\n\\nNothing significant happened during this week. The only change was that Hunor\\n[resolved](https://github.com/packit/packit-service/pull/850) a problem when sentry client library ([the alert service](https://sentry.io/) we use) caused errors in stage\\nenvironment and hence the problem didn\'t make it to production.\\n\\nWe have also released a new version of packit: [0.18](https://github.com/packit/packit/releases/tag/0.18.0).\\n\\n## Week 43 (October 19th - October 24th)\\n\\nWe finally had a week with plenty updates!\\n\\n- We found out the hard way that one cannot build in [Fedora koji](https://koji.fedoraproject.org/koji/) directly\\n from SRPM unless it\'s a scratch build. The discussion with Fedora rel-eng is\\n happening at [pagure.io/releng/issue/9801](https://pagure.io/releng/issue/9801) and in the meantime, all koji builds\\n will be halted on our side since we know they cannot succeed. Do `scratch: true` for koji builds before this gets resolved.\\n- Packit creates a symlink for a generated archive at the root of the project.\\n So far it only did it from a relative path and now absolute paths are\\n supported as well. This is useful when your specfile is placed in a\\n subdirectory and rpmbuild can\'t find the archive.\\n- There is a new usability improvement to proposing a new downstream update. If\\n the PR is already created, packit won\'t create it again. You will no longer\\n receive duplicate downstream PRs in dist-git.\\n- When doing a new downstream update, packit doesn\'t sync %changelog since\\n those are usually out of sync between upstream and downstream. Packit creates\\n a new entry for the new release in the downstream. There is a new packit.yaml\\n configuration option `sync_changelog` which bypasses this behaviour and\\n copies the %changelog from upstream and overwrites the downstream changelog.\\n Please use this option only when your changelogs are in sync. [Documentation](https://packit.dev/docs/configuration/#sync_changelog)\\n\\n## Week 44 (October 26th - October 30th)\\n\\nNo user-facing changes in packit(-service) this week.\\n\\n## Week 45 (November 2nd - November 6th)\\n\\n- [Laura] implemented an option for packit to copy description from a release into\\n a changelog when running `propose-update`. Also the default message has been changed\\n to the list of commit messages from last release. ([packit#1004](https://github.com/packit/packit/pull/1004))\\n- [Jano] improved handling of build targets in packit. ([packit#986](https://github.com/packit/packit/pull/986))\\n- [Tomas] improved an experience of a contributor to source-git in case the contributor\\n doesn\'t follow git-am patches style that is used. ([packit#1000](https://github.com/packit/packit/pull/1000))\\n\\n## Week 46 (November 9th - November 13th)\\n\\n- [Tomas] improved the UX of logging in the CLI. ([packit#1014](https://github.com/packit/packit/pull/1014))\\n- [Jano] improved logic of acquiring current version in the CLI. ([packit#1013](https://github.com/packit/packit/pull/1013))\\n- We appreciate getting feedback from our users, if you could find some time to\\n do so, there is an [open issue](https://github.com/packit/packit-service/issues/859)\\n for it.\\n\\n## Week 47 (November 16th - November 20th)\\n\\n- ~~[Matej] fixed [an\\n issue](https://github.com/packit/packit-service/issues/774) with Packit CLI,\\n enabling recursive search for spec-files\\n ([packit#1005](https://github.com/packit/packit/pull/1005)).~~ It turned\\n out, this change made it very easy to [deplete GitHub API quota], so it was\\n reverted.\\n- [Laura] made Copr builds to be part of the default jobs. This will cause\\n build jobs to explicitly run, and display their own result flags in PRs,\\n next to the test results. We hope this to be a more friendly behaviour for\\n our new users ([packit#1024](https://github.com/packit/packit/pull/1024)).\\n\\n## Week 48 (November 23rd - November 27th)\\n\\n- [Laura] [fixed a bug], where Packit Service failed to trigger Copr builds\\n before triggering the tests in case triggering Copr builds was configured\\n for a different event.\\n- Thanks to [Matej], Packit Service will now [comment on commits] in case Copr\\n builds fail after a merge, in order to indicate the reason for the failure.\\n- Packit Service will soon stop commenting on PRs after the first successful\\n build. The installation instructions from these comments [were moved to the\\n result page] by [Laura], while [Matej] [added a warning] to inform users\\n about this upcoming change.\\n\\n[laura]: https://github.com/lbarcziova\\n[jano]: https://github.com/sakalosj\\n[tomas]: https://github.com/TomasTomecek\\n[matej]: https://github.com/mfocko\\n[deplete github api quota]: https://github.com/packit/packit-service/issues/876\\n[fixed a bug]: https://github.com/packit/packit-service/pull/888\\n[comment on commits]: https://github.com/packit/packit-service/pull/854\\n[added a warning]: https://github.com/packit/packit-service/pull/891\\n[were moved to the result page]: https://github.com/packit/packit-service/pull/877\\n\\n## Week 49 (November 30th - December 4th)\\n\\n- [Jano] fixed a bug in `sync_release` method of Packit API. ([packit#1043](https://github.com/packit/packit/pull/1043))\\n- [Jiri Konecny] contributed a fix for how Packit creates COPR urls. ([packit#1039](https://github.com/packit/packit/pull/1039))\\n- [Laura] updated instructions how to retrigger a job. ([packit-service#892](https://github.com/packit/packit-service/pull/892))\\n\\n[jano]: https://github.com/sakalosj\\n[jiri konecny]: https://github.com/jkonecny12\\n[laura]: https://github.com/lbarcziova\\n\\n## Week 50 (December 7th - December 11th)\\n\\n- [Tomas] implemented the `--upstream-url` option of `packit init` command. When specified,\\n `init` also sets up a source-git repository next to creating a configuration file.\\n\\n[tomas]: https://github.com/TomasTomecek\\n\\n## Week 51 (December 14th - December 18th)\\n\\n- Congratulations comments are now disabled by default, unless enabled in config.\\n- A bug, which prevented npm to be run during SRPM build, has been fixed. ([sandcastle#86](https://github.com/packit/sandcastle/pull/86))"},{"id":"/2019","metadata":{"permalink":"/posts/weekly/2019","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2019.md","source":"@site/weekly/2019.md","title":"2019","description":"Let\'s see what happened in Packit in 2019.","date":"2021-01-07T00:00:00.000Z","formattedDate":"January 7, 2021","tags":[{"label":"2019","permalink":"/posts/weekly/tags/2019"}],"readingTime":15.625,"hasTruncateMarker":true,"authors":[],"frontMatter":{"title":"2019","date":"2021-01-07T00:00:00.000Z","tags":["2019"]},"prevItem":{"title":"2020","permalink":"/posts/weekly/2020"}},"content":"Let\'s see what happened in Packit in 2019.\\n\\n\x3c!--truncate--\x3e\\n\\n# Initial version 0.1.0 of packit is out! (2019-03-08)\\n\\nWe would like to announce general availability of the initial version of\\npackit, titled \'0.1.0\'.\\n\\nSince this is our first release, we would like to ask you to be patient if you\\nencounter any issues. We work hard on packit\'s usability. If you feel like that\\npackit is doing something weird or if anything is unclear, don\'t hesitate and\\nreach out to us by creating [a new GitHub\\nissue](https://github.com/packit-service/packit/issues/new).\\n\\nThe initial release contains two commands:\\n\\n- `packit propose-update` \u2014 Opens a pull request in dist-git for the latest\\n upstream release of a selected repository.\\n- `packit watch-releases` \u2014 Watches events for all the upstream releases and\\n performs `propose-update` for those who use packit.\\n\\n## Installation\\n\\n```\\n$ dnf install --enablerepo=updates-testing packit\\n```\\n\\nOr\\n\\n```\\n$ pip3 install --user packitos\\n```\\n\\nOr (if you\'re brave)\\n\\n```\\n$ pip3 install --user git+https://github.com/packit-service/packit\\n```\\n\\n## Requirements\\n\\nPresent features have strict requirements on the upstream projects:\\n\\n- You need to have a packit config file present in the upstream repo.\\n\\n- You need to have spec file present in the upstream repo.\\n\\nThis workflow is suitable for people who are both upstream and downstream\\nmaintainers of the particular project. If you don\'t fit into that bucket, then\\npackit might not be ready for you, yet. Please wait till we land more\\n[source-git](/source-git/)\\nrelated functionality into packit.\\n\\n## `propose-update`\\n\\nI\'m going to demonstrate this functionality on\\n[ogr](https://github.com/packit-service/ogr.git), our library for git forges,\\nwhich powers packit.\\n\\nIt was recently approved for Fedora, so we can use packit to bring the initial\\nversion of ogr into Fedora Rawhide, 30 and 29.\\n\\n### Do we have everything?\\n\\nLet\'s see [guide](/docs/cli/propose-downstream) for\\nthe `propose-update` command on what we need:\\n\\n#### 0. The upstream repository with a valid upstream release.\\n\\n```\\n$ git remote -v\\norigin git@github.com:TomasTomecek/ogr.git (fetch)\\norigin git@github.com:TomasTomecek/ogr.git (push)\\nupstream https://github.com/packit-service/ogr.git (fetch)\\nupstream https://github.com/packit-service/ogr.git (push)\\n```\\n\\nYup.\\n\\n```\\n$ git tag --list\\n0.0.1\\n0.0.2\\n0.0.3\\n\\n$ git checkout 0.0.3\\nNote: checking out \'0.0.3\'.\\n```\\n\\nAnd the tag name is matching the version in a spec file:\\n\\n```\\n$ grep Version python-ogr.spec\\nVersion: 0.0.3\\n```\\n\\n#### 1. Packit config file placed in the upstream repository.\\n\\n```\\n$ ll .packit.yaml\\n-rw-rw-r--. 1 tt tt 177 Mar 1 17:44 .packit.yaml\\n```\\n\\nCheck.\\n\\n#### 2. Spec file present in the upstream repository.\\n\\n```\\n$ ll python-ogr.spec\\n-rw-rw-r--. 1 tt tt 1.3K Mar 1 17:43 python-ogr.spec\\n```\\n\\n:+1:\\n\\n#### 3. Pagure API tokens for Fedora Dist-git.\\n\\n```\\n$ env | grep TOKEN\\nPAGURE_USER_TOKEN=will\\nPAGURE_FORK_TOKEN=not\\nGITHUB_TOKEN=share, sorry\\n```\\n\\n#### 4. Valid Fedora Kerberos ticket.\\n\\n```\\n$ kinit ttomecek@FEDORAPROJECT.ORG\\nPassword for ttomecek@FEDORAPROJECT.ORG:\\n\\n$ klist\\nTicket cache: KEYRING:persistent:1024:krb_ccache_g0t1Ty3Ah\\nDefault principal: ttomecek@FEDORAPROJECT.ORG\\n\\nValid starting Expires Service principal\\n03/01/2019 18:12:25 03/02/2019 18:12:19 krbtgt/FEDORAPROJECT.ORG@FEDORAPROJECT.ORG\\n renew until 03/08/2019 18:12:19\\n```\\n\\nWe\'re all set!\\n\\n### Time to shine\\n\\nWe are still in the \\"ogr\\" upstream git repository.\\n\\n```\\n$ packit propose-update\\nINFO: Running \'anitya\' versioneer\\nERROR: Failed to determine latest upstream version!\\nCheck that the package exists on https://release-monitoring.org.\\nusing \\"master\\" dist-git branch\\nsyncing ./python-ogr.spec\\nINFO: Downloading file from URL https://files.pythonhosted.org/packages/source/o/ogr/ogr-0.0.3.tar.gz\\n100%[=============================>] 17.95K eta 00:00:00\\ndownloaded archive: /tmp/tmp2e65b0xt/ogr-0.0.3.tar.gz\\nuploading to the lookaside cache\\nPR created: https://src.fedoraproject.org/rpms/python-ogr/pull-request/1\\n```\\n\\nMind-blowing, isn\'t it? Now we have latest python-ogr in Fedora Rawhide by\\nrunning only a single command.\\n\\nI have also [added](https://release-monitoring.org/project/18832/) ogr into release-monitoring as packit suggests.\\n\\nOnce we are okay with the changes, we have to [merge the pull\\nrequest](https://src.fedoraproject.org/rpms/python-ogr/pull-request/1). That\'s\\nour responsibility, as maintainers.\\n\\n### Building in koji\\n\\nTime to build the package (packit doesn\'t support building in koji, yet)\\n\\n```\\n$ fedpkg clone python-ogr\\nCloning into \'python-ogr\'...\\nremote: Counting objects: 8, done.\\nremote: Compressing objects: 100% (5/5), done.\\nremote: Total 8 (delta 0), reused 5 (delta 0)\\nReceiving objects: 100% (8/8), done.\\n\\n$ cd python-ogr\\n\\n$ git log\\ncommit c298df5e540ba1d010366e102c1c75d4f5b0b0cc (HEAD -> master, origin/master, origin/HEAD)\\nAuthor: Tomas Tomecek \\nDate: Fri Mar 1 18:15:00 2019 +0100\\n\\n [packit] 0.0.3 upstream release\\n\\n more info\\n\\n Signed-off-by: Tomas Tomecek \\n\\ncommit 7d5ab1471ca0ee2a6c0254410b83beaa83b80f0b\\nAuthor: Gwyn Ciesla \\nDate: Fri Mar 1 15:18:34 2019 +0000\\n\\n Added the README\\n```\\n\\nYup, that\'s our commit. `more info` was added there by accident, this is\\nalready fixed in packit.\\n\\n```\\n$ fedpkg build\\nBuilding python-ogr-0.0.3-1.fc31 for rawhide\\nCreated task: 33125435\\nTask info: https://koji.fedoraproject.org/koji/taskinfo?taskID=33125435\\nWatching tasks (this may be safely interrupted)...\\n33125435 build (rawhide, /rpms/python-ogr.git:c298df5e540ba1d010366e102c1c75d4f5b0b0cc): free\\n33125435 build (rawhide, /rpms/python-ogr.git:c298df5e540ba1d010366e102c1c75d4f5b0b0cc): free -> open (buildvm-14.phx2.fedoraproject.org)\\n 33125451 buildArch (python-ogr-0.0.3-1.fc31.src.rpm, noarch): open (buildvm-14.phx2.fedoraproject.org)\\n 33125436 buildSRPMFromSCM (/rpms/python-ogr.git:c298df5e540ba1d010366e102c1c75d4f5b0b0cc): closed\\n33125435 build (rawhide, /rpms/python-ogr.git:c298df5e540ba1d010366e102c1c75d4f5b0b0cc): open (buildvm-14.phx2.fedoraproject.org) -> closed\\n 0 free 1 open 2 done 0 failed\\n 33125464 tagBuild (noarch): closed\\n 33125451 buildArch (python-ogr-0.0.3-1.fc31.src.rpm, noarch): open (buildvm-14.phx2.fedoraproject.org) -> closed\\n 0 free 0 open 4 done 0 failed\\n\\n33125435 build (rawhide, /rpms/python-ogr.git:c298df5e540ba1d010366e102c1c75d4f5b0b0cc) completed successfully\\n```\\n\\nThat was rough, can\'t wait to do this with packit.\\n\\nLet\'s do Fedora 30 now:\\n\\n```\\n$ packit propose-update --dist-git-branch f30\\nINFO: Running \'anitya\' versioneer\\nusing \\"f30\\" dist-git branch\\nsyncing ./python-ogr.spec\\nINFO: Downloading file from URL https://files.pythonhosted.org/packages/source/o/ogr/ogr-0.0.3.tar.gz\\n100%[=============================>] 17.95K eta 00:00:00\\ndownloaded archive: /tmp/tmpl5xxq22x/ogr-0.0.3.tar.gz\\nuploading to the lookaside cache\\nPR created: https://src.fedoraproject.org/rpms/python-ogr/pull-request/3\\n```\\n\\nAnd so on...\\n\\n## Conclusion\\n\\nAs you can see, packit is useful for us right away.\\n\\nWe\'ll be delighted if you try it out and let us know what you think.\\n\\n# Packit 0.2.0 is here! (2019-03-19)\\n\\nOur sprint nears an end which means we have released [a new version of packit -\\n0.2.0](https://github.com/packit-service/packit/releases/tag/0.2.0)! You can\\nexpect a new release after every sprint (i.e. every 2 weeks).\\n\\nThe 0.2.0 version has a bunch of new features and improvements: you can find\\na complete list [in the\\nchangelog](https://github.com/packit-service/packit/blob/master/CHANGELOG.md#020).\\nWe also have a [detailed\\ndocumentation](https://github.com/packit-service/packit#workflows-covered-by-packit)\\nfor all the workflows packit covers.\\n\\nLet\'s get through what\'s new:\\n\\n1. We have decided to rename two keys in our config file so they are more\\n descriptive. Old names still work but they are deprecated:\\n - `package_name` \u2192 `downstream_package_name`\\n - `upstream_name` \u2192 `upstream_project_name`\\n2. You don\'t need to touch dist-git at all when getting your new upstream\\n release into Fedora, you can stay in your upstream repository and just fire\\n off a bunch of packit calls:\\n - `packit propose-update` to create a pull request in Fedora dist-git with\\n the selected upstream release\\n - `packit build` to build the new upstream release once the pull request is\\n merged\\n - and finally, `packit create-update` creates a new bodhi update (if you\\n chose a stable Fedora release)\\n3. Packit now has a `srpm` command which creates an SRPM out of the local\\n content of your upstream repository.\\n4. You can now use packit to sync files from your dist-git repo back into\\n upstream (mainly to keep spec files in sync). `sync-from-downstream` is the\\n command.\\n5. Command `propose-update` received numerous improvements:\\n - You can pick upstream version to use.\\n - Packit will NOT check out the git ref with the upstream release if you\\n specify `--local-content`\\n - It\'s possible to force packit to execute `fedpkg new-sources` using\\n `--force-new-sources` and bypass the caching mechanism.\\n\\n## Installation\\n\\nPlease make sure you are installing `0.2.0`:\\n\\n```\\n$ dnf install --enablerepo=updates-testing packit\\n```\\n\\nOr\\n\\n```\\n$ pip3 install --user packitos\\n```\\n\\nYou can also install packit from master branch, if you are brave enough:\\n\\n```\\n$ pip3 install --user git+https://github.com/packit-service/packit\\n```\\n\\n## How are we using packit?\\n\\nI\'d like to show you how we used packit to bring a new upstream\\nrelease of ogr into Fedora, a library which packit is using.\\n\\nOnce we have performed an upstream release of ogr, we can propose an update in\\ndist-git:\\n\\n```\\n$ git clone https://github.com/packit-service/ogr && cd ogr/\\n\\n$ packit propose-update\\nINFO: Running \'anitya\' versioneer\\nVersion in upstream registries is \'0.0.3\'.\\nVersion in spec file is \'0.0.3\'.\\nPicking version of the latest release from the upstream registry over spec file.\\nChecking out upstream version 0.0.3\\nUsing \'master\' dist-git branch\\nCloning repo: https://src.fedoraproject.org/rpms/python-ogr.git -> /tmp/tmpb9xlvdhj\\nSyncing /home/tt/g/user-cont/ogr/python-ogr.spec\\nArchive ogr-0.0.3.tar.gz found in lookaside cache (skipping upload).\\nERROR Cmd(\'git\') failed due to: exit code(1)\\n cmdline: git commit -s -m [packit] 0.0.3 upstream release -m Upstream tag: 0.0.3\\nUpstream commit: 059d21080a7849acff4626b6e0ec61830d537ac4\\n\\n stdout: \'On branch 0.0.3-master-update\\nnothing to commit, working tree clean\'\\n```\\n\\nWhoops, it seems that I have messed up, I forgot to bump the spec file in the\\nupstream repo when doing the release. I will bump it locally and utilize\\n`--local-content` argument:\\n\\n```\\n$ rpmdev-bumpspec -n 0.1.0 -c \'New upstream release: 0.1.0\' *.spec\\n\\n$ packit propose-update --local-content\\nINFO: Running \'anitya\' versioneer\\nVersion in upstream registries is \'0.0.3\'.\\nVersion in spec file is \'0.1.0\'.\\nPicking version of the latest release from the upstream registry over spec file.\\nUsing \'master\' dist-git branch\\nCloning repo: https://src.fedoraproject.org/rpms/python-ogr.git -> /tmp/tmpd9j4se27\\nSyncing /home/tt/g/user-cont/ogr/python-ogr.spec\\nArchive ogr-0.1.0.tar.gz found in lookaside cache (skipping upload).\\nINFO: Downloading file from URL https://files.pythonhosted.org/packages/source/o/ogr/ogr-0.1.0.tar.gz\\n100%[=============================>] 20.25K eta 00:00:00\\nDownloaded archive: \'/tmp/tmpd9j4se27/ogr-0.1.0.tar.gz\'\\nAbout to upload to lookaside cache\\nwon\'t be doing kinit, no credentials provided\\nPR created: https://src.fedoraproject.org/rpms/python-ogr/pull-request/6\\n```\\n\\nOnce the scratch build is done and tests passed we merged and built it:\\n\\n```\\n$ packit build\\nUsing \'master\' dist-git branch\\nCloning repo: https://src.fedoraproject.org/rpms/python-ogr.git -> /tmp/tmprp3cmdjy\\nBuilding python-ogr-0.1.0-1.fc31 for rawhide\\nCreated task: 33616980\\nTask info: https://koji.fedoraproject.org/koji/taskinfo?taskID=33616980\\n```\\n\\nWe have done the same for F30 and F29.\\n\\nThe previous commands were run in the directory of the upstream repository. Packit also accepts path to your upstream clone, or even URL. So let\'s create a bodhi update for python-ogr by specifying the upstream repo URL:\\n\\n```\\n$ cd $HOME\\n\\n$ packit create-update --dist-git-branch f29 https://github.com/packit-service/ogr\\nCloning repo: https://github.com/packit-service/ogr -> /tmp/tmpdkdadmn_\\nKoji builds for package python-ogr and koji tag f29-updates-candidate:\\n - python-ogr-0.1.0-1.fc29\\nCloning repo: https://src.fedoraproject.org/rpms/python-ogr.git -> /tmp/tmpn1809ec9\\nBodhi update FEDORA-2019-78948e62d2:\\n- https://bodhi.fedoraproject.org/updates/FEDORA-2019-78948e62d2\\n- stable_karma: 3\\n- unstable_karma: -3\\n- notes:\\nNew upstream release: 0.1.0\\n```\\n\\nAnd that\'s it, no need to access dist-git any more.\\n\\nPlease give packit a try and let us know what you think.\\n\\n# Packit 0.3.0 (2019-04-11)\\n\\nIn the previous post we promised to\\nprovide a new release every 2 weeks and we are already breaking this promise as\\nit\'s been 3 weeks since then. We decided to wait with the release to merge\\nseveral pull requests related to source-git support.\\n\\nNow the good news. You can find a complete list of new features and\\nimprovements of version\\n[0.3.0](https://github.com/packit-service/packit/releases/tag/0.3.0) in the\\n[changelog](https://github.com/packit-service/packit/blob/master/CHANGELOG.md#030).\\n\\n## Features\\n\\n- You can now specify your own hooks or actions to replace default packit\\n behaviour. (More information can be found [in the\\n documentation](/docs/configuration/actions/)).\\n- Packit supports pagure.io-based upstream projects.\\n- Commands `propose-update` and `sync-from-downstream` supports [copying\\n directories](/docs/configuration/#minimal-sample-config).\\n- A new command `status`! It displays useful upstream/downstream info.\\n- Packit now supports [Source-git](/source-git/). The\\n functionality is not available, yet - we will add a CLI interface for it in\\n the next release.\\n- You can now have a config file for packit in your home directory(`~/.config/packit.yaml`).\\n- Packit installed from an RPM now has manpages.\\n\\n### `packit status` example\\n\\n```bash\\n$ packit status\\nCloning repo: https://src.fedoraproject.org/rpms/packit.git -> /tmp/tmp84we_6n8\\nDownstream PRs: No open PRs.\\nf29: 0.2.0\\nf30: 0.2.0\\nmaster: 0.2.0\\n```\\n\\n# Packit 0.4.0 & 0.4.1 (2019-05-18)\\n\\nIt\'s been over a month since we released packit \\"0.3.0\\". Here comes packit 0.4.0 (and patch release 0.4.1) and as always they bring a lot of new features and improvements.\\n\\nYou can find a complete list in the\\n[changelog](https://github.com/packit-service/packit/blob/master/CHANGELOG.md#040).\\n\\n## Packit as a service\\n\\n- We have Packit as a service running in OpenShift and also a GitHub App, which uses it.\\n Unfortunately it\'s still not in the [Marketplace](https://github.com/marketplace),\\n so [we](https://github.com/packit-service) have been the only one using it so far.\\n The service/app submits builds in [copr](https://copr.fedorainfracloud.org/coprs/packit/) and\\n once they\'re done it adds a GitHub status and comment with instructions how to install the builds.\\n The service is now configurable via [jobs](/docs/configuration/#packit-service-jobs) defined\\n in configuration file.\\n- Packit is now able to check GPG signatures of the upstream commits against configured fingerprints.\\n\\n## CLI\\n\\n- `srpm` command now works also with [Source-git](/source-git/).\\n- `status` command now access remote APIs asynchronously in parallel, which should speed up\\n the execution.\\n- CLI has new `--dry-run` option to not perform any remote changes (pull requests or comments).\\n- Fedmsg parsing has been unified into a single `listen-to-fedmsg` command.\\n\\n# Packit 0.4.2 (2019-06-26)\\n\\nAnother relase after a month since [0.4.1](https://packit.dev/posts/packit-041/), this time mostly with bug fixes.\\n\\nWe\'ve been busy polishing our [GitHub App](https://packit.dev/packit-as-a-service/) recently, therefore we had no resources for new features.\\n\\nSee [CHANGELOG](https://github.com/packit-service/packit/blob/master/CHANGELOG.md#042) for more details.\\n\\n# September 2020\\n\\n## Week 36 (August 31th - September 4th)\\n\\n- We store the submission time of SRPM builds now ([packit-service#795](https://github.com/packit/packit-service/pull/795) by [Anchit]).\\n- [Shreyas] improved implementation of the build status reporting ([packit-service#740](https://github.com/packit/packit-service/pull/740)).\\n- [Anchit] enhanced the `/koji-builds` endpoint to be more consistent with `/copr-builds` endpoint ([packit-service#791](https://github.com/packit/packit-service/pull/791)).\\n\\n[anchit]: https://github.com/IceWreck\\n[shreyas]: https://github.com/shreyaspapi\\n\\n## Week 37 (September 7th - September 11th)\\n\\n- Stage now uses [Tokman](https://github.com/packit/tokman) to get access tokens for GitHub, which should resolve race condition when running parallel jobs\\n (Tokman by [Hunor], ogr integration by [Matej]).\\n- [Franta] has addressed problems with Testing-Farm cluster with custom response on PRs that links to more information ([pinned info](https://github.com/packit/packit-service/issues/803), [packit-service#798](https://github.com/packit/packit-service/pull/798)).\\n\\n[hunor]: https://github.com/csomh\\n[matej]: https://github.com/mfocko\\n[franta]: https://github.com/lachmanfrantisek\\n\\n## Week 38 (September 14th - September 18th)\\n\\n- The combination of the source-git patches with existing patches now works well\\n ([packit#963](https://github.com/packit/packit/pull/963)).\\n- Service now mostly supports also GitLab as you can see\\n [here](https://gitlab.com/packit-service/hello-world/-/merge_requests/10)\\n or [here](https://gitlab.com/packit-service/src/drpm/-/merge_requests/2).\\n A lot of small issues were fixed in the last week\\n ([packit-service#806](https://github.com/packit/packit-service/pull/806),\\n [packit-service#812](https://github.com/packit/packit-service/pull/812),\\n [packit-service#814](https://github.com/packit/packit-service/pull/814),\\n [packit-service#815](https://github.com/packit/packit-service/pull/815),\\n [packit-service#816](https://github.com/packit/packit-service/pull/816)\\n ).\\n- Created Copr projects are now prefixed with the hostname\\n for non-GitHub services and also support multipart namespaces\\n ([packit-service#819](https://github.com/packit/packit-service/pull/819)).\\n- [Laura] fixed two testing-farm related issues\\n ([packit-service#808](https://github.com/packit/packit-service/pull/808),\\n [packit-service#809](https://github.com/packit/packit-service/pull/809)).\\n You can now use `test` job also on Pagure and GitLab thanks to that.\\n\\n[laura]: https://github.com/lbarcziova\\n\\n## Week 39 (September 21st - September 25th)\\n\\n- Packit-service can be configured to work with private namespaces. This is plumbing work which we need right now for CentOS Stream. We are not planning to enable this for GitHub - packit-service will still work only for public repositories, private ones are ignored. [packit-service#831](https://github.com/packit/packit-service/pull/831)\\n- If git tag contains more information than just version (e.g. `pkg_name-v1.2.3`), it is possible to use upstream_tag_template to extract version from the tag, which will be used in a subsequent task. [doc](https://packit.dev/docs/configuration/#upstream_tag_template) [packit#959](https://github.com/packit/packit/pull/959)\\n- Added support for globbing pattern in upstream_ref. [doc](https://packit.dev/docs/configuration/#upstream_ref) [packit#960](https://github.com/packit/packit/pull/960)\\n- Packit `--remote` is global option now and available for all commands. Because of this `sync-from-downstream --remote` was renamed to `--remote-to-push`. Remote can now be specified in the user\'s config (via upstream_git_remote parameter). [packit#977](https://github.com/packit/packit/pull/977)\\n\\nFollowing bugs were fixed:\\n\\n- Packit dropping leading zeros in version. [packit#814](https://github.com/packit/packit/pull/814)\\n- Packit CLI issue caused by picking incorrect copr project name. [packit#971](https://github.com/packit/packit/pull/971)\\n\\n## Week 40 (September 28th - October 2nd)\\n\\n- Packit-service is now explicitly checking if requested copr-build targets exist and if not, the user is informed about it. [packit-service#835](https://github.com/packit/packit-service/pull/835)\\n- We have improved the way how packit updates `%setup` line in a spec file - you are now able to set content of `-n` option via archive_root_dir_template config option, it defaults to `{upstream-pkg-name}`. [doc](https://github.com/packit/packit.dev/pull/167) [packit#834](https://github.com/packit/packit-service/pull/834)\\n- Packit is able to generate a patch file with format-patch without leading a/ and b/ in the patch diff. Required for patches in dist-git which are applied with -p0.\\n- Contribution guidelines were updated, now we have one shared [link](https://github.com/packit/contributing).\\n\\n# Week 44-48 (November) 2019\\n\\nWith this blog post we\'d like to continue with the idea of openly communicating changes in Packit.\\nSince most of the developers use Packit as the [GitHub App](https://packit.dev/packit-as-a-service) (which uses code from [this repository - Packit Service](https://github.com/packit-service/packit-service)), this blog will be about changes in all the parts, i.e. the GitHub App, the Packit Service and Packit itself.\\n\\n## Continuous Deployment (CD)\\n\\nAt the moment the workflow is that one of us manually triggers production container image build at the end of a week.\\nThis image is then automatically deployed into our production instance of the service over a weekend (Sun/Mon night) so that everyone can start a week with all the amazing stuff we added the previous week.\\nIn case an issue makes it through our staging instance into production uncaught, we can easily rollback on Monday.\\nThe same person also writes down what\'s changed in Packit (service/app) since previous deployment.\\n\\n## Changes in production (since the end of November)\\n\\nPrevious post is almost half a year old so we won\'t list all the changes since then, but only since last deployment, i.e. since end of December.\\n\\n### Packit\\n\\nPrevious deployment was running [packit-0.7.1](https://pypi.org/project/packitos/0.7.1/).\\nWe haven\'t released a newer version since then, but in the service we install Packit from the Git repository (we have a separate `stable` git branch for our production deployment).\\nFrom the most visible changes, Packit now:\\n\\n- better handles Create-archive action\\n- is able to work in a repo with detached head\\n- logs output from subprocesses in realtime\\n- syncs config file and spec file by default in Propose-update action\\n- hadles patches with undecodable chars\\n\\n### Packit Service\\n\\nNow:\\n\\n- better reports Copr builds\\n - uses separate commit status for srpm build and every chroot\\n - clears test farm commit statuses when new build is triggered\\n - better handles failed Copr builds\\n- gracefully handles no config file in the repo\\n- better handles when no (copr build) targets are specified in config file\\n- better checks whitelist of users\\n- does not create duplicate tickets in our [notification repo](https://github.com/packit-service/notifications) when a new user install the app\\n\\nChanges not visible to end users:\\n\\n- using [Requre](https://github.com/packit-service/requre) for integration/E2E tests\\n- Fedora messaging consumer part of the service has been improved and moved to separate [repo/image](https://github.com/packit-service/packit-service-fedmsg)\\n- using FAS instead of Fedora Badges for checking whether a user is Fedora packager\\n- many improved logs\\n- many bugs squashed\\n- lot\'s of code refactored\\n\\n# December 2019\\n\\n## Week 49\\n\\n### ogr & packit\\n\\n- ogr-0.9.0 has been released greatly restructured. ([#291](https://github.com/packit-service/ogr/pull/291/files))\\n- `packit status` (CLI) now shows also latest Copr builds. ([#579](https://github.com/packit-service/packit/pull/579))\\n- Target aliases (currently `fedora-development`, `fedora-stable`, `fedora-all`) can now be used in the packit config file. ([#619](https://github.com/packit-service/packit/pull/619))\\n- When doing a new update in Fedora dist-git, packit now by default creates a new pull request instead of pushing directly to dist-git. ([#622](https://github.com/packit-service/packit/pull/622))\\n\\n### packit service\\n\\n- Does not set test checks when tests are not configured. ([#275](https://github.com/packit-service/packit-service/pull/275))\\n- Supports target aliases and dist-git branches aliases. ([#277](https://github.com/packit-service/packit-service/pull/277), [#285](https://github.com/packit-service/packit-service/pull/285))\\n- Nicely formats errors from OpenShift API. ([#283](https://github.com/packit-service/packit-service/pull/283))\\n- Runs Copr build when user adds a `/packit build` comment into a PR. ([#290](https://github.com/packit-service/packit-service/pull/290))\\n\\n## Week 50\\n\\n### packit\\n\\n- If there is no `upstream_package_name`/`downstream_package_name` given in `.packit.yaml`, they now default to the name of the GitHub repo. ([#624](https://github.com/packit-service/packit/pull/624))\\n- If no `jobs` are defined in `.packit.yaml` packit by default runs `build` job on `fedora-stable` targets and `propose_downstream` on `fedora-all` branches. ([#625](https://github.com/packit-service/packit/pull/625))\\n- `build` command has nicer output. ([#630](https://github.com/packit-service/packit/pull/630))\\n- Smaller fixes. ([#630](https://github.com/packit-service/packit/pull/630), [#636](https://github.com/packit-service/packit/pull/636))\\n\\n### packit service\\n\\n- Creates a new issue when `propose-update` fails. ([#300](https://github.com/packit-service/packit-service/pull/300))\\n- Better reports failed submitting of a Copr build. ([#301](https://github.com/packit-service/packit-service/pull/301))"}]}')}}]); \ No newline at end of file diff --git a/assets/js/e6722c50.cd124145.js b/assets/js/e6722c50.cd124145.js new file mode 100644 index 0000000000..a658ef0d84 --- /dev/null +++ b/assets/js/e6722c50.cd124145.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[94488],{38516:e=>{e.exports=JSON.parse('{"blogPosts":[{"id":"/2025/week-2","metadata":{"permalink":"/posts/weekly/2025/week-2","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2025/week-2.md","source":"@site/weekly/2025/week-2.md","title":"Week 2 in Packit","description":"Week 2 (January 7th \u2013 January 13th)","date":"2025-01-13T00:00:00.000Z","formattedDate":"January 13, 2025","tags":[{"label":"2025-January","permalink":"/posts/weekly/tags/2025-january"},{"label":"2025","permalink":"/posts/weekly/tags/2025"},{"label":"January","permalink":"/posts/weekly/tags/january"}],"readingTime":0.175,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 2 in Packit","date":"2025-01-13T00:00:00.000Z","authors":"flachman","tags":["2025-January","2025","January"]},"nextItem":{"title":"Week 1 in Packit","permalink":"/posts/weekly/2025/week-1"}},"content":"## Week 2 (January 7th \u2013 January 13th)\\n\\n- Fixed EVR regex used when parsing changelog entries in the _specfile_ library to not match email addresses with `-` in them. (contributed by [Dan \u010cerm\xe1k](https://github.com/dcermak), [specfile#445](https://github.com/packit/specfile/pull/445))"},{"id":"/2025/week-1","metadata":{"permalink":"/posts/weekly/2025/week-1","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2025/week-1.md","source":"@site/weekly/2025/week-1.md","title":"Week 1 in Packit","description":"Week 1 (January 2nd \u2013 January 6th)","date":"2025-01-06T00:00:00.000Z","formattedDate":"January 6, 2025","tags":[{"label":"2025-January","permalink":"/posts/weekly/tags/2025-january"},{"label":"2025","permalink":"/posts/weekly/tags/2025"},{"label":"January","permalink":"/posts/weekly/tags/january"}],"readingTime":0.105,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 1 in Packit","date":"2025-01-06T00:00:00.000Z","authors":"lbarczio","tags":["2025-January","2025","January"]},"prevItem":{"title":"Week 2 in Packit","permalink":"/posts/weekly/2025/week-2"},"nextItem":{"title":"Week 50 in Packit","permalink":"/posts/weekly/2024/week-50"}},"content":"## Week 1 (January 2nd \u2013 January 6th)\\n\\n- We have improved fallback commit status reporting via comments in GitLab. ([packit-service#2686](https://github.com/packit/packit-service/pull/2686))"},{"id":"/2024/week-50","metadata":{"permalink":"/posts/weekly/2024/week-50","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-50.md","source":"@site/weekly/2024/week-50.md","title":"Week 50 in Packit","description":"Week 50 (December 10th \u2013 December 16th)","date":"2024-12-16T00:00:00.000Z","formattedDate":"December 16, 2024","tags":[{"label":"2024-December","permalink":"/posts/weekly/tags/2024-december"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"December","permalink":"/posts/weekly/tags/december"}],"readingTime":0.69,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 50 in Packit","date":"2024-12-16T00:00:00.000Z","authors":"mfocko","tags":["2024-December","2024","December"]},"prevItem":{"title":"Week 1 in Packit","permalink":"/posts/weekly/2025/week-1"},"nextItem":{"title":"Week 49 in Packit","permalink":"/posts/weekly/2024/week-49"}},"content":"## Week 50 (December 10th \u2013 December 16th)\\n\\n- We have added a `--resultdir` option for building in mock via our CLI\\n (`packit build in-mock`).\\n ([packit#2475](https://github.com/packit/packit/pull/2475))\\n- For our [specfile](https://github.com/packit/specfile) users, there is a new\\n convenience method `Sections.get_or_create()` that allows you to manipulate\\n a section without checking if it exists first. If a section doesn\'t exist, it\\n will be appended to the end. For example, this will work properly even on\\n spec files without `%changelog`:\\n\\n ```\\n with spec.sections() as sections:\\n changelog = sections.get_or_create(\\"changelog\\")\\n changelog[:] = [\\"%autochangelog\\"]\\n ```\\n\\n ([specfile#441](https://github.com/packit/specfile/pull/441))\\n\\n- We have also switched our base images from _CentOS 9 Stream_ to _Fedora 41_ to\\n allow you using the features from the latest _rpm 4.20_.\\n ([deployment#622](https://github.com/packit/deployment/pull/622))\\n- We have unified status names for VM Image builds.\\n ([packit-service#2679](https://github.com/packit/packit-service/pull/2679))\\n- We have started building [our container images](https://quay.io/organization/packit)\\n for alternative architectures.\\n ([packit-service#2675](https://github.com/packit/packit-service/pull/2675))"},{"id":"/2024/week-49","metadata":{"permalink":"/posts/weekly/2024/week-49","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-49.md","source":"@site/weekly/2024/week-49.md","title":"Week 49 in Packit","description":"Week 49 (December 3rd \u2013 December 9th)","date":"2024-12-09T00:00:00.000Z","formattedDate":"December 9, 2024","tags":[{"label":"2024-December","permalink":"/posts/weekly/tags/2024-december"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"December","permalink":"/posts/weekly/tags/december"}],"readingTime":0.35,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 49 in Packit","date":"2024-12-09T00:00:00.000Z","authors":"flachman","tags":["2024-December","2024","December"]},"prevItem":{"title":"Week 50 in Packit","permalink":"/posts/weekly/2024/week-50"},"nextItem":{"title":"Week 48 in Packit","permalink":"/posts/weekly/2024/week-48"}},"content":"## Week 49 (December 3rd \u2013 December 9th)\\n\\n- It\'s finally here! The team is planning to release Packit 1.0.0! We want to take this opportunity to clean up long-time deprecated config options and a related code.\\n To not let you alone in this, you can expect a pull request with required changes in case you are affected.\\n More information about this change can be found on [a separate page](https://packit.dev/posts/packit_1_0_0_action_required)."},{"id":"/2024/week-48","metadata":{"permalink":"/posts/weekly/2024/week-48","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-48.md","source":"@site/weekly/2024/week-48.md","title":"Week 48 in Packit","description":"Week 48 (November 26th \u2013 December 2nd)","date":"2024-12-02T00:00:00.000Z","formattedDate":"December 2, 2024","tags":[{"label":"2024-November","permalink":"/posts/weekly/tags/2024-november"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"November","permalink":"/posts/weekly/tags/november"}],"readingTime":0.57,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 48 in Packit","date":"2024-12-02T00:00:00.000Z","authors":"mmassari","tags":["2024-November","2024","November"]},"prevItem":{"title":"Week 49 in Packit","permalink":"/posts/weekly/2024/week-49"},"nextItem":{"title":"Week 47 in Packit","permalink":"/posts/weekly/2024/week-47"}},"content":"## Week 48 (November 26th \u2013 December 2nd)\\n\\n- There is a new action/hook, `post-modifications`, that is executed after all modifications to the spec file are done and in case of syncing release after all remote sources are downloaded and before uploading to lookaside cache. You can use it for example to construct an additional source that depends on the primary source (that may not yet be available in other actions). ([packit#2474](https://github.com/packit/packit/pull/2474))\\n- We have fixed `/packit retest-failed` which was retriggering also non failed tests. ([packit-service#2665](https://github.com/packit/packit-service/pull/2665))\\n- Packit now includes dashboard links when reporting errors for Koji builds and Bodhi updates. ([packit-service#2663](https://github.com/packit/packit-service/pull/2663))\\n- We have improved Koji builds and Bodhi updates errors displaying. ([dashboard#497](https://github.com/packit/dashboard/pull/497))"},{"id":"/2024/week-47","metadata":{"permalink":"/posts/weekly/2024/week-47","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-47.md","source":"@site/weekly/2024/week-47.md","title":"Week 47 in Packit","description":"Week 47 (November 19th \u2013 November 25th)","date":"2024-11-25T00:00:00.000Z","formattedDate":"November 25, 2024","tags":[{"label":"2024-November","permalink":"/posts/weekly/tags/2024-november"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"November","permalink":"/posts/weekly/tags/november"}],"readingTime":0.205,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 47 in Packit","date":"2024-11-25T00:00:00.000Z","authors":"nforro","tags":["2024-November","2024","November"]},"prevItem":{"title":"Week 48 in Packit","permalink":"/posts/weekly/2024/week-48"},"nextItem":{"title":"Week 46 in Packit","permalink":"/posts/weekly/2024/week-46"}},"content":"## Week 47 (November 19th \u2013 November 25th)\\n\\n- Packit now uses the `fedora-distro-aliases` library to expand Fedora aliases.\\n This is Packit\'s original code being improved and properly maintained by the Copr team.\\n For further suggestions about aliases, use github.com/rpm-software-management/fedora-distro-aliases.\\n ([packit#2470](https://github.com/packit/packit/pull/2470))"},{"id":"/2024/week-46","metadata":{"permalink":"/posts/weekly/2024/week-46","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-46.md","source":"@site/weekly/2024/week-46.md","title":"Week 46 in Packit","description":"Week 46 (November 12th \u2013 November 18th)","date":"2024-11-18T00:00:00.000Z","formattedDate":"November 18, 2024","tags":[{"label":"2024-November","permalink":"/posts/weekly/tags/2024-november"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"November","permalink":"/posts/weekly/tags/november"}],"readingTime":0.67,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 46 in Packit","date":"2024-11-18T00:00:00.000Z","authors":"lbarczio","tags":["2024-November","2024","November"]},"prevItem":{"title":"Week 47 in Packit","permalink":"/posts/weekly/2024/week-47"},"nextItem":{"title":"Week 45 in Packit","permalink":"/posts/weekly/2024/week-45"}},"content":"## Week 46 (November 12th \u2013 November 18th)\\n\\n- The Packit configuration file now supports a top-level placeholder key, `_`, which is ignored when parsing the file.\\n This is useful for storing YAML anchors in complex config files, e.g.:\\n\\n```yaml\\n_:\\n base-test: &base-test\\n job: tests\\n fmf_path: .distro\\njobs:\\n - <<: *base-test\\n trigger: pull_request\\n manual_trigger: true\\n - <<: *internal-test\\n trigger: commit\\n use_internal_tf: true\\n```\\n\\n([packit#2378](https://github.com/packit/packit/pull/2378))\\n\\n- You can now define `with_opts` and `without_opts` in target-specific configuration of `copr_build` job to build with `--with` and `--without` rpmbuild options. ([packit#2463](https://github.com/packit/packit/pull/2463))\\n- We have made several improvements to our dashboard:\\n - The Copr installation instructions have been updated. ([dashboard#487](https://github.com/packit/dashboard/pull/487))\\n - You can now view the number of new findings from OpenScanHub scans. ([dashboard#489](https://github.com/packit/dashboard/pull/489))\\n - Displaying of Copr builds in Testing Farm run views was improved as well. ([dashboard#481](https://github.com/packit/dashboard/pull/481))"},{"id":"/2024/week-45","metadata":{"permalink":"/posts/weekly/2024/week-45","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-45.md","source":"@site/weekly/2024/week-45.md","title":"Week 45 in Packit","description":"Week 45 (November 5th \u2013 November 11th)","date":"2024-11-11T00:00:00.000Z","formattedDate":"November 11, 2024","tags":[{"label":"2024-November","permalink":"/posts/weekly/tags/2024-november"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"November","permalink":"/posts/weekly/tags/november"}],"readingTime":0.15,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 45 in Packit","date":"2024-11-11T00:00:00.000Z","authors":"mfocko","tags":["2024-November","2024","November"]},"prevItem":{"title":"Week 46 in Packit","permalink":"/posts/weekly/2024/week-46"},"nextItem":{"title":"Week 44 in Packit","permalink":"/posts/weekly/2024/week-44"}},"content":"## Week 45 (November 5th \u2013 November 11th)\\n\\n- Packit now provides information about submitted scans via `/osh-scans` API endpoint. ([packit-service#2614](https://github.com/packit/packit-service/pull/2614))\\n- We have improved reporting of OpenScanHub results. ([packit-service#2622](https://github.com/packit/packit-service/pull/2622))"},{"id":"/2024/week-44","metadata":{"permalink":"/posts/weekly/2024/week-44","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-44.md","source":"@site/weekly/2024/week-44.md","title":"Week 44 in Packit","description":"Week 44 (October 29th \u2013 November 4th)","date":"2024-11-04T00:00:00.000Z","formattedDate":"November 4, 2024","tags":[{"label":"2024-October","permalink":"/posts/weekly/tags/2024-october"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"October","permalink":"/posts/weekly/tags/october"}],"readingTime":0.115,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 44 in Packit","date":"2024-11-04T00:00:00.000Z","authors":"flachman","tags":["2024-October","2024","October"]},"prevItem":{"title":"Week 45 in Packit","permalink":"/posts/weekly/2024/week-45"},"nextItem":{"title":"Week 43 in Packit","permalink":"/posts/weekly/2024/week-43"}},"content":"## Week 44 (October 29th \u2013 November 4th)\\n\\n- Packit now supports and defaults to `fast_forward_merge_into` syntax via `--dist-git-branches-mapping` in `dist-git init`. ([packit#2456](https://github.com/packit/packit/pull/2456))"},{"id":"/2024/week-43","metadata":{"permalink":"/posts/weekly/2024/week-43","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-43.md","source":"@site/weekly/2024/week-43.md","title":"Week 43 in Packit","description":"Week 43 (October 22nd \u2013 October 28th)","date":"2024-10-28T00:00:00.000Z","formattedDate":"October 28, 2024","tags":[{"label":"2024-October","permalink":"/posts/weekly/tags/2024-october"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"October","permalink":"/posts/weekly/tags/october"}],"readingTime":0.785,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 43 in Packit","date":"2024-10-28T00:00:00.000Z","authors":"mmassari","tags":["2024-October","2024","October"]},"prevItem":{"title":"Week 44 in Packit","permalink":"/posts/weekly/2024/week-44"},"nextItem":{"title":"Week 42 in Packit","permalink":"/posts/weekly/2024/week-42"}},"content":"## Week 43 (October 22nd \u2013 October 28th)\\n\\n- We have added support for retriggering jobs that are configured for `commit` and `release` trigger. Retriggering can be done via commit comments on the relevant commit, using the usual comments, such as `/packit build` or `/packit test`, but the branch or tag need to be specified like this (without the arguments, we will default to `commit` trigger for the default branch of the repository):\\n\\n ```\\n /packit build --commit \\n ```\\n\\n or\\n\\n ```\\n /packit build --release \\n ```\\n\\n ([packit-service#2589](https://github.com/packit/packit-service/pull/2589))\\n\\n- There is a new method for getting a single commit comment, supporting also retrieval and adding reactions in GitHub. ([ogr#865](https://github.com/packit/ogr/pull/865))\\n\\n- We have improved the feedback for the Open Scan Hub job. You can now see if the scan is in a `pending`, `running`, `canceled`, `failed`, or `successful` state.\\n A `failed` or `canceled` scan is shown as neutral and does not cause your pull request validation to fail. ([packit-service#2543](https://github.com/packit/packit-service/issues/2543))"},{"id":"/2024/week-42","metadata":{"permalink":"/posts/weekly/2024/week-42","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-42.md","source":"@site/weekly/2024/week-42.md","title":"Week 42 in Packit","description":"Week 42 (October 15th \u2013 October 21st)","date":"2024-10-21T00:00:00.000Z","formattedDate":"October 21, 2024","tags":[{"label":"2024-October","permalink":"/posts/weekly/tags/2024-october"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"October","permalink":"/posts/weekly/tags/october"}],"readingTime":0.14,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 42 in Packit","date":"2024-10-21T00:00:00.000Z","authors":"nforro","tags":["2024-October","2024","October"]},"prevItem":{"title":"Week 43 in Packit","permalink":"/posts/weekly/2024/week-43"},"nextItem":{"title":"Week 41 in Packit","permalink":"/posts/weekly/2024/week-41"}},"content":"## Week 42 (October 15th \u2013 October 21st)\\n\\n- Manual test trigger command (`/packit test`) now accepts `--env` option(s)\\n to override environment variables passed to Testing Farm.\\n ([packit-service#2583](https://github.com/packit/packit-service/pull/2583))"},{"id":"/2024/week-41","metadata":{"permalink":"/posts/weekly/2024/week-41","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-41.md","source":"@site/weekly/2024/week-41.md","title":"Week 41 in Packit","description":"Week 41 (October 8th \u2013 October 14th)","date":"2024-10-14T00:00:00.000Z","formattedDate":"October 14, 2024","tags":[{"label":"2024-October","permalink":"/posts/weekly/tags/2024-october"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"October","permalink":"/posts/weekly/tags/october"}],"readingTime":0.185,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 41 in Packit","date":"2024-10-14T00:00:00.000Z","authors":"lbarczio","tags":["2024-October","2024","October"]},"prevItem":{"title":"Week 42 in Packit","permalink":"/posts/weekly/2024/week-42"},"nextItem":{"title":"Week 40 in Packit","permalink":"/posts/weekly/2024/week-40"}},"content":"## Week 41 (October 8th \u2013 October 14th)\\n\\n- We have fixed an issue that was introduced during the unification of the interface for passing resolved Bugzillas / Jira tickets to the `sync-release` or `bodhi_update` jobs. ([packit#2442](https://github.com/packit/packit/pull/2442))"},{"id":"/2024/week-40","metadata":{"permalink":"/posts/weekly/2024/week-40","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-40.md","source":"@site/weekly/2024/week-40.md","title":"Week 40 in Packit","description":"Week 40 (October 1st \u2013 October 7th)","date":"2024-10-07T00:00:00.000Z","formattedDate":"October 7, 2024","tags":[{"label":"2024-October","permalink":"/posts/weekly/tags/2024-october"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"October","permalink":"/posts/weekly/tags/october"}],"readingTime":0.85,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 40 in Packit","date":"2024-10-07T00:00:00.000Z","authors":"mfocko","tags":["2024-October","2024","October"]},"prevItem":{"title":"Week 41 in Packit","permalink":"/posts/weekly/2024/week-41"},"nextItem":{"title":"Week 39 in Packit","permalink":"/posts/weekly/2024/week-39"}},"content":"## Week 40 (October 1st \u2013 October 7th)\\n\\n- `packit validate-config` now checks for the existence of the downstream package. ([packit#2436](https://github.com/packit/packit/pull/2436))\\n- Packit now allows building VM images via CLI without any Copr repository specified. ([packit#2434](https://github.com/packit/packit/pull/2434))\\n- We have unified interface of passing resolved bugs (e.g., Bugzillas as of now) to Packit CLI and via comments. Both CLI and comments now use `--resolve-bug` switch (comments accept comma-separated list of bugs, CLI accepts the switch multiple times (also `-b`)).\\n ([packit#2428](https://github.com/packit/packit/pull/2428) and [packit-service#2560](https://github.com/packit/packit-service/pull/2560))\\n- `packit init` now adds working directories that are used in `packit prepare-sources` into the `.gitignore` file in the same directory where Packit config resides. ([packit#2431](https://github.com/packit/packit/pull/2431))\\n- Before triggering the non-scratch Koji builds, we now check whether there is not already a build in progress or completed for the same NVR. ([packit-service#2559](https://github.com/packit/packit-service/pull/2559))\\n- We have improved the error reporting for failed downstream jobs. ([packit-service#2544](https://github.com/packit/packit-service/pull/2544))\\n- We have fixed an issue that caused inconsistencies with the expected behaviour stated by the documentation when adding duplicitous reactions to GitLab comments. ([ogr#861](https://github.com/packit/ogr/pull/861))"},{"id":"/2024/week-39","metadata":{"permalink":"/posts/weekly/2024/week-39","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-39.md","source":"@site/weekly/2024/week-39.md","title":"Week 39 in Packit","description":"Week 39 (September 24th \u2013 September 30th)","date":"2024-09-30T00:00:00.000Z","formattedDate":"September 30, 2024","tags":[{"label":"2024-September","permalink":"/posts/weekly/tags/2024-september"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"September","permalink":"/posts/weekly/tags/september"}],"readingTime":0.235,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 39 in Packit","date":"2024-09-30T00:00:00.000Z","authors":"flachman","tags":["2024-September","2024","September"]},"prevItem":{"title":"Week 40 in Packit","permalink":"/posts/weekly/2024/week-40"},"nextItem":{"title":"Week 38 in Packit","permalink":"/posts/weekly/2024/week-38"}},"content":"## Week 39 (September 24th \u2013 September 30th)\\n\\n- Check for `upstream_project_url` presence in the configuration when `pull_from_upstream` job is configured was removed from `validate-config`, as this is no longer required. ([packit#2423](https://github.com/packit/packit/pull/2423))\\n- We have added a note about retriggering `pull_from_upstream` job from dist-git pull requests. ([packit-service#2542](https://github.com/packit/packit-service/pull/2542))"},{"id":"/2024/week-38","metadata":{"permalink":"/posts/weekly/2024/week-38","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-38.md","source":"@site/weekly/2024/week-38.md","title":"Week 38 in Packit","description":"Week 38 (September 17th \u2013 September 23rd)","date":"2024-09-23T00:00:00.000Z","formattedDate":"September 23, 2024","tags":[{"label":"2024-September","permalink":"/posts/weekly/tags/2024-september"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"September","permalink":"/posts/weekly/tags/september"}],"readingTime":0.14,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 38 in Packit","date":"2024-09-23T00:00:00.000Z","authors":"mmassari","tags":["2024-September","2024","September"]},"prevItem":{"title":"Week 39 in Packit","permalink":"/posts/weekly/2024/week-39"},"nextItem":{"title":"Week 37 in Packit","permalink":"/posts/weekly/2024/week-37"}},"content":"## Week 38 (September 17th \u2013 September 23rd)\\n\\n- Packit now allows to configure mock bootstrap feature setup of Copr projects with a new `bootstrap` configuration option. ([packit#2411](https://github.com/packit/packit/pull/2411))"},{"id":"/2024/week-37","metadata":{"permalink":"/posts/weekly/2024/week-37","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-37.md","source":"@site/weekly/2024/week-37.md","title":"Week 37 in Packit","description":"Week 37 (September 10th \u2013 September 16th)","date":"2024-09-16T00:00:00.000Z","formattedDate":"September 16, 2024","tags":[{"label":"2024-September","permalink":"/posts/weekly/tags/2024-september"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"September","permalink":"/posts/weekly/tags/september"}],"readingTime":0.135,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 37 in Packit","date":"2024-09-16T00:00:00.000Z","authors":"nforro","tags":["2024-September","2024","September"]},"prevItem":{"title":"Week 38 in Packit","permalink":"/posts/weekly/2024/week-38"},"nextItem":{"title":"Week 36 in Packit","permalink":"/posts/weekly/2024/week-36"}},"content":"## Week 37 (September 10th \u2013 September 16th)\\n\\n- We have fixed showing of Bodhi updates that are triggered by non-Packit Koji builds on our dashboard.\\n ([packit-service#2528](https://github.com/packit/packit-service/pull/2528))"},{"id":"/2024/week-36","metadata":{"permalink":"/posts/weekly/2024/week-36","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-36.md","source":"@site/weekly/2024/week-36.md","title":"Week 36 in Packit","description":"Week 36 (September 3rd \u2013 September 9th)","date":"2024-09-09T00:00:00.000Z","formattedDate":"September 9, 2024","tags":[{"label":"2024-September","permalink":"/posts/weekly/tags/2024-september"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"September","permalink":"/posts/weekly/tags/september"}],"readingTime":0.445,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 36 in Packit","date":"2024-09-09T00:00:00.000Z","authors":"lbarczio","tags":["2024-September","2024","September"]},"prevItem":{"title":"Week 37 in Packit","permalink":"/posts/weekly/2024/week-37"},"nextItem":{"title":"Week 34 in Packit","permalink":"/posts/weekly/2024/week-34"}},"content":"## Week 36 (September 3rd \u2013 September 9th)\\n\\n- Packit now supports passing custom arguments to various static analyzers through `--csmock-args` CLI option and `csmock_args` configuration. ([packit#2402](https://github.com/packit/packit/pull/2402))\\n- When syncing a new release, Packit can now avoid diverging git branches by reusing the commit from one branch when opening pull requests into other branches. (These pull requests can be merged in fast-forward mode.)\\n Use the new syntax for `dist_git_branches` as in this example to utilise this functionality:\\n\\n```\\n{\\n \\"rawhide\\": {\\n \\"fast_forward_merge_into\\": [\\"f40\\"]\\n },\\n \\"fedora-stable\\": {}\\n}\\n```\\n\\n([packit-service#2478](https://github.com/packit/packit-service/pull/2478))"},{"id":"/2024/week-34","metadata":{"permalink":"/posts/weekly/2024/week-34","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-34.md","source":"@site/weekly/2024/week-34.md","title":"Week 34 in Packit","description":"Week 34 (August 20st \u2013 August 27th)","date":"2024-08-27T00:00:00.000Z","formattedDate":"August 27, 2024","tags":[{"label":"2024-August","permalink":"/posts/weekly/tags/2024-august"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"August","permalink":"/posts/weekly/tags/august"}],"readingTime":0.425,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 34 in Packit","date":"2024-08-27T00:00:00.000Z","authors":"flachman","tags":["2024-August","2024","August"]},"prevItem":{"title":"Week 36 in Packit","permalink":"/posts/weekly/2024/week-36"},"nextItem":{"title":"Week 33 in Packit","permalink":"/posts/weekly/2024/week-33"}},"content":"## Week 34 (August 20st \u2013 August 27th)\\n\\n- `pull-from-upstream` is now supported also without specifying `upstream_project_url` in the configuration. For such cases, the upstream repository will not be detected and cloned during release syncing. ([packit#2398](https://github.com/packit/packit/pull/2398))\\n- `dist-git init` command now allows `upstream-git-url` not to be specified. ([packit#2387](https://github.com/packit/packit/pull/2387))\\n- You can newly tag builds of a package into a sidetag group by using `/packit koji-tag` comment command. ([packit-service#2507](https://github.com/packit/packit-service/pull/2507))\\n- Thanks to [Cristian Le](https://github.com/LecrisUT), `epel-10` is now correctly mapped to a `centos-stream-10` when running tests. ([packit-service#2508](https://github.com/packit/packit-service/pull/2508))"},{"id":"/2024/week-33","metadata":{"permalink":"/posts/weekly/2024/week-33","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-33.md","source":"@site/weekly/2024/week-33.md","title":"Week 33 in Packit","description":"Week 33 (August 13th \u2013 August 19th)","date":"2024-08-19T00:00:00.000Z","formattedDate":"August 19, 2024","tags":[{"label":"2024-August","permalink":"/posts/weekly/tags/2024-august"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"August","permalink":"/posts/weekly/tags/august"}],"readingTime":0.125,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 33 in Packit","date":"2024-08-19T00:00:00.000Z","authors":"lbarczio","tags":["2024-August","2024","August"]},"prevItem":{"title":"Week 34 in Packit","permalink":"/posts/weekly/2024/week-34"},"nextItem":{"title":"Week 32 in Packit","permalink":"/posts/weekly/2024/week-32"}},"content":"## Week 33 (August 13th \u2013 August 19th)\\n\\n- Several internal, but also performance improvements were done on our dashboard, thanks to\\n [Freya Gustavsson](https://github.com/Venefilyn) ([packit/dashboard#435](https://github.com/packit/dashboard/pull/435))!"},{"id":"/2024/week-32","metadata":{"permalink":"/posts/weekly/2024/week-32","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-32.md","source":"@site/weekly/2024/week-32.md","title":"Week 32 in Packit","description":"Week 32 (August 6th \u2013 August 12th)","date":"2024-08-12T00:00:00.000Z","formattedDate":"August 12, 2024","tags":[{"label":"2024-August","permalink":"/posts/weekly/tags/2024-august"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"August","permalink":"/posts/weekly/tags/august"}],"readingTime":0.14,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 32 in Packit","date":"2024-08-12T00:00:00.000Z","authors":"nforro","tags":["2024-August","2024","August"]},"prevItem":{"title":"Week 33 in Packit","permalink":"/posts/weekly/2024/week-33"},"nextItem":{"title":"Week 31 in Packit","permalink":"/posts/weekly/2024/week-31"}},"content":"## Week 32 (August 6th \u2013 August 12th)\\n\\n- Packit now passes `PACKIT_TAG_NAME` to the Testing Farm run when it\'s triggered by a release event.\\n Thanks [@Frawless](https://github.com/Frawless).\\n ([packit-service#2494](https://github.com/packit/packit-service/pull/2494))"},{"id":"/2024/week-31","metadata":{"permalink":"/posts/weekly/2024/week-31","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-31.md","source":"@site/weekly/2024/week-31.md","title":"Week 31 in Packit","description":"Week 31 (July 30th \u2013 August 5th)","date":"2024-08-05T00:00:00.000Z","formattedDate":"August 5, 2024","tags":[{"label":"2024-August","permalink":"/posts/weekly/tags/2024-august"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"August","permalink":"/posts/weekly/tags/august"}],"readingTime":0.095,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 31 in Packit","date":"2024-08-05T00:00:00.000Z","authors":"lbarczio","tags":["2024-August","2024","August"]},"prevItem":{"title":"Week 32 in Packit","permalink":"/posts/weekly/2024/week-32"},"nextItem":{"title":"Week 30 in Packit","permalink":"/posts/weekly/2024/week-30"}},"content":"## Week 31 (July 30th \u2013 August 5th)\\n\\n- It is now possible to run tests for releases. ([packit/packit-service#2490](https://github.com/packit/packit-service/pull/2490))"},{"id":"/2024/week-30","metadata":{"permalink":"/posts/weekly/2024/week-30","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-30.md","source":"@site/weekly/2024/week-30.md","title":"Week 30 in Packit","description":"Week 30 (July 23rd \u2013 July 29th)","date":"2024-07-29T00:00:00.000Z","formattedDate":"July 29, 2024","tags":[{"label":"2024-July","permalink":"/posts/weekly/tags/2024-july"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"July","permalink":"/posts/weekly/tags/july"}],"readingTime":0.54,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 30 in Packit","date":"2024-07-29T00:00:00.000Z","authors":"mfocko","tags":["2024-July","2024","July"]},"prevItem":{"title":"Week 31 in Packit","permalink":"/posts/weekly/2024/week-31"},"nextItem":{"title":"Week 29 in Packit","permalink":"/posts/weekly/2024/week-29"}},"content":"## Week 30 (July 23rd \u2013 July 29th)\\n\\n- `packit pull-from-upstream` now allows omitting `upstream_project_url` in the configuration in which case the interaction with the upstream repository is skipped during release syncing. ([packit#2354](https://github.com/packit/packit/pull/2354))\\n- We have added the initial version of functionality for running scans in OpenScanHub. You can read more about this functionality\\n [here](https://packit.dev/docs/configuration#osh_diff_scan_after_copr_build). ([packit-service#2472](https://github.com/packit/packit-service/pull/2472))\\n- Added a new configuration option `sync_test_job_statuses_with_builds` that controls whether test job statuses are updated together with their corresponding build job statuses. When set to `false`, while tests jobs are waiting for their corresponding build jobs to finish, their statuses remain in pending state and only build job statuses are updated. ([packit-service#2470](https://github.com/packit/packit-service/pull/2470))"},{"id":"/2024/week-29","metadata":{"permalink":"/posts/weekly/2024/week-29","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-29.md","source":"@site/weekly/2024/week-29.md","title":"Week 29 in Packit","description":"Week 29 (July 16th \u2013 July 22nd)","date":"2024-07-22T00:00:00.000Z","formattedDate":"July 22, 2024","tags":[{"label":"2024-July","permalink":"/posts/weekly/tags/2024-july"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"July","permalink":"/posts/weekly/tags/july"}],"readingTime":0.375,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 29 in Packit","date":"2024-07-22T00:00:00.000Z","authors":"flachman","tags":["2024-July","2024","July"]},"prevItem":{"title":"Week 30 in Packit","permalink":"/posts/weekly/2024/week-30"},"nextItem":{"title":"Week 28 in Packit","permalink":"/posts/weekly/2024/week-28"}},"content":"## Week 29 (July 16th \u2013 July 22nd)\\n\\n- We have implemented a CLI support for Koji builds against CBS Koji instance. ([packit#2267](https://github.com/packit/packit/pull/2267))\\n- Added a new configuration option `sync_test_job_statuses_with_builds` that controls whether test job statuses are updated together with their corresponding build job statuses. When set to `false`, while tests jobs are waiting for their corresponding build jobs to finish, their statuses remain in pending state and only build job statuses are updated. ([packit-service#2470](https://github.com/packit/packit-service/pull/2470))"},{"id":"/2024/week-28","metadata":{"permalink":"/posts/weekly/2024/week-28","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-28.md","source":"@site/weekly/2024/week-28.md","title":"Week 28 in Packit","description":"Week 28 (July 9th \u2013 July 15th)","date":"2024-07-15T00:00:00.000Z","formattedDate":"July 15, 2024","tags":[{"label":"2024-July","permalink":"/posts/weekly/tags/2024-july"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"July","permalink":"/posts/weekly/tags/july"}],"readingTime":0.19,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 28 in Packit","date":"2024-07-15T00:00:00.000Z","authors":"nforro","tags":["2024-July","2024","July"]},"prevItem":{"title":"Week 29 in Packit","permalink":"/posts/weekly/2024/week-29"},"nextItem":{"title":"Week 27 in Packit","permalink":"/posts/weekly/2024/week-27"}},"content":"## Week 28 (July 9th \u2013 July 15th)\\n\\n- We have improved the babysitting of Testing Farm runs to better handle API outages.\\n ([packit-service#2464](https://github.com/packit/packit-service/pull/2464))\\n- We have adjusted commenting behaviour regarding Packit logs on release syncing PRs.\\n ([packit-service#2373](https://github.com/packit/packit-service/pull/2373))"},{"id":"/2024/week-27","metadata":{"permalink":"/posts/weekly/2024/week-27","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-27.md","source":"@site/weekly/2024/week-27.md","title":"Week 27 in Packit","description":"Week 27 (July 2nd \u2013 July 8th)","date":"2024-07-08T00:00:00.000Z","formattedDate":"July 8, 2024","tags":[{"label":"2024-July","permalink":"/posts/weekly/tags/2024-july"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"July","permalink":"/posts/weekly/tags/july"}],"readingTime":0.15,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 27 in Packit","date":"2024-07-08T00:00:00.000Z","authors":"mmassari","tags":["2024-July","2024","July"]},"prevItem":{"title":"Week 28 in Packit","permalink":"/posts/weekly/2024/week-28"},"nextItem":{"title":"Week 26 in Packit","permalink":"/posts/weekly/2024/week-26"}},"content":"## Week 27 (July 2nd \u2013 July 8th)\\n\\n- Packit now updates its own, not yet merged, pull requests instead of creating new ones when syncing new releases downstream. ([packit#2204](https://github.com/packit/packit/pull/2204))"},{"id":"/2024/week-26","metadata":{"permalink":"/posts/weekly/2024/week-26","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-26.md","source":"@site/weekly/2024/week-26.md","title":"Week 26 in Packit","description":"Week 26 (June 25th \u2013 July 1st)","date":"2024-07-01T00:00:00.000Z","formattedDate":"July 1, 2024","tags":[{"label":"2024-June","permalink":"/posts/weekly/tags/2024-june"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"June","permalink":"/posts/weekly/tags/june"}],"readingTime":0.175,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 26 in Packit","date":"2024-07-01T00:00:00.000Z","authors":"mfocko","tags":["2024-June","2024","June"]},"prevItem":{"title":"Week 27 in Packit","permalink":"/posts/weekly/2024/week-27"},"nextItem":{"title":"Week 25 in Packit","permalink":"/posts/weekly/2024/week-25"}},"content":"## Week 26 (June 25th \u2013 July 1st)\\n\\n- Enabled HTTP/2 for Packit service. ([packit-service#2450](https://github.com/packit/packit-service/pull/2450))\\n- It is now possible to disable reporting of `propose_downstream` failures by setting `notifications.failure_issue.create` in the configuration to `false`. ([packit-service#2451](https://github.com/packit/packit-service/pull/2451))"},{"id":"/2024/week-25","metadata":{"permalink":"/posts/weekly/2024/week-25","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-25.md","source":"@site/weekly/2024/week-25.md","title":"Week 25 in Packit","description":"Week 25 (June 18th \u2013 June 24th)","date":"2024-06-24T00:00:00.000Z","formattedDate":"June 24, 2024","tags":[{"label":"2024-June","permalink":"/posts/weekly/tags/2024-june"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"June","permalink":"/posts/weekly/tags/june"}],"readingTime":0.165,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 25 in Packit","date":"2024-06-24T00:00:00.000Z","authors":"nforro","tags":["2024-June","2024","June"]},"prevItem":{"title":"Week 26 in Packit","permalink":"/posts/weekly/2024/week-26"},"nextItem":{"title":"Week 24 in Packit","permalink":"/posts/weekly/2024/week-24"}},"content":"## Week 25 (June 18th \u2013 June 24th)\\n\\n- We have fixed an issue that has been introduced by another bug fix.\\n This issue has caused an outage of upstream Koji builds.\\n ([packit#2329](https://github.com/packit/packit/pull/2329))"},{"id":"/2024/week-24","metadata":{"permalink":"/posts/weekly/2024/week-24","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-24.md","source":"@site/weekly/2024/week-24.md","title":"Week 24 in Packit","description":"Week 24 (June 11th \u2013 June 17th)","date":"2024-06-18T00:00:00.000Z","formattedDate":"June 18, 2024","tags":[{"label":"2024-June","permalink":"/posts/weekly/tags/2024-june"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"June","permalink":"/posts/weekly/tags/june"}],"readingTime":0.27,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 24 in Packit","date":"2024-06-18T00:00:00.000Z","authors":"flachman","tags":["2024-June","2024","June"]},"prevItem":{"title":"Week 25 in Packit","permalink":"/posts/weekly/2024/week-25"},"nextItem":{"title":"Week 22 in Packit","permalink":"/posts/weekly/2024/week-22"}},"content":"## Week 24 (June 11th \u2013 June 17th)\\n\\n- We have fixed a bug that caused inconsistency between the promised environment variables (from the docs) and the environment that has been actually provided. Now you should have access to `PACKIT_UPSTREAM_REPO` and `PACKIT_DOWNSTREAM_REPO` (in case of `propose_downstream` and `pull_from_upstream` jobs), in the `post-upstream-clone` action. ([packit#2327](https://github.com/packit/packit/pull/2327))"},{"id":"/2024/week-22","metadata":{"permalink":"/posts/weekly/2024/week-22","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-22.md","source":"@site/weekly/2024/week-22.md","title":"Week 22 in Packit","description":"Week 22 (May 28th \u2013 June 3rd)","date":"2024-06-03T00:00:00.000Z","formattedDate":"June 3, 2024","tags":[{"label":"2024-May","permalink":"/posts/weekly/tags/2024-may"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"May","permalink":"/posts/weekly/tags/may"}],"readingTime":0.185,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 22 in Packit","date":"2024-06-03T00:00:00.000Z","authors":"lbarczio","tags":["2024-May","2024","May"]},"prevItem":{"title":"Week 24 in Packit","permalink":"/posts/weekly/2024/week-24"},"nextItem":{"title":"Week 21 in Packit","permalink":"/posts/weekly/2024/week-21"}},"content":"## Week 22 (May 28th \u2013 June 3rd)\\n\\n- Issue with pushing to CentOS Stream dist-git on GitLab is now resolved.\\n ([packit-service#2433](https://github.com/packit/packit-service/pull/2433))\\n- Check for `allowed_pr_authors`/`allowed_committers` configuration before running Koji production builds is now more reliable.\\n ([packit/packit-service#2435](https://github.com/packit/packit-service/pull/2435))"},{"id":"/2024/week-21","metadata":{"permalink":"/posts/weekly/2024/week-21","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-21.md","source":"@site/weekly/2024/week-21.md","title":"Week 21 in Packit","description":"Week 21 (May 21st \u2013 May 27th)","date":"2024-05-27T00:00:00.000Z","formattedDate":"May 27, 2024","tags":[{"label":"2024-May","permalink":"/posts/weekly/tags/2024-may"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"May","permalink":"/posts/weekly/tags/may"}],"readingTime":0.11,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 21 in Packit","date":"2024-05-27T00:00:00.000Z","authors":"mfocko","tags":["2024-May","2024","May"]},"prevItem":{"title":"Week 22 in Packit","permalink":"/posts/weekly/2024/week-22"},"nextItem":{"title":"Week 20 in Packit","permalink":"/posts/weekly/2024/week-20"}},"content":"## Week 21 (May 21st \u2013 May 27th)\\n\\n- We have fixed the syncing of ACLs for `propose-downtream` for CentOS Stream. ([packit#2318](https://github.com/packit/packit/pull/2318))"},{"id":"/2024/week-20","metadata":{"permalink":"/posts/weekly/2024/week-20","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-20.md","source":"@site/weekly/2024/week-20.md","title":"Week 20 in Packit","description":"Week 20 (May 14th \u2013 May 20th)","date":"2024-05-20T00:00:00.000Z","formattedDate":"May 20, 2024","tags":[{"label":"2024-May","permalink":"/posts/weekly/tags/2024-may"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"May","permalink":"/posts/weekly/tags/may"}],"readingTime":0.25,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 20 in Packit","date":"2024-05-20T00:00:00.000Z","authors":"mmassari","tags":["2024-May","2024","May"]},"prevItem":{"title":"Week 21 in Packit","permalink":"/posts/weekly/2024/week-21"},"nextItem":{"title":"Week 19 in Packit","permalink":"/posts/weekly/2024/week-19"}},"content":"## Week 20 (May 14th \u2013 May 20th)\\n\\n- When running `dist-git init` command from CLI, you can pass a command to specify the git URL of the project. ([packit#2308](https://github.com/packit/packit/pull/2308))\\n- We have fixed the incorrect displaying of the time it took for the jobs to run on dashboard. ([dashboard#408](https://github.com/packit/dashboard/pull/408))"},{"id":"/2024/week-19","metadata":{"permalink":"/posts/weekly/2024/week-19","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-19.md","source":"@site/weekly/2024/week-19.md","title":"Week 19 in Packit","description":"Week 19 (May 7th \u2013 May 13th)","date":"2024-05-13T00:00:00.000Z","formattedDate":"May 13, 2024","tags":[{"label":"2024-May","permalink":"/posts/weekly/tags/2024-may"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"May","permalink":"/posts/weekly/tags/may"}],"readingTime":0.215,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 19 in Packit","date":"2024-05-13T00:00:00.000Z","authors":"flachman","tags":["2024-May","2024","May"]},"prevItem":{"title":"Week 20 in Packit","permalink":"/posts/weekly/2024/week-20"},"nextItem":{"title":"Week 18 in Packit","permalink":"/posts/weekly/2024/week-18"}},"content":"## Week 19 (May 7th \u2013 May 13th)\\n\\n- Added a `scan-in-osh` subcommand in the CLI to perform a scan through OpenScanHub. By default it performs a full scan of the packages and a differential scan can be performed through `--base-srpm` option. ([packit#2301](https://github.com/packit/packit/pull/2301))"},{"id":"/2024/week-18","metadata":{"permalink":"/posts/weekly/2024/week-18","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-18.md","source":"@site/weekly/2024/week-18.md","title":"Week 18 in Packit","description":"Week 18 (April 30th \u2013 May 6th)","date":"2024-05-06T00:00:00.000Z","formattedDate":"May 6, 2024","tags":[{"label":"2024-April","permalink":"/posts/weekly/tags/2024-april"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"April","permalink":"/posts/weekly/tags/april"}],"readingTime":0.49,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 18 in Packit","date":"2024-05-06T00:00:00.000Z","authors":"nforro","tags":["2024-April","2024","April"]},"prevItem":{"title":"Week 19 in Packit","permalink":"/posts/weekly/2024/week-19"},"nextItem":{"title":"Week 17 in Packit","permalink":"/posts/weekly/2024/week-17"}},"content":"## Week 18 (April 30th \u2013 May 6th)\\n\\n- Packit will now upload to lookaside cache sources that are not specified by URLs\\n and are present in the dist-git repo during release sync. Additionally, all the actions\\n ran during syncing release will provide the `PACKIT_PROJECT_VERSION` environment variable.\\n ([packit#2297](https://github.com/packit/packit/pull/2297))\\n- We have introduced a new `status_name_template` option that allows you to configure\\n status name for a Packit job. For further details have a look at our\\n [docs](https://packit.dev/docs/configuration#status_name_template).\\n This feature is still experimental and at the moment it is not possible\\n to retry such jobs via GitHub Checks\' re-run.\\n ([packit-service#2402](https://github.com/packit/packit-service/pull/2402))"},{"id":"/2024/week-17","metadata":{"permalink":"/posts/weekly/2024/week-17","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-17.md","source":"@site/weekly/2024/week-17.md","title":"Week 17 in Packit","description":"Week 17 (April 23rd \u2013 April 29th)","date":"2024-04-29T00:00:00.000Z","formattedDate":"April 29, 2024","tags":[{"label":"2024-April","permalink":"/posts/weekly/tags/2024-april"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"April","permalink":"/posts/weekly/tags/april"}],"readingTime":0.48,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 17 in Packit","date":"2024-04-29T00:00:00.000Z","authors":"lbarczio","tags":["2024-April","2024","April"]},"prevItem":{"title":"Week 18 in Packit","permalink":"/posts/weekly/2024/week-18"},"nextItem":{"title":"Week 16 in Packit","permalink":"/posts/weekly/2024/week-16"}},"content":"## Week 17 (April 23rd \u2013 April 29th)\\n\\n- We have fixed the syncing of ACLs during CentOS Stream release syncing.\\n ([packit#2298](https://github.com/packit/packit/pull/2298))\\n- `koji_build` job has a new `sidetag_group` option that allows to perform a downstream Koji build in a sidetag.\\n A new sidetag will be created for each configured `dist_git_branch` if it doesn\'t already exist.\\n This represents the first step towards multi-package Bodhi updates. Stay tuned for further advancements!\\n ([packit-service#2409](https://github.com/packit/packit-service/pull/2409))\\n- We have fixed an issue when `copr_build` job status checks were sometimes wrongly updated with a misleading\\n message after a SRPM build failure. ([packit-service#2406](https://github.com/packit/packit-service/pull/2406))"},{"id":"/2024/week-16","metadata":{"permalink":"/posts/weekly/2024/week-16","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-16.md","source":"@site/weekly/2024/week-16.md","title":"Week 16 in Packit","description":"Week 16 (April 16th \u2013 April 22nd)","date":"2024-04-22T00:00:00.000Z","formattedDate":"April 22, 2024","tags":[{"label":"2024-April","permalink":"/posts/weekly/tags/2024-april"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"April","permalink":"/posts/weekly/tags/april"}],"readingTime":0.57,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 16 in Packit","date":"2024-04-22T00:00:00.000Z","authors":"mfocko","tags":["2024-April","2024","April"]},"prevItem":{"title":"Week 17 in Packit","permalink":"/posts/weekly/2024/week-17"},"nextItem":{"title":"Week 15 in Packit","permalink":"/posts/weekly/2024/week-15"}},"content":"## Week 16 (April 16th \u2013 April 22nd)\\n\\n- `packit dist-git init` now allows specifying `--version-update-mask` option and also any arbitrary top-level configuration options. ([packit#2288](https://github.com/packit/packit/pull/2288))\\n- We have fixed Packit auto-referencing Upstream Release Monitoring bug for release syncing to CentOS Stream. ([packit#2284](https://github.com/packit/packit/pull/2284))\\n- We have changed the behaviour of `/packit test` comment command: in case there is a missing build for some target, the build will not be triggered anymore, it will just be reported to the user. We needed to make this change as with the increased complexity of the configuration (multiple test jobs), the previous implementation was prone to race conditions leading to wasting of resources of Copr and Testing Farm. ([packit-service#2399](https://github.com/packit/packit-service/pull/2399))"},{"id":"/2024/week-15","metadata":{"permalink":"/posts/weekly/2024/week-15","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-15.md","source":"@site/weekly/2024/week-15.md","title":"Week 15 in Packit","description":"Week 15 (April 9th \u2013 April 15th)","date":"2024-04-15T00:00:00.000Z","formattedDate":"April 15, 2024","tags":[{"label":"2024-April","permalink":"/posts/weekly/tags/2024-april"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"April","permalink":"/posts/weekly/tags/april"}],"readingTime":0.145,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 15 in Packit","date":"2024-04-15T00:00:00.000Z","authors":"mmassari","tags":["2024-April","2024","April"]},"prevItem":{"title":"Week 16 in Packit","permalink":"/posts/weekly/2024/week-16"},"nextItem":{"title":"Week 14 in Packit","permalink":"/posts/weekly/2024/week-14"}},"content":"## Week 15 (April 9th \u2013 April 15th)\\n\\n- We have planned the work for the next quarter, curious about what will come next? You can find it [here](https://github.com/orgs/packit/projects/7/views/29)."},{"id":"/2024/week-14","metadata":{"permalink":"/posts/weekly/2024/week-14","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-14.md","source":"@site/weekly/2024/week-14.md","title":"Week 14 in Packit","description":"Week 14 (April 2nd \u2013 April 8th)","date":"2024-04-08T00:00:00.000Z","formattedDate":"April 8, 2024","tags":[{"label":"2024-April","permalink":"/posts/weekly/tags/2024-april"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"April","permalink":"/posts/weekly/tags/april"}],"readingTime":0.24,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 14 in Packit","date":"2024-04-08T00:00:00.000Z","authors":"flachman","tags":["2024-April","2024","April"]},"prevItem":{"title":"Week 15 in Packit","permalink":"/posts/weekly/2024/week-15"},"nextItem":{"title":"Week 13 in Packit","permalink":"/posts/weekly/2024/week-13"}},"content":"## Week 14 (April 2nd \u2013 April 8th)\\n\\n- We have fixed a race condition that could occur when multiple `copr_build` jobs sharing a Copr project but having different targets were running at the same time. ([packit#2274](https://github.com/packit/packit/pull/2274))\\n- We have fixed reporting of tests with `manual_trigger: True`. ([packit-service#2389](https://github.com/packit/packit-service/pull/2389))"},{"id":"/2024/week-13","metadata":{"permalink":"/posts/weekly/2024/week-13","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-13.md","source":"@site/weekly/2024/week-13.md","title":"Week 13 in Packit","description":"Week 13 (March 27th \u2013 April 2nd)","date":"2024-04-02T00:00:00.000Z","formattedDate":"April 2, 2024","tags":[{"label":"2024-March","permalink":"/posts/weekly/tags/2024-march"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"March","permalink":"/posts/weekly/tags/march"}],"readingTime":0.475,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 13 in Packit","date":"2024-04-02T00:00:00.000Z","authors":"nforro","tags":["2024-March","2024","March"]},"prevItem":{"title":"Week 14 in Packit","permalink":"/posts/weekly/2024/week-14"},"nextItem":{"title":"Week 12 in Packit","permalink":"/posts/weekly/2024/week-12"}},"content":"## Week 13 (March 27th \u2013 April 2nd)\\n\\n- The default behaviour of changelog entry generation has been changed to comply with Fedora Packaging Guidelines\\n (see the relevant Fedora Packaging Committee [discussion](https://pagure.io/packaging-committee/issue/1339)).\\n From now on, the default changelog entry is \\"- Update to version \\\\\\".\\n Users can still affect this behaviour using custom commands in the `changelog-entry` action\\n or with the `copy_upstream_release_description` configuration option.\\n ([packit#2253](https://github.com/packit/packit/pull/2253))\\n\\n- \\"[packit]\\" prefix has been removed from default dist-git commit message titles in order to prevent\\n unnecessary noise in autogenerated changelog. Users can override this using the `commit-message` action.\\n ([packit#2263](https://github.com/packit/packit/pull/2263))"},{"id":"/2024/week-12","metadata":{"permalink":"/posts/weekly/2024/week-12","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-12.md","source":"@site/weekly/2024/week-12.md","title":"Week 12 in Packit","description":"Week 12 (March 19th \u2013 March 25th)","date":"2024-03-25T00:00:00.000Z","formattedDate":"March 25, 2024","tags":[{"label":"2024-March","permalink":"/posts/weekly/tags/2024-march"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"March","permalink":"/posts/weekly/tags/march"}],"readingTime":0.35,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 12 in Packit","date":"2024-03-25T00:00:00.000Z","authors":"lbarczio","tags":["2024-March","2024","March"]},"prevItem":{"title":"Week 13 in Packit","permalink":"/posts/weekly/2024/week-13"},"nextItem":{"title":"Week 11 in Packit","permalink":"/posts/weekly/2024/week-11"}},"content":"## Week 12 (March 19th \u2013 March 25th)\\n\\n- Packit no longer shows status checks for not yet triggered manual tests.\\n ([packit-service#2375](https://github.com/packit/packit-service/pull/2375))\\n- `packit validate-config` now checks whether `upstream_project_url` is set if `pull_from_upstream` job is configured.\\n ([packit#2254](https://github.com/packit/packit/pull/2254))\\n- We have fixed an issue in `%prep` section processing. For instance, if the `%patches` macro appeared there,\\n it would have been converted to `%patch es`, causing failure when executing `%prep` later.\\n ([specfile#356](https://github.com/packit/specfile/pull/356))"},{"id":"/2024/week-11","metadata":{"permalink":"/posts/weekly/2024/week-11","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-11.md","source":"@site/weekly/2024/week-11.md","title":"Week 11 in Packit","description":"Week 11 (March 12th \u2013 March 18th)","date":"2024-03-18T00:00:00.000Z","formattedDate":"March 18, 2024","tags":[{"label":"2024-March","permalink":"/posts/weekly/tags/2024-march"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"March","permalink":"/posts/weekly/tags/march"}],"readingTime":0.31,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 11 in Packit","date":"2024-03-18T00:00:00.000Z","authors":"mfocko","tags":["2024-March","2024","March"]},"prevItem":{"title":"Week 12 in Packit","permalink":"/posts/weekly/2024/week-12"},"nextItem":{"title":"Week 10 in Packit","permalink":"/posts/weekly/2024/week-10"}},"content":"## Week 11 (March 12th \u2013 March 18th)\\n\\n- Don\'t have time to set up Packit? Or, do you want to see what it would look like on your package?\\n Starting now, you can [ask the Packit team](https://github.com/packit/packit-service/issues/new?assignees=&labels=onboarding&projects=&template=onboarding.yml&title=Onboard+%5Bmy+package%5D) to prepare a config file for you. ([packit-service#2369](https://github.com/packit/packit-service/pull/2369))\\n- A trailing newline is no longer added to spec files without one upon saving. ([specfile#353](https://github.com/packit/specfile/pull/353))"},{"id":"/2024/week-10","metadata":{"permalink":"/posts/weekly/2024/week-10","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-10.md","source":"@site/weekly/2024/week-10.md","title":"Week 10 in Packit","description":"Week 10 (March 5th \u2013 March 11th)","date":"2024-03-11T00:00:00.000Z","formattedDate":"March 11, 2024","tags":[{"label":"2024-March","permalink":"/posts/weekly/tags/2024-march"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"March","permalink":"/posts/weekly/tags/march"}],"readingTime":0.17,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 10 in Packit","date":"2024-03-11T00:00:00.000Z","authors":"mmassari","tags":["2024-March","2024","March"]},"prevItem":{"title":"Week 11 in Packit","permalink":"/posts/weekly/2024/week-11"},"nextItem":{"title":"Week 9 in Packit","permalink":"/posts/weekly/2024/week-9"}},"content":"## Week 10 (March 5th \u2013 March 11th)\\n\\n- You can now configure a list of Fedora accounts of users whose successful Koji builds will trigger automatic Bodhi updates (by default only `packit`). ([packit-service#2364](https://github.com/packit/packit-service/pull/2364))"},{"id":"/2024/week-9","metadata":{"permalink":"/posts/weekly/2024/week-9","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-9.md","source":"@site/weekly/2024/week-9.md","title":"Week 9 in Packit","description":"Week 9 (February 27th \u2013 March 4th)","date":"2024-03-04T00:00:00.000Z","formattedDate":"March 4, 2024","tags":[{"label":"2024-February","permalink":"/posts/weekly/tags/2024-february"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"February","permalink":"/posts/weekly/tags/february"}],"readingTime":0.315,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 9 in Packit","date":"2024-03-04T00:00:00.000Z","authors":"mfocko","tags":["2024-February","2024","February"]},"prevItem":{"title":"Week 10 in Packit","permalink":"/posts/weekly/2024/week-10"},"nextItem":{"title":"Week 8 in Packit","permalink":"/posts/weekly/2024/week-8"}},"content":"## Week 9 (February 27th \u2013 March 4th)\\n\\n- We have fixed the bug about Packit overwriting the final state of the build in case the build start is being processed later than the end of the build. ([packit-service#2358](https://github.com/packit/packit-service/pull/2358))\\n- We have improved the reporting of configuration errors in GitLab. ([packit-service#2357](https://github.com/packit/packit-service/pull/2357))\\n- `GitLabProject.get_file_content()` can now correctly handle file paths starting with `./`. ([ogr#844](https://github.com/packit/ogr/pull/844))"},{"id":"/2024/week-8","metadata":{"permalink":"/posts/weekly/2024/week-8","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-8.md","source":"@site/weekly/2024/week-8.md","title":"Week 8 in Packit","description":"Week 8 (February 20th \u2013 February 26th)","date":"2024-02-26T00:00:00.000Z","formattedDate":"February 26, 2024","tags":[{"label":"2024-February","permalink":"/posts/weekly/tags/2024-february"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"February","permalink":"/posts/weekly/tags/february"}],"readingTime":0.135,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 8 in Packit","date":"2024-02-26T00:00:00.000Z","authors":"flachman","tags":["2024-February","2024","February"]},"prevItem":{"title":"Week 9 in Packit","permalink":"/posts/weekly/2024/week-9"},"nextItem":{"title":"Week 7 in Packit","permalink":"/posts/weekly/2024/week-7"}},"content":"## Week 8 (February 20th \u2013 February 26th)\\n\\n- Packit now checks the version to propose against the version in specfile and doesn\'t create downgrade PRs. ([packit#2239](https://github.com/packit/packit/pull/2239))"},{"id":"/2024/week-7","metadata":{"permalink":"/posts/weekly/2024/week-7","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-7.md","source":"@site/weekly/2024/week-7.md","title":"Week 7 in Packit","description":"Week 7 (February 13th \u2013 February 19th)","date":"2024-02-19T00:00:00.000Z","formattedDate":"February 19, 2024","tags":[{"label":"2024-February","permalink":"/posts/weekly/tags/2024-february"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"February","permalink":"/posts/weekly/tags/february"}],"readingTime":0.565,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 7 in Packit","date":"2024-02-19T00:00:00.000Z","authors":"lbarczio","tags":["2024-February","2024","February"]},"prevItem":{"title":"Week 8 in Packit","permalink":"/posts/weekly/2024/week-8"},"nextItem":{"title":"Week 6 in Packit","permalink":"/posts/weekly/2024/week-6"}},"content":"## Week 7 (February 13th \u2013 February 19th)\\n\\n- Packit now supports special value `ignore` for `trigger` in jobs configuration that indicates not to execute the job at all.\\n This can be useful for templates or temporarily disabled jobs. ([packit#2234](https://github.com/packit/packit/pull/2234))\\n- We have fixed the caching of data for the usage API endpoint. ([packit-service#2350](https://github.com/packit/packit-service/pull/2350))\\n- We have fixed an issue that caused loading the same data multiple times on the dashboard within the project views. ([packit-service#2349](https://github.com/packit/packit-service/pull/2349))\\n- We have also fixed crashing of dashboard\'s `Usage` page in case of unsuccessful queries. ([dashboard#378](https://github.com/packit/dashboard/pull/378))\\n- We have fixed parsing of resolved Bugzillas in comments with multiple arguments specified,\\n e.g. `/packit pull-from-upstream --with-pr-config --resolved-bugs rhbz#123`. ([packit-service#2346](https://github.com/packit/packit-service/pull/2346))"},{"id":"/2024/week-6","metadata":{"permalink":"/posts/weekly/2024/week-6","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-6.md","source":"@site/weekly/2024/week-6.md","title":"Week 6 in Packit","description":"Week 6 (February 6th \u2013 February 12th)","date":"2024-02-12T00:00:00.000Z","formattedDate":"February 12, 2024","tags":[{"label":"2024-February","permalink":"/posts/weekly/tags/2024-february"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"February","permalink":"/posts/weekly/tags/february"}],"readingTime":0.555,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 6 in Packit","date":"2024-02-12T00:00:00.000Z","authors":"mmassari","tags":["2024-February","2024","February"]},"prevItem":{"title":"Week 7 in Packit","permalink":"/posts/weekly/2024/week-7"},"nextItem":{"title":"Week 5 in Packit","permalink":"/posts/weekly/2024/week-5"}},"content":"## Week 6 (February 6th \u2013 February 12th)\\n\\n- Packit now searches for bugzilla about new release created by Upstream Release Monitoring to reference each time it syncs the release downstream. ([packit#2229](https://github.com/packit/packit/pull/2229))\\n- We have introduced new CLI command `packit dist-git init` that initializes Packit configuration for release automation in dist-git repository. ([packit#2225](https://github.com/packit/packit/pull/2225))\\n- We have introduced new configuration options `require.label.present` and `require.label.absent`. By configuring these you can specify labels that need to be present or absent on a pull request for Packit to react on such PR. ([packit-service#2333](https://github.com/packit/packit-service/pull/2333))\\n- Interface for labels was unified and `labels` property for PullRequest and Issue now return list of PRLabel and IssueLabel respectively. ([ogr#839](https://github.com/packit/ogr/pull/839))"},{"id":"/2024/week-5","metadata":{"permalink":"/posts/weekly/2024/week-5","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-5.md","source":"@site/weekly/2024/week-5.md","title":"Week 5 in Packit","description":"Week 5 (January 30th \u2013 February 5th)","date":"2024-02-05T00:00:00.000Z","formattedDate":"February 5, 2024","tags":[{"label":"2024-February","permalink":"/posts/weekly/tags/2024-february"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"February","permalink":"/posts/weekly/tags/february"}],"readingTime":0.355,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Week 5 in Packit","date":"2024-02-05T00:00:00.000Z","authors":"mmassari","tags":["2024-February","2024","February"]},"prevItem":{"title":"Week 6 in Packit","permalink":"/posts/weekly/2024/week-6"},"nextItem":{"title":"Week 4 in Packit","permalink":"/posts/weekly/2024/week-4"}},"content":"## Week 5 (January 30th \u2013 February 5th)\\n\\n- `packit validate-config` now checks whether the Upstream Release Monitoring for the package is correctly configured if `pull_from_upstream` job is present in the configuration. ([packit#2226](https://github.com/packit/packit/pull/2226))\\n- There is a new global configuration option `parse_time_macros` that allows to configure macros to be explicitly defined or undefined at spec file parse time. ([packit#2222](https://github.com/packit/packit/pull/2222))\\n- We have added additional retries and improvements for task processing. ([packit-service#2326](https://github.com/packit/packit-service/pull/2326))"},{"id":"/2024/week-4","metadata":{"permalink":"/posts/weekly/2024/week-4","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-4.md","source":"@site/weekly/2024/week-4.md","title":"Week 4 in Packit","description":"Week 4 (January 23rd \u2013 January 29th)","date":"2024-01-29T00:00:00.000Z","formattedDate":"January 29, 2024","tags":[{"label":"2024-January","permalink":"/posts/weekly/tags/2024-january"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"January","permalink":"/posts/weekly/tags/january"}],"readingTime":0.505,"hasTruncateMarker":false,"authors":[{"name":"Matej Focko","email":"mfocko@redhat.com","url":"https://github.com/mfocko","imageURL":"https://github.com/mfocko.png","key":"mfocko"}],"frontMatter":{"title":"Week 4 in Packit","date":"2024-01-29T00:00:00.000Z","authors":"mfocko","tags":["2024-January","2024","January"]},"prevItem":{"title":"Week 5 in Packit","permalink":"/posts/weekly/2024/week-5"},"nextItem":{"title":"Week 3 in Packit","permalink":"/posts/weekly/2024/week-3"}},"content":"## Week 4 (January 23rd \u2013 January 29th)\\n\\n- `pull-from-upstream` and `propose-downstream` commands now have the `--sync-acls` option that enables syncing the ACLs between dits-git repo and fork. The default behaviour was, however, **changed to not sync** the ACLs. ([packit#2214](https://github.com/packit/packit/pull/2214))\\n- Packit now properly handles exceptions when syncing ACLs during release syncing. ([packit#2213](https://github.com/packit/packit/pull/2213))\\n- `allowed_pr_authors` and `allowed_committers` now allow specifying groups and also aliases `all_admins` and `all_committers` (corresponding to the access to the repository). ([packit-service#2320](https://github.com/packit/packit-service/pull/2320))\\n- ogr now supports 2 new methods for Pagure: one for getting users with specified access rights and one for getting members of a group. ([ogr#834](https://github.com/packit/ogr/pull/834))"},{"id":"/2024/week-3","metadata":{"permalink":"/posts/weekly/2024/week-3","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-3.md","source":"@site/weekly/2024/week-3.md","title":"Week 3 in Packit","description":"Week 3 (January 16th \u2013 January 22nd)","date":"2024-01-22T00:00:00.000Z","formattedDate":"January 22, 2024","tags":[{"label":"2024-January","permalink":"/posts/weekly/tags/2024-january"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"January","permalink":"/posts/weekly/tags/january"}],"readingTime":0.5,"hasTruncateMarker":false,"authors":[{"name":"Franti\u0161ek Lachman","email":"flachman@redhat.com","url":"https://github.com/lachmanfrantisek","imageURL":"https://github.com/lachmanfrantisek.png","key":"flachman"}],"frontMatter":{"title":"Week 3 in Packit","date":"2024-01-22T00:00:00.000Z","authors":"flachman","tags":["2024-January","2024","January"]},"prevItem":{"title":"Week 4 in Packit","permalink":"/posts/weekly/2024/week-4"},"nextItem":{"title":"Week 2 in Packit","permalink":"/posts/weekly/2024/week-2"}},"content":"## Week 3 (January 16th \u2013 January 22nd)\\n\\n- Packit now properly handles exceptions when syncing ACLs during release syncing. ([packit#2213](https://github.com/packit/packit/pull/2213))\\n- We have fixed a bug in handling chroot-specific configuration once the chroots themselves are updated. ([packit#2194](https://github.com/packit/packit/pull/2194))\\n- We have increased the number of retries of Fedora release syncing for situations where the tarball is uploaded some time after the release happens. ([packit-service#2307](https://github.com/packit/packit-service/pull/2307))\\n- There is a new API endpoint `/bodhi-updates` for getting information about Bodhi updates submitted by Packit. ([packit-service#2310](https://github.com/packit/packit-service/pull/2310))\\n- For `/packit test` command, you can now also use `-i` and `--id` aliases for `--identifier` option. ([packit-service#2309](https://github.com/packit/packit-service/pull/2309))"},{"id":"/2024/week-2","metadata":{"permalink":"/posts/weekly/2024/week-2","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-2.md","source":"@site/weekly/2024/week-2.md","title":"Week 2 in Packit","description":"Week 2 (January 9th \u2013 January 15th)","date":"2024-01-15T00:00:00.000Z","formattedDate":"January 15, 2024","tags":[{"label":"2024-January","permalink":"/posts/weekly/tags/2024-january"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"January","permalink":"/posts/weekly/tags/january"}],"readingTime":0.195,"hasTruncateMarker":false,"authors":[{"name":"Laura Barcziov\xe1","email":"lbarczio@redhat.com","url":"https://github.com/lbarcziova","imageURL":"https://github.com/lbarcziova.png","key":"lbarczio"}],"frontMatter":{"title":"Week 2 in Packit","date":"2024-01-15T00:00:00.000Z","authors":"lbarczio","tags":["2024-January","2024","January"]},"prevItem":{"title":"Week 3 in Packit","permalink":"/posts/weekly/2024/week-3"},"nextItem":{"title":"Week 1 in Packit","permalink":"/posts/weekly/2024/week-1"}},"content":"## Week 2 (January 9th \u2013 January 15th)\\n\\n- We have fixed the behaviour of identifying the most recent git tag. This has previously caused issues\\n when building SRPMs for projects with different version tags in different branches.\\n ([packit-service#2302](https://github.com/packit/packit-service/pull/2302))"},{"id":"/2024/week-1","metadata":{"permalink":"/posts/weekly/2024/week-1","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2024/week-1.md","source":"@site/weekly/2024/week-1.md","title":"Week 1 in Packit","description":"Week 1 (January 2nd \u2013 January 8th)","date":"2024-01-08T00:00:00.000Z","formattedDate":"January 8, 2024","tags":[{"label":"2024-January","permalink":"/posts/weekly/tags/2024-january"},{"label":"2024","permalink":"/posts/weekly/tags/2024"},{"label":"January","permalink":"/posts/weekly/tags/january"}],"readingTime":0.28,"hasTruncateMarker":false,"authors":[{"name":"Nikola Forr\xf3","email":"nforro@redhat.com","url":"https://github.com/nforro","imageURL":"https://github.com/nforro.png","key":"nforro"}],"frontMatter":{"title":"Week 1 in Packit","date":"2024-01-08T00:00:00.000Z","authors":"nforro","tags":["2024-January","2024","January"]},"prevItem":{"title":"Week 2 in Packit","permalink":"/posts/weekly/2024/week-2"},"nextItem":{"title":"2023","permalink":"/posts/weekly/2023"}},"content":"## Week 1 (January 2nd \u2013 January 8th)\\n\\n- We have changed the behaviour of loading Packit configuration for `koji_build` and `bodhi_update` jobs.\\n For both of them, the behaviour is the same as for `pull_from_upstream` - the configuration is taken\\n from the default branch of the dist-git repository (usually `rawhide`) and other branches are ignored.\\n ([packit-service#2295](https://github.com/packit/packit-service/pull/2295))"},{"id":"/2023","metadata":{"permalink":"/posts/weekly/2023","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2023.md","source":"@site/weekly/2023.md","title":"2023","description":"Let\'s see what happened in Packit in 2023.","date":"2024-01-01T00:00:00.000Z","formattedDate":"January 1, 2024","tags":[{"label":"2023","permalink":"/posts/weekly/tags/2023"}],"readingTime":19.78,"hasTruncateMarker":true,"authors":[],"frontMatter":{"title":"2023","date":"2024-01-01T00:00:00.000Z","tags":["2023"]},"prevItem":{"title":"Week 1 in Packit","permalink":"/posts/weekly/2024/week-1"},"nextItem":{"title":"Packit workshop - Fedora Community Edition","permalink":"/posts/weekly/2023/packit-workshop"}},"content":"Let\'s see what happened in Packit in 2023.\\n\\n\x3c!--truncate--\x3e\\n\\n## Week 0 \ud83c\udf04 (December 20th 2022 \u2013 January 2nd 2023)\\n\\n- ogr now raises `GitForgeInternalError` rather than `PagureAPIException` when\\n getting 50x response from the Pagure API. This should increase usability as\\n those tasks will be retried.\\n ([ogr#762](https://github.com/packit/ogr/pull/762))\\n- Packit now puts the correct release number into the changelog when the\\n Release tag is reset during propose-downstream.\\n ([packit#1816](https://github.com/packit/packit/pull/1816)))\\n\\n## Week 1 (January 3rd \u2013 January 9th)\\n\\n- SRPMs for projects that installed the GitHub App before September 6th and\\n don\'t have `srpm_build_deps` defined are now built in Copr as well.\\n ([packit-service#1822](https://github.com/packit/packit-service/pull/1822))\\n- We have fixed a bug in dashboard that linked `null` as a Copr build for\\n Testing Farm runs that do not require any Copr build.\\n ([dashboard#200](https://github.com/packit/dashboard/pull/200))\\n- All classes including `Specfile` itself can now be copied using the standard\\n `copy()` and `deepcopy()` functions from `copy` module.\\n ([specfile#176](https://github.com/packit/specfile/pull/176))\\n\\n## Week 2 (January 10th \u2013 January 16th)\\n\\n- When configuring Copr chroot (target in Packit terminology) specific configuration, make sure to specify additional_modules as a string: module names separated with a comma, example: \\"httpd:2.4,python:4\\". ([packit#1826](https://github.com/packit/packit/pull/1826))\\n- We have fixed a bug which caused long Copr build end reporting time on a few occurrences. ([packit-service#1838](https://github.com/packit/packit-service/pull/1838))\\n- A few fixes has been implemented to make it possible to use [`propose-downstream` job](https://packit.dev/docs/configuration/#propose_downstream) on GitLab. ([packit-service#1842](https://github.com/packit/packit-service/pull/1842), [packit-service#1844](https://github.com/packit/packit-service/pull/1844), [packit-service#1845](https://github.com/packit/packit-service/pull/1845), [packit-service#1846](https://github.com/packit/packit-service/pull/1846))\\n\\n## Week 3-4 (January 17th \u2013 January 30th)\\n\\n- Users can now re-trigger _bodhi_update_ and _koji_build_ jobs by `/packit create-update`\\n and `/packit koji-update` comments in an issue opened by Packit in the configured `issue_repository` if anything\\n went wrong during these jobs. ([packit-service#1796](https://github.com/packit/packit-service/pull/1796))\\n- All Copr projects created by Packit now default to `enable_net=False`: our documentation stated this, but it\\n wasn\'t the case. This is now corrected. ([packit#1825](https://github.com/packit/packit/pull/1825))\\n- You can now specify `update_release: false` in the configuration to tell Packit not to change the Version and\\n Release in the spec file. It works the same as `--no-update-release` (renamed from now deprecated `--no-bump`) in\\n the CLI. ([packit#1827](https://github.com/packit/packit/pull/1827))\\n- Packit now supports setting `module_hotfixes` for Copr projects.\\n ([packit#1829](https://github.com/packit/packit/pull/1829))\\n- Packit now also allows passing in free-form parameters to Testing Farm in order to support all of its\\n options immediately once they are added. The parameters can be passed through the `tf_extra_params` config option.\\n The free-form dictionary must follow the structure of Testing Farm POST requests. See [our documentation](https://packit.dev/docs/testing-farm/)\\n and examples for more information. ([packit-service#1853](https://github.com/packit/packit-service/pull/1853))\\n- Fixed a bug in section parsing that caused sections to be ignored when there were macro definitions spread\\n across the spec file and not cumulated at the top. ([specfile#191](https://github.com/packit/specfile/pull/191))\\n- Also fixed the infinite loop that occurred when section options were followed by whitespace.\\n ([specfile#197](https://github.com/packit/specfile/pull/197))\\n\\n## Weeks 5\u20136 (February 1st \u2013 February 13th)\\n\\n- You can now use `--srpm` option with the `packit build locally` CLI command. ([packit#1810](https://github.com/packit/packit/pull/1810))\\n- You will newly see news about Packit as a footer of the GitHub check runs summary. ([packit-service#1881](https://github.com/packit/packit-service/pull/1881))\\n- Packit now groups related builds and test runs (e.g. triggered by the same event, just different chroots) together. In the future, this will allow better presentation of the overall pipelines (e.g. in the dashboard). We now also create database entries before sending requests to external service (e.g. Testing Farm), therefore failures will be more visible in the dashboard. ([packit-service#1787](https://github.com/packit/packit-service/pull/1787))\\n\\n## Week 7 (February 14th \u2013 February 20th)\\n\\n- Packit now provides `PACKIT_PROJECT_VERSION` environment variable when running `changelog-entry` action. ([packit#1853](https://github.com/packit/packit/pull/1853))\\n- Packit CLI now requires bodhi in version 7.0.0 at minimum. ([packit#1844](https://github.com/packit/packit/pull/1844))\\n- You can now specify branches for a job triggered by a commit with a regex. ([packit-service#1909](https://github.com/packit/packit-service/pull/1909))\\n\\n## Week 8 (February 21st \u2013 February 27th)\\n\\n- `packit validate-config` CLI command now provides details about errors when it cannot parse the config file. ([packit#1861](https://github.com/packit/packit/pull/1861))\\n- `--update-release`/`--no-update-release` CLI flag now affects only `Release`, not `Version`. ([packit#1857](https://github.com/packit/packit/pull/1857))\\n- Packit does fewer API calls when searching for the package configuration file in remote repositories. ([packit#1846](https://github.com/packit/packit/pull/1846))\\n- Commit statuses/check names will now contain the name of the branch or release for the build and test jobs with `commit` or `release` trigger.\\n This will prevent the collision of the names. ([packit-service#1920](https://github.com/packit/packit-service/pull/1920))\\n\\n## Week 9 (February 28th \u2013 March 6th)\\n\\n- Aliases logic was updated to account for the upcoming Fedora release (Bodhi now marks such release as `frozen`). From now on, Fedora 38 updates will be created even when the release is frozen. ([packit#1863](https://github.com/packit/packit/pull/1863))\\n- `packit validate-config` now correctly checks glob-patterns in \'files_to_sync\' ([packit#1865](https://github.com/packit/packit/pull/1865)) and provides details about errors when it cannot parse a config file. ([packit#1861](https://github.com/packit/packit/pull/1861))\\n- Pull-from-upstream jobs are now displayed on our dashboard \ud83e\udd73 https://dashboard.packit.dev/jobs/pull-from-upstreams ([packit-service#1951](https://github.com/packit/packit-service/pull/1951), [packit-service#1939](https://github.com/packit/packit-service/pull/1939))\\n- Packit will no longer automatically request access to the forks on GitLab. This will prevent us from spamming one-time contributors with requesting the access, whereas the regular contributors can add Packit following the instructions from the comments on the MRs, so they can receive the results of Packit pipeline right from the commit statuses. ([packit-service#1946](https://github.com/packit/packit-service/pull/1946))\\n- Packit will retry tasks that are interrupted by a worker shutdown. This should improve throughput and reduce cases where there is no outcome, i.e. \\"builds should have been done but nothing happened\\". ([packit-service#1935](https://github.com/packit/packit-service/pull/1935))\\n- OGR now understands a few community-hosted GitLab instances that could not be determined automatically from the hostname. Thanks to that, you don\'t need to hardcode these instances to be mapped correctly. ([ogr#775](https://github.com/packit/ogr/pull/775))\\n\\nThank you, [@SpyTec](https://github.com/SpyTec) for so many [wonderful changes in our dasbhoard](https://github.com/packit/dashboard/pulls?q=is%3Apr+author%3ASpyTec).\\n\\n## Week 10 (March 7th \u2013 March 13th)\\n\\n- Parsing the spec file by RPM is now performed only if really necessary, greatly improving performance in certain scenarios. ([specfile#212](https://github.com/packit/specfile/pull/212))\\n\\n## Week 11 (March 14th \u2013 March 20th)\\n\\n- Packit now uses the `get_current_version` action defined by the user to retrieve version before updating the specfile %setup macro (if any). ([packit#1886](https://github.com/packit/packit/pull/1886))\\n\\n## Week 12 (March 21st \u2013 March 27th)\\n\\n- \'upstream_tag_template\' is now also used when looking for the latest version tag in Git.\\n This allows upstream repositories to mix different tag-patterns in the same repository,\\n but consider only one to tell the latest version.\\n ([packit#1891](https://github.com/packit/packit/pull/1891))\\n\\n## Week 13 (March 28th \u2013 April 3rd)\\n\\n- Packit now preserves `%autorelease` during `propose_downstream` and `pull_from_upstream`. ([packit#1904](https://github.com/packit/packit/pull/1904))\\n- Since in GitLab, it is not possible to overwrite the pending statuses, Packit now provides more generic descriptions and URLs when setting the first pending status. ([packit-service#1975](https://github.com/packit/packit-service/pull/1975))\\n\\n## Weeks 14\u201315 (April 3rd \u2013 April 17th)\\n\\n- `packit source-git` related commands can skip dist-git repos, where the git trailer is not found, when looking for the right dist-git dir where to work. ([packit#1938](https://github.com/packit/packit/pull/1938))\\n- Tmt tests can now be run with fmf root outside of git root ([packit#1936](https://github.com/packit/packit/pull/1936))\\n- Commits created by Packit no longer contain the \\"Signed-off-by\\" tag. ([packit#1934](https://github.com/packit/packit/pull/1934))\\n- Packit\'s source_git functionality installs/loads the `_packitpatch` script in a more reliable manner that doesn\'t rely on deprecated setuptools functionality. ([packit#1926](https://github.com/packit/packit/pull/1926))\\n- Packit now supports monorepo configuration in CLI ([packit#1864](https://github.com/packit/packit/pull/1864))\\n- Packit should now correctly catch the logs if any of the user actions fail during `propose_downstream`. ([packit#1939](https://github.com/packit/packit/pull/1939))\\n- Packit now resets `Release` field in dist-git spec file to 1 when the version in upstream spec file is not up-to-date with the release that triggered `propose_downstream`. ([packit#1940](https://github.com/packit/packit/pull/1940))\\n\\n## Week 16 (April 18th \u2013 April 24th)\\n\\n- Packit now complies with [PEP 621](https://peps.python.org/pep-0621/) and stores project metadata in `pyproject.toml`. ([packit#1913](https://github.com/packit/packit/pull/1913))\\n- Packit now properly respects `upstream_ref` for tags that start with \\"a\\", \\"b\\", \\"c\\", \\"e\\", \\"n\\", \\"r\\", \\"s\\". ([packit#1943](https://github.com/packit/packit/pull/1943))\\n- Packit Service now supports multi package configuration (a.k.a. monorepo configuration). ([packit-service#1982](https://github.com/packit/packit-service/pull/1982))\\n\\n## Week 17-18 (April 25th \u2013 May 3rd)\\n\\n- Detection of `%autorelease` usage in dist-git spec file during `propose-downstream` and `pull-from-upstream` has been improved and Packit will always preserve it. ([packit#1949](https://github.com/packit/packit/pull/1949))\\n- We have fixed an issue that prevented you from building in Copr and Koji on release in the GitLab upstream. ([packit-service#2027](https://github.com/packit/packit-service/pull/2027))\\n- TMT tests can now be run with FMF root outside of git root. ([packit-service#2007](https://github.com/packit/packit-service/pull/2007))\\n- When reacting to branch pushes, Packit now correctly checks whether the branch name matches the configuration for the test jobs with configured `commit` trigger. ([packit-service#2015](https://github.com/packit/packit-service/pull/2015))\\n- The `propose-downstream` job triggered by an issue comment now correctly loads the configuration from the upstream repository. ([packit-service#2021](https://github.com/packit/packit-service/pull/2021))\\n- Packit is newly on Mastodon. Or, more specifically, on Fosstodon.\\n Follow [@packit@fosstodon.org](https://fosstodon.org/@packit) and be one of the first to know about all the news!\\n\\n## Week 18 (May 4th - May 9th)\\n\\nWe have experienced issues with automatic Bodhi updates that we are investigating.\\nIn case you miss a Bodhi update, you can\\n[retrigger the job](https://packit.dev/docs/fedora-releases-guide/#retriggering-2) via `/packit create-update`\\ncomment in a dist-git pull request.\\nBesides that, during this short week (another Czech Republic public holiday) we didn\'t manage to implement\\nany significant new features.\\n\\n## Week 19 (May 9th \u2013 May 15th)\\n\\n- Packit now doesn\'t react to its own comments on Pagure and GitLab (on GitHub, this was already implemented).\\n ([packit-service#2048](https://github.com/packit/packit-service/pull/2048))\\n\\n## Week 20 (May 16th \u2013 May 22nd)\\n\\n- We have implemented a denylisting mechanism allowing us to denylist namespaces/projects to prevent misuse of our service. ([packit-service#2046](https://github.com/packit/packit-service/pull/2046))\\n- Packit will now additionally require for each test job requiring build a build job definition to be present in the Packit configuration file. ([packit-service#2012](https://github.com/packit/packit-service/pull/2012))\\n- Packit now checks whether the configured architecture for the test target is supported by Testing Farm and in case it\'s not supported, Packit doesn\'t submit these test requests. ([packit-service#2053](https://github.com/packit/packit-service/pull/2053))\\n\\n## Week 21 (May 23rd \u2013 May 29th)\\n\\n- Unsuccessful Image Builder requests now provide error details so you can fix the Image configuration. ([packit#1981](https://github.com/packit/packit/pull/1981))\\n- Copr projects created by Packit will not follow the Fedora branching from now. This decision has been made to lower the load on Copr from the temporary Copr projects created, mainly, for the PR builds. If you are releasing your packages to the Copr, please use the new setting `follow_fedora_branching`.\\n Already existing projects are not affected by this change and it is also not enforced with the custom Copr repositories. ([packit#1970](https://github.com/packit/packit/pull/1970))\\n- Additional artifact(s) passed as `artifacts` in the `tf_extra_params` dictionary will be now combined with the artifact passed by Packit instead of rewriting it. ([packit-service#2056](https://github.com/packit/packit-service/pull/2056))\\n- Specfile library now handles multiple `%changelog` sections. ([specfile#230](https://github.com/packit/specfile/pull/230))\\n\\n## Week 22 (May 30th \u2013 June 5th)\\n\\n- Packit will now filter the pull requests based on the target branch if the `branch` is specified in the particular job configuration. ([packit-service#2074](https://github.com/packit/packit-service/pull/2074))\\n- Packit now supports `manual_trigger` in the configuration that allows you to make jobs run only when explicitly triggered by a comment. ([packit-service#2069](https://github.com/packit/packit-service/pull/2069))\\n\\n## Week 23 (June 6th \u2013 June 12th)\\n\\n- Our dashboard now shows projects in a table instead of the cards.\\n ([dashboard#267](https://github.com/packit/dashboard/pull/267))\\n- `/packit test` command has two new options:\\n\\n With `--identifier` option, Testing Farm will trigger only jobs with that identifier.\\n ([packit-service#2079](https://github.com/packit/packit-service/pull/2079))\\n\\n Also, it is now possible to specify labels for a job and trigger tests based on labels\\n using a `--labels` option of the `/packit test` command.\\n ([packit#1988](https://github.com/packit/packit/pull/1988),\\n [packit-service#2088](https://github.com/packit/packit-service/pull/2088))\\n\\n- If the `vm_image_build job` doesn\'t have Copr project/owner configured,\\n Copr project used for the latest Copr build of the pull request will be now used.\\n ([packit-service#2080](https://github.com/packit/packit-service/pull/2080))\\n- Fixed filters in `files_to_sync` not being applied properly.\\n ([packit#1977](https://github.com/packit/packit/pull/1977))\\n- The issue that could\'ve caused inconsistencies when tests from a PR\\n were supposed to be merged during the test runs on the Testing Farm has been fixed.\\n ([packit-service#2090](https://github.com/packit/packit-service/pull/2090))\\n\\n## Week 24 (June 13th \u2013 June 19th)\\n\\n- Packit now includes dist-git branch in the title of the PRs for `propose-downstream` and `pull-from-upstream`.\\n ([packit#1996](https://github.com/packit/packit/pull/1996))\\n\\n- Many dashboard issues have been fixed during the\\n [Contribute to an Open Source Service](https://sched.co/1MvMM)\\n workshop at [DevConf.CZ](https://www.devconf.info/cz/).\\n [Stef Walter](https://github.com/stefwalter),\\n [Erik Gustavsson](https://github.com/SpyTec),\\n [Roman Braunstingl](https://github.com/RFJBraunstingl),\\n [Jaroslav Reznik](https://github.com/jreznik),\\n [Christophe de Dinechin](https://github.com/c3d),\\n [Gris Ge](https://github.com/cathay4t)\\n and [David Duncan](https://github.com/davdunc),\\n thank you for your contribution!\\n ([dashboard#291](https://github.com/packit/dashboard/pull/291),\\n [dashboard#292](https://github.com/packit/dashboard/pull/292),\\n [dashboard#293](https://github.com/packit/dashboard/pull/293),\\n [dashboard#294](https://github.com/packit/dashboard/pull/294),\\n [dashboard#295](https://github.com/packit/dashboard/pull/295))\\n\\n## Week 25 (June 21st \u2013 June 27th)\\n\\n- If you are interested about the manual triggering deployed two weeks ago, David Kornel and Jakub Stejskal published [a blog post](https://fedoramagazine.org/how-to-use-testing-farm-outside-of-rhel/) about this on fedoramagazine.org.\\n- Copr builds configured as a monorepo job will now be built in one Copr project together. The bug with overwriting the statuses for monorepo jobs has been fixed as well. ([packit-service#2097](https://github.com/packit/packit-service/pull/2097))\\n\\n## Week 26 (June 27th \u2013 July 3rd)\\n\\n- The bug which prevented errors on Testing Farm request submission from being\\n correctly propagated to the user was fixed.\\n ([packit-service#2103](https://github.com/packit/packit-service/pull/2103))\\n- `pull_from_upstream` jobs can now be retriggered with a comment\\n `/packit pull-from-upstream` in a dist-git pull request.\\n ([packit-service#2087](https://github.com/packit/packit-service/pull/2087))\\n\\n## Week 27 (July 4th \u2013 July 10th)\\n\\n- Packit now correctly reloads upstream specfile after running `pre-sync` action. ([packit#2006](https://github.com/packit/packit/pull/2006))\\n\\n## Week 28 (July 11th \u2013 July 17th)\\n\\n- Packit now includes instructions on how to checkout the dist-git PR locally when syncing the release.\\n ([packit-service#2116](https://github.com/packit/packit-service/pull/2116))\\n- We have fixed a bug in processing options of `%prep` macros in our `specfile` library. For instance, when a quoted\\n string appeared inside an expression expansion, it could lead to improper parsing, rendering the spec file invalid\\n after accessing the options. ([specfile#253](https://github.com/packit/specfile/pull/253))\\n- packit.dev has a new format! As the content has expanded a lot in the recent year, we decided to switch to using\\n [Docosaurus](https://docusaurus.io/):\\n now all the documentation is in one place and this format also enables additional features for our blog posts.\\n ([packit.dev#694](https://github.com/packit/packit.dev/pull/694))\\n\\n## Weeks 29\u201330 (July 18th \u2013 July 31st)\\n\\n- With plenty of team members on vacation, we didn\'t manage to implement any significant new features during these two weeks.\\n\\n## Week 31 (August 1st \u2013 August 7th)\\n\\n- Licenses in Packit specfiles are now confirmed to be SPDX-compatible. (example PR: [packit#2026](https://github.com/packit/packit/pull/2026))\\n If you are interested in more details, see a [talk](https://www.youtube.com/watch?v=Hjhe6jtx3Zw&t=8651s) from Flock 2023 by Mirek.\\n\\n## Week 32 (August 8th \u2013 August 14th)\\n\\n- Two new configuration options for filtering when getting latest upstream release tag were introduced: `upstream_tag_include` and `upstream_tag_exclude`. They should contain a Python regex that can be used as an argument in `re.match`. ([packit#2030](https://github.com/packit/packit/pull/2030), [packit-service#2138](https://github.com/packit/packit-service/pull/2138))\\n- Retriggering of `pull-from-upstream` via a comment will now use the correct configuration file from the default dist-git branch. ([packit-service#2140](https://github.com/packit/packit-service/pull/2140))\\n- The `pull-from-upstream` job can now be used with upstream repos that are not hosted on a supported git forge. ([packit-service#2137](https://github.com/packit/packit-service/pull/2137))\\n\\n## Week 34 (August 22nd \u2013 August 28th)\\n\\n- We have fixed a bug in `packit source-git init` caused by the changed behaviour in the newer version of rpmbuild. ([packit#2048](https://github.com/packit/packit/pull/2048))\\n- We have fixed an issue in our API endpoint that could cause DoS until manual intervention from our team. ([packit-service#2164](https://github.com/packit/packit-service/pull/2164))\\n- We have fixed a bug causing broken retriggering of Github checks. ([packit-service#2161](https://github.com/packit/packit-service/pull/2161))\\n- SRPM build commit statuses, for monorepos projects, are now being correctly updated. ([packit-service#2157](https://github.com/packit/packit-service/pull/2157))\\n- We have fixed the bug resulting in incorrect reporting for tests when retriggering a build of a different target that was not configured for tests. ([packit-service#2144](https://github.com/packit/packit-service/pull/2144))\\n- We have fixed an issue that caused retriggers of Testing Farm to fail, if you specified any labels in the comment and had one or more test job definitions without any labels specified. ([packit-service#2156](https://github.com/packit/packit-service/pull/2156))\\n- Macro definitions and tags gained a new `valid` attribute. A macro definition/tag is considered valid if it doesn\'t appear in a false branch of any condition appearing in the spec file. ([specfile#276](https://github.com/packit/specfile/pull/276))\\n\\n## Week 35 (August 29th \u2013 September 4th)\\n\\n- Now Packit exposes `PACKIT_PACKAGE_NAME`, `PACKIT_UPSTREAM_PACKAGE_NAME` and `PACKIT_DOWNSTREAM_PACKAGE_NAME` env variables to all the actions. ([packit#2061](https://github.com/packit/packit/pull/2061))\\n- Packit now sets `PACKIT_UPSTREAM_REPO` and `PACKIT_DOWNSTREAM_REPO` environment variables for release syncing actions. The variables represent paths where the respective git repositories are cloned ([packit-service#2166](https://github.com/packit/packit-service/pull/2166))\\n- We have fixed a bug causing issues with displaying some `Project` views on our dashboard. ([packit-service#2165](https://github.com/packit/packit-service/pull/2165))\\n\\n## Week 36 (September 5th \u2013 September 11th)\\n\\n- Packit now supports `commit-message` action that can be used to override the default commit message produced by Packit during `propose-downstream` or `pull-from-upstream`. Please pay attention to [our documentation](https://packit.dev/docs/configuration/actions#commit-message) with regards to the usage of this action. ([packit#2070](https://github.com/packit/packit/pull/2070))\\n- Packit CLI now supports testing the `pull-from-upstream` workflow.\\n Use the `packit pull-from-upstream` command from the `packit` RPM package. ([packit#2063](https://github.com/packit/packit/pull/2063))\\n- Packit now passes `initiator` context for tmt to the Testing Farm. You can use [this option](https://tmt.readthedocs.io/en/latest/spec/context.html#initiator) to run or skip certain tests when they\'re run by Packit. ([packit-service#2176](https://github.com/packit/packit-service/pull/2176))\\n- Testing Farm started additionally exposing regexes on top of the exact compose names in the /composes/ endpoints, and we now support this as well when checking the validity of compose. ([packit-service#2168](https://github.com/packit/packit-service/pull/2168))\\n- We have disabled the jitter for retrying Bodhi update tasks to prevent race conditions causing not created updates. ([packit-service#2170](https://github.com/packit/packit-service/pull/2170))\\n- We have fixed a bug in `get_fork` method for Pagure about checking the usernames for a match when going through existing forks. ([ogr#800](https://github.com/packit/ogr/pull/800))\\n\\n## Week 37 (September 12th \u2013 September 18th)\\n\\n- If you have concerns about Packit uploading new archives to lookaside cache before creating a pull request, you can newly set `upload_sources` to False to disable this. ([packit#2086](https://github.com/packit/packit/pull/2086))\\n- We have introduced a new configuration option `notifications.failure_comment.message` that enables notifying users on failure via a comment using the configured message. ([packit-service#2182](https://github.com/packit/packit-service/pull/2182))\\n\\n## Week 38 (September 19th \u2013 September 25th)\\n\\n- As part of the effort of implementing release syncing for CentOS Stream,\\n Packit now supports the `pkg_tool` option in the config\\n (at the top-level or with specific packages when using the monorepo syntax).\\n This option can be used for switching between `fedpkg` or `centpkg`.\\n ([packit#2085](https://github.com/packit/packit/pull/2085))\\n- When updating the `Version` tag during `propose_downstream` or `pull_from_upstream`,\\n Packit now tries to update referenced macros (if any) rather than overwriting the references.\\n ([packit#2087](https://github.com/packit/packit/pull/2087))\\n\\n## Week 39 (September 26th \u2013 October 2nd)\\n\\n- When using packit CLI you can now specify bugs resolved by an update by `-b` or `--resolve-bug` option for `propose-downstream` and `pull-from-upstream` commands. The values will be added by default to the changelog and commit message and provided in `commit-message` and `changelog-entry` actions as `PACKIT_RESOLVED_BUGS` env variable. ([packit#2094](https://github.com/packit/packit/pull/2094))\\n- Packit-service now automatically adds bugzilla created by Upstream Release Monitoring as `- Resolves {bugzilla} ` to the changelog (or commit if autochangelog is used) and provides the value in `commit-message` and `changelog-entry` actions as `PACKIT_RESOLVED_BUGS` env variable. When retriggering the `pull-from-upstream` from comment, one can also specify the bug(s) as `/packit pull-from-upstream --resolved-bugs rhbz#123,rhbz#125` and Packit will do the same. ([packit-service#2193](https://github.com/packit/packit-service/pull/2193))\\n- You can now configure `notifications.failure_comment.message` also for downstream jobs, where the configured message will be used as an extension of the comment added by default by Packit. ([packit-service#2199](https://github.com/packit/packit-service/pull/2199))\\n\\n## Week 40 (October 3rd \u2013 October 9th)\\n\\n- We have fixed an issue that you could encounter when running the Packit from the CLI that caused misinterpretation of the repository to be an upstream repo instead of a downstream. ([packit#2117](https://github.com/packit/packit/pull/2117))\\n- Packit now also detects resolved bugs in the default update notes (created from changelog diff) and assigns these when submitting the Bodhi updates. ([packit#2111](https://github.com/packit/packit/pull/2111))\\n- We have fixed an issue that prevented automated allowlisting in the Packit Service. ([packit#2113](https://github.com/packit/packit/pull/2113))\\n- Packit now exports `PACKIT_UPSTREAM_PACKAGE_NAME`, `PACKIT_DOWNSTREAM_PACKAGE_NAME` and `PACKIT_CONFIG_PACKAGE_NAME` also in the `changelog_entry` action. ([packit#2103](https://github.com/packit/packit/pull/2103))\\n- Packit now posts a comment with a link to the Packit dashboard to the pull requests created in Fedora dist-git when syncing the release. ([packit-service#2215](https://github.com/packit/packit-service/pull/2215))\\n\\n## Week 41 (October 10th \u2013 October 16th)\\n\\n- (_breaking_) Packit no longer accepts `packit.json` or `.packit.json` as a configuration file name.\\n ([packit#2123](https://github.com/packit/packit/pull/2123))\\n- We have implemented several improvements in syncing the release downstream:\\n - Packit now updates ACL of its own dist-git forks to allow users and groups with commit rights to the original\\n dist-git repo to push directly to a fork. ([packit#2112](https://github.com/packit/packit/pull/2112))\\n - Packit now also properly cleans up the branch after syncing the release which should prevent unwanted files\\n (e.g. tarballs) being committed to dist-git. ([packit#2125](https://github.com/packit/packit/pull/2125))\\n - We have adjusted the way how Packit includes the resolved bugzillas in the commit messages created when syncing the release\\n downstream so that the resolved bugzillas are included in changelog when using `%autochangelog`.\\n ([packit#2126](https://github.com/packit/packit/pull/2126))\\n- Packit now reacts to retriggering comments for downstream jobs by commenting on the same issue/PR and\\n providing information about the jobs. ([packit-service#2222](https://github.com/packit/packit-service/pull/2222))\\n- We have fixed an issue that prevented you from running the jobs on the GitLab.com due to failing resolution\\n of the upstream/downstream relationship for the cloned project. ([packit#2120](https://github.com/packit/packit/pull/2120))\\n- Packit now triggers the build for the `/packit test` comment command if the last build was not successful.\\n ([packit-service#2228](https://github.com/packit/packit-service/pull/2228))\\n\\nAnd special thanks to [@SpyTec](https://github.com/SpyTec)\\nfor multiple wonderful [dashboard improvements](https://github.com/packit/dashboard/pulls?q=is%3Apr+author%3ASpyTec+merged%3A2023-10-10..2023-10-16)!\\n\\n## Week 43 (October 24th \u2013 October 30th)\\n\\n- Packit no longer downloads sources excluded using spec file conditions. ([packit#2132](https://github.com/packit/packit/pull/2132))\\n\\n## Week 44 (October 31st \u2013 November 6th)\\n\\n- Dist tag (`%{?dist}`) is now enforced when updating release during SRPM creation. ([packit#2106](https://github.com/packit/packit/pull/2106))\\n\\n## Week 45 (November 7th \u2013 November 13th)\\n\\n- Now Packit allows `~^+` (special characters) in a tag (used for building the version string). ([packit#2154](https://github.com/packit/packit/pull/2154))\\n- Downstream Koji builds are now shown in a separate table in `/jobs/downstream-koji-builds` on dashboard and are also accessible via `/api/koji-builds` API endpoint. ([packit-service#2244](https://github.com/packit/packit-service/pull/2244), [packit-service#2249](https://github.com/packit/packit-service/pull/2249), [dashboard#354](https://github.com/packit/dashboard/pull/354))\\n\\n## Week 46 (November 14th \u2013 November 20th)\\n\\n- Packit now supports pre-release version in `propose_downstream` and `pull_from_upstream`.\\n A spec file update might be required, see [the documentation](/docs/pre-releases) for more details.\\n ([packit#2149](https://github.com/packit/packit/pull/2149))\\n - In relation to that, specfile library has a new method, `Specfile.update_version()`, that allows updating spec file\\n version even if it is a pre-release. ([specfile#317](https://github.com/packit/specfile/pull/317))\\n- Packit can now check, using the new `update_version_mask` configuration option, that the proposed version of new release\\n and the current version of the dist-git branch are compatible and sync the dist-git branch only in that case.\\n ([packit#2156](https://github.com/packit/packit/pull/2156))\\n- Packit is now able to get the version from spec file even if the `Version` tag is not present in the specfile directly,\\n but e.g. imported from another file. ([packit#2157](https://github.com/packit/packit/pull/2157))\\n- `PACKIT_COPR_PROJECT` env var that is exposed to Testing Farm now includes the Copr project of the additional build\\n specified in comment, if present. ([packit-service#2253](https://github.com/packit/packit-service/pull/2253))\\n\\n## Week 47 (November 21st \u2013 November 27th)\\n\\n- Packit now correctly sets the specfile content (e.g. changelog entry) even if it syncs the specfile from upstream for the first time. ([packit#2170](https://github.com/packit/packit/pull/2170))\\n\\n## Week 48 (November 28th \u2013 December 4th)\\n\\n- Packit now links the information related to upstream events in PRs opened when syncing a release.\\n ([packit#2173](https://github.com/packit/packit/pull/2173))\\n\\n- When accessing tags or macro definitions by name, specfile library now takes validity into account\\n when looking for the best match. For example if there are two instances of `Version` tag,\\n one in the true and one in the false branch of a condition, `Specfile.version` will always access\\n the one that is in the true branch.\\n This also applies to Packit when syncing a release and updating value of `Version` tag.\\n ([specfile#328](https://github.com/packit/specfile/pull/328))\\n\\n## Week 49 (December 5th \u2013 December 11th)\\n\\n- We have introduced new configuration options `test_command.default_labels` and `test_command.default_identifier` that are used by default when running `/packit test` comment command without any arguments (instead of specifying them via `--labels`/`--identifier`). ([packit-service#2270](https://github.com/packit/packit-service/pull/2270))\\n\\n- We have fixed a bug that GithubRelease.url returned an API URL. ([ogr#824](https://github.com/packit/ogr/pull/824))\\n\\n## Week 50 (December 12th \u2013 December 18th)\\n\\n- We have fixed a bug preventing a release from being synced downstream if the changelog to be set is empty.\\n ([packit#2183](https://github.com/packit/packit/pull/2183))\\n- We have fixed a bug of not running Koji builds for Packit dist-git PRs with multiple commits if the last commit\\n of the PR did not contain a spec file change.\\n ([packit-service#2275](https://github.com/packit/packit-service/pull/2275))\\n\\n## End of the year in Packit\\n\\n- We have hit some issues with the firewall rules on the new cluster hosting our production. We are waiting for the required fix that is done outside of our team which should be deployed around January 11th. We will keep you informed about the current status. At the moment we are aware of the issues related to the:\\n - `pull-from-upstream` jobs that have sources hosted at infradead.org, sourceforge.net and gitlab.gnome.org\\n - jobs running on the gitlab.gnome.org in general\\n- We have also fixed an issue that caused some Cockpit releases to fail, others might\'ve been affected too, though there are no reports."},{"id":"/2023/packit-workshop","metadata":{"permalink":"/posts/weekly/2023/packit-workshop","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2023/packit-workshop.md","source":"@site/weekly/2023/packit-workshop.md","title":"Packit workshop - Fedora Community Edition","description":"We, the packit team, are happy to invite you to our upcoming workshop about pulling upstream releases to Fedora using Packit.","date":"2023-12-05T00:00:00.000Z","formattedDate":"December 5, 2023","tags":[{"label":"2023-December","permalink":"/posts/weekly/tags/2023-december"},{"label":"2023","permalink":"/posts/weekly/tags/2023"},{"label":"December","permalink":"/posts/weekly/tags/december"}],"readingTime":0.965,"hasTruncateMarker":false,"authors":[{"name":"Maja Massarini","email":"mmassari@redhat.com","url":"https://github.com/majamassarini","imageURL":"https://github.com/majamassarini.png","key":"mmassari"}],"frontMatter":{"title":"Packit workshop - Fedora Community Edition","date":"2023-12-05T00:00:00.000Z","authors":"mmassari","tags":["2023-December","2023","December"]},"prevItem":{"title":"2023","permalink":"/posts/weekly/2023"},"nextItem":{"title":"2022","permalink":"/posts/weekly/2022"}},"content":"We, the packit team, are happy to invite you to our upcoming workshop about pulling upstream releases to Fedora using Packit.\\n\\n**When: Wed, Jan 10, 9:30 AM - Wed, Jan 10, 12:30 PM (GMT+1)**\\n\\n**Where: Online!**\\n\\n**Who should attend:** Anyone who maintains a package in Fedora or EPEL and would like to automate syncing the upstream releases for it. The automation is most suitable for simple packages with straightforward update processes (e.g. without patches, or need to build in side-tags). It works without access to the upstream repository.\\n\\n**No package?** It\u2019s not an issue. The workshop can help you understand the Fedora release process and the services involved. During the workshop, you can help someone else automate their package or ask someone around if you can help with the maintenance (that\u2019s usually very welcome!). You can also bring an orphaned package back to life!\\n\\n**Can\u2019t make it this time?** You can also follow our [documentation](https://packit.dev/docs/fedora-releases-guide) and ask for help in case of any issue: #packit:fedora.im (Matrix).\\n\\n**If you want to join us please fill [this form](https://forms.gle/WnEN3KXnhRS2cf1E7) or contact us on Matrix, and we will send you further details!**\\n\\n**Looking forward to seeing you!**"},{"id":"/2022","metadata":{"permalink":"/posts/weekly/2022","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2022.md","source":"@site/weekly/2022.md","title":"2022","description":"Let\'s see what happened in Packit in 2022.","date":"2023-01-01T00:00:00.000Z","formattedDate":"January 1, 2023","tags":[{"label":"2022","permalink":"/posts/weekly/tags/2022"}],"readingTime":24.99,"hasTruncateMarker":true,"authors":[],"frontMatter":{"title":"2022","date":"2023-01-01T00:00:00.000Z","aliases":["/posts/weekly/january-2022","/posts/weekly/february-2022","/posts/weekly/march-2022","/posts/weekly/april-2022","/posts/weekly/may-2022","/posts/weekly/june-2022","/posts/weekly/july-2022","/posts/weekly/august-2022","/posts/weekly/september-2022","/posts/weekly/october-2022","/posts/weekly/november-2022","/posts/weekly/december-2022"],"tags":["2022"]},"prevItem":{"title":"Packit workshop - Fedora Community Edition","permalink":"/posts/weekly/2023/packit-workshop"},"nextItem":{"title":"2021","permalink":"/posts/weekly/2021"}},"content":"Let\'s see what happened in Packit in 2022.\\n\\n\x3c!--truncate--\x3e\\n\\n## Week 0 (December 13th - January 2nd)\\n\\n- Dashboard shows a message when the SRPM build logs are not present instead of\\n an empty page that might suggest logs are being loaded.\\n ([packit/dashboard#158](https://github.com/packit/dashboard/pull/158))\\n\\n## Week 1 (January 3rd - January 7th)\\n\\n- Packit service now discards old (currently, this means 3 months) SRPM builds logs.\\n ([packit/packit-service#1315](https://github.com/packit/packit-service/pull/1315))\\n- We have added `target_branch_head_commit` property to the `PullRequest` class in ogr that allows\\n you to get commit hash of the HEAD of the target branch (i.e. base, where the changes are merged to).\\n ([packit/ogr#671](https://github.com/packit/ogr/pull/671))\\n- Service now passes `PACKIT_TARGET_SHA` variable, which holds commit hash of the HEAD of the target\\n branch where the changes are supposed to be merged, to the Testing Farm environment. This should\\n help solving the issue of running tests from non-merged codebase on the Testing Farm side.\\n ([packit/packit-service#1319](https://github.com/packit/packit-service/pull/1319))\\n\\n## Week 2 (January 10th - January 14th)\\n\\n- Packit no longer ignores `--no-bump` and `--release-suffix` options for\\n source-git repos.\\n [packit/packit#1452](https://github.com/packit/packit/pull/1452)\\n- Packit now names local branch `pr/{pr_id}` when checking out a PR, even when\\n it\'s not being merged with the target branch. This results into NVR of the\\n build containing `pr{pr_id}` instead of `pr.changes{pr_id}`.\\n [packit/packit#1445](https://github.com/packit/packit/pull/1445)\\n\\n## Week 3 (January 17th - January 21st)\\n\\n- `%changelog` sections in dist-git using the `%autochangelog` macro [are\\n preserved](https://github.com/packit/packit/pull/1453) when running\\n `propose-downstream`, except when `sync_changelog` is set to `true`.\\n- When checking if directories hold a Git-tree, Packit now also allows [`.git`\\n to be a file with a `gitdir`](https://github.com/packit/packit/pull/1458)\\n reference, not only a directory.\\n\\n## Week 4 (January 25th - January 28th)\\n\\n- SRPM build view contains info about build start and finished time.\\n [packit/dashboard#163](https://github.com/packit/dashboard/pull/163)\\n- When submitting a distgit PR during `propose-downstream` job, we create\\n a `README.packit` file with some info about the sync the packit version used.\\n To avoid this you can add `create_sync_note: false` to conig file.\\n [packit/packit#1465](https://github.com/packit/packit/pull/1465)\\n\\n## Week 5 (January 31th - February 7th)\\n\\n- A new option `--no-require-autosetup` for `source-git init` command has been\\n introduced. Please note that source-git repositories not using `%autosetup` may\\n not be properly initialized. ([packit#1470](https://github.com/packit/packit/pull/1470))\\n- Packit-service now supports re-triggering against failed task using comment on\\n pull request `/packit rebuild-failed` and similarly for testing farm: `/packit retest-failed`.\\n ([packit-service#1303](https://github.com/packit/packit-service/pull/1303))\\n\\n## Week 6 (February 8th - February 14th)\\n\\n- Packit now correctly handles colons in git trailer values in source-git commits.\\n ([packit#1478](https://github.com/packit/packit/pull/1478))\\n\\n## Week 7 (February 14th\u2764\ufe0f - February 18th)\\n\\n- Synchronization of default files can now be disabled using a new config\\n `files_to_sync`. Key `sync_files` is now deprecated.\\n ([packit#1483](https://github.com/packit/packit/pull/1483))\\n ([packit.dev#390](https://github.com/packit/packit.dev/pull/390))\\n- `python3-setuptools_scm` is now available by default in the sandbox.\\n\\n## Week 8 (February 18th - February 28th)\\n\\n- Packit now allows specifying more test distros for one build target\\n to test on in Testing Farm in the configuration. The checks for the\\n test job will also contain the name of the actual test distro\\n (and not the build target as previously).\\n- A new option, `srpm_build_deps`, in the packit configuration file \\n can be used. Which is a list of RPM dependencies that are needed for\\n the actions to be run when building SRPM and is an indicator to build\\n the SRPMs in Copr.\\n\\n## Week 9 (March 1st - March 7th)\\n\\n- When a specfile is being generated, and both `specfile_path` and\\n `downstream_package_name` are not set, Packit now correctly resolves this\\n situation and sets `specfile_path` to the name of the upstream repo suffixed\\n with `\\".spec\\"`.\\n ([packit#1499](https://github.com/packit/packit/pull/1499))\\n- A new command `packit source-git status` has been introduced for checking\\n the synchronization of a source-git and a dist-git repository based on the\\n used git trailers. The command outputs a range of commits which need to be\\n synchronized from dist-git to source-git or the other way around. If possible,\\n the command also provides instructions on how to synchronize the repositories.\\n ([packit#1500](https://github.com/packit/packit/pull/1500))\\n- We have added a new `enable_net` configuration option for Copr builds that\\n allows you to disable network access during Copr builds. It is also complemented\\n by `--enable-net`/`--disable-net` CLI options if you use Packit locally.\\n ([packit#1504](https://github.com/packit/packit/pull/1504))\\n- Packit now adds \ud83d\udc40 instead of \ud83d\udc4d as a reaction to `/packit command`\\n ([packit-service#1372](https://github.com/packit/packit-service/pull/1372))\\n- Progress of propose-downstream is now saved in the database and is available\\n via API. Visualization in the dashboard is to follow next week, stay tuned.\\n ([packit-service#1292](https://github.com/packit/packit-service/pull/1292))\\n- When running tests for the pull-request job, we now expose environment\\n variables for commit hash, branch and URL both for pull-request source and\\n target. In the test environment, you can use the following variables:\\n `PACKIT_SOURCE_SHA`, `PACKIT_TARGET_SHA`, `PACKIT_SOURCE_BRANCH`,\\n `PACKIT_TARGET_BRANCH`, `PACKIT_SOURCE_URL` and `PACKIT_TARGET_URL`.\\n These variables are not set for test runs of releases and branch pushes.\\n ([packit-service#1382](https://github.com/packit/packit-service/pull/1382))\\n\\n## Week 10 (March 8th - March 14th)\\n\\n- You can view information about ongoing propose-downstream jobs via our dashboard.\\n ([dashboard#168](https://github.com/packit/dashboard/pull/168))\\n- We have switched the cache for dist-git branches and Copr targets to TTL cache\\n that gets discarded once in 12 hours, in case there is a change in targets, the\\n changes shall propagate to both of our deployments without the need to redeploy\\n within 12 hours. ([packit#1513](https://github.com/packit/packit/pull/1513))\\n- Packit now comments when it fails to find Copr project specified in the config.\\n ([packit#1395](https://github.com/packit/packit-service/pull/1395))\\n- Packit now reacts to dist-git pushes to either `rawhide` or `main` when configured\\n to do Koji builds for `rawhide`.\\n ([packit#1393](https://github.com/packit/packit-service/pull/1393))\\n- You can specify an identifier for your job to be able to configure one job multiple times.\\n For example, you can build multiple projects from one repository (known as monorepo concept)\\n or try multiple build options. Using identifiers allows Packit to avoid naming collisions\\n in commit statuses and default Copr project names.\\n ([packit-service#1385](https://github.com/packit/packit-service/pull/1385))\\n- Packit no longer provides a misleading comment when it fails to update a set of\\n targets on its own Copr projects.\\n ([packit-service#1397](https://github.com/packit/packit-service/pull/1397))\\n\\n## Week 11 (March 15th - March 21st)\\n\\n- When using Packit CLI for creating Bodhi updates,\\n you can now set `fas_username` and `fas_password` in your Packit user config\\n to not be asked about that when the command is executed.\\n Also, this allows Packit GitHub application to use this as well\\n so you can look forward to Bodhi updates created by Packit\\n (will be announced and described in a dedicated post).\\n ([packit#1517](https://github.com/packit/packit/pull/1517))\\n\\n## Week 12 (March 22nd - March 28th)\\n\\n- We have updated contact information to `Packit `.\\n ([packit-service#1410](https://github.com/packit/packit-service/pull/1410))\\n- Interactions with Bodhi should be now more reliable when creating Bodhi updates.\\n ([packit#1528](https://github.com/packit/packit/pull/1528))\\n- Packit will no longer error out when trying to create a new Copr repository\\n when it is already present.\\n ([packit#1527](https://github.com/packit/packit/pull/1527))\\n- There is a new `packit_instances` key that you can use to specify the Packit\\n instances you want to use for working on your jobs. Nothing will change for our\\n production users, but users of our stage instance need to use this key to\\n preserve the support of the stage instance -- they can set both stg and prod in\\n the `packit_instances` list to use both, or use just one. Just be careful with\\n the downstream jobs where both instances work with the same services.\\n This new option works like other Packit options so you can set it on the top\\n level and/or (re)define it on the job level.\\n More information about our staging instance can be found here:\\n [packit#1530](https://github.com/packit/packit/discussions/1530).\\n ([packit#1417](https://github.com/packit/packit-service/pull/1417))\\n\\n## Week 13 (March 29th - April 4th)\\n\\n- We have implemented `get_contributors` function in ogr that can be used for getting contributors to the project on GitHub (set of logins) and GitLab (set of authors).\\n ([ogr#692](https://github.com/packit/ogr/pull/692))\\n- When multiple propose downstream attempts for the same PR fail, the error messages are sent to to the same issue (as comments), instead of creating multiple new issues.\\n ([packit#1427](https://github.com/packit/packit-service/pull/1427))\\n- Downstream synchronization of the Packit configuration file (aka `packit.yaml`) is now working properly again.\\n ([packit#1532](https://github.com/packit/packit/pull/1532))\\n- `packit source-git update-dist-git` and `packit source-git update-source-git` now check the synchronization of source-git and dist-git repositories prior to doing the update. If the update can\'t be done, for example, because the histories have diverged, the command provides instructions on how to synchronize the repositories.\\n A `--force` option is available to try to update the destination repository anyway.\\n ([packit#1534](https://github.com/packit/packit/pull/1534))\\n- When using `post_upstream_clone` to generate your spec-file,\\n Packit now correctly checks out a release before the action is run.\\n ([packit#1542](https://github.com/packit/packit/pull/1542))\\n\\n## Week 14 (April 5th - April 11th)\\n\\n- We have introduced two new build and test target aliases: `fedora-latest-stable` resolves to the latest stable Fedora\\n Linux release, while `fedora-branched` resolves to all branched releases (all Fedora Linux release, except `rawhide`).\\n ([packit#1546](https://github.com/packit/packit/pull/1546))\\n- We have reverted the functionality of Packit that allowed you to have set **only** specific targets for Copr repositories.\\n This functionality was introduced a while ago and was found to be not very beneficial in cases of differently\\n configured Copr jobs building in parallel in the same Copr repository. This is an implementation detail in the end,\\n but Copr project chroots are now only added and never subtracted\\n (every build has precisely specified targets based on the copr_build job definition).\\n ([packit#1551](https://github.com/packit/packit/pull/1551))\\n- If you are using our stage instance, we make it listen only on `/packit-stg` comment commands so you can now differentiate\\n between the instances when commanding Packit via pull-request or issue comments.\\n For the production instance, you can continue using `/packit` prefix as you are used to.\\n ([packit-service#1432](https://github.com/packit/packit-service/pull/1432))\\n- A new configuration option `downstream_branch_name` has been added, which is meant to be used in source-git projects\\n and allows users to customize the name of the branch in dist-git which corresponds to the current source-git branch.\\n ([packit#1555](https://github.com/packit/packit/pull/1555))\\n- `revision-range` argument of the source-git `update-source-git` command is now optional. If not specified,\\n dist-git commits with no counterpart in source-git are synchronized.\\n ([packit#1547](https://github.com/packit/packit/pull/1547))\\n\\n## Week 15 (April 12th - April 14th)\\n\\n- We have implemented reporting of status for the propose-downstream job which means that you can now\\n see the progress of the job via check runs/commit statuses on the particular release commits.\\n ([packit-service#1435](https://github.com/packit/packit-service/pull/1435))\\n\\n## Week 16 (April 19th - April 25th)\\n\\n- The bug in our service about not setting GitHub and Gitlab statuses in case of lack of permissions was fixed.\\n ([packit/packit-service#1457](https://github.com/packit/packit-service/pull/1457))\\n- Packit\'s CLI `source-git update-*` commands now check whether the target repository is pristine and in case not raise an error.\\n ([packit/packit#1562](https://github.com/packit/packit/pull/1562))\\n\\n## Week 17 (April 26th - May 2th)\\n\\n- We have fixed an issue affecting Pipelines view on Dashboard. Currently you should be able to see pipelines again; we are also working on fixing empty rows for `propose-downstream` jobs.\\n ([packit-service#1461](https://github.com/packit/packit-service/pull/1461))\\n- Packit now shows the specific info when it does not have permissions to create a Bodhi update of your package.\\n When you configure `issue_repository` in your Packit config file, Packit will create an issue in that project and link the dist-git page where you can give _Packit FAS user_ the correct permissions.\\n ([packit-service#1465](https://github.com/packit/packit-service/pull/1465))\\n- Packit now exports `PACKIT_PR_ID` environment variable to the Testing Farm.\\n ([packit-service#1467](https://github.com/packit/packit-service/pull/1467))\\n- The bug in the Copr permission request is now fixed. (After the release of a new Copr client, Packit didn\'t catch that permission problem and didn\'t request the permissions to build in a custom Copr project.)\\n ([packit-service#1472](https://github.com/packit/packit-service/pull/1472))\\n- We have fixed a bug that caused Packit to fail when submitting Testing Farm on `commit` trigger.\\n ([packit-service#1474](https://github.com/packit/packit-service/pull/1472))\\n- Packit now builds RPMs in Copr triggered by `release` event with correct NVR (without the artificial release suffix). You can use it for distributing RPM packages via Copr. \\n ([packit-service#1478](https://github.com/packit/packit-service/pull/1478))\\n- From the security perspective, we have decided to disable the `create_pr` option for our service, from now on Packit will unconditionally create PRs when running `propose-downstream`.\\n We have also updated the `propose-downstream` CLI such that it is possible to use `create_pr` from configuration **or** override it via `--pr/--no-pr` options.\\n ([packit#1563](https://github.com/packit/packit/pull/1563))\\n- Packit now supports `release_suffix` configuration option that allows you to override the long release string provided by Packit that is used to ensure correct ordering and uniqueness of RPMs built in Copr.\\n ([packit#1568](https://github.com/packit/packit/pull/1568))\\n\\n## Week 18 (May 3rd - May 9th)\\n\\n- `packit source-git` commands learnt to replace [Git-trailers in commit messages](https://packit.dev/source-git/work-with-source-git/control-patch-generation/) if they already exist. ([packit#1577](https://github.com/packit/packit/pull/1577))\\n- When initializing source-git repos, the author of downstream commits created from patch files which are not in a git-am format is set to the original author of the patch-file in dist-git, instead of using the locally configured Git author. ([packit#1575](https://github.com/packit/packit/pull/1575))\\n- Packit now correctly inform users about downstream errors only on the last try. (Previously, Packit informed for all tries even the last try succeded.) ([packit-service#1485](https://github.com/packit/packit-service/pull/1485))\\n- Dashboard now also shows propose-downstream jobs in pipelines view. We have also merged all jobs to one column to minimize dead space on the page. ([dashboard#178](https://github.com/packit/dashboard/pull/178))\\n\\n## Week 19 (May 10th - May 16th)\\n\\n- Metadata dictionary is no longer required when specifying a job. Keys which used to belong to the yaml metadata dictionary are now keys of the job dictionary itself. ([packit#1569](https://github.com/packit/packit/pull/1569))\\n- Packit now correctly removes patches during `packit source-git init` when the preamble does not contain blank lines. ([packit#1582](https://github.com/packit/packit/pull/1582))\\n- Packit now supports `--release-suffix` parameter in all of the related CLI commands. Also we have added a support for the `release_suffix` option from configuration to the CLI. With regards to that we have introduced a new CLI switch `--default-release-suffix` that allows you to override the configuration option to Packit-generated default option that ensures correct NVR ordering of the RPMs. ([packit#1586](https://github.com/packit/packit/pull/1586))\\n- Resolved an SRPM build problem caused by a new version of git that refuses to fetch in a git repo when it\'s owned on the OS level by someone else. ([packit#1497](https://github.com/packit/packit-service/pull/1497))\\n- Packit now passes `PACKIT_COPR_PROJECT` and `PACKIT_COPR_RPMS` variables to the Testing Farm. `PACKIT_COPR_PROJECT` holds Copr project in format owner/project and `PACKIT_COPR_RPMS` space-separated RPMs that were built in Copr. ([packit-service#1486](https://github.com/packit/packit-service/pull/1486))\\n- Packit now builds only its own dist-git commits. Other commits are not being acted upon. For reasoning, see [packit-service#1490](https://github.com/packit/packit-service/issues/1490). ([packit-service#1498](https://github.com/packit/packit-service/pull/1498))\\n- We have automated our allowlisting process via a new Packit comment command `/packit verify-fas`. You can find more info in [our requirements](https://packit.dev/docs/guide/#2-approval). ([packit-service#1487](https://github.com/packit/packit-service/pull/1487))\\n\\n## Week 20 (May 17th - May 23rd)\\n\\n- We have fixed an issue with the handling of messages from Copr on release builds, which has resulted in not setting the correct statuses on commits. ([packit-service#1513](https://github.com/packit/packit-service/pull/1513))\\n- When doing an automatic FAS account verification, Packit now suggests the URL where the GitHub account needs to be set. ([packit-service#1508](https://github.com/packit/packit-service/pull/1508))\\n\\n## Week 21 (May 24th - May 30th)\\n\\n- Packit will not raise an exception anymore when creating a SRPM with dangling symlinks. ([packit#1592](https://github.com/packit/packit/pull/1592))\\n- You can now override which dist-git commits will be built in Koji by specifying FAS accounts of authors and committers using\\n `allowed_pr_authors` or `allowed_committers` in the job metadata (see [the documentation](https://packit.dev/docs/configuration/#koji_build)). ([packit-service#1520](https://github.com/packit/packit-service/pull/1520))\\n\\n## Week 22 (May 31st - June 6th)\\n\\n- Packit shows basic information about allowlisting in the status description\\n when your namespace is not allowed.\\n ([packit-service#1533](https://github.com/packit/packit-service/pull/1533))\\n\\n## Week 23 (June 7th - June 13th)\\n\\n- The creation of Bodhi updates should not time out anymore, because we no longer get the latest build of a package via Bodhi.\\n ([packit#1612](https://github.com/packit/packit/pull/1612))\\n- We have fixed a regression where string values for the `targets` and `dist_git_branches` configuration keys were not accepted.\\n ([packit#1608](https://github.com/packit/packit/pull/1608))\\n- We improved the reporting for the test job if we are not able to find any FMF metadata and the `skip_build` option is enabled.\\n ([packit-service#1539](https://github.com/packit/packit-service/pull/1539))\\n\\n## Week 24 (June 14th - June 21st)\\n\\n- Git ref name that Packit works with during `propose-downstream` is now made more obvious in logs.\\n ([packit#1626](https://github.com/packit/packit/pull/1626))\\n- Packit now correctly handles creation of custom archives in root while a specfile is in a subdirectory.\\n ([packit#1622](https://github.com/packit/packit/pull/1622))\\n- There is a new check for git projects that are allowed to use a custom Copr project.\\n There will be a better integration in the form of a new config field in Copr settings that Packit can use.\\n In the meantime, the mapping is defined and maintained by the Packit team.\\n Let us know if you need a project to be allowed.\\n ([packit-service#1556](https://github.com/packit/packit-service/pull/1556))\\n- A link to Copr build logs was updated: it now points to a place where logs are available once a build starts.\\n ([packit-service#1554](https://github.com/packit/packit-service/pull/1554))\\n\\n## Week 25 (June 21st - June 27th)\\n\\n- Packit Bash completion file is no longer needlessly executable. ([packit#1634](https://github.com/packit/packit/pull/1634))\\n- Packit now works with Bodhi 5 and Bodhi 6 authentication mechanism. ([packit#1629](https://github.com/packit/packit/pull/1629))\\n- Git ref name that Packit works with during `propose-downstream` is now made more obvious in logs. ([packit#1626](https://github.com/packit/packit/pull/1626))\\n- We have fixed the incorrect displaying of `propose downstream` results in our dashboard. ([packit-service#1553](https://github.com/packit/packit-service/pull/1553))\\n\\n## Weeks 26\u201327 (June 27th\u2013July 11th)\\n\\n- We adjusted the way we check the author of the PR for PRs related to\\n dist-git commits that trigger Koji build jobs. This should fix the race\\n condition causing not creating Koji builds in some cases.\\n ([packit-service#1573](https://github.com/packit/packit-service/pull/1573))\\n- Results from Testing Farm are now correctly reported when multiple jobs with\\n different identifier are defined.\\n ([packit-service#1565](https://github.com/packit/packit-service/pull/1565))\\n- On a Bodhi authentication error, Packit will retry the task multiple times\\n in ten-minute intervals to be able to fix the issue in the meantime.\\n ([packit-service#1564](https://github.com/packit/packit-service/pull/1564))\\n\\n## Week 28 (July 12th\u2013July 18th)\\n\\n- Packit now guides everyone better when a FAS account is private\\n and updates the internal information about installations correctly\\n when the app is reinstalled.\\n ([packit-service#1575](https://github.com/packit/packit-service/pull/1575))\\n- Packit can now correctly create Bodhi updates using the new Bodhi 6 client.\\n ([packit#1651](https://github.com/packit/packit/pull/1651))\\n- RPM build commands of Packit CLI have been merged into one build subcommand,\\n for more information see the updated [documentation](https://packit.dev/docs/cli/build/).\\n We have also introduced a new --srpm option to the new build subcommand\\n that can be used to trigger local, Copr or Koji build from an already built\\n SRPM rather than the one implicitly created by Packit.\\n ([packit#1611](https://github.com/packit/packit/pull/1611))\\n\\n## Week 29 (July 19th\u2013July 25th)\\n\\n- Packit now correctly supports `tmt_plan` and `tf_post_install_script` in the\\n configuration. ([packit#1659](https://github.com/packit/packit/pull/1659))\\n- We have reverted to Bodhi 5 client since Packit couldn\'t create bodhi updates\\n with the new version 6 client: [fedora-infra/bodhi#4660](https://github.com/fedora-infra/bodhi/issues/4660)\\n ([packit-service#1590](https://github.com/packit/packit-service/pull/1590)).\\n Packit also provides a more helpful error message when it hits this.\\n ([packit#1660](https://github.com/packit/packit/pull/1660))\\n- During creating Copr builds, on Copr errors, Packit will retry the task\\n multiple times in case there is a Copr outage.\\n ([packit-service#1579](https://github.com/packit/packit-service/pull/1579))\\n\\n## Week 30 (July 26th\u2013August 1st)\\n\\n- Packit has switched to `python-specfile` library for handling spec files. This may cause some issues to pop up. ([packit#1588](https://github.com/packit/packit/pull/1588))\\n- Packit CLI can now build RPMs in mock. For more information see https://packit.dev/docs/cli/build/mock ([packit#1662](https://github.com/packit/packit/pull/1662))\\n- When using Packit before being allowed, Packit newly links an approval issue where the self-approval can be performed. ([packit-service#1596](https://github.com/packit/packit-service/pull/1596))\\n- A downstream koji-build can now be re-triggered by adding a comment containing `/packit koji-build` into a dist-git pull request with target branch corresponding to the branch the build should be acted upon. ([packit-service#1586](https://github.com/packit/packit-service/pull/1586))\\n\\n## Week 31 (August 2nd \u2013 August 8th)\\n\\n- Action `fix_spec_file` can change a spec file - Packit now preserves that change.\\n ([packit#1679](https://github.com/packit/packit/pull/1679))\\n- BREAKING CHANGE: fixed an issue where the repo was searched for the specfile\\n before checking if `downstream_package_name` is set, and\\n `.spec` can be used as the `specfile_path`.\\n ([packit#1663](https://github.com/packit/packit/pull/1663))\\n\\n## Week 32 (August 9th \u2013 August 15th)\\n\\n- We have fixed an issue when propose downstream didn\'t retry to download sources that were not yet available at the time of the first attempt. ([packit-service#1609](https://github.com/packit/packit-service/pull/1609))\\n- When creating Copr builds, Packit will now retry multiple times in case there is a GitHub outage or an internal error. ([packit-service#1589](https://github.com/packit/packit-service/pull/1589))\\n\\n## Week 33 (August 16th \u2013 August 22nd)\\n\\n- Packit CLI can now submit VM images in [Red Hat Image Builder](https://console.redhat.com/insights/image-builder).\\n All build-related commands have now consistent `--wait` / `--no-wait` options.\\n ([packit#1666](https://github.com/packit/packit/pull/1666))\\n- Packit `prepare-sources` command now has a `--create-symlinks` / `--no-create-symlinks` option,\\n which enables copying the archive instead of symlinking. This will be used in the Copr environment,\\n where symlinking the archive previously caused issues.\\n ([packit#1682](https://github.com/packit/packit/pull/1682))\\n- We have fixed the handling of the situation when Packit lacks permission to update a Copr project.\\n ([packit#1684](https://github.com/packit/packit/pull/1684))\\n- Dashboard should now load data for [jobs](https://dashboard.packit.dev/jobs) faster because\\n the database querying has been improved and also queries are done only when needed.\\n ([packit-service#1617](https://github.com/packit/packit-service/pull/1617),\\n [dashboard#189](https://github.com/packit/dashboard/pull/189))\\n\\n## Week 34 (August 23rd \u2013 August 29th)\\n\\n- `packit propose-downstream` is now more informative when sources cannot be\\n downloaded. ([packit#1698](https://github.com/packit/packit/pull/1698))\\n- No more annoying issues will be created after a successful _propose\\n downstream_. ([packit#1693](https://github.com/packit/packit/pull/1693))\\n- We have fixed an issue with reporting results when multiple Testing Farm\\n jobs with identifiers are configured.\\n ([packit-service#1634](https://github.com/packit/packit-service/pull/1634))\\n\\n## Week 35 (August 30th \u2013 September 5th)\\n\\n- SRPMs for Copr builds are built in Copr by default for Packit GitHub app installations since September 6, 2022.\\n For older installations, you can set the `srpm_build_deps` config option to use Copr as a builder.\\n Let us know if you hit any issue with the new implementation. We are going to slowly decommission the old implementation\\n and are happy to help with the transition. ([packit-service#1636](https://github.com/packit/packit-service/pull/1636))\\n- More indexes added to the database have further improved API/dashboard response times. ([packit-service#1639](https://github.com/packit/packit-service/pull/1639))\\n- When submitting Testing Farm tests, Packit will now retry multiple times in case there is a failure.\\n ([packit-service#1605](https://github.com/packit/packit-service/pull/1605))\\n- We have implemented checking the available composes before submitting the tests for both internal and public Testing\\n Farm. ([packit-service#1628](https://github.com/packit/packit-service/pull/1628))\\n\\n## Week 36 (September 6th \u2013 September 12th)\\n\\n- When querying Bodhi for information about Fedora/EPEL releases to resolve aliases,\\n packit now correctly handles pagination of API results. This resolves an issue that caused\\n Fedora 37 not to be pointed to from any alias.\\n ([packit#1704](https://github.com/packit/packit/pull/1704))\\n\\n## Week 37 (September 13th \u2013 September 19th)\\n\\n- Added support for filenames specified in source URL fragments, for example: `https://example.com/foo/1.0/download.cgi#/%{name}-%{version}.tar.gz` ([specfile#100](https://github.com/packit/specfile/pull/100))\\n- Some more underlying improvements to our libraries and deployment.\\n\\n## Week 38 (September 20th \u2013 September 26th)\\n\\n- Propose downstream job now pushes changes even when it\'s not creating a new pull request. This allows updating existing pull requests. ([packit#1725](https://github.com/packit/packit/pull/1725))\\n- Packit now deduces Copr targets for Copr builds when you have set your custom Copr project to be used. ([packit-service#1673](https://github.com/packit/packit-service/pull/1673))\\n- Retriggering tasks via re-run button in Github commit checks when there are configured identifiers for jobs should now work correctly. ([packit-service#1671](https://github.com/packit/packit-service/pull/1671))\\n- Packit now reports a pending state rather than an error on Testing Farm runs in case the related copr build has not finished yet. ([packit-service#1669](https://github.com/packit/packit-service/pull/1669))\\n- Users can now **allow** building in a custom Copr project from a _git-forge_ project.\\n User has to add manually the _git-forge_ project reference to the Copr project settings.\\n As an example, we should add _github.com/packit/ogr_ to the list named _Packit forge project allowed_ in our _packit-dev_ Copr project settings: https://copr.fedorainfracloud.org/coprs/packit/packit-dev/edit#packit_forge_projects_allowed. ([packit-service#1638](https://github.com/packit/packit-service/pull/1638))\\n\\n## Week 39 (September 27th \u2013 October 3rd)\\n\\n- We have improved mapping of Testing Farm Composes, if you have set your own custom mapping and the TF Compose is available, it will be used as is without any additional modifications we do (version, etc.). ([packit-service#1675](https://github.com/packit/packit-service/pull/1675))\\n- We have added support for running the tests with Copr builds built by Packit in another pull request (in a different repository). You can read more about this feature in [our documentation](https://packit.dev/docs/testing-farm/#running-tests-with-builds-from-another-pull-request). ([packit-service#1658](https://github.com/packit/packit-service/pull/1658))\\n\\n## Week 40 (October 4th \u2013 October 10th)\\n\\n- Packit now correctly selects a Testing Farm compose when it\'s specified correctly in the configuration without an architecture suffix. ([packit-service#1689](https://github.com/packit/packit-service/pull/1689))\\n- We have fixed an issue that prevented Packit to work correctly on merge requests on GitLab instances. ([packit-service#1683](https://github.com/packit/packit-service/pull/1683))\\n- Packit Service will now replace invalid characters for the Copr projects using the default naming scheme. ([packit-service#1684](https://github.com/packit/packit-service/pull/1684))\\n- When we report to set `Packit allowed forge projects` in the Copr projects, the link for the group projects is now correct. ([packit-service#1680](https://github.com/packit/packit-service/pull/1680))\\n- It is now possible to filter changelog entries by specifying lower bound EVR, upper bound EVR or both. ([specfile#104](https://github.com/packit/specfile/pull/104))\\n\\n## Week 41 (October 11th \u2013 October 17th)\\n\\n- Packit now correctly authenticates with Bodhi 6 and therefore creates Bodhi updates. \ud83d\ude80 ([packit#1746](https://github.com/packit/packit/pull/1746), [packit-service#1704](https://github.com/packit/packit-service/pull/1704))\\n- There are two changes in the naming of the service jobs:\\n The `build` job type name has been deprecated. It aimed to be an alias when Packit supported just one build type.\\n There are currently more types of builds and just `build` can be misleading. Please, be explicit and use `copr_build` instead.\\n The `production_build` name for upstream Koji build is misleading because it is not used to run production/non-scratch\\n builds and because it can be confused with the `koji_build` job that is triggered for dist-git commits.\\n (The `koji_build` job can trigger both scratch and non-scratch/production builds.)\\n To be explicit, use `upstream_koji_build` for builds triggered in upstream and `koji_build` for builds triggered in downstream.\\n Users will get a neutral status describing the change when the old names are in use. The status will become a warning\\n starting in November and the old names will be removed by the end of the year. ([packit-service#1656](https://github.com/packit/packit-service/pull/1656))\\n- We\'ve fixed the Markdown table format in the GitHub checks page, which was broken when the user\'s repo was not allowed to use Packit. ([packit-service#1688](https://github.com/packit/packit-service/pull/1688))\\n\\n## Week 42 (October 17th \u2013 October 23rd)\\n\\n- Packit now won\'t repeatedly comment in pull requests about the need to migrate configuration of allowed forge projects to Copr. ([packit-service#1716](https://github.com/packit/packit-service/pull/1716))\\n\\n## Week 43 (October 25th \u2013 October 31th)\\n\\n- Fixed an issue with version and release in a spec file being updated even if `--no-bump` flag was specified.\\n Also fixed an issue when `None` appeared in release instead of a number.\\n ([packit#1753](https://github.com/packit/packit/pull/1753))\\n- We have improved the handling of test jobs which should fix related issues with reporting and triggering\\n that occurred when multiple test jobs were configured.\\n ([packit-service#1717](https://github.com/packit/packit-service/pull/1717))\\n\\n## Week 44 (November 1st \u2013 November 7th)\\n\\n- Fixed an issue due to which the repository was never searched for a specfile if `specfile_path` was not specified, and `specfile_path` was always set to `.spec`. ([packit#1758](https://github.com/packit/packit/pull/1758))\\n- Packit is now able to generate automatic Bodhi update notes including a changelog diff since the latest stable build of a package. ([packit#1747](https://github.com/packit/packit/pull/1747))\\n- Description of Bodhi updates now contains a changelog diff. ([packit-service#1713](https://github.com/packit/packit-service/pull/1713))\\n\\n## Week 45 (November 8th \u2013 November 14th)\\n\\n- You can re-trigger a Bodhi update via dist-git PR comment `/packit create-update`. ([packit-service#1729](https://github.com/packit/packit-service/pull/1729))\\n- Packit now correctly finds an SRPM when rpmbuild reports warnings while it parses a spec file. ([packit#1772](https://github.com/packit/packit/pull/1772))\\n- When packit.yaml is present in the repo but is empty, Packit now produces a better error message instead of an internal Python exception. ([packit#1769](https://github.com/packit/packit/pull/1769))\\n- Retriggering of tests when there is a build job and a test job with an identifier configured was fixed. ([packit-service#1731](https://github.com/packit/packit-service/pull/1731))\\n- Packit GitHub app will not modify a package version when `release_suffix` configuration option is empty. ([packit-service#1738](https://github.com/packit/packit-service/pull/1738))\\n- Our `specfile` parser now supports localized tags (e.g. `Summary(fr)`) and tags with qualifiers (e.g. `Requires(post)`). ([specfile#132](https://github.com/packit/specfile/pull/132))\\n- SRPM build logs are now deleted after 30 days instead of 90 days. This doesn\'t apply to SRPM builds done in Copr, which deletes the logs after 14 days. ([packit/packit-service#1745](https://github.com/packit/packit-service/pull/1745))\\n\\n## Week 46 (November 15th \u2013 November 21st)\\n\\n- `srpm_build_deps` can be now configured also on the job configuration level. ([packit-service#1757](https://github.com/packit/packit-service/pull/1757))\\n\\n## Week 47 (November 22nd \u2013 November 28th)\\n\\n- We have changed the limit for our [SLO1](https://packit.dev/docs/service-level-objectives/#slo1-changes-to-github-prs-receive-a-status-update-within-15-seconds-in-99-of-cases): it was increased from 15s to 30s to account for setting all statuses. ([packit-service#1776](https://github.com/packit/packit-service/pull/1776))\\n- The job names deprecated in October (`build` alias of `copr_build` and `production_build` replaced by `upstream_koji_build`) newly lead to an error state (was `neutral` ) of the deprecated status created by Packit.\\n The old names will be removed by the end of the year. ([packit-service#1777](https://github.com/packit/packit-service/pull/1777))\\n- The Copr build logs URL now points to logs that are available even while building. ([packit-service#1767](https://github.com/packit/packit-service/pull/1767))\\n- Fixed an issue that caused empty lines originally inside changelog entries to appear at the end. ([specfile#140](https://github.com/packit/specfile/pull/140))\\n\\n## Week 48 (November 29th \u2013 December 5th)\\n\\n- `packit propose-downstream` now uploads all remote sources (those specified as URLs) and the\\n source specified by `spec_source_id` (whether remote or not) to lookaside. Previously, only Source0\\n was uploaded. Source0 is no longer treated specially, but as `spec_source_id` is `Source0` by default,\\n Source0 is still being uploaded by default unless `spec_source_id` is overriden.\\n ([packit#1778](https://github.com/packit/packit/pull/1778))\\n- [A VM image build](/docs/configuration/upstream/vm_image_build) can be triggered inside a PR via a comment\\n command `/packit vm-image-build` (the job needs to be defined in the configuration).\\n This feature is experimental and is still being tested.\\n ([packit-service#1761](https://github.com/packit/packit-service/pull/1761))\\n- `Section` and `Tag` objects in `specfile` library now have `normalized_name` property for more convenient comparison.\\n There is a new method, `Specfile.get_active_macros()`, to get active macros in the context of the spec file.\\n The underlying `rpm.spec` instance is now exposed as `Specfile.rpm_spec` property.\\n There is a new utility class for parsing NEVRA strings. ([specfile#141](https://github.com/packit/specfile/pull/141))\\n\\n## Week 49 (December 6th \u2013 December 12th)\\n\\n- Packit now correctly handles a race condition when it tries to create bodhi\\n updates for builds that are not yet tagged properly. CLI exprience was also\\n improved for this case.\\n ([packit#1803](https://github.com/packit/packit/pull/1803))\\n- Packit now resets the `Release` tag during `propose-downstream` if the version\\n is updated and the `Release` tag has not explicitly been overridden in the\\n upstream specfile.\\n ([packit#1801](https://github.com/packit/packit/pull/1801))\\n- If you still don\'t build SRPMs in Copr you\'ll get a warning status that you\\n should use `srpm_build_deps` to be sure that we don\'t break your workflow once\\n we switch to building all SRPMs in Copr in January.\\n ([packit-service#1804](https://github.com/packit/packit-service/pull/1804))\\n- We\'ve increased internal task retry backoff time in Packit GitHub app from 3 to\\n 7 seconds. We hope this will increase success for network flakes and _random_\\n infrastructure issues. Creation of bodhi updates should be now more reliable too\\n as Packit will try more times (from 2 to 5).\\n ([packit-service#1800](https://github.com/packit/packit-service/pull/1800))\\n- Tags enclosed in conditional macro expansions are not ignored anymore.\\n ([specfile#156](https://github.com/packit/specfile/pull/156))\\n- Context managers (`Specfile.sections()`, `Specfile.tags()` etc.) can now be nested\\n and combined together (with one exception - `Specfile.macro_definitions()`), and\\n it is also possible to use tag properties (e.g. `Specfile.version`, `Specfile.license`)\\n inside them. It is also possible to access the data directly, avoiding the `with`\\n statement, by using the `content` property (e.g. `Specfile.tags().content`), but\\n be aware that no modifications done to such data will be preserved. You must use\\n `with` to make changes.\\n ([specfile#153](https://github.com/packit/specfile/pull/153))\\n\\n## Week 50 (December 13th \u2013 December 19th)\\n\\n- Context managers are no longer shared between `Specfile` instances, making it possible\\n to work with more than one `Specfile` instance at a time.\\n ([specfile#157](https://github.com/packit/specfile/pull/157))"},{"id":"/2021","metadata":{"permalink":"/posts/weekly/2021","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2021.md","source":"@site/weekly/2021.md","title":"2021","description":"Let\'s see what happened in Packit in 2021.","date":"2022-05-16T00:00:00.000Z","formattedDate":"May 16, 2022","tags":[{"label":"2021","permalink":"/posts/weekly/tags/2021"}],"readingTime":18.03,"hasTruncateMarker":true,"authors":[],"frontMatter":{"title":"2021","date":"2022-05-16T00:00:00.000Z","tags":["2021"]},"prevItem":{"title":"2022","permalink":"/posts/weekly/2022"},"nextItem":{"title":"2020","permalink":"/posts/weekly/2020"}},"content":"Let\'s see what happened in Packit in 2021.\\n\\n\x3c!--truncate--\x3e\\n\\n## Week 1 (January 4th - January 8th)\\n\\n- Name of the job/command/comment to propose update of downstream package has been synced\\n between CLI and service to `propose-downstream`.\\n `propose-update` is now deprecated. ([packit#1065](https://github.com/packit-service/packit/pull/1065), [packit-service#913](https://github.com/packit/packit-service/pull/913))\\n\\n## Week 2 (January 11th - January 15th)\\n\\n- Branch deletions are now correctly ignored. ([packit-service#919](https://github.com/packit/packit-service/pull/919))\\n- Multiple internal improvements have been done.\\n ([packit#1072](https://github.com/packit/packit/pull/1072),\\n [packit-service#922](https://github.com/packit/packit-service/pull/922),\\n [packit-service#923](https://github.com/packit/packit-service/pull/923))\\n\\n## Week 3 (January 18th - January 22th)\\n\\n- We have temporarily disabled the testing-farm support because the cluster with old runner has died and the new runner is not ready.\\n The tests are now skipped and you get `Testing farm is temporarily disabled.` status until we have the new runner available.\\n ([packit-service#929](https://github.com/packit/packit-service/pull/929))\\n\\n## Week 4 (January 25th - January 29th)\\n\\n- The CLI and the service now detect name of the default branch of a repository\\n instead of assuming it to be called `master`.\\n ([packit#1074](https://github.com/packit/packit/pull/1074),\\n [packit-service#924](https://github.com/packit/packit-service/pull/924))\\n- Build status page now points to the built SRPM uploaded to COPR.\\n ([packit-service#889](https://github.com/packit/packit-service/pull/889))\\n- `propose-downstream` on source-git repositories now always uses `--local-content`.\\n ([packit#1093](https://github.com/packit/packit/pull/1093))\\n- Hunor fixed bug [packit#1089](https://github.com/packit/packit/pull/1089)\\n which caused a wrong revision to be used for certain jobs in Packit Service.\\n- Tomas improved the reliability of our sandboxing service.\\n ([sandcastle#95](https://github.com/packit/sandcastle/pull/95))\\n- Default branches in all [our repositories](https://github.com/packit)\\n have been renamed from `master` to `main`.\\n\\n## Week 5 (February 1st - February 5th)\\n\\n- The service uses new Testing Farm ([API](https://api.testing-farm.io)).\\n We are still working on better user experience and fixing bugs.\\n ([packit-service#875](https://github.com/packit/packit-service/pull/875))\\n- MatejF refactored permission system on pull requests and issues comments and\\n renamed whitelist to allowlist. ([packit-service#936](https://github.com/packit/packit-service/pull/936))\\n- The service now retries failed tasks.\\n ([packit-service#931](https://github.com/packit/packit-service/pull/931))\\n- `--koji-target` option of the CLI\'s `build` command now accepts aliases.\\n ([packit#1052](https://github.com/packit/packit/pull/1052))\\n- The service runs on Fedora 33 now.\\n\\n## Week 6 (February 8th - February 12th)\\n\\n- `--dist-git-branches` option in the CLI\'s `propose-downstream` command was\\n fixed, it now respects set branches.\\n ([packit#1094](https://github.com/packit/packit/pull/1094))\\n- The way Packit adds patches to spec-file in source-git repo was improved, now\\n it shouldn\'t fail if patches are sparsely numbered.\\n ([packit#1100](https://github.com/packit/packit/pull/1100))\\n\\n## Week 7 (February 15th - February 19th)\\n\\n- The service now handles issue/MR comments on Gitlab.\\n ([packit-service#985](https://github.com/packit/packit-service/pull/985))\\n- `packit init` command now works with CentOS packages.\\n ([packit#1106](https://github.com/packit/packit/pull/1106))\\n\\n## Week 8 (February 22th - February 25th)\\n\\n- Sandcastle can run multiple commands in one sandbox, kudos to Tomas.\\n ([sandcastle#93](https://github.com/packit/sandcastle/pull/93))\\n- MatejF & MatejM improved CLI\'s `create-update` to work with EPEL and add password prompt.\\n ([packit#1122](https://github.com/packit/packit/pull/1122),\\n [packit#1127](https://github.com/packit/packit/pull/1127))\\n- Service runs builds for targets from `build` + `test` jobs, kudos to Laura.\\n ([packit-service#996](https://github.com/packit/packit-service/pull/996))\\n- MatejF did a lot of small fixes and improvements of packit-service.\\n ([packit-service#989](https://github.com/packit/packit-service/pull/989),\\n [packit-service#993](https://github.com/packit/packit-service/pull/993),\\n [packit-service#994](https://github.com/packit/packit-service/pull/994))\\n\\n## Week 9 (March 1st - March 5th)\\n\\n- Tomas improved the performance of sandcastle, all the user-defined actions now run in one sandbox.\\n This should also speed up the SRPM builds. ([packit#1129](https://github.com/packit/packit/pull/1129))\\n- You can view the results of jobs directly in our dashboard, kudos to Anchit. ([dashboard#73](https://github.com/packit/dashboard/pull/73))\\n- Jirka implemented setting of the [environment context](https://tmt.readthedocs.io/en/latest/spec/context.html)\\n when running the Testing farm tests. ([packit-service#1008](https://github.com/packit/packit-service/pull/1008))\\n- In Packit there is a new configuration option `sources` which overrides the URLs defined in specfiles.\\n ([packit#1131](https://github.com/packit/packit/pull/1131), [packit#1143](https://github.com/packit/packit/pull/1143))\\n\\n## Week 10 (March 8th - March 12th)\\n\\n- Jirka worked on setting up GitHub Workflows across all of the Packit\\n repositories to build the container images for Packit Service and push them\\n to Quay.io.\\n- Tom\xe1\u0161 fixed a bug in the linearization mechanism used when generating patch\\n files from a series of Git commits. ([packit#1144](https://github.com/packit/packit/pull/1144))\\n- Hunor implemented a way for `packit` to detect if patch-files generated from\\n Git are identical with the ones already in dist-git. This should help\\n avoiding superfluous changes done by `propose-downstream`. ([packit#1133](https://github.com/packit/packit/pull/1133))\\n- Jirka increased the delay (to 3 minutes in total) for Packit Service when\\n retrying downloading the sources during a `propose-downstream` job. This\\n should give more time for the sources to become available after a release is\\n created. ([packit-service#1019](https://github.com/packit/packit-service/pull/1019))\\n- Mat\u011bj fixed an ugly bug which caused Packit Service not to react to\\n installation events. ([packit-service#1018](https://github.com/packit/packit-service/pull/1018))\\n\\n## Week 11 (March 15th - March 19th)\\n\\n- Laura fixed a bug in the processing of GitHub App installations.\\n ([packit-service#1020](https://github.com/packit/packit-service/pull/1020))\\n- Jirka fixed a bug that caused improper numbering of patches for source-git.\\n ([packit#1164](https://github.com/packit/packit/pull/1164))\\n\\n## Week 12 (March 22th - March 26th)\\n\\n- Franta improved database schema. It will help us match builds and tests together more easily and solve some UX problems.\\n ([packit-service#954](https://github.com/packit/packit-service/pull/954))\\n- `packit init` CLI command has been updated to\\n - place downstream packaging files in a subdirectory `.distro` instead of `fedora`.\\n ([packit#1165](https://github.com/packit/packit/pull/1165))\\n - enable using Stream 9 dist-git as a source.\\n ([packit#1177](https://github.com/packit/packit/pull/1177))\\n- Laura reworked how specfiles are being synced from downstream dist-git repositories and we are running a PoC for packit\'s projects to test the new approach.\\n ([packit-service#1023](https://github.com/packit/packit-service/pull/1023))\\n- It\'s possible to specify a distinct test repository for tests in a test job.\\n ([packit#1155](https://github.com/packit/packit/pull/1155))\\n ([packit-service#1021](https://github.com/packit/packit-service/pull/1021))\\n- `centos-stream` target is temporarily resolved to `centos-stream-8` to reflect a change in Copr.\\n ([packit#1167](https://github.com/packit/packit/pull/1167))\\n\\n## Week 13 (March 29th - April 1st)\\n\\n- Jirka fixed a bug in `packit push-update`\\n ([packit#1191](https://github.com/packit/packit/pull/1191)).\\n- Mat\u011bj introduced the `fedora-latest` alias for build and test targets, which\\n resolves to the latest _branched_ Fedora Linux\\n ([packit#1187](https://github.com/packit/packit/pull/1187)).\\n- A custom path for the package config (aka `packit.yaml`) can be specified\\n using a new, top-level `-c, --config` option\\n ([packit#1184](https://github.com/packit/packit/pull/1184)).\\n\\n## Week 14 (April 4th - April 9th)\\n\\n- Honza converted packit\'s test suite from STI to FMF and configured packit to\\n synchronize the suite to Fedora dist-git\\n ([packit#1192](https://github.com/packit/packit/pull/1192)).\\n- Franta fixed a bug in packit which kept only appending targets to an existing\\n COPR project which is no longer a case - dropped targets are now being\\n removed\\n ([packit#1197](https://github.com/packit/packit/pull/1197)).\\n\\n## Week 15 (April 12th - April 16th)\\n\\n- Tom\xe1\u0161 fixed an issue in chaining variable definitions in the RPM macros used\\n to set up source-git repositories with `packit init`\\n ([packit#1206](https://github.com/packit/packit/pull/1206)).\\n- Jirka improved the error message Packit Service emits when the request to\\n start a test in Testing Farm fails\\n ([packit-service#1055](https://github.com/packit/packit-service/pull/1055)).\\n- Laura made Packit Service to set a status for jobs as soon as the requests\\n are received, and before starting any of the jobs\\n ([packit-service#1046](https://github.com/packit/packit-service/pull/1046)).\\n This way users will receive a more immediate feedback about the Service\\n handling their requests.\\n\\n## Week 16 (April 19th - April 23th)\\n\\n- The `current_version_command` and `create_tarball_command` config options are being deprecated\\n in favour of [actions](https://packit.dev/docs/configuration/actions/).\\n An issue will be created in the affected repositories if we find those options in use.\\n ([packit-service#1064](https://github.com/packit/packit-service/pull/1064))\\n- The result pages have been replaced by the views on our dashboard.\\n Let us know what do you think about that and what information do you want to see there.\\n You can expect more changes on this field.\\n - The result views have been implemented by [@IceWreck](https://github.com/IceWreck)\\n ([dashboard#73](https://github.com/packit/dashboard/pull/73)).\\n - The integration on packit-service side has been done by [Ma\u0165o](https://github.com/mfocko)\\n ([packit-service#1056](https://github.com/packit/packit-service/pull/1056),\\n [dashboard#95](https://github.com/packit/dashboard/pull/95)).\\n\\n## Week 17 (April 26th - April 30th)\\n\\n- When initiating a new source-git repo, packit adds info about sources to packit.yaml.\\n Also dist-git sources from the lookaside cache are not commited.\\n ([packit#1208](https://github.com/packit/packit/pull/1208),\\n [packit#1216](https://github.com/packit/packit/pull/1216)).\\n- Franta added support for git repository cache into packit. The service part is yet to be done\\n ([packit#1214](https://github.com/packit/packit/pull/1214)).\\n- Service reacts to `/packit` commands only when they appear alone on a line\\n ([packit-service#1065](https://github.com/packit/packit-service/pull/1065),\\n [packit-service#1083](https://github.com/packit/packit-service/pull/1083)).\\n- Service doesn\'t create duplicate issues when configuration is invalid\\n ([packit-service#1075](https://github.com/packit/packit-service/pull/1075)).\\n- We deprecated `current_version_command` and `create_tarball_command` in packit config\\n ([packit#1212](https://github.com/packit/packit/pull/1212)).\\n\\n## Week 18 (May 3rd - May 7th)\\n\\n- Laura fixed the problem with `fedora-latest` alias\\n ([packit#1222](https://github.com/packit/packit/pull/1222)).\\n- We now have separate workers for short and long running tasks. This should\\n lead to better responsiveness\\n ([packit-service#1059](https://github.com/packit/packit-service/pull/1059),\\n [deployment#202](https://github.com/packit/deployment/pull/202)).\\n\\n## Week 19 (May 10th - May 14th)\\n\\n- Jirka added support for creating Bugzilla bugs for newly created MRs on GitLab\\n ([packit-service#1087](https://github.com/packit/packit-service/pull/1087)).\\n- The installation instructions for failed or unfinished COPR builds are not\\n displayed on the results page ([dashboard#104](https://github.com/packit/dashboard/pull/104)).\\n\\n## Week 20 (May 17th - May 21st)\\n\\n- Hunor created an update-dist-git command\\n ([packit#1228](https://github.com/packit/packit/pull/1228)).\\n- Jan: use packit config as a place to create reference to tests\\n ([packit#1245](https://github.com/packit/packit/pull/1245)).\\n\\n## Week 21 (May 24th - May 28th)\\n\\n- Jirka added attribute for `update-dist-git` command to specify the packaging tool (e.g. `centpkg`).\\n By default, `fedpkg` is used.\\n ([packit#1257](https://github.com/packit/packit/pull/1257),\\n [packit-service#1105](https://github.com/packit/packit-service/pull/1105)).\\n- Tom\xe1\u0161 added support for `patch_id` in the metadata of source-git commits.\\n ([packit#1252](https://github.com/packit/packit/pull/1252))\\n- Hunor improved the strategy of checking Copr results\\n when we don\'t receive that information over message-bus.\\n ([packit-service#1104](https://github.com/packit/packit-service/pull/1104))\\n\\n## Week 22 (May 31st - June 4th)\\n\\n- We have a new [status page](https://status.packit.dev), kudos to Jirka!\\n- Franta fixed a bug that if some action during `propose-downstream` caused an upstream git repository to be dirty,\\n the sync for other branches failed. ([packit-service#1111](https://github.com/packit/packit-service/pull/1111))\\n- `packit generate` is not supported anymore. ([packit#1269](https://github.com/packit/packit/pull/1269))\\n- Tom\xe1\u0161 improved the patch ordering. ([packit#1263](https://github.com/packit/packit/pull/1263))\\n\\n## Week 23 (June 7th - June 11th)\\n\\n- Tom\xe1\u0161 improved the way changelog is passed from source-git repo to dist-git.\\n ([packit#1265](https://github.com/packit/packit/pull/1265))\\n- Hunor created a new subcommand `source-git` to group source-git related commands\\n `init` and `update-dist-git`. ([packit#1273](https://github.com/packit/packit/pull/1273))\\n- Franti\u0161ek improved API by adding `submitted_time` to the test result.\\n ([packit-service#1113](https://github.com/packit/packit-service/pull/1113))\\n\\n## Week 24 (June 14th - June 19th)\\n\\n- Franta started working on packit-service being able to submit test jobs to\\n internal testing farm so teams can test upstream changes against RHEL.\\n ([packit-service#1124](https://github.com/packit/packit-service/pull/1124)\\n [packit#1280](https://github.com/packit/packit/pull/1280))\\n- Hunor continues working on `packit source-git init`: CLI is now more\\n streamlined and simplified, and the command produces source-git repos\\n matching [our documentation]({{< ref \\"create-source-git.md\\" >}}).\\n ([packit#1277](https://github.com/packit/packit/pull/1277))\\n- Ma\u0165o Focko finished his refactoring of the `Upstream` class - should not have\\n impact on our users, but make the code easier to work with.\\n ([packit#1157](https://github.com/packit/packit/pull/1157))\\n\\n## Week 25 (June 21st - June 26th)\\n\\n- Hunor made several improvements to `source-git init`\'s CLI.\\n ([packit#1284](https://github.com/packit/packit/pull/1284))\\n- Thanks to Frantisek there is now one COPR project/repo used for all releases.\\n ([packit-service#1128](https://github.com/packit/packit-service/pull/1128))\\n- Laura fixed a bug in syncing downstream to upstream.\\n ([packit#1285](https://github.com/packit/packit/pull/1285))\\n\\n## Week 26+27 (June 28th - July 9th)\\n\\nSummer is here and vacations with it. Most of the work done in this sprint\\nis either internal (not user facing) or not finished yet.\\n\\n- Thanks to Ma\u0165ejM Packit Service now triggers a new Copr build if no\\n suitable build has been found. That fixes an issue that the service sometimes\\n did not react to `/packit test`.\\n ([packit-service#1132](https://github.com/packit/packit-service/pull/1132))\\n\\n## Week 28 (July 12th - July 16th)\\n\\n- We have a new API endpoint for obtaining projects of a given forge.\\n ([packit-service#1159](https://github.com/packit/packit-service/pull/1159))\\n- The bug causing that some projects couldn\'t be loaded in our dashboard was fixed.\\n ([packit-service#1161](https://github.com/packit/packit-service/pull/1161))\\n\\n## Week 29 (July 19th - July 23th)\\n\\n- Various improvements on our dashboard were done; mainly:\\n - Projects can be filtered by a forge.\\n ([dashboard#124](https://github.com/packit/dashboard/pull/124))\\n - Table with jobs was unified and cleaned.\\n ([dashboard#121](https://github.com/packit/dashboard/pull/121))\\n- Newly, we use the [Checks API](https://docs.github.com/en/rest/reference/checks) to show results on GitHub.\\n You can still see the results on the bottom of the pull-request page,\\n but also in the `Checks` tab.\\n This gives us more options like status with a neutral state\\n (e.g. currently, for permission errors) or a place for showing more details.\\n Don\'t forget to give our GitHub application permissions to use it.\\n You can expect more improvements in this field.\\n ([packit-service#1167](https://github.com/packit/packit-service/pull/1167))\\n\\n## Week 30 (July 26th - July 30th)\\n\\n- Source-git patch metadata: the `squash_commits` key is deprecated. Instead of using this,\\n set the same [`patch_name`](/development/patch-metadata#patch_name) in the commit\\n message of adjacent commits, which should end up in the same patch file.\\n ([packit#1309](https://github.com/packit/packit/pull/1309))\\n- `packit init` can now find a spec file inside of a git repository and set\\n it in `.packit.yaml`. ([packit#1313](https://github.com/packit/packit/pull/1313))\\n- A lot of work has been done on our dashboard:\\n - Status labels on dashboard have been reworked.\\n - New pipelines view for dashboard has been released, where you can see all builds and\\n tests that were recently run for your pull request, release or branch push. Each row\\n represents one pipeline of builds and tests from SRPM all the way to the Testing Farm. \\n ([dashboard#128](https://github.com/packit/dashboard/pull/128))\\n\\n## Week 31 (August 2nd - August 6th)\\n\\n- `sync_release` in API allows specifying a suffix for the newly created branch in a dist-git repo fork,\\n so that there can be more open update PRs for the same dist-git branch at the same time.\\n ([packit#1326](https://github.com/packit/packit/pull/1326))\\n- The behaviour of running tests triggered by `/packit test` comment was improved.\\n If there is no existing Copr build when the tests are triggered,\\n Packit service should now react and create a new build.\\n Also when the last Copr build status is failed,\\n tests are not submitted and users are informed about this.\\n ([packit-service#1188](https://github.com/packit/packit-service/pull/1188))\\n- You can use `oraclelinux-7`/`oraclelinux-8` chroots for build and test of your package on Oracle Linux.\\n ([packit-service#1186](https://github.com/packit/packit-service/pull/1186))\\n\\n## Week 32 (August 9th - August 13th)\\n\\n- `status` command of Packit\'s CLI has been refactored and now provides much cleaner output. ([packit#1329](https://github.com/packit/packit/pull/1329))\\n\\n## Week 33 (August 16th - August 20th)\\n\\n- When reacting to `/packit test`, Packit service sets a status before starting the job\\n to unify the behaviour with reacting to triggering builds. ([packit-service#1187](https://github.com/packit/packit-service/pull/1187))\\n- `packit validate-config` now checks also the value of the `specfile_path` configuration option\\n and shows warning if the specified file is not present in the repository. ([packit#1342](https://github.com/packit/packit/pull/1342))\\n\\n## Week 34 (August 23rd - August 27th)\\n\\n- Packit by default locally merges checked out pull requests into target branch.\\n Logging for checking out pull requests was improved to contain hashes and\\n summaries of last commit on both source and target branches.\\n ([packit#1344](https://github.com/packit/packit/pull/1344))\\n- Packit Service now runs Copr and Koji builds and following tests on Testing Farm\\n for pull requests on the code that would be a result of merging into the target branch.\\n In case merge conflicts occur during preparation of SRPM,\\n you can find more info in the SRPM logs.\\n ([packit-service#1206](https://github.com/packit/packit-service/pull/1206))\\n- Packit\'s CLI `source-git update-dist-git` now supports using Git trailers to define patch metadata,\\n which will control how patches are generated and added to the spec-file.\\n `source-git init` uses this format to capture patch metadata when setting up\\n a source-git repo, instead of the YAML one.\\n To maintain backwards compatibility, the YAML format is still parsed,\\n but only if none of the patches defines metadata using Git trailers.\\n ([packit#1336](https://github.com/packit/packit/pull/1336))\\n- These changes will be applied next week (not this week as usual).\\n\\n## Week 35 (August 30th - September 3rd)\\n\\n- A bug in Packit that caused purging or syncing upstream changelog\\n (when not configured) from specfile when running `propose-downstream` was fixed.\\n New behavior preserves downstream changelog and in case there are either\\n no entries or no %changelog section present, it is created with a new entry.\\n ([packit#1349](https://github.com/packit/packit/pull/1349))\\n\\n## Week 36 (September 6th - September 10th)\\n\\n- `packit source-git init` was updated to try to apply patches with `git am` first, and use `patch` only when this fails, in order to keep the commit message of Git-formatted (mbox) patch files in the source-git history. ([packit#1358](https://github.com/packit/packit/pull/1358))\\n\\n## Week 37 (September 13th - September 17th)\\n\\n- Now you can find URL pointing directly to testing farm results on GitHub Checks page. ([packit-service#1215](https://github.com/packit/packit-service/pull/1215))\\n- Ogr now supports reacting to the comment with a given reaction, getting them in list and deleting them (only when reaction is added by using ogr API). ([ogr#636](https://github.com/packit/ogr/pull/636))\\n- Packit now provides `PACKIT_RPMSPEC_RELEASE` environment variable in actions. ([packit#1363](https://github.com/packit/packit/pull/1363))\\n- Dashboard no longer shrinks Copr/Koji icons when being open in narrow view. ([dashboard#140](https://github.com/packit/dashboard/pull/140))\\n\\n## Week 38 (September 20th - September 24th)\\n\\n- [Dashboard](https://dashboard.packit.dev) now shows more readable format of time,\\n e.g. \\"just now\\", \\"a minute ago\\", etc. If you wish to see exact date-time of\\n the run, you can either hover over the time and tooltip with details appear.\\n In case of result pages more readable format is present in the tooltip rather\\n than by default. Also times are now shown in your local time zone. ([dashboard#142](https://github.com/packit/dashboard/pull/142))\\n- Packit can now read commit messages from a patch to support characters which cannot be encoded with UTF-8. ([packit#1372](https://github.com/packit/packit/pull/1372))\\n- EPEL targets are now being mapped to CentOS Linux inside the internal Testing Farm runs. ([packit-service#1225](https://github.com/packit/packit-service/pull/1225))\\n\\n## Week 39 (September 27th - October 1st)\\n\\n- Clicking on logo on [dashboard](https://dashboard.packit.dev/) no longer\\n opens a new page, but rather reloads the current one.\\n- We consider [Pipelines view](https://dashboard.packit.dev/pipelines) on\\n dashboard to be ready for production use. We\'re planning to improve the user\\n experience when using pipelines with easier navigation and filtering\\n options.\\n- Building the latest development versions of\\n [packit](https://github.com/packit/packit) and\\n [ogr](https://github.com/packit/ogr) was moved to the\\n [packit/packit-dev](https://copr.fedorainfracloud.org/coprs/packit/packit-dev/)\\n Copr repo.\\n\\n## Week 40 (October 4th - October 8th)\\n\\n- [A bug](https://github.com/packit/packit/issues/1255) in Packit causing\\n issues with local build when the branch was named with prefix `rpm` has been\\n fixed.\\n- To fulfill requests regarding updating targets on Copr repositories, Packit\\n Service will sync targets for the projects created by Packit Service (e.g.\\n pull requests, or non-set Copr repository for releases and branch builds)\\n and for Copr repositories **not owned by Packit** will try to extend the\\n list if necessary.\\n- If you trigger packit jobs with one of `/packit _` commands, our bot gives\\n you a \ud83d\udc4d reaction to let you know that we are working on it.\\n- Rerunning of failed tasks via GitHub Checks interface is now supported. You are now free to click those \\"Re-run\\" links.\\n- [ogr documentation](https://packit.github.io/ogr/) is converted to\\n Google-style docstrings. In case there are any discrepancies, missing docs\\n or docstrings in different format, please open an issue.\\n\\n## Week 41 (October 11th - October 15th)\\n\\n- We have added a new option to Packit CLI when creating Bodhi updates, you can\\n use `-b` or `--resolve- bugzillas` and specify IDs (separated by comma, e.g.\\n `-b 1` or `-b 1,2,3`) of bugzillas that are being closed by the update.\\n ([packit#1383](https://github.com/packit/packit/pull/1383))\\n- Packit will deduce the version for SRPM from the spec file, if there are no\\n git tags or action for acquiring current version defined.\\n ([packit#1388](https://github.com/packit/packit/pull/1388))\\n- It is possible to use `aarch64` architecture in the Testing Farm.\\n ([packit-service#1247](https://github.com/packit/packit-service/pull/1247))\\n- Running tests via Testing Farm now supports `centos-6` target.\\n ([packit-service#1244](https://github.com/packit/packit-service/pull/1244))\\n\\n## Week 42 (October 18th - October 22th)\\n\\n- We have introduced new options for generating SRPM packages:\\n ([packit#1396](https://github.com/packit/packit/pull/1396))\\n - `--no-bump` that prevents changing of the release in the SRPM,\\n which can be used for creating SRPMs on checked out tags/releases.\\n - `--release-suffix` that allows you to customize the suffix after the release number,\\n e.g. reference bugzilla or specific branch of the build.\\n- Copr build installation instructions now contain detailed info about\\n the built packages, so you can install the precise build from your pull request.\\n ([dashboard#149](https://github.com/packit/dashboard/pull/149))\\n\\n## Week 43 (October 25th - November 1st)\\n\\n- We have introduced a new configuration option `merge_pr_in_ci` that allows you to disable merging of PR into the base branch before creating SRPM in service. ([packit#1395](https://github.com/packit/packit/pull/1395), [packit-service#1261](https://github.com/packit/packit-service/pull/1261))\\n- If the upstream spec file is located in a subdirectory (such as\\n `packaging/fedora/pkg.spec`), it is now correctly synced to the root of\\n the downstream repository, since that\'s where rpmbuild will look\\n for it. ([packit#1402](https://github.com/packit/packit/pull/1402))\\n- The \\"Congratulations!\\" comment no longer has a disclaimer about our intentions to stop posting it by default. We have already made that move earlier this year, so the disclaimer is no longer relevant. ([packit-service#1260](https://github.com/packit/packit-service/pull/1260))\\n- Deprecated configuration options `current_version_command` and `create_tarball_command` have been removed and are no longer supported. They are superseded by actions `get-current-version` and `create-archive`. ([packit#1397](https://github.com/packit/packit/pull/1397))\\n\\n## Week 44 (November 1st - November 5th)\\n\\n- We have fixed several issues in packit when it\'s periodically checking\\n statuses of jobs. You should now reliably see up to date check statuses for\\n Copr RPM builds and Testing Farm runs.\\n ([packit-service#1267](https://github.com/packit/packit-service/pull/1267)),\\n ([packit-service#1265](https://github.com/packit/packit-service/pull/1265))\\n- Fixed an issue, which raised a `UnicodeEncodingError`, when working with\\n dist-git patch files with an encoding other than UTF-8.\\n ([packit#1406](https://github.com/packit/packit/pull/1406))\\n- Backup alias definitions now reflect the official release of Fedora 35.\\n ([packit#1405](https://github.com/packit/packit/pull/1405))\\n\\n## Week 45 (November 8th - November 12th)\\n\\n- You can now specify `skip_build` option in the test job metadata in the\\n Packit configuration file. This will cause no Copr build to be built and\\n installed into the testing environment, but only trigger the tests in\\n Testing Farm (the selected components to be installed should be part of the\\n TMT definitions).\\n ([packit-service#1256](https://github.com/packit/packit-service/pull/1256))\\n- Packit supports `changelog-entry` action that is used when creating SRPM.\\n The action is supposed to generate whole changelog entry (including `- ` at\\n the start of the lines) and has a priority over any other way we modify the\\n changelog with. ([packit#1367](https://github.com/packit/packit/pull/1367))\\n\\n## Week 46 (November 15th - November 19th)\\n\\n- A new `env` config option has been added for specifying environment variables,\\n which are then passed to Testing Farm along with some more pre-defined\\n variables (e.g. name of the project, URL, etc).\\n ([packit#1411](https://github.com/packit/packit/pull/1411))\\n ([packit-service#1275](https://github.com/packit/packit-service/pull/1275))\\n- The GitHub check run names are now shorter and easier to read.\\n ([packit-service#1281](https://github.com/packit/packit-service/pull/1281))\\n\\n## Week 47 (November 22th - November 26th)\\n\\n- You can set up a new `koji_build` job using the commit trigger to submit a\\n Koji build for a new commit in a dist-git branch. The configuration file\\n needs to be present in the dist-git for now\\n (the state for the new commit is used).\\n ([packit-service#1278](https://github.com/packit/packit-service/pull/1278))\\n\\n## Week 48 (November 29th - December 3rd)\\n\\n- External contributors can\'t trigger internal tests initially. Project\\n maintainers need to trigger the action via `/packit test` comment to run\\n the job.\\n ([packit-service#1302](https://github.com/packit/packit-service/pull/1302))\\n ([packit-service#1305](https://github.com/packit/packit-service/pull/1305))\\n- A new `packit prepare-sources` command has been implemented for preparing\\n sources for an SRPM build using the content of an upstream repository.\\n ([packit#1424](https://github.com/packit/packit/pull/1424))\\n- Packit now visibly informs about an ongoing cloning process to remove\\n potential confusion.\\n ([packit#1431](https://github.com/packit/packit/pull/1431))\\n- The `upstream_package_name` config option is now checked for illegal\\n characters and an error is thrown if it contains them.\\n ([packit#1434](https://github.com/packit/packit/pull/1434))\\n\\n## Week 49 (December 6th - December 12th)\\n\\n- Packit now correctly finds the release event if you don\'t use the version as a release title.\\n ([packit#1437](https://github.com/packit/packit/pull/1437))"},{"id":"/2020","metadata":{"permalink":"/posts/weekly/2020","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2020.md","source":"@site/weekly/2020.md","title":"2020","description":"Let\'s see what happened in Packit in 2020.","date":"2022-01-04T00:00:00.000Z","formattedDate":"January 4, 2022","tags":[{"label":"2020","permalink":"/posts/weekly/tags/2020"}],"readingTime":22.565,"hasTruncateMarker":true,"authors":[],"frontMatter":{"title":"2020","date":"2022-01-04T00:00:00.000Z","tags":["2020"]},"prevItem":{"title":"2021","permalink":"/posts/weekly/2021"},"nextItem":{"title":"2019","permalink":"/posts/weekly/2019"}},"content":"Let\'s see what happened in Packit in 2020.\\n\\n\x3c!--truncate--\x3e\\n\\n## Week 1\\n\\n### packit\\n\\n- Correctly updates version on srpm build. ([#642](https://github.com/packit-service/packit/pull/642))\\n- Downloads all URL sources before srpm build. ([#643](https://github.com/packit-service/packit/pull/643))\\n\\n### packit service\\n\\n- Runs on Fedora 31. ([#303](https://github.com/packit-service/packit-service/pull/303), [#304](https://github.com/packit-service/packit-service/pull/304))\\n- Correctly checks list of whitelisted repositories when issue comment is added. ([#309](https://github.com/packit-service/packit-service/pull/309))\\n\\n## Week 2\\n\\n### packit\\n\\n- Incorporates lots of SRPM related improvements. ([#646](https://github.com/packit-service/packit/pull/646), [#650](https://github.com/packit-service/packit/pull/650), [#651](https://github.com/packit-service/packit/pull/651), [#652](https://github.com/packit-service/packit/pull/652), [#653](https://github.com/packit-service/packit/pull/653))\\n- Better handles when Copr owner is not set. ([#648](https://github.com/packit-service/packit/pull/648))\\n\\n### packit service\\n\\n- Fixes SRPM exceptions/errors handling. ([#311](https://github.com/packit-service/packit-service/pull/311), [#317](https://github.com/packit-service/packit-service/pull/317))\\n- Has loading of config fixed. ([#318](https://github.com/packit-service/packit-service/pull/318))\\n\\n## Week 3\\n\\n### packit\\n\\n- Uses [Marshmallow](https://pypi.org/project/marshmallow) for configuration schema. ([#657](https://github.com/packit-service/packit/pull/657))\\n- Is able to build in [Koji](https://koji.fedoraproject.org) from upstream/source-git. ([#658](https://github.com/packit-service/packit/pull/658))\\n- Doesn\'t download remote sources when \\"sources\\" path exists in upstream. ([#659](https://github.com/packit-service/packit/pull/659))\\n- Configuration file allows list syntax in action commands. ([#663](https://github.com/packit-service/packit/pull/663))\\n- Configuration can use a new option to exclude paths from patching. ([#666](https://github.com/packit-service/packit/pull/666))\\n- Has few less bugs. ([#660](https://github.com/packit-service/packit/pull/660), [#661](https://github.com/packit-service/packit/pull/661), [#664](https://github.com/packit-service/packit/pull/664), [#667](https://github.com/packit-service/packit/pull/667))\\n\\n### packit service\\n\\n- Uses [Marshmallow](https://pypi.org/project/marshmallow) for configuration schema. ([#320](https://github.com/packit-service/packit-service/pull/320))\\n- Runs build for test job even when it\'s not explicitly configured. ([#324](https://github.com/packit-service/packit-service/pull/324))\\n- Reports invalid or missing packit config. ([#328](https://github.com/packit-service/packit-service/pull/328))\\n- Status workflow has been changed and simplified. ([#338](https://github.com/packit-service/packit-service/pull/338))\\n- Minor fixes. ([#323](https://github.com/packit-service/packit-service/pull/323), [#326](https://github.com/packit-service/packit-service/pull/326), [#329](https://github.com/packit-service/packit-service/pull/329), [#331](https://github.com/packit-service/packit-service/pull/331), [#335](https://github.com/packit-service/packit-service/pull/335), [#336](https://github.com/packit-service/packit-service/pull/336))\\n\\n## Week 4\\n\\n### packit\\n\\n- [0.8.1](https://pypi.org/project/packitos/0.8.1/) has been released.\\n- CLI has bash auto completion. ([#654](https://github.com/packit-service/packit/pull/654))\\n- Few bugs have been squashed. ([#668](https://github.com/packit-service/packit/pull/668), [#670](https://github.com/packit-service/packit/pull/670), [#676](https://github.com/packit-service/packit/pull/676), [#677](https://github.com/packit-service/packit/pull/677), [#678](https://github.com/packit-service/packit/pull/678), [#680](https://github.com/packit-service/packit/pull/680), [#682](https://github.com/packit-service/packit/pull/682))\\n\\n### packit service\\n\\n- More checks messages have been unified. ([#355](https://github.com/packit-service/packit-service/pull/355))\\n- One more testing-farm status is now shown before the tests are submitted. ([#343](https://github.com/packit-service/packit-service/pull/343))\\n- No-fmf scenario has better messages. ([#362](https://github.com/packit-service/packit-service/pull/362))\\n- Minor fixes and improvements. ([#339](https://github.com/packit-service/packit-service/pull/339), [#340](https://github.com/packit-service/packit-service/pull/340), [#342](https://github.com/packit-service/packit-service/pull/342), [#345](https://github.com/packit-service/packit-service/pull/345), [#346](https://github.com/packit-service/packit-service/pull/346), [#347](https://github.com/packit-service/packit-service/pull/347), [#348](https://github.com/packit-service/packit-service/pull/348), [#352](https://github.com/packit-service/packit-service/pull/352), [#353](https://github.com/packit-service/packit-service/pull/353), [#350](https://github.com/packit-service/packit-service/pull/350), [#357](https://github.com/packit-service/packit-service/pull/357), [#358](https://github.com/packit-service/packit-service/pull/358), [#361](https://github.com/packit-service/packit-service/pull/361), [#364](https://github.com/packit-service/packit-service/pull/364))\\n\\n## Week 5\\n\\n### packit\\n\\n- CLI has a new command for local build. ([#687](https://github.com/packit-service/packit/pull/687))\\n- Logs less. ([#685](https://github.com/packit-service/packit/pull/685))\\n\\n### packit service\\n\\n- Minor fixes and improvements. ([#365](https://github.com/packit-service/packit-service/pull/365), [#371](https://github.com/packit-service/packit-service/pull/371), [#373](https://github.com/packit-service/packit-service/pull/373), [#376](https://github.com/packit-service/packit-service/pull/376))\\n\\n## Week 6\\n\\nBoth Packit and Packit Service pre-commit hooks [were][1] [updated][2] to include\\n[prettier] and [setup-cfg-fmt], in order to have a more consistent formatting of\\nmarkup, YAML, JSON and `setup.cfg` files.\\n\\nIt became easier for developers to [build the Packit base image] locally, and\\ntests in Zuul [were configured] to run on Fedora 31.\\n\\nPackit learned [how to look for RPM spec files on its own], so specifying\\n`specfile_path` in the configuration is not mandatory anymore. Packit will\\nrecursively search the tree and use the first spec file found.\\n\\nThe Redis pod in Packit Service uses an up to date image now, [based on Fedora 31].\\nKudos to [hhorak] for the help!\\n\\n[1]: https://github.com/packit-service/packit/pull/697\\n[2]: https://github.com/packit-service/packit-service/pull/383\\n[prettier]: https://github.com/prettier/prettier\\n[setup-cfg-fmt]: https://github.com/asottile/setup-cfg-fmt\\n[build the packit base image]: https://github.com/packit-service/packit/pull/695\\n[were configured]: https://github.com/packit-service/packit/pull/694\\n[how to look for rpm spec files on its own]: https://github.com/packit-service/packit/pull/634\\n[based on fedora 31]: https://github.com/packit-service/deployment/pull/51\\n[hhorak]: https://github.com/hhorak\\n\\n## Week 7\\n\\nThe default configuration generated by Packit has [test jobs enabled] from now\\non. This should simplify configuring Packit in new repositories.\\n\\n[Fixed a bug] which was causing SRPM-build failures in Packit Service for projects\\nwhich had their spec files stored in a subdirectory.\\n\\nAs a result of [keys.fedoraproject.org] being turned off, Packit now [tries] a\\nlist of GPG keyservers when downloading keys to check commit signatures.\\n\\nWhen enabling Packit Service for new GitHub repositories, instead of checking\\nif the requester is a Fedora packager, we\'ll check if they [signed the Fedora\\nProject Contributor Agreement].\\n\\nWhile proposing an update to Fedora, Packit Service will [report a failure] now\\nwhen there are no releases found in the upstream GitHub repository.\\n\\nTest results became [serializable], we will not block when [no test results\\nare received], and Packit Service received [some initial code] to enable using\\nPostgreSQL as a data backend.\\n\\n[test jobs enabled]: https://github.com/packit-service/packit/pull/703\\n[fixed a bug]: https://github.com/packit-service/packit/pull/698\\n[tries]: https://github.com/packit-service/packit/pull/699\\n[keys.fedoraproject.org]: https://lists.fedoraproject.org/archives/list/devel@lists.fedoraproject.org/message/COEYWJBQDAWRSYNQW7Y7TD2EKEGBWOAY/\\n[signed the fedora project contributor agreement]: https://github.com/packit-service/packit-service/pull/403\\n[no test results are received]: https://github.com/packit-service/packit-service/pull/388\\n[some initial code]: https://github.com/packit-service/packit-service/pull/319\\n[report a failure]: https://github.com/packit-service/packit-service/pull/399\\n[serializable]: https://github.com/packit-service/packit-service/pull/391\\n\\n## Week 8\\n\\nPostgresql database was introduced in production environment to improve performance and enable implementation\\nof new features, e.g. storing logs to reduce amount of messages sent directly to pull request [(#406)], [(#420)].\\n\\nCleanup in configuration files was performed, so no longer needed values were removed from .packit.yaml [(#709)].\\nUser experience was improved by adding new `--upstrem-ref` option to `copr-build` command in command-line interface [(#718)]\\nand making error reporting more robust by adding new fedpkg clones related error message [(#714)].\\n\\nFollowing bugs were fixed:\\n\\n- bug in copr-build command fixed [(#713)]\\n- get_local_package_config() duplicate entries in \'directories\' bug fixed [(#715)]\\n\\n[(#709)]: https://github.com/packit-service/packit/pull/709\\n[(#718)]: https://github.com/packit-service/packit/pull/718\\n[(#714)]: https://github.com/packit-service/packit/pull/714\\n[(#713)]: https://github.com/packit-service/packit/pull/713\\n[(#715)]: https://github.com/packit-service/packit/pull/715\\n[(#406)]: https://github.com/packit-service/packit-service/pull/406\\n[(#420)]: https://github.com/packit-service/packit-service/pull/420\\n\\n## Week 9\\n\\n### packit\\n\\n- Dist-git patches are now applied in source-git repos with `-p1` to resolve an issue when they are generated with git and patch program fails to apply them [(#730)].\\n- Fedora 32 was added to \'fedora-all\' and \'fedora-development\' aliases [(#731)].\\n- We have put more links to our documentation (README, deprecation warning in packit) so that people can easily correct their configuration files [(#726)].\\n\\n### packit-service\\n\\n- `targets` key in copr job definition in the packit.yaml is no longer a required field (it defaults to `fedora-stable`) [(#431)].\\n- Builds are now correctly linked to their actual GitHub projects (this can be seen in the logs view) [(#441)].\\n\\n[(#730)]: https://github.com/packit-service/packit/pull/730\\n[(#731)]: https://github.com/packit-service/packit/pull/731\\n[(#726)]: https://github.com/packit-service/packit/pull/726\\n[(#431)]: https://github.com/packit-service/packit-service/pull/431\\n[(#441)]: https://github.com/packit-service/packit-service/pull/441\\n\\n## Week 10 (March 2nd - March 6th)\\n\\n### packit\\n\\n- The generate command is now deprecated in favour of the init command\\n [(#728)], contributed by [@shreyaspapi](https://github.com/shreyaspapi).\\n\\n### packit-service\\n\\n- When a non-collaborator creates a PR, packit says that only \\"Collaborators\\n can trigger packit-service\\" - this message has been improved to better match\\n the reality [(#445)].\\n- Packit service no longer posts comments on pull requests when a SRPM can\'t be\\n created - the logs should be now aviable in the service\'s logs view available\\n when clocking on the commit status check URL [(#447)].\\n- Commands to control packit service can now be embedded in a comment\\n (previously, the whole comment was treated as a command) - hence you can now\\n create a comment to give an update and also trigger packit [(#433)],\\n contributed by [@IceWreck](https://github.com/IceWreck).\\n- We have improved monitoring of packit-service by using more sentry.io\'s\\n features [(#458)].\\n- You can now disable the functionality when packit service comments on a PR\\n when it gets built for the first time (`notifications: {pull_request: {successful_build:: false}}` in your packit.yaml), hi\\n [Lars](https://github.com/larskarlitski)! [(#455)].\\n\\n[(#728)]: https://github.com/packit-service/packit/pull/728\\n[(#445)]: https://github.com/packit-service/packit-service/pull/445\\n[(#447)]: https://github.com/packit-service/packit-service/pull/447\\n[(#433)]: https://github.com/packit-service/packit-service/pull/433\\n[(#458)]: https://github.com/packit-service/packit-service/pull/458\\n[(#455)]: https://github.com/packit-service/packit-service/pull/455\\n\\n## Week 11 (March 9th - March 13th)\\n\\n### packit\\n\\n- We have changed how packit treats version and release in the spec file [(#748)].\\n - We handle the `git-describe` output better which should help when tags\\n contain dashes [(#759)].\\n- When packit adds source-git patches into a spec file it adds them outside\\n of rpm macros now [(#760)].\\n- In pull request pipelines we run the packit-service tests so that we are sure we\\n do not break the service [(#752)].\\n\\n### packit-service\\n\\n- Comments from packit-service about successful `propose-update` in the issue\\n which triggered the update now include the URL of the new pull-request in Fedora [(#472)].\\n- We have done some major refactoring how jobs are processed\\n [(#476)], [(#746)], [(#453)].\\n- Development and debugging of the packit-service should be easier now, we\\n documented how to run packit-service locally [(#473)].\\n\\n[(#746)]: https://github.com/packit-service/packit/pull/746\\n[(#748)]: https://github.com/packit-service/packit/pull/748\\n[(#752)]: https://github.com/packit-service/packit/pull/752\\n[(#759)]: https://github.com/packit-service/packit/pull/759\\n[(#760)]: https://github.com/packit-service/packit/pull/760\\n[(#472)]: https://github.com/packit-service/packit-service/pull/472\\n[(#473)]: https://github.com/packit-service/packit-service/pull/473\\n[(#476)]: https://github.com/packit-service/packit-service/pull/476\\n[(#453)]: https://github.com/packit-service/packit-service/pull/453\\n\\n## Week 12 (March 16th - March 20th)\\n\\n### packit\\n\\n- When you are executing `copr-build` command, you do not\\n need to set the project name if this value is defined in\\n the `copr_build` job in the configuration file [(#763)].\\n- All patches generated from a source-git repo are now prefixed with a number\\n so they are easy to sort [(#765)].\\n- We improved the behaviour when loading the authentication in the config file -\\n users are warned only if deprecated keys are used, no more confusing messages when\\n you do not have `authentication` key in the configuration [(#754)].\\n\\n### packit-service\\n\\n- We periodically check the status of the copr-build so that we do not need to rely\\n on the Fedora message bus. This should avoid failures in build status reporting [(#490)].\\n- `Propose-update` triggered by comment in GitHub now recognizes also pre-releases [(#498)].\\n- Several bugs in how we report results from Testing farm have been fixed and Testing\\n farm results should now appear correctly in commit status checks\\n [(#496)], [(#505)], [(#510)], [(#513)].\\n\\n[(#765)]: https://github.com/packit-service/packit/pull/765\\n[(#754)]: https://github.com/packit-service/packit/pull/754\\n[(#763)]: https://github.com/packit-service/packit/pull/763\\n[(#490)]: https://github.com/packit-service/packit-service/pull/490\\n[(#498)]: https://github.com/packit-service/packit-service/pull/498\\n[(#497)]: https://github.com/packit-service/packit-service/pull/497\\n[(#496)]: https://github.com/packit-service/packit-service/pull/496\\n[(#505)]: https://github.com/packit-service/packit-service/pull/505\\n[(#510)]: https://github.com/packit-service/packit-service/pull/510\\n[(#513)]: https://github.com/packit-service/packit-service/pull/513\\n\\n## Week 13 (March 23th - March 27th)\\n\\n- New Packit version 0.9.0 was released.\\n- Packit Service now mostly uses PostgreSQL instead of Redis as a backend,\\n which will result in more responsive API and Dashboard.\\n\\n## Week 14 (March 30th - April 3rd)\\n\\n### packit\\n\\n- Fix web URLs for Copr builds owned by groups [(#778)].\\n- Create downstream spec if it\'s not there (propose-update) - this used to happen when using packit on a newly created package in Fedora which did not have spec fille added yet. [(#779)]\\n- Packit no longer inspects archive extension set in `Source` and creates `.tar.gz` by default - this should be more flexible and prevent issues for \\"non-standard\\" archive names. [(#781)]\\n\\n### packit-service\\n\\n- Several fixes and improvements after switching data store from Redis to PostgreSQL.\\n- Use the configured COPR project when triggering Testing Farm (tests no longer fail for projects which are built in their own COPR namespace) [(#524)].\\n\\n[(#778)]: https://github.com/packit-service/packit/pull/778\\n[(#779)]: https://github.com/packit-service/packit/pull/779\\n[(#781)]: https://github.com/packit-service/packit/pull/781\\n[(#524)]: https://github.com/packit-service/packit-service/pull/524\\n\\n## Week 15 (March 6th - April 9th)\\n\\n### packit\\n\\n- [Tom\xe1\u0161] finished teaching `packit srpm` to [linearise extremely complex Git\\n histories], in order to get patches that can be applied when building the\\n SRPM.\\n- [Jirka] made the schema validation code [Marshmallow3 compatible]. This\\n enables building `packit` in Fedora 32 and Rawhide.\\n\\n### packit-service\\n\\n- [Franta] fixed an issue with [parsing release events].\\n- [Jirka] made code [Marshmallow3] compatible in this project, too.\\n\\n[tom\xe1\u0161]: https://github.com/TomasTomecek\\n[jirka]: https://github.com/jpopelka\\n[franta]: https://github.com/lachmanfrantisek\\n[linearise extremely complex git histories]: https://github.com/packit-service/packit/pull/766\\n[marshmallow3 compatible]: https://github.com/packit-service/packit/pull/775\\n[marshmallow3]: https://github.com/packit-service/packit-service/pull/538\\n[parsing release events]: https://github.com/packit-service/packit-service/issues/536\\n\\n## Week 16 (April 14th - April 17th)\\n\\n### packit & packit-service\\n\\n- Job metadata field `dist-git-branch` is now marked as deprecated, to be\\n replaced by `dist_git_branches` to match the naming of other metadata fields\\n and to accept multiple branch names where Packit should work. ([#797],\\n [#788] and [#564]).\\n- A great deal of refactoring, CI work and general code improvements which\\n will make Packit and Packit Service run smoother and development easier.\\n\\n[#797]: https://github.com/packit-service/packit/pull/797\\n[#788]: https://github.com/packit-service/packit/pull/788\\n[#564]: https://github.com/packit-service/packit-service/pull/564\\n\\n## Week 17 (April 20th - April 24th)\\n\\n### packit-service\\n\\nIn this week we mostly focused on CentOS Stream and\\nsome under the hood improvements,\\nnone of which are available for GitHub projects.\\n\\n- [Jano] did a lot of work on [initial CentOS Stream integration].\\n- [Hunor] added a Pagure build status reporting.\\n- [Anchit] added first API tests and improved build statuses given by the API.\\n- [Laura] and [Rishav] improved how data about Copr builds are stored in our db.\\n\\n[anchit]: https://github.com/IceWreck\\n[hunor]: https://github.com/csomh\\n[jano]: https://github.com/sakalosj\\n[laura]: https://github.com/lbarcziova\\n[rishav]: https://github.com/rishavanand\\n[initial centos stream integration]: https://github.com/packit-service/packit-service/pull/515\\n\\n## Week 18 (April 27th - April 30th)\\n\\n### packit-service\\n\\n- [Franta] did a great deal of service & worker refactoring related to CentOS ([#586])\\n and to forks usage in GitHub. ([#589])\\n- [Hunor] fixed confusing GitHub status messages while building in Copr. ([#588])\\n\\n[#586]: https://github.com/packit-service/packit-service/pull/586\\n[#588]: https://github.com/packit-service/packit-service/pull/588\\n[#589]: https://github.com/packit-service/packit-service/pull/589\\n\\n## Week 19 (May 4th - May 6th)\\n\\n### packit\\n\\n- The image now uses ogr from git master instead of from Fedora stable RPM.\\n\\n### packit-service\\n\\n- [Franta] Fixed a previous week introduced bug, which prevented users from being whitelisted. ([#599])\\n- [Hunor] Made improvements to avoid a race condition in getting app access token. ([#601])\\n\\n[franta]: https://github.com/lachmanfrantisek\\n[hunor]: https://github.com/csomh\\n[#599]: https://github.com/packit-service/packit-service/pull/599\\n[#601]: https://github.com/packit-service/packit-service/pull/601\\n\\n## Week 20+21 (May 11th - May 22th)\\n\\n### packit\\n\\n- The debug logs in the CLI are now much more consistent. ([#824])\\n- A bug in the `propose-update` causing problems with the synchronization of the spec-file content was fixed. ([#830])\\n- You can now use `epel-all` alias in the arguments and also in the configuration. ([#835])\\n\\n### packit-service\\n\\n- In job definition for packit-service you can use `epel-all` alias as well. ([#835])\\n\\n[#824]: https://github.com/packit-service/packit/pull/824\\n[#830]: https://github.com/packit-service/packit/pull/830\\n[#835]: https://github.com/packit-service/packit/pull/835\\n\\n## Week 22 (May 25th - May 29th)\\n\\n### packit\\n\\n- [The problem with kerberos initialization](https://github.com/packit-service/packit/issues/837)\\n was fixed. ([#838])\\n- We released a new version of the packit package. ([release 0.11.0])\\n- We have been also working on some smaller issues and preparation steps for our future work.\\n ([#841], [#843], [#846], [#847])\\n\\n[#838]: https://github.com/packit-service/packit/pull/838\\n[#841]: https://github.com/packit-service/packit/pull/841\\n[#843]: https://github.com/packit-service/packit/pull/843\\n[#846]: https://github.com/packit-service/packit/pull/846\\n[#847]: https://github.com/packit-service/packit/pull/847\\n[release 0.11.0]: https://github.com/packit-service/packit/releases/tag/0.11.0\\n\\n### packit-service\\n\\n- [Jirka] implemented creating a new bug in Bugzilla for CentOS Stream pull-requests ([#627]).\\n This will be triggered when the label \\"accepted\\" is added to a PR in the (near) future.\\n- You will be able to use aliases also for koji builds. ([packit:#839], [#632])\\n- [Laura] fixed [a problem](https://github.com/packit-service/packit-service/issues/535)\\n with missing builds when triggering Packit Service with `/packit test`.\\n Now, we trigger the build first if there are no builds for the pull-request yet. ([#631])\\n\\n[jirka]: https://github.com/jpopelka\\n[laura]: https://github.com/lbarcziova\\n[#627]: https://github.com/packit-service/packit-service/pull/627\\n[packit:#839]: https://github.com/packit-service/packit/pull/839\\n[#632]: https://github.com/packit-service/packit-service/pull/632\\n[#631]: https://github.com/packit-service/packit-service/pull/631\\n\\n## Week 23 (June 1st - June 5th)\\n\\nHello everyone, during this week we didn\'t manage to implement any significant new features - most of the work happened under the hood.\\n\\n### packit\\n\\n- We have fixed a formatting issue when packit prints installation instructions for using builds from a copr repo (by [@lachmanfrantisek](https://github.com/lachmanfrantisek), [#852](https://github.com/packit-service/packit/pulls/852)).\\n- You are able to set up builds when you push to a branch, we have set this up for master branch of packit, feel free to get inspired (by [@lachmanfrantisek](https://github.com/lachmanfrantisek), [#851](https://github.com/packit-service/packit/pulls/851)).\\n\\n### packit-as-a-service\\n\\n- We have run into multiple problems when you set up jobs for PRs and branch pushes - there were multiple fixes for this, packit-service wasn\'t able to work well with the fact that there are multiple jobs defined for the same job type - e.g. build.\\n\\n## Week 24 (June 8th - June 11th)\\n\\n### packit\\n\\n- [Tomas](https://github.com/TomasTomecek) re-implemented overriding of package config per job. This will enable overriding configuration for builds and releases once the corresponding changes are merged in Packit-as-a-Service. ([#858](https://github.com/packit-service/packit/pull/858), [#859](https://github.com/packit-service/packit/pull/859)).\\n\\n### packit-as-a-service\\n\\n- We are now parsing events from Koji about the progress of the builds and report them (by [Franta](https://github.com/lachmanfrantisek/), [#657](https://github.com/packit-service/packit-service/pull/657)).\\n- We are now able to listen to Gitlab hooks and parse the (comment & push) events (by [Shreyas](https://github.com/shreyaspapi), [#629](https://github.com/packit-service/packit-service/pull/629), [#671](https://github.com/packit-service/packit-service/pull/671)).\\n- Log pages have been restructured by linking SRPM build logs instead of including them (by [Hunor](https://github.com/csomh), [#641](https://github.com/packit-service/packit-service/pull/641)).\\n\\n## Week 25 (June 15th - June 19th)\\n\\n### packit\\n\\n- Packit logs more information for RebaseHelper errors (by [@csomh](https://github.com/csomh), [#865](https://github.com/packit-service/packit/pull/865)).\\n\\n### packit-as-a-service\\n\\n- Obtaining builds via packit [API endpoint](https://prod.packit.dev/api/copr-builds) is now significantly quicker (by [@IceWreck](https://github.com/IceWreck), [#674](https://github.com/packit-service/packit-service/pull/674)).\\n- We now have an API endpoint for obtaining results from testing farm (by [@IceWreck](https://github.com/IceWreck), [#678](https://github.com/packit-service/packit-service/pull/678)).\\n- We finished the implementation of the trigger to create bugs in Bugzilla. Therefore packit is now able to create bugzilla for accepted PR\'s in CentOS (by [@jpopelka](https://github.com/jpopelka), [#662](https://github.com/packit-service/packit-service/pull/662)).\\n\\n## Week 26 (June 22th - June 26th)\\n\\n### packit\\n\\n- packit now supports using custom repositories and packages when building in Copr and has options to preserve the project and to list it in on the Copr home page [@lachmanfrantisek](https://github.com/lachmanfrantisek), [#872](https://github.com/packit-service/packit/pull/872).\\n- Custom commands defined by user in packit config now are run in the shell, no more `bash -c` required (by [@TomasTomecek](https://github.com/TomasTomecek), [#871](https://github.com/packit-service/packit/pull/871)).\\n- packit now includes pull request ID in version of rpm. (by [@sturivny](https://github.com/sturivny) and [@TomasTomecek](https://github.com/TomasTomecek), [#870](https://github.com/packit-service/packit/pull/870)).\\n\\n### packit-as-a-service\\n\\n- We added support for copr builds in gitlab (by [@shreyaspapi](https://github.com/shreyaspapi), [#683](https://github.com/packit-service/packit-service/pull/683)).\\n- packit-service utilizes the new options introduced in packit (by [@lachmanfrantisek](https://github.com/lachmanfrantisek), [#694](https://github.com/packit-service/packit-service/pull/694)).\\n\\n## Week 27 (June 29th - July 3rd)\\n\\n### packit\\n\\n- We introduced a new command `packit validate-config` which validates the contect of a package configuration file in your project\\n (contributed by [@TomasJani](https://github.com/TomasJani), [#826](https://github.com/packit-service/packit/pull/826)).\\n\\n### packit-as-a-service\\n\\n- You are now able to override configuration for builds, releases and other jobs (by [@TomasTomecek](https://github.com/TomasTomecek), [#676](https://github.com/packit-service/packit-service/pull/676)).\\n Read more about this feature [here](/docs/configuration/#overriding-global-parameters).\\n\\n## Week 28 (July 6th - July 10th)\\n\\n### packit\\n\\n- Command `validate-config` works properly now and does not produce odd error messages, by [@TomasTomecek](https://github.com/TomasTomecek) and [@csomh](https://github.com/csomh), [#894](https://github.com/packit-service/packit/pull/894) and [#895](https://github.com/packit-service/packit/pull/895)\\n- You will now properly see git-describe metadata in the `%release` field in spec file when using `srpm` command, by [@TomasTomecek](https://github.com/TomasTomecek), [#894](https://github.com/packit-service/packit/pull/894)\\n- git-log is being used to get a list of commits between HEAD and latest tag to pick up commit messages and add those to %changelog, by [@TomasTomecek](https://github.com/TomasTomecek), [#889](https://github.com/packit-service/packit/pull/889)\\n- packit is now able to load metadata from commits of a source-git repo and utilize them when creating patch files, by [@lachmanfrantisek](https://github.com/lachmanfrantisek), [#875](https://github.com/packit-service/packit/pull/875)\\n\\n### packit-as-a-service\\n\\n- We now have a new API endpoint: [`/api/projects/`](https://prod.packit.dev/api/projects), by [@IceWreck](https://github.com/IceWreck), [#716](https://github.com/packit-service/packit-service/pull/716)\\n- Over the last few weeks, [@lbarcziova](https://github.com/lbarcziova) was very busy with refactoring how jobs and tasks are being executed in packit-service. This work is now complete which allows us to scale the deployment up while giving us better introspection in what\'s happening inside, by [@lbarcziova](https://github.com/lbarcziova), [#704](https://github.com/packit-service/packit-service/pull/704)\\n\\n## Week 29 (July 13th - July 17th)\\n\\n![Tatranska Lomnica](img/tatranska-lomnica-dhodovsk.jpg) Copyright (c) Dominika Hodovska. This work is licensed under a [Creative Commons Attribution 4.0 International License](http://creativecommons.org/licenses/by/4.0/).\\n\\n## Week 30 (July 20th - July 24th)\\n\\n- [Anchit] added [a few new API endpoints] to Packit-as-a-Service to retrieve\\n project information. This is used in the Dashboard, to provide [an overview\\n of the projects] served by Packit.\\n\\n[anchit]: https://github.com/IceWreck\\n[a few new api endpoints]: https://github.com/packit-service/packit-service/pull/746\\n[an overview of the projects]: https://dashboard.packit.dev/projects\\n\\n## Week 31 (July 27th - July 31st)\\n\\n- [Jano] did a lot of work on our deployment. The installation of all our dependencies is much simpler now.\\n ([packit-service#747](https://github.com/packit-service/packit-service/pull/747),\\n [packit-service#753](https://github.com/packit-service/packit-service/pull/753),\\n [packit-service#756](https://github.com/packit-service/packit-service/pull/756),\\n [packit-service#757](https://github.com/packit-service/packit-service/pull/757),\\n [packit#919](https://github.com/packit-service/packit/pull/919)),\\n- Packit now puts a link to our documentation in a pull request status when a contributor is not allowed to build the PR, thanks to [Tom\xe1\u0161].\\n ([packit-service#758](https://github.com/packit-service/packit-service/pull/758))\\n\\n[jano]: https://github.com/sakalosj\\n[tom\xe1\u0161]: https://github.com/TomasTomecek\\n\\n## Week 32 (August 3rd - August 7th) and 33 (August 10th - August 13th)\\n\\n- We renamed our GitHub organisation to `packit`.\\n That user had been inactive for a long time and [Hunor]\'s request was successful.\\n- The Copr project settings are now changed only if needed. If we can\'t edit the settings,\\n we ask for the admin access to the Copr project and the service shows you a table with\\n the changes if you want to do the edit manually.\\n ([packit#921](https://github.com/packit/packit/pull/921),\\n [packit-service#764](https://github.com/packit/packit-service/pull/764))\\n- [Matej] fixed an old bug with the custom command for creating archives.\\n The archive was not found when building SRPM because of the incorrect processing\\n of the paths from the command output.\\n ([packit#923](https://github.com/packit/packit/pull/923))\\n\\n[hunor]: https://github.com/csomh\\n[matej]: https://github.com/mfocko\\n\\n## Week 34 (August 17th - August 20th)\\n\\n- [Tomas] tought packit how to merge related commits, which were previously created\\n by git-am applying of a multiple commit patch. ([packit#933](https://github.com/packit/packit/pull/933))\\n- [Anchit] added new `/api/srpm-builds/` endpoint.\\n- Service now requests \'builder\' permission for custom projects if needed.\\n- [Franta] fixed a problem with only one job executed executed for 2 build definitions for the same trigger.\\n\\n[anchit]: https://github.com/IceWreck\\n[franta]: https://github.com/lachmanfrantisek\\n[tomas]: https://github.com/TomasTomecek\\n\\n## Week 35 (August 24th - August 28th)\\n\\n- [Tomas] improved logging of the Packit actions\' output. ([packit#950](https://github.com/packit/packit/pull/950))\\n- [Anchit] fixed and enhanced the `/api/srpm-builds` endpoint.\\n ([packit-service#788](https://github.com/packit/packit-service/pull/788))\\n\\n[tomas]: https://github.com/TomasTomecek\\n[anchit]: https://github.com/IceWreck\\n\\n## Week 36 (August 31th - September 4th)\\n\\n- We store the submission time of SRPM builds now ([packit-service#795](https://github.com/packit/packit-service/pull/795) by [Anchit]).\\n- [Shreyas] improved implementation of the build status reporting ([packit-service#740](https://github.com/packit/packit-service/pull/740)).\\n- [Anchit] enhanced the `/koji-builds` endpoint to be more consistent with `/copr-builds` endpoint ([packit-service#791](https://github.com/packit/packit-service/pull/791)).\\n\\n[anchit]: https://github.com/IceWreck\\n[shreyas]: https://github.com/shreyaspapi\\n\\n## Week 37 (September 7th - September 11th)\\n\\n- Stage now uses [Tokman](https://github.com/packit/tokman) to get access tokens for GitHub, which should resolve race condition when running parallel jobs\\n (Tokman by [Hunor], ogr integration by [Matej]).\\n- [Franta] has addressed problems with Testing-Farm cluster with custom response on PRs that links to more information ([pinned info](https://github.com/packit/packit-service/issues/803), [packit-service#798](https://github.com/packit/packit-service/pull/798)).\\n\\n[hunor]: https://github.com/csomh\\n[matej]: https://github.com/mfocko\\n[franta]: https://github.com/lachmanfrantisek\\n\\n## Week 38 (September 14th - September 18th)\\n\\n- The combination of the source-git patches with existing patches now works well\\n ([packit#963](https://github.com/packit/packit/pull/963)).\\n- Service now mostly supports also GitLab as you can see\\n [here](https://gitlab.com/packit-service/hello-world/-/merge_requests/10)\\n or [here](https://gitlab.com/packit-service/src/drpm/-/merge_requests/2).\\n A lot of small issues were fixed in the last week\\n ([packit-service#806](https://github.com/packit/packit-service/pull/806),\\n [packit-service#812](https://github.com/packit/packit-service/pull/812),\\n [packit-service#814](https://github.com/packit/packit-service/pull/814),\\n [packit-service#815](https://github.com/packit/packit-service/pull/815),\\n [packit-service#816](https://github.com/packit/packit-service/pull/816)\\n ).\\n- Created Copr projects are now prefixed with the hostname\\n for non-GitHub services and also support multipart namespaces\\n ([packit-service#819](https://github.com/packit/packit-service/pull/819)).\\n- [Laura] fixed two testing-farm related issues\\n ([packit-service#808](https://github.com/packit/packit-service/pull/808),\\n [packit-service#809](https://github.com/packit/packit-service/pull/809)).\\n You can now use `test` job also on Pagure and GitLab thanks to that.\\n\\n[laura]: https://github.com/lbarcziova\\n\\n## Week 39 (September 21st - September 25th)\\n\\n- Packit-service can be configured to work with private namespaces. This is plumbing work which we need right now for CentOS Stream. We are not planning to enable this for GitHub - packit-service will still work only for public repositories, private ones are ignored. [packit-service#831](https://github.com/packit/packit-service/pull/831)\\n- If git tag contains more information than just version (e.g. `pkg_name-v1.2.3`), it is possible to use upstream_tag_template to extract version from the tag, which will be used in a subsequent task. [doc](https://packit.dev/docs/configuration/#upstream_tag_template) [packit#959](https://github.com/packit/packit/pull/959)\\n- Added support for globbing pattern in upstream_ref. [doc](https://packit.dev/docs/configuration/#upstream_ref) [packit#960](https://github.com/packit/packit/pull/960)\\n- Packit `--remote` is global option now and available for all commands. Because of this `sync-from-downstream --remote` was renamed to `--remote-to-push`. Remote can now be specified in the user\'s config (via upstream_git_remote parameter). [packit#977](https://github.com/packit/packit/pull/977)\\n\\nFollowing bugs were fixed:\\n\\n- Packit dropping leading zeros in version. [packit#814](https://github.com/packit/packit/pull/814)\\n- Packit CLI issue caused by picking incorrect copr project name. [packit#971](https://github.com/packit/packit/pull/971)\\n\\n## Week 40 (September 28th - October 2nd)\\n\\n- Packit-service is now explicitly checking if requested copr-build targets exist and if not, the user is informed about it. [packit-service#835](https://github.com/packit/packit-service/pull/835)\\n- We have improved the way how packit updates `%setup` line in a spec file - you are now able to set content of `-n` option via archive_root_dir_template config option, it defaults to `{upstream-pkg-name}`. [doc](https://github.com/packit/packit.dev/pull/167) [packit#834](https://github.com/packit/packit-service/pull/834)\\n- Packit is able to generate a patch file with format-patch without leading a/ and b/ in the patch diff. Required for patches in dist-git which are applied with -p0.\\n- Contribution guidelines were updated, now we have one shared [link](https://github.com/packit/contributing).\\n\\n## Week 41 (October 5th - October 9th)\\n\\n- [franta] made triggering of jobs more reliable and in correct situations ([packit-service#837](https://github.com/packit/packit-service/pull/837))\\n\\n[franta]: https://github.com/lachmanfrantisek\\n\\n## Week 42 (October 12th - October 16th)\\n\\nNothing significant happened during this week. The only change was that Hunor\\n[resolved](https://github.com/packit/packit-service/pull/850) a problem when sentry client library ([the alert service](https://sentry.io/) we use) caused errors in stage\\nenvironment and hence the problem didn\'t make it to production.\\n\\nWe have also released a new version of packit: [0.18](https://github.com/packit/packit/releases/tag/0.18.0).\\n\\n## Week 43 (October 19th - October 24th)\\n\\nWe finally had a week with plenty updates!\\n\\n- We found out the hard way that one cannot build in [Fedora koji](https://koji.fedoraproject.org/koji/) directly\\n from SRPM unless it\'s a scratch build. The discussion with Fedora rel-eng is\\n happening at [pagure.io/releng/issue/9801](https://pagure.io/releng/issue/9801) and in the meantime, all koji builds\\n will be halted on our side since we know they cannot succeed. Do `scratch: true` for koji builds before this gets resolved.\\n- Packit creates a symlink for a generated archive at the root of the project.\\n So far it only did it from a relative path and now absolute paths are\\n supported as well. This is useful when your specfile is placed in a\\n subdirectory and rpmbuild can\'t find the archive.\\n- There is a new usability improvement to proposing a new downstream update. If\\n the PR is already created, packit won\'t create it again. You will no longer\\n receive duplicate downstream PRs in dist-git.\\n- When doing a new downstream update, packit doesn\'t sync %changelog since\\n those are usually out of sync between upstream and downstream. Packit creates\\n a new entry for the new release in the downstream. There is a new packit.yaml\\n configuration option `sync_changelog` which bypasses this behaviour and\\n copies the %changelog from upstream and overwrites the downstream changelog.\\n Please use this option only when your changelogs are in sync. [Documentation](https://packit.dev/docs/configuration/#sync_changelog)\\n\\n## Week 44 (October 26th - October 30th)\\n\\nNo user-facing changes in packit(-service) this week.\\n\\n## Week 45 (November 2nd - November 6th)\\n\\n- [Laura] implemented an option for packit to copy description from a release into\\n a changelog when running `propose-update`. Also the default message has been changed\\n to the list of commit messages from last release. ([packit#1004](https://github.com/packit/packit/pull/1004))\\n- [Jano] improved handling of build targets in packit. ([packit#986](https://github.com/packit/packit/pull/986))\\n- [Tomas] improved an experience of a contributor to source-git in case the contributor\\n doesn\'t follow git-am patches style that is used. ([packit#1000](https://github.com/packit/packit/pull/1000))\\n\\n## Week 46 (November 9th - November 13th)\\n\\n- [Tomas] improved the UX of logging in the CLI. ([packit#1014](https://github.com/packit/packit/pull/1014))\\n- [Jano] improved logic of acquiring current version in the CLI. ([packit#1013](https://github.com/packit/packit/pull/1013))\\n- We appreciate getting feedback from our users, if you could find some time to\\n do so, there is an [open issue](https://github.com/packit/packit-service/issues/859)\\n for it.\\n\\n## Week 47 (November 16th - November 20th)\\n\\n- ~~[Matej] fixed [an\\n issue](https://github.com/packit/packit-service/issues/774) with Packit CLI,\\n enabling recursive search for spec-files\\n ([packit#1005](https://github.com/packit/packit/pull/1005)).~~ It turned\\n out, this change made it very easy to [deplete GitHub API quota], so it was\\n reverted.\\n- [Laura] made Copr builds to be part of the default jobs. This will cause\\n build jobs to explicitly run, and display their own result flags in PRs,\\n next to the test results. We hope this to be a more friendly behaviour for\\n our new users ([packit#1024](https://github.com/packit/packit/pull/1024)).\\n\\n## Week 48 (November 23rd - November 27th)\\n\\n- [Laura] [fixed a bug], where Packit Service failed to trigger Copr builds\\n before triggering the tests in case triggering Copr builds was configured\\n for a different event.\\n- Thanks to [Matej], Packit Service will now [comment on commits] in case Copr\\n builds fail after a merge, in order to indicate the reason for the failure.\\n- Packit Service will soon stop commenting on PRs after the first successful\\n build. The installation instructions from these comments [were moved to the\\n result page] by [Laura], while [Matej] [added a warning] to inform users\\n about this upcoming change.\\n\\n[laura]: https://github.com/lbarcziova\\n[jano]: https://github.com/sakalosj\\n[tomas]: https://github.com/TomasTomecek\\n[matej]: https://github.com/mfocko\\n[deplete github api quota]: https://github.com/packit/packit-service/issues/876\\n[fixed a bug]: https://github.com/packit/packit-service/pull/888\\n[comment on commits]: https://github.com/packit/packit-service/pull/854\\n[added a warning]: https://github.com/packit/packit-service/pull/891\\n[were moved to the result page]: https://github.com/packit/packit-service/pull/877\\n\\n## Week 49 (November 30th - December 4th)\\n\\n- [Jano] fixed a bug in `sync_release` method of Packit API. ([packit#1043](https://github.com/packit/packit/pull/1043))\\n- [Jiri Konecny] contributed a fix for how Packit creates COPR urls. ([packit#1039](https://github.com/packit/packit/pull/1039))\\n- [Laura] updated instructions how to retrigger a job. ([packit-service#892](https://github.com/packit/packit-service/pull/892))\\n\\n[jano]: https://github.com/sakalosj\\n[jiri konecny]: https://github.com/jkonecny12\\n[laura]: https://github.com/lbarcziova\\n\\n## Week 50 (December 7th - December 11th)\\n\\n- [Tomas] implemented the `--upstream-url` option of `packit init` command. When specified,\\n `init` also sets up a source-git repository next to creating a configuration file.\\n\\n[tomas]: https://github.com/TomasTomecek\\n\\n## Week 51 (December 14th - December 18th)\\n\\n- Congratulations comments are now disabled by default, unless enabled in config.\\n- A bug, which prevented npm to be run during SRPM build, has been fixed. ([sandcastle#86](https://github.com/packit/sandcastle/pull/86))"},{"id":"/2019","metadata":{"permalink":"/posts/weekly/2019","editUrl":"https://github.com/packit/packit.dev/tree/main/weekly/2019.md","source":"@site/weekly/2019.md","title":"2019","description":"Let\'s see what happened in Packit in 2019.","date":"2021-01-07T00:00:00.000Z","formattedDate":"January 7, 2021","tags":[{"label":"2019","permalink":"/posts/weekly/tags/2019"}],"readingTime":15.625,"hasTruncateMarker":true,"authors":[],"frontMatter":{"title":"2019","date":"2021-01-07T00:00:00.000Z","tags":["2019"]},"prevItem":{"title":"2020","permalink":"/posts/weekly/2020"}},"content":"Let\'s see what happened in Packit in 2019.\\n\\n\x3c!--truncate--\x3e\\n\\n# Initial version 0.1.0 of packit is out! (2019-03-08)\\n\\nWe would like to announce general availability of the initial version of\\npackit, titled \'0.1.0\'.\\n\\nSince this is our first release, we would like to ask you to be patient if you\\nencounter any issues. We work hard on packit\'s usability. If you feel like that\\npackit is doing something weird or if anything is unclear, don\'t hesitate and\\nreach out to us by creating [a new GitHub\\nissue](https://github.com/packit-service/packit/issues/new).\\n\\nThe initial release contains two commands:\\n\\n- `packit propose-update` \u2014 Opens a pull request in dist-git for the latest\\n upstream release of a selected repository.\\n- `packit watch-releases` \u2014 Watches events for all the upstream releases and\\n performs `propose-update` for those who use packit.\\n\\n## Installation\\n\\n```\\n$ dnf install --enablerepo=updates-testing packit\\n```\\n\\nOr\\n\\n```\\n$ pip3 install --user packitos\\n```\\n\\nOr (if you\'re brave)\\n\\n```\\n$ pip3 install --user git+https://github.com/packit-service/packit\\n```\\n\\n## Requirements\\n\\nPresent features have strict requirements on the upstream projects:\\n\\n- You need to have a packit config file present in the upstream repo.\\n\\n- You need to have spec file present in the upstream repo.\\n\\nThis workflow is suitable for people who are both upstream and downstream\\nmaintainers of the particular project. If you don\'t fit into that bucket, then\\npackit might not be ready for you, yet. Please wait till we land more\\n[source-git](/source-git/)\\nrelated functionality into packit.\\n\\n## `propose-update`\\n\\nI\'m going to demonstrate this functionality on\\n[ogr](https://github.com/packit-service/ogr.git), our library for git forges,\\nwhich powers packit.\\n\\nIt was recently approved for Fedora, so we can use packit to bring the initial\\nversion of ogr into Fedora Rawhide, 30 and 29.\\n\\n### Do we have everything?\\n\\nLet\'s see [guide](/docs/cli/propose-downstream) for\\nthe `propose-update` command on what we need:\\n\\n#### 0. The upstream repository with a valid upstream release.\\n\\n```\\n$ git remote -v\\norigin git@github.com:TomasTomecek/ogr.git (fetch)\\norigin git@github.com:TomasTomecek/ogr.git (push)\\nupstream https://github.com/packit-service/ogr.git (fetch)\\nupstream https://github.com/packit-service/ogr.git (push)\\n```\\n\\nYup.\\n\\n```\\n$ git tag --list\\n0.0.1\\n0.0.2\\n0.0.3\\n\\n$ git checkout 0.0.3\\nNote: checking out \'0.0.3\'.\\n```\\n\\nAnd the tag name is matching the version in a spec file:\\n\\n```\\n$ grep Version python-ogr.spec\\nVersion: 0.0.3\\n```\\n\\n#### 1. Packit config file placed in the upstream repository.\\n\\n```\\n$ ll .packit.yaml\\n-rw-rw-r--. 1 tt tt 177 Mar 1 17:44 .packit.yaml\\n```\\n\\nCheck.\\n\\n#### 2. Spec file present in the upstream repository.\\n\\n```\\n$ ll python-ogr.spec\\n-rw-rw-r--. 1 tt tt 1.3K Mar 1 17:43 python-ogr.spec\\n```\\n\\n:+1:\\n\\n#### 3. Pagure API tokens for Fedora Dist-git.\\n\\n```\\n$ env | grep TOKEN\\nPAGURE_USER_TOKEN=will\\nPAGURE_FORK_TOKEN=not\\nGITHUB_TOKEN=share, sorry\\n```\\n\\n#### 4. Valid Fedora Kerberos ticket.\\n\\n```\\n$ kinit ttomecek@FEDORAPROJECT.ORG\\nPassword for ttomecek@FEDORAPROJECT.ORG:\\n\\n$ klist\\nTicket cache: KEYRING:persistent:1024:krb_ccache_g0t1Ty3Ah\\nDefault principal: ttomecek@FEDORAPROJECT.ORG\\n\\nValid starting Expires Service principal\\n03/01/2019 18:12:25 03/02/2019 18:12:19 krbtgt/FEDORAPROJECT.ORG@FEDORAPROJECT.ORG\\n renew until 03/08/2019 18:12:19\\n```\\n\\nWe\'re all set!\\n\\n### Time to shine\\n\\nWe are still in the \\"ogr\\" upstream git repository.\\n\\n```\\n$ packit propose-update\\nINFO: Running \'anitya\' versioneer\\nERROR: Failed to determine latest upstream version!\\nCheck that the package exists on https://release-monitoring.org.\\nusing \\"master\\" dist-git branch\\nsyncing ./python-ogr.spec\\nINFO: Downloading file from URL https://files.pythonhosted.org/packages/source/o/ogr/ogr-0.0.3.tar.gz\\n100%[=============================>] 17.95K eta 00:00:00\\ndownloaded archive: /tmp/tmp2e65b0xt/ogr-0.0.3.tar.gz\\nuploading to the lookaside cache\\nPR created: https://src.fedoraproject.org/rpms/python-ogr/pull-request/1\\n```\\n\\nMind-blowing, isn\'t it? Now we have latest python-ogr in Fedora Rawhide by\\nrunning only a single command.\\n\\nI have also [added](https://release-monitoring.org/project/18832/) ogr into release-monitoring as packit suggests.\\n\\nOnce we are okay with the changes, we have to [merge the pull\\nrequest](https://src.fedoraproject.org/rpms/python-ogr/pull-request/1). That\'s\\nour responsibility, as maintainers.\\n\\n### Building in koji\\n\\nTime to build the package (packit doesn\'t support building in koji, yet)\\n\\n```\\n$ fedpkg clone python-ogr\\nCloning into \'python-ogr\'...\\nremote: Counting objects: 8, done.\\nremote: Compressing objects: 100% (5/5), done.\\nremote: Total 8 (delta 0), reused 5 (delta 0)\\nReceiving objects: 100% (8/8), done.\\n\\n$ cd python-ogr\\n\\n$ git log\\ncommit c298df5e540ba1d010366e102c1c75d4f5b0b0cc (HEAD -> master, origin/master, origin/HEAD)\\nAuthor: Tomas Tomecek \\nDate: Fri Mar 1 18:15:00 2019 +0100\\n\\n [packit] 0.0.3 upstream release\\n\\n more info\\n\\n Signed-off-by: Tomas Tomecek \\n\\ncommit 7d5ab1471ca0ee2a6c0254410b83beaa83b80f0b\\nAuthor: Gwyn Ciesla \\nDate: Fri Mar 1 15:18:34 2019 +0000\\n\\n Added the README\\n```\\n\\nYup, that\'s our commit. `more info` was added there by accident, this is\\nalready fixed in packit.\\n\\n```\\n$ fedpkg build\\nBuilding python-ogr-0.0.3-1.fc31 for rawhide\\nCreated task: 33125435\\nTask info: https://koji.fedoraproject.org/koji/taskinfo?taskID=33125435\\nWatching tasks (this may be safely interrupted)...\\n33125435 build (rawhide, /rpms/python-ogr.git:c298df5e540ba1d010366e102c1c75d4f5b0b0cc): free\\n33125435 build (rawhide, /rpms/python-ogr.git:c298df5e540ba1d010366e102c1c75d4f5b0b0cc): free -> open (buildvm-14.phx2.fedoraproject.org)\\n 33125451 buildArch (python-ogr-0.0.3-1.fc31.src.rpm, noarch): open (buildvm-14.phx2.fedoraproject.org)\\n 33125436 buildSRPMFromSCM (/rpms/python-ogr.git:c298df5e540ba1d010366e102c1c75d4f5b0b0cc): closed\\n33125435 build (rawhide, /rpms/python-ogr.git:c298df5e540ba1d010366e102c1c75d4f5b0b0cc): open (buildvm-14.phx2.fedoraproject.org) -> closed\\n 0 free 1 open 2 done 0 failed\\n 33125464 tagBuild (noarch): closed\\n 33125451 buildArch (python-ogr-0.0.3-1.fc31.src.rpm, noarch): open (buildvm-14.phx2.fedoraproject.org) -> closed\\n 0 free 0 open 4 done 0 failed\\n\\n33125435 build (rawhide, /rpms/python-ogr.git:c298df5e540ba1d010366e102c1c75d4f5b0b0cc) completed successfully\\n```\\n\\nThat was rough, can\'t wait to do this with packit.\\n\\nLet\'s do Fedora 30 now:\\n\\n```\\n$ packit propose-update --dist-git-branch f30\\nINFO: Running \'anitya\' versioneer\\nusing \\"f30\\" dist-git branch\\nsyncing ./python-ogr.spec\\nINFO: Downloading file from URL https://files.pythonhosted.org/packages/source/o/ogr/ogr-0.0.3.tar.gz\\n100%[=============================>] 17.95K eta 00:00:00\\ndownloaded archive: /tmp/tmpl5xxq22x/ogr-0.0.3.tar.gz\\nuploading to the lookaside cache\\nPR created: https://src.fedoraproject.org/rpms/python-ogr/pull-request/3\\n```\\n\\nAnd so on...\\n\\n## Conclusion\\n\\nAs you can see, packit is useful for us right away.\\n\\nWe\'ll be delighted if you try it out and let us know what you think.\\n\\n# Packit 0.2.0 is here! (2019-03-19)\\n\\nOur sprint nears an end which means we have released [a new version of packit -\\n0.2.0](https://github.com/packit-service/packit/releases/tag/0.2.0)! You can\\nexpect a new release after every sprint (i.e. every 2 weeks).\\n\\nThe 0.2.0 version has a bunch of new features and improvements: you can find\\na complete list [in the\\nchangelog](https://github.com/packit-service/packit/blob/master/CHANGELOG.md#020).\\nWe also have a [detailed\\ndocumentation](https://github.com/packit-service/packit#workflows-covered-by-packit)\\nfor all the workflows packit covers.\\n\\nLet\'s get through what\'s new:\\n\\n1. We have decided to rename two keys in our config file so they are more\\n descriptive. Old names still work but they are deprecated:\\n - `package_name` \u2192 `downstream_package_name`\\n - `upstream_name` \u2192 `upstream_project_name`\\n2. You don\'t need to touch dist-git at all when getting your new upstream\\n release into Fedora, you can stay in your upstream repository and just fire\\n off a bunch of packit calls:\\n - `packit propose-update` to create a pull request in Fedora dist-git with\\n the selected upstream release\\n - `packit build` to build the new upstream release once the pull request is\\n merged\\n - and finally, `packit create-update` creates a new bodhi update (if you\\n chose a stable Fedora release)\\n3. Packit now has a `srpm` command which creates an SRPM out of the local\\n content of your upstream repository.\\n4. You can now use packit to sync files from your dist-git repo back into\\n upstream (mainly to keep spec files in sync). `sync-from-downstream` is the\\n command.\\n5. Command `propose-update` received numerous improvements:\\n - You can pick upstream version to use.\\n - Packit will NOT check out the git ref with the upstream release if you\\n specify `--local-content`\\n - It\'s possible to force packit to execute `fedpkg new-sources` using\\n `--force-new-sources` and bypass the caching mechanism.\\n\\n## Installation\\n\\nPlease make sure you are installing `0.2.0`:\\n\\n```\\n$ dnf install --enablerepo=updates-testing packit\\n```\\n\\nOr\\n\\n```\\n$ pip3 install --user packitos\\n```\\n\\nYou can also install packit from master branch, if you are brave enough:\\n\\n```\\n$ pip3 install --user git+https://github.com/packit-service/packit\\n```\\n\\n## How are we using packit?\\n\\nI\'d like to show you how we used packit to bring a new upstream\\nrelease of ogr into Fedora, a library which packit is using.\\n\\nOnce we have performed an upstream release of ogr, we can propose an update in\\ndist-git:\\n\\n```\\n$ git clone https://github.com/packit-service/ogr && cd ogr/\\n\\n$ packit propose-update\\nINFO: Running \'anitya\' versioneer\\nVersion in upstream registries is \'0.0.3\'.\\nVersion in spec file is \'0.0.3\'.\\nPicking version of the latest release from the upstream registry over spec file.\\nChecking out upstream version 0.0.3\\nUsing \'master\' dist-git branch\\nCloning repo: https://src.fedoraproject.org/rpms/python-ogr.git -> /tmp/tmpb9xlvdhj\\nSyncing /home/tt/g/user-cont/ogr/python-ogr.spec\\nArchive ogr-0.0.3.tar.gz found in lookaside cache (skipping upload).\\nERROR Cmd(\'git\') failed due to: exit code(1)\\n cmdline: git commit -s -m [packit] 0.0.3 upstream release -m Upstream tag: 0.0.3\\nUpstream commit: 059d21080a7849acff4626b6e0ec61830d537ac4\\n\\n stdout: \'On branch 0.0.3-master-update\\nnothing to commit, working tree clean\'\\n```\\n\\nWhoops, it seems that I have messed up, I forgot to bump the spec file in the\\nupstream repo when doing the release. I will bump it locally and utilize\\n`--local-content` argument:\\n\\n```\\n$ rpmdev-bumpspec -n 0.1.0 -c \'New upstream release: 0.1.0\' *.spec\\n\\n$ packit propose-update --local-content\\nINFO: Running \'anitya\' versioneer\\nVersion in upstream registries is \'0.0.3\'.\\nVersion in spec file is \'0.1.0\'.\\nPicking version of the latest release from the upstream registry over spec file.\\nUsing \'master\' dist-git branch\\nCloning repo: https://src.fedoraproject.org/rpms/python-ogr.git -> /tmp/tmpd9j4se27\\nSyncing /home/tt/g/user-cont/ogr/python-ogr.spec\\nArchive ogr-0.1.0.tar.gz found in lookaside cache (skipping upload).\\nINFO: Downloading file from URL https://files.pythonhosted.org/packages/source/o/ogr/ogr-0.1.0.tar.gz\\n100%[=============================>] 20.25K eta 00:00:00\\nDownloaded archive: \'/tmp/tmpd9j4se27/ogr-0.1.0.tar.gz\'\\nAbout to upload to lookaside cache\\nwon\'t be doing kinit, no credentials provided\\nPR created: https://src.fedoraproject.org/rpms/python-ogr/pull-request/6\\n```\\n\\nOnce the scratch build is done and tests passed we merged and built it:\\n\\n```\\n$ packit build\\nUsing \'master\' dist-git branch\\nCloning repo: https://src.fedoraproject.org/rpms/python-ogr.git -> /tmp/tmprp3cmdjy\\nBuilding python-ogr-0.1.0-1.fc31 for rawhide\\nCreated task: 33616980\\nTask info: https://koji.fedoraproject.org/koji/taskinfo?taskID=33616980\\n```\\n\\nWe have done the same for F30 and F29.\\n\\nThe previous commands were run in the directory of the upstream repository. Packit also accepts path to your upstream clone, or even URL. So let\'s create a bodhi update for python-ogr by specifying the upstream repo URL:\\n\\n```\\n$ cd $HOME\\n\\n$ packit create-update --dist-git-branch f29 https://github.com/packit-service/ogr\\nCloning repo: https://github.com/packit-service/ogr -> /tmp/tmpdkdadmn_\\nKoji builds for package python-ogr and koji tag f29-updates-candidate:\\n - python-ogr-0.1.0-1.fc29\\nCloning repo: https://src.fedoraproject.org/rpms/python-ogr.git -> /tmp/tmpn1809ec9\\nBodhi update FEDORA-2019-78948e62d2:\\n- https://bodhi.fedoraproject.org/updates/FEDORA-2019-78948e62d2\\n- stable_karma: 3\\n- unstable_karma: -3\\n- notes:\\nNew upstream release: 0.1.0\\n```\\n\\nAnd that\'s it, no need to access dist-git any more.\\n\\nPlease give packit a try and let us know what you think.\\n\\n# Packit 0.3.0 (2019-04-11)\\n\\nIn the previous post we promised to\\nprovide a new release every 2 weeks and we are already breaking this promise as\\nit\'s been 3 weeks since then. We decided to wait with the release to merge\\nseveral pull requests related to source-git support.\\n\\nNow the good news. You can find a complete list of new features and\\nimprovements of version\\n[0.3.0](https://github.com/packit-service/packit/releases/tag/0.3.0) in the\\n[changelog](https://github.com/packit-service/packit/blob/master/CHANGELOG.md#030).\\n\\n## Features\\n\\n- You can now specify your own hooks or actions to replace default packit\\n behaviour. (More information can be found [in the\\n documentation](/docs/configuration/actions/)).\\n- Packit supports pagure.io-based upstream projects.\\n- Commands `propose-update` and `sync-from-downstream` supports [copying\\n directories](/docs/configuration/#minimal-sample-config).\\n- A new command `status`! It displays useful upstream/downstream info.\\n- Packit now supports [Source-git](/source-git/). The\\n functionality is not available, yet - we will add a CLI interface for it in\\n the next release.\\n- You can now have a config file for packit in your home directory(`~/.config/packit.yaml`).\\n- Packit installed from an RPM now has manpages.\\n\\n### `packit status` example\\n\\n```bash\\n$ packit status\\nCloning repo: https://src.fedoraproject.org/rpms/packit.git -> /tmp/tmp84we_6n8\\nDownstream PRs: No open PRs.\\nf29: 0.2.0\\nf30: 0.2.0\\nmaster: 0.2.0\\n```\\n\\n# Packit 0.4.0 & 0.4.1 (2019-05-18)\\n\\nIt\'s been over a month since we released packit \\"0.3.0\\". Here comes packit 0.4.0 (and patch release 0.4.1) and as always they bring a lot of new features and improvements.\\n\\nYou can find a complete list in the\\n[changelog](https://github.com/packit-service/packit/blob/master/CHANGELOG.md#040).\\n\\n## Packit as a service\\n\\n- We have Packit as a service running in OpenShift and also a GitHub App, which uses it.\\n Unfortunately it\'s still not in the [Marketplace](https://github.com/marketplace),\\n so [we](https://github.com/packit-service) have been the only one using it so far.\\n The service/app submits builds in [copr](https://copr.fedorainfracloud.org/coprs/packit/) and\\n once they\'re done it adds a GitHub status and comment with instructions how to install the builds.\\n The service is now configurable via [jobs](/docs/configuration/#packit-service-jobs) defined\\n in configuration file.\\n- Packit is now able to check GPG signatures of the upstream commits against configured fingerprints.\\n\\n## CLI\\n\\n- `srpm` command now works also with [Source-git](/source-git/).\\n- `status` command now access remote APIs asynchronously in parallel, which should speed up\\n the execution.\\n- CLI has new `--dry-run` option to not perform any remote changes (pull requests or comments).\\n- Fedmsg parsing has been unified into a single `listen-to-fedmsg` command.\\n\\n# Packit 0.4.2 (2019-06-26)\\n\\nAnother relase after a month since [0.4.1](https://packit.dev/posts/packit-041/), this time mostly with bug fixes.\\n\\nWe\'ve been busy polishing our [GitHub App](https://packit.dev/packit-as-a-service/) recently, therefore we had no resources for new features.\\n\\nSee [CHANGELOG](https://github.com/packit-service/packit/blob/master/CHANGELOG.md#042) for more details.\\n\\n# September 2020\\n\\n## Week 36 (August 31th - September 4th)\\n\\n- We store the submission time of SRPM builds now ([packit-service#795](https://github.com/packit/packit-service/pull/795) by [Anchit]).\\n- [Shreyas] improved implementation of the build status reporting ([packit-service#740](https://github.com/packit/packit-service/pull/740)).\\n- [Anchit] enhanced the `/koji-builds` endpoint to be more consistent with `/copr-builds` endpoint ([packit-service#791](https://github.com/packit/packit-service/pull/791)).\\n\\n[anchit]: https://github.com/IceWreck\\n[shreyas]: https://github.com/shreyaspapi\\n\\n## Week 37 (September 7th - September 11th)\\n\\n- Stage now uses [Tokman](https://github.com/packit/tokman) to get access tokens for GitHub, which should resolve race condition when running parallel jobs\\n (Tokman by [Hunor], ogr integration by [Matej]).\\n- [Franta] has addressed problems with Testing-Farm cluster with custom response on PRs that links to more information ([pinned info](https://github.com/packit/packit-service/issues/803), [packit-service#798](https://github.com/packit/packit-service/pull/798)).\\n\\n[hunor]: https://github.com/csomh\\n[matej]: https://github.com/mfocko\\n[franta]: https://github.com/lachmanfrantisek\\n\\n## Week 38 (September 14th - September 18th)\\n\\n- The combination of the source-git patches with existing patches now works well\\n ([packit#963](https://github.com/packit/packit/pull/963)).\\n- Service now mostly supports also GitLab as you can see\\n [here](https://gitlab.com/packit-service/hello-world/-/merge_requests/10)\\n or [here](https://gitlab.com/packit-service/src/drpm/-/merge_requests/2).\\n A lot of small issues were fixed in the last week\\n ([packit-service#806](https://github.com/packit/packit-service/pull/806),\\n [packit-service#812](https://github.com/packit/packit-service/pull/812),\\n [packit-service#814](https://github.com/packit/packit-service/pull/814),\\n [packit-service#815](https://github.com/packit/packit-service/pull/815),\\n [packit-service#816](https://github.com/packit/packit-service/pull/816)\\n ).\\n- Created Copr projects are now prefixed with the hostname\\n for non-GitHub services and also support multipart namespaces\\n ([packit-service#819](https://github.com/packit/packit-service/pull/819)).\\n- [Laura] fixed two testing-farm related issues\\n ([packit-service#808](https://github.com/packit/packit-service/pull/808),\\n [packit-service#809](https://github.com/packit/packit-service/pull/809)).\\n You can now use `test` job also on Pagure and GitLab thanks to that.\\n\\n[laura]: https://github.com/lbarcziova\\n\\n## Week 39 (September 21st - September 25th)\\n\\n- Packit-service can be configured to work with private namespaces. This is plumbing work which we need right now for CentOS Stream. We are not planning to enable this for GitHub - packit-service will still work only for public repositories, private ones are ignored. [packit-service#831](https://github.com/packit/packit-service/pull/831)\\n- If git tag contains more information than just version (e.g. `pkg_name-v1.2.3`), it is possible to use upstream_tag_template to extract version from the tag, which will be used in a subsequent task. [doc](https://packit.dev/docs/configuration/#upstream_tag_template) [packit#959](https://github.com/packit/packit/pull/959)\\n- Added support for globbing pattern in upstream_ref. [doc](https://packit.dev/docs/configuration/#upstream_ref) [packit#960](https://github.com/packit/packit/pull/960)\\n- Packit `--remote` is global option now and available for all commands. Because of this `sync-from-downstream --remote` was renamed to `--remote-to-push`. Remote can now be specified in the user\'s config (via upstream_git_remote parameter). [packit#977](https://github.com/packit/packit/pull/977)\\n\\nFollowing bugs were fixed:\\n\\n- Packit dropping leading zeros in version. [packit#814](https://github.com/packit/packit/pull/814)\\n- Packit CLI issue caused by picking incorrect copr project name. [packit#971](https://github.com/packit/packit/pull/971)\\n\\n## Week 40 (September 28th - October 2nd)\\n\\n- Packit-service is now explicitly checking if requested copr-build targets exist and if not, the user is informed about it. [packit-service#835](https://github.com/packit/packit-service/pull/835)\\n- We have improved the way how packit updates `%setup` line in a spec file - you are now able to set content of `-n` option via archive_root_dir_template config option, it defaults to `{upstream-pkg-name}`. [doc](https://github.com/packit/packit.dev/pull/167) [packit#834](https://github.com/packit/packit-service/pull/834)\\n- Packit is able to generate a patch file with format-patch without leading a/ and b/ in the patch diff. Required for patches in dist-git which are applied with -p0.\\n- Contribution guidelines were updated, now we have one shared [link](https://github.com/packit/contributing).\\n\\n# Week 44-48 (November) 2019\\n\\nWith this blog post we\'d like to continue with the idea of openly communicating changes in Packit.\\nSince most of the developers use Packit as the [GitHub App](https://packit.dev/packit-as-a-service) (which uses code from [this repository - Packit Service](https://github.com/packit-service/packit-service)), this blog will be about changes in all the parts, i.e. the GitHub App, the Packit Service and Packit itself.\\n\\n## Continuous Deployment (CD)\\n\\nAt the moment the workflow is that one of us manually triggers production container image build at the end of a week.\\nThis image is then automatically deployed into our production instance of the service over a weekend (Sun/Mon night) so that everyone can start a week with all the amazing stuff we added the previous week.\\nIn case an issue makes it through our staging instance into production uncaught, we can easily rollback on Monday.\\nThe same person also writes down what\'s changed in Packit (service/app) since previous deployment.\\n\\n## Changes in production (since the end of November)\\n\\nPrevious post is almost half a year old so we won\'t list all the changes since then, but only since last deployment, i.e. since end of December.\\n\\n### Packit\\n\\nPrevious deployment was running [packit-0.7.1](https://pypi.org/project/packitos/0.7.1/).\\nWe haven\'t released a newer version since then, but in the service we install Packit from the Git repository (we have a separate `stable` git branch for our production deployment).\\nFrom the most visible changes, Packit now:\\n\\n- better handles Create-archive action\\n- is able to work in a repo with detached head\\n- logs output from subprocesses in realtime\\n- syncs config file and spec file by default in Propose-update action\\n- hadles patches with undecodable chars\\n\\n### Packit Service\\n\\nNow:\\n\\n- better reports Copr builds\\n - uses separate commit status for srpm build and every chroot\\n - clears test farm commit statuses when new build is triggered\\n - better handles failed Copr builds\\n- gracefully handles no config file in the repo\\n- better handles when no (copr build) targets are specified in config file\\n- better checks whitelist of users\\n- does not create duplicate tickets in our [notification repo](https://github.com/packit-service/notifications) when a new user install the app\\n\\nChanges not visible to end users:\\n\\n- using [Requre](https://github.com/packit-service/requre) for integration/E2E tests\\n- Fedora messaging consumer part of the service has been improved and moved to separate [repo/image](https://github.com/packit-service/packit-service-fedmsg)\\n- using FAS instead of Fedora Badges for checking whether a user is Fedora packager\\n- many improved logs\\n- many bugs squashed\\n- lot\'s of code refactored\\n\\n# December 2019\\n\\n## Week 49\\n\\n### ogr & packit\\n\\n- ogr-0.9.0 has been released greatly restructured. ([#291](https://github.com/packit-service/ogr/pull/291/files))\\n- `packit status` (CLI) now shows also latest Copr builds. ([#579](https://github.com/packit-service/packit/pull/579))\\n- Target aliases (currently `fedora-development`, `fedora-stable`, `fedora-all`) can now be used in the packit config file. ([#619](https://github.com/packit-service/packit/pull/619))\\n- When doing a new update in Fedora dist-git, packit now by default creates a new pull request instead of pushing directly to dist-git. ([#622](https://github.com/packit-service/packit/pull/622))\\n\\n### packit service\\n\\n- Does not set test checks when tests are not configured. ([#275](https://github.com/packit-service/packit-service/pull/275))\\n- Supports target aliases and dist-git branches aliases. ([#277](https://github.com/packit-service/packit-service/pull/277), [#285](https://github.com/packit-service/packit-service/pull/285))\\n- Nicely formats errors from OpenShift API. ([#283](https://github.com/packit-service/packit-service/pull/283))\\n- Runs Copr build when user adds a `/packit build` comment into a PR. ([#290](https://github.com/packit-service/packit-service/pull/290))\\n\\n## Week 50\\n\\n### packit\\n\\n- If there is no `upstream_package_name`/`downstream_package_name` given in `.packit.yaml`, they now default to the name of the GitHub repo. ([#624](https://github.com/packit-service/packit/pull/624))\\n- If no `jobs` are defined in `.packit.yaml` packit by default runs `build` job on `fedora-stable` targets and `propose_downstream` on `fedora-all` branches. ([#625](https://github.com/packit-service/packit/pull/625))\\n- `build` command has nicer output. ([#630](https://github.com/packit-service/packit/pull/630))\\n- Smaller fixes. ([#630](https://github.com/packit-service/packit/pull/630), [#636](https://github.com/packit-service/packit/pull/636))\\n\\n### packit service\\n\\n- Creates a new issue when `propose-update` fails. ([#300](https://github.com/packit-service/packit-service/pull/300))\\n- Better reports failed submitting of a Copr build. ([#301](https://github.com/packit-service/packit-service/pull/301))"}]}')}}]); \ No newline at end of file diff --git a/assets/js/ee0a670e.2321d181.js b/assets/js/ee0a670e.1251ad89.js similarity index 78% rename from assets/js/ee0a670e.2321d181.js rename to assets/js/ee0a670e.1251ad89.js index b5c63fc7fd..bc64ecaf16 100644 --- a/assets/js/ee0a670e.2321d181.js +++ b/assets/js/ee0a670e.1251ad89.js @@ -1 +1 @@ -"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[44142],{29896:a=>{a.exports=JSON.parse('{"label":"2025-January","permalink":"/posts/weekly/tags/2025-january","allTagsPath":"/posts/weekly/tags","count":1}')}}]); \ No newline at end of file +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[44142],{29896:a=>{a.exports=JSON.parse('{"label":"2025-January","permalink":"/posts/weekly/tags/2025-january","allTagsPath":"/posts/weekly/tags","count":2}')}}]); \ No newline at end of file diff --git a/assets/js/ef8289cd.04febb28.js b/assets/js/ef8289cd.80219fb4.js similarity index 76% rename from assets/js/ef8289cd.04febb28.js rename to assets/js/ef8289cd.80219fb4.js index eaf0332c96..9f1da10dbc 100644 --- a/assets/js/ef8289cd.04febb28.js +++ b/assets/js/ef8289cd.80219fb4.js @@ -1 +1 @@ -"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[95011],{82898:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly/tags/2025-january","page":1,"postsPerPage":10,"totalPages":1,"totalCount":1,"blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[95011],{82898:e=>{e.exports=JSON.parse('{"permalink":"/posts/weekly/tags/2025-january","page":1,"postsPerPage":10,"totalPages":1,"totalCount":2,"blogDescription":"Blog","blogTitle":"Blog"}')}}]); \ No newline at end of file diff --git a/assets/js/fa07b7e4.df24d059.js b/assets/js/fa07b7e4.df24d059.js new file mode 100644 index 0000000000..590b6b9581 --- /dev/null +++ b/assets/js/fa07b7e4.df24d059.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[85189],{3905:(e,t,r)=>{r.d(t,{Zo:()=>u,kt:()=>f});var a=r(67294);function n(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function i(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,a)}return r}function o(e){for(var t=1;t=0||(n[r]=e[r]);return n}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(n[r]=e[r])}return n}var c=a.createContext({}),p=function(e){var t=a.useContext(c),r=t;return e&&(r="function"==typeof e?e(t):o(o({},t),e)),r},u=function(e){var t=p(e.components);return a.createElement(c.Provider,{value:t},e.children)},s="mdxType",m={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},y=a.forwardRef((function(e,t){var r=e.components,n=e.mdxType,i=e.originalType,c=e.parentName,u=l(e,["components","mdxType","originalType","parentName"]),s=p(r),y=n,f=s["".concat(c,".").concat(y)]||s[y]||m[y]||i;return r?a.createElement(f,o(o({ref:t},u),{},{components:r})):a.createElement(f,o({ref:t},u))}));function f(e,t){var r=arguments,n=t&&t.mdxType;if("string"==typeof e||n){var i=r.length,o=new Array(i);o[0]=y;var l={};for(var c in t)hasOwnProperty.call(t,c)&&(l[c]=t[c]);l.originalType=e,l[s]="string"==typeof e?e:n,o[1]=l;for(var p=2;p{r.r(t),r.d(t,{assets:()=>c,contentTitle:()=>o,default:()=>m,frontMatter:()=>i,metadata:()=>l,toc:()=>p});var a=r(87462),n=(r(67294),r(3905));const i={title:"Week 2 in Packit",date:new Date("2025-01-13T00:00:00.000Z"),authors:"flachman",tags:["2025-January",2025,"January"]},o=void 0,l={permalink:"/posts/weekly/2025/week-2",editUrl:"https://github.com/packit/packit.dev/tree/main/weekly/2025/week-2.md",source:"@site/weekly/2025/week-2.md",title:"Week 2 in Packit",description:"Week 2 (January 7th \u2013 January 13th)",date:"2025-01-13T00:00:00.000Z",formattedDate:"January 13, 2025",tags:[{label:"2025-January",permalink:"/posts/weekly/tags/2025-january"},{label:"2025",permalink:"/posts/weekly/tags/2025"},{label:"January",permalink:"/posts/weekly/tags/january"}],readingTime:.175,hasTruncateMarker:!1,authors:[{name:"Franti\u0161ek Lachman",email:"flachman@redhat.com",url:"https://github.com/lachmanfrantisek",imageURL:"https://github.com/lachmanfrantisek.png",key:"flachman"}],frontMatter:{title:"Week 2 in Packit",date:"2025-01-13T00:00:00.000Z",authors:"flachman",tags:["2025-January","2025","January"]},nextItem:{title:"Week 1 in Packit",permalink:"/posts/weekly/2025/week-1"}},c={authorsImageUrls:[void 0]},p=[{value:"Week 2 (January 7th \u2013 January 13th)",id:"week-2-january-7th--january-13th",level:2}],u={toc:p},s="wrapper";function m(e){let{components:t,...r}=e;return(0,n.kt)(s,(0,a.Z)({},u,r,{components:t,mdxType:"MDXLayout"}),(0,n.kt)("h2",{id:"week-2-january-7th--january-13th"},"Week 2 (January 7th \u2013 January 13th)"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"Fixed EVR regex used when parsing changelog entries in the ",(0,n.kt)("em",{parentName:"li"},"specfile")," library to not match email addresses with ",(0,n.kt)("inlineCode",{parentName:"li"},"-")," in them. (contributed by ",(0,n.kt)("a",{parentName:"li",href:"https://github.com/dcermak"},"Dan \u010cerm\xe1k"),", ",(0,n.kt)("a",{parentName:"li",href:"https://github.com/packit/specfile/pull/445"},"specfile#445"),")")))}m.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/main.83b78699.js b/assets/js/main.83b78699.js new file mode 100644 index 0000000000..50c67b29b4 --- /dev/null +++ b/assets/js/main.83b78699.js @@ -0,0 +1,2 @@ +/*! For license information please see main.83b78699.js.LICENSE.txt */ +(self.webpackChunkpackit_dev=self.webpackChunkpackit_dev||[]).push([[40179],{20830:(e,t,n)=>{"use strict";n.d(t,{W:()=>r});var a=n(67294);function r(){return a.createElement("svg",{width:"20",height:"20",className:"DocSearch-Search-Icon",viewBox:"0 0 20 20"},a.createElement("path",{d:"M14.386 14.386l4.0877 4.0877-4.0877-4.0877c-2.9418 2.9419-7.7115 2.9419-10.6533 0-2.9419-2.9418-2.9419-7.7115 0-10.6533 2.9418-2.9419 7.7115-2.9419 10.6533 0 2.9419 2.9418 2.9419 7.7115 0 10.6533z",stroke:"currentColor",fill:"none",fillRule:"evenodd",strokeLinecap:"round",strokeLinejoin:"round"}))}},723:(e,t,n)=>{"use strict";n.d(t,{Z:()=>f});var a=n(67294),r=n(87462),o=n(68356),i=n.n(o),s=n(16887);const c={"00d23cda":[()=>n.e(60365).then(n.bind(n,51934)),"@site/docs/pre-releases.md",51934],"0189f045":[()=>n.e(80207).then(n.t.bind(n,26765,19)),"~blog/posts/posts-tags-shift-left-ecc-list.json",26765],"01926b26":[()=>n.e(57111).then(n.bind(n,80524)),"@site/posts/fas-verification-automation/index.md",80524],"01a85c17":[()=>Promise.all([n.e(40532),n.e(64013)]).then(n.bind(n,91223)),"@theme/BlogTagsListPage",91223],"0273335d":[()=>n.e(4398).then(n.t.bind(n,9185,19)),"~blog/weekly/posts-weekly-tags-2024-january-77a.json",9185],"031c33a1":[()=>n.e(59173).then(n.bind(n,9087)),"@site/research/fedora-packages-onboarding/index.md",9087],"03a13b6c":[()=>n.e(75034).then(n.bind(n,58555)),"@site/posts/aws-and-image-builder/index.md",58555],"03d8c9c7":[()=>n.e(3528).then(n.bind(n,8764)),"@site/weekly/2025/week-1.md?truncated=true",8764],"0433e083":[()=>n.e(11534).then(n.bind(n,54798)),"@site/weekly/2024/week-4.md?truncated=true",54798],"04495dc7":[()=>n.e(83513).then(n.bind(n,61846)),"@site/research/making-decisions/index.md",61846],"04691ff1":[()=>n.e(7535).then(n.bind(n,47775)),"@site/weekly/2024/week-3.md",47775],"04743bed":[()=>n.e(42605).then(n.bind(n,52067)),"@site/weekly/2024/week-47.md?truncated=true",52067],"0480b142":[()=>n.e(30836).then(n.bind(n,11771)),"@site/docs/faq.md",11771],"04935377":[()=>n.e(95189).then(n.bind(n,46898)),"@site/posts/pre-commit-hooks/index.md",46898],"04f572f3":[()=>n.e(78003).then(n.t.bind(n,65727,19)),"~blog/posts/posts-tags-sast-f52.json",65727],"04f77bb8":[()=>n.e(36348).then(n.bind(n,85648)),"@site/weekly/2024/week-39.md",85648],"05535d53":[()=>n.e(10457).then(n.bind(n,34832)),"@site/docs/reproduce-locally.md",34832],"05a87762":[()=>n.e(41863).then(n.bind(n,90559)),"@site/research/ui/dashboard/index.md",90559],"061fa4b9":[()=>n.e(60071).then(n.bind(n,32396)),"@site/research/source-git/split-the-stream.md",32396],"06d675e9":[()=>n.e(3964).then(n.bind(n,36110)),"@site/docs/cli/validate-config.md",36110],"07134920":[()=>n.e(29676).then(n.bind(n,87419)),"@site/weekly/2024/week-34.md?truncated=true",87419],"074db93b":[()=>n.e(13909).then(n.t.bind(n,73599,19)),"~docs/docs/category-docs-autogenerated-category-downstream-jobs-dea.json",73599],"07a60307":[()=>n.e(23418).then(n.t.bind(n,88430,19)),"~blog/posts/posts-b4e.json",88430],"07ce80b1":[()=>n.e(56026).then(n.bind(n,64185)),"@site/source-git/index.md",64185],"07d9bf67":[()=>n.e(5068).then(n.bind(n,47228)),"@site/docs/cli/sync-from-downstream.md",47228],"08373b81":[()=>n.e(623).then(n.t.bind(n,17697,19)),"~blog/weekly/posts-weekly-tags-august-dad.json",17697],"093cf48e":[()=>n.e(13264).then(n.bind(n,95672)),"@site/research/monitoring/adoption-metrics/implementation.md",95672],"099c9d19":[()=>n.e(73059).then(n.bind(n,99009)),"@site/research/user-stories/python_project_from_scratch.md",99009],"09c5b42f":[()=>n.e(90600).then(n.bind(n,17288)),"@site/research/specfiles/library-requirements.md",17288],"0aaaabd1":[()=>n.e(60621).then(n.t.bind(n,78467,19)),"~blog/weekly/posts-weekly-tags-2023-december-26c.json",78467],"0b0b97cf":[()=>n.e(45873).then(n.bind(n,69197)),"@site/weekly/2024/week-47.md",69197],"0b387740":[()=>n.e(68467).then(n.t.bind(n,69676,19)),"~docs/docs/version-current-metadata-prop-751.json",69676],"0bf3f15a":[()=>n.e(39776).then(n.t.bind(n,83026,19)),"~blog/posts/posts-tags-ux-d97.json",83026],"0ca0dc81":[()=>n.e(6631).then(n.bind(n,36033)),"@site/weekly/2024/week-9.md?truncated=true",36033],"0d1f0907":[()=>n.e(3056).then(n.t.bind(n,9054,19)),"~blog/posts/posts-tags-copr-7ad.json",9054],"0de75d10":[()=>n.e(21712).then(n.bind(n,22058)),"@site/weekly/2024/week-28.md",22058],"0e5f325a":[()=>n.e(55171).then(n.bind(n,34600)),"@site/docs/cli/source-git/init.md",34600],"0ecef1e6":[()=>n.e(61929).then(n.bind(n,92116)),"@site/specfile/api/specfile/changelog.md",92116],"0f07849a":[()=>n.e(42022).then(n.bind(n,38885)),"@site/posts/packit-in-2024/index.md",38885],"0f462a6e":[()=>n.e(299).then(n.t.bind(n,80135,19)),"~blog/weekly/posts-weekly-tags-2024-february-910.json",80135],"0f599908":[()=>n.e(54478).then(n.t.bind(n,47380,19)),"~blog/weekly/posts-weekly-tags-2024-august-cbf-list.json",47380],"1008b54f":[()=>n.e(2699).then(n.bind(n,87434)),"@site/research/database/whats-in-production-database.md",87434],"10db9446":[()=>n.e(18823).then(n.bind(n,62566)),"@site/docs/configuration/downstream/pull_from_upstream.md",62566],"115a6d30":[()=>n.e(36087).then(n.bind(n,63821)),"@site/posts/specfile-introduction/index.md?truncated=true",63821],"118661c0":[()=>n.e(98428).then(n.bind(n,69274)),"@site/weekly/2024/week-25.md",69274],"1243a642":[()=>n.e(34786).then(n.t.bind(n,40146,19)),"~blog/posts/posts-tags-monorepos-ced.json",40146],"12cdc6e3":[()=>n.e(11849).then(n.bind(n,82002)),"@site/deployment/specifics/fedora-source-git.md",82002],"13bad44f":[()=>n.e(83227).then(n.t.bind(n,46546,19)),"~blog/weekly/posts-weekly-tags-january-fac-list.json",46546],"13cb03dc":[()=>n.e(87734).then(n.bind(n,97718)),"@site/research/testing/openshift-to-podman-kube-play.md",97718],"1421d519":[()=>n.e(65496).then(n.bind(n,24869)),"@site/docs/configuration/examples.md",24869],"145e22f0":[()=>n.e(13017).then(n.bind(n,92337)),"@site/weekly/2024/week-21.md?truncated=true",92337],"14eb3368":[()=>Promise.all([n.e(40532),n.e(9817)]).then(n.bind(n,34228)),"@theme/DocCategoryGeneratedIndexPage",34228],"15249e53":[()=>n.e(13831).then(n.bind(n,96950)),"@site/specfile/api/specfile/formatter.md",96950],"1583d6b9":[()=>n.e(15144).then(n.bind(n,44927)),"@site/docs/cli/create-update.md",44927],"1631e7cd":[()=>n.e(90171).then(n.t.bind(n,17540,19)),"/home/runner/work/packit.dev/packit.dev/.docusaurus/docusaurus-plugin-content-docs/source-git/plugin-route-context-module-100.json",17540],16333274:[()=>n.e(13199).then(n.t.bind(n,15745,19)),"/home/runner/work/packit.dev/packit.dev/.docusaurus/docusaurus-plugin-content-pages/default/plugin-route-context-module-100.json",15745],"168daeb3":[()=>n.e(56528).then(n.t.bind(n,69244,19)),"~blog/posts/posts-tags-dashboard-22c-list.json",69244],"16a7bc7d":[()=>n.e(74787).then(n.bind(n,54938)),"@site/posts/aws-and-image-builder/index.md?truncated=true",54938],"16cea1d0":[()=>n.e(5584).then(n.bind(n,73086)),"@site/weekly/2024/week-44.md",73086],"17480b6d":[()=>n.e(39261).then(n.t.bind(n,37371,19)),"/home/runner/work/packit.dev/packit.dev/.docusaurus/docusaurus-plugin-content-docs/docs/plugin-route-context-module-100.json",37371],17896441:[()=>Promise.all([n.e(40532),n.e(8954),n.e(27918)]).then(n.bind(n,15154)),"@theme/DocItem",15154],"17cd4ac7":[()=>n.e(68262).then(n.t.bind(n,44275,19)),"~docs/research/category-research-autogenerated-category-deployment-e54.json",44275],18172295:[()=>n.e(32449).then(n.bind(n,43481)),"@site/docs/fedora-releases-guide/fedora-notifications.md",43481],"1827865e":[()=>n.e(56002).then(n.bind(n,68494)),"@site/weekly/2024/week-29.md?truncated=true",68494],"19558b89":[()=>n.e(67432).then(n.t.bind(n,69748,19)),"~blog/weekly/posts-weekly-tags-2024-october-531.json",69748],"195e308d":[()=>n.e(38428).then(n.t.bind(n,85605,19)),"~blog/weekly/posts-weekly-tags-december-c96-list.json",85605],"196b8894":[()=>n.e(97840).then(n.bind(n,63418)),"@site/deployment/continuous-deployment.md",63418],"19d5a286":[()=>n.e(5780).then(n.bind(n,35210)),"@site/deployment/postgresql.md",35210],"19dff6b7":[()=>n.e(36819).then(n.bind(n,41669)),"@site/weekly/2024/week-30.md",41669],"1a297f3b":[()=>n.e(38452).then(n.bind(n,63441)),"@site/posts/testing-farm-triggering/index.md",63441],"1a4e3797":[()=>Promise.all([n.e(40532),n.e(97920)]).then(n.bind(n,39172)),"@theme/SearchPage",39172],"1aab09e1":[()=>n.e(45494).then(n.bind(n,65510)),"@site/specfile/api/specfile/value_parser.md",65510],"1aec3247":[()=>n.e(30118).then(n.bind(n,89345)),"@site/docs/cli/build/in-copr.md",89345],"1b34ddc9":[()=>n.e(63611).then(n.bind(n,58217)),"@site/weekly/2022.md",58217],"1b7dcea5":[()=>n.e(92202).then(n.bind(n,96644)),"@site/weekly/2024/week-42.md",96644],"1be78505":[()=>Promise.all([n.e(40532),n.e(29514)]).then(n.bind(n,19963)),"@theme/DocPage",19963],"1ca549ca":[()=>n.e(93300).then(n.bind(n,69217)),"@site/posts/non-divergent-dist-git-branches/index.md",69217],"1caf0a5a":[()=>n.e(8800).then(n.bind(n,77280)),"@site/research/monitoring/error-budgets/SLOs-SLIs.md",77280],"1d123cb0":[()=>n.e(22948).then(n.t.bind(n,96833,19)),"~blog/weekly/posts-weekly-tags-april-968.json",96833],"1d4d83b3":[()=>n.e(60242).then(n.bind(n,90979)),"@site/research/internal-automation/sync2jira.md",90979],"1d6cf8fd":[()=>n.e(39145).then(n.t.bind(n,69989,19)),"~blog/posts/posts-tags-shift-left-ecc.json",69989],"1d7e8137":[()=>n.e(5963).then(n.bind(n,66671)),"@site/research/user-stories/tests-builds-from-more-prs.md",66671],"1df93b7f":[()=>Promise.all([n.e(40532),n.e(53237)]).then(n.bind(n,78391)),"@site/src/pages/index.tsx",78391],"1e1536ef":[()=>n.e(44351).then(n.t.bind(n,80781,19)),"~blog/posts/posts-tags-configuration-2cd-list.json",80781],"1e2970af":[()=>n.e(67574).then(n.t.bind(n,9891,19)),"~blog/weekly/posts-weekly-tags-tags-852.json",9891],"1f06a528":[()=>n.e(17447).then(n.t.bind(n,87535,19)),"~blog/posts/posts-tags-ux-d97-list.json",87535],"1f6a6b55":[()=>n.e(55040).then(n.bind(n,35516)),"@site/research/ux/configuration-versioning.md",35516],"1fa89a7f":[()=>n.e(44107).then(n.bind(n,35597)),"@site/posts/packit-in-2024/index.md?truncated=true",35597],"1fdd111c":[()=>n.e(83963).then(n.t.bind(n,38313,19)),"~blog/posts/posts-tags-image-builder-8e7.json",38313],"1feca888":[()=>n.e(45728).then(n.bind(n,17587)),"@site/research/celery/task-workflow-refactor.md",17587],"20a056fc":[()=>n.e(66381).then(n.bind(n,76382)),"@site/weekly/2024/week-22.md?truncated=true",76382],"20b5692c":[()=>n.e(62218).then(n.bind(n,88814)),"@site/docs/cli/status.md",88814],"20e87077":[()=>n.e(63618).then(n.bind(n,90746)),"@site/weekly/2024/week-31.md",90746],"21779a86":[()=>n.e(24488).then(n.bind(n,4200)),"@site/research/deployment/deploy-packit-pr.md",4200],"218918b3":[()=>n.e(48058).then(n.t.bind(n,87195,19)),"~docs/agile/version-current-metadata-prop-751.json",87195],"2196da81":[()=>n.e(87658).then(n.t.bind(n,11056,19)),"~blog/weekly/posts-weekly-tags-2024-september-f01-list.json",11056],"21c47013":[()=>n.e(83739).then(n.t.bind(n,56227,19)),"~blog/weekly/posts-weekly-tags-2024-april-0ee-list.json",56227],"22c6a1d8":[()=>n.e(45949).then(n.t.bind(n,518,19)),"~blog/weekly/posts-weekly-tags-november-c17.json",518],"236a0aa9":[()=>n.e(30418).then(n.t.bind(n,39738,19)),"~docs/specfile/version-current-metadata-prop-751.json",39738],23709317:[()=>n.e(81820).then(n.bind(n,97871)),"@site/source-git/work-with-source-git/build-locally.md",97871],"23a2f3ae":[()=>n.e(22511).then(n.bind(n,89762)),"@site/deployment/tls-certs.md",89762],"242f2c36":[()=>n.e(88862).then(n.t.bind(n,94407,19)),"~blog/posts/posts-tags-image-builder-8e7-list.json",94407],24594894:[()=>n.e(37667).then(n.bind(n,72663)),"@site/posts/verify-sync-release-volunteers/index.md?truncated=true",72663],"251b46b4":[()=>n.e(66280).then(n.bind(n,38979)),"@site/weekly/2024/week-5.md?truncated=true",38979],"25ec039b":[()=>n.e(89847).then(n.bind(n,90719)),"@site/weekly/2024/week-40.md",90719],"26cf06cb":[()=>n.e(95518).then(n.t.bind(n,89363,19)),"/home/runner/work/packit.dev/packit.dev/.docusaurus/docusaurus-plugin-content-docs/agile/plugin-route-context-module-100.json",89363],"273d2bad":[()=>n.e(13735).then(n.t.bind(n,93272,19)),"~blog/posts/posts-tags-propose-downstream-19f.json",93272],"2760f50c":[()=>n.e(12926).then(n.bind(n,37374)),"@site/research/deployment/automotive-rosa.md",37374],"281b958a":[()=>n.e(2846).then(n.bind(n,74509)),"@site/research/deployment/workers-scaling.md",74509],"2884f75b":[()=>n.e(51815).then(n.bind(n,11884)),"@site/docs/workshops-materials.md",11884],"28d93f7e":[()=>n.e(77855).then(n.bind(n,23581)),"@site/source-git/work-with-source-git/propose-to-dist-git.md",23581],"295a855e":[()=>n.e(68435).then(n.t.bind(n,96082,19)),"~docs/research/category-research-autogenerated-category-user-interface-d06.json",96082],"29bf5e7b":[()=>n.e(88704).then(n.t.bind(n,29757,19)),"~blog/weekly/posts-weekly-tags-2024-august-cbf.json",29757],"29f68dba":[()=>n.e(36672).then(n.t.bind(n,43344,19)),"~blog/posts/blog-post-list-prop-posts.json",43344],"2a4ad605":[()=>n.e(6896).then(n.bind(n,30639)),"@site/weekly/2024/week-50.md",30639],"2a530d92":[()=>n.e(88372).then(n.bind(n,2303)),"@site/research/integrations/building-srpm-in-copr/september-2022.md",2303],"2a57f356":[()=>n.e(49848).then(n.bind(n,73730)),"@site/weekly/2024/week-3.md?truncated=true",73730],"2bbe8192":[()=>n.e(49564).then(n.t.bind(n,6162,19)),"~blog/weekly/posts-weekly-page-5-6a0.json",6162],"2bd51f01":[()=>n.e(15).then(n.bind(n,96472)),"@site/posts/specfile-introduction/index.md",96472],"2c482982":[()=>n.e(73459).then(n.t.bind(n,37763,19)),"~blog/weekly/posts-weekly-tags-february-551.json",37763],"2cba120e":[()=>n.e(3762).then(n.bind(n,94186)),"@site/posts/non-git-upstreams-support/index.md?truncated=true",94186],"2cddb6e8":[()=>n.e(27557).then(n.bind(n,95940)),"@site/src/pages/usage.tsx",95940],"2dd50e28":[()=>n.e(14150).then(n.t.bind(n,28472,19)),"~blog/weekly/posts-weekly-tags-2025-83f.json",28472],"2e300c84":[()=>n.e(5103).then(n.t.bind(n,20804,19)),"~blog/weekly/posts-weekly-tags-2024-june-aa6-list.json",20804],"2e4d0dd6":[()=>n.e(6620).then(n.bind(n,97912)),"@site/weekly/2024/week-28.md?truncated=true",97912],"2e769fcf":[()=>n.e(8698).then(n.bind(n,33587)),"@site/posts/project-mycorrhiza/index.md?truncated=true",33587],"2f57843d":[()=>n.e(64518).then(n.bind(n,8028)),"@site/posts/fedora-eln/index.md?truncated=true",8028],"301dd56f":[()=>n.e(63545).then(n.t.bind(n,21411,19)),"~blog/weekly/posts-weekly-tags-december-c96.json",21411],"3033bc75":[()=>n.e(23328).then(n.bind(n,57039)),"@site/research/git-notes/index.md",57039],"304350ac":[()=>n.e(37109).then(n.bind(n,27031)),"@site/docs/cli/srpm.md",27031],"3088e41b":[()=>n.e(85349).then(n.bind(n,41730)),"@site/source-git/work-with-source-git/create-source-git.md",41730],"30a5a511":[()=>n.e(2996).then(n.bind(n,87605)),"@site/source-git/work-with-source-git/index.md",87605],"313a1f45":[()=>n.e(686).then(n.bind(n,99701)),"@site/weekly/2025/week-2.md",99701],31640710:[()=>n.e(89486).then(n.bind(n,23617)),"@site/research/automation-tools/rdopkg.md",23617],"3189d5b9":[()=>n.e(49910).then(n.bind(n,72391)),"@site/specfile/api/specfile/macros.md",72391],"31f13df0":[()=>n.e(84673).then(n.t.bind(n,15956,19)),"/home/runner/work/packit.dev/packit.dev/.docusaurus/docusaurus-plugin-content-docs/deployment/plugin-route-context-module-100.json",15956],"32a4c819":[()=>n.e(36144).then(n.bind(n,65485)),"@site/research/deployment/distributed-workers/index.md",65485],"33dd0779":[()=>n.e(79026).then(n.bind(n,29515)),"@site/research/monitoring/error-budgets/index.md",29515],"33ef67ff":[()=>n.e(30749).then(n.t.bind(n,60377,19)),"~blog/weekly/posts-weekly-page-3-de0.json",60377],"34aa6077":[()=>n.e(39256).then(n.bind(n,44429)),"@site/docs/service-level-objectives.md",44429],"35c7dc37":[()=>n.e(92966).then(n.bind(n,63993)),"@site/development/patch-metadata.md",63993],"360bb53e":[()=>n.e(75127).then(n.bind(n,73150)),"@site/weekly/2024/week-18.md?truncated=true",73150],"360f096f":[()=>n.e(85253).then(n.bind(n,35247)),"@site/research/database/refactoring_project_events_and_commit_sha.md",35247],36889891:[()=>n.e(84702).then(n.bind(n,76967)),"@site/research/internal-automation/onboard/index.md",76967],"37228b11":[()=>n.e(62888).then(n.t.bind(n,84136,19)),"~blog/weekly/posts-weekly-tags-2024-aea.json",84136],"3733844b":[()=>n.e(61452).then(n.bind(n,55089)),"@site/research/monitoring/index.md",55089],"37ebd97f":[()=>n.e(44132).then(n.bind(n,29487)),"@site/research/specfiles/packages-with-patches/index.md",29487],"391047cf":[()=>n.e(78663).then(n.bind(n,45417)),"@site/research/user-stories/index.md",45417],"39785c65":[()=>n.e(71108).then(n.bind(n,13889)),"@site/research/source-git/dist-git-to-src-git/updates.md",13889],"3aa7bb4c":[()=>n.e(35331).then(n.bind(n,9871)),"@site/posts/specfile-advanced/index.md",9871],"3bc64c3d":[()=>n.e(88213).then(n.bind(n,70830)),"@site/posts/monorepos/index.md?truncated=true",70830],"3bd03a06":[()=>n.e(42248).then(n.bind(n,58472)),"@site/research/monorepo-support/refactoring.md",58472],"3c24ef76":[()=>n.e(73287).then(n.bind(n,49991)),"@site/weekly/2019.md?truncated=true",49991],"3c25ca84":[()=>n.e(15817).then(n.t.bind(n,71594,19)),"~docs/deployment/version-current-metadata-prop-751.json",71594],"3c6108bf":[()=>n.e(97089).then(n.bind(n,556)),"@site/agile/weekly-roles/index.md",556],"3cd4aa69":[()=>n.e(42303).then(n.bind(n,56556)),"@site/weekly/2024/week-2.md",56556],"3d8d21df":[()=>n.e(6535).then(n.bind(n,5411)),"@site/docs/about.md",5411],"3d9ded8f":[()=>n.e(10160).then(n.bind(n,54038)),"@site/weekly/2024/week-18.md",54038],"3de95d1b":[()=>n.e(79448).then(n.bind(n,36245)),"@site/deployment/testing-changes.md",36245],"403dbe61":[()=>n.e(16878).then(n.bind(n,37326)),"@site/weekly/2024/week-15.md",37326],"41a599a1":[()=>n.e(98636).then(n.t.bind(n,93558,19)),"~docs/source-git/version-current-metadata-prop-751.json",93558],"41b307bb":[()=>n.e(54766).then(n.bind(n,72137)),"@site/specfile/api/specfile/specfile.md",72137],"41f6b13c":[()=>n.e(41418).then(n.bind(n,89900)),"@site/docs/fedora-releases-guide/index.md",89900],"424a8cf5":[()=>n.e(80976).then(n.bind(n,73013)),"@site/weekly/2024/week-38.md?truncated=true",73013],"43dd483a":[()=>n.e(14540).then(n.bind(n,70357)),"@site/weekly/2024/week-33.md",70357],"43e1a395":[()=>n.e(12298).then(n.bind(n,33578)),"@site/research/workflow-engines/prefect.md",33578],"43ea9c74":[()=>n.e(28845).then(n.bind(n,58163)),"@site/docs/cli/init.md",58163],"43ed34bf":[()=>n.e(14827).then(n.bind(n,32331)),"@site/deployment/resource-requirements.md",32331],"4496dd28":[()=>n.e(56080).then(n.bind(n,77570)),"@site/docs/fedora-releases-guide/non-divergent-dist-git-branches.md",77570],"4519bae3":[()=>n.e(52224).then(n.bind(n,67965)),"@site/research/deployment/verification.md",67965],"45691e52":[()=>n.e(41930).then(n.bind(n,95971)),"@site/weekly/2024/week-7.md",95971],"456d9388":[()=>n.e(13319).then(n.bind(n,24580)),"@site/specfile/api/specfile/conditions.md",24580],"4785b4eb":[()=>n.e(14526).then(n.bind(n,69846)),"@site/research/database/postgres-views/index.md",69846],"4813d5c5":[()=>n.e(78778).then(n.t.bind(n,49469,19)),"~blog/weekly/posts-weekly-tags-2024-january-77a-list.json",49469],"481e2d7b":[()=>n.e(23384).then(n.bind(n,64827)),"@site/weekly/2024/week-45.md",64827],"4828e39a":[()=>n.e(2993).then(n.bind(n,69722)),"@site/research/source-git/on-pagure.md",69722],"492e9aa4":[()=>n.e(68313).then(n.t.bind(n,66235,19)),"~blog/posts/posts-tags-downstream-247-list.json",66235],"49c953f2":[()=>n.e(46423).then(n.bind(n,21665)),"@site/research/automation-tools/rpkg-util.md",21665],"49d4d7f5":[()=>n.e(51786).then(n.t.bind(n,72820,19)),"~blog/weekly/posts-weekly-tags-may-e9a-list.json",72820],"4a859e77":[()=>n.e(99478).then(n.bind(n,94200)),"@site/research/database/composite-types.md",94200],"4b2dc70a":[()=>n.e(89454).then(n.bind(n,69092)),"@site/weekly/2024/week-17.md?truncated=true",69092],"4bb5f62b":[()=>n.e(67513).then(n.bind(n,20613)),"@site/posts/openscanhub-prototype/index.md",20613],"4cafa77a":[()=>n.e(39140).then(n.bind(n,2294)),"@site/posts/downstream-automation/index.md?truncated=true",2294],"4d03f5fa":[()=>n.e(4455).then(n.bind(n,97918)),"@site/research/monitoring/metrics.md",97918],"4d3b2def":[()=>n.e(24029).then(n.bind(n,34513)),"@site/weekly/2024/week-30.md?truncated=true",34513],"4da0ab7d":[()=>n.e(87742).then(n.bind(n,72733)),"@site/docs/cli/build/in-image-builder.md",72733],"4dd0e433":[()=>n.e(52887).then(n.bind(n,81880)),"@site/deployment/monitoring/logs.md",81880],"50232afd":[()=>n.e(89788).then(n.bind(n,32547)),"@site/deployment/scripts.md",32547],"5043a3ef":[()=>n.e(39023).then(n.bind(n,49859)),"@site/development/how-open-is-this-service.md",49859],"5054467f":[()=>n.e(88314).then(n.t.bind(n,91578,19)),"~blog/weekly/posts-weekly-4b8.json",91578],"50b9f00e":[()=>n.e(67425).then(n.bind(n,36210)),"@site/posts/testing-farm-triggering/index.md?truncated=true",36210],"50ed3ab9":[()=>n.e(20534).then(n.t.bind(n,70253,19)),"~docs/docs/category-docs-autogenerated-category-upstream-jobs-c6d.json",70253],"5121e5e6":[()=>n.e(91644).then(n.t.bind(n,85623,19)),"~blog/posts/posts-tags-openscanhub-d64-list.json",85623],"51e66db3":[()=>n.e(51925).then(n.t.bind(n,95362,19)),"~blog/posts/posts-tags-staging-725.json",95362],"53503bf6":[()=>n.e(98477).then(n.bind(n,10357)),"@site/posts/project-mycorrhiza/index.md",10357],"53537d8b":[()=>n.e(47073).then(n.bind(n,88769)),"@site/posts/changelogs/index.md?truncated=true",88769],"55b22ef9":[()=>n.e(95988).then(n.t.bind(n,13921,19)),"~docs/research/category-research-autogenerated-category-integrations-b7a.json",13921],56005495:[()=>n.e(99738).then(n.bind(n,13447)),"@site/docs/cli/build/index.md",13447],"561af407":[()=>n.e(85398).then(n.bind(n,23439)),"@site/specfile/index.md",23439],56384167:[()=>n.e(30860).then(n.t.bind(n,7085,19)),"/home/runner/work/packit.dev/packit.dev/.docusaurus/docusaurus-theme-search-algolia/default/plugin-route-context-module-100.json",7085],"566dc98d":[()=>n.e(33469).then(n.bind(n,93201)),"@site/posts/pull-from-upstream/index.md",93201],56774503:[()=>n.e(30485).then(n.bind(n,45159)),"@site/research/celery/tasks-prioritizing.md",45159],"5739a1bd":[()=>n.e(3698).then(n.bind(n,20230)),"@site/weekly/2024/week-1.md?truncated=true",20230],"5817dc2c":[()=>n.e(41724).then(n.bind(n,67103)),"@site/posts/2022-features/index.md?truncated=true",67103],"58daa998":[()=>n.e(50447).then(n.t.bind(n,3746,19)),"~docs/research/version-current-metadata-prop-751.json",3746],"58deca8d":[()=>n.e(55955).then(n.t.bind(n,63291,19)),"~blog/weekly/posts-weekly-tags-2021-d53-list.json",63291],"598a2fdb":[()=>n.e(4162).then(n.bind(n,85389)),"@site/deployment/index.md",85389],"59e5d3c1":[()=>n.e(97248).then(n.bind(n,83558)),"@site/research/source-git/index.md",83558],"5becb6b1":[()=>n.e(32291).then(n.t.bind(n,93833,19)),"~blog/weekly/posts-weekly-tags-september-e37-list.json",93833],"5bf4439e":[()=>n.e(12213).then(n.t.bind(n,63,19)),"~blog/posts/posts-page-3-70d.json",63],"5bf6367e":[()=>n.e(56938).then(n.t.bind(n,18891,19)),"~blog/weekly/posts-weekly-tags-june-2a8-list.json",18891],"5e11d67a":[()=>n.e(85766).then(n.t.bind(n,16804,19)),"~blog/weekly/posts-weekly-tags-april-968-list.json",16804],"5e459208":[()=>n.e(37809).then(n.bind(n,9262)),"@site/research/testing/openshift-zuul-test-alternatives.md",9262],"5e9f5e1a":[()=>Promise.resolve().then(n.bind(n,36809)),"@generated/docusaurus.config",36809],"5ebbaa88":[()=>n.e(78521).then(n.bind(n,42181)),"@site/deployment/specifics/packit-service.md",42181],"60e3ffe8":[()=>n.e(51514).then(n.t.bind(n,40011,19)),"~blog/posts/posts-tags-fedora-e8f-list.json",40011],"624f6bbf":[()=>n.e(68009).then(n.bind(n,26605)),"@site/weekly/2020.md",26605],"629a5e16":[()=>n.e(52422).then(n.bind(n,28900)),"@site/specfile/api/specfile/options.md",28900],63008411:[()=>n.e(17796).then(n.bind(n,87818)),"@site/research/workflow-engines/index.md",87818],"6316283b":[()=>n.e(99209).then(n.t.bind(n,1585,19)),"/home/runner/work/packit.dev/packit.dev/.docusaurus/docusaurus-plugin-content-blog/posts/plugin-route-context-module-100.json",1585],"637d3dfa":[()=>n.e(59941).then(n.t.bind(n,491,19)),"~docs/docs/category-docs-autogenerated-category-dist-git-fad.json",491],"643da868":[()=>n.e(42888).then(n.bind(n,31298)),"@site/docs/cli/source-git/update-source-git.md",31298],"656ba791":[()=>n.e(57753).then(n.bind(n,21282)),"@site/research/outages/reporting.md",21282],"67788cf7":[()=>n.e(30422).then(n.bind(n,33984)),"@site/posts/flock_2024_diary/index.md",33984],"678ef1c6":[()=>n.e(4843).then(n.bind(n,77335)),"@site/source-git/shutdown.md",77335],"67ec9723":[()=>n.e(37299).then(n.bind(n,91218)),"@site/posts/manual-triggering/index.md?truncated=true",91218],"6851a236":[()=>n.e(5681).then(n.t.bind(n,27831,19)),"~blog/posts/posts-tags-specfile-0c6.json",27831],"6875c492":[()=>Promise.all([n.e(40532),n.e(8954),n.e(46048),n.e(48610)]).then(n.bind(n,41714)),"@theme/BlogTagsPostsPage",41714],"691ef3b6":[()=>n.e(66720).then(n.t.bind(n,51463,19)),"~docs/research/category-research-autogenerated-category-user-experience-c5c.json",51463],"698688c0":[()=>n.e(85958).then(n.t.bind(n,78405,19)),"~blog/weekly/posts-weekly-tags-2025-83f-list.json",78405],"6a238fac":[()=>n.e(16012).then(n.bind(n,72850)),"@site/posts/copr-srpms/index.md",72850],"6af1ef04":[()=>n.e(85621).then(n.bind(n,10504)),"@site/weekly/2024/week-7.md?truncated=true",10504],"6b6a41d2":[()=>n.e(96424).then(n.bind(n,26141)),"@site/specfile/api/specfile/sourcelist.md",26141],"6b9c3960":[()=>n.e(18482).then(n.bind(n,42357)),"@site/research/database/data-stores.md",42357],"6c060eb1":[()=>n.e(33352).then(n.t.bind(n,2688,19)),"/home/runner/work/packit.dev/packit.dev/.docusaurus/docusaurus-plugin-content-docs/specfile/plugin-route-context-module-100.json",2688],"6cb2d84e":[()=>n.e(86423).then(n.bind(n,98662)),"@site/research/monitoring/github-api-call-inventory/index.md",98662],"6cb47a98":[()=>n.e(98588).then(n.t.bind(n,11696,19)),"~blog/weekly/posts-weekly-tags-august-dad-list.json",11696],"6cd37f94":[()=>n.e(95655).then(n.bind(n,36737)),"@site/research/workflow-engines/selinon.md",36737],"6d96a08b":[()=>n.e(42208).then(n.bind(n,24644)),"@site/weekly/2024/week-48.md",24644],"6e047ae3":[()=>n.e(80489).then(n.t.bind(n,18847,19)),"~blog/posts/posts-page-2-c5d.json",18847],"6fa0ba47":[()=>n.e(87378).then(n.t.bind(n,30022,19)),"~blog/weekly/posts-weekly-tags-2024-october-531-list.json",30022],"6ffa8a82":[()=>n.e(15058).then(n.t.bind(n,91168,19)),"~docs/research/category-research-autogenerated-category-automation-of-internal-processes-f47.json",91168],"709b2afb":[()=>n.e(79022).then(n.bind(n,9034)),"@site/research/automation-tools/tito.md",9034],"7102b336":[()=>n.e(52474).then(n.t.bind(n,15251,19)),"~blog/weekly/posts-weekly-tags-2024-june-aa6.json",15251],"7159dcfb":[()=>n.e(90141).then(n.t.bind(n,57976,19)),"~blog/weekly/posts-weekly-tags-2024-november-05e.json",57976],72917567:[()=>n.e(38544).then(n.bind(n,51597)),"@site/weekly/2024/week-43.md",51597],"72e9ee25":[()=>n.e(90589).then(n.t.bind(n,14128,19)),"~blog/posts/posts-tags-copr-7ad-list.json",14128],"72fa94c8":[()=>n.e(56034).then(n.bind(n,24103)),"@site/docs/configuration/actions.md",24103],"731a8a15":[()=>n.e(61659).then(n.t.bind(n,19078,19)),"~blog/weekly/posts-weekly-tags-june-2a8.json",19078],74719024:[()=>n.e(714).then(n.bind(n,58971)),"@site/deployment/openshift_local_cluster.md",58971],"7527a5f5":[()=>n.e(83725).then(n.bind(n,69636)),"@site/specfile/api/specfile/macro_definitions.md",69636],"759a8cc0":[()=>n.e(51073).then(n.t.bind(n,13298,19)),"~blog/weekly/posts-weekly-tags-2024-march-a4d-list.json",13298],"75a941da":[()=>n.e(58494).then(n.t.bind(n,13510,19)),"~blog/weekly/posts-weekly-tags-2024-july-9ab.json",13510],"763f3776":[()=>n.e(14505).then(n.bind(n,59928)),"@site/research/integrations/downstream/index.md",59928],"7760e989":[()=>n.e(11060).then(n.bind(n,65944)),"@site/docs/cli/index.md",65944],"77cacbdf":[()=>n.e(21741).then(n.t.bind(n,10877,19)),"~blog/weekly/posts-weekly-tags-2024-march-a4d.json",10877],"78461ecb":[()=>n.e(64756).then(n.t.bind(n,34703,19)),"~blog/weekly/posts-weekly-tags-2023-december-26c-list.json",34703],"791542c3":[()=>n.e(56679).then(n.bind(n,94998)),"@site/weekly/2024/week-50.md?truncated=true",94998],"7959a7e8":[()=>n.e(47559).then(n.bind(n,15883)),"@site/specfile/api/specfile/exceptions.md",15883],"79686d8b":[()=>n.e(49128).then(n.bind(n,36375)),"@site/source-git/design.md",36375],79909006:[()=>n.e(30098).then(n.bind(n,99978)),"@site/weekly/2024/week-10.md",99978],"79ac0311":[()=>n.e(64540).then(n.bind(n,4625)),"@site/posts/experiences_with_rust/index.md",4625],"7a524534":[()=>n.e(71967).then(n.bind(n,23166)),"@site/posts/2021-features/index.md",23166],"7ae439d7":[()=>n.e(6623).then(n.bind(n,1278)),"@site/source-git/work-with-source-git/update-spec.md",1278],"7ae56ea1":[()=>n.e(23216).then(n.t.bind(n,55014,19)),"~blog/posts/posts-tags-yearly-features-34f.json",55014],"7b207a68":[()=>n.e(60788).then(n.t.bind(n,91472,19)),"~blog/weekly/posts-weekly-tags-2024-page-5-6d8.json",91472],"7ba6b78c":[()=>n.e(3105).then(n.t.bind(n,29338,19)),"~blog/weekly/posts-weekly-tags-february-551-list.json",29338],"7d461870":[()=>n.e(75163).then(n.bind(n,1785)),"@site/specfile/api/specfile/utils.md",1785],"7e35e429":[()=>n.e(5989).then(n.bind(n,86762)),"@site/docs/cli/build/in-koji.md",86762],"7e7109f9":[()=>n.e(58047).then(n.t.bind(n,93849,19)),"~blog/weekly/posts-weekly-page-2-c85.json",93849],"7e981f1e":[()=>n.e(27564).then(n.bind(n,65204)),"@site/weekly/2024/week-13.md?truncated=true",65204],"80c1bd4f":[()=>n.e(11150).then(n.t.bind(n,64320,19)),"~blog/posts/posts-archive-049.json",64320],"814d92e8":[()=>n.e(52861).then(n.bind(n,42536)),"@site/research/ux/improve-service-processing.md",42536],"81a6fbb3":[()=>n.e(26949).then(n.bind(n,497)),"@site/research/ui/dashboard/dashboard-improvements.md",497],82117311:[()=>n.e(20503).then(n.bind(n,30260)),"@site/weekly/2024/week-27.md",30260],"8228eeeb":[()=>n.e(45716).then(n.t.bind(n,70155,19)),"~blog/posts/posts-tags-workflow-5f6.json",70155],"82b9c782":[()=>n.e(99250).then(n.bind(n,55200)),"@site/weekly/2023/packit-workshop.md",55200],"82bb726c":[()=>n.e(19647).then(n.bind(n,3941)),"@site/source-git/status.md",3941],"82d0bde2":[()=>n.e(98088).then(n.bind(n,49099)),"@site/docs/configuration/jobs.md",49099],"8307ae4c":[()=>n.e(3091).then(n.bind(n,81975)),"@site/weekly/2024/week-16.md?truncated=true",81975],"840b9c4d":[()=>n.e(44e3).then(n.bind(n,1088)),"@site/docs/cli/propose-downstream.md",1088],"845cca31":[()=>n.e(30083).then(n.bind(n,79795)),"@site/weekly/2024/week-43.md?truncated=true",79795],"846a4c26":[()=>n.e(54473).then(n.bind(n,67327)),"@site/weekly/2024/week-22.md",67327],"84a3b10e":[()=>n.e(63764).then(n.t.bind(n,53284,19)),"~blog/weekly/posts-weekly-tags-2024-page-3-845-list.json",53284],"8641c6bd":[()=>n.e(9725).then(n.bind(n,13058)),"@site/weekly/2024/week-27.md?truncated=true",13058],"86d5a44a":[()=>n.e(84308).then(n.t.bind(n,47725,19)),"~blog/posts/posts-tags-2021-0c8.json",47725],"8746ea35":[()=>n.e(66310).then(n.bind(n,71694)),"@site/specfile/api/specfile/spec_parser.md",71694],"87ec6932":[()=>n.e(34407).then(n.bind(n,8987)),"@site/weekly/2024/week-1.md",8987],"87f4acab":[()=>n.e(70444).then(n.bind(n,32417)),"@site/weekly/2024/week-17.md",32417],"886d1372":[()=>n.e(80349).then(n.t.bind(n,2988,19)),"~docs/research/category-research-autogenerated-category-database-41c.json",2988],"8875e568":[()=>n.e(26522).then(n.t.bind(n,34584,19)),"~blog/posts/posts-tags-fas-5af-list.json",34584],"89a7199b":[()=>n.e(50911).then(n.bind(n,399)),"@site/weekly/2024/week-6.md?truncated=true",399],"8a5fb69f":[()=>n.e(74635).then(n.bind(n,39255)),"@site/research/integrations/console.md",39255],"8a70a7c4":[()=>n.e(55860).then(n.bind(n,37210)),"@site/posts/2022-features/index.md",37210],"8b7a4a46":[()=>n.e(23502).then(n.bind(n,23263)),"@site/development/index.md",23263],"8bc496ec":[()=>n.e(53198).then(n.t.bind(n,97672,19)),"~blog/weekly/posts-weekly-tags-march-27c-list.json",97672],"8c224857":[()=>n.e(44588).then(n.bind(n,58706)),"@site/weekly/2024/week-37.md",58706],"8c306d97":[()=>n.e(61193).then(n.bind(n,79402)),"@site/deployment/specifics/clusters.md",79402],"8cadce09":[()=>n.e(12017).then(n.t.bind(n,265,19)),"~blog/weekly/posts-weekly-tags-october-1b8.json",265],"8d023c0f":[()=>n.e(62896).then(n.t.bind(n,11181,19)),"~blog/posts/posts-tags-project-mycorrhiza-c59-list.json",11181],"8d88c4d9":[()=>n.e(10974).then(n.t.bind(n,97225,19)),"~blog/posts/posts-tags-project-mycorrhiza-c59.json",97225],"8da84e9e":[()=>n.e(20284).then(n.t.bind(n,89794,19)),"~blog/posts/posts-tags-2022-5d4-list.json",89794],"8e319551":[()=>n.e(16251).then(n.bind(n,21588)),"@site/weekly/2024/week-19.md?truncated=true",21588],"8e3f82a3":[()=>n.e(64097).then(n.bind(n,44850)),"@site/specfile/api/specfile/prep.md",44850],"8e3fb1e1":[()=>n.e(14550).then(n.bind(n,92673)),"@site/research/ui/website-improvements.md",92673],"8e9af1e5":[()=>n.e(36673).then(n.bind(n,11623)),"@site/weekly/2024/week-12.md",11623],"8f901ad7":[()=>n.e(47751).then(n.bind(n,46313)),"@site/weekly/2022.md?truncated=true",46313],"8fbda36b":[()=>n.e(6268).then(n.bind(n,44440)),"@site/weekly/2024/week-4.md",44440],"8feda5ba":[()=>n.e(28399).then(n.bind(n,17674)),"@site/agile/kanban.md",17674],"900bc352":[()=>n.e(49158).then(n.bind(n,70639)),"@site/deployment/secrets.md",70639],"904d4a62":[()=>n.e(40945).then(n.bind(n,13658)),"@site/specfile/api/specfile/context_management.md",13658],90686207:[()=>n.e(40466).then(n.bind(n,54717)),"@site/research/deployment/automation-for-stable-branches.md",54717],"90edf56d":[()=>n.e(94911).then(n.bind(n,45456)),"@site/weekly/2025/week-1.md",45456],91127785:[()=>n.e(81977).then(n.bind(n,51037)),"@site/weekly/2024/week-39.md?truncated=true",51037],"917f9494":[()=>n.e(71925).then(n.t.bind(n,18834,19)),"~blog/weekly/posts-weekly-tags-2024-page-2-91e.json",18834],"918dee3e":[()=>n.e(57906).then(n.bind(n,15957)),"@site/weekly/2024/week-48.md?truncated=true",15957],"9205cbf2":[()=>n.e(99618).then(n.bind(n,48091)),"@site/research/database/refresh.md",48091],"92dc2473":[()=>n.e(74183).then(n.bind(n,29259)),"@site/docs/configuration/upstream/upstream_koji_build.md",29259],"934c94c3":[()=>n.e(20243).then(n.t.bind(n,40536,19)),"~blog/posts/posts-tags-yearly-features-34f-list.json",40536],"93c19874":[()=>n.e(48590).then(n.t.bind(n,9612,19)),"~blog/weekly/posts-weekly-tags-2024-december-939.json",9612],"943c4455":[()=>n.e(53709).then(n.bind(n,92054)),"@site/posts/pull-from-upstream/index.md?truncated=true",92054],94602731:[()=>n.e(16159).then(n.t.bind(n,69840,19)),"~blog/posts/posts-tags-fedora-e8f.json",69840],"94b15e4a":[()=>n.e(9359).then(n.bind(n,21310)),"@site/weekly/2020.md?truncated=true",21310],95282724:[()=>n.e(64357).then(n.bind(n,79477)),"@site/posts/specfile-advanced/index.md?truncated=true",79477],"95d530d1":[()=>n.e(23455).then(n.bind(n,36508)),"@site/weekly/2024/week-44.md?truncated=true",36508],"95f730a4":[()=>n.e(96217).then(n.bind(n,97822)),"@site/weekly/2024/week-36.md?truncated=true",97822],"96c88a1c":[()=>n.e(21073).then(n.t.bind(n,46383,19)),"~blog/weekly/posts-weekly-tags-2023-203.json",46383],"9705bc60":[()=>n.e(88230).then(n.bind(n,3652)),"@site/weekly/2024/week-14.md?truncated=true",3652],"98073b56":[()=>n.e(73156).then(n.t.bind(n,80402,19)),"/home/runner/work/packit.dev/packit.dev/.docusaurus/docusaurus-plugin-content-blog/weekly/plugin-route-context-module-100.json",80402],"98e91f35":[()=>n.e(15779).then(n.t.bind(n,93027,19)),"~blog/posts/posts-tags-propose-downstream-19f-list.json",93027],"99354cae":[()=>n.e(66952).then(n.t.bind(n,34195,19)),"~blog/posts/posts-tags-downstream-247.json",34195],99497812:[()=>n.e(58887).then(n.t.bind(n,80570,19)),"~blog/posts/posts-tags-srpm-071.json",80570],"998260a0":[()=>n.e(23987).then(n.bind(n,5020)),"@site/weekly/2024/week-11.md",5020],"99aea035":[()=>n.e(97485).then(n.bind(n,52236)),"@site/research/ux/automatic-config-updates.md",52236],"99b62762":[()=>n.e(35695).then(n.bind(n,2093)),"@site/research/monitoring/logs-aggregation/index.md",2093],"9a87c403":[()=>n.e(40002).then(n.t.bind(n,94923,19)),"~docs/research/category-research-autogenerated-category-specfiles-f99.json",94923],"9ab0720d":[()=>n.e(21279).then(n.t.bind(n,94525,19)),"~blog/weekly/posts-weekly-tags-november-c17-list.json",94525],"9ae5889b":[()=>n.e(97457).then(n.bind(n,20033)),"@site/source-git/work-with-source-git/sync-from-dist-git.md",20033],"9b0e3930":[()=>n.e(7600).then(n.bind(n,17402)),"@site/posts/non-divergent-dist-git-branches/index.md?truncated=true",17402],"9b17ca5c":[()=>n.e(29741).then(n.bind(n,87997)),"@site/weekly/2024/week-36.md",87997],"9cbf899b":[()=>n.e(91922).then(n.t.bind(n,83378,19)),"~blog/posts/posts-tags-pull-from-upstream-a24.json",83378],"9dfb0dde":[()=>n.e(48210).then(n.bind(n,81626)),"@site/deployment/monitoring/index.md",81626],"9e4087bc":[()=>n.e(53608).then(n.bind(n,63169)),"@theme/BlogArchivePage",63169],"9f03ac94":[()=>n.e(58647).then(n.bind(n,9804)),"@site/weekly/2024/week-9.md",9804],a1aba5a8:[()=>n.e(43734).then(n.bind(n,31166)),"@site/docs/configuration/downstream_configuration_template.md",31166],a1e2e3af:[()=>n.e(33055).then(n.t.bind(n,39189,19)),"~blog/weekly/posts-weekly-tags-march-27c.json",39189],a1fff5e9:[()=>n.e(57099).then(n.bind(n,99691)),"@site/research/integrations/fedora-ci/index.md",99691],a214fff1:[()=>n.e(20215).then(n.bind(n,23226)),"@site/weekly/2024/week-12.md?truncated=true",23226],a2275ab1:[()=>n.e(33805).then(n.t.bind(n,53385,19)),"~docs/research/category-research-autogenerated-category-testing-759.json",53385],a25cd4f7:[()=>n.e(69024).then(n.bind(n,58546)),"@site/research/ui/dashboard/oauth.md",58546],a2b87eb6:[()=>n.e(62281).then(n.t.bind(n,28079,19)),"~blog/weekly/posts-weekly-page-4-a25.json",28079],a2cb0f32:[()=>n.e(39118).then(n.bind(n,5567)),"@site/posts/monorepos/index.md",5567],a2ef09a9:[()=>n.e(87924).then(n.t.bind(n,1951,19)),"~docs/development/version-current-metadata-prop-751.json",1951],a371ca0e:[()=>n.e(60775).then(n.bind(n,28099)),"@site/posts/flock_2024_diary/index.md?truncated=true",28099],a3e02e67:[()=>n.e(60825).then(n.t.bind(n,94224,19)),"~blog/weekly/posts-weekly-tags-2022-47e.json",94224],a3e5d6a2:[()=>n.e(22568).then(n.bind(n,60821)),"@site/docs/cli/dist-git/init.md",60821],a3e87acb:[()=>n.e(94154).then(n.bind(n,81918)),"@site/weekly/2024/week-33.md?truncated=true",81918],a3f6e39a:[()=>n.e(54152).then(n.bind(n,1149)),"@site/weekly/2024/week-8.md",1149],a45a012c:[()=>n.e(5510).then(n.bind(n,67072)),"@site/posts/2021-in-numbers/index.md",67072],a462cc58:[()=>n.e(88061).then(n.bind(n,36598)),"@site/development/creating-stream-9-repos.md",36598],a4bf7db1:[()=>n.e(69146).then(n.t.bind(n,39557,19)),"~blog/posts/posts-tags-summary-862.json",39557],a4d25f68:[()=>n.e(51828).then(n.bind(n,89758)),"@site/weekly/2024/week-19.md",89758],a5064e60:[()=>n.e(74721).then(n.bind(n,4093)),"@site/weekly/2024/week-45.md?truncated=true",4093],a64b3083:[()=>n.e(99124).then(n.bind(n,44250)),"@site/weekly/2024/week-8.md?truncated=true",44250],a6752ca1:[()=>n.e(3593).then(n.bind(n,13814)),"@site/posts/fedora-eln/index.md",13814],a6aa9e1f:[()=>Promise.all([n.e(40532),n.e(8954),n.e(46048),n.e(93089)]).then(n.bind(n,80046)),"@theme/BlogListPage",80046],a6f639c4:[()=>n.e(51189).then(n.bind(n,7628)),"@site/posts/packit_1_0_0_action_required/index.md",7628],a7324faf:[()=>n.e(66861).then(n.bind(n,59187)),"@site/specfile/api/specfile/sources.md",59187],a8554a0d:[()=>n.e(75178).then(n.t.bind(n,56057,19)),"~blog/weekly/posts-weekly-tags-2024-july-9ab-list.json",56057],a8b895ad:[()=>n.e(5743).then(n.bind(n,1047)),"@site/research/workflow-engines/celery-canvas.md",1047],a8bb5334:[()=>n.e(8756).then(n.bind(n,36350)),"@site/docs/guide.md",36350],a93f7cfd:[()=>n.e(61644).then(n.bind(n,32899)),"@site/posts/release-field-handling/index.md",32899],aa13154b:[()=>n.e(54793).then(n.bind(n,8706)),"@site/weekly/2024/week-32.md?truncated=true",8706],aa5f9066:[()=>n.e(70818).then(n.t.bind(n,68911,19)),"~blog/weekly/posts-weekly-tags-2024-april-0ee.json",68911],ab0407bd:[()=>n.e(17782).then(n.bind(n,95845)),"@site/research/integrations/gitlab/index.md",95845],ac452aa3:[()=>n.e(66314).then(n.t.bind(n,20313,19)),"~blog/posts/posts-tags-configuration-2cd.json",20313],ad33aa20:[()=>n.e(89401).then(n.bind(n,35458)),"@site/docs/cli/source-git/status.md",35458],add8c385:[()=>n.e(9087).then(n.bind(n,61923)),"@site/posts/openscanhub-prototype/index.md?truncated=true",61923],ae308360:[()=>n.e(6520).then(n.bind(n,27432)),"@site/source-git/work-with-source-git/fix-diverged-history.md",27432],ae6cf626:[()=>n.e(46215).then(n.bind(n,41597)),"@site/docs/cli/prepare-sources.md",41597],aea0f75b:[()=>n.e(43801).then(n.bind(n,75950)),"@site/weekly/2024/week-6.md",75950],aed23c73:[()=>n.e(80145).then(n.bind(n,56231)),"@site/weekly/2024/week-5.md",56231],af0a1b2e:[()=>n.e(17676).then(n.bind(n,59779)),"@site/weekly/2024/week-49.md?truncated=true",59779],af7e7d2f:[()=>n.e(69843).then(n.bind(n,8391)),"@site/weekly/2024/week-26.md?truncated=true",8391],af90649c:[()=>n.e(41705).then(n.bind(n,65483)),"@site/research/source-git/sync-status.md",65483],af9b46a1:[()=>n.e(40354).then(n.t.bind(n,38718,19)),"~blog/posts/posts-tags-2024-cf2-list.json",38718],afb295bf:[()=>n.e(65584).then(n.t.bind(n,54075,19)),"~blog/weekly/posts-weekly-tags-2020-8c7.json",54075],b0081a5c:[()=>n.e(49672).then(n.bind(n,9618)),"@site/deployment/vars.md",9618],b1581c40:[()=>n.e(58020).then(n.bind(n,17745)),"@site/posts/packit_1_0_0_action_required/index.md?truncated=true",17745],b36b65f3:[()=>n.e(79466).then(n.bind(n,98370)),"@site/research/workflow-engines/argo-workflows.md",98370],b37d2dac:[()=>n.e(45959).then(n.t.bind(n,57424,19)),"~blog/posts/posts-tags-dashboard-22c.json",57424],b392693c:[()=>n.e(26950).then(n.bind(n,32641)),"@site/weekly/2024/week-41.md?truncated=true",32641],b3b08e1f:[()=>n.e(11615).then(n.bind(n,52419)),"@site/research/deployment/distributed-workers/AWS-SQS-RDS.md",52419],b3e0d976:[()=>n.e(69570).then(n.t.bind(n,23999,19)),"~blog/posts/posts-tags-sast-f52-list.json",23999],b5092fc4:[()=>n.e(23643).then(n.bind(n,28791)),"@site/agile/roles.md",28791],b6247aba:[()=>n.e(10058).then(n.bind(n,67)),"@site/weekly/2024/week-31.md?truncated=true",67],b7176c34:[()=>n.e(70802).then(n.t.bind(n,8083,19)),"~blog/posts/posts-tags-fas-5af.json",8083],b735410e:[()=>n.e(66259).then(n.t.bind(n,87617,19)),"~blog/weekly/posts-weekly-tags-2024-aea-list.json",87617],b7d0514c:[()=>n.e(11853).then(n.bind(n,34806)),"@site/posts/downstream-automation/index.md",34806],b7d0aaab:[()=>n.e(22667).then(n.t.bind(n,88697,19)),"~blog/posts/posts-tags-2024-cf2.json",88697],b8330396:[()=>n.e(4773).then(n.bind(n,41843)),"@site/deployment/specifics/centos-stream-source-git.md",41843],b8a09bca:[()=>n.e(48235).then(n.t.bind(n,65402,19)),"~blog/posts/posts-tags-2021-0c8-list.json",65402],b8c1fd37:[()=>n.e(66767).then(n.bind(n,1136)),"@site/weekly/2021.md",1136],b94605fa:[()=>n.e(37480).then(n.bind(n,38667)),"@site/source-git/work-with-source-git/control-patch-generation.md",38667],b98f4147:[()=>n.e(34015).then(n.bind(n,49004)),"@site/weekly/2024/week-10.md?truncated=true",49004],b9da35a4:[()=>n.e(6682).then(n.bind(n,25263)),"@site/docs/configuration/upstream/tests.md",25263],ba236f3f:[()=>n.e(72679).then(n.bind(n,23092)),"@site/weekly/2024/week-41.md",23092],ba5416a0:[()=>n.e(15024).then(n.bind(n,65980)),"@site/weekly/2024/week-13.md",65980],bb5e3948:[()=>n.e(20095).then(n.t.bind(n,24568,19)),"~blog/posts/posts-tags-logs-f01.json",24568],bc2282da:[()=>n.e(32297).then(n.bind(n,73294)),"@site/docs/cli/build/in-mock.md",73294],bd15657a:[()=>n.e(98371).then(n.t.bind(n,26549,19)),"~blog/weekly/posts-weekly-tags-may-e9a.json",26549],be3a2dac:[()=>n.e(4308).then(n.t.bind(n,91371,19)),"~blog/posts/posts-tags-workflow-5f6-list.json",91371],bec3799f:[()=>n.e(7572).then(n.bind(n,16136)),"@site/research/integrations/building-srpm-in-copr/index.md",16136],bf7a3826:[()=>n.e(26318).then(n.bind(n,22967)),"@site/research/user-stories/summit-demo.md",22967],bfdf3364:[()=>n.e(82909).then(n.bind(n,32201)),"@site/research/source-git/fedora-spec-files/index.md",32201],c0246954:[()=>n.e(39583).then(n.bind(n,62686)),"@site/weekly/2024/week-49.md",62686],c06492b1:[()=>n.e(18195).then(n.bind(n,60120)),"@site/research/internal-automation/cert-management.md",60120],c14519d6:[()=>n.e(3591).then(n.bind(n,82109)),"@site/docs/cross-project-testing.md",82109],c17489ce:[()=>n.e(90391).then(n.bind(n,99358)),"@site/research/monorepo-support/index.md",99358],c1a99778:[()=>n.e(68995).then(n.bind(n,57112)),"@site/weekly/2024/week-15.md?truncated=true",57112],c1e4ae13:[()=>n.e(79190).then(n.t.bind(n,19267,19)),"~blog/posts/posts-tags-testing-farm-08a-list.json",19267],c21ae192:[()=>n.e(67006).then(n.bind(n,22766)),"@site/research/automation-tools/dlrn.md",22766],c31edf67:[()=>n.e(80155).then(n.bind(n,81237)),"@site/specfile/api/specfile/tags.md",81237],c364bf00:[()=>n.e(45061).then(n.bind(n,87736)),"@site/docs/cli/push-updates.md",87736],c377a04b:[()=>n.e(46971).then(n.bind(n,15156)),"@site/docs/index.md",15156],c3a456ca:[()=>n.e(97669).then(n.bind(n,96806)),"@site/posts/devconf-2024/index.md?truncated=true",96806],c3aaf83c:[()=>n.e(4175).then(n.bind(n,36862)),"@site/research/automation-tools/rpkg.md",36862],c466c400:[()=>n.e(59900).then(n.t.bind(n,15329,19)),"~blog/weekly/posts-weekly-tags-september-e37.json",15329],c6ff0ac2:[()=>n.e(5409).then(n.t.bind(n,24689,19)),"~blog/weekly/posts-weekly-tags-october-1b8-list.json",24689],c79e53b3:[()=>n.e(85980).then(n.t.bind(n,35073,19)),"~blog/weekly/posts-weekly-tags-2020-8c7-list.json",35073],c8fc2b21:[()=>n.e(15539).then(n.t.bind(n,48696,19)),"~blog/posts/posts-tags-flock-d32-list.json",48696],ca71f0ed:[()=>n.e(43569).then(n.t.bind(n,87463,19)),"~blog/weekly/posts-weekly-tags-2024-may-fed-list.json",87463],ca801a32:[()=>n.e(74412).then(n.bind(n,27205)),"@site/research/index.md",27205],cad7e7c6:[()=>n.e(55300).then(n.bind(n,16226)),"@site/posts/devconf-2024/index.md",16226],cb7b78ee:[()=>n.e(122).then(n.bind(n,92906)),"@site/weekly/2024/week-16.md",92906],cb932834:[()=>n.e(63394).then(n.t.bind(n,70485,19)),"~blog/weekly/posts-weekly-tags-2024-page-4-426.json",70485],cbbe5f17:[()=>n.e(97455).then(n.t.bind(n,73734,19)),"~blog/weekly/posts-weekly-tags-2024-february-910-list.json",73734],ccc49370:[()=>Promise.all([n.e(40532),n.e(8954),n.e(46048),n.e(46103)]).then(n.bind(n,65203)),"@theme/BlogPostPage",65203],cce7c47a:[()=>n.e(59715).then(n.bind(n,35415)),"@site/weekly/2023.md?truncated=true",35415],cd86d947:[()=>n.e(15919).then(n.bind(n,85584)),"@site/posts/2021-features/index.md?truncated=true",85584],cd954261:[()=>n.e(14159).then(n.bind(n,85296)),"@site/research/outages/index.md",85296],ce3551f9:[()=>n.e(44798).then(n.bind(n,11074)),"@site/research/source-git/in-zuul.md",11074],ce758554:[()=>n.e(1084).then(n.t.bind(n,89298,19)),"~blog/posts/posts-tags-conference-cd8.json",89298],ceaad2a8:[()=>n.e(93213).then(n.bind(n,80488)),"@site/weekly/2023.md",80488],cf25184c:[()=>n.e(14892).then(n.t.bind(n,90879,19)),"~blog/weekly/posts-weekly-tags-july-23e-list.json",90879],d1096f17:[()=>n.e(35749).then(n.t.bind(n,31280,19)),"~blog/posts/posts-tags-logs-f01-list.json",31280],d164bb8d:[()=>n.e(23510).then(n.t.bind(n,9323,19)),"~blog/weekly/posts-weekly-tags-2023-203-list.json",9323],d1b800f6:[()=>n.e(14849).then(n.t.bind(n,1281,19)),"~docs/deployment/category-deployment-autogenerated-category-deployment-specifics-b06.json",1281],d2883f60:[()=>n.e(98703).then(n.bind(n,77572)),"@site/research/monitoring/error-budgets/users-expectations.md",77572],d33bea9b:[()=>n.e(39418).then(n.bind(n,41495)),"@site/posts/fas-verification-automation/index.md?truncated=true",41495],d34552b2:[()=>n.e(22466).then(n.bind(n,45067)),"@site/docs/configuration/upstream/vm_image_build.md",45067],d3cd371b:[()=>n.e(51906).then(n.bind(n,99348)),"@site/docs/archive-not-matching-git.md",99348],d47d5584:[()=>n.e(3908).then(n.bind(n,49262)),"@site/docs/configuration/downstream/bodhi_update.md",49262],d4906370:[()=>n.e(14554).then(n.t.bind(n,85494,19)),"~blog/posts/posts-tags-monorepos-ced-list.json",85494],d4b098fe:[()=>n.e(69759).then(n.bind(n,23371)),"@site/research/source-git/update.md",23371],d52f6c87:[()=>n.e(70177).then(n.bind(n,77098)),"@site/weekly/2024/week-42.md?truncated=true",77098],d52fed64:[()=>n.e(71119).then(n.bind(n,36096)),"@site/weekly/2024/week-46.md?truncated=true",36096],d56dea34:[()=>n.e(99792).then(n.bind(n,11293)),"@site/research/internal-automation/onboard/status.md",11293],d66746c1:[()=>n.e(73996).then(n.bind(n,86525)),"@site/weekly/2024/week-20.md?truncated=true",86525],d66c5321:[()=>n.e(26151).then(n.bind(n,82682)),"@site/posts/copr-srpms/index.md?truncated=true",82682],d6a3d420:[()=>n.e(78514).then(n.t.bind(n,53688,19)),"~blog/posts/posts-tags-yearly-numbers-207-list.json",53688],d6ff966b:[()=>n.e(15647).then(n.bind(n,96673)),"@site/docs/configuration/upstream/copr_build.md",96673],d7260e5d:[()=>n.e(83385).then(n.bind(n,70313)),"@site/weekly/2024/week-24.md?truncated=true",70313],d7ccb4c2:[()=>n.e(12442).then(n.t.bind(n,97560,19)),"/home/runner/work/packit.dev/packit.dev/.docusaurus/docusaurus-plugin-content-docs/research/plugin-route-context-module-100.json",97560],d7e63866:[()=>n.e(66342).then(n.t.bind(n,49780,19)),"~blog/weekly/posts-weekly-tags-2024-may-fed.json",49780],d7fc2346:[()=>n.e(97825).then(n.t.bind(n,46949,19)),"~blog/posts/posts-tags-2022-5d4.json",46949],d9f22873:[()=>n.e(51540).then(n.t.bind(n,8559,19)),"~blog/weekly/posts-weekly-tags-2024-page-3-845.json",8559],da2ff862:[()=>n.e(2982).then(n.t.bind(n,18153,19)),"~blog/weekly/posts-weekly-tags-july-23e.json",18153],da818bca:[()=>n.e(4195).then(n.bind(n,75449)),"@site/weekly/2024/week-34.md",75449],db3b0523:[()=>n.e(62626).then(n.bind(n,70551)),"@site/weekly/2024/week-32.md",70551],dbfa3dd6:[()=>n.e(61651).then(n.bind(n,34185)),"@site/posts/pre-commit-hooks/index.md?truncated=true",34185],dce9b99e:[()=>n.e(81873).then(n.bind(n,69845)),"@site/docs/cli/source-git/update-dist-git.md",69845],dd09c8af:[()=>n.e(3281).then(n.bind(n,16932)),"@site/research/job_referencing/index.md",16932],dd4ac388:[()=>n.e(35651).then(n.bind(n,31382)),"@site/posts/non-git-upstreams-support/index.md",31382],dd889d07:[()=>n.e(38500).then(n.t.bind(n,45668,19)),"~blog/posts/posts-tags-openscanhub-d64.json",45668],ddfe5dc3:[()=>n.e(49582).then(n.t.bind(n,85599,19)),"~blog/weekly/posts-weekly-tags-january-fac.json",85599],de20f52c:[()=>n.e(13288).then(n.t.bind(n,52317,19)),"~blog/weekly/posts-weekly-tags-2024-page-4-426-list.json",52317],de459308:[()=>n.e(69432).then(n.bind(n,23309)),"@site/research/source-git/customize-update-dist-git.md",23309],df85a926:[()=>n.e(68746).then(n.bind(n,39723)),"@site/weekly/2024/week-29.md",39723],e0147710:[()=>n.e(37425).then(n.t.bind(n,7842,19)),"~blog/weekly/posts-weekly-tags-2024-november-05e-list.json",7842],e0b86265:[()=>n.e(64956).then(n.t.bind(n,30696,19)),"~blog/weekly/posts-weekly-page-6-6bb.json",30696],e0c41194:[()=>n.e(53443).then(n.bind(n,73383)),"@site/posts/2021-in-numbers/index.md?truncated=true",73383],e21f8356:[()=>n.e(65646).then(n.bind(n,62930)),"@site/weekly/2019.md",62930],e25a039d:[()=>n.e(95376).then(n.bind(n,75829)),"@site/weekly/2024/week-46.md",75829],e273a171:[()=>n.e(36982).then(n.bind(n,54345)),"@site/docs/configuration/downstream/koji_build.md",54345],e2d3297a:[()=>n.e(52774).then(n.bind(n,52008)),"@site/specfile/api/specfile/sections.md",52008],e3603f1c:[()=>n.e(91073).then(n.t.bind(n,45461,19)),"~docs/docs/category-docs-autogenerated-category-source-git-4d4.json",45461],e43e771c:[()=>n.e(23383).then(n.t.bind(n,70016,19)),"~blog/weekly/posts-weekly-tags-2019-495.json",70016],e4a8fc5f:[()=>n.e(92558).then(n.bind(n,12874)),"@site/weekly/2024/week-14.md",12874],e4be8ed3:[()=>n.e(60713).then(n.bind(n,82043)),"@site/weekly/2024/week-24.md",82043],e4febce7:[()=>n.e(64836).then(n.bind(n,87042)),"@site/posts/manual-triggering/index.md",87042],e534fa64:[()=>n.e(57154).then(n.bind(n,59464)),"@site/posts/experiences_with_rust/index.md?truncated=true",59464],e53b4525:[()=>n.e(51486).then(n.bind(n,17305)),"@site/research/workflow-engines/airflow.md",17305],e5572fcd:[()=>n.e(67799).then(n.bind(n,72705)),"@site/deployment/specifics/redict.md",72705],e6339af7:[()=>n.e(21907).then(n.t.bind(n,15062,19)),"~blog/weekly/blog-post-list-prop-weekly.json",15062],e648938d:[()=>n.e(80747).then(n.bind(n,91446)),"@site/source-git/work-with-source-git/pull-upstream-fixes.md",91446],e6722c50:[()=>n.e(94488).then(n.t.bind(n,38516,19)),"~blog/weekly/posts-weekly-archive-9a4.json",38516],e6bbf751:[()=>n.e(48578).then(n.bind(n,99443)),"@site/research/workflow-engines/temporal.md",99443],e721cd31:[()=>n.e(99481).then(n.bind(n,67466)),"@site/weekly/2024/week-40.md?truncated=true",67466],e7c388ba:[()=>n.e(22074).then(n.t.bind(n,22191,19)),"~blog/weekly/posts-weekly-tags-2024-page-2-91e-list.json",22191],e7dac2d9:[()=>n.e(67653).then(n.bind(n,22102)),"@site/research/integrations/image-builder/index.md",22102],e7dd9cc3:[()=>n.e(81923).then(n.bind(n,56750)),"@site/research/deployment/deployment-improvements/index.md",56750],e8269cea:[()=>n.e(38208).then(n.t.bind(n,88735,19)),"~blog/weekly/posts-weekly-tags-2021-d53.json",88735],e8dac370:[()=>n.e(7446).then(n.t.bind(n,79431,19)),"~blog/posts/posts-tags-tags-3de.json",79431],eb2f71fd:[()=>n.e(79775).then(n.bind(n,30835)),"@site/weekly/2024/week-2.md?truncated=true",30835],eb37e67b:[()=>n.e(7176).then(n.bind(n,53119)),"@site/weekly/2024/week-38.md",53119],eb517363:[()=>n.e(80292).then(n.bind(n,78375)),"@site/research/monitoring/adoption-metrics/index.md",78375],ebfc212e:[()=>n.e(47061).then(n.t.bind(n,5348,19)),"~blog/posts/posts-tags-testing-farm-08a.json",5348],ec27e18d:[()=>n.e(63780).then(n.bind(n,35387)),"@site/research/source-git/dist-git-to-src-git/index.md",35387],ecc63bc3:[()=>n.e(87366).then(n.bind(n,71890)),"@site/weekly/2021.md?truncated=true",71890],ed5b6b44:[()=>n.e(65206).then(n.t.bind(n,29292,19)),"~blog/posts/posts-tags-specfile-0c6-list.json",29292],ee0a670e:[()=>n.e(44142).then(n.t.bind(n,29896,19)),"~blog/weekly/posts-weekly-tags-2025-january-80e.json",29896],ee1121cc:[()=>n.e(56518).then(n.bind(n,15230)),"@site/weekly/2024/week-20.md",15230],ee360d9b:[()=>n.e(94805).then(n.bind(n,76764)),"@site/weekly/2024/week-37.md?truncated=true",76764],eefbce61:[()=>n.e(67075).then(n.bind(n,13396)),"@site/docs/fedora-releases-guide/releasing-multiple-packages.md",13396],ef3babef:[()=>n.e(76774).then(n.bind(n,71948)),"@site/weekly/2023/packit-workshop.md?truncated=true",71948],ef8289cd:[()=>n.e(95011).then(n.t.bind(n,82898,19)),"~blog/weekly/posts-weekly-tags-2025-january-80e-list.json",82898],f02e71ef:[()=>n.e(60889).then(n.t.bind(n,72994,19)),"~blog/weekly/posts-weekly-tags-2024-page-5-6d8-list.json",72994],f070b3d4:[()=>n.e(52372).then(n.bind(n,28007)),"@site/docs/configuration/upstream/propose_downstream.md",28007],f1552835:[()=>n.e(31730).then(n.t.bind(n,45343,19)),"/home/runner/work/packit.dev/packit.dev/.docusaurus/docusaurus-plugin-content-docs/development/plugin-route-context-module-100.json",45343],f26768b8:[()=>n.e(72152).then(n.t.bind(n,31137,19)),"~blog/weekly/posts-weekly-tags-2022-47e-list.json",31137],f303156d:[()=>n.e(28257).then(n.bind(n,372)),"@site/deployment/images.md",372],f3e20d74:[()=>n.e(55890).then(n.bind(n,78074)),"@site/agile/index.md",78074],f3ec6093:[()=>n.e(83257).then(n.bind(n,46279)),"@site/deployment/internal_tf.md",46279],f40fa3b8:[()=>n.e(7633).then(n.bind(n,9766)),"@site/weekly/2024/week-25.md?truncated=true",9766],f4486898:[()=>n.e(30317).then(n.t.bind(n,22622,19)),"~docs/research/category-research-autogenerated-category-celery-921.json",22622],f47a8e69:[()=>n.e(27271).then(n.t.bind(n,8512,19)),"~blog/posts/posts-tags-staging-725-list.json",8512],f4b4122b:[()=>n.e(69651).then(n.bind(n,86132)),"@site/agile/meetings.md",86132],f4b7f768:[()=>n.e(13450).then(n.bind(n,7839)),"@site/posts/verify-sync-release-volunteers/index.md",7839],f4db4b00:[()=>n.e(3934).then(n.t.bind(n,44644,19)),"~blog/posts/posts-tags-flock-d32.json",44644],f5cbbd34:[()=>n.e(34597).then(n.bind(n,37753)),"@site/docs/cli/scan-in-osh.md",37753],f5d908f4:[()=>n.e(39843).then(n.t.bind(n,26376,19)),"~blog/posts/posts-tags-srpm-071-list.json",26376],f5f5a225:[()=>n.e(41731).then(n.bind(n,97316)),"@site/research/specfiles/hosting-sources/index.md",97316],f6d78023:[()=>n.e(89016).then(n.bind(n,91551)),"@site/docs/configuration/index.md",91551],f80516b8:[()=>n.e(14114).then(n.t.bind(n,98372,19)),"~blog/posts/posts-tags-summary-862-list.json",98372],f8a37000:[()=>n.e(29564).then(n.bind(n,3361)),"@site/posts/release-field-handling/index.md?truncated=true",3361],f8cf70e9:[()=>n.e(96837).then(n.t.bind(n,86562,19)),"~blog/posts/posts-tags-pull-from-upstream-a24-list.json",86562],f8d02322:[()=>n.e(898).then(n.bind(n,86730)),"@site/research/deprecation/index.md",86730],f9407d5f:[()=>n.e(34084).then(n.t.bind(n,48418,19)),"~blog/weekly/posts-weekly-tags-2024-september-f01.json",48418],f97836aa:[()=>n.e(38379).then(n.bind(n,56048)),"@site/weekly/2024/week-11.md?truncated=true",56048],fa07b7e4:[()=>n.e(85189).then(n.bind(n,9599)),"@site/weekly/2025/week-2.md?truncated=true",9599],fa6222e7:[()=>n.e(27911).then(n.bind(n,10837)),"@site/weekly/2024/week-21.md",10837],fa89d654:[()=>n.e(4411).then(n.t.bind(n,95819,19)),"~blog/posts/posts-tags-yearly-numbers-207.json",95819],fac44d3a:[()=>n.e(56555).then(n.bind(n,24015)),"@site/docs/cli/build/locally.md",24015],fb049ecb:[()=>n.e(55031).then(n.bind(n,48126)),"@site/posts/changelogs/index.md",48126],fb94c13d:[()=>n.e(48500).then(n.bind(n,87597)),"@site/research/monitoring/adoption-metrics/define-adoption-metrics.md",87597],fc539523:[()=>n.e(71434).then(n.bind(n,15332)),"@site/research/testing/zuul.md",15332],fd3c8ea5:[()=>n.e(51326).then(n.t.bind(n,5262,19)),"~blog/posts/posts-tags-conference-cd8-list.json",5262],fd5dbc67:[()=>n.e(72256).then(n.t.bind(n,17111,19)),"~blog/weekly/posts-weekly-tags-2019-495-list.json",17111],fdecaeb2:[()=>n.e(93566).then(n.bind(n,37202)),"@site/docs/fedora-releases-guide/dist-git-onboarding.md",37202],fe554645:[()=>n.e(25241).then(n.t.bind(n,41446,19)),"~blog/weekly/posts-weekly-tags-2024-december-939-list.json",41446],fe9a6872:[()=>n.e(97305).then(n.bind(n,79555)),"@site/docs/cli/pull-from-upstream.md",79555],ffae348c:[()=>n.e(71260).then(n.bind(n,55091)),"@site/research/testing/external-testing.md",55091],ffe09f92:[()=>n.e(81614).then(n.bind(n,66885)),"@site/research/automation-tools/index.md",66885],fff526c7:[()=>n.e(42128).then(n.bind(n,41627)),"@site/weekly/2024/week-26.md",41627]};function l(e){let{error:t,retry:n,pastDelay:r}=e;return t?a.createElement("div",{style:{textAlign:"center",color:"#fff",backgroundColor:"#fa383e",borderColor:"#fa383e",borderStyle:"solid",borderRadius:"0.25rem",borderWidth:"1px",boxSizing:"border-box",display:"block",padding:"1rem",flex:"0 0 50%",marginLeft:"25%",marginRight:"25%",marginTop:"5rem",maxWidth:"50%",width:"100%"}},a.createElement("p",null,String(t)),a.createElement("div",null,a.createElement("button",{type:"button",onClick:n},"Retry"))):r?a.createElement("div",{style:{display:"flex",justifyContent:"center",alignItems:"center",height:"100vh"}},a.createElement("svg",{id:"loader",style:{width:128,height:110,position:"absolute",top:"calc(100vh - 64%)"},viewBox:"0 0 45 45",xmlns:"http://www.w3.org/2000/svg",stroke:"#61dafb"},a.createElement("g",{fill:"none",fillRule:"evenodd",transform:"translate(1 1)",strokeWidth:"2"},a.createElement("circle",{cx:"22",cy:"22",r:"6",strokeOpacity:"0"},a.createElement("animate",{attributeName:"r",begin:"1.5s",dur:"3s",values:"6;22",calcMode:"linear",repeatCount:"indefinite"}),a.createElement("animate",{attributeName:"stroke-opacity",begin:"1.5s",dur:"3s",values:"1;0",calcMode:"linear",repeatCount:"indefinite"}),a.createElement("animate",{attributeName:"stroke-width",begin:"1.5s",dur:"3s",values:"2;0",calcMode:"linear",repeatCount:"indefinite"})),a.createElement("circle",{cx:"22",cy:"22",r:"6",strokeOpacity:"0"},a.createElement("animate",{attributeName:"r",begin:"3s",dur:"3s",values:"6;22",calcMode:"linear",repeatCount:"indefinite"}),a.createElement("animate",{attributeName:"stroke-opacity",begin:"3s",dur:"3s",values:"1;0",calcMode:"linear",repeatCount:"indefinite"}),a.createElement("animate",{attributeName:"stroke-width",begin:"3s",dur:"3s",values:"2;0",calcMode:"linear",repeatCount:"indefinite"})),a.createElement("circle",{cx:"22",cy:"22",r:"8"},a.createElement("animate",{attributeName:"r",begin:"0s",dur:"1.5s",values:"6;1;2;3;4;5;6",calcMode:"linear",repeatCount:"indefinite"}))))):null}var u=n(99670),d=n(30226);function p(e,t){if("*"===e)return i()({loading:l,loader:()=>n.e(4972).then(n.bind(n,4972)),modules:["@theme/NotFound"],webpack:()=>[4972],render(e,t){const n=e.default;return a.createElement(d.z,{value:{plugin:{name:"native",id:"default"}}},a.createElement(n,t))}});const o=s[`${e}-${t}`],p={},f=[],m=[],g=(0,u.Z)(o);return Object.entries(g).forEach((e=>{let[t,n]=e;const a=c[n];a&&(p[t]=a[0],f.push(a[1]),m.push(a[2]))})),i().Map({loading:l,loader:p,modules:f,webpack:()=>m,render(t,n){const i=JSON.parse(JSON.stringify(o));Object.entries(t).forEach((t=>{let[n,a]=t;const r=a.default;if(!r)throw new Error(`The page component at ${e} doesn't have a default export. This makes it impossible to render anything. Consider default-exporting a React component.`);"object"!=typeof r&&"function"!=typeof r||Object.keys(a).filter((e=>"default"!==e)).forEach((e=>{r[e]=a[e]}));let o=i;const s=n.split(".");s.slice(0,-1).forEach((e=>{o=o[e]})),o[s[s.length-1]]=r}));const s=i.__comp;delete i.__comp;const c=i.__context;return delete i.__context,a.createElement(d.z,{value:c},a.createElement(s,(0,r.Z)({},i,n)))}})}const f=[{path:"/posts",component:p("/posts","f85"),exact:!0},{path:"/posts/2021-features",component:p("/posts/2021-features","648"),exact:!0},{path:"/posts/2021-in-numbers",component:p("/posts/2021-in-numbers","dd2"),exact:!0},{path:"/posts/2022-features",component:p("/posts/2022-features","3ec"),exact:!0},{path:"/posts/archive",component:p("/posts/archive","90b"),exact:!0},{path:"/posts/aws-and-image-builder",component:p("/posts/aws-and-image-builder","8b9"),exact:!0},{path:"/posts/changelogs",component:p("/posts/changelogs","188"),exact:!0},{path:"/posts/copr-srpms",component:p("/posts/copr-srpms","a6c"),exact:!0},{path:"/posts/devconf-2024",component:p("/posts/devconf-2024","677"),exact:!0},{path:"/posts/downstream-automation",component:p("/posts/downstream-automation","a93"),exact:!0},{path:"/posts/experiences_with_rust",component:p("/posts/experiences_with_rust","733"),exact:!0},{path:"/posts/fas-verification-automation",component:p("/posts/fas-verification-automation","bcf"),exact:!0},{path:"/posts/fedora-eln",component:p("/posts/fedora-eln","0e1"),exact:!0},{path:"/posts/flock_2024_diary",component:p("/posts/flock_2024_diary","3bc"),exact:!0},{path:"/posts/manual-triggering",component:p("/posts/manual-triggering","27d"),exact:!0},{path:"/posts/monorepos",component:p("/posts/monorepos","db3"),exact:!0},{path:"/posts/non-divergent-dist-git-branches",component:p("/posts/non-divergent-dist-git-branches","4c0"),exact:!0},{path:"/posts/non-git-upstreams-support",component:p("/posts/non-git-upstreams-support","305"),exact:!0},{path:"/posts/openscanhub-prototype",component:p("/posts/openscanhub-prototype","b38"),exact:!0},{path:"/posts/packit_1_0_0_action_required",component:p("/posts/packit_1_0_0_action_required","1fc"),exact:!0},{path:"/posts/packit-in-2024",component:p("/posts/packit-in-2024","908"),exact:!0},{path:"/posts/page/2",component:p("/posts/page/2","455"),exact:!0},{path:"/posts/page/3",component:p("/posts/page/3","ef8"),exact:!0},{path:"/posts/pre-commit-hooks",component:p("/posts/pre-commit-hooks","0ca"),exact:!0},{path:"/posts/project-mycorrhiza",component:p("/posts/project-mycorrhiza","0d8"),exact:!0},{path:"/posts/pull-from-upstream",component:p("/posts/pull-from-upstream","904"),exact:!0},{path:"/posts/release-field-handling",component:p("/posts/release-field-handling","fef"),exact:!0},{path:"/posts/specfile-advanced",component:p("/posts/specfile-advanced","ceb"),exact:!0},{path:"/posts/specfile-introduction",component:p("/posts/specfile-introduction","c37"),exact:!0},{path:"/posts/tags",component:p("/posts/tags","3ad"),exact:!0},{path:"/posts/tags/2021",component:p("/posts/tags/2021","a42"),exact:!0},{path:"/posts/tags/2022",component:p("/posts/tags/2022","d6c"),exact:!0},{path:"/posts/tags/2024",component:p("/posts/tags/2024","d82"),exact:!0},{path:"/posts/tags/conference",component:p("/posts/tags/conference","b9e"),exact:!0},{path:"/posts/tags/configuration",component:p("/posts/tags/configuration","56b"),exact:!0},{path:"/posts/tags/copr",component:p("/posts/tags/copr","442"),exact:!0},{path:"/posts/tags/dashboard",component:p("/posts/tags/dashboard","d5b"),exact:!0},{path:"/posts/tags/downstream",component:p("/posts/tags/downstream","5b6"),exact:!0},{path:"/posts/tags/fas",component:p("/posts/tags/fas","195"),exact:!0},{path:"/posts/tags/fedora",component:p("/posts/tags/fedora","e72"),exact:!0},{path:"/posts/tags/flock",component:p("/posts/tags/flock","919"),exact:!0},{path:"/posts/tags/image-builder",component:p("/posts/tags/image-builder","aab"),exact:!0},{path:"/posts/tags/logs",component:p("/posts/tags/logs","359"),exact:!0},{path:"/posts/tags/monorepos",component:p("/posts/tags/monorepos","901"),exact:!0},{path:"/posts/tags/openscanhub",component:p("/posts/tags/openscanhub","088"),exact:!0},{path:"/posts/tags/project-mycorrhiza",component:p("/posts/tags/project-mycorrhiza","2f8"),exact:!0},{path:"/posts/tags/propose-downstream",component:p("/posts/tags/propose-downstream","605"),exact:!0},{path:"/posts/tags/pull-from-upstream",component:p("/posts/tags/pull-from-upstream","01a"),exact:!0},{path:"/posts/tags/sast",component:p("/posts/tags/sast","d46"),exact:!0},{path:"/posts/tags/shift-left",component:p("/posts/tags/shift-left","921"),exact:!0},{path:"/posts/tags/specfile",component:p("/posts/tags/specfile","5c3"),exact:!0},{path:"/posts/tags/srpm",component:p("/posts/tags/srpm","584"),exact:!0},{path:"/posts/tags/staging",component:p("/posts/tags/staging","207"),exact:!0},{path:"/posts/tags/summary",component:p("/posts/tags/summary","338"),exact:!0},{path:"/posts/tags/testing-farm",component:p("/posts/tags/testing-farm","1ad"),exact:!0},{path:"/posts/tags/ux",component:p("/posts/tags/ux","973"),exact:!0},{path:"/posts/tags/workflow",component:p("/posts/tags/workflow","9b6"),exact:!0},{path:"/posts/tags/yearly-features",component:p("/posts/tags/yearly-features","b32"),exact:!0},{path:"/posts/tags/yearly-numbers",component:p("/posts/tags/yearly-numbers","30c"),exact:!0},{path:"/posts/testing-farm-triggering",component:p("/posts/testing-farm-triggering","916"),exact:!0},{path:"/posts/verify-sync-release-volunteers",component:p("/posts/verify-sync-release-volunteers","4c9"),exact:!0},{path:"/posts/weekly",component:p("/posts/weekly","83c"),exact:!0},{path:"/posts/weekly/2019",component:p("/posts/weekly/2019","b64"),exact:!0},{path:"/posts/weekly/2020",component:p("/posts/weekly/2020","8aa"),exact:!0},{path:"/posts/weekly/2021",component:p("/posts/weekly/2021","2e2"),exact:!0},{path:"/posts/weekly/2022",component:p("/posts/weekly/2022","a10"),exact:!0},{path:"/posts/weekly/2023",component:p("/posts/weekly/2023","9a5"),exact:!0},{path:"/posts/weekly/2023/packit-workshop",component:p("/posts/weekly/2023/packit-workshop","c4b"),exact:!0},{path:"/posts/weekly/2024/week-1",component:p("/posts/weekly/2024/week-1","5c6"),exact:!0},{path:"/posts/weekly/2024/week-10",component:p("/posts/weekly/2024/week-10","d3f"),exact:!0},{path:"/posts/weekly/2024/week-11",component:p("/posts/weekly/2024/week-11","b9b"),exact:!0},{path:"/posts/weekly/2024/week-12",component:p("/posts/weekly/2024/week-12","12a"),exact:!0},{path:"/posts/weekly/2024/week-13",component:p("/posts/weekly/2024/week-13","5cc"),exact:!0},{path:"/posts/weekly/2024/week-14",component:p("/posts/weekly/2024/week-14","9b2"),exact:!0},{path:"/posts/weekly/2024/week-15",component:p("/posts/weekly/2024/week-15","c96"),exact:!0},{path:"/posts/weekly/2024/week-16",component:p("/posts/weekly/2024/week-16","362"),exact:!0},{path:"/posts/weekly/2024/week-17",component:p("/posts/weekly/2024/week-17","266"),exact:!0},{path:"/posts/weekly/2024/week-18",component:p("/posts/weekly/2024/week-18","807"),exact:!0},{path:"/posts/weekly/2024/week-19",component:p("/posts/weekly/2024/week-19","169"),exact:!0},{path:"/posts/weekly/2024/week-2",component:p("/posts/weekly/2024/week-2","453"),exact:!0},{path:"/posts/weekly/2024/week-20",component:p("/posts/weekly/2024/week-20","0c4"),exact:!0},{path:"/posts/weekly/2024/week-21",component:p("/posts/weekly/2024/week-21","312"),exact:!0},{path:"/posts/weekly/2024/week-22",component:p("/posts/weekly/2024/week-22","23b"),exact:!0},{path:"/posts/weekly/2024/week-24",component:p("/posts/weekly/2024/week-24","9a2"),exact:!0},{path:"/posts/weekly/2024/week-25",component:p("/posts/weekly/2024/week-25","da9"),exact:!0},{path:"/posts/weekly/2024/week-26",component:p("/posts/weekly/2024/week-26","e76"),exact:!0},{path:"/posts/weekly/2024/week-27",component:p("/posts/weekly/2024/week-27","65d"),exact:!0},{path:"/posts/weekly/2024/week-28",component:p("/posts/weekly/2024/week-28","88c"),exact:!0},{path:"/posts/weekly/2024/week-29",component:p("/posts/weekly/2024/week-29","d74"),exact:!0},{path:"/posts/weekly/2024/week-3",component:p("/posts/weekly/2024/week-3","0e7"),exact:!0},{path:"/posts/weekly/2024/week-30",component:p("/posts/weekly/2024/week-30","277"),exact:!0},{path:"/posts/weekly/2024/week-31",component:p("/posts/weekly/2024/week-31","5c5"),exact:!0},{path:"/posts/weekly/2024/week-32",component:p("/posts/weekly/2024/week-32","667"),exact:!0},{path:"/posts/weekly/2024/week-33",component:p("/posts/weekly/2024/week-33","aac"),exact:!0},{path:"/posts/weekly/2024/week-34",component:p("/posts/weekly/2024/week-34","d80"),exact:!0},{path:"/posts/weekly/2024/week-36",component:p("/posts/weekly/2024/week-36","25c"),exact:!0},{path:"/posts/weekly/2024/week-37",component:p("/posts/weekly/2024/week-37","a75"),exact:!0},{path:"/posts/weekly/2024/week-38",component:p("/posts/weekly/2024/week-38","f36"),exact:!0},{path:"/posts/weekly/2024/week-39",component:p("/posts/weekly/2024/week-39","6cf"),exact:!0},{path:"/posts/weekly/2024/week-4",component:p("/posts/weekly/2024/week-4","c50"),exact:!0},{path:"/posts/weekly/2024/week-40",component:p("/posts/weekly/2024/week-40","458"),exact:!0},{path:"/posts/weekly/2024/week-41",component:p("/posts/weekly/2024/week-41","2af"),exact:!0},{path:"/posts/weekly/2024/week-42",component:p("/posts/weekly/2024/week-42","aa5"),exact:!0},{path:"/posts/weekly/2024/week-43",component:p("/posts/weekly/2024/week-43","680"),exact:!0},{path:"/posts/weekly/2024/week-44",component:p("/posts/weekly/2024/week-44","133"),exact:!0},{path:"/posts/weekly/2024/week-45",component:p("/posts/weekly/2024/week-45","b9e"),exact:!0},{path:"/posts/weekly/2024/week-46",component:p("/posts/weekly/2024/week-46","972"),exact:!0},{path:"/posts/weekly/2024/week-47",component:p("/posts/weekly/2024/week-47","cf7"),exact:!0},{path:"/posts/weekly/2024/week-48",component:p("/posts/weekly/2024/week-48","91e"),exact:!0},{path:"/posts/weekly/2024/week-49",component:p("/posts/weekly/2024/week-49","07c"),exact:!0},{path:"/posts/weekly/2024/week-5",component:p("/posts/weekly/2024/week-5","ebb"),exact:!0},{path:"/posts/weekly/2024/week-50",component:p("/posts/weekly/2024/week-50","a8c"),exact:!0},{path:"/posts/weekly/2024/week-6",component:p("/posts/weekly/2024/week-6","32f"),exact:!0},{path:"/posts/weekly/2024/week-7",component:p("/posts/weekly/2024/week-7","b45"),exact:!0},{path:"/posts/weekly/2024/week-8",component:p("/posts/weekly/2024/week-8","1b6"),exact:!0},{path:"/posts/weekly/2024/week-9",component:p("/posts/weekly/2024/week-9","420"),exact:!0},{path:"/posts/weekly/2025/week-1",component:p("/posts/weekly/2025/week-1","b60"),exact:!0},{path:"/posts/weekly/2025/week-2",component:p("/posts/weekly/2025/week-2","52a"),exact:!0},{path:"/posts/weekly/archive",component:p("/posts/weekly/archive","6ab"),exact:!0},{path:"/posts/weekly/page/2",component:p("/posts/weekly/page/2","547"),exact:!0},{path:"/posts/weekly/page/3",component:p("/posts/weekly/page/3","518"),exact:!0},{path:"/posts/weekly/page/4",component:p("/posts/weekly/page/4","396"),exact:!0},{path:"/posts/weekly/page/5",component:p("/posts/weekly/page/5","235"),exact:!0},{path:"/posts/weekly/page/6",component:p("/posts/weekly/page/6","23e"),exact:!0},{path:"/posts/weekly/tags",component:p("/posts/weekly/tags","ad3"),exact:!0},{path:"/posts/weekly/tags/2019",component:p("/posts/weekly/tags/2019","ac2"),exact:!0},{path:"/posts/weekly/tags/2020",component:p("/posts/weekly/tags/2020","dc2"),exact:!0},{path:"/posts/weekly/tags/2021",component:p("/posts/weekly/tags/2021","361"),exact:!0},{path:"/posts/weekly/tags/2022",component:p("/posts/weekly/tags/2022","00e"),exact:!0},{path:"/posts/weekly/tags/2023",component:p("/posts/weekly/tags/2023","99a"),exact:!0},{path:"/posts/weekly/tags/2023-december",component:p("/posts/weekly/tags/2023-december","ce6"),exact:!0},{path:"/posts/weekly/tags/2024",component:p("/posts/weekly/tags/2024","971"),exact:!0},{path:"/posts/weekly/tags/2024-april",component:p("/posts/weekly/tags/2024-april","3c4"),exact:!0},{path:"/posts/weekly/tags/2024-august",component:p("/posts/weekly/tags/2024-august","3aa"),exact:!0},{path:"/posts/weekly/tags/2024-december",component:p("/posts/weekly/tags/2024-december","66c"),exact:!0},{path:"/posts/weekly/tags/2024-february",component:p("/posts/weekly/tags/2024-february","95f"),exact:!0},{path:"/posts/weekly/tags/2024-january",component:p("/posts/weekly/tags/2024-january","495"),exact:!0},{path:"/posts/weekly/tags/2024-july",component:p("/posts/weekly/tags/2024-july","00f"),exact:!0},{path:"/posts/weekly/tags/2024-june",component:p("/posts/weekly/tags/2024-june","14b"),exact:!0},{path:"/posts/weekly/tags/2024-march",component:p("/posts/weekly/tags/2024-march","4c6"),exact:!0},{path:"/posts/weekly/tags/2024-may",component:p("/posts/weekly/tags/2024-may","060"),exact:!0},{path:"/posts/weekly/tags/2024-november",component:p("/posts/weekly/tags/2024-november","f4c"),exact:!0},{path:"/posts/weekly/tags/2024-october",component:p("/posts/weekly/tags/2024-october","235"),exact:!0},{path:"/posts/weekly/tags/2024-september",component:p("/posts/weekly/tags/2024-september","72a"),exact:!0},{path:"/posts/weekly/tags/2024/page/2",component:p("/posts/weekly/tags/2024/page/2","4bb"),exact:!0},{path:"/posts/weekly/tags/2024/page/3",component:p("/posts/weekly/tags/2024/page/3","3f5"),exact:!0},{path:"/posts/weekly/tags/2024/page/4",component:p("/posts/weekly/tags/2024/page/4","b87"),exact:!0},{path:"/posts/weekly/tags/2024/page/5",component:p("/posts/weekly/tags/2024/page/5","ca0"),exact:!0},{path:"/posts/weekly/tags/2025",component:p("/posts/weekly/tags/2025","001"),exact:!0},{path:"/posts/weekly/tags/2025-january",component:p("/posts/weekly/tags/2025-january","f2b"),exact:!0},{path:"/posts/weekly/tags/april",component:p("/posts/weekly/tags/april","776"),exact:!0},{path:"/posts/weekly/tags/august",component:p("/posts/weekly/tags/august","fa6"),exact:!0},{path:"/posts/weekly/tags/december",component:p("/posts/weekly/tags/december","2f0"),exact:!0},{path:"/posts/weekly/tags/february",component:p("/posts/weekly/tags/february","20a"),exact:!0},{path:"/posts/weekly/tags/january",component:p("/posts/weekly/tags/january","137"),exact:!0},{path:"/posts/weekly/tags/july",component:p("/posts/weekly/tags/july","989"),exact:!0},{path:"/posts/weekly/tags/june",component:p("/posts/weekly/tags/june","9b9"),exact:!0},{path:"/posts/weekly/tags/march",component:p("/posts/weekly/tags/march","066"),exact:!0},{path:"/posts/weekly/tags/may",component:p("/posts/weekly/tags/may","fc3"),exact:!0},{path:"/posts/weekly/tags/november",component:p("/posts/weekly/tags/november","24d"),exact:!0},{path:"/posts/weekly/tags/october",component:p("/posts/weekly/tags/october","bfc"),exact:!0},{path:"/posts/weekly/tags/september",component:p("/posts/weekly/tags/september","8bf"),exact:!0},{path:"/search",component:p("/search","a40"),exact:!0},{path:"/usage",component:p("/usage","e6d"),exact:!0},{path:"/agile",component:p("/agile","981"),routes:[{path:"/agile",component:p("/agile","c4c"),exact:!0,sidebar:"autogenerated"},{path:"/agile/kanban",component:p("/agile/kanban","a5e"),exact:!0,sidebar:"autogenerated"},{path:"/agile/meetings",component:p("/agile/meetings","5d8"),exact:!0,sidebar:"autogenerated"},{path:"/agile/roles",component:p("/agile/roles","750"),exact:!0,sidebar:"autogenerated"},{path:"/agile/weekly-roles",component:p("/agile/weekly-roles","bfa"),exact:!0,sidebar:"autogenerated"}]},{path:"/deployment",component:p("/deployment","eff"),routes:[{path:"/deployment",component:p("/deployment","905"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/category/deployment-specifics",component:p("/deployment/category/deployment-specifics","144"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/continuous-deployment",component:p("/deployment/continuous-deployment","63e"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/images",component:p("/deployment/images","9e8"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/internal_tf",component:p("/deployment/internal_tf","0fa"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/monitoring",component:p("/deployment/monitoring","ff6"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/monitoring/logs",component:p("/deployment/monitoring/logs","fde"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/openshift_local_cluster",component:p("/deployment/openshift_local_cluster","e25"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/postgresql",component:p("/deployment/postgresql","815"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/resource-requirements",component:p("/deployment/resource-requirements","fef"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/scripts",component:p("/deployment/scripts","b62"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/secrets",component:p("/deployment/secrets","bdf"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/specifics/centos-stream-source-git",component:p("/deployment/specifics/centos-stream-source-git","2a2"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/specifics/clusters",component:p("/deployment/specifics/clusters","7d6"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/specifics/fedora-source-git",component:p("/deployment/specifics/fedora-source-git","e16"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/specifics/packit-service",component:p("/deployment/specifics/packit-service","d84"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/specifics/redict",component:p("/deployment/specifics/redict","718"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/testing-changes",component:p("/deployment/testing-changes","65b"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/tls-certs",component:p("/deployment/tls-certs","cd0"),exact:!0,sidebar:"autogenerated"},{path:"/deployment/vars",component:p("/deployment/vars","799"),exact:!0,sidebar:"autogenerated"}]},{path:"/development",component:p("/development","b6a"),routes:[{path:"/development",component:p("/development","ce2"),exact:!0,sidebar:"autogenerated"},{path:"/development/creating-stream-9-repos",component:p("/development/creating-stream-9-repos","17d"),exact:!0,sidebar:"autogenerated"},{path:"/development/how-open-is-this-service",component:p("/development/how-open-is-this-service","ff0"),exact:!0,sidebar:"autogenerated"},{path:"/development/patch-metadata",component:p("/development/patch-metadata","eb2"),exact:!0,sidebar:"autogenerated"}]},{path:"/docs",component:p("/docs","e13"),routes:[{path:"/docs",component:p("/docs","e83"),exact:!0,sidebar:"autogenerated"},{path:"/docs/about",component:p("/docs/about","db0"),exact:!0,sidebar:"autogenerated"},{path:"/docs/archive-not-matching-git",component:p("/docs/archive-not-matching-git","de1"),exact:!0,sidebar:"autogenerated"},{path:"/docs/category/dist-git",component:p("/docs/category/dist-git","ef4"),exact:!0,sidebar:"autogenerated"},{path:"/docs/category/downstream-jobs",component:p("/docs/category/downstream-jobs","dc0"),exact:!0,sidebar:"autogenerated"},{path:"/docs/category/source-git",component:p("/docs/category/source-git","854"),exact:!0,sidebar:"autogenerated"},{path:"/docs/category/upstream-jobs",component:p("/docs/category/upstream-jobs","afa"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli",component:p("/docs/cli","52c"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/build",component:p("/docs/cli/build","a28"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/build/in-copr",component:p("/docs/cli/build/in-copr","9b6"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/build/in-image-builder",component:p("/docs/cli/build/in-image-builder","cd6"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/build/in-koji",component:p("/docs/cli/build/in-koji","48f"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/build/in-mock",component:p("/docs/cli/build/in-mock","23a"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/build/locally",component:p("/docs/cli/build/locally","33d"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/create-update",component:p("/docs/cli/create-update","e84"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/dist-git/init",component:p("/docs/cli/dist-git/init","104"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/init",component:p("/docs/cli/init","ec0"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/prepare-sources",component:p("/docs/cli/prepare-sources","4d7"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/propose-downstream",component:p("/docs/cli/propose-downstream","7c9"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/pull-from-upstream",component:p("/docs/cli/pull-from-upstream","64b"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/push-updates",component:p("/docs/cli/push-updates","fe6"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/scan-in-osh",component:p("/docs/cli/scan-in-osh","98b"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/source-git/init",component:p("/docs/cli/source-git/init","fbf"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/source-git/status",component:p("/docs/cli/source-git/status","447"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/source-git/update-dist-git",component:p("/docs/cli/source-git/update-dist-git","54a"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/source-git/update-source-git",component:p("/docs/cli/source-git/update-source-git","715"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/srpm",component:p("/docs/cli/srpm","708"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/status",component:p("/docs/cli/status","c40"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/sync-from-downstream",component:p("/docs/cli/sync-from-downstream","135"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cli/validate-config",component:p("/docs/cli/validate-config","5e9"),exact:!0,sidebar:"autogenerated"},{path:"/docs/configuration",component:p("/docs/configuration","399"),exact:!0,sidebar:"autogenerated"},{path:"/docs/configuration/actions",component:p("/docs/configuration/actions","fba"),exact:!0,sidebar:"autogenerated"},{path:"/docs/configuration/downstream_configuration_template",component:p("/docs/configuration/downstream_configuration_template","664"),exact:!0,sidebar:"autogenerated"},{path:"/docs/configuration/downstream/bodhi_update",component:p("/docs/configuration/downstream/bodhi_update","3c9"),exact:!0,sidebar:"autogenerated"},{path:"/docs/configuration/downstream/koji_build",component:p("/docs/configuration/downstream/koji_build","2e5"),exact:!0,sidebar:"autogenerated"},{path:"/docs/configuration/downstream/pull_from_upstream",component:p("/docs/configuration/downstream/pull_from_upstream","6af"),exact:!0,sidebar:"autogenerated"},{path:"/docs/configuration/examples",component:p("/docs/configuration/examples","801"),exact:!0,sidebar:"autogenerated"},{path:"/docs/configuration/jobs",component:p("/docs/configuration/jobs","439"),exact:!0,sidebar:"autogenerated"},{path:"/docs/configuration/upstream/copr_build",component:p("/docs/configuration/upstream/copr_build","a9e"),exact:!0,sidebar:"autogenerated"},{path:"/docs/configuration/upstream/propose_downstream",component:p("/docs/configuration/upstream/propose_downstream","778"),exact:!0,sidebar:"autogenerated"},{path:"/docs/configuration/upstream/tests",component:p("/docs/configuration/upstream/tests","9a7"),exact:!0,sidebar:"autogenerated"},{path:"/docs/configuration/upstream/upstream_koji_build",component:p("/docs/configuration/upstream/upstream_koji_build","5b2"),exact:!0,sidebar:"autogenerated"},{path:"/docs/configuration/upstream/vm_image_build",component:p("/docs/configuration/upstream/vm_image_build","bb3"),exact:!0,sidebar:"autogenerated"},{path:"/docs/cross-project-testing",component:p("/docs/cross-project-testing","422"),exact:!0,sidebar:"autogenerated"},{path:"/docs/faq",component:p("/docs/faq","aa9"),exact:!0,sidebar:"autogenerated"},{path:"/docs/fedora-releases-guide",component:p("/docs/fedora-releases-guide","3e5"),exact:!0,sidebar:"autogenerated"},{path:"/docs/fedora-releases-guide/dist-git-onboarding",component:p("/docs/fedora-releases-guide/dist-git-onboarding","bca"),exact:!0,sidebar:"autogenerated"},{path:"/docs/fedora-releases-guide/fedora-notifications",component:p("/docs/fedora-releases-guide/fedora-notifications","cbc"),exact:!0,sidebar:"autogenerated"},{path:"/docs/fedora-releases-guide/non-divergent-dist-git-branches",component:p("/docs/fedora-releases-guide/non-divergent-dist-git-branches","97c"),exact:!0,sidebar:"autogenerated"},{path:"/docs/fedora-releases-guide/releasing-multiple-packages",component:p("/docs/fedora-releases-guide/releasing-multiple-packages","b75"),exact:!0,sidebar:"autogenerated"},{path:"/docs/guide",component:p("/docs/guide","647"),exact:!0,sidebar:"autogenerated"},{path:"/docs/pre-releases",component:p("/docs/pre-releases","da8"),exact:!0,sidebar:"autogenerated"},{path:"/docs/reproduce-locally",component:p("/docs/reproduce-locally","58c"),exact:!0,sidebar:"autogenerated"},{path:"/docs/service-level-objectives",component:p("/docs/service-level-objectives","086"),exact:!0,sidebar:"autogenerated"},{path:"/docs/workshops-materials",component:p("/docs/workshops-materials","b17"),exact:!0,sidebar:"autogenerated"}]},{path:"/research",component:p("/research","5b4"),routes:[{path:"/research",component:p("/research","0a8"),exact:!0,sidebar:"autogenerated"},{path:"/research/automation-tools",component:p("/research/automation-tools","15b"),exact:!0,sidebar:"autogenerated"},{path:"/research/automation-tools/dlrn",component:p("/research/automation-tools/dlrn","5be"),exact:!0,sidebar:"autogenerated"},{path:"/research/automation-tools/rdopkg",component:p("/research/automation-tools/rdopkg","436"),exact:!0,sidebar:"autogenerated"},{path:"/research/automation-tools/rpkg",component:p("/research/automation-tools/rpkg","221"),exact:!0,sidebar:"autogenerated"},{path:"/research/automation-tools/rpkg-util",component:p("/research/automation-tools/rpkg-util","fa6"),exact:!0,sidebar:"autogenerated"},{path:"/research/automation-tools/tito",component:p("/research/automation-tools/tito","15c"),exact:!0,sidebar:"autogenerated"},{path:"/research/category/automation-of-internal-processes",component:p("/research/category/automation-of-internal-processes","ce2"),exact:!0,sidebar:"autogenerated"},{path:"/research/category/celery",component:p("/research/category/celery","70f"),exact:!0,sidebar:"autogenerated"},{path:"/research/category/database",component:p("/research/category/database","bc2"),exact:!0,sidebar:"autogenerated"},{path:"/research/category/deployment",component:p("/research/category/deployment","cf2"),exact:!0,sidebar:"autogenerated"},{path:"/research/category/integrations",component:p("/research/category/integrations","832"),exact:!0,sidebar:"autogenerated"},{path:"/research/category/specfiles",component:p("/research/category/specfiles","080"),exact:!0,sidebar:"autogenerated"},{path:"/research/category/testing",component:p("/research/category/testing","1c6"),exact:!0,sidebar:"autogenerated"},{path:"/research/category/user-experience",component:p("/research/category/user-experience","e80"),exact:!0,sidebar:"autogenerated"},{path:"/research/category/user-interface",component:p("/research/category/user-interface","66e"),exact:!0,sidebar:"autogenerated"},{path:"/research/celery/task-workflow-refactor",component:p("/research/celery/task-workflow-refactor","5fe"),exact:!0,sidebar:"autogenerated"},{path:"/research/celery/tasks-prioritizing",component:p("/research/celery/tasks-prioritizing","dab"),exact:!0,sidebar:"autogenerated"},{path:"/research/database/composite-types",component:p("/research/database/composite-types","638"),exact:!0,sidebar:"autogenerated"},{path:"/research/database/data-stores",component:p("/research/database/data-stores","1ce"),exact:!0,sidebar:"autogenerated"},{path:"/research/database/postgres-views",component:p("/research/database/postgres-views","cb4"),exact:!0,sidebar:"autogenerated"},{path:"/research/database/refactoring_project_events_and_commit_sha",component:p("/research/database/refactoring_project_events_and_commit_sha","0c2"),exact:!0,sidebar:"autogenerated"},{path:"/research/database/refresh",component:p("/research/database/refresh","b0d"),exact:!0,sidebar:"autogenerated"},{path:"/research/database/whats-in-production-database",component:p("/research/database/whats-in-production-database","f9c"),exact:!0,sidebar:"autogenerated"},{path:"/research/deployment/automation-for-stable-branches",component:p("/research/deployment/automation-for-stable-branches","951"),exact:!0,sidebar:"autogenerated"},{path:"/research/deployment/automotive-rosa",component:p("/research/deployment/automotive-rosa","756"),exact:!0,sidebar:"autogenerated"},{path:"/research/deployment/deploy-packit-pr",component:p("/research/deployment/deploy-packit-pr","1c8"),exact:!0,sidebar:"autogenerated"},{path:"/research/deployment/deployment-improvements",component:p("/research/deployment/deployment-improvements","baa"),exact:!0,sidebar:"autogenerated"},{path:"/research/deployment/distributed-workers",component:p("/research/deployment/distributed-workers","235"),exact:!0,sidebar:"autogenerated"},{path:"/research/deployment/distributed-workers/AWS-SQS-RDS",component:p("/research/deployment/distributed-workers/AWS-SQS-RDS","e84"),exact:!0,sidebar:"autogenerated"},{path:"/research/deployment/verification",component:p("/research/deployment/verification","eb0"),exact:!0,sidebar:"autogenerated"},{path:"/research/deployment/workers-scaling",component:p("/research/deployment/workers-scaling","832"),exact:!0,sidebar:"autogenerated"},{path:"/research/deprecation",component:p("/research/deprecation","9d3"),exact:!0,sidebar:"autogenerated"},{path:"/research/fedora-packages-onboarding",component:p("/research/fedora-packages-onboarding","43d"),exact:!0,sidebar:"autogenerated"},{path:"/research/git-notes",component:p("/research/git-notes","fe9"),exact:!0,sidebar:"autogenerated"},{path:"/research/integrations/building-srpm-in-copr",component:p("/research/integrations/building-srpm-in-copr","1e9"),exact:!0,sidebar:"autogenerated"},{path:"/research/integrations/building-srpm-in-copr/september-2022",component:p("/research/integrations/building-srpm-in-copr/september-2022","35b"),exact:!0,sidebar:"autogenerated"},{path:"/research/integrations/console",component:p("/research/integrations/console","2f8"),exact:!0,sidebar:"autogenerated"},{path:"/research/integrations/downstream",component:p("/research/integrations/downstream","bdb"),exact:!0,sidebar:"autogenerated"},{path:"/research/integrations/fedora-ci",component:p("/research/integrations/fedora-ci","7e3"),exact:!0,sidebar:"autogenerated"},{path:"/research/integrations/gitlab",component:p("/research/integrations/gitlab","bb6"),exact:!0,sidebar:"autogenerated"},{path:"/research/integrations/image-builder",component:p("/research/integrations/image-builder","4d2"),exact:!0,sidebar:"autogenerated"},{path:"/research/internal-automation/cert-management",component:p("/research/internal-automation/cert-management","2b5"),exact:!0,sidebar:"autogenerated"},{path:"/research/internal-automation/onboard",component:p("/research/internal-automation/onboard","b6c"),exact:!0,sidebar:"autogenerated"},{path:"/research/internal-automation/onboard/status",component:p("/research/internal-automation/onboard/status","3c5"),exact:!0,sidebar:"autogenerated"},{path:"/research/internal-automation/sync2jira",component:p("/research/internal-automation/sync2jira","59f"),exact:!0,sidebar:"autogenerated"},{path:"/research/job_referencing",component:p("/research/job_referencing","f71"),exact:!0,sidebar:"autogenerated"},{path:"/research/making-decisions",component:p("/research/making-decisions","ef6"),exact:!0,sidebar:"autogenerated"},{path:"/research/monitoring",component:p("/research/monitoring","a55"),exact:!0,sidebar:"autogenerated"},{path:"/research/monitoring/adoption-metrics",component:p("/research/monitoring/adoption-metrics","8ba"),exact:!0,sidebar:"autogenerated"},{path:"/research/monitoring/adoption-metrics/define-adoption-metrics",component:p("/research/monitoring/adoption-metrics/define-adoption-metrics","0a8"),exact:!0,sidebar:"autogenerated"},{path:"/research/monitoring/adoption-metrics/implementation",component:p("/research/monitoring/adoption-metrics/implementation","d5e"),exact:!0,sidebar:"autogenerated"},{path:"/research/monitoring/error-budgets",component:p("/research/monitoring/error-budgets","326"),exact:!0,sidebar:"autogenerated"},{path:"/research/monitoring/error-budgets/SLOs-SLIs",component:p("/research/monitoring/error-budgets/SLOs-SLIs","34b"),exact:!0,sidebar:"autogenerated"},{path:"/research/monitoring/error-budgets/users-expectations",component:p("/research/monitoring/error-budgets/users-expectations","5f0"),exact:!0,sidebar:"autogenerated"},{path:"/research/monitoring/github-api-call-inventory",component:p("/research/monitoring/github-api-call-inventory","0f3"),exact:!0,sidebar:"autogenerated"},{path:"/research/monitoring/logs-aggregation",component:p("/research/monitoring/logs-aggregation","83b"),exact:!0,sidebar:"autogenerated"},{path:"/research/monitoring/metrics",component:p("/research/monitoring/metrics","af4"),exact:!0,sidebar:"autogenerated"},{path:"/research/monorepo-support",component:p("/research/monorepo-support","0ec"),exact:!0,sidebar:"autogenerated"},{path:"/research/monorepo-support/refactoring",component:p("/research/monorepo-support/refactoring","408"),exact:!0,sidebar:"autogenerated"},{path:"/research/outages",component:p("/research/outages","119"),exact:!0,sidebar:"autogenerated"},{path:"/research/outages/reporting",component:p("/research/outages/reporting","b14"),exact:!0,sidebar:"autogenerated"},{path:"/research/source-git",component:p("/research/source-git","d03"),exact:!0,sidebar:"autogenerated"},{path:"/research/source-git/customize-update-dist-git",component:p("/research/source-git/customize-update-dist-git","96b"),exact:!0,sidebar:"autogenerated"},{path:"/research/source-git/dist-git-to-src-git",component:p("/research/source-git/dist-git-to-src-git","bae"),exact:!0,sidebar:"autogenerated"},{path:"/research/source-git/dist-git-to-src-git/updates",component:p("/research/source-git/dist-git-to-src-git/updates","8be"),exact:!0,sidebar:"autogenerated"},{path:"/research/source-git/fedora-spec-files",component:p("/research/source-git/fedora-spec-files","cd7"),exact:!0,sidebar:"autogenerated"},{path:"/research/source-git/in-zuul",component:p("/research/source-git/in-zuul","0ad"),exact:!0,sidebar:"autogenerated"},{path:"/research/source-git/on-pagure",component:p("/research/source-git/on-pagure","11a"),exact:!0,sidebar:"autogenerated"},{path:"/research/source-git/split-the-stream",component:p("/research/source-git/split-the-stream","7b0"),exact:!0,sidebar:"autogenerated"},{path:"/research/source-git/sync-status",component:p("/research/source-git/sync-status","7c2"),exact:!0,sidebar:"autogenerated"},{path:"/research/source-git/update",component:p("/research/source-git/update","01b"),exact:!0,sidebar:"autogenerated"},{path:"/research/specfiles/hosting-sources",component:p("/research/specfiles/hosting-sources","0f0"),exact:!0,sidebar:"autogenerated"},{path:"/research/specfiles/library-requirements",component:p("/research/specfiles/library-requirements","2b9"),exact:!0,sidebar:"autogenerated"},{path:"/research/specfiles/packages-with-patches",component:p("/research/specfiles/packages-with-patches","ac7"),exact:!0,sidebar:"autogenerated"},{path:"/research/testing/external-testing",component:p("/research/testing/external-testing","eb2"),exact:!0,sidebar:"autogenerated"},{path:"/research/testing/openshift-to-podman-kube-play",component:p("/research/testing/openshift-to-podman-kube-play","aab"),exact:!0,sidebar:"autogenerated"},{path:"/research/testing/openshift-zuul-test-alternatives",component:p("/research/testing/openshift-zuul-test-alternatives","11e"),exact:!0,sidebar:"autogenerated"},{path:"/research/testing/zuul",component:p("/research/testing/zuul","5ec"),exact:!0,sidebar:"autogenerated"},{path:"/research/ui/dashboard",component:p("/research/ui/dashboard","99a"),exact:!0,sidebar:"autogenerated"},{path:"/research/ui/dashboard/dashboard-improvements",component:p("/research/ui/dashboard/dashboard-improvements","257"),exact:!0,sidebar:"autogenerated"},{path:"/research/ui/dashboard/oauth",component:p("/research/ui/dashboard/oauth","de4"),exact:!0,sidebar:"autogenerated"},{path:"/research/ui/website-improvements",component:p("/research/ui/website-improvements","492"),exact:!0,sidebar:"autogenerated"},{path:"/research/user-stories",component:p("/research/user-stories","998"),exact:!0,sidebar:"autogenerated"},{path:"/research/user-stories/python_project_from_scratch",component:p("/research/user-stories/python_project_from_scratch","1d0"),exact:!0,sidebar:"autogenerated"},{path:"/research/user-stories/summit-demo",component:p("/research/user-stories/summit-demo","ec7"),exact:!0,sidebar:"autogenerated"},{path:"/research/user-stories/tests-builds-from-more-prs",component:p("/research/user-stories/tests-builds-from-more-prs","125"),exact:!0,sidebar:"autogenerated"},{path:"/research/ux/automatic-config-updates",component:p("/research/ux/automatic-config-updates","491"),exact:!0,sidebar:"autogenerated"},{path:"/research/ux/configuration-versioning",component:p("/research/ux/configuration-versioning","211"),exact:!0,sidebar:"autogenerated"},{path:"/research/ux/improve-service-processing",component:p("/research/ux/improve-service-processing","361"),exact:!0,sidebar:"autogenerated"},{path:"/research/workflow-engines",component:p("/research/workflow-engines","fb7"),exact:!0,sidebar:"autogenerated"},{path:"/research/workflow-engines/airflow",component:p("/research/workflow-engines/airflow","00a"),exact:!0,sidebar:"autogenerated"},{path:"/research/workflow-engines/argo-workflows",component:p("/research/workflow-engines/argo-workflows","3a0"),exact:!0,sidebar:"autogenerated"},{path:"/research/workflow-engines/celery-canvas",component:p("/research/workflow-engines/celery-canvas","59d"),exact:!0,sidebar:"autogenerated"},{path:"/research/workflow-engines/prefect",component:p("/research/workflow-engines/prefect","962"),exact:!0,sidebar:"autogenerated"},{path:"/research/workflow-engines/selinon",component:p("/research/workflow-engines/selinon","e59"),exact:!0,sidebar:"autogenerated"},{path:"/research/workflow-engines/temporal",component:p("/research/workflow-engines/temporal","193"),exact:!0,sidebar:"autogenerated"}]},{path:"/source-git",component:p("/source-git","96c"),routes:[{path:"/source-git",component:p("/source-git","baa"),exact:!0,sidebar:"autogenerated"},{path:"/source-git/design",component:p("/source-git/design","4f6"),exact:!0,sidebar:"autogenerated"},{path:"/source-git/shutdown",component:p("/source-git/shutdown","fee"),exact:!0,sidebar:"autogenerated"},{path:"/source-git/status",component:p("/source-git/status","aa6"),exact:!0,sidebar:"autogenerated"},{path:"/source-git/work-with-source-git",component:p("/source-git/work-with-source-git","ce0"),exact:!0,sidebar:"autogenerated"},{path:"/source-git/work-with-source-git/build-locally",component:p("/source-git/work-with-source-git/build-locally","765"),exact:!0,sidebar:"autogenerated"},{path:"/source-git/work-with-source-git/control-patch-generation",component:p("/source-git/work-with-source-git/control-patch-generation","330"),exact:!0,sidebar:"autogenerated"},{path:"/source-git/work-with-source-git/create-source-git",component:p("/source-git/work-with-source-git/create-source-git","561"),exact:!0,sidebar:"autogenerated"},{path:"/source-git/work-with-source-git/fix-diverged-history",component:p("/source-git/work-with-source-git/fix-diverged-history","adc"),exact:!0,sidebar:"autogenerated"},{path:"/source-git/work-with-source-git/propose-to-dist-git",component:p("/source-git/work-with-source-git/propose-to-dist-git","462"),exact:!0,sidebar:"autogenerated"},{path:"/source-git/work-with-source-git/pull-upstream-fixes",component:p("/source-git/work-with-source-git/pull-upstream-fixes","9f7"),exact:!0,sidebar:"autogenerated"},{path:"/source-git/work-with-source-git/sync-from-dist-git",component:p("/source-git/work-with-source-git/sync-from-dist-git","fab"),exact:!0,sidebar:"autogenerated"},{path:"/source-git/work-with-source-git/update-spec",component:p("/source-git/work-with-source-git/update-spec","044"),exact:!0,sidebar:"autogenerated"}]},{path:"/specfile",component:p("/specfile","206"),routes:[{path:"/specfile",component:p("/specfile","c72"),exact:!0,sidebar:"autogenerated"},{path:"/specfile/api/specfile",component:p("/specfile/api/specfile","9b2"),exact:!0,sidebar:"autogenerated"},{path:"/specfile/api/specfile/changelog",component:p("/specfile/api/specfile/changelog","c46"),exact:!0,sidebar:"autogenerated"},{path:"/specfile/api/specfile/conditions",component:p("/specfile/api/specfile/conditions","1ed"),exact:!0,sidebar:"autogenerated"},{path:"/specfile/api/specfile/context_management",component:p("/specfile/api/specfile/context_management","83f"),exact:!0,sidebar:"autogenerated"},{path:"/specfile/api/specfile/exceptions",component:p("/specfile/api/specfile/exceptions","57a"),exact:!0,sidebar:"autogenerated"},{path:"/specfile/api/specfile/formatter",component:p("/specfile/api/specfile/formatter","b78"),exact:!0,sidebar:"autogenerated"},{path:"/specfile/api/specfile/macro_definitions",component:p("/specfile/api/specfile/macro_definitions","147"),exact:!0,sidebar:"autogenerated"},{path:"/specfile/api/specfile/macros",component:p("/specfile/api/specfile/macros","9f7"),exact:!0,sidebar:"autogenerated"},{path:"/specfile/api/specfile/options",component:p("/specfile/api/specfile/options","8ea"),exact:!0,sidebar:"autogenerated"},{path:"/specfile/api/specfile/prep",component:p("/specfile/api/specfile/prep","b38"),exact:!0,sidebar:"autogenerated"},{path:"/specfile/api/specfile/sections",component:p("/specfile/api/specfile/sections","310"),exact:!0,sidebar:"autogenerated"},{path:"/specfile/api/specfile/sourcelist",component:p("/specfile/api/specfile/sourcelist","322"),exact:!0,sidebar:"autogenerated"},{path:"/specfile/api/specfile/sources",component:p("/specfile/api/specfile/sources","89e"),exact:!0,sidebar:"autogenerated"},{path:"/specfile/api/specfile/spec_parser",component:p("/specfile/api/specfile/spec_parser","7d3"),exact:!0,sidebar:"autogenerated"},{path:"/specfile/api/specfile/tags",component:p("/specfile/api/specfile/tags","8d1"),exact:!0,sidebar:"autogenerated"},{path:"/specfile/api/specfile/utils",component:p("/specfile/api/specfile/utils","e5e"),exact:!0,sidebar:"autogenerated"},{path:"/specfile/api/specfile/value_parser",component:p("/specfile/api/specfile/value_parser","eb3"),exact:!0,sidebar:"autogenerated"}]},{path:"/",component:p("/","6cd"),exact:!0},{path:"*",component:p("*")}]},98934:(e,t,n)=>{"use strict";n.d(t,{_:()=>r,t:()=>o});var a=n(67294);const r=a.createContext(!1);function o(e){let{children:t}=e;const[n,o]=(0,a.useState)(!1);return(0,a.useEffect)((()=>{o(!0)}),[]),a.createElement(r.Provider,{value:n},t)}},49383:(e,t,n)=>{"use strict";var a=n(67294),r=n(73935),o=n(73727),i=n(70405),s=n(10412);const c=[n(32497),n(3310),n(18320),n(52295)];var l=n(723),u=n(16550),d=n(18790);function p(e){let{children:t}=e;return a.createElement(a.Fragment,null,t)}var f=n(87462),m=n(35742),g=n(52263),h=n(44996),b=n(86668),y=n(10833),w=n(94711),v=n(19727),k=n(43320),_=n(90197);function x(){const{i18n:{defaultLocale:e,localeConfigs:t}}=(0,g.Z)(),n=(0,w.l)();return a.createElement(m.Z,null,Object.entries(t).map((e=>{let[t,{htmlLang:r}]=e;return a.createElement("link",{key:t,rel:"alternate",href:n.createUrl({locale:t,fullyQualified:!0}),hrefLang:r})})),a.createElement("link",{rel:"alternate",href:n.createUrl({locale:e,fullyQualified:!0}),hrefLang:"x-default"}))}function E(e){let{permalink:t}=e;const{siteConfig:{url:n}}=(0,g.Z)(),r=function(){const{siteConfig:{url:e}}=(0,g.Z)(),{pathname:t}=(0,u.TH)();return e+(0,h.Z)(t)}(),o=t?`${n}${t}`:r;return a.createElement(m.Z,null,a.createElement("meta",{property:"og:url",content:o}),a.createElement("link",{rel:"canonical",href:o}))}function S(){const{i18n:{currentLocale:e}}=(0,g.Z)(),{metadata:t,image:n}=(0,b.L)();return a.createElement(a.Fragment,null,a.createElement(m.Z,null,a.createElement("meta",{name:"twitter:card",content:"summary_large_image"}),a.createElement("body",{className:v.h})),n&&a.createElement(y.d,{image:n}),a.createElement(E,null),a.createElement(x,null),a.createElement(_.Z,{tag:k.HX,locale:e}),a.createElement(m.Z,null,t.map(((e,t)=>a.createElement("meta",(0,f.Z)({key:t},e))))))}const C=new Map;function T(e){if(C.has(e.pathname))return{...e,pathname:C.get(e.pathname)};if((0,d.f)(l.Z,e.pathname).some((e=>{let{route:t}=e;return!0===t.exact})))return C.set(e.pathname,e.pathname),e;const t=e.pathname.trim().replace(/(?:\/index)?\.html$/,"")||"/";return C.set(e.pathname,t),{...e,pathname:t}}var A=n(98934),L=n(58940);function P(e){for(var t=arguments.length,n=new Array(t>1?t-1:0),a=1;a{const a=t.default?.[e]??t[e];return a?.(...n)}));return()=>r.forEach((e=>e?.()))}const R=function(e){let{children:t,location:n,previousLocation:r}=e;return(0,a.useLayoutEffect)((()=>{r!==n&&(!function(e){let{location:t,previousLocation:n}=e;if(!n)return;const a=t.pathname===n.pathname,r=t.hash===n.hash,o=t.search===n.search;if(a&&r&&!o)return;const{hash:i}=t;if(i){const e=decodeURIComponent(i.substring(1)),t=document.getElementById(e);t?.scrollIntoView()}else window.scrollTo(0,0)}({location:n,previousLocation:r}),P("onRouteDidUpdate",{previousLocation:r,location:n}))}),[r,n]),t};function j(e){const t=Array.from(new Set([e,decodeURI(e)])).map((e=>(0,d.f)(l.Z,e))).flat();return Promise.all(t.map((e=>e.route.component.preload?.())))}class N extends a.Component{previousLocation;routeUpdateCleanupCb;constructor(e){super(e),this.previousLocation=null,this.routeUpdateCleanupCb=s.Z.canUseDOM?P("onRouteUpdate",{previousLocation:null,location:this.props.location}):()=>{},this.state={nextRouteHasLoaded:!0}}shouldComponentUpdate(e,t){if(e.location===this.props.location)return t.nextRouteHasLoaded;const n=e.location;return this.previousLocation=this.props.location,this.setState({nextRouteHasLoaded:!1}),this.routeUpdateCleanupCb=P("onRouteUpdate",{previousLocation:this.previousLocation,location:n}),j(n.pathname).then((()=>{this.routeUpdateCleanupCb(),this.setState({nextRouteHasLoaded:!0})})).catch((e=>{console.warn(e),window.location.reload()})),!1}render(){const{children:e,location:t}=this.props;return a.createElement(R,{previousLocation:this.previousLocation,location:t},a.createElement(u.AW,{location:t,render:()=>e}))}}const O=N,I="__docusaurus-base-url-issue-banner-container",M="__docusaurus-base-url-issue-banner",D="__docusaurus-base-url-issue-banner-suggestion-container",B="__DOCUSAURUS_INSERT_BASEURL_BANNER";function F(e){return`\nwindow['${B}'] = true;\n\ndocument.addEventListener('DOMContentLoaded', maybeInsertBanner);\n\nfunction maybeInsertBanner() {\n var shouldInsert = window['${B}'];\n shouldInsert && insertBanner();\n}\n\nfunction insertBanner() {\n var bannerContainer = document.getElementById('${I}');\n if (!bannerContainer) {\n return;\n }\n var bannerHtml = ${JSON.stringify(function(e){return`\n
\n

Your Docusaurus site did not load properly.

\n

A very common reason is a wrong site baseUrl configuration.

\n

Current configured baseUrl = ${e} ${"/"===e?" (default value)":""}

\n

We suggest trying baseUrl =

\n
\n`}(e)).replace(/{window[B]=!1}),[]),a.createElement(a.Fragment,null,!s.Z.canUseDOM&&a.createElement(m.Z,null,a.createElement("script",null,F(e))),a.createElement("div",{id:I}))}function U(){const{siteConfig:{baseUrl:e,baseUrlIssueBanner:t}}=(0,g.Z)(),{pathname:n}=(0,u.TH)();return t&&n===e?a.createElement(z,null):null}function $(){const{siteConfig:{favicon:e,title:t,noIndex:n},i18n:{currentLocale:r,localeConfigs:o}}=(0,g.Z)(),i=(0,h.Z)(e),{htmlLang:s,direction:c}=o[r];return a.createElement(m.Z,null,a.createElement("html",{lang:s,dir:c}),a.createElement("title",null,t),a.createElement("meta",{property:"og:title",content:t}),a.createElement("meta",{name:"viewport",content:"width=device-width, initial-scale=1.0"}),n&&a.createElement("meta",{name:"robots",content:"noindex, nofollow"}),e&&a.createElement("link",{rel:"icon",href:i}))}var q=n(44763);function G(){const e=(0,d.H)(l.Z),t=(0,u.TH)();return a.createElement(q.Z,null,a.createElement(L.M,null,a.createElement(A.t,null,a.createElement(p,null,a.createElement($,null),a.createElement(S,null),a.createElement(U,null),a.createElement(O,{location:T(t)},e)))))}var H=n(16887);const Z=function(e){try{return document.createElement("link").relList.supports(e)}catch{return!1}}("prefetch")?function(e){return new Promise(((t,n)=>{if("undefined"==typeof document)return void n();const a=document.createElement("link");a.setAttribute("rel","prefetch"),a.setAttribute("href",e),a.onload=()=>t(),a.onerror=()=>n();const r=document.getElementsByTagName("head")[0]??document.getElementsByName("script")[0]?.parentNode;r?.appendChild(a)}))}:function(e){return new Promise(((t,n)=>{const a=new XMLHttpRequest;a.open("GET",e,!0),a.withCredentials=!0,a.onload=()=>{200===a.status?t():n()},a.send(null)}))};var V=n(99670);const W=new Set,K=new Set,Y=()=>navigator.connection?.effectiveType.includes("2g")||navigator.connection?.saveData,Q={prefetch(e){if(!(e=>!Y()&&!K.has(e)&&!W.has(e))(e))return!1;W.add(e);const t=(0,d.f)(l.Z,e).flatMap((e=>{return t=e.route.path,Object.entries(H).filter((e=>{let[n]=e;return n.replace(/-[^-]+$/,"")===t})).flatMap((e=>{let[,t]=e;return Object.values((0,V.Z)(t))}));var t}));return Promise.all(t.map((e=>{const t=n.gca(e);return t&&!t.includes("undefined")?Z(t).catch((()=>{})):Promise.resolve()})))},preload:e=>!!(e=>!Y()&&!K.has(e))(e)&&(K.add(e),j(e))},X=Object.freeze(Q);if(s.Z.canUseDOM){window.docusaurus=X;const e=r.hydrate;j(window.location.pathname).then((()=>{e(a.createElement(i.B6,null,a.createElement(o.VK,null,a.createElement(G,null))),document.getElementById("__docusaurus"))}))}},58940:(e,t,n)=>{"use strict";n.d(t,{_:()=>u,M:()=>d});var a=n(67294),r=n(36809);const o=JSON.parse('{"docusaurus-plugin-content-docs":{"deployment":{"path":"/deployment","versions":[{"name":"current","label":"Next","isLast":true,"path":"/deployment","mainDocId":"index","docs":[{"id":"continuous-deployment","path":"/deployment/continuous-deployment","sidebar":"autogenerated"},{"id":"images","path":"/deployment/images","sidebar":"autogenerated"},{"id":"index","path":"/deployment/","sidebar":"autogenerated"},{"id":"internal_tf","path":"/deployment/internal_tf","sidebar":"autogenerated"},{"id":"monitoring/index","path":"/deployment/monitoring/","sidebar":"autogenerated"},{"id":"monitoring/logs","path":"/deployment/monitoring/logs","sidebar":"autogenerated"},{"id":"openshift_local_cluster","path":"/deployment/openshift_local_cluster","sidebar":"autogenerated"},{"id":"postgresql","path":"/deployment/postgresql","sidebar":"autogenerated"},{"id":"resource-requirements","path":"/deployment/resource-requirements","sidebar":"autogenerated"},{"id":"scripts","path":"/deployment/scripts","sidebar":"autogenerated"},{"id":"secrets","path":"/deployment/secrets","sidebar":"autogenerated"},{"id":"specifics/centos-stream-source-git","path":"/deployment/specifics/centos-stream-source-git","sidebar":"autogenerated"},{"id":"specifics/clusters","path":"/deployment/specifics/clusters","sidebar":"autogenerated"},{"id":"specifics/fedora-source-git","path":"/deployment/specifics/fedora-source-git","sidebar":"autogenerated"},{"id":"specifics/packit-service","path":"/deployment/specifics/packit-service","sidebar":"autogenerated"},{"id":"specifics/redict","path":"/deployment/specifics/redict","sidebar":"autogenerated"},{"id":"testing-changes","path":"/deployment/testing-changes","sidebar":"autogenerated"},{"id":"tls-certs","path":"/deployment/tls-certs","sidebar":"autogenerated"},{"id":"vars","path":"/deployment/vars","sidebar":"autogenerated"},{"id":"/category/deployment-specifics","path":"/deployment/category/deployment-specifics","sidebar":"autogenerated"}],"draftIds":[],"sidebars":{"autogenerated":{"link":{"path":"/deployment/","label":"index"}}}}],"breadcrumbs":true},"agile":{"path":"/agile","versions":[{"name":"current","label":"Next","isLast":true,"path":"/agile","mainDocId":"index","docs":[{"id":"index","path":"/agile/","sidebar":"autogenerated"},{"id":"kanban","path":"/agile/kanban","sidebar":"autogenerated"},{"id":"meetings","path":"/agile/meetings","sidebar":"autogenerated"},{"id":"roles","path":"/agile/roles","sidebar":"autogenerated"},{"id":"weekly-roles/index","path":"/agile/weekly-roles/","sidebar":"autogenerated"}],"draftIds":[],"sidebars":{"autogenerated":{"link":{"path":"/agile/","label":"index"}}}}],"breadcrumbs":true},"source-git":{"path":"/source-git","versions":[{"name":"current","label":"Next","isLast":true,"path":"/source-git","mainDocId":"index","docs":[{"id":"design","path":"/source-git/design","sidebar":"autogenerated"},{"id":"index","path":"/source-git/","sidebar":"autogenerated"},{"id":"shutdown","path":"/source-git/shutdown","sidebar":"autogenerated"},{"id":"status","path":"/source-git/status","sidebar":"autogenerated"},{"id":"work-with-source-git/build-locally","path":"/source-git/work-with-source-git/build-locally","sidebar":"autogenerated"},{"id":"work-with-source-git/control-patch-generation","path":"/source-git/work-with-source-git/control-patch-generation","sidebar":"autogenerated"},{"id":"work-with-source-git/create-source-git","path":"/source-git/work-with-source-git/create-source-git","sidebar":"autogenerated"},{"id":"work-with-source-git/fix-diverged-history","path":"/source-git/work-with-source-git/fix-diverged-history","sidebar":"autogenerated"},{"id":"work-with-source-git/index","path":"/source-git/work-with-source-git/","sidebar":"autogenerated"},{"id":"work-with-source-git/propose-to-dist-git","path":"/source-git/work-with-source-git/propose-to-dist-git","sidebar":"autogenerated"},{"id":"work-with-source-git/pull-upstream-fixes","path":"/source-git/work-with-source-git/pull-upstream-fixes","sidebar":"autogenerated"},{"id":"work-with-source-git/sync-from-dist-git","path":"/source-git/work-with-source-git/sync-from-dist-git","sidebar":"autogenerated"},{"id":"work-with-source-git/update-spec","path":"/source-git/work-with-source-git/update-spec","sidebar":"autogenerated"}],"draftIds":[],"sidebars":{"autogenerated":{"link":{"path":"/source-git/","label":"index"}}}}],"breadcrumbs":true},"research":{"path":"/research","versions":[{"name":"current","label":"Next","isLast":true,"path":"/research","mainDocId":"index","docs":[{"id":"automation-tools/dlrn","path":"/research/automation-tools/dlrn","sidebar":"autogenerated"},{"id":"automation-tools/index","path":"/research/automation-tools/","sidebar":"autogenerated"},{"id":"automation-tools/rdopkg","path":"/research/automation-tools/rdopkg","sidebar":"autogenerated"},{"id":"automation-tools/rpkg","path":"/research/automation-tools/rpkg","sidebar":"autogenerated"},{"id":"automation-tools/rpkg-util","path":"/research/automation-tools/rpkg-util","sidebar":"autogenerated"},{"id":"automation-tools/tito","path":"/research/automation-tools/tito","sidebar":"autogenerated"},{"id":"celery/task-workflow-refactor","path":"/research/celery/task-workflow-refactor","sidebar":"autogenerated"},{"id":"celery/tasks-prioritizing","path":"/research/celery/tasks-prioritizing","sidebar":"autogenerated"},{"id":"database/composite-types","path":"/research/database/composite-types","sidebar":"autogenerated"},{"id":"database/data-stores","path":"/research/database/data-stores","sidebar":"autogenerated"},{"id":"database/postgres-views/index","path":"/research/database/postgres-views/","sidebar":"autogenerated"},{"id":"database/refactoring_project_events_and_commit_sha","path":"/research/database/refactoring_project_events_and_commit_sha","sidebar":"autogenerated"},{"id":"database/refresh","path":"/research/database/refresh","sidebar":"autogenerated"},{"id":"database/whats-in-production-database","path":"/research/database/whats-in-production-database","sidebar":"autogenerated"},{"id":"deployment/automation-for-stable-branches","path":"/research/deployment/automation-for-stable-branches","sidebar":"autogenerated"},{"id":"deployment/automotive-rosa","path":"/research/deployment/automotive-rosa","sidebar":"autogenerated"},{"id":"deployment/deploy-packit-pr","path":"/research/deployment/deploy-packit-pr","sidebar":"autogenerated"},{"id":"deployment/deployment-improvements/index","path":"/research/deployment/deployment-improvements/","sidebar":"autogenerated"},{"id":"deployment/distributed-workers/AWS-SQS-RDS","path":"/research/deployment/distributed-workers/AWS-SQS-RDS","sidebar":"autogenerated"},{"id":"deployment/distributed-workers/index","path":"/research/deployment/distributed-workers/","sidebar":"autogenerated"},{"id":"deployment/verification","path":"/research/deployment/verification","sidebar":"autogenerated"},{"id":"deployment/workers-scaling","path":"/research/deployment/workers-scaling","sidebar":"autogenerated"},{"id":"deprecation/index","path":"/research/deprecation/","sidebar":"autogenerated"},{"id":"fedora-packages-onboarding/index","path":"/research/fedora-packages-onboarding/","sidebar":"autogenerated"},{"id":"git-notes/index","path":"/research/git-notes/","sidebar":"autogenerated"},{"id":"index","path":"/research/","sidebar":"autogenerated"},{"id":"integrations/building-srpm-in-copr/index","path":"/research/integrations/building-srpm-in-copr/","sidebar":"autogenerated"},{"id":"integrations/building-srpm-in-copr/september-2022","path":"/research/integrations/building-srpm-in-copr/september-2022","sidebar":"autogenerated"},{"id":"integrations/console","path":"/research/integrations/console","sidebar":"autogenerated"},{"id":"integrations/downstream/index","path":"/research/integrations/downstream/","sidebar":"autogenerated"},{"id":"integrations/fedora-ci/index","path":"/research/integrations/fedora-ci/","sidebar":"autogenerated"},{"id":"integrations/gitlab/index","path":"/research/integrations/gitlab/","sidebar":"autogenerated"},{"id":"integrations/image-builder/index","path":"/research/integrations/image-builder/","sidebar":"autogenerated"},{"id":"internal-automation/cert-management","path":"/research/internal-automation/cert-management","sidebar":"autogenerated"},{"id":"internal-automation/onboard/index","path":"/research/internal-automation/onboard/","sidebar":"autogenerated"},{"id":"internal-automation/onboard/status","path":"/research/internal-automation/onboard/status","sidebar":"autogenerated"},{"id":"internal-automation/sync2jira","path":"/research/internal-automation/sync2jira","sidebar":"autogenerated"},{"id":"job_referencing/index","path":"/research/job_referencing/","sidebar":"autogenerated"},{"id":"making-decisions/index","path":"/research/making-decisions/","sidebar":"autogenerated"},{"id":"monitoring/adoption-metrics/define-adoption-metrics","path":"/research/monitoring/adoption-metrics/define-adoption-metrics","sidebar":"autogenerated"},{"id":"monitoring/adoption-metrics/implementation","path":"/research/monitoring/adoption-metrics/implementation","sidebar":"autogenerated"},{"id":"monitoring/adoption-metrics/index","path":"/research/monitoring/adoption-metrics/","sidebar":"autogenerated"},{"id":"monitoring/error-budgets/index","path":"/research/monitoring/error-budgets/","sidebar":"autogenerated"},{"id":"monitoring/error-budgets/SLOs-SLIs","path":"/research/monitoring/error-budgets/SLOs-SLIs","sidebar":"autogenerated"},{"id":"monitoring/error-budgets/users-expectations","path":"/research/monitoring/error-budgets/users-expectations","sidebar":"autogenerated"},{"id":"monitoring/github-api-call-inventory/index","path":"/research/monitoring/github-api-call-inventory/","sidebar":"autogenerated"},{"id":"monitoring/index","path":"/research/monitoring/","sidebar":"autogenerated"},{"id":"monitoring/logs-aggregation/index","path":"/research/monitoring/logs-aggregation/","sidebar":"autogenerated"},{"id":"monitoring/metrics","path":"/research/monitoring/metrics","sidebar":"autogenerated"},{"id":"monorepo-support/index","path":"/research/monorepo-support/","sidebar":"autogenerated"},{"id":"monorepo-support/refactoring","path":"/research/monorepo-support/refactoring","sidebar":"autogenerated"},{"id":"outages/index","path":"/research/outages/","sidebar":"autogenerated"},{"id":"outages/reporting","path":"/research/outages/reporting","sidebar":"autogenerated"},{"id":"source-git/customize-update-dist-git","path":"/research/source-git/customize-update-dist-git","sidebar":"autogenerated"},{"id":"source-git/dist-git-to-src-git/index","path":"/research/source-git/dist-git-to-src-git/","sidebar":"autogenerated"},{"id":"source-git/dist-git-to-src-git/updates","path":"/research/source-git/dist-git-to-src-git/updates","sidebar":"autogenerated"},{"id":"source-git/fedora-spec-files/index","path":"/research/source-git/fedora-spec-files/","sidebar":"autogenerated"},{"id":"source-git/in-zuul","path":"/research/source-git/in-zuul","sidebar":"autogenerated"},{"id":"source-git/index","path":"/research/source-git/","sidebar":"autogenerated"},{"id":"source-git/on-pagure","path":"/research/source-git/on-pagure","sidebar":"autogenerated"},{"id":"source-git/split-the-stream","path":"/research/source-git/split-the-stream","sidebar":"autogenerated"},{"id":"source-git/sync-status","path":"/research/source-git/sync-status","sidebar":"autogenerated"},{"id":"source-git/update","path":"/research/source-git/update","sidebar":"autogenerated"},{"id":"specfiles/hosting-sources/index","path":"/research/specfiles/hosting-sources/","sidebar":"autogenerated"},{"id":"specfiles/library-requirements","path":"/research/specfiles/library-requirements","sidebar":"autogenerated"},{"id":"specfiles/packages-with-patches/index","path":"/research/specfiles/packages-with-patches/","sidebar":"autogenerated"},{"id":"testing/external-testing","path":"/research/testing/external-testing","sidebar":"autogenerated"},{"id":"testing/openshift-to-podman-kube-play","path":"/research/testing/openshift-to-podman-kube-play","sidebar":"autogenerated"},{"id":"testing/openshift-zuul-test-alternatives","path":"/research/testing/openshift-zuul-test-alternatives","sidebar":"autogenerated"},{"id":"testing/zuul","path":"/research/testing/zuul","sidebar":"autogenerated"},{"id":"ui/dashboard/dashboard-improvements","path":"/research/ui/dashboard/dashboard-improvements","sidebar":"autogenerated"},{"id":"ui/dashboard/index","path":"/research/ui/dashboard/","sidebar":"autogenerated"},{"id":"ui/dashboard/oauth","path":"/research/ui/dashboard/oauth","sidebar":"autogenerated"},{"id":"ui/website-improvements","path":"/research/ui/website-improvements","sidebar":"autogenerated"},{"id":"user-stories/index","path":"/research/user-stories/","sidebar":"autogenerated"},{"id":"user-stories/python_project_from_scratch","path":"/research/user-stories/python_project_from_scratch","sidebar":"autogenerated"},{"id":"user-stories/summit-demo","path":"/research/user-stories/summit-demo","sidebar":"autogenerated"},{"id":"user-stories/tests-builds-from-more-prs","path":"/research/user-stories/tests-builds-from-more-prs","sidebar":"autogenerated"},{"id":"ux/automatic-config-updates","path":"/research/ux/automatic-config-updates","sidebar":"autogenerated"},{"id":"ux/configuration-versioning","path":"/research/ux/configuration-versioning","sidebar":"autogenerated"},{"id":"ux/improve-service-processing","path":"/research/ux/improve-service-processing","sidebar":"autogenerated"},{"id":"workflow-engines/airflow","path":"/research/workflow-engines/airflow","sidebar":"autogenerated"},{"id":"workflow-engines/argo-workflows","path":"/research/workflow-engines/argo-workflows","sidebar":"autogenerated"},{"id":"workflow-engines/celery-canvas","path":"/research/workflow-engines/celery-canvas","sidebar":"autogenerated"},{"id":"workflow-engines/index","path":"/research/workflow-engines/","sidebar":"autogenerated"},{"id":"workflow-engines/prefect","path":"/research/workflow-engines/prefect","sidebar":"autogenerated"},{"id":"workflow-engines/selinon","path":"/research/workflow-engines/selinon","sidebar":"autogenerated"},{"id":"workflow-engines/temporal","path":"/research/workflow-engines/temporal","sidebar":"autogenerated"},{"id":"/category/celery","path":"/research/category/celery","sidebar":"autogenerated"},{"id":"/category/database","path":"/research/category/database","sidebar":"autogenerated"},{"id":"/category/deployment","path":"/research/category/deployment","sidebar":"autogenerated"},{"id":"/category/integrations","path":"/research/category/integrations","sidebar":"autogenerated"},{"id":"/category/automation-of-internal-processes","path":"/research/category/automation-of-internal-processes","sidebar":"autogenerated"},{"id":"/category/specfiles","path":"/research/category/specfiles","sidebar":"autogenerated"},{"id":"/category/testing","path":"/research/category/testing","sidebar":"autogenerated"},{"id":"/category/user-interface","path":"/research/category/user-interface","sidebar":"autogenerated"},{"id":"/category/user-experience","path":"/research/category/user-experience","sidebar":"autogenerated"}],"draftIds":[],"sidebars":{"autogenerated":{"link":{"path":"/research/","label":"index"}}}}],"breadcrumbs":true},"development":{"path":"/development","versions":[{"name":"current","label":"Next","isLast":true,"path":"/development","mainDocId":"index","docs":[{"id":"creating-stream-9-repos","path":"/development/creating-stream-9-repos","sidebar":"autogenerated"},{"id":"how-open-is-this-service","path":"/development/how-open-is-this-service","sidebar":"autogenerated"},{"id":"index","path":"/development/","sidebar":"autogenerated"},{"id":"patch-metadata","path":"/development/patch-metadata","sidebar":"autogenerated"}],"draftIds":[],"sidebars":{"autogenerated":{"link":{"path":"/development/","label":"index"}}}}],"breadcrumbs":true},"docs":{"path":"/docs","versions":[{"name":"current","label":"Next","isLast":true,"path":"/docs","mainDocId":"index","docs":[{"id":"about","path":"/docs/about","sidebar":"autogenerated"},{"id":"archive-not-matching-git","path":"/docs/archive-not-matching-git","sidebar":"autogenerated"},{"id":"cli/build/in-copr","path":"/docs/cli/build/in-copr","sidebar":"autogenerated"},{"id":"cli/build/in-image-builder","path":"/docs/cli/build/in-image-builder","sidebar":"autogenerated"},{"id":"cli/build/in-koji","path":"/docs/cli/build/in-koji","sidebar":"autogenerated"},{"id":"cli/build/in-mock","path":"/docs/cli/build/in-mock","sidebar":"autogenerated"},{"id":"cli/build/index","path":"/docs/cli/build/","sidebar":"autogenerated"},{"id":"cli/build/locally","path":"/docs/cli/build/locally","sidebar":"autogenerated"},{"id":"cli/create-update","path":"/docs/cli/create-update","sidebar":"autogenerated"},{"id":"cli/dist-git/init","path":"/docs/cli/dist-git/init","sidebar":"autogenerated"},{"id":"cli/index","path":"/docs/cli/","sidebar":"autogenerated"},{"id":"cli/init","path":"/docs/cli/init","sidebar":"autogenerated"},{"id":"cli/prepare-sources","path":"/docs/cli/prepare-sources","sidebar":"autogenerated"},{"id":"cli/propose-downstream","path":"/docs/cli/propose-downstream","sidebar":"autogenerated"},{"id":"cli/pull-from-upstream","path":"/docs/cli/pull-from-upstream","sidebar":"autogenerated"},{"id":"cli/push-updates","path":"/docs/cli/push-updates","sidebar":"autogenerated"},{"id":"cli/scan-in-osh","path":"/docs/cli/scan-in-osh","sidebar":"autogenerated"},{"id":"cli/source-git/init","path":"/docs/cli/source-git/init","sidebar":"autogenerated"},{"id":"cli/source-git/status","path":"/docs/cli/source-git/status","sidebar":"autogenerated"},{"id":"cli/source-git/update-dist-git","path":"/docs/cli/source-git/update-dist-git","sidebar":"autogenerated"},{"id":"cli/source-git/update-source-git","path":"/docs/cli/source-git/update-source-git","sidebar":"autogenerated"},{"id":"cli/srpm","path":"/docs/cli/srpm","sidebar":"autogenerated"},{"id":"cli/status","path":"/docs/cli/status","sidebar":"autogenerated"},{"id":"cli/sync-from-downstream","path":"/docs/cli/sync-from-downstream","sidebar":"autogenerated"},{"id":"cli/validate-config","path":"/docs/cli/validate-config","sidebar":"autogenerated"},{"id":"configuration/actions","path":"/docs/configuration/actions","sidebar":"autogenerated"},{"id":"configuration/downstream_configuration_template","path":"/docs/configuration/downstream_configuration_template","sidebar":"autogenerated"},{"id":"configuration/downstream/bodhi_update","path":"/docs/configuration/downstream/bodhi_update","sidebar":"autogenerated"},{"id":"configuration/downstream/koji_build","path":"/docs/configuration/downstream/koji_build","sidebar":"autogenerated"},{"id":"configuration/downstream/pull_from_upstream","path":"/docs/configuration/downstream/pull_from_upstream","sidebar":"autogenerated"},{"id":"configuration/examples","path":"/docs/configuration/examples","sidebar":"autogenerated"},{"id":"configuration/index","path":"/docs/configuration/","sidebar":"autogenerated"},{"id":"configuration/jobs","path":"/docs/configuration/jobs","sidebar":"autogenerated"},{"id":"configuration/upstream/copr_build","path":"/docs/configuration/upstream/copr_build","sidebar":"autogenerated"},{"id":"configuration/upstream/propose_downstream","path":"/docs/configuration/upstream/propose_downstream","sidebar":"autogenerated"},{"id":"configuration/upstream/tests","path":"/docs/configuration/upstream/tests","sidebar":"autogenerated"},{"id":"configuration/upstream/upstream_koji_build","path":"/docs/configuration/upstream/upstream_koji_build","sidebar":"autogenerated"},{"id":"configuration/upstream/vm_image_build","path":"/docs/configuration/upstream/vm_image_build","sidebar":"autogenerated"},{"id":"cross-project-testing","path":"/docs/cross-project-testing","sidebar":"autogenerated"},{"id":"faq","path":"/docs/faq","sidebar":"autogenerated"},{"id":"fedora-releases-guide/dist-git-onboarding","path":"/docs/fedora-releases-guide/dist-git-onboarding","sidebar":"autogenerated"},{"id":"fedora-releases-guide/fedora-notifications","path":"/docs/fedora-releases-guide/fedora-notifications","sidebar":"autogenerated"},{"id":"fedora-releases-guide/index","path":"/docs/fedora-releases-guide/","sidebar":"autogenerated"},{"id":"fedora-releases-guide/non-divergent-dist-git-branches","path":"/docs/fedora-releases-guide/non-divergent-dist-git-branches","sidebar":"autogenerated"},{"id":"fedora-releases-guide/releasing-multiple-packages","path":"/docs/fedora-releases-guide/releasing-multiple-packages","sidebar":"autogenerated"},{"id":"guide","path":"/docs/guide","sidebar":"autogenerated"},{"id":"index","path":"/docs/","sidebar":"autogenerated"},{"id":"pre-releases","path":"/docs/pre-releases","sidebar":"autogenerated"},{"id":"reproduce-locally","path":"/docs/reproduce-locally","sidebar":"autogenerated"},{"id":"service-level-objectives","path":"/docs/service-level-objectives","sidebar":"autogenerated"},{"id":"workshops-materials","path":"/docs/workshops-materials","sidebar":"autogenerated"},{"id":"/category/upstream-jobs","path":"/docs/category/upstream-jobs","sidebar":"autogenerated"},{"id":"/category/downstream-jobs","path":"/docs/category/downstream-jobs","sidebar":"autogenerated"},{"id":"/category/dist-git","path":"/docs/category/dist-git","sidebar":"autogenerated"},{"id":"/category/source-git","path":"/docs/category/source-git","sidebar":"autogenerated"}],"draftIds":[],"sidebars":{"autogenerated":{"link":{"path":"/docs/","label":"index"}}}}],"breadcrumbs":true},"specfile":{"path":"/specfile","versions":[{"name":"current","label":"Next","isLast":true,"path":"/specfile","mainDocId":"index","docs":[{"id":"api/specfile/changelog","path":"/specfile/api/specfile/changelog","sidebar":"autogenerated"},{"id":"api/specfile/conditions","path":"/specfile/api/specfile/conditions","sidebar":"autogenerated"},{"id":"api/specfile/context_management","path":"/specfile/api/specfile/context_management","sidebar":"autogenerated"},{"id":"api/specfile/exceptions","path":"/specfile/api/specfile/exceptions","sidebar":"autogenerated"},{"id":"api/specfile/formatter","path":"/specfile/api/specfile/formatter","sidebar":"autogenerated"},{"id":"api/specfile/macro_definitions","path":"/specfile/api/specfile/macro_definitions","sidebar":"autogenerated"},{"id":"api/specfile/macros","path":"/specfile/api/specfile/macros","sidebar":"autogenerated"},{"id":"api/specfile/options","path":"/specfile/api/specfile/options","sidebar":"autogenerated"},{"id":"api/specfile/prep","path":"/specfile/api/specfile/prep","sidebar":"autogenerated"},{"id":"api/specfile/sections","path":"/specfile/api/specfile/sections","sidebar":"autogenerated"},{"id":"api/specfile/sourcelist","path":"/specfile/api/specfile/sourcelist","sidebar":"autogenerated"},{"id":"api/specfile/sources","path":"/specfile/api/specfile/sources","sidebar":"autogenerated"},{"id":"api/specfile/spec_parser","path":"/specfile/api/specfile/spec_parser","sidebar":"autogenerated"},{"id":"api/specfile/specfile","path":"/specfile/api/specfile/","sidebar":"autogenerated"},{"id":"api/specfile/tags","path":"/specfile/api/specfile/tags","sidebar":"autogenerated"},{"id":"api/specfile/utils","path":"/specfile/api/specfile/utils","sidebar":"autogenerated"},{"id":"api/specfile/value_parser","path":"/specfile/api/specfile/value_parser","sidebar":"autogenerated"},{"id":"index","path":"/specfile/","sidebar":"autogenerated"}],"draftIds":[],"sidebars":{"autogenerated":{"link":{"path":"/specfile/api/specfile/","label":"specfile"}}}}],"breadcrumbs":true}}}'),i=JSON.parse('{"defaultLocale":"en","locales":["en"],"path":"i18n","currentLocale":"en","localeConfigs":{"en":{"label":"English","direction":"ltr","htmlLang":"en","calendar":"gregory","path":"en"}}}');var s=n(57529);const c=JSON.parse('{"docusaurusVersion":"2.4.1","siteVersion":"0.0.0","pluginVersions":{"docusaurus-plugin-content-pages":{"type":"package","name":"@docusaurus/plugin-content-pages","version":"2.4.1"},"docusaurus-plugin-sitemap":{"type":"package","name":"@docusaurus/plugin-sitemap","version":"2.4.1"},"docusaurus-theme-classic":{"type":"package","name":"@docusaurus/theme-classic","version":"2.4.1"},"docusaurus-theme-search-algolia":{"type":"package","name":"@docusaurus/theme-search-algolia","version":"2.4.1"},"docusaurus-plugin-content-docs":{"type":"package","name":"@docusaurus/plugin-content-docs","version":"2.4.1"},"docusaurus-plugin-content-blog":{"type":"package","name":"@docusaurus/plugin-content-blog","version":"2.4.1"},"docusaurus-plugin-client-redirects":{"type":"package","name":"@docusaurus/plugin-client-redirects","version":"2.4.1"},"docusaurus-theme-mermaid":{"type":"package","name":"@docusaurus/theme-mermaid","version":"2.4.1"}}}'),l={siteConfig:r.default,siteMetadata:c,globalData:o,i18n:i,codeTranslations:s},u=a.createContext(l);function d(e){let{children:t}=e;return a.createElement(u.Provider,{value:l},t)}},44763:(e,t,n)=>{"use strict";n.d(t,{Z:()=>p});var a=n(67294),r=n(10412),o=n(35742),i=n(18780),s=n(7452);function c(e){let{error:t,tryAgain:n}=e;return a.createElement("div",{style:{display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"flex-start",minHeight:"100vh",width:"100%",maxWidth:"80ch",fontSize:"20px",margin:"0 auto",padding:"1rem"}},a.createElement("h1",{style:{fontSize:"3rem"}},"This page crashed"),a.createElement("button",{type:"button",onClick:n,style:{margin:"1rem 0",fontSize:"2rem",cursor:"pointer",borderRadius:20,padding:"1rem"}},"Try again"),a.createElement(l,{error:t}))}function l(e){let{error:t}=e;const n=(0,i.getErrorCausalChain)(t).map((e=>e.message)).join("\n\nCause:\n");return a.createElement("p",{style:{whiteSpace:"pre-wrap"}},n)}function u(e){let{error:t,tryAgain:n}=e;return a.createElement(p,{fallback:()=>a.createElement(c,{error:t,tryAgain:n})},a.createElement(o.Z,null,a.createElement("title",null,"Page Error")),a.createElement(s.Z,null,a.createElement(c,{error:t,tryAgain:n})))}const d=e=>a.createElement(u,e);class p extends a.Component{constructor(e){super(e),this.state={error:null}}componentDidCatch(e){r.Z.canUseDOM&&this.setState({error:e})}render(){const{children:e}=this.props,{error:t}=this.state;if(t){const e={error:t,tryAgain:()=>this.setState({error:null})};return(this.props.fallback??d)(e)}return e??null}}},10412:(e,t,n)=>{"use strict";n.d(t,{Z:()=>r});const a="undefined"!=typeof window&&"document"in window&&"createElement"in window.document,r={canUseDOM:a,canUseEventListeners:a&&("addEventListener"in window||"attachEvent"in window),canUseIntersectionObserver:a&&"IntersectionObserver"in window,canUseViewport:a&&"screen"in window}},35742:(e,t,n)=>{"use strict";n.d(t,{Z:()=>o});var a=n(67294),r=n(70405);function o(e){return a.createElement(r.ql,e)}},39960:(e,t,n)=>{"use strict";n.d(t,{Z:()=>f});var a=n(87462),r=n(67294),o=n(73727),i=n(18780),s=n(52263),c=n(13919),l=n(10412);const u=r.createContext({collectLink:()=>{}});var d=n(44996);function p(e,t){let{isNavLink:n,to:p,href:f,activeClassName:m,isActive:g,"data-noBrokenLinkCheck":h,autoAddBaseUrl:b=!0,...y}=e;const{siteConfig:{trailingSlash:w,baseUrl:v}}=(0,s.Z)(),{withBaseUrl:k}=(0,d.C)(),_=(0,r.useContext)(u),x=(0,r.useRef)(null);(0,r.useImperativeHandle)(t,(()=>x.current));const E=p||f;const S=(0,c.Z)(E),C=E?.replace("pathname://","");let T=void 0!==C?(A=C,b&&(e=>e.startsWith("/"))(A)?k(A):A):void 0;var A;T&&S&&(T=(0,i.applyTrailingSlash)(T,{trailingSlash:w,baseUrl:v}));const L=(0,r.useRef)(!1),P=n?o.OL:o.rU,R=l.Z.canUseIntersectionObserver,j=(0,r.useRef)(),N=()=>{L.current||null==T||(window.docusaurus.preload(T),L.current=!0)};(0,r.useEffect)((()=>(!R&&S&&null!=T&&window.docusaurus.prefetch(T),()=>{R&&j.current&&j.current.disconnect()})),[j,T,R,S]);const O=T?.startsWith("#")??!1,I=!T||!S||O;return I||h||_.collectLink(T),I?r.createElement("a",(0,a.Z)({ref:x,href:T},E&&!S&&{target:"_blank",rel:"noopener noreferrer"},y)):r.createElement(P,(0,a.Z)({},y,{onMouseEnter:N,onTouchStart:N,innerRef:e=>{x.current=e,R&&e&&S&&(j.current=new window.IntersectionObserver((t=>{t.forEach((t=>{e===t.target&&(t.isIntersecting||t.intersectionRatio>0)&&(j.current.unobserve(e),j.current.disconnect(),null!=T&&window.docusaurus.prefetch(T))}))})),j.current.observe(e))},to:T},n&&{isActive:g,activeClassName:m}))}const f=r.forwardRef(p)},95999:(e,t,n)=>{"use strict";n.d(t,{Z:()=>c,I:()=>s});var a=n(67294);function r(e,t){const n=e.split(/(\{\w+\})/).map(((e,n)=>{if(n%2==1){const n=t?.[e.slice(1,-1)];if(void 0!==n)return n}return e}));return n.some((e=>(0,a.isValidElement)(e)))?n.map(((e,t)=>(0,a.isValidElement)(e)?a.cloneElement(e,{key:t}):e)).filter((e=>""!==e)):n.join("")}var o=n(57529);function i(e){let{id:t,message:n}=e;if(void 0===t&&void 0===n)throw new Error("Docusaurus translation declarations must have at least a translation id or a default translation message");return o[t??n]??n??t}function s(e,t){let{message:n,id:a}=e;return r(i({message:n,id:a}),t)}function c(e){let{children:t,id:n,values:o}=e;if(t&&"string"!=typeof t)throw console.warn("Illegal children",t),new Error("The Docusaurus component only accept simple string values");const s=i({message:t,id:n});return a.createElement(a.Fragment,null,r(s,o))}},29935:(e,t,n)=>{"use strict";n.d(t,{m:()=>a});const a="default"},13919:(e,t,n)=>{"use strict";function a(e){return/^(?:\w*:|\/\/)/.test(e)}function r(e){return void 0!==e&&!a(e)}n.d(t,{Z:()=>r,b:()=>a})},44996:(e,t,n)=>{"use strict";n.d(t,{C:()=>i,Z:()=>s});var a=n(67294),r=n(52263),o=n(13919);function i(){const{siteConfig:{baseUrl:e,url:t}}=(0,r.Z)(),n=(0,a.useCallback)(((n,a)=>function(e,t,n,a){let{forcePrependBaseUrl:r=!1,absolute:i=!1}=void 0===a?{}:a;if(!n||n.startsWith("#")||(0,o.b)(n))return n;if(r)return t+n.replace(/^\//,"");if(n===t.replace(/\/$/,""))return t;const s=n.startsWith(t)?n:t+n.replace(/^\//,"");return i?e+s:s}(t,e,n,a)),[t,e]);return{withBaseUrl:n}}function s(e,t){void 0===t&&(t={});const{withBaseUrl:n}=i();return n(e,t)}},52263:(e,t,n)=>{"use strict";n.d(t,{Z:()=>o});var a=n(67294),r=n(58940);function o(){return(0,a.useContext)(r._)}},72389:(e,t,n)=>{"use strict";n.d(t,{Z:()=>o});var a=n(67294),r=n(98934);function o(){return(0,a.useContext)(r._)}},99670:(e,t,n)=>{"use strict";n.d(t,{Z:()=>r});const a=e=>"object"==typeof e&&!!e&&Object.keys(e).length>0;function r(e){const t={};return function e(n,r){Object.entries(n).forEach((n=>{let[o,i]=n;const s=r?`${r}.${o}`:o;a(i)?e(i,s):t[s]=i}))}(e),t}},30226:(e,t,n)=>{"use strict";n.d(t,{_:()=>r,z:()=>o});var a=n(67294);const r=a.createContext(null);function o(e){let{children:t,value:n}=e;const o=a.useContext(r),i=(0,a.useMemo)((()=>function(e){let{parent:t,value:n}=e;if(!t){if(!n)throw new Error("Unexpected: no Docusaurus route context found");if(!("plugin"in n))throw new Error("Unexpected: Docusaurus topmost route context has no `plugin` attribute");return n}const a={...t.data,...n?.data};return{plugin:t.plugin,data:a}}({parent:o,value:n})),[o,n]);return a.createElement(r.Provider,{value:i},t)}},80143:(e,t,n)=>{"use strict";n.d(t,{Iw:()=>b,gA:()=>f,WS:()=>m,_r:()=>d,Jo:()=>y,zh:()=>p,yW:()=>h,gB:()=>g});var a=n(16550),r=n(52263),o=n(29935);function i(e,t){void 0===t&&(t={});const n=function(){const{globalData:e}=(0,r.Z)();return e}()[e];if(!n&&t.failfast)throw new Error(`Docusaurus plugin global data not found for "${e}" plugin.`);return n}const s=e=>e.versions.find((e=>e.isLast));function c(e,t){const n=s(e);return[...e.versions.filter((e=>e!==n)),n].find((e=>!!(0,a.LX)(t,{path:e.path,exact:!1,strict:!1})))}function l(e,t){const n=c(e,t),r=n?.docs.find((e=>!!(0,a.LX)(t,{path:e.path,exact:!0,strict:!1})));return{activeVersion:n,activeDoc:r,alternateDocVersions:r?function(t){const n={};return e.versions.forEach((e=>{e.docs.forEach((a=>{a.id===t&&(n[e.name]=a)}))})),n}(r.id):{}}}const u={},d=()=>i("docusaurus-plugin-content-docs")??u,p=e=>function(e,t,n){void 0===t&&(t=o.m),void 0===n&&(n={});const a=i(e),r=a?.[t];if(!r&&n.failfast)throw new Error(`Docusaurus plugin global data not found for "${e}" plugin with id "${t}".`);return r}("docusaurus-plugin-content-docs",e,{failfast:!0});function f(e){void 0===e&&(e={});const t=d(),{pathname:n}=(0,a.TH)();return function(e,t,n){void 0===n&&(n={});const r=Object.entries(e).sort(((e,t)=>t[1].path.localeCompare(e[1].path))).find((e=>{let[,n]=e;return!!(0,a.LX)(t,{path:n.path,exact:!1,strict:!1})})),o=r?{pluginId:r[0],pluginData:r[1]}:void 0;if(!o&&n.failfast)throw new Error(`Can't find active docs plugin for "${t}" pathname, while it was expected to be found. Maybe you tried to use a docs feature that can only be used on a docs-related page? Existing docs plugin paths are: ${Object.values(e).map((e=>e.path)).join(", ")}`);return o}(t,n,e)}function m(e){void 0===e&&(e={});const t=f(e),{pathname:n}=(0,a.TH)();if(!t)return;return{activePlugin:t,activeVersion:c(t.pluginData,n)}}function g(e){return p(e).versions}function h(e){const t=p(e);return s(t)}function b(e){const t=p(e),{pathname:n}=(0,a.TH)();return l(t,n)}function y(e){const t=p(e),{pathname:n}=(0,a.TH)();return function(e,t){const n=s(e);return{latestDocSuggestion:l(e,t).alternateDocVersions[n.name],latestVersionSuggestion:n}}(t,n)}},18320:(e,t,n)=>{"use strict";n.r(t),n.d(t,{default:()=>o});var a=n(74865),r=n.n(a);r().configure({showSpinner:!1});const o={onRouteUpdate(e){let{location:t,previousLocation:n}=e;if(n&&t.pathname!==n.pathname){const e=window.setTimeout((()=>{r().start()}),200);return()=>window.clearTimeout(e)}},onRouteDidUpdate(){r().done()}}},3310:(e,t,n)=>{"use strict";n.r(t);var a=n(87410),r=n(36809);!function(e){const{themeConfig:{prism:t}}=r.default,{additionalLanguages:a}=t;globalThis.Prism=e,a.forEach((e=>{n(6726)(`./prism-${e}`)})),delete globalThis.Prism}(a.Z)},39471:(e,t,n)=>{"use strict";n.d(t,{Z:()=>o});var a=n(67294);const r={iconExternalLink:"iconExternalLink_nPIU"};function o(e){let{width:t=13.5,height:n=13.5}=e;return a.createElement("svg",{width:t,height:n,"aria-hidden":"true",viewBox:"0 0 24 24",className:r.iconExternalLink},a.createElement("path",{fill:"currentColor",d:"M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"}))}},7452:(e,t,n)=>{"use strict";n.d(t,{Z:()=>Pt});var a=n(67294),r=n(86010),o=n(44763),i=n(10833),s=n(87462),c=n(16550),l=n(95999),u=n(85936);const d="__docusaurus_skipToContent_fallback";function p(e){e.setAttribute("tabindex","-1"),e.focus(),e.removeAttribute("tabindex")}function f(){const e=(0,a.useRef)(null),{action:t}=(0,c.k6)(),n=(0,a.useCallback)((e=>{e.preventDefault();const t=document.querySelector("main:first-of-type")??document.getElementById(d);t&&p(t)}),[]);return(0,u.S)((n=>{let{location:a}=n;e.current&&!a.hash&&"PUSH"===t&&p(e.current)})),{containerRef:e,onClick:n}}const m=(0,l.I)({id:"theme.common.skipToMainContent",description:"The skip to content label used for accessibility, allowing to rapidly navigate to main content with keyboard tab/enter navigation",message:"Skip to main content"});function g(e){const t=e.children??m,{containerRef:n,onClick:r}=f();return a.createElement("div",{ref:n,role:"region","aria-label":m},a.createElement("a",(0,s.Z)({},e,{href:`#${d}`,onClick:r}),t))}var h=n(35281),b=n(19727);const y={skipToContent:"skipToContent_fXgn"};function w(){return a.createElement(g,{className:y.skipToContent})}var v=n(86668),k=n(59689);function _(e){let{width:t=21,height:n=21,color:r="currentColor",strokeWidth:o=1.2,className:i,...c}=e;return a.createElement("svg",(0,s.Z)({viewBox:"0 0 15 15",width:t,height:n},c),a.createElement("g",{stroke:r,strokeWidth:o},a.createElement("path",{d:"M.75.75l13.5 13.5M14.25.75L.75 14.25"})))}const x={closeButton:"closeButton_CVFx"};function E(e){return a.createElement("button",(0,s.Z)({type:"button","aria-label":(0,l.I)({id:"theme.AnnouncementBar.closeButtonAriaLabel",message:"Close",description:"The ARIA label for close button of announcement bar"})},e,{className:(0,r.Z)("clean-btn close",x.closeButton,e.className)}),a.createElement(_,{width:14,height:14,strokeWidth:3.1}))}const S={content:"content_knG7"};function C(e){const{announcementBar:t}=(0,v.L)(),{content:n}=t;return a.createElement("div",(0,s.Z)({},e,{className:(0,r.Z)(S.content,e.className),dangerouslySetInnerHTML:{__html:n}}))}const T={announcementBar:"announcementBar_mb4j",announcementBarPlaceholder:"announcementBarPlaceholder_vyr4",announcementBarClose:"announcementBarClose_gvF7",announcementBarContent:"announcementBarContent_xLdY"};function A(){const{announcementBar:e}=(0,v.L)(),{isActive:t,close:n}=(0,k.nT)();if(!t)return null;const{backgroundColor:r,textColor:o,isCloseable:i}=e;return a.createElement("div",{className:T.announcementBar,style:{backgroundColor:r,color:o},role:"banner"},i&&a.createElement("div",{className:T.announcementBarPlaceholder}),a.createElement(C,{className:T.announcementBarContent}),i&&a.createElement(E,{onClick:n,className:T.announcementBarClose}))}var L=n(93163),P=n(12466);var R=n(902),j=n(13102);const N=a.createContext(null);function O(e){let{children:t}=e;const n=function(){const e=(0,L.e)(),t=(0,j.HY)(),[n,r]=(0,a.useState)(!1),o=null!==t.component,i=(0,R.D9)(o);return(0,a.useEffect)((()=>{o&&!i&&r(!0)}),[o,i]),(0,a.useEffect)((()=>{o?e.shown||r(!0):r(!1)}),[e.shown,o]),(0,a.useMemo)((()=>[n,r]),[n])}();return a.createElement(N.Provider,{value:n},t)}function I(e){if(e.component){const t=e.component;return a.createElement(t,e.props)}}function M(){const e=(0,a.useContext)(N);if(!e)throw new R.i6("NavbarSecondaryMenuDisplayProvider");const[t,n]=e,r=(0,a.useCallback)((()=>n(!1)),[n]),o=(0,j.HY)();return(0,a.useMemo)((()=>({shown:t,hide:r,content:I(o)})),[r,o,t])}function D(e){let{header:t,primaryMenu:n,secondaryMenu:o}=e;const{shown:i}=M();return a.createElement("div",{className:"navbar-sidebar"},t,a.createElement("div",{className:(0,r.Z)("navbar-sidebar__items",{"navbar-sidebar__items--show-secondary":i})},a.createElement("div",{className:"navbar-sidebar__item menu"},n),a.createElement("div",{className:"navbar-sidebar__item menu"},o)))}var B=n(92949),F=n(72389);function z(e){return a.createElement("svg",(0,s.Z)({viewBox:"0 0 24 24",width:24,height:24},e),a.createElement("path",{fill:"currentColor",d:"M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"}))}function U(e){return a.createElement("svg",(0,s.Z)({viewBox:"0 0 24 24",width:24,height:24},e),a.createElement("path",{fill:"currentColor",d:"M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"}))}const $={toggle:"toggle_vylO",toggleButton:"toggleButton_gllP",darkToggleIcon:"darkToggleIcon_wfgR",lightToggleIcon:"lightToggleIcon_pyhR",toggleButtonDisabled:"toggleButtonDisabled_aARS"};function q(e){let{className:t,buttonClassName:n,value:o,onChange:i}=e;const s=(0,F.Z)(),c=(0,l.I)({message:"Switch between dark and light mode (currently {mode})",id:"theme.colorToggle.ariaLabel",description:"The ARIA label for the navbar color mode toggle"},{mode:"dark"===o?(0,l.I)({message:"dark mode",id:"theme.colorToggle.ariaLabel.mode.dark",description:"The name for the dark color mode"}):(0,l.I)({message:"light mode",id:"theme.colorToggle.ariaLabel.mode.light",description:"The name for the light color mode"})});return a.createElement("div",{className:(0,r.Z)($.toggle,t)},a.createElement("button",{className:(0,r.Z)("clean-btn",$.toggleButton,!s&&$.toggleButtonDisabled,n),type:"button",onClick:()=>i("dark"===o?"light":"dark"),disabled:!s,title:c,"aria-label":c,"aria-live":"polite"},a.createElement(z,{className:(0,r.Z)($.toggleIcon,$.lightToggleIcon)}),a.createElement(U,{className:(0,r.Z)($.toggleIcon,$.darkToggleIcon)})))}const G=a.memo(q),H={darkNavbarColorModeToggle:"darkNavbarColorModeToggle_X3D1"};function Z(e){let{className:t}=e;const n=(0,v.L)().navbar.style,r=(0,v.L)().colorMode.disableSwitch,{colorMode:o,setColorMode:i}=(0,B.I)();return r?null:a.createElement(G,{className:t,buttonClassName:"dark"===n?H.darkNavbarColorModeToggle:void 0,value:o,onChange:i})}var V=n(21327);function W(){return a.createElement(V.Z,{className:"navbar__brand",imageClassName:"navbar__logo",titleClassName:"navbar__title text--truncate"})}function K(){const e=(0,L.e)();return a.createElement("button",{type:"button","aria-label":(0,l.I)({id:"theme.docs.sidebar.closeSidebarButtonAriaLabel",message:"Close navigation bar",description:"The ARIA label for close button of mobile sidebar"}),className:"clean-btn navbar-sidebar__close",onClick:()=>e.toggle()},a.createElement(_,{color:"var(--ifm-color-emphasis-600)"}))}function Y(){return a.createElement("div",{className:"navbar-sidebar__brand"},a.createElement(W,null),a.createElement(Z,{className:"margin-right--md"}),a.createElement(K,null))}var Q=n(39960),X=n(44996),J=n(13919),ee=n(98022),te=n(39471);function ne(e){let{activeBasePath:t,activeBaseRegex:n,to:r,href:o,label:i,html:c,isDropdownLink:l,prependBaseUrlToHref:u,...d}=e;const p=(0,X.Z)(r),f=(0,X.Z)(t),m=(0,X.Z)(o,{forcePrependBaseUrl:!0}),g=i&&o&&!(0,J.Z)(o),h=c?{dangerouslySetInnerHTML:{__html:c}}:{children:a.createElement(a.Fragment,null,i,g&&a.createElement(te.Z,l&&{width:12,height:12}))};return o?a.createElement(Q.Z,(0,s.Z)({href:u?m:o},d,h)):a.createElement(Q.Z,(0,s.Z)({to:p,isNavLink:!0},(t||n)&&{isActive:(e,t)=>n?(0,ee.F)(n,t.pathname):t.pathname.startsWith(f)},d,h))}function ae(e){let{className:t,isDropdownItem:n=!1,...o}=e;const i=a.createElement(ne,(0,s.Z)({className:(0,r.Z)(n?"dropdown__link":"navbar__item navbar__link",t),isDropdownLink:n},o));return n?a.createElement("li",null,i):i}function re(e){let{className:t,isDropdownItem:n,...o}=e;return a.createElement("li",{className:"menu__list-item"},a.createElement(ne,(0,s.Z)({className:(0,r.Z)("menu__link",t)},o)))}function oe(e){let{mobile:t=!1,position:n,...r}=e;const o=t?re:ae;return a.createElement(o,(0,s.Z)({},r,{activeClassName:r.activeClassName??(t?"menu__link--active":"navbar__link--active")}))}var ie=n(86043),se=n(48596),ce=n(52263);function le(e,t){return e.some((e=>function(e,t){return!!(0,se.Mg)(e.to,t)||!!(0,ee.F)(e.activeBaseRegex,t)||!(!e.activeBasePath||!t.startsWith(e.activeBasePath))}(e,t)))}function ue(e){let{items:t,position:n,className:o,onClick:i,...c}=e;const l=(0,a.useRef)(null),[u,d]=(0,a.useState)(!1);return(0,a.useEffect)((()=>{const e=e=>{l.current&&!l.current.contains(e.target)&&d(!1)};return document.addEventListener("mousedown",e),document.addEventListener("touchstart",e),document.addEventListener("focusin",e),()=>{document.removeEventListener("mousedown",e),document.removeEventListener("touchstart",e),document.removeEventListener("focusin",e)}}),[l]),a.createElement("div",{ref:l,className:(0,r.Z)("navbar__item","dropdown","dropdown--hoverable",{"dropdown--right":"right"===n,"dropdown--show":u})},a.createElement(ne,(0,s.Z)({"aria-haspopup":"true","aria-expanded":u,role:"button",href:c.to?void 0:"#",className:(0,r.Z)("navbar__link",o)},c,{onClick:c.to?void 0:e=>e.preventDefault(),onKeyDown:e=>{"Enter"===e.key&&(e.preventDefault(),d(!u))}}),c.children??c.label),a.createElement("ul",{className:"dropdown__menu"},t.map(((e,t)=>a.createElement(qe,(0,s.Z)({isDropdownItem:!0,activeClassName:"dropdown__link--active"},e,{key:t}))))))}function de(e){let{items:t,className:n,position:o,onClick:i,...l}=e;const u=function(){const{siteConfig:{baseUrl:e}}=(0,ce.Z)(),{pathname:t}=(0,c.TH)();return t.replace(e,"/")}(),d=le(t,u),{collapsed:p,toggleCollapsed:f,setCollapsed:m}=(0,ie.u)({initialState:()=>!d});return(0,a.useEffect)((()=>{d&&m(!d)}),[u,d,m]),a.createElement("li",{className:(0,r.Z)("menu__list-item",{"menu__list-item--collapsed":p})},a.createElement(ne,(0,s.Z)({role:"button",className:(0,r.Z)("menu__link menu__link--sublist menu__link--sublist-caret",n)},l,{onClick:e=>{e.preventDefault(),f()}}),l.children??l.label),a.createElement(ie.z,{lazy:!0,as:"ul",className:"menu__list",collapsed:p},t.map(((e,t)=>a.createElement(qe,(0,s.Z)({mobile:!0,isDropdownItem:!0,onClick:i,activeClassName:"menu__link--active"},e,{key:t}))))))}function pe(e){let{mobile:t=!1,...n}=e;const r=t?de:ue;return a.createElement(r,n)}var fe=n(94711);function me(e){let{width:t=20,height:n=20,...r}=e;return a.createElement("svg",(0,s.Z)({viewBox:"0 0 24 24",width:t,height:n,"aria-hidden":!0},r),a.createElement("path",{fill:"currentColor",d:"M12.87 15.07l-2.54-2.51.03-.03c1.74-1.94 2.98-4.17 3.71-6.53H17V4h-7V2H8v2H1v1.99h11.17C11.5 7.92 10.44 9.75 9 11.35 8.07 10.32 7.3 9.19 6.69 8h-2c.73 1.63 1.73 3.17 2.98 4.56l-5.09 5.02L4 19l5-5 3.11 3.11.76-2.04zM18.5 10h-2L12 22h2l1.12-3h4.75L21 22h2l-4.5-12zm-2.62 7l1.62-4.33L19.12 17h-3.24z"}))}const ge="iconLanguage_nlXk";function he(){return a.createElement("svg",{width:"15",height:"15",className:"DocSearch-Control-Key-Icon"},a.createElement("path",{d:"M4.505 4.496h2M5.505 5.496v5M8.216 4.496l.055 5.993M10 7.5c.333.333.5.667.5 1v2M12.326 4.5v5.996M8.384 4.496c1.674 0 2.116 0 2.116 1.5s-.442 1.5-2.116 1.5M3.205 9.303c-.09.448-.277 1.21-1.241 1.203C1 10.5.5 9.513.5 8V7c0-1.57.5-2.5 1.464-2.494.964.006 1.134.598 1.24 1.342M12.553 10.5h1.953",strokeWidth:"1.2",stroke:"currentColor",fill:"none",strokeLinecap:"square"}))}var be=n(20830),ye=["translations"];function we(){return we=Object.assign||function(e){for(var t=1;te.length)&&(t=e.length);for(var n=0,a=new Array(t);n=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var xe="Ctrl";var Ee=a.forwardRef((function(e,t){var n=e.translations,r=void 0===n?{}:n,o=_e(e,ye),i=r.buttonText,s=void 0===i?"Search":i,c=r.buttonAriaLabel,l=void 0===c?"Search":c,u=ve((0,a.useState)(null),2),d=u[0],p=u[1];return(0,a.useEffect)((function(){"undefined"!=typeof navigator&&(/(Mac|iPhone|iPod|iPad)/i.test(navigator.platform)?p("\u2318"):p(xe))}),[]),a.createElement("button",we({type:"button",className:"DocSearch DocSearch-Button","aria-label":l},o,{ref:t}),a.createElement("span",{className:"DocSearch-Button-Container"},a.createElement(be.W,null),a.createElement("span",{className:"DocSearch-Button-Placeholder"},s)),a.createElement("span",{className:"DocSearch-Button-Keys"},null!==d&&a.createElement(a.Fragment,null,a.createElement("kbd",{className:"DocSearch-Button-Key"},d===xe?a.createElement(he,null):d),a.createElement("kbd",{className:"DocSearch-Button-Key"},"K"))))})),Se=n(35742),Ce=n(66177),Te=n(239),Ae=n(43320);var Le=n(73935);const Pe={button:{buttonText:(0,l.I)({id:"theme.SearchBar.label",message:"Search",description:"The ARIA label and placeholder for search button"}),buttonAriaLabel:(0,l.I)({id:"theme.SearchBar.label",message:"Search",description:"The ARIA label and placeholder for search button"})},modal:{searchBox:{resetButtonTitle:(0,l.I)({id:"theme.SearchModal.searchBox.resetButtonTitle",message:"Clear the query",description:"The label and ARIA label for search box reset button"}),resetButtonAriaLabel:(0,l.I)({id:"theme.SearchModal.searchBox.resetButtonTitle",message:"Clear the query",description:"The label and ARIA label for search box reset button"}),cancelButtonText:(0,l.I)({id:"theme.SearchModal.searchBox.cancelButtonText",message:"Cancel",description:"The label and ARIA label for search box cancel button"}),cancelButtonAriaLabel:(0,l.I)({id:"theme.SearchModal.searchBox.cancelButtonText",message:"Cancel",description:"The label and ARIA label for search box cancel button"})},startScreen:{recentSearchesTitle:(0,l.I)({id:"theme.SearchModal.startScreen.recentSearchesTitle",message:"Recent",description:"The title for recent searches"}),noRecentSearchesText:(0,l.I)({id:"theme.SearchModal.startScreen.noRecentSearchesText",message:"No recent searches",description:"The text when no recent searches"}),saveRecentSearchButtonTitle:(0,l.I)({id:"theme.SearchModal.startScreen.saveRecentSearchButtonTitle",message:"Save this search",description:"The label for save recent search button"}),removeRecentSearchButtonTitle:(0,l.I)({id:"theme.SearchModal.startScreen.removeRecentSearchButtonTitle",message:"Remove this search from history",description:"The label for remove recent search button"}),favoriteSearchesTitle:(0,l.I)({id:"theme.SearchModal.startScreen.favoriteSearchesTitle",message:"Favorite",description:"The title for favorite searches"}),removeFavoriteSearchButtonTitle:(0,l.I)({id:"theme.SearchModal.startScreen.removeFavoriteSearchButtonTitle",message:"Remove this search from favorites",description:"The label for remove favorite search button"})},errorScreen:{titleText:(0,l.I)({id:"theme.SearchModal.errorScreen.titleText",message:"Unable to fetch results",description:"The title for error screen of search modal"}),helpText:(0,l.I)({id:"theme.SearchModal.errorScreen.helpText",message:"You might want to check your network connection.",description:"The help text for error screen of search modal"})},footer:{selectText:(0,l.I)({id:"theme.SearchModal.footer.selectText",message:"to select",description:"The explanatory text of the action for the enter key"}),selectKeyAriaLabel:(0,l.I)({id:"theme.SearchModal.footer.selectKeyAriaLabel",message:"Enter key",description:"The ARIA label for the Enter key button that makes the selection"}),navigateText:(0,l.I)({id:"theme.SearchModal.footer.navigateText",message:"to navigate",description:"The explanatory text of the action for the Arrow up and Arrow down key"}),navigateUpKeyAriaLabel:(0,l.I)({id:"theme.SearchModal.footer.navigateUpKeyAriaLabel",message:"Arrow up",description:"The ARIA label for the Arrow up key button that makes the navigation"}),navigateDownKeyAriaLabel:(0,l.I)({id:"theme.SearchModal.footer.navigateDownKeyAriaLabel",message:"Arrow down",description:"The ARIA label for the Arrow down key button that makes the navigation"}),closeText:(0,l.I)({id:"theme.SearchModal.footer.closeText",message:"to close",description:"The explanatory text of the action for Escape key"}),closeKeyAriaLabel:(0,l.I)({id:"theme.SearchModal.footer.closeKeyAriaLabel",message:"Escape key",description:"The ARIA label for the Escape key button that close the modal"}),searchByText:(0,l.I)({id:"theme.SearchModal.footer.searchByText",message:"Search by",description:"The text explain that the search is making by Algolia"})},noResultsScreen:{noResultsText:(0,l.I)({id:"theme.SearchModal.noResultsScreen.noResultsText",message:"No results for",description:"The text explains that there are no results for the following search"}),suggestedQueryText:(0,l.I)({id:"theme.SearchModal.noResultsScreen.suggestedQueryText",message:"Try searching for",description:"The text for the suggested query when no results are found for the following search"}),reportMissingResultsText:(0,l.I)({id:"theme.SearchModal.noResultsScreen.reportMissingResultsText",message:"Believe this query should return results?",description:"The text for the question where the user thinks there are missing results"}),reportMissingResultsLinkText:(0,l.I)({id:"theme.SearchModal.noResultsScreen.reportMissingResultsLinkText",message:"Let us know.",description:"The text for the link to report missing results"})}},placeholder:(0,l.I)({id:"theme.SearchModal.placeholder",message:"Search docs",description:"The placeholder of the input of the DocSearch pop-up modal"})};let Re=null;function je(e){let{hit:t,children:n}=e;return a.createElement(Q.Z,{to:t.url},n)}function Ne(e){let{state:t,onClose:n}=e;const r=(0,Ce.M)();return a.createElement(Q.Z,{to:r(t.query),onClick:n},a.createElement(l.Z,{id:"theme.SearchBar.seeAll",values:{count:t.context.nbHits}},"See all {count} results"))}function Oe(e){let{contextualSearch:t,externalUrlRegex:r,...o}=e;const{siteMetadata:i}=(0,ce.Z)(),l=(0,Te.l)(),u=function(){const{locale:e,tags:t}=(0,Ae._q)();return[`language:${e}`,t.map((e=>`docusaurus_tag:${e}`))]}(),d=o.searchParameters?.facetFilters??[],p=t?function(e,t){const n=e=>"string"==typeof e?[e]:e;return[...n(e),...n(t)]}(u,d):d,f={...o.searchParameters,facetFilters:p},m=(0,c.k6)(),g=(0,a.useRef)(null),h=(0,a.useRef)(null),[b,y]=(0,a.useState)(!1),[w,v]=(0,a.useState)(void 0),k=(0,a.useCallback)((()=>Re?Promise.resolve():Promise.all([n.e(61426).then(n.bind(n,61426)),Promise.all([n.e(40532),n.e(46945)]).then(n.bind(n,46945)),Promise.all([n.e(40532),n.e(18894)]).then(n.bind(n,18894))]).then((e=>{let[{DocSearchModal:t}]=e;Re=t}))),[]),_=(0,a.useCallback)((()=>{k().then((()=>{g.current=document.createElement("div"),document.body.insertBefore(g.current,document.body.firstChild),y(!0)}))}),[k,y]),x=(0,a.useCallback)((()=>{y(!1),g.current?.remove()}),[y]),E=(0,a.useCallback)((e=>{k().then((()=>{y(!0),v(e.key)}))}),[k,y,v]),S=(0,a.useRef)({navigate(e){let{itemUrl:t}=e;(0,ee.F)(r,t)?window.location.href=t:m.push(t)}}).current,C=(0,a.useRef)((e=>o.transformItems?o.transformItems(e):e.map((e=>({...e,url:l(e.url)}))))).current,T=(0,a.useMemo)((()=>e=>a.createElement(Ne,(0,s.Z)({},e,{onClose:x}))),[x]),A=(0,a.useCallback)((e=>(e.addAlgoliaAgent("docusaurus",i.docusaurusVersion),e)),[i.docusaurusVersion]);return function(e){var t=e.isOpen,n=e.onOpen,r=e.onClose,o=e.onInput,i=e.searchButtonRef;a.useEffect((function(){function e(e){var a;(27===e.keyCode&&t||"k"===(null===(a=e.key)||void 0===a?void 0:a.toLowerCase())&&(e.metaKey||e.ctrlKey)||!function(e){var t=e.target,n=t.tagName;return t.isContentEditable||"INPUT"===n||"SELECT"===n||"TEXTAREA"===n}(e)&&"/"===e.key&&!t)&&(e.preventDefault(),t?r():document.body.classList.contains("DocSearch--active")||document.body.classList.contains("DocSearch--active")||n()),i&&i.current===document.activeElement&&o&&/[a-zA-Z0-9]/.test(String.fromCharCode(e.keyCode))&&o(e)}return window.addEventListener("keydown",e),function(){window.removeEventListener("keydown",e)}}),[t,n,r,o,i])}({isOpen:b,onOpen:_,onClose:x,onInput:E,searchButtonRef:h}),a.createElement(a.Fragment,null,a.createElement(Se.Z,null,a.createElement("link",{rel:"preconnect",href:`https://${o.appId}-dsn.algolia.net`,crossOrigin:"anonymous"})),a.createElement(Ee,{onTouchStart:k,onFocus:k,onMouseOver:k,onClick:_,ref:h,translations:Pe.button}),b&&Re&&g.current&&(0,Le.createPortal)(a.createElement(Re,(0,s.Z)({onClose:x,initialScrollY:window.scrollY,initialQuery:w,navigator:S,transformItems:C,hitComponent:je,transformSearchClient:A},o.searchPagePath&&{resultsFooterComponent:T},o,{searchParameters:f,placeholder:Pe.placeholder,translations:Pe.modal})),g.current))}function Ie(){const{siteConfig:e}=(0,ce.Z)();return a.createElement(Oe,e.themeConfig.algolia)}const Me={searchBox:"searchBox_ZlJk"};function De(e){let{children:t,className:n}=e;return a.createElement("div",{className:(0,r.Z)(n,Me.searchBox)},t)}var Be=n(80143),Fe=n(52802);var ze=n(60373);const Ue=e=>e.docs.find((t=>t.id===e.mainDocId));const $e={default:oe,localeDropdown:function(e){let{mobile:t,dropdownItemsBefore:n,dropdownItemsAfter:r,...o}=e;const{i18n:{currentLocale:i,locales:u,localeConfigs:d}}=(0,ce.Z)(),p=(0,fe.l)(),{search:f,hash:m}=(0,c.TH)(),g=[...n,...u.map((e=>{const n=`${`pathname://${p.createUrl({locale:e,fullyQualified:!1})}`}${f}${m}`;return{label:d[e].label,lang:d[e].htmlLang,to:n,target:"_self",autoAddBaseUrl:!1,className:e===i?t?"menu__link--active":"dropdown__link--active":""}})),...r],h=t?(0,l.I)({message:"Languages",id:"theme.navbar.mobileLanguageDropdown.label",description:"The label for the mobile language switcher dropdown"}):d[i].label;return a.createElement(pe,(0,s.Z)({},o,{mobile:t,label:a.createElement(a.Fragment,null,a.createElement(me,{className:ge}),h),items:g}))},search:function(e){let{mobile:t,className:n}=e;return t?null:a.createElement(De,{className:n},a.createElement(Ie,null))},dropdown:pe,html:function(e){let{value:t,className:n,mobile:o=!1,isDropdownItem:i=!1}=e;const s=i?"li":"div";return a.createElement(s,{className:(0,r.Z)({navbar__item:!o&&!i,"menu__list-item":o},n),dangerouslySetInnerHTML:{__html:t}})},doc:function(e){let{docId:t,label:n,docsPluginId:r,...o}=e;const{activeDoc:i}=(0,Be.Iw)(r),c=(0,Fe.vY)(t,r);return null===c?null:a.createElement(oe,(0,s.Z)({exact:!0},o,{isActive:()=>i?.path===c.path||!!i?.sidebar&&i.sidebar===c.sidebar,label:n??c.id,to:c.path}))},docSidebar:function(e){let{sidebarId:t,label:n,docsPluginId:r,...o}=e;const{activeDoc:i}=(0,Be.Iw)(r),c=(0,Fe.oz)(t,r).link;if(!c)throw new Error(`DocSidebarNavbarItem: Sidebar with ID "${t}" doesn't have anything to be linked to.`);return a.createElement(oe,(0,s.Z)({exact:!0},o,{isActive:()=>i?.sidebar===t,label:n??c.label,to:c.path}))},docsVersion:function(e){let{label:t,to:n,docsPluginId:r,...o}=e;const i=(0,Fe.lO)(r)[0],c=t??i.label,l=n??(e=>e.docs.find((t=>t.id===e.mainDocId)))(i).path;return a.createElement(oe,(0,s.Z)({},o,{label:c,to:l}))},docsVersionDropdown:function(e){let{mobile:t,docsPluginId:n,dropdownActiveClassDisabled:r,dropdownItemsBefore:o,dropdownItemsAfter:i,...u}=e;const{search:d,hash:p}=(0,c.TH)(),f=(0,Be.Iw)(n),m=(0,Be.gB)(n),{savePreferredVersionName:g}=(0,ze.J)(n),h=[...o,...m.map((e=>{const t=f.alternateDocVersions[e.name]??Ue(e);return{label:e.label,to:`${t.path}${d}${p}`,isActive:()=>e===f.activeVersion,onClick:()=>g(e.name)}})),...i],b=(0,Fe.lO)(n)[0],y=t&&h.length>1?(0,l.I)({id:"theme.navbar.mobileVersionsDropdown.label",message:"Versions",description:"The label for the navbar versions dropdown on mobile view"}):b.label,w=t&&h.length>1?void 0:Ue(b).path;return h.length<=1?a.createElement(oe,(0,s.Z)({},u,{mobile:t,label:y,to:w,isActive:r?()=>!1:void 0})):a.createElement(pe,(0,s.Z)({},u,{mobile:t,label:y,to:w,items:h,isActive:r?()=>!1:void 0}))}};function qe(e){let{type:t,...n}=e;const r=function(e,t){return e&&"default"!==e?e:"items"in t?"dropdown":"default"}(t,n),o=$e[r];if(!o)throw new Error(`No NavbarItem component found for type "${t}".`);return a.createElement(o,n)}function Ge(){const e=(0,L.e)(),t=(0,v.L)().navbar.items;return a.createElement("ul",{className:"menu__list"},t.map(((t,n)=>a.createElement(qe,(0,s.Z)({mobile:!0},t,{onClick:()=>e.toggle(),key:n})))))}function He(e){return a.createElement("button",(0,s.Z)({},e,{type:"button",className:"clean-btn navbar-sidebar__back"}),a.createElement(l.Z,{id:"theme.navbar.mobileSidebarSecondaryMenu.backButtonLabel",description:"The label of the back button to return to main menu, inside the mobile navbar sidebar secondary menu (notably used to display the docs sidebar)"},"\u2190 Back to main menu"))}function Ze(){const e=0===(0,v.L)().navbar.items.length,t=M();return a.createElement(a.Fragment,null,!e&&a.createElement(He,{onClick:()=>t.hide()}),t.content)}function Ve(){const e=(0,L.e)();var t;return void 0===(t=e.shown)&&(t=!0),(0,a.useEffect)((()=>(document.body.style.overflow=t?"hidden":"visible",()=>{document.body.style.overflow="visible"})),[t]),e.shouldRender?a.createElement(D,{header:a.createElement(Y,null),primaryMenu:a.createElement(Ge,null),secondaryMenu:a.createElement(Ze,null)}):null}const We={navbarHideable:"navbarHideable_m1mJ",navbarHidden:"navbarHidden_jGov"};function Ke(e){return a.createElement("div",(0,s.Z)({role:"presentation"},e,{className:(0,r.Z)("navbar-sidebar__backdrop",e.className)}))}function Ye(e){let{children:t}=e;const{navbar:{hideOnScroll:n,style:o}}=(0,v.L)(),i=(0,L.e)(),{navbarRef:s,isNavbarVisible:c}=function(e){const[t,n]=(0,a.useState)(e),r=(0,a.useRef)(!1),o=(0,a.useRef)(0),i=(0,a.useCallback)((e=>{null!==e&&(o.current=e.getBoundingClientRect().height)}),[]);return(0,P.RF)(((t,a)=>{let{scrollY:i}=t;if(!e)return;if(i=s?n(!1):i+l{if(!e)return;const a=t.location.hash;if(a?document.getElementById(a.substring(1)):void 0)return r.current=!0,void n(!1);n(!0)})),{navbarRef:i,isNavbarVisible:t}}(n);return a.createElement("nav",{ref:s,"aria-label":(0,l.I)({id:"theme.NavBar.navAriaLabel",message:"Main",description:"The ARIA label for the main navigation"}),className:(0,r.Z)("navbar","navbar--fixed-top",n&&[We.navbarHideable,!c&&We.navbarHidden],{"navbar--dark":"dark"===o,"navbar--primary":"primary"===o,"navbar-sidebar--show":i.shown})},t,a.createElement(Ke,{onClick:i.toggle}),a.createElement(Ve,null))}var Qe=n(18780);const Xe={errorBoundaryError:"errorBoundaryError_a6uf"};function Je(e){return a.createElement("button",(0,s.Z)({type:"button"},e),a.createElement(l.Z,{id:"theme.ErrorPageContent.tryAgain",description:"The label of the button to try again rendering when the React error boundary captures an error"},"Try again"))}function et(e){let{error:t}=e;const n=(0,Qe.getErrorCausalChain)(t).map((e=>e.message)).join("\n\nCause:\n");return a.createElement("p",{className:Xe.errorBoundaryError},n)}class tt extends a.Component{componentDidCatch(e,t){throw this.props.onError(e,t)}render(){return this.props.children}}const nt="right";function at(e){let{width:t=30,height:n=30,className:r,...o}=e;return a.createElement("svg",(0,s.Z)({className:r,width:t,height:n,viewBox:"0 0 30 30","aria-hidden":"true"},o),a.createElement("path",{stroke:"currentColor",strokeLinecap:"round",strokeMiterlimit:"10",strokeWidth:"2",d:"M4 7h22M4 15h22M4 23h22"}))}function rt(){const{toggle:e,shown:t}=(0,L.e)();return a.createElement("button",{onClick:e,"aria-label":(0,l.I)({id:"theme.docs.sidebar.toggleSidebarButtonAriaLabel",message:"Toggle navigation bar",description:"The ARIA label for hamburger menu button of mobile navigation"}),"aria-expanded":t,className:"navbar__toggle clean-btn",type:"button"},a.createElement(at,null))}const ot={colorModeToggle:"colorModeToggle_DEke"};function it(e){let{items:t}=e;return a.createElement(a.Fragment,null,t.map(((e,t)=>a.createElement(tt,{key:t,onError:t=>new Error(`A theme navbar item failed to render.\nPlease double-check the following navbar item (themeConfig.navbar.items) of your Docusaurus config:\n${JSON.stringify(e,null,2)}`,{cause:t})},a.createElement(qe,e)))))}function st(e){let{left:t,right:n}=e;return a.createElement("div",{className:"navbar__inner"},a.createElement("div",{className:"navbar__items"},t),a.createElement("div",{className:"navbar__items navbar__items--right"},n))}function ct(){const e=(0,L.e)(),t=(0,v.L)().navbar.items,[n,r]=function(e){function t(e){return"left"===(e.position??nt)}return[e.filter(t),e.filter((e=>!t(e)))]}(t),o=t.find((e=>"search"===e.type));return a.createElement(st,{left:a.createElement(a.Fragment,null,!e.disabled&&a.createElement(rt,null),a.createElement(W,null),a.createElement(it,{items:n})),right:a.createElement(a.Fragment,null,a.createElement(it,{items:r}),a.createElement(Z,{className:ot.colorModeToggle}),!o&&a.createElement(De,null,a.createElement(Ie,null)))})}function lt(){return a.createElement(Ye,null,a.createElement(ct,null))}function ut(e){let{item:t}=e;const{to:n,href:r,label:o,prependBaseUrlToHref:i,...c}=t,l=(0,X.Z)(n),u=(0,X.Z)(r,{forcePrependBaseUrl:!0});return a.createElement(Q.Z,(0,s.Z)({className:"footer__link-item"},r?{href:i?u:r}:{to:l},c),o,r&&!(0,J.Z)(r)&&a.createElement(te.Z,null))}function dt(e){let{item:t}=e;return t.html?a.createElement("li",{className:"footer__item",dangerouslySetInnerHTML:{__html:t.html}}):a.createElement("li",{key:t.href??t.to,className:"footer__item"},a.createElement(ut,{item:t}))}function pt(e){let{column:t}=e;return a.createElement("div",{className:"col footer__col"},a.createElement("div",{className:"footer__title"},t.title),a.createElement("ul",{className:"footer__items clean-list"},t.items.map(((e,t)=>a.createElement(dt,{key:t,item:e})))))}function ft(e){let{columns:t}=e;return a.createElement("div",{className:"row footer__links"},t.map(((e,t)=>a.createElement(pt,{key:t,column:e}))))}function mt(){return a.createElement("span",{className:"footer__link-separator"},"\xb7")}function gt(e){let{item:t}=e;return t.html?a.createElement("span",{className:"footer__link-item",dangerouslySetInnerHTML:{__html:t.html}}):a.createElement(ut,{item:t})}function ht(e){let{links:t}=e;return a.createElement("div",{className:"footer__links text--center"},a.createElement("div",{className:"footer__links"},t.map(((e,n)=>a.createElement(a.Fragment,{key:n},a.createElement(gt,{item:e}),t.length!==n+1&&a.createElement(mt,null))))))}function bt(e){let{links:t}=e;return function(e){return"title"in e[0]}(t)?a.createElement(ft,{columns:t}):a.createElement(ht,{links:t})}var yt=n(50941);const wt={footerLogoLink:"footerLogoLink_BH7S"};function vt(e){let{logo:t}=e;const{withBaseUrl:n}=(0,X.C)(),o={light:n(t.src),dark:n(t.srcDark??t.src)};return a.createElement(yt.Z,{className:(0,r.Z)("footer__logo",t.className),alt:t.alt,sources:o,width:t.width,height:t.height,style:t.style})}function kt(e){let{logo:t}=e;return t.href?a.createElement(Q.Z,{href:t.href,className:wt.footerLogoLink,target:t.target},a.createElement(vt,{logo:t})):a.createElement(vt,{logo:t})}function _t(e){let{copyright:t}=e;return a.createElement("div",{className:"footer__copyright",dangerouslySetInnerHTML:{__html:t}})}function xt(e){let{style:t,links:n,logo:o,copyright:i}=e;return a.createElement("footer",{className:(0,r.Z)("footer",{"footer--dark":"dark"===t})},a.createElement("div",{className:"container container-fluid"},n,(o||i)&&a.createElement("div",{className:"footer__bottom text--center"},o&&a.createElement("div",{className:"margin-bottom--sm"},o),i)))}function Et(){const{footer:e}=(0,v.L)();if(!e)return null;const{copyright:t,links:n,logo:r,style:o}=e;return a.createElement(xt,{style:o,links:n&&n.length>0&&a.createElement(bt,{links:n}),logo:r&&a.createElement(kt,{logo:r}),copyright:t&&a.createElement(_t,{copyright:t})})}const St=a.memo(Et),Ct=(0,R.Qc)([B.S,k.pl,P.OC,ze.L5,i.VC,function(e){let{children:t}=e;return a.createElement(j.n2,null,a.createElement(L.M,null,a.createElement(O,null,t)))}]);function Tt(e){let{children:t}=e;return a.createElement(Ct,null,t)}function At(e){let{error:t,tryAgain:n}=e;return a.createElement("main",{className:"container margin-vert--xl"},a.createElement("div",{className:"row"},a.createElement("div",{className:"col col--6 col--offset-3"},a.createElement("h1",{className:"hero__title"},a.createElement(l.Z,{id:"theme.ErrorPageContent.title",description:"The title of the fallback page when the page crashed"},"This page crashed.")),a.createElement("div",{className:"margin-vert--lg"},a.createElement(Je,{onClick:n,className:"button button--primary shadow--lw"})),a.createElement("hr",null),a.createElement("div",{className:"margin-vert--md"},a.createElement(et,{error:t})))))}const Lt={mainWrapper:"mainWrapper_z2l0"};function Pt(e){const{children:t,noFooter:n,wrapperClassName:s,title:c,description:l}=e;return(0,b.t)(),a.createElement(Tt,null,a.createElement(i.d,{title:c,description:l}),a.createElement(w,null),a.createElement(A,null),a.createElement(lt,null),a.createElement("div",{id:d,className:(0,r.Z)(h.k.wrapper.main,Lt.mainWrapper,s)},a.createElement(o.Z,{fallback:e=>a.createElement(At,e)},t)),!n&&a.createElement(St,null))}},21327:(e,t,n)=>{"use strict";n.d(t,{Z:()=>d});var a=n(87462),r=n(67294),o=n(39960),i=n(44996),s=n(52263),c=n(86668),l=n(50941);function u(e){let{logo:t,alt:n,imageClassName:a}=e;const o={light:(0,i.Z)(t.src),dark:(0,i.Z)(t.srcDark||t.src)},s=r.createElement(l.Z,{className:t.className,sources:o,height:t.height,width:t.width,alt:n,style:t.style});return a?r.createElement("div",{className:a},s):s}function d(e){const{siteConfig:{title:t}}=(0,s.Z)(),{navbar:{title:n,logo:l}}=(0,c.L)(),{imageClassName:d,titleClassName:p,...f}=e,m=(0,i.Z)(l?.href||"/"),g=n?"":t,h=l?.alt??g;return r.createElement(o.Z,(0,a.Z)({to:m},f,l?.target&&{target:l.target}),l&&r.createElement(u,{logo:l,alt:h,imageClassName:d}),null!=n&&r.createElement("b",{className:p},n))}},90197:(e,t,n)=>{"use strict";n.d(t,{Z:()=>o});var a=n(67294),r=n(35742);function o(e){let{locale:t,version:n,tag:o}=e;const i=t;return a.createElement(r.Z,null,t&&a.createElement("meta",{name:"docusaurus_locale",content:t}),n&&a.createElement("meta",{name:"docusaurus_version",content:n}),o&&a.createElement("meta",{name:"docusaurus_tag",content:o}),i&&a.createElement("meta",{name:"docsearch:language",content:i}),n&&a.createElement("meta",{name:"docsearch:version",content:n}),o&&a.createElement("meta",{name:"docsearch:docusaurus_tag",content:o}))}},50941:(e,t,n)=>{"use strict";n.d(t,{Z:()=>l});var a=n(87462),r=n(67294),o=n(86010),i=n(72389),s=n(92949);const c={themedImage:"themedImage_ToTc","themedImage--light":"themedImage--light_HNdA","themedImage--dark":"themedImage--dark_i4oU"};function l(e){const t=(0,i.Z)(),{colorMode:n}=(0,s.I)(),{sources:l,className:u,alt:d,...p}=e,f=t?"dark"===n?["dark"]:["light"]:["light","dark"];return r.createElement(r.Fragment,null,f.map((e=>r.createElement("img",(0,a.Z)({key:e,src:l[e],alt:d,className:(0,o.Z)(c.themedImage,c[`themedImage--${e}`],u)},p)))))}},86043:(e,t,n)=>{"use strict";n.d(t,{u:()=>c,z:()=>h});var a=n(87462),r=n(67294),o=n(10412),i=n(91442);const s="ease-in-out";function c(e){let{initialState:t}=e;const[n,a]=(0,r.useState)(t??!1),o=(0,r.useCallback)((()=>{a((e=>!e))}),[]);return{collapsed:n,setCollapsed:a,toggleCollapsed:o}}const l={display:"none",overflow:"hidden",height:"0px"},u={display:"block",overflow:"visible",height:"auto"};function d(e,t){const n=t?l:u;e.style.display=n.display,e.style.overflow=n.overflow,e.style.height=n.height}function p(e){let{collapsibleRef:t,collapsed:n,animation:a}=e;const o=(0,r.useRef)(!1);(0,r.useEffect)((()=>{const e=t.current;function r(){const t=e.scrollHeight,n=a?.duration??function(e){if((0,i.n)())return 1;const t=e/36;return Math.round(10*(4+15*t**.25+t/5))}(t);return{transition:`height ${n}ms ${a?.easing??s}`,height:`${t}px`}}function c(){const t=r();e.style.transition=t.transition,e.style.height=t.height}if(!o.current)return d(e,n),void(o.current=!0);return e.style.willChange="height",function(){const t=requestAnimationFrame((()=>{n?(c(),requestAnimationFrame((()=>{e.style.height=l.height,e.style.overflow=l.overflow}))):(e.style.display="block",requestAnimationFrame((()=>{c()})))}));return()=>cancelAnimationFrame(t)}()}),[t,n,a])}function f(e){if(!o.Z.canUseDOM)return e?l:u}function m(e){let{as:t="div",collapsed:n,children:a,animation:o,onCollapseTransitionEnd:i,className:s,disableSSRStyle:c}=e;const l=(0,r.useRef)(null);return p({collapsibleRef:l,collapsed:n,animation:o}),r.createElement(t,{ref:l,style:c?void 0:f(n),onTransitionEnd:e=>{"height"===e.propertyName&&(d(l.current,n),i?.(n))},className:s},a)}function g(e){let{collapsed:t,...n}=e;const[o,i]=(0,r.useState)(!t),[s,c]=(0,r.useState)(t);return(0,r.useLayoutEffect)((()=>{t||i(!0)}),[t]),(0,r.useLayoutEffect)((()=>{o&&c(t)}),[o,t]),o?r.createElement(m,(0,a.Z)({},n,{collapsed:s})):null}function h(e){let{lazy:t,...n}=e;const a=t?g:m;return r.createElement(a,n)}},59689:(e,t,n)=>{"use strict";n.d(t,{nT:()=>m,pl:()=>f});var a=n(67294),r=n(72389),o=n(50012),i=n(902),s=n(86668);const c=(0,o.WA)("docusaurus.announcement.dismiss"),l=(0,o.WA)("docusaurus.announcement.id"),u=()=>"true"===c.get(),d=e=>c.set(String(e)),p=a.createContext(null);function f(e){let{children:t}=e;const n=function(){const{announcementBar:e}=(0,s.L)(),t=(0,r.Z)(),[n,o]=(0,a.useState)((()=>!!t&&u()));(0,a.useEffect)((()=>{o(u())}),[]);const i=(0,a.useCallback)((()=>{d(!0),o(!0)}),[]);return(0,a.useEffect)((()=>{if(!e)return;const{id:t}=e;let n=l.get();"annoucement-bar"===n&&(n="announcement-bar");const a=t!==n;l.set(t),a&&d(!1),!a&&u()||o(!1)}),[e]),(0,a.useMemo)((()=>({isActive:!!e&&!n,close:i})),[e,n,i])}();return a.createElement(p.Provider,{value:n},t)}function m(){const e=(0,a.useContext)(p);if(!e)throw new i.i6("AnnouncementBarProvider");return e}},92949:(e,t,n)=>{"use strict";n.d(t,{I:()=>h,S:()=>g});var a=n(67294),r=n(10412),o=n(902),i=n(50012),s=n(86668);const c=a.createContext(void 0),l="theme",u=(0,i.WA)(l),d={light:"light",dark:"dark"},p=e=>e===d.dark?d.dark:d.light,f=e=>r.Z.canUseDOM?p(document.documentElement.getAttribute("data-theme")):p(e),m=e=>{u.set(p(e))};function g(e){let{children:t}=e;const n=function(){const{colorMode:{defaultMode:e,disableSwitch:t,respectPrefersColorScheme:n}}=(0,s.L)(),[r,o]=(0,a.useState)(f(e));(0,a.useEffect)((()=>{t&&u.del()}),[t]);const i=(0,a.useCallback)((function(t,a){void 0===a&&(a={});const{persist:r=!0}=a;t?(o(t),r&&m(t)):(o(n?window.matchMedia("(prefers-color-scheme: dark)").matches?d.dark:d.light:e),u.del())}),[n,e]);(0,a.useEffect)((()=>{document.documentElement.setAttribute("data-theme",p(r))}),[r]),(0,a.useEffect)((()=>{if(t)return;const e=e=>{if(e.key!==l)return;const t=u.get();null!==t&&i(p(t))};return window.addEventListener("storage",e),()=>window.removeEventListener("storage",e)}),[t,i]);const c=(0,a.useRef)(!1);return(0,a.useEffect)((()=>{if(t&&!n)return;const e=window.matchMedia("(prefers-color-scheme: dark)"),a=()=>{window.matchMedia("print").matches||c.current?c.current=window.matchMedia("print").matches:i(null)};return e.addListener(a),()=>e.removeListener(a)}),[i,t,n]),(0,a.useMemo)((()=>({colorMode:r,setColorMode:i,get isDarkTheme(){return r===d.dark},setLightTheme(){i(d.light)},setDarkTheme(){i(d.dark)}})),[r,i])}();return a.createElement(c.Provider,{value:n},t)}function h(){const e=(0,a.useContext)(c);if(null==e)throw new o.i6("ColorModeProvider","Please see https://docusaurus.io/docs/api/themes/configuration#use-color-mode.");return e}},60373:(e,t,n)=>{"use strict";n.d(t,{J:()=>y,L5:()=>h,Oh:()=>w});var a=n(67294),r=n(80143),o=n(29935),i=n(86668),s=n(52802),c=n(902),l=n(50012);const u=e=>`docs-preferred-version-${e}`,d={save:(e,t,n)=>{(0,l.WA)(u(e),{persistence:t}).set(n)},read:(e,t)=>(0,l.WA)(u(e),{persistence:t}).get(),clear:(e,t)=>{(0,l.WA)(u(e),{persistence:t}).del()}},p=e=>Object.fromEntries(e.map((e=>[e,{preferredVersionName:null}])));const f=a.createContext(null);function m(){const e=(0,r._r)(),t=(0,i.L)().docs.versionPersistence,n=(0,a.useMemo)((()=>Object.keys(e)),[e]),[o,s]=(0,a.useState)((()=>p(n)));(0,a.useEffect)((()=>{s(function(e){let{pluginIds:t,versionPersistence:n,allDocsData:a}=e;function r(e){const t=d.read(e,n);return a[e].versions.some((e=>e.name===t))?{preferredVersionName:t}:(d.clear(e,n),{preferredVersionName:null})}return Object.fromEntries(t.map((e=>[e,r(e)])))}({allDocsData:e,versionPersistence:t,pluginIds:n}))}),[e,t,n]);return[o,(0,a.useMemo)((()=>({savePreferredVersion:function(e,n){d.save(e,t,n),s((t=>({...t,[e]:{preferredVersionName:n}})))}})),[t])]}function g(e){let{children:t}=e;const n=m();return a.createElement(f.Provider,{value:n},t)}function h(e){let{children:t}=e;return s.cE?a.createElement(g,null,t):a.createElement(a.Fragment,null,t)}function b(){const e=(0,a.useContext)(f);if(!e)throw new c.i6("DocsPreferredVersionContextProvider");return e}function y(e){void 0===e&&(e=o.m);const t=(0,r.zh)(e),[n,i]=b(),{preferredVersionName:s}=n[e];return{preferredVersion:t.versions.find((e=>e.name===s))??null,savePreferredVersionName:(0,a.useCallback)((t=>{i.savePreferredVersion(e,t)}),[i,e])}}function w(){const e=(0,r._r)(),[t]=b();function n(n){const a=e[n],{preferredVersionName:r}=t[n];return a.versions.find((e=>e.name===r))??null}const a=Object.keys(e);return Object.fromEntries(a.map((e=>[e,n(e)])))}},1116:(e,t,n)=>{"use strict";n.d(t,{V:()=>c,b:()=>s});var a=n(67294),r=n(902);const o=Symbol("EmptyContext"),i=a.createContext(o);function s(e){let{children:t,name:n,items:r}=e;const o=(0,a.useMemo)((()=>n&&r?{name:n,items:r}:null),[n,r]);return a.createElement(i.Provider,{value:o},t)}function c(){const e=(0,a.useContext)(i);if(e===o)throw new r.i6("DocsSidebarProvider");return e}},74477:(e,t,n)=>{"use strict";n.d(t,{E:()=>s,q:()=>i});var a=n(67294),r=n(902);const o=a.createContext(null);function i(e){let{children:t,version:n}=e;return a.createElement(o.Provider,{value:n},t)}function s(){const e=(0,a.useContext)(o);if(null===e)throw new r.i6("DocsVersionProvider");return e}},93163:(e,t,n)=>{"use strict";n.d(t,{M:()=>d,e:()=>p});var a=n(67294),r=n(13102),o=n(87524),i=n(91980),s=n(86668),c=n(902);const l=a.createContext(void 0);function u(){const e=function(){const e=(0,r.HY)(),{items:t}=(0,s.L)().navbar;return 0===t.length&&!e.component}(),t=(0,o.i)(),n=!e&&"mobile"===t,[c,l]=(0,a.useState)(!1);(0,i.Rb)((()=>{if(c)return l(!1),!1}));const u=(0,a.useCallback)((()=>{l((e=>!e))}),[]);return(0,a.useEffect)((()=>{"desktop"===t&&l(!1)}),[t]),(0,a.useMemo)((()=>({disabled:e,shouldRender:n,toggle:u,shown:c})),[e,n,u,c])}function d(e){let{children:t}=e;const n=u();return a.createElement(l.Provider,{value:n},t)}function p(){const e=a.useContext(l);if(void 0===e)throw new c.i6("NavbarMobileSidebarProvider");return e}},13102:(e,t,n)=>{"use strict";n.d(t,{HY:()=>s,Zo:()=>c,n2:()=>i});var a=n(67294),r=n(902);const o=a.createContext(null);function i(e){let{children:t}=e;const n=(0,a.useState)({component:null,props:null});return a.createElement(o.Provider,{value:n},t)}function s(){const e=(0,a.useContext)(o);if(!e)throw new r.i6("NavbarSecondaryMenuContentProvider");return e[0]}function c(e){let{component:t,props:n}=e;const i=(0,a.useContext)(o);if(!i)throw new r.i6("NavbarSecondaryMenuContentProvider");const[,s]=i,c=(0,r.Ql)(n);return(0,a.useEffect)((()=>{s({component:t,props:c})}),[s,t,c]),(0,a.useEffect)((()=>()=>s({component:null,props:null})),[s]),null}},19727:(e,t,n)=>{"use strict";n.d(t,{h:()=>r,t:()=>o});var a=n(67294);const r="navigation-with-keyboard";function o(){(0,a.useEffect)((()=>{function e(e){"keydown"===e.type&&"Tab"===e.key&&document.body.classList.add(r),"mousedown"===e.type&&document.body.classList.remove(r)}return document.addEventListener("keydown",e),document.addEventListener("mousedown",e),()=>{document.body.classList.remove(r),document.removeEventListener("keydown",e),document.removeEventListener("mousedown",e)}}),[])}},66177:(e,t,n)=>{"use strict";n.d(t,{K:()=>s,M:()=>c});var a=n(67294),r=n(52263),o=n(91980);const i="q";function s(){return(0,o.Nc)(i)}function c(){const{siteConfig:{baseUrl:e,themeConfig:t}}=(0,r.Z)(),{algolia:{searchPagePath:n}}=t;return(0,a.useCallback)((t=>`${e}${n}?${i}=${encodeURIComponent(t)}`),[e,n])}},87524:(e,t,n)=>{"use strict";n.d(t,{i:()=>l});var a=n(67294),r=n(10412);const o={desktop:"desktop",mobile:"mobile",ssr:"ssr"},i=996;function s(){return r.Z.canUseDOM?window.innerWidth>i?o.desktop:o.mobile:o.ssr}const c=!1;function l(){const[e,t]=(0,a.useState)((()=>c?"ssr":s()));return(0,a.useEffect)((()=>{function e(){t(s())}const n=c?window.setTimeout(e,1e3):void 0;return window.addEventListener("resize",e),()=>{window.removeEventListener("resize",e),clearTimeout(n)}}),[]),e}},35281:(e,t,n)=>{"use strict";n.d(t,{k:()=>a});const a={page:{blogListPage:"blog-list-page",blogPostPage:"blog-post-page",blogTagsListPage:"blog-tags-list-page",blogTagPostListPage:"blog-tags-post-list-page",docsDocPage:"docs-doc-page",docsTagsListPage:"docs-tags-list-page",docsTagDocListPage:"docs-tags-doc-list-page",mdxPage:"mdx-page"},wrapper:{main:"main-wrapper",blogPages:"blog-wrapper",docsPages:"docs-wrapper",mdxPages:"mdx-wrapper"},common:{editThisPage:"theme-edit-this-page",lastUpdated:"theme-last-updated",backToTopButton:"theme-back-to-top-button",codeBlock:"theme-code-block",admonition:"theme-admonition",admonitionType:e=>`theme-admonition-${e}`},layout:{},docs:{docVersionBanner:"theme-doc-version-banner",docVersionBadge:"theme-doc-version-badge",docBreadcrumbs:"theme-doc-breadcrumbs",docMarkdown:"theme-doc-markdown",docTocMobile:"theme-doc-toc-mobile",docTocDesktop:"theme-doc-toc-desktop",docFooter:"theme-doc-footer",docFooterTagsRow:"theme-doc-footer-tags-row",docFooterEditMetaRow:"theme-doc-footer-edit-meta-row",docSidebarContainer:"theme-doc-sidebar-container",docSidebarMenu:"theme-doc-sidebar-menu",docSidebarItemCategory:"theme-doc-sidebar-item-category",docSidebarItemLink:"theme-doc-sidebar-item-link",docSidebarItemCategoryLevel:e=>`theme-doc-sidebar-item-category-level-${e}`,docSidebarItemLinkLevel:e=>`theme-doc-sidebar-item-link-level-${e}`},blog:{}}},91442:(e,t,n)=>{"use strict";function a(){return window.matchMedia("(prefers-reduced-motion: reduce)").matches}n.d(t,{n:()=>a})},52802:(e,t,n)=>{"use strict";n.d(t,{MN:()=>S,Wl:()=>m,_F:()=>y,cE:()=>p,jA:()=>g,xz:()=>f,hI:()=>E,lO:()=>k,vY:()=>x,oz:()=>_,s1:()=>v});var a=n(67294),r=n(16550),o=n(18790),i=n(80143),s=n(60373),c=n(74477),l=n(1116);function u(e){return Array.from(new Set(e))}var d=n(48596);const p=!!i._r;function f(e){const t=(0,c.E)();if(!e)return;const n=t.docs[e];if(!n)throw new Error(`no version doc found by id=${e}`);return n}function m(e){if(e.href)return e.href;for(const t of e.items){if("link"===t.type)return t.href;if("category"===t.type){const e=m(t);if(e)return e}}}function g(){const{pathname:e}=(0,r.TH)(),t=(0,l.V)();if(!t)throw new Error("Unexpected: cant find current sidebar in context");const n=w({sidebarItems:t.items,pathname:e,onlyCategories:!0}).slice(-1)[0];if(!n)throw new Error(`${e} is not associated with a category. useCurrentSidebarCategory() should only be used on category index pages.`);return n}const h=(e,t)=>void 0!==e&&(0,d.Mg)(e,t),b=(e,t)=>e.some((e=>y(e,t)));function y(e,t){return"link"===e.type?h(e.href,t):"category"===e.type&&(h(e.href,t)||b(e.items,t))}function w(e){let{sidebarItems:t,pathname:n,onlyCategories:a=!1}=e;const r=[];return function e(t){for(const o of t)if("category"===o.type&&((0,d.Mg)(o.href,n)||e(o.items))||"link"===o.type&&(0,d.Mg)(o.href,n)){return a&&"category"!==o.type||r.unshift(o),!0}return!1}(t),r}function v(){const e=(0,l.V)(),{pathname:t}=(0,r.TH)(),n=(0,i.gA)()?.pluginData.breadcrumbs;return!1!==n&&e?w({sidebarItems:e.items,pathname:t}):null}function k(e){const{activeVersion:t}=(0,i.Iw)(e),{preferredVersion:n}=(0,s.J)(e),r=(0,i.yW)(e);return(0,a.useMemo)((()=>u([t,n,r].filter(Boolean))),[t,n,r])}function _(e,t){const n=k(t);return(0,a.useMemo)((()=>{const t=n.flatMap((e=>e.sidebars?Object.entries(e.sidebars):[])),a=t.find((t=>t[0]===e));if(!a)throw new Error(`Can't find any sidebar with id "${e}" in version${n.length>1?"s":""} ${n.map((e=>e.name)).join(", ")}".\nAvailable sidebar ids are:\n- ${t.map((e=>e[0])).join("\n- ")}`);return a[1]}),[e,n])}function x(e,t){const n=k(t);return(0,a.useMemo)((()=>{const t=n.flatMap((e=>e.docs)),a=t.find((t=>t.id===e));if(!a){if(n.flatMap((e=>e.draftIds)).includes(e))return null;throw new Error(`Couldn't find any doc with id "${e}" in version${n.length>1?"s":""} "${n.map((e=>e.name)).join(", ")}".\nAvailable doc ids are:\n- ${u(t.map((e=>e.id))).join("\n- ")}`)}return a}),[e,n])}function E(e){let{route:t,versionMetadata:n}=e;const a=(0,r.TH)(),i=t.routes,s=i.find((e=>(0,r.LX)(a.pathname,e)));if(!s)return null;const c=s.sidebar,l=c?n.docsSidebars[c]:void 0;return{docElement:(0,o.H)(i),sidebarName:c,sidebarItems:l}}function S(e){return e.filter((e=>"category"!==e.type||!!m(e)))}},82128:(e,t,n)=>{"use strict";n.d(t,{p:()=>r});var a=n(52263);function r(e){const{siteConfig:t}=(0,a.Z)(),{title:n,titleDelimiter:r}=t;return e?.trim().length?`${e.trim()} ${r} ${n}`:n}},91980:(e,t,n)=>{"use strict";n.d(t,{Nc:()=>l,Rb:()=>s});var a=n(67294),r=n(16550),o=n(61688),i=n(902);function s(e){!function(e){const t=(0,r.k6)(),n=(0,i.zX)(e);(0,a.useEffect)((()=>t.block(((e,t)=>n(e,t)))),[t,n])}(((t,n)=>{if("POP"===n)return e(t,n)}))}function c(e){return function(e){const t=(0,r.k6)();return(0,o.useSyncExternalStore)(t.listen,(()=>e(t)),(()=>e(t)))}((t=>null===e?null:new URLSearchParams(t.location.search).get(e)))}function l(e){const t=c(e)??"",n=function(){const e=(0,r.k6)();return(0,a.useCallback)(((t,n,a)=>{const r=new URLSearchParams(e.location.search);n?r.set(t,n):r.delete(t),(a?.push?e.push:e.replace)({search:r.toString()})}),[e])}();return[t,(0,a.useCallback)(((t,a)=>{n(e,t,a)}),[n,e])]}},10833:(e,t,n)=>{"use strict";n.d(t,{FG:()=>p,d:()=>u,VC:()=>f});var a=n(67294),r=n(86010),o=n(35742),i=n(30226);function s(){const e=a.useContext(i._);if(!e)throw new Error("Unexpected: no Docusaurus route context found");return e}var c=n(44996),l=n(82128);function u(e){let{title:t,description:n,keywords:r,image:i,children:s}=e;const u=(0,l.p)(t),{withBaseUrl:d}=(0,c.C)(),p=i?d(i,{absolute:!0}):void 0;return a.createElement(o.Z,null,t&&a.createElement("title",null,u),t&&a.createElement("meta",{property:"og:title",content:u}),n&&a.createElement("meta",{name:"description",content:n}),n&&a.createElement("meta",{property:"og:description",content:n}),r&&a.createElement("meta",{name:"keywords",content:Array.isArray(r)?r.join(","):r}),p&&a.createElement("meta",{property:"og:image",content:p}),p&&a.createElement("meta",{name:"twitter:image",content:p}),s)}const d=a.createContext(void 0);function p(e){let{className:t,children:n}=e;const i=a.useContext(d),s=(0,r.Z)(i,t);return a.createElement(d.Provider,{value:s},a.createElement(o.Z,null,a.createElement("html",{className:s})),n)}function f(e){let{children:t}=e;const n=s(),o=`plugin-${n.plugin.name.replace(/docusaurus-(?:plugin|theme)-(?:content-)?/gi,"")}`;const i=`plugin-id-${n.plugin.id}`;return a.createElement(p,{className:(0,r.Z)(o,i)},t)}},902:(e,t,n)=>{"use strict";n.d(t,{D9:()=>i,Qc:()=>l,Ql:()=>c,i6:()=>s,zX:()=>o});var a=n(67294);const r=n(10412).Z.canUseDOM?a.useLayoutEffect:a.useEffect;function o(e){const t=(0,a.useRef)(e);return r((()=>{t.current=e}),[e]),(0,a.useCallback)((function(){return t.current(...arguments)}),[])}function i(e){const t=(0,a.useRef)();return r((()=>{t.current=e})),t.current}class s extends Error{constructor(e,t){super(),this.name="ReactContextError",this.message=`Hook ${this.stack?.split("\n")[1]?.match(/at (?:\w+\.)?(?\w+)/)?.groups.name??""} is called outside the <${e}>. ${t??""}`}}function c(e){const t=Object.entries(e);return t.sort(((e,t)=>e[0].localeCompare(t[0]))),(0,a.useMemo)((()=>e),t.flat())}function l(e){return t=>{let{children:n}=t;return a.createElement(a.Fragment,null,e.reduceRight(((e,t)=>a.createElement(t,null,e)),n))}}},98022:(e,t,n)=>{"use strict";function a(e,t){return void 0!==e&&void 0!==t&&new RegExp(e,"gi").test(t)}n.d(t,{F:()=>a})},48596:(e,t,n)=>{"use strict";n.d(t,{Mg:()=>i,Ns:()=>s});var a=n(67294),r=n(723),o=n(52263);function i(e,t){const n=e=>(!e||e.endsWith("/")?e:`${e}/`)?.toLowerCase();return n(e)===n(t)}function s(){const{baseUrl:e}=(0,o.Z)().siteConfig;return(0,a.useMemo)((()=>function(e){let{baseUrl:t,routes:n}=e;function a(e){return e.path===t&&!0===e.exact}function r(e){return e.path===t&&!e.exact}return function e(t){if(0===t.length)return;return t.find(a)||e(t.filter(r).flatMap((e=>e.routes??[])))}(n)}({routes:r.Z,baseUrl:e})),[e])}},12466:(e,t,n)=>{"use strict";n.d(t,{Ct:()=>p,OC:()=>c,RF:()=>d});var a=n(67294),r=n(10412),o=n(72389),i=n(902);const s=a.createContext(void 0);function c(e){let{children:t}=e;const n=function(){const e=(0,a.useRef)(!0);return(0,a.useMemo)((()=>({scrollEventsEnabledRef:e,enableScrollEvents:()=>{e.current=!0},disableScrollEvents:()=>{e.current=!1}})),[])}();return a.createElement(s.Provider,{value:n},t)}function l(){const e=(0,a.useContext)(s);if(null==e)throw new i.i6("ScrollControllerProvider");return e}const u=()=>r.Z.canUseDOM?{scrollX:window.pageXOffset,scrollY:window.pageYOffset}:null;function d(e,t){void 0===t&&(t=[]);const{scrollEventsEnabledRef:n}=l(),r=(0,a.useRef)(u()),o=(0,i.zX)(e);(0,a.useEffect)((()=>{const e=()=>{if(!n.current)return;const e=u();o(e,r.current),r.current=e},t={passive:!0};return e(),window.addEventListener("scroll",e,t),()=>window.removeEventListener("scroll",e,t)}),[o,n,...t])}function p(){const e=(0,a.useRef)(null),t=(0,o.Z)()&&"smooth"===getComputedStyle(document.documentElement).scrollBehavior;return{startScroll:n=>{e.current=t?function(e){return window.scrollTo({top:e,behavior:"smooth"}),()=>{}}(n):function(e){let t=null;const n=document.documentElement.scrollTop>e;return function a(){const r=document.documentElement.scrollTop;(n&&r>e||!n&&rt&&cancelAnimationFrame(t)}(n)},cancelScroll:()=>e.current?.()}}},43320:(e,t,n)=>{"use strict";n.d(t,{HX:()=>i,_q:()=>c,os:()=>s});var a=n(80143),r=n(52263),o=n(60373);const i="default";function s(e,t){return`docs-${e}-${t}`}function c(){const{i18n:e}=(0,r.Z)(),t=(0,a._r)(),n=(0,a.WS)(),c=(0,o.Oh)();const l=[i,...Object.keys(t).map((function(e){const a=n?.activePlugin.pluginId===e?n.activeVersion:void 0,r=c[e],o=t[e].versions.find((e=>e.isLast));return s(e,(a??r??o).name)}))];return{locale:e.currentLocale,tags:l}}},50012:(e,t,n)=>{"use strict";n.d(t,{WA:()=>c});n(67294),n(61688);const a="localStorage";function r(e){let{key:t,oldValue:n,newValue:a,storage:r}=e;if(n===a)return;const o=document.createEvent("StorageEvent");o.initStorageEvent("storage",!1,!1,t,n,a,window.location.href,r),window.dispatchEvent(o)}function o(e){if(void 0===e&&(e=a),"undefined"==typeof window)throw new Error("Browser storage is not available on Node.js/Docusaurus SSR process.");if("none"===e)return null;try{return window[e]}catch(n){return t=n,i||(console.warn("Docusaurus browser storage is not available.\nPossible reasons: running Docusaurus in an iframe, in an incognito browser session, or using too strict browser privacy settings.",t),i=!0),null}var t}let i=!1;const s={get:()=>null,set:()=>{},del:()=>{},listen:()=>()=>{}};function c(e,t){if("undefined"==typeof window)return function(e){function t(){throw new Error(`Illegal storage API usage for storage key "${e}".\nDocusaurus storage APIs are not supposed to be called on the server-rendering process.\nPlease only call storage APIs in effects and event handlers.`)}return{get:t,set:t,del:t,listen:t}}(e);const n=o(t?.persistence);return null===n?s:{get:()=>{try{return n.getItem(e)}catch(t){return console.error(`Docusaurus storage error, can't get key=${e}`,t),null}},set:t=>{try{const a=n.getItem(e);n.setItem(e,t),r({key:e,oldValue:a,newValue:t,storage:n})}catch(a){console.error(`Docusaurus storage error, can't set ${e}=${t}`,a)}},del:()=>{try{const t=n.getItem(e);n.removeItem(e),r({key:e,oldValue:t,newValue:null,storage:n})}catch(t){console.error(`Docusaurus storage error, can't delete key=${e}`,t)}},listen:t=>{try{const a=a=>{a.storageArea===n&&a.key===e&&t(a)};return window.addEventListener("storage",a),()=>window.removeEventListener("storage",a)}catch(a){return console.error(`Docusaurus storage error, can't listen for changes of key=${e}`,a),()=>{}}}}}},94711:(e,t,n)=>{"use strict";n.d(t,{l:()=>o});var a=n(52263),r=n(16550);function o(){const{siteConfig:{baseUrl:e,url:t},i18n:{defaultLocale:n,currentLocale:o}}=(0,a.Z)(),{pathname:i}=(0,r.TH)(),s=o===n?e:e.replace(`/${o}/`,"/"),c=i.replace(e,"");return{createUrl:function(e){let{locale:a,fullyQualified:r}=e;return`${r?t:""}${function(e){return e===n?`${s}`:`${s}${e}/`}(a)}${c}`}}}},85936:(e,t,n)=>{"use strict";n.d(t,{S:()=>i});var a=n(67294),r=n(16550),o=n(902);function i(e){const t=(0,r.TH)(),n=(0,o.D9)(t),i=(0,o.zX)(e);(0,a.useEffect)((()=>{n&&t!==n&&i({location:t,previousLocation:n})}),[i,t,n])}},86668:(e,t,n)=>{"use strict";n.d(t,{L:()=>r});var a=n(52263);function r(){return(0,a.Z)().siteConfig.themeConfig}},6278:(e,t,n)=>{"use strict";n.d(t,{L:()=>r});var a=n(52263);function r(){const{siteConfig:{themeConfig:e}}=(0,a.Z)();return e}},239:(e,t,n)=>{"use strict";n.d(t,{l:()=>s});var a=n(67294),r=n(98022),o=n(44996),i=n(6278);function s(){const{withBaseUrl:e}=(0,o.C)(),{algolia:{externalUrlRegex:t,replaceSearchResultPathname:n}}=(0,i.L)();return(0,a.useCallback)((a=>{const o=new URL(a);if((0,r.F)(t,o.href))return a;const i=`${o.pathname+o.hash}`;return e(function(e,t){return t?e.replaceAll(new RegExp(t.from,"g"),t.to):e}(i,n))}),[e,t,n])}},8802:(e,t)=>{"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e,t){const{trailingSlash:n,baseUrl:a}=t;if(e.startsWith("#"))return e;if(void 0===n)return e;const[r]=e.split(/[#?]/),o="/"===r||r===a?r:(i=r,n?function(e){return e.endsWith("/")?e:`${e}/`}(i):function(e){return e.endsWith("/")?e.slice(0,-1):e}(i));var i;return e.replace(r,o)}},54143:(e,t)=>{"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.getErrorCausalChain=void 0,t.getErrorCausalChain=function e(t){return t.cause?[t,...e(t.cause)]:[t]}},18780:function(e,t,n){"use strict";var a=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(t,"__esModule",{value:!0}),t.getErrorCausalChain=t.applyTrailingSlash=t.blogPostContainerID=void 0,t.blogPostContainerID="__blog-post-container";var r=n(8802);Object.defineProperty(t,"applyTrailingSlash",{enumerable:!0,get:function(){return a(r).default}});var o=n(54143);Object.defineProperty(t,"getErrorCausalChain",{enumerable:!0,get:function(){return o.getErrorCausalChain}})},86010:(e,t,n)=>{"use strict";function a(e){var t,n,r="";if("string"==typeof e||"number"==typeof e)r+=e;else if("object"==typeof e)if(Array.isArray(e))for(t=0;tr});const r=function(){for(var e,t,n=0,r="";n{"use strict";n.d(t,{lX:()=>v,q_:()=>C,ob:()=>f,PP:()=>A,Ep:()=>p});var a=n(87462);function r(e){return"/"===e.charAt(0)}function o(e,t){for(var n=t,a=n+1,r=e.length;a=0;p--){var f=i[p];"."===f?o(i,p):".."===f?(o(i,p),d++):d&&(o(i,p),d--)}if(!l)for(;d--;d)i.unshift("..");!l||""===i[0]||i[0]&&r(i[0])||i.unshift("");var m=i.join("/");return n&&"/"!==m.substr(-1)&&(m+="/"),m};var s=n(38776);function c(e){return"/"===e.charAt(0)?e:"/"+e}function l(e){return"/"===e.charAt(0)?e.substr(1):e}function u(e,t){return function(e,t){return 0===e.toLowerCase().indexOf(t.toLowerCase())&&-1!=="/?#".indexOf(e.charAt(t.length))}(e,t)?e.substr(t.length):e}function d(e){return"/"===e.charAt(e.length-1)?e.slice(0,-1):e}function p(e){var t=e.pathname,n=e.search,a=e.hash,r=t||"/";return n&&"?"!==n&&(r+="?"===n.charAt(0)?n:"?"+n),a&&"#"!==a&&(r+="#"===a.charAt(0)?a:"#"+a),r}function f(e,t,n,r){var o;"string"==typeof e?(o=function(e){var t=e||"/",n="",a="",r=t.indexOf("#");-1!==r&&(a=t.substr(r),t=t.substr(0,r));var o=t.indexOf("?");return-1!==o&&(n=t.substr(o),t=t.substr(0,o)),{pathname:t,search:"?"===n?"":n,hash:"#"===a?"":a}}(e),o.state=t):(void 0===(o=(0,a.Z)({},e)).pathname&&(o.pathname=""),o.search?"?"!==o.search.charAt(0)&&(o.search="?"+o.search):o.search="",o.hash?"#"!==o.hash.charAt(0)&&(o.hash="#"+o.hash):o.hash="",void 0!==t&&void 0===o.state&&(o.state=t));try{o.pathname=decodeURI(o.pathname)}catch(s){throw s instanceof URIError?new URIError('Pathname "'+o.pathname+'" could not be decoded. This is likely caused by an invalid percent-encoding.'):s}return n&&(o.key=n),r?o.pathname?"/"!==o.pathname.charAt(0)&&(o.pathname=i(o.pathname,r.pathname)):o.pathname=r.pathname:o.pathname||(o.pathname="/"),o}function m(){var e=null;var t=[];return{setPrompt:function(t){return e=t,function(){e===t&&(e=null)}},confirmTransitionTo:function(t,n,a,r){if(null!=e){var o="function"==typeof e?e(t,n):e;"string"==typeof o?"function"==typeof a?a(o,r):r(!0):r(!1!==o)}else r(!0)},appendListener:function(e){var n=!0;function a(){n&&e.apply(void 0,arguments)}return t.push(a),function(){n=!1,t=t.filter((function(e){return e!==a}))}},notifyListeners:function(){for(var e=arguments.length,n=new Array(e),a=0;at?n.splice(t,n.length-t,r):n.push(r),d({action:a,location:r,index:t,entries:n})}}))},replace:function(e,t){var a="REPLACE",r=f(e,t,g(),v.location);u.confirmTransitionTo(r,a,n,(function(e){e&&(v.entries[v.index]=r,d({action:a,location:r}))}))},go:w,goBack:function(){w(-1)},goForward:function(){w(1)},canGo:function(e){var t=v.index+e;return t>=0&&t{"use strict";var a=n(59864),r={childContextTypes:!0,contextType:!0,contextTypes:!0,defaultProps:!0,displayName:!0,getDefaultProps:!0,getDerivedStateFromError:!0,getDerivedStateFromProps:!0,mixins:!0,propTypes:!0,type:!0},o={name:!0,length:!0,prototype:!0,caller:!0,callee:!0,arguments:!0,arity:!0},i={$$typeof:!0,compare:!0,defaultProps:!0,displayName:!0,propTypes:!0,type:!0},s={};function c(e){return a.isMemo(e)?i:s[e.$$typeof]||r}s[a.ForwardRef]={$$typeof:!0,render:!0,defaultProps:!0,displayName:!0,propTypes:!0},s[a.Memo]=i;var l=Object.defineProperty,u=Object.getOwnPropertyNames,d=Object.getOwnPropertySymbols,p=Object.getOwnPropertyDescriptor,f=Object.getPrototypeOf,m=Object.prototype;e.exports=function e(t,n,a){if("string"!=typeof n){if(m){var r=f(n);r&&r!==m&&e(t,r,a)}var i=u(n);d&&(i=i.concat(d(n)));for(var s=c(t),g=c(n),h=0;h{"use strict";e.exports=function(e,t,n,a,r,o,i,s){if(!e){var c;if(void 0===t)c=new Error("Minified exception occurred; use the non-minified dev environment for the full error message and additional helpful warnings.");else{var l=[n,a,r,o,i,s],u=0;(c=new Error(t.replace(/%s/g,(function(){return l[u++]})))).name="Invariant Violation"}throw c.framesToPop=1,c}}},5826:e=>{e.exports=Array.isArray||function(e){return"[object Array]"==Object.prototype.toString.call(e)}},32497:(e,t,n)=>{"use strict";n.r(t)},52295:(e,t,n)=>{"use strict";n.r(t)},74865:function(e,t,n){var a,r;a=function(){var e,t,n={version:"0.2.0"},a=n.settings={minimum:.08,easing:"ease",positionUsing:"",speed:200,trickle:!0,trickleRate:.02,trickleSpeed:800,showSpinner:!0,barSelector:'[role="bar"]',spinnerSelector:'[role="spinner"]',parent:"body",template:'
'};function r(e,t,n){return en?n:e}function o(e){return 100*(-1+e)}function i(e,t,n){var r;return(r="translate3d"===a.positionUsing?{transform:"translate3d("+o(e)+"%,0,0)"}:"translate"===a.positionUsing?{transform:"translate("+o(e)+"%,0)"}:{"margin-left":o(e)+"%"}).transition="all "+t+"ms "+n,r}n.configure=function(e){var t,n;for(t in e)void 0!==(n=e[t])&&e.hasOwnProperty(t)&&(a[t]=n);return this},n.status=null,n.set=function(e){var t=n.isStarted();e=r(e,a.minimum,1),n.status=1===e?null:e;var o=n.render(!t),l=o.querySelector(a.barSelector),u=a.speed,d=a.easing;return o.offsetWidth,s((function(t){""===a.positionUsing&&(a.positionUsing=n.getPositioningCSS()),c(l,i(e,u,d)),1===e?(c(o,{transition:"none",opacity:1}),o.offsetWidth,setTimeout((function(){c(o,{transition:"all "+u+"ms linear",opacity:0}),setTimeout((function(){n.remove(),t()}),u)}),u)):setTimeout(t,u)})),this},n.isStarted=function(){return"number"==typeof n.status},n.start=function(){n.status||n.set(0);var e=function(){setTimeout((function(){n.status&&(n.trickle(),e())}),a.trickleSpeed)};return a.trickle&&e(),this},n.done=function(e){return e||n.status?n.inc(.3+.5*Math.random()).set(1):this},n.inc=function(e){var t=n.status;return t?("number"!=typeof e&&(e=(1-t)*r(Math.random()*t,.1,.95)),t=r(t+e,0,.994),n.set(t)):n.start()},n.trickle=function(){return n.inc(Math.random()*a.trickleRate)},e=0,t=0,n.promise=function(a){return a&&"resolved"!==a.state()?(0===t&&n.start(),e++,t++,a.always((function(){0==--t?(e=0,n.done()):n.set((e-t)/e)})),this):this},n.render=function(e){if(n.isRendered())return document.getElementById("nprogress");u(document.documentElement,"nprogress-busy");var t=document.createElement("div");t.id="nprogress",t.innerHTML=a.template;var r,i=t.querySelector(a.barSelector),s=e?"-100":o(n.status||0),l=document.querySelector(a.parent);return c(i,{transition:"all 0 linear",transform:"translate3d("+s+"%,0,0)"}),a.showSpinner||(r=t.querySelector(a.spinnerSelector))&&f(r),l!=document.body&&u(l,"nprogress-custom-parent"),l.appendChild(t),t},n.remove=function(){d(document.documentElement,"nprogress-busy"),d(document.querySelector(a.parent),"nprogress-custom-parent");var e=document.getElementById("nprogress");e&&f(e)},n.isRendered=function(){return!!document.getElementById("nprogress")},n.getPositioningCSS=function(){var e=document.body.style,t="WebkitTransform"in e?"Webkit":"MozTransform"in e?"Moz":"msTransform"in e?"ms":"OTransform"in e?"O":"";return t+"Perspective"in e?"translate3d":t+"Transform"in e?"translate":"margin"};var s=function(){var e=[];function t(){var n=e.shift();n&&n(t)}return function(n){e.push(n),1==e.length&&t()}}(),c=function(){var e=["Webkit","O","Moz","ms"],t={};function n(e){return e.replace(/^-ms-/,"ms-").replace(/-([\da-z])/gi,(function(e,t){return t.toUpperCase()}))}function a(t){var n=document.body.style;if(t in n)return t;for(var a,r=e.length,o=t.charAt(0).toUpperCase()+t.slice(1);r--;)if((a=e[r]+o)in n)return a;return t}function r(e){return e=n(e),t[e]||(t[e]=a(e))}function o(e,t,n){t=r(t),e.style[t]=n}return function(e,t){var n,a,r=arguments;if(2==r.length)for(n in t)void 0!==(a=t[n])&&t.hasOwnProperty(n)&&o(e,n,a);else o(e,r[1],r[2])}}();function l(e,t){return("string"==typeof e?e:p(e)).indexOf(" "+t+" ")>=0}function u(e,t){var n=p(e),a=n+t;l(n,t)||(e.className=a.substring(1))}function d(e,t){var n,a=p(e);l(e,t)&&(n=a.replace(" "+t+" "," "),e.className=n.substring(1,n.length-1))}function p(e){return(" "+(e.className||"")+" ").replace(/\s+/gi," ")}function f(e){e&&e.parentNode&&e.parentNode.removeChild(e)}return n},void 0===(r="function"==typeof a?a.call(t,n,t,e):a)||(e.exports=r)},27418:e=>{"use strict";var t=Object.getOwnPropertySymbols,n=Object.prototype.hasOwnProperty,a=Object.prototype.propertyIsEnumerable;e.exports=function(){try{if(!Object.assign)return!1;var e=new String("abc");if(e[5]="de","5"===Object.getOwnPropertyNames(e)[0])return!1;for(var t={},n=0;n<10;n++)t["_"+String.fromCharCode(n)]=n;if("0123456789"!==Object.getOwnPropertyNames(t).map((function(e){return t[e]})).join(""))return!1;var a={};return"abcdefghijklmnopqrst".split("").forEach((function(e){a[e]=e})),"abcdefghijklmnopqrst"===Object.keys(Object.assign({},a)).join("")}catch(r){return!1}}()?Object.assign:function(e,r){for(var o,i,s=function(e){if(null==e)throw new TypeError("Object.assign cannot be called with null or undefined");return Object(e)}(e),c=1;c{"use strict";n.d(t,{Z:()=>o});var a=function(){var e=/(?:^|\s)lang(?:uage)?-([\w-]+)(?=\s|$)/i,t=0,n={},a={util:{encode:function e(t){return t instanceof r?new r(t.type,e(t.content),t.alias):Array.isArray(t)?t.map(e):t.replace(/&/g,"&").replace(/=d.reach);x+=_.value.length,_=_.next){var E=_.value;if(t.length>e.length)return;if(!(E instanceof r)){var S,C=1;if(y){if(!(S=o(k,x,e,b))||S.index>=e.length)break;var T=S.index,A=S.index+S[0].length,L=x;for(L+=_.value.length;T>=L;)L+=(_=_.next).value.length;if(x=L-=_.value.length,_.value instanceof r)continue;for(var P=_;P!==t.tail&&(Ld.reach&&(d.reach=O);var I=_.prev;if(j&&(I=c(t,I,j),x+=j.length),l(t,I,C),_=c(t,I,new r(p,h?a.tokenize(R,h):R,w,R)),N&&c(t,_,N),C>1){var M={cause:p+","+m,reach:O};i(e,t,n,_.prev,x,M),d&&M.reach>d.reach&&(d.reach=M.reach)}}}}}}function s(){var e={value:null,prev:null,next:null},t={value:null,prev:e,next:null};e.next=t,this.head=e,this.tail=t,this.length=0}function c(e,t,n){var a=t.next,r={value:n,prev:t,next:a};return t.next=r,a.prev=r,e.length++,r}function l(e,t,n){for(var a=t.next,r=0;r"+o.content+""},a}(),r=a;a.default=a,r.languages.markup={comment:{pattern://,greedy:!0},prolog:{pattern:/<\?[\s\S]+?\?>/,greedy:!0},doctype:{pattern:/"'[\]]|"[^"]*"|'[^']*')+(?:\[(?:[^<"'\]]|"[^"]*"|'[^']*'|<(?!!--)|)*\]\s*)?>/i,greedy:!0,inside:{"internal-subset":{pattern:/(^[^\[]*\[)[\s\S]+(?=\]>$)/,lookbehind:!0,greedy:!0,inside:null},string:{pattern:/"[^"]*"|'[^']*'/,greedy:!0},punctuation:/^$|[[\]]/,"doctype-tag":/^DOCTYPE/i,name:/[^\s<>'"]+/}},cdata:{pattern://i,greedy:!0},tag:{pattern:/<\/?(?!\d)[^\s>\/=$<%]+(?:\s(?:\s*[^\s>\/=]+(?:\s*=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+(?=[\s>]))|(?=[\s/>])))+)?\s*\/?>/,greedy:!0,inside:{tag:{pattern:/^<\/?[^\s>\/]+/,inside:{punctuation:/^<\/?/,namespace:/^[^\s>\/:]+:/}},"special-attr":[],"attr-value":{pattern:/=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+)/,inside:{punctuation:[{pattern:/^=/,alias:"attr-equals"},/"|'/]}},punctuation:/\/?>/,"attr-name":{pattern:/[^\s>\/]+/,inside:{namespace:/^[^\s>\/:]+:/}}}},entity:[{pattern:/&[\da-z]{1,8};/i,alias:"named-entity"},/&#x?[\da-f]{1,8};/i]},r.languages.markup.tag.inside["attr-value"].inside.entity=r.languages.markup.entity,r.languages.markup.doctype.inside["internal-subset"].inside=r.languages.markup,r.hooks.add("wrap",(function(e){"entity"===e.type&&(e.attributes.title=e.content.replace(/&/,"&"))})),Object.defineProperty(r.languages.markup.tag,"addInlined",{value:function(e,t){var n={};n["language-"+t]={pattern:/(^$)/i,lookbehind:!0,inside:r.languages[t]},n.cdata=/^$/i;var a={"included-cdata":{pattern://i,inside:n}};a["language-"+t]={pattern:/[\s\S]+/,inside:r.languages[t]};var o={};o[e]={pattern:RegExp(/(<__[^>]*>)(?:))*\]\]>|(?!)/.source.replace(/__/g,(function(){return e})),"i"),lookbehind:!0,greedy:!0,inside:a},r.languages.insertBefore("markup","cdata",o)}}),Object.defineProperty(r.languages.markup.tag,"addAttribute",{value:function(e,t){r.languages.markup.tag.inside["special-attr"].push({pattern:RegExp(/(^|["'\s])/.source+"(?:"+e+")"+/\s*=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+(?=[\s>]))/.source,"i"),lookbehind:!0,inside:{"attr-name":/^[^\s=]+/,"attr-value":{pattern:/=[\s\S]+/,inside:{value:{pattern:/(^=\s*(["']|(?!["'])))\S[\s\S]*(?=\2$)/,lookbehind:!0,alias:[t,"language-"+t],inside:r.languages[t]},punctuation:[{pattern:/^=/,alias:"attr-equals"},/"|'/]}}}})}}),r.languages.html=r.languages.markup,r.languages.mathml=r.languages.markup,r.languages.svg=r.languages.markup,r.languages.xml=r.languages.extend("markup",{}),r.languages.ssml=r.languages.xml,r.languages.atom=r.languages.xml,r.languages.rss=r.languages.xml,function(e){var t="\\b(?:BASH|BASHOPTS|BASH_ALIASES|BASH_ARGC|BASH_ARGV|BASH_CMDS|BASH_COMPLETION_COMPAT_DIR|BASH_LINENO|BASH_REMATCH|BASH_SOURCE|BASH_VERSINFO|BASH_VERSION|COLORTERM|COLUMNS|COMP_WORDBREAKS|DBUS_SESSION_BUS_ADDRESS|DEFAULTS_PATH|DESKTOP_SESSION|DIRSTACK|DISPLAY|EUID|GDMSESSION|GDM_LANG|GNOME_KEYRING_CONTROL|GNOME_KEYRING_PID|GPG_AGENT_INFO|GROUPS|HISTCONTROL|HISTFILE|HISTFILESIZE|HISTSIZE|HOME|HOSTNAME|HOSTTYPE|IFS|INSTANCE|JOB|LANG|LANGUAGE|LC_ADDRESS|LC_ALL|LC_IDENTIFICATION|LC_MEASUREMENT|LC_MONETARY|LC_NAME|LC_NUMERIC|LC_PAPER|LC_TELEPHONE|LC_TIME|LESSCLOSE|LESSOPEN|LINES|LOGNAME|LS_COLORS|MACHTYPE|MAILCHECK|MANDATORY_PATH|NO_AT_BRIDGE|OLDPWD|OPTERR|OPTIND|ORBIT_SOCKETDIR|OSTYPE|PAPERSIZE|PATH|PIPESTATUS|PPID|PS1|PS2|PS3|PS4|PWD|RANDOM|REPLY|SECONDS|SELINUX_INIT|SESSION|SESSIONTYPE|SESSION_MANAGER|SHELL|SHELLOPTS|SHLVL|SSH_AUTH_SOCK|TERM|UID|UPSTART_EVENTS|UPSTART_INSTANCE|UPSTART_JOB|UPSTART_SESSION|USER|WINDOWID|XAUTHORITY|XDG_CONFIG_DIRS|XDG_CURRENT_DESKTOP|XDG_DATA_DIRS|XDG_GREETER_DATA_DIR|XDG_MENU_PREFIX|XDG_RUNTIME_DIR|XDG_SEAT|XDG_SEAT_PATH|XDG_SESSION_DESKTOP|XDG_SESSION_ID|XDG_SESSION_PATH|XDG_SESSION_TYPE|XDG_VTNR|XMODIFIERS)\\b",n={pattern:/(^(["']?)\w+\2)[ \t]+\S.*/,lookbehind:!0,alias:"punctuation",inside:null},a={bash:n,environment:{pattern:RegExp("\\$"+t),alias:"constant"},variable:[{pattern:/\$?\(\([\s\S]+?\)\)/,greedy:!0,inside:{variable:[{pattern:/(^\$\(\([\s\S]+)\)\)/,lookbehind:!0},/^\$\(\(/],number:/\b0x[\dA-Fa-f]+\b|(?:\b\d+(?:\.\d*)?|\B\.\d+)(?:[Ee]-?\d+)?/,operator:/--|\+\+|\*\*=?|<<=?|>>=?|&&|\|\||[=!+\-*/%<>^&|]=?|[?~:]/,punctuation:/\(\(?|\)\)?|,|;/}},{pattern:/\$\((?:\([^)]+\)|[^()])+\)|`[^`]+`/,greedy:!0,inside:{variable:/^\$\(|^`|\)$|`$/}},{pattern:/\$\{[^}]+\}/,greedy:!0,inside:{operator:/:[-=?+]?|[!\/]|##?|%%?|\^\^?|,,?/,punctuation:/[\[\]]/,environment:{pattern:RegExp("(\\{)"+t),lookbehind:!0,alias:"constant"}}},/\$(?:\w+|[#?*!@$])/],entity:/\\(?:[abceEfnrtv\\"]|O?[0-7]{1,3}|U[0-9a-fA-F]{8}|u[0-9a-fA-F]{4}|x[0-9a-fA-F]{1,2})/};e.languages.bash={shebang:{pattern:/^#!\s*\/.*/,alias:"important"},comment:{pattern:/(^|[^"{\\$])#.*/,lookbehind:!0},"function-name":[{pattern:/(\bfunction\s+)[\w-]+(?=(?:\s*\(?:\s*\))?\s*\{)/,lookbehind:!0,alias:"function"},{pattern:/\b[\w-]+(?=\s*\(\s*\)\s*\{)/,alias:"function"}],"for-or-select":{pattern:/(\b(?:for|select)\s+)\w+(?=\s+in\s)/,alias:"variable",lookbehind:!0},"assign-left":{pattern:/(^|[\s;|&]|[<>]\()\w+(?=\+?=)/,inside:{environment:{pattern:RegExp("(^|[\\s;|&]|[<>]\\()"+t),lookbehind:!0,alias:"constant"}},alias:"variable",lookbehind:!0},string:[{pattern:/((?:^|[^<])<<-?\s*)(\w+)\s[\s\S]*?(?:\r?\n|\r)\2/,lookbehind:!0,greedy:!0,inside:a},{pattern:/((?:^|[^<])<<-?\s*)(["'])(\w+)\2\s[\s\S]*?(?:\r?\n|\r)\3/,lookbehind:!0,greedy:!0,inside:{bash:n}},{pattern:/(^|[^\\](?:\\\\)*)"(?:\\[\s\S]|\$\([^)]+\)|\$(?!\()|`[^`]+`|[^"\\`$])*"/,lookbehind:!0,greedy:!0,inside:a},{pattern:/(^|[^$\\])'[^']*'/,lookbehind:!0,greedy:!0},{pattern:/\$'(?:[^'\\]|\\[\s\S])*'/,greedy:!0,inside:{entity:a.entity}}],environment:{pattern:RegExp("\\$?"+t),alias:"constant"},variable:a.variable,function:{pattern:/(^|[\s;|&]|[<>]\()(?:add|apropos|apt|apt-cache|apt-get|aptitude|aspell|automysqlbackup|awk|basename|bash|bc|bconsole|bg|bzip2|cal|cat|cfdisk|chgrp|chkconfig|chmod|chown|chroot|cksum|clear|cmp|column|comm|composer|cp|cron|crontab|csplit|curl|cut|date|dc|dd|ddrescue|debootstrap|df|diff|diff3|dig|dir|dircolors|dirname|dirs|dmesg|docker|docker-compose|du|egrep|eject|env|ethtool|expand|expect|expr|fdformat|fdisk|fg|fgrep|file|find|fmt|fold|format|free|fsck|ftp|fuser|gawk|git|gparted|grep|groupadd|groupdel|groupmod|groups|grub-mkconfig|gzip|halt|head|hg|history|host|hostname|htop|iconv|id|ifconfig|ifdown|ifup|import|install|ip|jobs|join|kill|killall|less|link|ln|locate|logname|logrotate|look|lpc|lpr|lprint|lprintd|lprintq|lprm|ls|lsof|lynx|make|man|mc|mdadm|mkconfig|mkdir|mke2fs|mkfifo|mkfs|mkisofs|mknod|mkswap|mmv|more|most|mount|mtools|mtr|mutt|mv|nano|nc|netstat|nice|nl|node|nohup|notify-send|npm|nslookup|op|open|parted|passwd|paste|pathchk|ping|pkill|pnpm|podman|podman-compose|popd|pr|printcap|printenv|ps|pushd|pv|quota|quotacheck|quotactl|ram|rar|rcp|reboot|remsync|rename|renice|rev|rm|rmdir|rpm|rsync|scp|screen|sdiff|sed|sendmail|seq|service|sftp|sh|shellcheck|shuf|shutdown|sleep|slocate|sort|split|ssh|stat|strace|su|sudo|sum|suspend|swapon|sync|tac|tail|tar|tee|time|timeout|top|touch|tr|traceroute|tsort|tty|umount|uname|unexpand|uniq|units|unrar|unshar|unzip|update-grub|uptime|useradd|userdel|usermod|users|uudecode|uuencode|v|vcpkg|vdir|vi|vim|virsh|vmstat|wait|watch|wc|wget|whereis|which|who|whoami|write|xargs|xdg-open|yarn|yes|zenity|zip|zsh|zypper)(?=$|[)\s;|&])/,lookbehind:!0},keyword:{pattern:/(^|[\s;|&]|[<>]\()(?:case|do|done|elif|else|esac|fi|for|function|if|in|select|then|until|while)(?=$|[)\s;|&])/,lookbehind:!0},builtin:{pattern:/(^|[\s;|&]|[<>]\()(?:\.|:|alias|bind|break|builtin|caller|cd|command|continue|declare|echo|enable|eval|exec|exit|export|getopts|hash|help|let|local|logout|mapfile|printf|pwd|read|readarray|readonly|return|set|shift|shopt|source|test|times|trap|type|typeset|ulimit|umask|unalias|unset)(?=$|[)\s;|&])/,lookbehind:!0,alias:"class-name"},boolean:{pattern:/(^|[\s;|&]|[<>]\()(?:false|true)(?=$|[)\s;|&])/,lookbehind:!0},"file-descriptor":{pattern:/\B&\d\b/,alias:"important"},operator:{pattern:/\d?<>|>\||\+=|=[=~]?|!=?|<<[<-]?|[&\d]?>>|\d[<>]&?|[<>][&=]?|&[>&]?|\|[&|]?/,inside:{"file-descriptor":{pattern:/^\d/,alias:"important"}}},punctuation:/\$?\(\(?|\)\)?|\.\.|[{}[\];\\]/,number:{pattern:/(^|\s)(?:[1-9]\d*|0)(?:[.,]\d+)?\b/,lookbehind:!0}},n.inside=e.languages.bash;for(var r=["comment","function-name","for-or-select","assign-left","string","environment","function","keyword","builtin","boolean","file-descriptor","operator","punctuation","number"],o=a.variable[1].inside,i=0;i]=?|[!=]=?=?|--?|\+\+?|&&?|\|\|?|[?*/~^%]/,punctuation:/[{}[\];(),.:]/},r.languages.c=r.languages.extend("clike",{comment:{pattern:/\/\/(?:[^\r\n\\]|\\(?:\r\n?|\n|(?![\r\n])))*|\/\*[\s\S]*?(?:\*\/|$)/,greedy:!0},string:{pattern:/"(?:\\(?:\r\n|[\s\S])|[^"\\\r\n])*"/,greedy:!0},"class-name":{pattern:/(\b(?:enum|struct)\s+(?:__attribute__\s*\(\([\s\S]*?\)\)\s*)?)\w+|\b[a-z]\w*_t\b/,lookbehind:!0},keyword:/\b(?:_Alignas|_Alignof|_Atomic|_Bool|_Complex|_Generic|_Imaginary|_Noreturn|_Static_assert|_Thread_local|__attribute__|asm|auto|break|case|char|const|continue|default|do|double|else|enum|extern|float|for|goto|if|inline|int|long|register|return|short|signed|sizeof|static|struct|switch|typedef|typeof|union|unsigned|void|volatile|while)\b/,function:/\b[a-z_]\w*(?=\s*\()/i,number:/(?:\b0x(?:[\da-f]+(?:\.[\da-f]*)?|\.[\da-f]+)(?:p[+-]?\d+)?|(?:\b\d+(?:\.\d*)?|\B\.\d+)(?:e[+-]?\d+)?)[ful]{0,4}/i,operator:/>>=?|<<=?|->|([-+&|:])\1|[?:~]|[-+*/%&|^!=<>]=?/}),r.languages.insertBefore("c","string",{char:{pattern:/'(?:\\(?:\r\n|[\s\S])|[^'\\\r\n]){0,32}'/,greedy:!0}}),r.languages.insertBefore("c","string",{macro:{pattern:/(^[\t ]*)#\s*[a-z](?:[^\r\n\\/]|\/(?!\*)|\/\*(?:[^*]|\*(?!\/))*\*\/|\\(?:\r\n|[\s\S]))*/im,lookbehind:!0,greedy:!0,alias:"property",inside:{string:[{pattern:/^(#\s*include\s*)<[^>]+>/,lookbehind:!0},r.languages.c.string],char:r.languages.c.char,comment:r.languages.c.comment,"macro-name":[{pattern:/(^#\s*define\s+)\w+\b(?!\()/i,lookbehind:!0},{pattern:/(^#\s*define\s+)\w+\b(?=\()/i,lookbehind:!0,alias:"function"}],directive:{pattern:/^(#\s*)[a-z]+/,lookbehind:!0,alias:"keyword"},"directive-hash":/^#/,punctuation:/##|\\(?=[\r\n])/,expression:{pattern:/\S[\s\S]*/,inside:r.languages.c}}}}),r.languages.insertBefore("c","function",{constant:/\b(?:EOF|NULL|SEEK_CUR|SEEK_END|SEEK_SET|__DATE__|__FILE__|__LINE__|__TIMESTAMP__|__TIME__|__func__|stderr|stdin|stdout)\b/}),delete r.languages.c.boolean,function(e){var t=/\b(?:alignas|alignof|asm|auto|bool|break|case|catch|char|char16_t|char32_t|char8_t|class|co_await|co_return|co_yield|compl|concept|const|const_cast|consteval|constexpr|constinit|continue|decltype|default|delete|do|double|dynamic_cast|else|enum|explicit|export|extern|final|float|for|friend|goto|if|import|inline|int|int16_t|int32_t|int64_t|int8_t|long|module|mutable|namespace|new|noexcept|nullptr|operator|override|private|protected|public|register|reinterpret_cast|requires|return|short|signed|sizeof|static|static_assert|static_cast|struct|switch|template|this|thread_local|throw|try|typedef|typeid|typename|uint16_t|uint32_t|uint64_t|uint8_t|union|unsigned|using|virtual|void|volatile|wchar_t|while)\b/,n=/\b(?!)\w+(?:\s*\.\s*\w+)*\b/.source.replace(//g,(function(){return t.source}));e.languages.cpp=e.languages.extend("c",{"class-name":[{pattern:RegExp(/(\b(?:class|concept|enum|struct|typename)\s+)(?!)\w+/.source.replace(//g,(function(){return t.source}))),lookbehind:!0},/\b[A-Z]\w*(?=\s*::\s*\w+\s*\()/,/\b[A-Z_]\w*(?=\s*::\s*~\w+\s*\()/i,/\b\w+(?=\s*<(?:[^<>]|<(?:[^<>]|<[^<>]*>)*>)*>\s*::\s*\w+\s*\()/],keyword:t,number:{pattern:/(?:\b0b[01']+|\b0x(?:[\da-f']+(?:\.[\da-f']*)?|\.[\da-f']+)(?:p[+-]?[\d']+)?|(?:\b[\d']+(?:\.[\d']*)?|\B\.[\d']+)(?:e[+-]?[\d']+)?)[ful]{0,4}/i,greedy:!0},operator:/>>=?|<<=?|->|--|\+\+|&&|\|\||[?:~]|<=>|[-+*/%&|^!=<>]=?|\b(?:and|and_eq|bitand|bitor|not|not_eq|or|or_eq|xor|xor_eq)\b/,boolean:/\b(?:false|true)\b/}),e.languages.insertBefore("cpp","string",{module:{pattern:RegExp(/(\b(?:import|module)\s+)/.source+"(?:"+/"(?:\\(?:\r\n|[\s\S])|[^"\\\r\n])*"|<[^<>\r\n]*>/.source+"|"+/(?:\s*:\s*)?|:\s*/.source.replace(//g,(function(){return n}))+")"),lookbehind:!0,greedy:!0,inside:{string:/^[<"][\s\S]+/,operator:/:/,punctuation:/\./}},"raw-string":{pattern:/R"([^()\\ ]{0,16})\([\s\S]*?\)\1"/,alias:"string",greedy:!0}}),e.languages.insertBefore("cpp","keyword",{"generic-function":{pattern:/\b(?!operator\b)[a-z_]\w*\s*<(?:[^<>]|<[^<>]*>)*>(?=\s*\()/i,inside:{function:/^\w+/,generic:{pattern:/<[\s\S]+/,alias:"class-name",inside:e.languages.cpp}}}}),e.languages.insertBefore("cpp","operator",{"double-colon":{pattern:/::/,alias:"punctuation"}}),e.languages.insertBefore("cpp","class-name",{"base-clause":{pattern:/(\b(?:class|struct)\s+\w+\s*:\s*)[^;{}"'\s]+(?:\s+[^;{}"'\s]+)*(?=\s*[;{])/,lookbehind:!0,greedy:!0,inside:e.languages.extend("cpp",{})}}),e.languages.insertBefore("inside","double-colon",{"class-name":/\b[a-z_]\w*\b(?!\s*::)/i},e.languages.cpp["base-clause"])}(r),function(e){var t=/(?:"(?:\\(?:\r\n|[\s\S])|[^"\\\r\n])*"|'(?:\\(?:\r\n|[\s\S])|[^'\\\r\n])*')/;e.languages.css={comment:/\/\*[\s\S]*?\*\//,atrule:{pattern:/@[\w-](?:[^;{\s]|\s+(?![\s{]))*(?:;|(?=\s*\{))/,inside:{rule:/^@[\w-]+/,"selector-function-argument":{pattern:/(\bselector\s*\(\s*(?![\s)]))(?:[^()\s]|\s+(?![\s)])|\((?:[^()]|\([^()]*\))*\))+(?=\s*\))/,lookbehind:!0,alias:"selector"},keyword:{pattern:/(^|[^\w-])(?:and|not|only|or)(?![\w-])/,lookbehind:!0}}},url:{pattern:RegExp("\\burl\\((?:"+t.source+"|"+/(?:[^\\\r\n()"']|\\[\s\S])*/.source+")\\)","i"),greedy:!0,inside:{function:/^url/i,punctuation:/^\(|\)$/,string:{pattern:RegExp("^"+t.source+"$"),alias:"url"}}},selector:{pattern:RegExp("(^|[{}\\s])[^{}\\s](?:[^{};\"'\\s]|\\s+(?![\\s{])|"+t.source+")*(?=\\s*\\{)"),lookbehind:!0},string:{pattern:t,greedy:!0},property:{pattern:/(^|[^-\w\xA0-\uFFFF])(?!\s)[-_a-z\xA0-\uFFFF](?:(?!\s)[-\w\xA0-\uFFFF])*(?=\s*:)/i,lookbehind:!0},important:/!important\b/i,function:{pattern:/(^|[^-a-z0-9])[-a-z0-9]+(?=\()/i,lookbehind:!0},punctuation:/[(){};:,]/},e.languages.css.atrule.inside.rest=e.languages.css;var n=e.languages.markup;n&&(n.tag.addInlined("style","css"),n.tag.addAttribute("style","css"))}(r),function(e){var t,n=/("|')(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/;e.languages.css.selector={pattern:e.languages.css.selector.pattern,lookbehind:!0,inside:t={"pseudo-element":/:(?:after|before|first-letter|first-line|selection)|::[-\w]+/,"pseudo-class":/:[-\w]+/,class:/\.[-\w]+/,id:/#[-\w]+/,attribute:{pattern:RegExp("\\[(?:[^[\\]\"']|"+n.source+")*\\]"),greedy:!0,inside:{punctuation:/^\[|\]$/,"case-sensitivity":{pattern:/(\s)[si]$/i,lookbehind:!0,alias:"keyword"},namespace:{pattern:/^(\s*)(?:(?!\s)[-*\w\xA0-\uFFFF])*\|(?!=)/,lookbehind:!0,inside:{punctuation:/\|$/}},"attr-name":{pattern:/^(\s*)(?:(?!\s)[-\w\xA0-\uFFFF])+/,lookbehind:!0},"attr-value":[n,{pattern:/(=\s*)(?:(?!\s)[-\w\xA0-\uFFFF])+(?=\s*$)/,lookbehind:!0}],operator:/[|~*^$]?=/}},"n-th":[{pattern:/(\(\s*)[+-]?\d*[\dn](?:\s*[+-]\s*\d+)?(?=\s*\))/,lookbehind:!0,inside:{number:/[\dn]+/,operator:/[+-]/}},{pattern:/(\(\s*)(?:even|odd)(?=\s*\))/i,lookbehind:!0}],combinator:/>|\+|~|\|\|/,punctuation:/[(),]/}},e.languages.css.atrule.inside["selector-function-argument"].inside=t,e.languages.insertBefore("css","property",{variable:{pattern:/(^|[^-\w\xA0-\uFFFF])--(?!\s)[-_a-z\xA0-\uFFFF](?:(?!\s)[-\w\xA0-\uFFFF])*/i,lookbehind:!0}});var a={pattern:/(\b\d+)(?:%|[a-z]+(?![\w-]))/,lookbehind:!0},r={pattern:/(^|[^\w.-])-?(?:\d+(?:\.\d+)?|\.\d+)/,lookbehind:!0};e.languages.insertBefore("css","function",{operator:{pattern:/(\s)[+\-*\/](?=\s)/,lookbehind:!0},hexcode:{pattern:/\B#[\da-f]{3,8}\b/i,alias:"color"},color:[{pattern:/(^|[^\w-])(?:AliceBlue|AntiqueWhite|Aqua|Aquamarine|Azure|Beige|Bisque|Black|BlanchedAlmond|Blue|BlueViolet|Brown|BurlyWood|CadetBlue|Chartreuse|Chocolate|Coral|CornflowerBlue|Cornsilk|Crimson|Cyan|DarkBlue|DarkCyan|DarkGoldenRod|DarkGr[ae]y|DarkGreen|DarkKhaki|DarkMagenta|DarkOliveGreen|DarkOrange|DarkOrchid|DarkRed|DarkSalmon|DarkSeaGreen|DarkSlateBlue|DarkSlateGr[ae]y|DarkTurquoise|DarkViolet|DeepPink|DeepSkyBlue|DimGr[ae]y|DodgerBlue|FireBrick|FloralWhite|ForestGreen|Fuchsia|Gainsboro|GhostWhite|Gold|GoldenRod|Gr[ae]y|Green|GreenYellow|HoneyDew|HotPink|IndianRed|Indigo|Ivory|Khaki|Lavender|LavenderBlush|LawnGreen|LemonChiffon|LightBlue|LightCoral|LightCyan|LightGoldenRodYellow|LightGr[ae]y|LightGreen|LightPink|LightSalmon|LightSeaGreen|LightSkyBlue|LightSlateGr[ae]y|LightSteelBlue|LightYellow|Lime|LimeGreen|Linen|Magenta|Maroon|MediumAquaMarine|MediumBlue|MediumOrchid|MediumPurple|MediumSeaGreen|MediumSlateBlue|MediumSpringGreen|MediumTurquoise|MediumVioletRed|MidnightBlue|MintCream|MistyRose|Moccasin|NavajoWhite|Navy|OldLace|Olive|OliveDrab|Orange|OrangeRed|Orchid|PaleGoldenRod|PaleGreen|PaleTurquoise|PaleVioletRed|PapayaWhip|PeachPuff|Peru|Pink|Plum|PowderBlue|Purple|Red|RosyBrown|RoyalBlue|SaddleBrown|Salmon|SandyBrown|SeaGreen|SeaShell|Sienna|Silver|SkyBlue|SlateBlue|SlateGr[ae]y|Snow|SpringGreen|SteelBlue|Tan|Teal|Thistle|Tomato|Transparent|Turquoise|Violet|Wheat|White|WhiteSmoke|Yellow|YellowGreen)(?![\w-])/i,lookbehind:!0},{pattern:/\b(?:hsl|rgb)\(\s*\d{1,3}\s*,\s*\d{1,3}%?\s*,\s*\d{1,3}%?\s*\)\B|\b(?:hsl|rgb)a\(\s*\d{1,3}\s*,\s*\d{1,3}%?\s*,\s*\d{1,3}%?\s*,\s*(?:0|0?\.\d+|1)\s*\)\B/i,inside:{unit:a,number:r,function:/[\w-]+(?=\()/,punctuation:/[(),]/}}],entity:/\\[\da-f]{1,8}/i,unit:a,number:r})}(r),r.languages.javascript=r.languages.extend("clike",{"class-name":[r.languages.clike["class-name"],{pattern:/(^|[^$\w\xA0-\uFFFF])(?!\s)[_$A-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\.(?:constructor|prototype))/,lookbehind:!0}],keyword:[{pattern:/((?:^|\})\s*)catch\b/,lookbehind:!0},{pattern:/(^|[^.]|\.\.\.\s*)\b(?:as|assert(?=\s*\{)|async(?=\s*(?:function\b|\(|[$\w\xA0-\uFFFF]|$))|await|break|case|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally(?=\s*(?:\{|$))|for|from(?=\s*(?:['"]|$))|function|(?:get|set)(?=\s*(?:[#\[$\w\xA0-\uFFFF]|$))|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)\b/,lookbehind:!0}],function:/#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*(?:\.\s*(?:apply|bind|call)\s*)?\()/,number:{pattern:RegExp(/(^|[^\w$])/.source+"(?:"+/NaN|Infinity/.source+"|"+/0[bB][01]+(?:_[01]+)*n?/.source+"|"+/0[oO][0-7]+(?:_[0-7]+)*n?/.source+"|"+/0[xX][\dA-Fa-f]+(?:_[\dA-Fa-f]+)*n?/.source+"|"+/\d+(?:_\d+)*n/.source+"|"+/(?:\d+(?:_\d+)*(?:\.(?:\d+(?:_\d+)*)?)?|\.\d+(?:_\d+)*)(?:[Ee][+-]?\d+(?:_\d+)*)?/.source+")"+/(?![\w$])/.source),lookbehind:!0},operator:/--|\+\+|\*\*=?|=>|&&=?|\|\|=?|[!=]==|<<=?|>>>?=?|[-+*/%&|^!=<>]=?|\.{3}|\?\?=?|\?\.?|[~:]/}),r.languages.javascript["class-name"][0].pattern=/(\b(?:class|extends|implements|instanceof|interface|new)\s+)[\w.\\]+/,r.languages.insertBefore("javascript","keyword",{regex:{pattern:/((?:^|[^$\w\xA0-\uFFFF."'\])\s]|\b(?:return|yield))\s*)\/(?:\[(?:[^\]\\\r\n]|\\.)*\]|\\.|[^/\\\[\r\n])+\/[dgimyus]{0,7}(?=(?:\s|\/\*(?:[^*]|\*(?!\/))*\*\/)*(?:$|[\r\n,.;:})\]]|\/\/))/,lookbehind:!0,greedy:!0,inside:{"regex-source":{pattern:/^(\/)[\s\S]+(?=\/[a-z]*$)/,lookbehind:!0,alias:"language-regex",inside:r.languages.regex},"regex-delimiter":/^\/|\/$/,"regex-flags":/^[a-z]+$/}},"function-variable":{pattern:/#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*[=:]\s*(?:async\s*)?(?:\bfunction\b|(?:\((?:[^()]|\([^()]*\))*\)|(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*)\s*=>))/,alias:"function"},parameter:[{pattern:/(function(?:\s+(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*)?\s*\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\))/,lookbehind:!0,inside:r.languages.javascript},{pattern:/(^|[^$\w\xA0-\uFFFF])(?!\s)[_$a-z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*=>)/i,lookbehind:!0,inside:r.languages.javascript},{pattern:/(\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\)\s*=>)/,lookbehind:!0,inside:r.languages.javascript},{pattern:/((?:\b|\s|^)(?!(?:as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)(?![$\w\xA0-\uFFFF]))(?:(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*\s*)\(\s*|\]\s*\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\)\s*\{)/,lookbehind:!0,inside:r.languages.javascript}],constant:/\b[A-Z](?:[A-Z_]|\dx?)*\b/}),r.languages.insertBefore("javascript","string",{hashbang:{pattern:/^#!.*/,greedy:!0,alias:"comment"},"template-string":{pattern:/`(?:\\[\s\S]|\$\{(?:[^{}]|\{(?:[^{}]|\{[^}]*\})*\})+\}|(?!\$\{)[^\\`])*`/,greedy:!0,inside:{"template-punctuation":{pattern:/^`|`$/,alias:"string"},interpolation:{pattern:/((?:^|[^\\])(?:\\{2})*)\$\{(?:[^{}]|\{(?:[^{}]|\{[^}]*\})*\})+\}/,lookbehind:!0,inside:{"interpolation-punctuation":{pattern:/^\$\{|\}$/,alias:"punctuation"},rest:r.languages.javascript}},string:/[\s\S]+/}},"string-property":{pattern:/((?:^|[,{])[ \t]*)(["'])(?:\\(?:\r\n|[\s\S])|(?!\2)[^\\\r\n])*\2(?=\s*:)/m,lookbehind:!0,greedy:!0,alias:"property"}}),r.languages.insertBefore("javascript","operator",{"literal-property":{pattern:/((?:^|[,{])[ \t]*)(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*:)/m,lookbehind:!0,alias:"property"}}),r.languages.markup&&(r.languages.markup.tag.addInlined("script","javascript"),r.languages.markup.tag.addAttribute(/on(?:abort|blur|change|click|composition(?:end|start|update)|dblclick|error|focus(?:in|out)?|key(?:down|up)|load|mouse(?:down|enter|leave|move|out|over|up)|reset|resize|scroll|select|slotchange|submit|unload|wheel)/.source,"javascript")),r.languages.js=r.languages.javascript,function(e){var t=/#(?!\{).+/,n={pattern:/#\{[^}]+\}/,alias:"variable"};e.languages.coffeescript=e.languages.extend("javascript",{comment:t,string:[{pattern:/'(?:\\[\s\S]|[^\\'])*'/,greedy:!0},{pattern:/"(?:\\[\s\S]|[^\\"])*"/,greedy:!0,inside:{interpolation:n}}],keyword:/\b(?:and|break|by|catch|class|continue|debugger|delete|do|each|else|extend|extends|false|finally|for|if|in|instanceof|is|isnt|let|loop|namespace|new|no|not|null|of|off|on|or|own|return|super|switch|then|this|throw|true|try|typeof|undefined|unless|until|when|while|window|with|yes|yield)\b/,"class-member":{pattern:/@(?!\d)\w+/,alias:"variable"}}),e.languages.insertBefore("coffeescript","comment",{"multiline-comment":{pattern:/###[\s\S]+?###/,alias:"comment"},"block-regex":{pattern:/\/{3}[\s\S]*?\/{3}/,alias:"regex",inside:{comment:t,interpolation:n}}}),e.languages.insertBefore("coffeescript","string",{"inline-javascript":{pattern:/`(?:\\[\s\S]|[^\\`])*`/,inside:{delimiter:{pattern:/^`|`$/,alias:"punctuation"},script:{pattern:/[\s\S]+/,alias:"language-javascript",inside:e.languages.javascript}}},"multiline-string":[{pattern:/'''[\s\S]*?'''/,greedy:!0,alias:"string"},{pattern:/"""[\s\S]*?"""/,greedy:!0,alias:"string",inside:{interpolation:n}}]}),e.languages.insertBefore("coffeescript","keyword",{property:/(?!\d)\w+(?=\s*:(?!:))/}),delete e.languages.coffeescript["template-string"],e.languages.coffee=e.languages.coffeescript}(r),function(e){var t=/[*&][^\s[\]{},]+/,n=/!(?:<[\w\-%#;/?:@&=+$,.!~*'()[\]]+>|(?:[a-zA-Z\d-]*!)?[\w\-%#;/?:@&=+$.~*'()]+)?/,a="(?:"+n.source+"(?:[ \t]+"+t.source+")?|"+t.source+"(?:[ \t]+"+n.source+")?)",r=/(?:[^\s\x00-\x08\x0e-\x1f!"#%&'*,\-:>?@[\]`{|}\x7f-\x84\x86-\x9f\ud800-\udfff\ufffe\uffff]|[?:-])(?:[ \t]*(?:(?![#:])|:))*/.source.replace(//g,(function(){return/[^\s\x00-\x08\x0e-\x1f,[\]{}\x7f-\x84\x86-\x9f\ud800-\udfff\ufffe\uffff]/.source})),o=/"(?:[^"\\\r\n]|\\.)*"|'(?:[^'\\\r\n]|\\.)*'/.source;function i(e,t){t=(t||"").replace(/m/g,"")+"m";var n=/([:\-,[{]\s*(?:\s<>[ \t]+)?)(?:<>)(?=[ \t]*(?:$|,|\]|\}|(?:[\r\n]\s*)?#))/.source.replace(/<>/g,(function(){return a})).replace(/<>/g,(function(){return e}));return RegExp(n,t)}e.languages.yaml={scalar:{pattern:RegExp(/([\-:]\s*(?:\s<>[ \t]+)?[|>])[ \t]*(?:((?:\r?\n|\r)[ \t]+)\S[^\r\n]*(?:\2[^\r\n]+)*)/.source.replace(/<>/g,(function(){return a}))),lookbehind:!0,alias:"string"},comment:/#.*/,key:{pattern:RegExp(/((?:^|[:\-,[{\r\n?])[ \t]*(?:<>[ \t]+)?)<>(?=\s*:\s)/.source.replace(/<>/g,(function(){return a})).replace(/<>/g,(function(){return"(?:"+r+"|"+o+")"}))),lookbehind:!0,greedy:!0,alias:"atrule"},directive:{pattern:/(^[ \t]*)%.+/m,lookbehind:!0,alias:"important"},datetime:{pattern:i(/\d{4}-\d\d?-\d\d?(?:[tT]|[ \t]+)\d\d?:\d{2}:\d{2}(?:\.\d*)?(?:[ \t]*(?:Z|[-+]\d\d?(?::\d{2})?))?|\d{4}-\d{2}-\d{2}|\d\d?:\d{2}(?::\d{2}(?:\.\d*)?)?/.source),lookbehind:!0,alias:"number"},boolean:{pattern:i(/false|true/.source,"i"),lookbehind:!0,alias:"important"},null:{pattern:i(/null|~/.source,"i"),lookbehind:!0,alias:"important"},string:{pattern:i(o),lookbehind:!0,greedy:!0},number:{pattern:i(/[+-]?(?:0x[\da-f]+|0o[0-7]+|(?:\d+(?:\.\d*)?|\.\d+)(?:e[+-]?\d+)?|\.inf|\.nan)/.source,"i"),lookbehind:!0},tag:n,important:t,punctuation:/---|[:[\]{}\-,|>?]|\.\.\./},e.languages.yml=e.languages.yaml}(r),function(e){var t=/(?:\\.|[^\\\n\r]|(?:\n|\r\n?)(?![\r\n]))/.source;function n(e){return e=e.replace(//g,(function(){return t})),RegExp(/((?:^|[^\\])(?:\\{2})*)/.source+"(?:"+e+")")}var a=/(?:\\.|``(?:[^`\r\n]|`(?!`))+``|`[^`\r\n]+`|[^\\|\r\n`])+/.source,r=/\|?__(?:\|__)+\|?(?:(?:\n|\r\n?)|(?![\s\S]))/.source.replace(/__/g,(function(){return a})),o=/\|?[ \t]*:?-{3,}:?[ \t]*(?:\|[ \t]*:?-{3,}:?[ \t]*)+\|?(?:\n|\r\n?)/.source;e.languages.markdown=e.languages.extend("markup",{}),e.languages.insertBefore("markdown","prolog",{"front-matter-block":{pattern:/(^(?:\s*[\r\n])?)---(?!.)[\s\S]*?[\r\n]---(?!.)/,lookbehind:!0,greedy:!0,inside:{punctuation:/^---|---$/,"front-matter":{pattern:/\S+(?:\s+\S+)*/,alias:["yaml","language-yaml"],inside:e.languages.yaml}}},blockquote:{pattern:/^>(?:[\t ]*>)*/m,alias:"punctuation"},table:{pattern:RegExp("^"+r+o+"(?:"+r+")*","m"),inside:{"table-data-rows":{pattern:RegExp("^("+r+o+")(?:"+r+")*$"),lookbehind:!0,inside:{"table-data":{pattern:RegExp(a),inside:e.languages.markdown},punctuation:/\|/}},"table-line":{pattern:RegExp("^("+r+")"+o+"$"),lookbehind:!0,inside:{punctuation:/\||:?-{3,}:?/}},"table-header-row":{pattern:RegExp("^"+r+"$"),inside:{"table-header":{pattern:RegExp(a),alias:"important",inside:e.languages.markdown},punctuation:/\|/}}}},code:[{pattern:/((?:^|\n)[ \t]*\n|(?:^|\r\n?)[ \t]*\r\n?)(?: {4}|\t).+(?:(?:\n|\r\n?)(?: {4}|\t).+)*/,lookbehind:!0,alias:"keyword"},{pattern:/^```[\s\S]*?^```$/m,greedy:!0,inside:{"code-block":{pattern:/^(```.*(?:\n|\r\n?))[\s\S]+?(?=(?:\n|\r\n?)^```$)/m,lookbehind:!0},"code-language":{pattern:/^(```).+/,lookbehind:!0},punctuation:/```/}}],title:[{pattern:/\S.*(?:\n|\r\n?)(?:==+|--+)(?=[ \t]*$)/m,alias:"important",inside:{punctuation:/==+$|--+$/}},{pattern:/(^\s*)#.+/m,lookbehind:!0,alias:"important",inside:{punctuation:/^#+|#+$/}}],hr:{pattern:/(^\s*)([*-])(?:[\t ]*\2){2,}(?=\s*$)/m,lookbehind:!0,alias:"punctuation"},list:{pattern:/(^\s*)(?:[*+-]|\d+\.)(?=[\t ].)/m,lookbehind:!0,alias:"punctuation"},"url-reference":{pattern:/!?\[[^\]]+\]:[\t ]+(?:\S+|<(?:\\.|[^>\\])+>)(?:[\t ]+(?:"(?:\\.|[^"\\])*"|'(?:\\.|[^'\\])*'|\((?:\\.|[^)\\])*\)))?/,inside:{variable:{pattern:/^(!?\[)[^\]]+/,lookbehind:!0},string:/(?:"(?:\\.|[^"\\])*"|'(?:\\.|[^'\\])*'|\((?:\\.|[^)\\])*\))$/,punctuation:/^[\[\]!:]|[<>]/},alias:"url"},bold:{pattern:n(/\b__(?:(?!_)|_(?:(?!_))+_)+__\b|\*\*(?:(?!\*)|\*(?:(?!\*))+\*)+\*\*/.source),lookbehind:!0,greedy:!0,inside:{content:{pattern:/(^..)[\s\S]+(?=..$)/,lookbehind:!0,inside:{}},punctuation:/\*\*|__/}},italic:{pattern:n(/\b_(?:(?!_)|__(?:(?!_))+__)+_\b|\*(?:(?!\*)|\*\*(?:(?!\*))+\*\*)+\*/.source),lookbehind:!0,greedy:!0,inside:{content:{pattern:/(^.)[\s\S]+(?=.$)/,lookbehind:!0,inside:{}},punctuation:/[*_]/}},strike:{pattern:n(/(~~?)(?:(?!~))+\2/.source),lookbehind:!0,greedy:!0,inside:{content:{pattern:/(^~~?)[\s\S]+(?=\1$)/,lookbehind:!0,inside:{}},punctuation:/~~?/}},"code-snippet":{pattern:/(^|[^\\`])(?:``[^`\r\n]+(?:`[^`\r\n]+)*``(?!`)|`[^`\r\n]+`(?!`))/,lookbehind:!0,greedy:!0,alias:["code","keyword"]},url:{pattern:n(/!?\[(?:(?!\]))+\](?:\([^\s)]+(?:[\t ]+"(?:\\.|[^"\\])*")?\)|[ \t]?\[(?:(?!\]))+\])/.source),lookbehind:!0,greedy:!0,inside:{operator:/^!/,content:{pattern:/(^\[)[^\]]+(?=\])/,lookbehind:!0,inside:{}},variable:{pattern:/(^\][ \t]?\[)[^\]]+(?=\]$)/,lookbehind:!0},url:{pattern:/(^\]\()[^\s)]+/,lookbehind:!0},string:{pattern:/(^[ \t]+)"(?:\\.|[^"\\])*"(?=\)$)/,lookbehind:!0}}}}),["url","bold","italic","strike"].forEach((function(t){["url","bold","italic","strike","code-snippet"].forEach((function(n){t!==n&&(e.languages.markdown[t].inside.content.inside[n]=e.languages.markdown[n])}))})),e.hooks.add("after-tokenize",(function(e){"markdown"!==e.language&&"md"!==e.language||function e(t){if(t&&"string"!=typeof t)for(var n=0,a=t.length;n",quot:'"'},c=String.fromCodePoint||String.fromCharCode;e.languages.md=e.languages.markdown}(r),r.languages.graphql={comment:/#.*/,description:{pattern:/(?:"""(?:[^"]|(?!""")")*"""|"(?:\\.|[^\\"\r\n])*")(?=\s*[a-z_])/i,greedy:!0,alias:"string",inside:{"language-markdown":{pattern:/(^"(?:"")?)(?!\1)[\s\S]+(?=\1$)/,lookbehind:!0,inside:r.languages.markdown}}},string:{pattern:/"""(?:[^"]|(?!""")")*"""|"(?:\\.|[^\\"\r\n])*"/,greedy:!0},number:/(?:\B-|\b)\d+(?:\.\d+)?(?:e[+-]?\d+)?\b/i,boolean:/\b(?:false|true)\b/,variable:/\$[a-z_]\w*/i,directive:{pattern:/@[a-z_]\w*/i,alias:"function"},"attr-name":{pattern:/\b[a-z_]\w*(?=\s*(?:\((?:[^()"]|"(?:\\.|[^\\"\r\n])*")*\))?:)/i,greedy:!0},"atom-input":{pattern:/\b[A-Z]\w*Input\b/,alias:"class-name"},scalar:/\b(?:Boolean|Float|ID|Int|String)\b/,constant:/\b[A-Z][A-Z_\d]*\b/,"class-name":{pattern:/(\b(?:enum|implements|interface|on|scalar|type|union)\s+|&\s*|:\s*|\[)[A-Z_]\w*/,lookbehind:!0},fragment:{pattern:/(\bfragment\s+|\.{3}\s*(?!on\b))[a-zA-Z_]\w*/,lookbehind:!0,alias:"function"},"definition-mutation":{pattern:/(\bmutation\s+)[a-zA-Z_]\w*/,lookbehind:!0,alias:"function"},"definition-query":{pattern:/(\bquery\s+)[a-zA-Z_]\w*/,lookbehind:!0,alias:"function"},keyword:/\b(?:directive|enum|extend|fragment|implements|input|interface|mutation|on|query|repeatable|scalar|schema|subscription|type|union)\b/,operator:/[!=|&]|\.{3}/,"property-query":/\w+(?=\s*\()/,object:/\w+(?=\s*\{)/,punctuation:/[!(){}\[\]:=,]/,property:/\w+/},r.hooks.add("after-tokenize",(function(e){if("graphql"===e.language)for(var t=e.tokens.filter((function(e){return"string"!=typeof e&&"comment"!==e.type&&"scalar"!==e.type})),n=0;n0)){var s=p(/^\{$/,/^\}$/);if(-1===s)continue;for(var c=n;c=0&&f(l,"variable-input")}}}}function u(e){return t[n+e]}function d(e,t){t=t||0;for(var n=0;n?|<|>)?|>[>=]?|\b(?:AND|BETWEEN|DIV|ILIKE|IN|IS|LIKE|NOT|OR|REGEXP|RLIKE|SOUNDS LIKE|XOR)\b/i,punctuation:/[;[\]()`,.]/},function(e){var t=e.languages.javascript["template-string"],n=t.pattern.source,a=t.inside.interpolation,r=a.inside["interpolation-punctuation"],o=a.pattern.source;function i(t,a){if(e.languages[t])return{pattern:RegExp("((?:"+a+")\\s*)"+n),lookbehind:!0,greedy:!0,inside:{"template-punctuation":{pattern:/^`|`$/,alias:"string"},"embedded-code":{pattern:/[\s\S]+/,alias:t}}}}function s(e,t){return"___"+t.toUpperCase()+"_"+e+"___"}function c(t,n,a){var r={code:t,grammar:n,language:a};return e.hooks.run("before-tokenize",r),r.tokens=e.tokenize(r.code,r.grammar),e.hooks.run("after-tokenize",r),r.tokens}function l(t){var n={};n["interpolation-punctuation"]=r;var o=e.tokenize(t,n);if(3===o.length){var i=[1,1];i.push.apply(i,c(o[1],e.languages.javascript,"javascript")),o.splice.apply(o,i)}return new e.Token("interpolation",o,a.alias,t)}function u(t,n,a){var r=e.tokenize(t,{interpolation:{pattern:RegExp(o),lookbehind:!0}}),i=0,u={},d=c(r.map((function(e){if("string"==typeof e)return e;for(var n,r=e.content;-1!==t.indexOf(n=s(i++,a)););return u[n]=r,n})).join(""),n,a),p=Object.keys(u);return i=0,function e(t){for(var n=0;n=p.length)return;var a=t[n];if("string"==typeof a||"string"==typeof a.content){var r=p[i],o="string"==typeof a?a:a.content,s=o.indexOf(r);if(-1!==s){++i;var c=o.substring(0,s),d=l(u[r]),f=o.substring(s+r.length),m=[];if(c&&m.push(c),m.push(d),f){var g=[f];e(g),m.push.apply(m,g)}"string"==typeof a?(t.splice.apply(t,[n,1].concat(m)),n+=m.length-1):a.content=m}}else{var h=a.content;Array.isArray(h)?e(h):e([h])}}}(d),new e.Token(a,d,"language-"+a,t)}e.languages.javascript["template-string"]=[i("css",/\b(?:styled(?:\([^)]*\))?(?:\s*\.\s*\w+(?:\([^)]*\))*)*|css(?:\s*\.\s*(?:global|resolve))?|createGlobalStyle|keyframes)/.source),i("html",/\bhtml|\.\s*(?:inner|outer)HTML\s*\+?=/.source),i("svg",/\bsvg/.source),i("markdown",/\b(?:markdown|md)/.source),i("graphql",/\b(?:gql|graphql(?:\s*\.\s*experimental)?)/.source),i("sql",/\bsql/.source),t].filter(Boolean);var d={javascript:!0,js:!0,typescript:!0,ts:!0,jsx:!0,tsx:!0};function p(e){return"string"==typeof e?e:Array.isArray(e)?e.map(p).join(""):p(e.content)}e.hooks.add("after-tokenize",(function(t){t.language in d&&function t(n){for(var a=0,r=n.length;a]|<(?:[^<>]|<[^<>]*>)*>)*>)?/,lookbehind:!0,greedy:!0,inside:null},builtin:/\b(?:Array|Function|Promise|any|boolean|console|never|number|string|symbol|unknown)\b/}),e.languages.typescript.keyword.push(/\b(?:abstract|declare|is|keyof|readonly|require)\b/,/\b(?:asserts|infer|interface|module|namespace|type)\b(?=\s*(?:[{_$a-zA-Z\xA0-\uFFFF]|$))/,/\btype\b(?=\s*(?:[\{*]|$))/),delete e.languages.typescript.parameter,delete e.languages.typescript["literal-property"];var t=e.languages.extend("typescript",{});delete t["class-name"],e.languages.typescript["class-name"].inside=t,e.languages.insertBefore("typescript","function",{decorator:{pattern:/@[$\w\xA0-\uFFFF]+/,inside:{at:{pattern:/^@/,alias:"operator"},function:/^[\s\S]+/}},"generic-function":{pattern:/#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*\s*<(?:[^<>]|<(?:[^<>]|<[^<>]*>)*>)*>(?=\s*\()/,greedy:!0,inside:{function:/^#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*/,generic:{pattern:/<[\s\S]+/,alias:"class-name",inside:t}}}}),e.languages.ts=e.languages.typescript}(r),function(e){function t(e,t){return RegExp(e.replace(//g,(function(){return/(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*/.source})),t)}e.languages.insertBefore("javascript","function-variable",{"method-variable":{pattern:RegExp("(\\.\\s*)"+e.languages.javascript["function-variable"].pattern.source),lookbehind:!0,alias:["function-variable","method","function","property-access"]}}),e.languages.insertBefore("javascript","function",{method:{pattern:RegExp("(\\.\\s*)"+e.languages.javascript.function.source),lookbehind:!0,alias:["function","property-access"]}}),e.languages.insertBefore("javascript","constant",{"known-class-name":[{pattern:/\b(?:(?:Float(?:32|64)|(?:Int|Uint)(?:8|16|32)|Uint8Clamped)?Array|ArrayBuffer|BigInt|Boolean|DataView|Date|Error|Function|Intl|JSON|(?:Weak)?(?:Map|Set)|Math|Number|Object|Promise|Proxy|Reflect|RegExp|String|Symbol|WebAssembly)\b/,alias:"class-name"},{pattern:/\b(?:[A-Z]\w*)Error\b/,alias:"class-name"}]}),e.languages.insertBefore("javascript","keyword",{imports:{pattern:t(/(\bimport\b\s*)(?:(?:\s*,\s*(?:\*\s*as\s+|\{[^{}]*\}))?|\*\s*as\s+|\{[^{}]*\})(?=\s*\bfrom\b)/.source),lookbehind:!0,inside:e.languages.javascript},exports:{pattern:t(/(\bexport\b\s*)(?:\*(?:\s*as\s+)?(?=\s*\bfrom\b)|\{[^{}]*\})/.source),lookbehind:!0,inside:e.languages.javascript}}),e.languages.javascript.keyword.unshift({pattern:/\b(?:as|default|export|from|import)\b/,alias:"module"},{pattern:/\b(?:await|break|catch|continue|do|else|finally|for|if|return|switch|throw|try|while|yield)\b/,alias:"control-flow"},{pattern:/\bnull\b/,alias:["null","nil"]},{pattern:/\bundefined\b/,alias:"nil"}),e.languages.insertBefore("javascript","operator",{spread:{pattern:/\.{3}/,alias:"operator"},arrow:{pattern:/=>/,alias:"operator"}}),e.languages.insertBefore("javascript","punctuation",{"property-access":{pattern:t(/(\.\s*)#?/.source),lookbehind:!0},"maybe-class-name":{pattern:/(^|[^$\w\xA0-\uFFFF])[A-Z][$\w\xA0-\uFFFF]+/,lookbehind:!0},dom:{pattern:/\b(?:document|(?:local|session)Storage|location|navigator|performance|window)\b/,alias:"variable"},console:{pattern:/\bconsole(?=\s*\.)/,alias:"class-name"}});for(var n=["function","function-variable","method","method-variable","property-access"],a=0;a*\.{3}(?:[^{}]|)*\})/.source;function o(e,t){return e=e.replace(//g,(function(){return n})).replace(//g,(function(){return a})).replace(//g,(function(){return r})),RegExp(e,t)}r=o(r).source,e.languages.jsx=e.languages.extend("markup",t),e.languages.jsx.tag.pattern=o(/<\/?(?:[\w.:-]+(?:+(?:[\w.:$-]+(?:=(?:"(?:\\[\s\S]|[^\\"])*"|'(?:\\[\s\S]|[^\\'])*'|[^\s{'"/>=]+|))?|))**\/?)?>/.source),e.languages.jsx.tag.inside.tag.pattern=/^<\/?[^\s>\/]*/,e.languages.jsx.tag.inside["attr-value"].pattern=/=(?!\{)(?:"(?:\\[\s\S]|[^\\"])*"|'(?:\\[\s\S]|[^\\'])*'|[^\s'">]+)/,e.languages.jsx.tag.inside.tag.inside["class-name"]=/^[A-Z]\w*(?:\.[A-Z]\w*)*$/,e.languages.jsx.tag.inside.comment=t.comment,e.languages.insertBefore("inside","attr-name",{spread:{pattern:o(//.source),inside:e.languages.jsx}},e.languages.jsx.tag),e.languages.insertBefore("inside","special-attr",{script:{pattern:o(/=/.source),alias:"language-javascript",inside:{"script-punctuation":{pattern:/^=(?=\{)/,alias:"punctuation"},rest:e.languages.jsx}}},e.languages.jsx.tag);var i=function(e){return e?"string"==typeof e?e:"string"==typeof e.content?e.content:e.content.map(i).join(""):""},s=function(t){for(var n=[],a=0;a0&&n[n.length-1].tagName===i(r.content[0].content[1])&&n.pop():"/>"===r.content[r.content.length-1].content||n.push({tagName:i(r.content[0].content[1]),openedBraces:0}):n.length>0&&"punctuation"===r.type&&"{"===r.content?n[n.length-1].openedBraces++:n.length>0&&n[n.length-1].openedBraces>0&&"punctuation"===r.type&&"}"===r.content?n[n.length-1].openedBraces--:o=!0),(o||"string"==typeof r)&&n.length>0&&0===n[n.length-1].openedBraces){var c=i(r);a0&&("string"==typeof t[a-1]||"plain-text"===t[a-1].type)&&(c=i(t[a-1])+c,t.splice(a-1,1),a--),t[a]=new e.Token("plain-text",c,null,c)}r.content&&"string"!=typeof r.content&&s(r.content)}};e.hooks.add("after-tokenize",(function(e){"jsx"!==e.language&&"tsx"!==e.language||s(e.tokens)}))}(r),function(e){e.languages.diff={coord:[/^(?:\*{3}|-{3}|\+{3}).*$/m,/^@@.*@@$/m,/^\d.*$/m]};var t={"deleted-sign":"-","deleted-arrow":"<","inserted-sign":"+","inserted-arrow":">",unchanged:" ",diff:"!"};Object.keys(t).forEach((function(n){var a=t[n],r=[];/^\w+$/.test(n)||r.push(/\w+/.exec(n)[0]),"diff"===n&&r.push("bold"),e.languages.diff[n]={pattern:RegExp("^(?:["+a+"].*(?:\r\n?|\n|(?![\\s\\S])))+","m"),alias:r,inside:{line:{pattern:/(.)(?=[\s\S]).*(?:\r\n?|\n)?/,lookbehind:!0},prefix:{pattern:/[\s\S]/,alias:/\w+/.exec(n)[0]}}}})),Object.defineProperty(e.languages.diff,"PREFIXES",{value:t})}(r),r.languages.git={comment:/^#.*/m,deleted:/^[-\u2013].*/m,inserted:/^\+.*/m,string:/("|')(?:\\.|(?!\1)[^\\\r\n])*\1/,command:{pattern:/^.*\$ git .*$/m,inside:{parameter:/\s--?\w+/}},coord:/^@@.*@@$/m,"commit-sha1":/^commit \w{40}$/m},r.languages.go=r.languages.extend("clike",{string:{pattern:/(^|[^\\])"(?:\\.|[^"\\\r\n])*"|`[^`]*`/,lookbehind:!0,greedy:!0},keyword:/\b(?:break|case|chan|const|continue|default|defer|else|fallthrough|for|func|go(?:to)?|if|import|interface|map|package|range|return|select|struct|switch|type|var)\b/,boolean:/\b(?:_|false|iota|nil|true)\b/,number:[/\b0(?:b[01_]+|o[0-7_]+)i?\b/i,/\b0x(?:[a-f\d_]+(?:\.[a-f\d_]*)?|\.[a-f\d_]+)(?:p[+-]?\d+(?:_\d+)*)?i?(?!\w)/i,/(?:\b\d[\d_]*(?:\.[\d_]*)?|\B\.\d[\d_]*)(?:e[+-]?[\d_]+)?i?(?!\w)/i],operator:/[*\/%^!=]=?|\+[=+]?|-[=-]?|\|[=|]?|&(?:=|&|\^=?)?|>(?:>=?|=)?|<(?:<=?|=|-)?|:=|\.\.\./,builtin:/\b(?:append|bool|byte|cap|close|complex|complex(?:64|128)|copy|delete|error|float(?:32|64)|u?int(?:8|16|32|64)?|imag|len|make|new|panic|print(?:ln)?|real|recover|rune|string|uintptr)\b/}),r.languages.insertBefore("go","string",{char:{pattern:/'(?:\\.|[^'\\\r\n]){0,10}'/,greedy:!0}}),delete r.languages.go["class-name"],function(e){function t(e,t){return"___"+e.toUpperCase()+t+"___"}Object.defineProperties(e.languages["markup-templating"]={},{buildPlaceholders:{value:function(n,a,r,o){if(n.language===a){var i=n.tokenStack=[];n.code=n.code.replace(r,(function(e){if("function"==typeof o&&!o(e))return e;for(var r,s=i.length;-1!==n.code.indexOf(r=t(a,s));)++s;return i[s]=e,r})),n.grammar=e.languages.markup}}},tokenizePlaceholders:{value:function(n,a){if(n.language===a&&n.tokenStack){n.grammar=e.languages[a];var r=0,o=Object.keys(n.tokenStack);!function i(s){for(var c=0;c=o.length);c++){var l=s[c];if("string"==typeof l||l.content&&"string"==typeof l.content){var u=o[r],d=n.tokenStack[u],p="string"==typeof l?l:l.content,f=t(a,u),m=p.indexOf(f);if(m>-1){++r;var g=p.substring(0,m),h=new e.Token(a,e.tokenize(d,n.grammar),"language-"+a,d),b=p.substring(m+f.length),y=[];g&&y.push.apply(y,i([g])),y.push(h),b&&y.push.apply(y,i([b])),"string"==typeof l?s.splice.apply(s,[c,1].concat(y)):l.content=y}}else l.content&&i(l.content)}return s}(n.tokens)}}}})}(r),function(e){e.languages.handlebars={comment:/\{\{![\s\S]*?\}\}/,delimiter:{pattern:/^\{\{\{?|\}\}\}?$/,alias:"punctuation"},string:/(["'])(?:\\.|(?!\1)[^\\\r\n])*\1/,number:/\b0x[\dA-Fa-f]+\b|(?:\b\d+(?:\.\d*)?|\B\.\d+)(?:[Ee][+-]?\d+)?/,boolean:/\b(?:false|true)\b/,block:{pattern:/^(\s*(?:~\s*)?)[#\/]\S+?(?=\s*(?:~\s*)?$|\s)/,lookbehind:!0,alias:"keyword"},brackets:{pattern:/\[[^\]]+\]/,inside:{punctuation:/\[|\]/,variable:/[\s\S]+/}},punctuation:/[!"#%&':()*+,.\/;<=>@\[\\\]^`{|}~]/,variable:/[^!"#%&'()*+,\/;<=>@\[\\\]^`{|}~\s]+/},e.hooks.add("before-tokenize",(function(t){e.languages["markup-templating"].buildPlaceholders(t,"handlebars",/\{\{\{[\s\S]+?\}\}\}|\{\{[\s\S]+?\}\}/g)})),e.hooks.add("after-tokenize",(function(t){e.languages["markup-templating"].tokenizePlaceholders(t,"handlebars")})),e.languages.hbs=e.languages.handlebars}(r),r.languages.json={property:{pattern:/(^|[^\\])"(?:\\.|[^\\"\r\n])*"(?=\s*:)/,lookbehind:!0,greedy:!0},string:{pattern:/(^|[^\\])"(?:\\.|[^\\"\r\n])*"(?!\s*:)/,lookbehind:!0,greedy:!0},comment:{pattern:/\/\/.*|\/\*[\s\S]*?(?:\*\/|$)/,greedy:!0},number:/-?\b\d+(?:\.\d+)?(?:e[+-]?\d+)?\b/i,punctuation:/[{}[\],]/,operator:/:/,boolean:/\b(?:false|true)\b/,null:{pattern:/\bnull\b/,alias:"keyword"}},r.languages.webmanifest=r.languages.json,r.languages.less=r.languages.extend("css",{comment:[/\/\*[\s\S]*?\*\//,{pattern:/(^|[^\\])\/\/.*/,lookbehind:!0}],atrule:{pattern:/@[\w-](?:\((?:[^(){}]|\([^(){}]*\))*\)|[^(){};\s]|\s+(?!\s))*?(?=\s*\{)/,inside:{punctuation:/[:()]/}},selector:{pattern:/(?:@\{[\w-]+\}|[^{};\s@])(?:@\{[\w-]+\}|\((?:[^(){}]|\([^(){}]*\))*\)|[^(){};@\s]|\s+(?!\s))*?(?=\s*\{)/,inside:{variable:/@+[\w-]+/}},property:/(?:@\{[\w-]+\}|[\w-])+(?:\+_?)?(?=\s*:)/,operator:/[+\-*\/]/}),r.languages.insertBefore("less","property",{variable:[{pattern:/@[\w-]+\s*:/,inside:{punctuation:/:/}},/@@?[\w-]+/],"mixin-usage":{pattern:/([{;]\s*)[.#](?!\d)[\w-].*?(?=[(;])/,lookbehind:!0,alias:"function"}}),r.languages.makefile={comment:{pattern:/(^|[^\\])#(?:\\(?:\r\n|[\s\S])|[^\\\r\n])*/,lookbehind:!0},string:{pattern:/(["'])(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/,greedy:!0},"builtin-target":{pattern:/\.[A-Z][^:#=\s]+(?=\s*:(?!=))/,alias:"builtin"},target:{pattern:/^(?:[^:=\s]|[ \t]+(?![\s:]))+(?=\s*:(?!=))/m,alias:"symbol",inside:{variable:/\$+(?:(?!\$)[^(){}:#=\s]+|(?=[({]))/}},variable:/\$+(?:(?!\$)[^(){}:#=\s]+|\([@*%<^+?][DF]\)|(?=[({]))/,keyword:/-include\b|\b(?:define|else|endef|endif|export|ifn?def|ifn?eq|include|override|private|sinclude|undefine|unexport|vpath)\b/,function:{pattern:/(\()(?:abspath|addsuffix|and|basename|call|dir|error|eval|file|filter(?:-out)?|findstring|firstword|flavor|foreach|guile|if|info|join|lastword|load|notdir|or|origin|patsubst|realpath|shell|sort|strip|subst|suffix|value|warning|wildcard|word(?:list|s)?)(?=[ \t])/,lookbehind:!0},operator:/(?:::|[?:+!])?=|[|@]/,punctuation:/[:;(){}]/},r.languages.objectivec=r.languages.extend("c",{string:{pattern:/@?"(?:\\(?:\r\n|[\s\S])|[^"\\\r\n])*"/,greedy:!0},keyword:/\b(?:asm|auto|break|case|char|const|continue|default|do|double|else|enum|extern|float|for|goto|if|in|inline|int|long|register|return|self|short|signed|sizeof|static|struct|super|switch|typedef|typeof|union|unsigned|void|volatile|while)\b|(?:@interface|@end|@implementation|@protocol|@class|@public|@protected|@private|@property|@try|@catch|@finally|@throw|@synthesize|@dynamic|@selector)\b/,operator:/-[->]?|\+\+?|!=?|<>?=?|==?|&&?|\|\|?|[~^%?*\/@]/}),delete r.languages.objectivec["class-name"],r.languages.objc=r.languages.objectivec,r.languages.ocaml={comment:{pattern:/\(\*[\s\S]*?\*\)/,greedy:!0},char:{pattern:/'(?:[^\\\r\n']|\\(?:.|[ox]?[0-9a-f]{1,3}))'/i,greedy:!0},string:[{pattern:/"(?:\\(?:[\s\S]|\r\n)|[^\\\r\n"])*"/,greedy:!0},{pattern:/\{([a-z_]*)\|[\s\S]*?\|\1\}/,greedy:!0}],number:[/\b(?:0b[01][01_]*|0o[0-7][0-7_]*)\b/i,/\b0x[a-f0-9][a-f0-9_]*(?:\.[a-f0-9_]*)?(?:p[+-]?\d[\d_]*)?(?!\w)/i,/\b\d[\d_]*(?:\.[\d_]*)?(?:e[+-]?\d[\d_]*)?(?!\w)/i],directive:{pattern:/\B#\w+/,alias:"property"},label:{pattern:/\B~\w+/,alias:"property"},"type-variable":{pattern:/\B'\w+/,alias:"function"},variant:{pattern:/`\w+/,alias:"symbol"},keyword:/\b(?:as|assert|begin|class|constraint|do|done|downto|else|end|exception|external|for|fun|function|functor|if|in|include|inherit|initializer|lazy|let|match|method|module|mutable|new|nonrec|object|of|open|private|rec|sig|struct|then|to|try|type|val|value|virtual|when|where|while|with)\b/,boolean:/\b(?:false|true)\b/,"operator-like-punctuation":{pattern:/\[[<>|]|[>|]\]|\{<|>\}/,alias:"punctuation"},operator:/\.[.~]|:[=>]|[=<>@^|&+\-*\/$%!?~][!$%&*+\-.\/:<=>?@^|~]*|\b(?:and|asr|land|lor|lsl|lsr|lxor|mod|or)\b/,punctuation:/;;|::|[(){}\[\].,:;#]|\b_\b/},r.languages.python={comment:{pattern:/(^|[^\\])#.*/,lookbehind:!0,greedy:!0},"string-interpolation":{pattern:/(?:f|fr|rf)(?:("""|''')[\s\S]*?\1|("|')(?:\\.|(?!\2)[^\\\r\n])*\2)/i,greedy:!0,inside:{interpolation:{pattern:/((?:^|[^{])(?:\{\{)*)\{(?!\{)(?:[^{}]|\{(?!\{)(?:[^{}]|\{(?!\{)(?:[^{}])+\})+\})+\}/,lookbehind:!0,inside:{"format-spec":{pattern:/(:)[^:(){}]+(?=\}$)/,lookbehind:!0},"conversion-option":{pattern:/![sra](?=[:}]$)/,alias:"punctuation"},rest:null}},string:/[\s\S]+/}},"triple-quoted-string":{pattern:/(?:[rub]|br|rb)?("""|''')[\s\S]*?\1/i,greedy:!0,alias:"string"},string:{pattern:/(?:[rub]|br|rb)?("|')(?:\\.|(?!\1)[^\\\r\n])*\1/i,greedy:!0},function:{pattern:/((?:^|\s)def[ \t]+)[a-zA-Z_]\w*(?=\s*\()/g,lookbehind:!0},"class-name":{pattern:/(\bclass\s+)\w+/i,lookbehind:!0},decorator:{pattern:/(^[\t ]*)@\w+(?:\.\w+)*/m,lookbehind:!0,alias:["annotation","punctuation"],inside:{punctuation:/\./}},keyword:/\b(?:_(?=\s*:)|and|as|assert|async|await|break|case|class|continue|def|del|elif|else|except|exec|finally|for|from|global|if|import|in|is|lambda|match|nonlocal|not|or|pass|print|raise|return|try|while|with|yield)\b/,builtin:/\b(?:__import__|abs|all|any|apply|ascii|basestring|bin|bool|buffer|bytearray|bytes|callable|chr|classmethod|cmp|coerce|compile|complex|delattr|dict|dir|divmod|enumerate|eval|execfile|file|filter|float|format|frozenset|getattr|globals|hasattr|hash|help|hex|id|input|int|intern|isinstance|issubclass|iter|len|list|locals|long|map|max|memoryview|min|next|object|oct|open|ord|pow|property|range|raw_input|reduce|reload|repr|reversed|round|set|setattr|slice|sorted|staticmethod|str|sum|super|tuple|type|unichr|unicode|vars|xrange|zip)\b/,boolean:/\b(?:False|None|True)\b/,number:/\b0(?:b(?:_?[01])+|o(?:_?[0-7])+|x(?:_?[a-f0-9])+)\b|(?:\b\d+(?:_\d+)*(?:\.(?:\d+(?:_\d+)*)?)?|\B\.\d+(?:_\d+)*)(?:e[+-]?\d+(?:_\d+)*)?j?(?!\w)/i,operator:/[-+%=]=?|!=|:=|\*\*?=?|\/\/?=?|<[<=>]?|>[=>]?|[&|^~]/,punctuation:/[{}[\];(),.:]/},r.languages.python["string-interpolation"].inside.interpolation.inside.rest=r.languages.python,r.languages.py=r.languages.python,r.languages.reason=r.languages.extend("clike",{string:{pattern:/"(?:\\(?:\r\n|[\s\S])|[^\\\r\n"])*"/,greedy:!0},"class-name":/\b[A-Z]\w*/,keyword:/\b(?:and|as|assert|begin|class|constraint|do|done|downto|else|end|exception|external|for|fun|function|functor|if|in|include|inherit|initializer|lazy|let|method|module|mutable|new|nonrec|object|of|open|or|private|rec|sig|struct|switch|then|to|try|type|val|virtual|when|while|with)\b/,operator:/\.{3}|:[:=]|\|>|->|=(?:==?|>)?|<=?|>=?|[|^?'#!~`]|[+\-*\/]\.?|\b(?:asr|land|lor|lsl|lsr|lxor|mod)\b/}),r.languages.insertBefore("reason","class-name",{char:{pattern:/'(?:\\x[\da-f]{2}|\\o[0-3][0-7][0-7]|\\\d{3}|\\.|[^'\\\r\n])'/,greedy:!0},constructor:/\b[A-Z]\w*\b(?!\s*\.)/,label:{pattern:/\b[a-z]\w*(?=::)/,alias:"symbol"}}),delete r.languages.reason.function,function(e){e.languages.sass=e.languages.extend("css",{comment:{pattern:/^([ \t]*)\/[\/*].*(?:(?:\r?\n|\r)\1[ \t].+)*/m,lookbehind:!0,greedy:!0}}),e.languages.insertBefore("sass","atrule",{"atrule-line":{pattern:/^(?:[ \t]*)[@+=].+/m,greedy:!0,inside:{atrule:/(?:@[\w-]+|[+=])/}}}),delete e.languages.sass.atrule;var t=/\$[-\w]+|#\{\$[-\w]+\}/,n=[/[+*\/%]|[=!]=|<=?|>=?|\b(?:and|not|or)\b/,{pattern:/(\s)-(?=\s)/,lookbehind:!0}];e.languages.insertBefore("sass","property",{"variable-line":{pattern:/^[ \t]*\$.+/m,greedy:!0,inside:{punctuation:/:/,variable:t,operator:n}},"property-line":{pattern:/^[ \t]*(?:[^:\s]+ *:.*|:[^:\s].*)/m,greedy:!0,inside:{property:[/[^:\s]+(?=\s*:)/,{pattern:/(:)[^:\s]+/,lookbehind:!0}],punctuation:/:/,variable:t,operator:n,important:e.languages.sass.important}}}),delete e.languages.sass.property,delete e.languages.sass.important,e.languages.insertBefore("sass","punctuation",{selector:{pattern:/^([ \t]*)\S(?:,[^,\r\n]+|[^,\r\n]*)(?:,[^,\r\n]+)*(?:,(?:\r?\n|\r)\1[ \t]+\S(?:,[^,\r\n]+|[^,\r\n]*)(?:,[^,\r\n]+)*)*/m,lookbehind:!0,greedy:!0}})}(r),r.languages.scss=r.languages.extend("css",{comment:{pattern:/(^|[^\\])(?:\/\*[\s\S]*?\*\/|\/\/.*)/,lookbehind:!0},atrule:{pattern:/@[\w-](?:\([^()]+\)|[^()\s]|\s+(?!\s))*?(?=\s+[{;])/,inside:{rule:/@[\w-]+/}},url:/(?:[-a-z]+-)?url(?=\()/i,selector:{pattern:/(?=\S)[^@;{}()]?(?:[^@;{}()\s]|\s+(?!\s)|#\{\$[-\w]+\})+(?=\s*\{(?:\}|\s|[^}][^:{}]*[:{][^}]))/,inside:{parent:{pattern:/&/,alias:"important"},placeholder:/%[-\w]+/,variable:/\$[-\w]+|#\{\$[-\w]+\}/}},property:{pattern:/(?:[-\w]|\$[-\w]|#\{\$[-\w]+\})+(?=\s*:)/,inside:{variable:/\$[-\w]+|#\{\$[-\w]+\}/}}}),r.languages.insertBefore("scss","atrule",{keyword:[/@(?:content|debug|each|else(?: if)?|extend|for|forward|function|if|import|include|mixin|return|use|warn|while)\b/i,{pattern:/( )(?:from|through)(?= )/,lookbehind:!0}]}),r.languages.insertBefore("scss","important",{variable:/\$[-\w]+|#\{\$[-\w]+\}/}),r.languages.insertBefore("scss","function",{"module-modifier":{pattern:/\b(?:as|hide|show|with)\b/i,alias:"keyword"},placeholder:{pattern:/%[-\w]+/,alias:"selector"},statement:{pattern:/\B!(?:default|optional)\b/i,alias:"keyword"},boolean:/\b(?:false|true)\b/,null:{pattern:/\bnull\b/,alias:"keyword"},operator:{pattern:/(\s)(?:[-+*\/%]|[=!]=|<=?|>=?|and|not|or)(?=\s)/,lookbehind:!0}}),r.languages.scss.atrule.inside.rest=r.languages.scss,function(e){var t={pattern:/(\b\d+)(?:%|[a-z]+)/,lookbehind:!0},n={pattern:/(^|[^\w.-])-?(?:\d+(?:\.\d+)?|\.\d+)/,lookbehind:!0},a={comment:{pattern:/(^|[^\\])(?:\/\*[\s\S]*?\*\/|\/\/.*)/,lookbehind:!0},url:{pattern:/\burl\((["']?).*?\1\)/i,greedy:!0},string:{pattern:/("|')(?:(?!\1)[^\\\r\n]|\\(?:\r\n|[\s\S]))*\1/,greedy:!0},interpolation:null,func:null,important:/\B!(?:important|optional)\b/i,keyword:{pattern:/(^|\s+)(?:(?:else|for|if|return|unless)(?=\s|$)|@[\w-]+)/,lookbehind:!0},hexcode:/#[\da-f]{3,6}/i,color:[/\b(?:AliceBlue|AntiqueWhite|Aqua|Aquamarine|Azure|Beige|Bisque|Black|BlanchedAlmond|Blue|BlueViolet|Brown|BurlyWood|CadetBlue|Chartreuse|Chocolate|Coral|CornflowerBlue|Cornsilk|Crimson|Cyan|DarkBlue|DarkCyan|DarkGoldenRod|DarkGr[ae]y|DarkGreen|DarkKhaki|DarkMagenta|DarkOliveGreen|DarkOrange|DarkOrchid|DarkRed|DarkSalmon|DarkSeaGreen|DarkSlateBlue|DarkSlateGr[ae]y|DarkTurquoise|DarkViolet|DeepPink|DeepSkyBlue|DimGr[ae]y|DodgerBlue|FireBrick|FloralWhite|ForestGreen|Fuchsia|Gainsboro|GhostWhite|Gold|GoldenRod|Gr[ae]y|Green|GreenYellow|HoneyDew|HotPink|IndianRed|Indigo|Ivory|Khaki|Lavender|LavenderBlush|LawnGreen|LemonChiffon|LightBlue|LightCoral|LightCyan|LightGoldenRodYellow|LightGr[ae]y|LightGreen|LightPink|LightSalmon|LightSeaGreen|LightSkyBlue|LightSlateGr[ae]y|LightSteelBlue|LightYellow|Lime|LimeGreen|Linen|Magenta|Maroon|MediumAquaMarine|MediumBlue|MediumOrchid|MediumPurple|MediumSeaGreen|MediumSlateBlue|MediumSpringGreen|MediumTurquoise|MediumVioletRed|MidnightBlue|MintCream|MistyRose|Moccasin|NavajoWhite|Navy|OldLace|Olive|OliveDrab|Orange|OrangeRed|Orchid|PaleGoldenRod|PaleGreen|PaleTurquoise|PaleVioletRed|PapayaWhip|PeachPuff|Peru|Pink|Plum|PowderBlue|Purple|Red|RosyBrown|RoyalBlue|SaddleBrown|Salmon|SandyBrown|SeaGreen|SeaShell|Sienna|Silver|SkyBlue|SlateBlue|SlateGr[ae]y|Snow|SpringGreen|SteelBlue|Tan|Teal|Thistle|Tomato|Transparent|Turquoise|Violet|Wheat|White|WhiteSmoke|Yellow|YellowGreen)\b/i,{pattern:/\b(?:hsl|rgb)\(\s*\d{1,3}\s*,\s*\d{1,3}%?\s*,\s*\d{1,3}%?\s*\)\B|\b(?:hsl|rgb)a\(\s*\d{1,3}\s*,\s*\d{1,3}%?\s*,\s*\d{1,3}%?\s*,\s*(?:0|0?\.\d+|1)\s*\)\B/i,inside:{unit:t,number:n,function:/[\w-]+(?=\()/,punctuation:/[(),]/}}],entity:/\\[\da-f]{1,8}/i,unit:t,boolean:/\b(?:false|true)\b/,operator:[/~|[+!\/%<>?=]=?|[-:]=|\*[*=]?|\.{2,3}|&&|\|\||\B-\B|\b(?:and|in|is(?: a| defined| not|nt)?|not|or)\b/],number:n,punctuation:/[{}()\[\];:,]/};a.interpolation={pattern:/\{[^\r\n}:]+\}/,alias:"variable",inside:{delimiter:{pattern:/^\{|\}$/,alias:"punctuation"},rest:a}},a.func={pattern:/[\w-]+\([^)]*\).*/,inside:{function:/^[^(]+/,rest:a}},e.languages.stylus={"atrule-declaration":{pattern:/(^[ \t]*)@.+/m,lookbehind:!0,inside:{atrule:/^@[\w-]+/,rest:a}},"variable-declaration":{pattern:/(^[ \t]*)[\w$-]+\s*.?=[ \t]*(?:\{[^{}]*\}|\S.*|$)/m,lookbehind:!0,inside:{variable:/^\S+/,rest:a}},statement:{pattern:/(^[ \t]*)(?:else|for|if|return|unless)[ \t].+/m,lookbehind:!0,inside:{keyword:/^\S+/,rest:a}},"property-declaration":{pattern:/((?:^|\{)([ \t]*))(?:[\w-]|\{[^}\r\n]+\})+(?:\s*:\s*|[ \t]+)(?!\s)[^{\r\n]*(?:;|[^{\r\n,]$(?!(?:\r?\n|\r)(?:\{|\2[ \t])))/m,lookbehind:!0,inside:{property:{pattern:/^[^\s:]+/,inside:{interpolation:a.interpolation}},rest:a}},selector:{pattern:/(^[ \t]*)(?:(?=\S)(?:[^{}\r\n:()]|::?[\w-]+(?:\([^)\r\n]*\)|(?![\w-]))|\{[^}\r\n]+\})+)(?:(?:\r?\n|\r)(?:\1(?:(?=\S)(?:[^{}\r\n:()]|::?[\w-]+(?:\([^)\r\n]*\)|(?![\w-]))|\{[^}\r\n]+\})+)))*(?:,$|\{|(?=(?:\r?\n|\r)(?:\{|\1[ \t])))/m,lookbehind:!0,inside:{interpolation:a.interpolation,comment:a.comment,punctuation:/[{},]/}},func:a.func,string:a.string,comment:{pattern:/(^|[^\\])(?:\/\*[\s\S]*?\*\/|\/\/.*)/,lookbehind:!0,greedy:!0},interpolation:a.interpolation,punctuation:/[{}()\[\];:.]/}}(r),function(e){var t=e.util.clone(e.languages.typescript);e.languages.tsx=e.languages.extend("jsx",t),delete e.languages.tsx.parameter,delete e.languages.tsx["literal-property"];var n=e.languages.tsx.tag;n.pattern=RegExp(/(^|[^\w$]|(?=<\/))/.source+"(?:"+n.pattern.source+")",n.pattern.flags),n.lookbehind=!0}(r),r.languages.wasm={comment:[/\(;[\s\S]*?;\)/,{pattern:/;;.*/,greedy:!0}],string:{pattern:/"(?:\\[\s\S]|[^"\\])*"/,greedy:!0},keyword:[{pattern:/\b(?:align|offset)=/,inside:{operator:/=/}},{pattern:/\b(?:(?:f32|f64|i32|i64)(?:\.(?:abs|add|and|ceil|clz|const|convert_[su]\/i(?:32|64)|copysign|ctz|demote\/f64|div(?:_[su])?|eqz?|extend_[su]\/i32|floor|ge(?:_[su])?|gt(?:_[su])?|le(?:_[su])?|load(?:(?:8|16|32)_[su])?|lt(?:_[su])?|max|min|mul|neg?|nearest|or|popcnt|promote\/f32|reinterpret\/[fi](?:32|64)|rem_[su]|rot[lr]|shl|shr_[su]|sqrt|store(?:8|16|32)?|sub|trunc(?:_[su]\/f(?:32|64))?|wrap\/i64|xor))?|memory\.(?:grow|size))\b/,inside:{punctuation:/\./}},/\b(?:anyfunc|block|br(?:_if|_table)?|call(?:_indirect)?|data|drop|elem|else|end|export|func|get_(?:global|local)|global|if|import|local|loop|memory|module|mut|nop|offset|param|result|return|select|set_(?:global|local)|start|table|tee_local|then|type|unreachable)\b/],variable:/\$[\w!#$%&'*+\-./:<=>?@\\^`|~]+/,number:/[+-]?\b(?:\d(?:_?\d)*(?:\.\d(?:_?\d)*)?(?:[eE][+-]?\d(?:_?\d)*)?|0x[\da-fA-F](?:_?[\da-fA-F])*(?:\.[\da-fA-F](?:_?[\da-fA-D])*)?(?:[pP][+-]?\d(?:_?\d)*)?)\b|\binf\b|\bnan(?::0x[\da-fA-F](?:_?[\da-fA-D])*)?\b/,punctuation:/[()]/};const o=r},29901:e=>{e.exports&&(e.exports={core:{meta:{path:"components/prism-core.js",option:"mandatory"},core:"Core"},themes:{meta:{path:"themes/{id}.css",link:"index.html?theme={id}",exclusive:!0},prism:{title:"Default",option:"default"},"prism-dark":"Dark","prism-funky":"Funky","prism-okaidia":{title:"Okaidia",owner:"ocodia"},"prism-twilight":{title:"Twilight",owner:"remybach"},"prism-coy":{title:"Coy",owner:"tshedor"},"prism-solarizedlight":{title:"Solarized Light",owner:"hectormatos2011 "},"prism-tomorrow":{title:"Tomorrow Night",owner:"Rosey"}},languages:{meta:{path:"components/prism-{id}",noCSS:!0,examplesPath:"examples/prism-{id}",addCheckAll:!0},markup:{title:"Markup",alias:["html","xml","svg","mathml","ssml","atom","rss"],aliasTitles:{html:"HTML",xml:"XML",svg:"SVG",mathml:"MathML",ssml:"SSML",atom:"Atom",rss:"RSS"},option:"default"},css:{title:"CSS",option:"default",modify:"markup"},clike:{title:"C-like",option:"default"},javascript:{title:"JavaScript",require:"clike",modify:"markup",optional:"regex",alias:"js",option:"default"},abap:{title:"ABAP",owner:"dellagustin"},abnf:{title:"ABNF",owner:"RunDevelopment"},actionscript:{title:"ActionScript",require:"javascript",modify:"markup",owner:"Golmote"},ada:{title:"Ada",owner:"Lucretia"},agda:{title:"Agda",owner:"xy-ren"},al:{title:"AL",owner:"RunDevelopment"},antlr4:{title:"ANTLR4",alias:"g4",owner:"RunDevelopment"},apacheconf:{title:"Apache Configuration",owner:"GuiTeK"},apex:{title:"Apex",require:["clike","sql"],owner:"RunDevelopment"},apl:{title:"APL",owner:"ngn"},applescript:{title:"AppleScript",owner:"Golmote"},aql:{title:"AQL",owner:"RunDevelopment"},arduino:{title:"Arduino",require:"cpp",alias:"ino",owner:"dkern"},arff:{title:"ARFF",owner:"Golmote"},armasm:{title:"ARM Assembly",alias:"arm-asm",owner:"RunDevelopment"},arturo:{title:"Arturo",alias:"art",optional:["bash","css","javascript","markup","markdown","sql"],owner:"drkameleon"},asciidoc:{alias:"adoc",title:"AsciiDoc",owner:"Golmote"},aspnet:{title:"ASP.NET (C#)",require:["markup","csharp"],owner:"nauzilus"},asm6502:{title:"6502 Assembly",owner:"kzurawel"},asmatmel:{title:"Atmel AVR Assembly",owner:"cerkit"},autohotkey:{title:"AutoHotkey",owner:"aviaryan"},autoit:{title:"AutoIt",owner:"Golmote"},avisynth:{title:"AviSynth",alias:"avs",owner:"Zinfidel"},"avro-idl":{title:"Avro IDL",alias:"avdl",owner:"RunDevelopment"},awk:{title:"AWK",alias:"gawk",aliasTitles:{gawk:"GAWK"},owner:"RunDevelopment"},bash:{title:"Bash",alias:["sh","shell"],aliasTitles:{sh:"Shell",shell:"Shell"},owner:"zeitgeist87"},basic:{title:"BASIC",owner:"Golmote"},batch:{title:"Batch",owner:"Golmote"},bbcode:{title:"BBcode",alias:"shortcode",aliasTitles:{shortcode:"Shortcode"},owner:"RunDevelopment"},bbj:{title:"BBj",owner:"hyyan"},bicep:{title:"Bicep",owner:"johnnyreilly"},birb:{title:"Birb",require:"clike",owner:"Calamity210"},bison:{title:"Bison",require:"c",owner:"Golmote"},bnf:{title:"BNF",alias:"rbnf",aliasTitles:{rbnf:"RBNF"},owner:"RunDevelopment"},bqn:{title:"BQN",owner:"yewscion"},brainfuck:{title:"Brainfuck",owner:"Golmote"},brightscript:{title:"BrightScript",owner:"RunDevelopment"},bro:{title:"Bro",owner:"wayward710"},bsl:{title:"BSL (1C:Enterprise)",alias:"oscript",aliasTitles:{oscript:"OneScript"},owner:"Diversus23"},c:{title:"C",require:"clike",owner:"zeitgeist87"},csharp:{title:"C#",require:"clike",alias:["cs","dotnet"],owner:"mvalipour"},cpp:{title:"C++",require:"c",owner:"zeitgeist87"},cfscript:{title:"CFScript",require:"clike",alias:"cfc",owner:"mjclemente"},chaiscript:{title:"ChaiScript",require:["clike","cpp"],owner:"RunDevelopment"},cil:{title:"CIL",owner:"sbrl"},cilkc:{title:"Cilk/C",require:"c",alias:"cilk-c",owner:"OpenCilk"},cilkcpp:{title:"Cilk/C++",require:"cpp",alias:["cilk-cpp","cilk"],owner:"OpenCilk"},clojure:{title:"Clojure",owner:"troglotit"},cmake:{title:"CMake",owner:"mjrogozinski"},cobol:{title:"COBOL",owner:"RunDevelopment"},coffeescript:{title:"CoffeeScript",require:"javascript",alias:"coffee",owner:"R-osey"},concurnas:{title:"Concurnas",alias:"conc",owner:"jasontatton"},csp:{title:"Content-Security-Policy",owner:"ScottHelme"},cooklang:{title:"Cooklang",owner:"ahue"},coq:{title:"Coq",owner:"RunDevelopment"},crystal:{title:"Crystal",require:"ruby",owner:"MakeNowJust"},"css-extras":{title:"CSS Extras",require:"css",modify:"css",owner:"milesj"},csv:{title:"CSV",owner:"RunDevelopment"},cue:{title:"CUE",owner:"RunDevelopment"},cypher:{title:"Cypher",owner:"RunDevelopment"},d:{title:"D",require:"clike",owner:"Golmote"},dart:{title:"Dart",require:"clike",owner:"Golmote"},dataweave:{title:"DataWeave",owner:"machaval"},dax:{title:"DAX",owner:"peterbud"},dhall:{title:"Dhall",owner:"RunDevelopment"},diff:{title:"Diff",owner:"uranusjr"},django:{title:"Django/Jinja2",require:"markup-templating",alias:"jinja2",owner:"romanvm"},"dns-zone-file":{title:"DNS zone file",owner:"RunDevelopment",alias:"dns-zone"},docker:{title:"Docker",alias:"dockerfile",owner:"JustinBeckwith"},dot:{title:"DOT (Graphviz)",alias:"gv",optional:"markup",owner:"RunDevelopment"},ebnf:{title:"EBNF",owner:"RunDevelopment"},editorconfig:{title:"EditorConfig",owner:"osipxd"},eiffel:{title:"Eiffel",owner:"Conaclos"},ejs:{title:"EJS",require:["javascript","markup-templating"],owner:"RunDevelopment",alias:"eta",aliasTitles:{eta:"Eta"}},elixir:{title:"Elixir",owner:"Golmote"},elm:{title:"Elm",owner:"zwilias"},etlua:{title:"Embedded Lua templating",require:["lua","markup-templating"],owner:"RunDevelopment"},erb:{title:"ERB",require:["ruby","markup-templating"],owner:"Golmote"},erlang:{title:"Erlang",owner:"Golmote"},"excel-formula":{title:"Excel Formula",alias:["xlsx","xls"],owner:"RunDevelopment"},fsharp:{title:"F#",require:"clike",owner:"simonreynolds7"},factor:{title:"Factor",owner:"catb0t"},false:{title:"False",owner:"edukisto"},"firestore-security-rules":{title:"Firestore security rules",require:"clike",owner:"RunDevelopment"},flow:{title:"Flow",require:"javascript",owner:"Golmote"},fortran:{title:"Fortran",owner:"Golmote"},ftl:{title:"FreeMarker Template Language",require:"markup-templating",owner:"RunDevelopment"},gml:{title:"GameMaker Language",alias:"gamemakerlanguage",require:"clike",owner:"LiarOnce"},gap:{title:"GAP (CAS)",owner:"RunDevelopment"},gcode:{title:"G-code",owner:"RunDevelopment"},gdscript:{title:"GDScript",owner:"RunDevelopment"},gedcom:{title:"GEDCOM",owner:"Golmote"},gettext:{title:"gettext",alias:"po",owner:"RunDevelopment"},gherkin:{title:"Gherkin",owner:"hason"},git:{title:"Git",owner:"lgiraudel"},glsl:{title:"GLSL",require:"c",owner:"Golmote"},gn:{title:"GN",alias:"gni",owner:"RunDevelopment"},"linker-script":{title:"GNU Linker Script",alias:"ld",owner:"RunDevelopment"},go:{title:"Go",require:"clike",owner:"arnehormann"},"go-module":{title:"Go module",alias:"go-mod",owner:"RunDevelopment"},gradle:{title:"Gradle",require:"clike",owner:"zeabdelkhalek-badido18"},graphql:{title:"GraphQL",optional:"markdown",owner:"Golmote"},groovy:{title:"Groovy",require:"clike",owner:"robfletcher"},haml:{title:"Haml",require:"ruby",optional:["css","css-extras","coffeescript","erb","javascript","less","markdown","scss","textile"],owner:"Golmote"},handlebars:{title:"Handlebars",require:"markup-templating",alias:["hbs","mustache"],aliasTitles:{mustache:"Mustache"},owner:"Golmote"},haskell:{title:"Haskell",alias:"hs",owner:"bholst"},haxe:{title:"Haxe",require:"clike",optional:"regex",owner:"Golmote"},hcl:{title:"HCL",owner:"outsideris"},hlsl:{title:"HLSL",require:"c",owner:"RunDevelopment"},hoon:{title:"Hoon",owner:"matildepark"},http:{title:"HTTP",optional:["csp","css","hpkp","hsts","javascript","json","markup","uri"],owner:"danielgtaylor"},hpkp:{title:"HTTP Public-Key-Pins",owner:"ScottHelme"},hsts:{title:"HTTP Strict-Transport-Security",owner:"ScottHelme"},ichigojam:{title:"IchigoJam",owner:"BlueCocoa"},icon:{title:"Icon",owner:"Golmote"},"icu-message-format":{title:"ICU Message Format",owner:"RunDevelopment"},idris:{title:"Idris",alias:"idr",owner:"KeenS",require:"haskell"},ignore:{title:".ignore",owner:"osipxd",alias:["gitignore","hgignore","npmignore"],aliasTitles:{gitignore:".gitignore",hgignore:".hgignore",npmignore:".npmignore"}},inform7:{title:"Inform 7",owner:"Golmote"},ini:{title:"Ini",owner:"aviaryan"},io:{title:"Io",owner:"AlesTsurko"},j:{title:"J",owner:"Golmote"},java:{title:"Java",require:"clike",owner:"sherblot"},javadoc:{title:"JavaDoc",require:["markup","java","javadoclike"],modify:"java",optional:"scala",owner:"RunDevelopment"},javadoclike:{title:"JavaDoc-like",modify:["java","javascript","php"],owner:"RunDevelopment"},javastacktrace:{title:"Java stack trace",owner:"RunDevelopment"},jexl:{title:"Jexl",owner:"czosel"},jolie:{title:"Jolie",require:"clike",owner:"thesave"},jq:{title:"JQ",owner:"RunDevelopment"},jsdoc:{title:"JSDoc",require:["javascript","javadoclike","typescript"],modify:"javascript",optional:["actionscript","coffeescript"],owner:"RunDevelopment"},"js-extras":{title:"JS Extras",require:"javascript",modify:"javascript",optional:["actionscript","coffeescript","flow","n4js","typescript"],owner:"RunDevelopment"},json:{title:"JSON",alias:"webmanifest",aliasTitles:{webmanifest:"Web App Manifest"},owner:"CupOfTea696"},json5:{title:"JSON5",require:"json",owner:"RunDevelopment"},jsonp:{title:"JSONP",require:"json",owner:"RunDevelopment"},jsstacktrace:{title:"JS stack trace",owner:"sbrl"},"js-templates":{title:"JS Templates",require:"javascript",modify:"javascript",optional:["css","css-extras","graphql","markdown","markup","sql"],owner:"RunDevelopment"},julia:{title:"Julia",owner:"cdagnino"},keepalived:{title:"Keepalived Configure",owner:"dev-itsheng"},keyman:{title:"Keyman",owner:"mcdurdin"},kotlin:{title:"Kotlin",alias:["kt","kts"],aliasTitles:{kts:"Kotlin Script"},require:"clike",owner:"Golmote"},kumir:{title:"KuMir (\u041a\u0443\u041c\u0438\u0440)",alias:"kum",owner:"edukisto"},kusto:{title:"Kusto",owner:"RunDevelopment"},latex:{title:"LaTeX",alias:["tex","context"],aliasTitles:{tex:"TeX",context:"ConTeXt"},owner:"japborst"},latte:{title:"Latte",require:["clike","markup-templating","php"],owner:"nette"},less:{title:"Less",require:"css",optional:"css-extras",owner:"Golmote"},lilypond:{title:"LilyPond",require:"scheme",alias:"ly",owner:"RunDevelopment"},liquid:{title:"Liquid",require:"markup-templating",owner:"cinhtau"},lisp:{title:"Lisp",alias:["emacs","elisp","emacs-lisp"],owner:"JuanCaicedo"},livescript:{title:"LiveScript",owner:"Golmote"},llvm:{title:"LLVM IR",owner:"porglezomp"},log:{title:"Log file",optional:"javastacktrace",owner:"RunDevelopment"},lolcode:{title:"LOLCODE",owner:"Golmote"},lua:{title:"Lua",owner:"Golmote"},magma:{title:"Magma (CAS)",owner:"RunDevelopment"},makefile:{title:"Makefile",owner:"Golmote"},markdown:{title:"Markdown",require:"markup",optional:"yaml",alias:"md",owner:"Golmote"},"markup-templating":{title:"Markup templating",require:"markup",owner:"Golmote"},mata:{title:"Mata",owner:"RunDevelopment"},matlab:{title:"MATLAB",owner:"Golmote"},maxscript:{title:"MAXScript",owner:"RunDevelopment"},mel:{title:"MEL",owner:"Golmote"},mermaid:{title:"Mermaid",owner:"RunDevelopment"},metafont:{title:"METAFONT",owner:"LaeriExNihilo"},mizar:{title:"Mizar",owner:"Golmote"},mongodb:{title:"MongoDB",owner:"airs0urce",require:"javascript"},monkey:{title:"Monkey",owner:"Golmote"},moonscript:{title:"MoonScript",alias:"moon",owner:"RunDevelopment"},n1ql:{title:"N1QL",owner:"TMWilds"},n4js:{title:"N4JS",require:"javascript",optional:"jsdoc",alias:"n4jsd",owner:"bsmith-n4"},"nand2tetris-hdl":{title:"Nand To Tetris HDL",owner:"stephanmax"},naniscript:{title:"Naninovel Script",owner:"Elringus",alias:"nani"},nasm:{title:"NASM",owner:"rbmj"},neon:{title:"NEON",owner:"nette"},nevod:{title:"Nevod",owner:"nezaboodka"},nginx:{title:"nginx",owner:"volado"},nim:{title:"Nim",owner:"Golmote"},nix:{title:"Nix",owner:"Golmote"},nsis:{title:"NSIS",owner:"idleberg"},objectivec:{title:"Objective-C",require:"c",alias:"objc",owner:"uranusjr"},ocaml:{title:"OCaml",owner:"Golmote"},odin:{title:"Odin",owner:"edukisto"},opencl:{title:"OpenCL",require:"c",modify:["c","cpp"],owner:"Milania1"},openqasm:{title:"OpenQasm",alias:"qasm",owner:"RunDevelopment"},oz:{title:"Oz",owner:"Golmote"},parigp:{title:"PARI/GP",owner:"Golmote"},parser:{title:"Parser",require:"markup",owner:"Golmote"},pascal:{title:"Pascal",alias:"objectpascal",aliasTitles:{objectpascal:"Object Pascal"},owner:"Golmote"},pascaligo:{title:"Pascaligo",owner:"DefinitelyNotAGoat"},psl:{title:"PATROL Scripting Language",owner:"bertysentry"},pcaxis:{title:"PC-Axis",alias:"px",owner:"RunDevelopment"},peoplecode:{title:"PeopleCode",alias:"pcode",owner:"RunDevelopment"},perl:{title:"Perl",owner:"Golmote"},php:{title:"PHP",require:"markup-templating",owner:"milesj"},phpdoc:{title:"PHPDoc",require:["php","javadoclike"],modify:"php",owner:"RunDevelopment"},"php-extras":{title:"PHP Extras",require:"php",modify:"php",owner:"milesj"},"plant-uml":{title:"PlantUML",alias:"plantuml",owner:"RunDevelopment"},plsql:{title:"PL/SQL",require:"sql",owner:"Golmote"},powerquery:{title:"PowerQuery",alias:["pq","mscript"],owner:"peterbud"},powershell:{title:"PowerShell",owner:"nauzilus"},processing:{title:"Processing",require:"clike",owner:"Golmote"},prolog:{title:"Prolog",owner:"Golmote"},promql:{title:"PromQL",owner:"arendjr"},properties:{title:".properties",owner:"Golmote"},protobuf:{title:"Protocol Buffers",require:"clike",owner:"just-boris"},pug:{title:"Pug",require:["markup","javascript"],optional:["coffeescript","ejs","handlebars","less","livescript","markdown","scss","stylus","twig"],owner:"Golmote"},puppet:{title:"Puppet",owner:"Golmote"},pure:{title:"Pure",optional:["c","cpp","fortran"],owner:"Golmote"},purebasic:{title:"PureBasic",require:"clike",alias:"pbfasm",owner:"HeX0R101"},purescript:{title:"PureScript",require:"haskell",alias:"purs",owner:"sriharshachilakapati"},python:{title:"Python",alias:"py",owner:"multipetros"},qsharp:{title:"Q#",require:"clike",alias:"qs",owner:"fedonman"},q:{title:"Q (kdb+ database)",owner:"Golmote"},qml:{title:"QML",require:"javascript",owner:"RunDevelopment"},qore:{title:"Qore",require:"clike",owner:"temnroegg"},r:{title:"R",owner:"Golmote"},racket:{title:"Racket",require:"scheme",alias:"rkt",owner:"RunDevelopment"},cshtml:{title:"Razor C#",alias:"razor",require:["markup","csharp"],optional:["css","css-extras","javascript","js-extras"],owner:"RunDevelopment"},jsx:{title:"React JSX",require:["markup","javascript"],optional:["jsdoc","js-extras","js-templates"],owner:"vkbansal"},tsx:{title:"React TSX",require:["jsx","typescript"]},reason:{title:"Reason",require:"clike",owner:"Golmote"},regex:{title:"Regex",owner:"RunDevelopment"},rego:{title:"Rego",owner:"JordanSh"},renpy:{title:"Ren'py",alias:"rpy",owner:"HyuchiaDiego"},rescript:{title:"ReScript",alias:"res",owner:"vmarcosp"},rest:{title:"reST (reStructuredText)",owner:"Golmote"},rip:{title:"Rip",owner:"ravinggenius"},roboconf:{title:"Roboconf",owner:"Golmote"},robotframework:{title:"Robot Framework",alias:"robot",owner:"RunDevelopment"},ruby:{title:"Ruby",require:"clike",alias:"rb",owner:"samflores"},rust:{title:"Rust",owner:"Golmote"},sas:{title:"SAS",optional:["groovy","lua","sql"],owner:"Golmote"},sass:{title:"Sass (Sass)",require:"css",optional:"css-extras",owner:"Golmote"},scss:{title:"Sass (SCSS)",require:"css",optional:"css-extras",owner:"MoOx"},scala:{title:"Scala",require:"java",owner:"jozic"},scheme:{title:"Scheme",owner:"bacchus123"},"shell-session":{title:"Shell session",require:"bash",alias:["sh-session","shellsession"],owner:"RunDevelopment"},smali:{title:"Smali",owner:"RunDevelopment"},smalltalk:{title:"Smalltalk",owner:"Golmote"},smarty:{title:"Smarty",require:"markup-templating",optional:"php",owner:"Golmote"},sml:{title:"SML",alias:"smlnj",aliasTitles:{smlnj:"SML/NJ"},owner:"RunDevelopment"},solidity:{title:"Solidity (Ethereum)",alias:"sol",require:"clike",owner:"glachaud"},"solution-file":{title:"Solution file",alias:"sln",owner:"RunDevelopment"},soy:{title:"Soy (Closure Template)",require:"markup-templating",owner:"Golmote"},sparql:{title:"SPARQL",require:"turtle",owner:"Triply-Dev",alias:"rq"},"splunk-spl":{title:"Splunk SPL",owner:"RunDevelopment"},sqf:{title:"SQF: Status Quo Function (Arma 3)",require:"clike",owner:"RunDevelopment"},sql:{title:"SQL",owner:"multipetros"},squirrel:{title:"Squirrel",require:"clike",owner:"RunDevelopment"},stan:{title:"Stan",owner:"RunDevelopment"},stata:{title:"Stata Ado",require:["mata","java","python"],owner:"RunDevelopment"},iecst:{title:"Structured Text (IEC 61131-3)",owner:"serhioromano"},stylus:{title:"Stylus",owner:"vkbansal"},supercollider:{title:"SuperCollider",alias:"sclang",owner:"RunDevelopment"},swift:{title:"Swift",owner:"chrischares"},systemd:{title:"Systemd configuration file",owner:"RunDevelopment"},"t4-templating":{title:"T4 templating",owner:"RunDevelopment"},"t4-cs":{title:"T4 Text Templates (C#)",require:["t4-templating","csharp"],alias:"t4",owner:"RunDevelopment"},"t4-vb":{title:"T4 Text Templates (VB)",require:["t4-templating","vbnet"],owner:"RunDevelopment"},tap:{title:"TAP",owner:"isaacs",require:"yaml"},tcl:{title:"Tcl",owner:"PeterChaplin"},tt2:{title:"Template Toolkit 2",require:["clike","markup-templating"],owner:"gflohr"},textile:{title:"Textile",require:"markup",optional:"css",owner:"Golmote"},toml:{title:"TOML",owner:"RunDevelopment"},tremor:{title:"Tremor",alias:["trickle","troy"],owner:"darach",aliasTitles:{trickle:"trickle",troy:"troy"}},turtle:{title:"Turtle",alias:"trig",aliasTitles:{trig:"TriG"},owner:"jakubklimek"},twig:{title:"Twig",require:"markup-templating",owner:"brandonkelly"},typescript:{title:"TypeScript",require:"javascript",optional:"js-templates",alias:"ts",owner:"vkbansal"},typoscript:{title:"TypoScript",alias:"tsconfig",aliasTitles:{tsconfig:"TSConfig"},owner:"dkern"},unrealscript:{title:"UnrealScript",alias:["uscript","uc"],owner:"RunDevelopment"},uorazor:{title:"UO Razor Script",owner:"jaseowns"},uri:{title:"URI",alias:"url",aliasTitles:{url:"URL"},owner:"RunDevelopment"},v:{title:"V",require:"clike",owner:"taggon"},vala:{title:"Vala",require:"clike",optional:"regex",owner:"TemplarVolk"},vbnet:{title:"VB.Net",require:"basic",owner:"Bigsby"},velocity:{title:"Velocity",require:"markup",owner:"Golmote"},verilog:{title:"Verilog",owner:"a-rey"},vhdl:{title:"VHDL",owner:"a-rey"},vim:{title:"vim",owner:"westonganger"},"visual-basic":{title:"Visual Basic",alias:["vb","vba"],aliasTitles:{vba:"VBA"},owner:"Golmote"},warpscript:{title:"WarpScript",owner:"RunDevelopment"},wasm:{title:"WebAssembly",owner:"Golmote"},"web-idl":{title:"Web IDL",alias:"webidl",owner:"RunDevelopment"},wgsl:{title:"WGSL",owner:"Dr4gonthree"},wiki:{title:"Wiki markup",require:"markup",owner:"Golmote"},wolfram:{title:"Wolfram language",alias:["mathematica","nb","wl"],aliasTitles:{mathematica:"Mathematica",nb:"Mathematica Notebook"},owner:"msollami"},wren:{title:"Wren",owner:"clsource"},xeora:{title:"Xeora",require:"markup",alias:"xeoracube",aliasTitles:{xeoracube:"XeoraCube"},owner:"freakmaxi"},"xml-doc":{title:"XML doc (.net)",require:"markup",modify:["csharp","fsharp","vbnet"],owner:"RunDevelopment"},xojo:{title:"Xojo (REALbasic)",owner:"Golmote"},xquery:{title:"XQuery",require:"markup",owner:"Golmote"},yaml:{title:"YAML",alias:"yml",owner:"hason"},yang:{title:"YANG",owner:"RunDevelopment"},zig:{title:"Zig",owner:"RunDevelopment"}},plugins:{meta:{path:"plugins/{id}/prism-{id}",link:"plugins/{id}/"},"line-highlight":{title:"Line Highlight",description:"Highlights specific lines and/or line ranges."},"line-numbers":{title:"Line Numbers",description:"Line number at the beginning of code lines.",owner:"kuba-kubula"},"show-invisibles":{title:"Show Invisibles",description:"Show hidden characters such as tabs and line breaks.",optional:["autolinker","data-uri-highlight"]},autolinker:{title:"Autolinker",description:"Converts URLs and emails in code to clickable links. Parses Markdown links in comments."},wpd:{title:"WebPlatform Docs",description:'Makes tokens link to WebPlatform.org documentation. The links open in a new tab.'},"custom-class":{title:"Custom Class",description:"This plugin allows you to prefix Prism's default classes (.comment can become .namespace--comment) or replace them with your defined ones (like .editor__comment). You can even add new classes.",owner:"dvkndn",noCSS:!0},"file-highlight":{title:"File Highlight",description:"Fetch external files and highlight them with Prism. Used on the Prism website itself.",noCSS:!0},"show-language":{title:"Show Language",description:"Display the highlighted language in code blocks (inline code does not show the label).",owner:"nauzilus",noCSS:!0,require:"toolbar"},"jsonp-highlight":{title:"JSONP Highlight",description:"Fetch content with JSONP and highlight some interesting content (e.g. GitHub/Gists or Bitbucket API).",noCSS:!0,owner:"nauzilus"},"highlight-keywords":{title:"Highlight Keywords",description:"Adds special CSS classes for each keyword for fine-grained highlighting.",owner:"vkbansal",noCSS:!0},"remove-initial-line-feed":{title:"Remove initial line feed",description:"Removes the initial line feed in code blocks.",owner:"Golmote",noCSS:!0},"inline-color":{title:"Inline color",description:"Adds a small inline preview for colors in style sheets.",require:"css-extras",owner:"RunDevelopment"},previewers:{title:"Previewers",description:"Previewers for angles, colors, gradients, easing and time.",require:"css-extras",owner:"Golmote"},autoloader:{title:"Autoloader",description:"Automatically loads the needed languages to highlight the code blocks.",owner:"Golmote",noCSS:!0},"keep-markup":{title:"Keep Markup",description:"Prevents custom markup from being dropped out during highlighting.",owner:"Golmote",optional:"normalize-whitespace",noCSS:!0},"command-line":{title:"Command Line",description:"Display a command line with a prompt and, optionally, the output/response from the commands.",owner:"chriswells0"},"unescaped-markup":{title:"Unescaped Markup",description:"Write markup without having to escape anything."},"normalize-whitespace":{title:"Normalize Whitespace",description:"Supports multiple operations to normalize whitespace in code blocks.",owner:"zeitgeist87",optional:"unescaped-markup",noCSS:!0},"data-uri-highlight":{title:"Data-URI Highlight",description:"Highlights data-URI contents.",owner:"Golmote",noCSS:!0},toolbar:{title:"Toolbar",description:"Attach a toolbar for plugins to easily register buttons on the top of a code block.",owner:"mAAdhaTTah"},"copy-to-clipboard":{title:"Copy to Clipboard Button",description:"Add a button that copies the code block to the clipboard when clicked.",owner:"mAAdhaTTah",require:"toolbar",noCSS:!0},"download-button":{title:"Download Button",description:"A button in the toolbar of a code block adding a convenient way to download a code file.",owner:"Golmote",require:"toolbar",noCSS:!0},"match-braces":{title:"Match braces",description:"Highlights matching braces.",owner:"RunDevelopment"},"diff-highlight":{title:"Diff Highlight",description:"Highlights the code inside diff blocks.",owner:"RunDevelopment",require:"diff"},"filter-highlight-all":{title:"Filter highlightAll",description:"Filters the elements the highlightAll and highlightAllUnder methods actually highlight.",owner:"RunDevelopment",noCSS:!0},treeview:{title:"Treeview",description:"A language with special styles to highlight file system tree structures.",owner:"Golmote"}}})},2885:(e,t,n)=>{const a=n(29901),r=n(39642),o=new Set;function i(e){void 0===e?e=Object.keys(a.languages).filter((e=>"meta"!=e)):Array.isArray(e)||(e=[e]);const t=[...o,...Object.keys(Prism.languages)];r(a,e,t).load((e=>{if(!(e in a.languages))return void(i.silent||console.warn("Language does not exist: "+e));const t="./prism-"+e;delete n.c[n(16500).resolve(t)],delete Prism.languages[e],n(16500)(t),o.add(e)}))}i.silent=!1,e.exports=i},6726:(e,t,n)=>{var a={"./":2885};function r(e){var t=o(e);return n(t)}function o(e){if(!n.o(a,e)){var t=new Error("Cannot find module '"+e+"'");throw t.code="MODULE_NOT_FOUND",t}return a[e]}r.keys=function(){return Object.keys(a)},r.resolve=o,e.exports=r,r.id=6726},16500:(e,t,n)=>{var a={"./":2885};function r(e){var t=o(e);return n(t)}function o(e){if(!n.o(a,e)){var t=new Error("Cannot find module '"+e+"'");throw t.code="MODULE_NOT_FOUND",t}return a[e]}r.keys=function(){return Object.keys(a)},r.resolve=o,e.exports=r,r.id=16500},39642:e=>{"use strict";var t=function(){var e=function(){};function t(e,t){Array.isArray(e)?e.forEach(t):null!=e&&t(e,0)}function n(e){for(var t={},n=0,a=e.length;n "));var s={},c=e[a];if(c){function l(t){if(!(t in e))throw new Error(a+" depends on an unknown component "+t);if(!(t in s))for(var i in r(t,o),s[t]=!0,n[t])s[i]=!0}t(c.require,l),t(c.optional,l),t(c.modify,l)}n[a]=s,o.pop()}}return function(e){var t=n[e];return t||(r(e,a),t=n[e]),t}}function r(e){for(var t in e)return!0;return!1}return function(o,i,s){var c=function(e){var t={};for(var n in e){var a=e[n];for(var r in a)if("meta"!=r){var o=a[r];t[r]="string"==typeof o?{title:o}:o}}return t}(o),l=function(e){var n;return function(a){if(a in e)return a;if(!n)for(var r in n={},e){var o=e[r];t(o&&o.alias,(function(t){if(t in n)throw new Error(t+" cannot be alias for both "+r+" and "+n[t]);if(t in e)throw new Error(t+" cannot be alias of "+r+" because it is a component.");n[t]=r}))}return n[a]||a}}(c);i=i.map(l),s=(s||[]).map(l);var u=n(i),d=n(s);i.forEach((function e(n){var a=c[n];t(a&&a.require,(function(t){t in d||(u[t]=!0,e(t))}))}));for(var p,f=a(c),m=u;r(m);){for(var g in p={},m){var h=c[g];t(h&&h.modify,(function(e){e in d&&(p[e]=!0)}))}for(var b in d)if(!(b in u))for(var y in f(b))if(y in u){p[b]=!0;break}for(var w in m=p)u[w]=!0}var v={getIds:function(){var e=[];return v.load((function(t){e.push(t)})),e},load:function(t,n){return function(t,n,a,r){var o=r?r.series:void 0,i=r?r.parallel:e,s={},c={};function l(e){if(e in s)return s[e];c[e]=!0;var r,u=[];for(var d in t(e))d in n&&u.push(d);if(0===u.length)r=a(e);else{var p=i(u.map((function(e){var t=l(e);return delete c[e],t})));o?r=o(p,(function(){return a(e)})):a(e)}return s[e]=r}for(var u in n)l(u);var d=[];for(var p in c)d.push(s[p]);return i(d)}(f,u,t,n)}};return v}}();e.exports=t},92703:(e,t,n)=>{"use strict";var a=n(50414);function r(){}function o(){}o.resetWarningCache=r,e.exports=function(){function e(e,t,n,r,o,i){if(i!==a){var s=new Error("Calling PropTypes validators directly is not supported by the `prop-types` package. Use PropTypes.checkPropTypes() to call them. Read more at http://fb.me/use-check-prop-types");throw s.name="Invariant Violation",s}}function t(){return e}e.isRequired=e;var n={array:e,bigint:e,bool:e,func:e,number:e,object:e,string:e,symbol:e,any:e,arrayOf:t,element:e,elementType:e,instanceOf:t,node:e,objectOf:t,oneOf:t,oneOfType:t,shape:t,exact:t,checkPropTypes:o,resetWarningCache:r};return n.PropTypes=n,n}},45697:(e,t,n)=>{e.exports=n(92703)()},50414:e=>{"use strict";e.exports="SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED"},64448:(e,t,n)=>{"use strict";var a=n(67294),r=n(27418),o=n(63840);function i(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,n=1;n