diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 218f85d..03426f9 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -15,7 +15,7 @@ jobs: uses: actions/checkout@v2 - name: Get golangci-lint run: | - curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s v1.52.2 + curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s v1.61.0 - name: Run golangci-lint run: | ./bin/golangci-lint run --out-format=github-actions --issues-exit-code=1 @@ -25,7 +25,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - go: [ '1.18', '1.17', '1.16', '1.15', '1.14' ] + go: ['1.22', '1.21', '1.20', '1.19', '1.18'] env: CGO_ENABLED: 0 steps: diff --git a/README.md b/README.md index 76c1edd..0d2e891 100644 --- a/README.md +++ b/README.md @@ -6,7 +6,7 @@ unipdf-cli is a CLI tool which makes working with PDF files very easy. It supports the most common PDF operations. The application is written in Golang and is -powered by the [UniPDF](https://github.com/unidoc/unipdf-cli) PDF library. +powered by the [UniPDF](https://github.com/unidoc/unipdf) PDF library. ## Features diff --git a/go.mod b/go.mod index 7e93689..bc0bfe9 100644 --- a/go.mod +++ b/go.mod @@ -1,10 +1,34 @@ module github.com/unidoc/unipdf-cli require ( - github.com/inconshreveable/mousetrap v1.0.0 // indirect github.com/spf13/cobra v0.0.3 + github.com/unidoc/unipdf/v3 v3.62.0 +) + +require ( + github.com/adrg/strutil v0.3.1 // indirect + github.com/adrg/sysfont v0.1.2 // indirect + github.com/adrg/xdg v0.4.0 // indirect + github.com/davecgh/go-spew v1.1.1 // indirect + github.com/gabriel-vasile/mimetype v1.4.3 // indirect + github.com/gorilla/i18n v0.0.0-20150820051429-8b358169da46 // indirect + github.com/inconshreveable/mousetrap v1.0.0 // indirect + github.com/pmezard/go-difflib v1.0.0 // indirect + github.com/sirupsen/logrus v1.9.3 // indirect github.com/spf13/pflag v1.0.3 // indirect - github.com/unidoc/unipdf/v3 v3.40.0 + github.com/stretchr/testify v1.9.0 // indirect + github.com/unidoc/freetype v0.2.3 // indirect + github.com/unidoc/pkcs7 v0.2.0 // indirect + github.com/unidoc/timestamp v0.0.0-20200412005513-91597fd3793a // indirect + github.com/unidoc/unichart v0.3.0 // indirect + github.com/unidoc/unitype v0.4.0 // indirect + golang.org/x/crypto v0.22.0 // indirect + golang.org/x/image v0.18.0 // indirect + golang.org/x/net v0.24.0 // indirect + golang.org/x/sys v0.19.0 // indirect + golang.org/x/text v0.16.0 // indirect + golang.org/x/xerrors v0.0.0-20231012003039-104605ab7028 // indirect + gopkg.in/yaml.v3 v3.0.1 // indirect ) -go 1.13 +go 1.18 diff --git a/go.sum b/go.sum index 8677319..080ba3d 100644 --- a/go.sum +++ b/go.sum @@ -1,76 +1,85 @@ -github.com/adrg/strutil v0.1.0 h1:IOQnSOAjbE17+7l1lw4rXgX6JuSeJGdZa7BucTMV3Qg= -github.com/adrg/strutil v0.1.0/go.mod h1:pXRr2+IyX5AEPAF5icj/EeTaiflPSD2hvGjnguilZgE= -github.com/adrg/sysfont v0.1.1 h1:l9WKJNHsIpsfOhYIm1oSj+77837r/vls1MH17SH6gp0= -github.com/adrg/sysfont v0.1.1/go.mod h1:19nTHzfIn/HbngFMet+yNAvwSQYtOJYMI7vWexLWyNw= -github.com/adrg/xdg v0.2.1 h1:VSVdnH7cQ7V+B33qSJHTCRlNgra1607Q8PzEmnvb2Ic= -github.com/adrg/xdg v0.2.1/go.mod h1:ZuOshBmzV4Ta+s23hdfFZnBsdzmoR3US0d7ErpqSbTQ= -github.com/boombuler/barcode v1.0.0/go.mod h1:paBWMcWSl3LHKBqUq+rly7CNSldXjb2rDl3JlRe0mD8= +github.com/adrg/strutil v0.2.2/go.mod h1:EF2fjOFlGTepljfI+FzgTG13oXthR7ZAil9/aginnNQ= +github.com/adrg/strutil v0.3.1 h1:OLvSS7CSJO8lBii4YmBt8jiK9QOtB9CzCzwl4Ic/Fz4= +github.com/adrg/strutil v0.3.1/go.mod h1:8h90y18QLrs11IBffcGX3NW/GFBXCMcNg4M7H6MspPA= +github.com/adrg/sysfont v0.1.2 h1:MSU3KREM4RhsQ+7QgH7wPEPTgAgBIz0Hw6Nd4u7QgjE= +github.com/adrg/sysfont v0.1.2/go.mod h1:6d3l7/BSjX9VaeXWJt9fcrftFaD/t7l11xgSywCPZGk= +github.com/adrg/xdg v0.3.0/go.mod h1:7I2hH/IT30IsupOpKZ5ue7/qNi3CoKzD6tL3HwpaRMQ= +github.com/adrg/xdg v0.4.0 h1:RzRqFcjH4nE5C6oTAxhBtoE2IRyjBSa62SCbyPidvls= +github.com/adrg/xdg v0.4.0/go.mod h1:N6ag73EX4wyxeaoeHctc1mas01KZgsj5tYiAIwqJE/E= github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= -github.com/golang/snappy v0.0.4/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q= +github.com/gabriel-vasile/mimetype v1.4.3 h1:in2uUcidCuFcDKtdcBxlR0rJ1+fsokWf+uqxgUFjbI0= +github.com/gabriel-vasile/mimetype v1.4.3/go.mod h1:d8uq/6HKRL6CGdk+aubisF/M5GcPfT7nKyLpA0lbSSk= github.com/gorilla/i18n v0.0.0-20150820051429-8b358169da46 h1:N+R2A3fGIr5GucoRMu2xpqyQWQlfY31orbofBCdjMz8= github.com/gorilla/i18n v0.0.0-20150820051429-8b358169da46/go.mod h1:2Yoiy15Cf7Q3NFwfaJquh7Mk1uGI09ytcD7CUhn8j7s= github.com/inconshreveable/mousetrap v1.0.0 h1:Z8tu5sraLXCXIcARxBp/8cbvlwVa7Z1NHg9XEKhtSvM= github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8= github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= -github.com/konsorten/go-windows-terminal-sequences v1.0.2 h1:DB17ag19krx9CFsz4o3enTrPXyIXCl+2iCXH/aMAp9s= github.com/konsorten/go-windows-terminal-sequences v1.0.2/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= github.com/kr/pretty v0.1.0 h1:L/CwN0zerZDmRFUapSPitk6f+Q3+0za1rQkzVuMiMFI= github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo= github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ= github.com/kr/text v0.1.0 h1:45sCR5RtlFHMR4UwH9sdQ5TC8v0qDQCHnXt+kaKSTVE= github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI= -github.com/montanaflynn/stats v0.6.6/go.mod h1:etXPPgVO6n31NxCd9KQUMvCM+ve0ruNzt6R8Bnaayow= github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= -github.com/sirupsen/logrus v1.5.0 h1:1N5EYkVAPEywqZRJd7cwnRtCb6xJx7NH3T3WUTF980Q= github.com/sirupsen/logrus v1.5.0/go.mod h1:+F7Ogzej0PZc/94MaYx/nvG9jOFMD2osvC3s+Squfpo= +github.com/sirupsen/logrus v1.9.3 h1:dueUQJ1C2q9oE3F7wvmSGAaVtTmUizReu6fjN8uqzbQ= +github.com/sirupsen/logrus v1.9.3/go.mod h1:naHLuLoDiP4jHNo9R0sCBMtWGeIprob74mVsIT4qYEQ= github.com/spf13/cobra v0.0.3 h1:ZlrZ4XsMRm04Fr5pSFxBgfND2EBVa1nLpiy1stUsX/8= github.com/spf13/cobra v0.0.3/go.mod h1:1l0Ry5zgKvJasoi3XT1TypsSe7PqH0Sj9dhYf7v3XqQ= github.com/spf13/pflag v1.0.3 h1:zPAT6CGy6wXeQ7NtTnaTerfKOsV6V6F8agHXFiazDkg= github.com/spf13/pflag v1.0.3/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4= github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= +github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw= +github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo= github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4= -github.com/stretchr/testify v1.7.1 h1:5TQK59W5E3v0r2duFAb7P95B6hEeOyEnHRa8MjYSMTY= +github.com/stretchr/testify v1.6.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= +github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= -github.com/trimmer-io/go-xmp v1.0.0/go.mod h1:Aaptr9sp1lLv7UnCAdQ+gSHZyY2miYaKmcNVj7HRBwA= -github.com/unidoc/freetype v0.0.0-20220130190903-3efbeefd0c90 h1:Rk4easgDQslR3DK7vwtl6jYMZTF3JqZ3ceUdyT6a3UM= -github.com/unidoc/freetype v0.0.0-20220130190903-3efbeefd0c90/go.mod h1:mJ/Q7JnqEoWtajJVrV6S1InbRv0K/fJerPB5SQs32KI= -github.com/unidoc/garabic v0.0.0-20220702200334-8c7cb25baa11/go.mod h1:SX63w9Ww4+Z7E96B01OuG59SleQUb+m+dmapZ8o1Jac= +github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU= +github.com/stretchr/testify v1.8.4/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo= +github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsTg= +github.com/stretchr/testify v1.9.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY= +github.com/unidoc/freetype v0.2.3 h1:uPqW+AY0vXN6K2tvtg8dMAtHTEvvHTN52b72XpZU+3I= +github.com/unidoc/freetype v0.2.3/go.mod h1:mJ/Q7JnqEoWtajJVrV6S1InbRv0K/fJerPB5SQs32KI= github.com/unidoc/pkcs7 v0.0.0-20200411230602-d883fd70d1df/go.mod h1:UEzOZUEpJfDpywVJMUT8QiugqEZC29pDq7kdIZhWCr8= -github.com/unidoc/pkcs7 v0.1.0 h1:9bQfbWMYsIfUP8PyhTcBudOsvbLpNH0MBv4U0P/jDTE= -github.com/unidoc/pkcs7 v0.1.0/go.mod h1:UEzOZUEpJfDpywVJMUT8QiugqEZC29pDq7kdIZhWCr8= +github.com/unidoc/pkcs7 v0.2.0 h1:0Y0RJR5Zu7OuD+/l7bODXARn6b8Ev2G4A8lI4rzy9kg= +github.com/unidoc/pkcs7 v0.2.0/go.mod h1:UEzOZUEpJfDpywVJMUT8QiugqEZC29pDq7kdIZhWCr8= github.com/unidoc/timestamp v0.0.0-20200412005513-91597fd3793a h1:RLtvUhe4DsUDl66m7MJ8OqBjq8jpWBXPK6/RKtqeTkc= github.com/unidoc/timestamp v0.0.0-20200412005513-91597fd3793a/go.mod h1:j+qMWZVpZFTvDey3zxUkSgPJZEX33tDgU/QIA0IzCUw= -github.com/unidoc/unichart v0.1.0 h1:GoJ/rxSoOYZsqlG3yOJpKkwgfsIQgb9hHX7bILZHcCg= -github.com/unidoc/unichart v0.1.0/go.mod h1:9sJXeqxIIsU2D07tmhpDMoND0mBFRGfKBJnXZMsJnzk= -github.com/unidoc/unipdf/v3 v3.40.0 h1:aSB5SGL9HMBhy6F14O35hu9/0r0Wj+PLP6Br3sZpSME= -github.com/unidoc/unipdf/v3 v3.40.0/go.mod h1:GD44mz5CQWK2QVgUy8PcMlhMX3l8Ymd3FdLmi0ucn7E= -github.com/unidoc/unitype v0.2.1 h1:x0jMn7pB/tNrjEVjy3Ukpxo++HOBQaTCXcTYFA6BH3w= -github.com/unidoc/unitype v0.2.1/go.mod h1:mafyug7zYmDOusqa7G0dJV45qp4b6TDAN+pHN7ZUIBU= -golang.org/x/crypto v0.0.0-20220722155217-630584e8d5aa h1:zuSxTR4o9y82ebqCUJYNGJbGPo6sKVl54f/TVDObg1c= -golang.org/x/crypto v0.0.0-20220722155217-630584e8d5aa/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4= -golang.org/x/image v0.0.0-20211028202545-6944b10bf410 h1:hTftEOvwiOq2+O8k2D5/Q7COC7k5Qcrgc2TFURJYnvQ= +github.com/unidoc/unichart v0.3.0 h1:VX1j5yzhjrR3f2flC03Yat6/WF3h7Z+DLEvJLoTGhoc= +github.com/unidoc/unichart v0.3.0/go.mod h1:8JnLNKSOl8yQt1jXewNgYFHhFm5M6/ZiaydncFDpakA= +github.com/unidoc/unipdf/v3 v3.62.0 h1:CVsxq6k1SSIrprotlFvq6iBhA+5745dWaApB0LKtGcc= +github.com/unidoc/unipdf/v3 v3.62.0/go.mod h1:0OIzSHHno23Y8WzaK+852abK8d3AxUZ1GQkMqpyCzu8= +github.com/unidoc/unitype v0.4.0 h1:/TMZ3wgwfWWX64mU5x2O9no9UmoBqYCB089LYYqHyQQ= +github.com/unidoc/unitype v0.4.0/go.mod h1:HV5zuUeqMKA4QgYQq3KDlJY/P96XF90BQB+6czK6LVA= +golang.org/x/crypto v0.22.0 h1:g1v0xeRhjcugydODzvb3mEM9SQ0HGp9s/nh3COQ/C30= +golang.org/x/crypto v0.22.0/go.mod h1:vr6Su+7cTlO45qkww3VDJlzDn0ctJvRgYbC2NvXHt+M= golang.org/x/image v0.0.0-20211028202545-6944b10bf410/go.mod h1:023OzeP/+EPmXeapQh35lcL3II3LrY8Ic+EFFKVhULM= -golang.org/x/net v0.0.0-20211112202133-69e39bad7dc2/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= +golang.org/x/image v0.18.0 h1:jGzIakQa/ZXI1I0Fxvaa9W7yP25TqT6cHIHn+6CqvSQ= +golang.org/x/image v0.18.0/go.mod h1:4yyo5vMFQjVjUcVk4jEQcU9MGy/rulF5WvUILseCM2E= +golang.org/x/net v0.24.0 h1:1PcaxkF854Fu3+lvBIx5SYn9wRlBzzcnHZSiaFFAb0w= +golang.org/x/net v0.24.0/go.mod h1:2Q7sJY5mzlzWjKtYUEXSlBWCdyaioyXzRB2RtU8KVE8= golang.org/x/sys v0.0.0-20190422165155-953cdadca894/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20200413165638-669c56c373c4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20210423082822-04245dca01da/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20210615035016-665e8c7367d1 h1:SrN+KX8Art/Sf4HNj6Zcz06G7VEz+7w9tdXTPOZ7+l4= -golang.org/x/sys v0.0.0-20210615035016-665e8c7367d1/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= -golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= +golang.org/x/sys v0.0.0-20211025201205-69cdffdb9359/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220715151400-c0bba94af5f8/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20220731174439-a90be440212d/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.19.0 h1:q5f1RH2jigJ1MoAWp2KTp3gm5zAGFUTarQZ5U386+4o= +golang.org/x/sys v0.19.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk= -golang.org/x/text v0.3.6 h1:aRYxNxv6iGQlyVaZmk6ZgYEDa+Jg18DxebPSrd6bg1M= golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= +golang.org/x/text v0.16.0 h1:a94ExnEXNtEwYLGJSIUxnWoxoRz/ZcCsV63ROupILh4= +golang.org/x/text v0.16.0/go.mod h1:GhwF1Be+LQoKShO3cGOHzqOgRrGaYc9AvblQOmPVHnI= golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= -golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1 h1:go1bK/D/BFZV2I8cIQd1NKEZ+0owSTG1fDTci4IqFcE= -golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= +golang.org/x/xerrors v0.0.0-20231012003039-104605ab7028 h1:+cNy6SZtPcJQH3LJVLOSmiC7MMxXNOb3PU/VUEz+EhU= +golang.org/x/xerrors v0.0.0-20231012003039-104605ab7028/go.mod h1:NDW/Ps6MPRej6fsCIbMTohpP40sJ/P/vI1MoTEGwX90= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127 h1:qIbj1fsPNlZgppZ+VLlY7N33q108Sa+fhmuc+sWQYwY= gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= -gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c h1:dUUwHk2QECo/6vqA44rthZ8ie2QXMNeKRTHCNY2nXvo= gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= +gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= +gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= diff --git a/internal/cli/decrypt.go b/internal/cli/decrypt.go index 9473575..6b5442a 100644 --- a/internal/cli/decrypt.go +++ b/internal/cli/decrypt.go @@ -46,7 +46,7 @@ var decryptCmd = &cobra.Command{ fmt.Printf("Successfully decrypted %s\n", inputPath) fmt.Printf("Output file saved to %s\n", outputPath) }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 1 { return errors.New("must provide the PDF file to decrypt") } diff --git a/internal/cli/encrypt.go b/internal/cli/encrypt.go index 9de3438..c4155d1 100644 --- a/internal/cli/encrypt.go +++ b/internal/cli/encrypt.go @@ -100,7 +100,7 @@ var encryptCmd = &cobra.Command{ fmt.Printf("File %s successfully encrypted\n", inputPath) fmt.Printf("Output file saved to %s\n", outputPath) }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 2 { return errors.New("must provide the input file and the owner password") } diff --git a/internal/cli/explode.go b/internal/cli/explode.go index 862874c..2a132d9 100644 --- a/internal/cli/explode.go +++ b/internal/cli/explode.go @@ -65,7 +65,7 @@ var explodeCmd = &cobra.Command{ fmt.Printf("File %s successfully exploded\n", inputPath) fmt.Printf("Output file saved to %s\n", outputPath) }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 1 { return errors.New("must provide the input file") } diff --git a/internal/cli/extract_images.go b/internal/cli/extract_images.go index 086e299..69745ef 100644 --- a/internal/cli/extract_images.go +++ b/internal/cli/extract_images.go @@ -83,7 +83,7 @@ var extractImagesCmd = &cobra.Command{ fmt.Printf("Images successfully extracted to %s\n", outputPath) } }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 1 { return errors.New("must provide the input file") } diff --git a/internal/cli/extract_text.go b/internal/cli/extract_text.go index e37657a..1fd7c80 100644 --- a/internal/cli/extract_text.go +++ b/internal/cli/extract_text.go @@ -59,7 +59,7 @@ var extractTextCmd = &cobra.Command{ fmt.Println(text) }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 1 { return errors.New("must provide the input file") } diff --git a/internal/cli/form_export.go b/internal/cli/form_export.go index 3f2f64f..cea9fce 100644 --- a/internal/cli/form_export.go +++ b/internal/cli/form_export.go @@ -8,7 +8,6 @@ package cli import ( "errors" "fmt" - "io/ioutil" "os" "github.com/spf13/cobra" @@ -59,7 +58,8 @@ var formExportCmd = &cobra.Command{ return } - err = ioutil.WriteFile(outputPath, []byte(json), os.ModePerm) + // #nosec G306 + err = os.WriteFile(outputPath, []byte(json), 0644) if err != nil { printErr("Could not export form fields: %s\n", err) } @@ -67,7 +67,7 @@ var formExportCmd = &cobra.Command{ fmt.Printf("Form fields successfully exported from %s\n", inputPath) fmt.Printf("Output file saved to %s\n", outputPath) }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 1 { return errors.New("must provide the input file") } diff --git a/internal/cli/form_fdfmerge.go b/internal/cli/form_fdfmerge.go index 691eea9..869d6b4 100644 --- a/internal/cli/form_fdfmerge.go +++ b/internal/cli/form_fdfmerge.go @@ -95,7 +95,7 @@ var formFDFMergeCmd = &cobra.Command{ fmt.Println(strings.Repeat("-", 10)) } }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 2 { return errors.New("must provide the FDF file and at least one input file") } diff --git a/internal/cli/form_fill.go b/internal/cli/form_fill.go index 732bed7..9d8c4e7 100644 --- a/internal/cli/form_fill.go +++ b/internal/cli/form_fill.go @@ -98,7 +98,7 @@ var formFillCmd = &cobra.Command{ fmt.Println(strings.Repeat("-", 10)) } }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 2 { return errors.New("must provide the JSON file and at least one input file") } diff --git a/internal/cli/form_flatten.go b/internal/cli/form_flatten.go index c65f6d9..51f2262 100644 --- a/internal/cli/form_flatten.go +++ b/internal/cli/form_flatten.go @@ -89,7 +89,7 @@ var formFlattenCmd = &cobra.Command{ fmt.Println(strings.Repeat("-", 10)) } }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 1 { return errors.New("must provide the at least on input file or directory") } diff --git a/internal/cli/grayscale.go b/internal/cli/grayscale.go index 91b16a8..ad4853a 100644 --- a/internal/cli/grayscale.go +++ b/internal/cli/grayscale.go @@ -65,7 +65,7 @@ var grayscaleCmd = &cobra.Command{ fmt.Printf("Successfully converted %s to grayscale\n", inputPath) fmt.Printf("Output file saved to %s\n", outputPath) }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 1 { return errors.New("must provide the input file") } diff --git a/internal/cli/info.go b/internal/cli/info.go index 4b32f0e..884272a 100644 --- a/internal/cli/info.go +++ b/internal/cli/info.go @@ -71,7 +71,7 @@ var infoCmd = &cobra.Command{ fmt.Println("\nFile is safe") } }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 1 { return errors.New("must provide the input file") } diff --git a/internal/cli/license_info.go b/internal/cli/license_info.go index e199e54..4bbe3c8 100644 --- a/internal/cli/license_info.go +++ b/internal/cli/license_info.go @@ -27,7 +27,7 @@ var licenseInfoCmd = &cobra.Command{ Long: licenseInfoCmdDesc, Example: licenseInfoCmdExample, DisableFlagsInUseLine: true, - Run: func(cmd *cobra.Command, args []string) { + Run: func(_ *cobra.Command, _ []string) { licenseKey := os.Getenv("UNIDOC_LICENSE_API_KEY") if licenseKey != "" { // To get your free API key for metered license, sign up on: https://cloud.unidoc.io diff --git a/internal/cli/merge.go b/internal/cli/merge.go index ba0b4ec..11528fd 100644 --- a/internal/cli/merge.go +++ b/internal/cli/merge.go @@ -26,7 +26,7 @@ var mergeCmd = &cobra.Command{ Long: mergeCmdDesc, Example: mergeCmdExample, DisableFlagsInUseLine: true, - Run: func(cmd *cobra.Command, args []string) { + Run: func(_ *cobra.Command, args []string) { outputPath := args[0] inputPaths := args[1:] @@ -37,7 +37,7 @@ var mergeCmd = &cobra.Command{ fmt.Printf("Successfully merged input files\n") fmt.Printf("Output file saved to %s\n", outputPath) }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 3 { return errors.New("must provide the output file and at least two input files") } diff --git a/internal/cli/optimize.go b/internal/cli/optimize.go index 292a608..eaab519 100644 --- a/internal/cli/optimize.go +++ b/internal/cli/optimize.go @@ -120,7 +120,7 @@ var optimizeCmd = &cobra.Command{ fmt.Println(strings.Repeat("-", 10)) } }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 1 { return errors.New("must provide at least one input file") } diff --git a/internal/cli/passwd.go b/internal/cli/passwd.go index 2e8e90e..f641955 100644 --- a/internal/cli/passwd.go +++ b/internal/cli/passwd.go @@ -54,7 +54,7 @@ var passwdCmd = &cobra.Command{ fmt.Printf("Password successfully changed\n") fmt.Printf("Output file saved to %s\n", outputPath) }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 2 { return errors.New("must provide the input file and the new owner password") } diff --git a/internal/cli/render.go b/internal/cli/render.go index 5cd189d..20a242a 100644 --- a/internal/cli/render.go +++ b/internal/cli/render.go @@ -92,7 +92,7 @@ var renderCmd = &cobra.Command{ fmt.Printf("File %s successfully rendered\n", inputPath) fmt.Printf("Output file saved to %s\n", outputPath) }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 1 { return errors.New("must provide the input file") } diff --git a/internal/cli/root.go b/internal/cli/root.go index 23f4753..ff6ea21 100644 --- a/internal/cli/root.go +++ b/internal/cli/root.go @@ -14,7 +14,7 @@ import ( ) const appName = "unipdf" -const appVersion = "0.5.0" +const appVersion = "0.6.0" const rootCmdDesc = ` is a CLI application for working with PDF files. It supports the most common PDF operations. A full list of the supported diff --git a/internal/cli/rotate.go b/internal/cli/rotate.go index b8221cb..71de7a7 100644 --- a/internal/cli/rotate.go +++ b/internal/cli/rotate.go @@ -74,7 +74,7 @@ var rotateCmd = &cobra.Command{ fmt.Printf("Successfully rotated %s\n", inputPath) fmt.Printf("Output file saved to %s\n", outputPath) }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 2 { return errors.New("must provide the input file and the rotation angle") } diff --git a/internal/cli/search.go b/internal/cli/search.go index 45f1022..02409df 100644 --- a/internal/cli/search.go +++ b/internal/cli/search.go @@ -50,7 +50,7 @@ var searchCmd = &cobra.Command{ fmt.Printf("Total occurrences: %d\n", totalOccurrences) }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 2 { return errors.New("must provide a PDF file and the text to search") } diff --git a/internal/cli/split.go b/internal/cli/split.go index 8d10b7a..0b32521 100644 --- a/internal/cli/split.go +++ b/internal/cli/split.go @@ -60,7 +60,7 @@ var splitCmd = &cobra.Command{ fmt.Printf("Successfully split file %s\n", inputPath) fmt.Printf("Output file saved to %s\n", outputPath) }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 2 { return errors.New("must provide at least the input and output files") } diff --git a/internal/cli/version.go b/internal/cli/version.go index 37ac052..c632973 100644 --- a/internal/cli/version.go +++ b/internal/cli/version.go @@ -22,7 +22,7 @@ var versionCmd = &cobra.Command{ Short: "Output version information and exit", Example: versionCmdExample, DisableFlagsInUseLine: true, - Run: func(cmd *cobra.Command, args []string) { + Run: func(_ *cobra.Command, _ []string) { version := pdf.Version() fmt.Printf("%s CLI v%s\n", appName, appVersion) diff --git a/internal/cli/watermark.go b/internal/cli/watermark.go index 45cc3f4..f777be5 100644 --- a/internal/cli/watermark.go +++ b/internal/cli/watermark.go @@ -66,7 +66,7 @@ var watermarkCmd = &cobra.Command{ fmt.Printf("Watermark successfully applied to %s\n", inputPath) fmt.Printf("Output file saved to %s\n", outputPath) }, - Args: func(cmd *cobra.Command, args []string) error { + Args: func(_ *cobra.Command, args []string) error { if len(args) < 2 { return errors.New("must provide the input file and the watermark image") } diff --git a/pkg/pdf/grayscale.go b/pkg/pdf/grayscale.go index c30db68..ebe1339 100644 --- a/pkg/pdf/grayscale.go +++ b/pkg/pdf/grayscale.go @@ -373,7 +373,7 @@ func transformContentStreamToGrayscale(contents string, resources *unipdf.PdfPag // Add handler for image related handling. Note that inline images are completely stored with a ContentStreamInlineImage // object as the parameter for BI. processor.AddHandler(unicontent.HandlerConditionEnumOperand, "BI", - func(op *unicontent.ContentStreamOperation, gs unicontent.GraphicsState, resources *unipdf.PdfPageResources) error { + func(op *unicontent.ContentStreamOperation, _ unicontent.GraphicsState, resources *unipdf.PdfPageResources) error { if len(op.Params) != 1 { fmt.Printf("BI Error invalid number of params\n") return errors.New("invalid number of parameters") @@ -446,7 +446,7 @@ func transformContentStreamToGrayscale(contents string, resources *unipdf.PdfPag processedXObjects := map[string]bool{} // Keep track of processed XObjects to avoid repetition. processor.AddHandler(unicontent.HandlerConditionEnumOperand, "Do", - func(op *unicontent.ContentStreamOperation, gs unicontent.GraphicsState, resources *unipdf.PdfPageResources) error { + func(op *unicontent.ContentStreamOperation, _ unicontent.GraphicsState, resources *unipdf.PdfPageResources) error { if len(op.Params) < 1 { fmt.Printf("ERROR: Invalid number of params for Do object.\n") return errors.New("range check") diff --git a/pkg/pdf/pdf.go b/pkg/pdf/pdf.go index a65a948..5b3e490 100644 --- a/pkg/pdf/pdf.go +++ b/pkg/pdf/pdf.go @@ -7,7 +7,7 @@ package pdf import ( "fmt" - "io/ioutil" + "os" unicommon "github.com/unidoc/unipdf/v3/common" unilicense "github.com/unidoc/unipdf/v3/common/license" @@ -16,7 +16,7 @@ import ( // SetLicense sets the license for using the UniDoc library. func SetLicense(licensePath string, customer string) error { // Read license file - content, err := ioutil.ReadFile(licensePath) + content, err := os.ReadFile(licensePath) if err != nil { return err }