{"id":35305046,"url":"https://github.com/pyihe/secret","last_synced_at":"2025-12-30T17:07:18.104Z","repository":{"id":109437232,"uuid":"268441273","full_name":"pyihe/secret","owner":"pyihe","description":"usual encryption algorithm(HASH/DES/AES/RSA/MAC) written in go","archived":false,"fork":false,"pushed_at":"2025-02-14T03:36:16.000Z","size":169,"stargazers_count":3,"open_issues_count":0,"forks_count":1,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-02-14T04:28:34.018Z","etag":null,"topics":["encryption-algorithm","go"],"latest_commit_sha":null,"homepage":"","language":"Go","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/pyihe.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2020-06-01T06:20:10.000Z","updated_at":"2025-02-14T03:35:53.000Z","dependencies_parsed_at":null,"dependency_job_id":"a189c801-d2f2-4a1d-a91a-e4627470e6db","html_url":"https://github.com/pyihe/secret","commit_stats":null,"previous_names":[],"tags_count":4,"template":false,"template_full_name":null,"purl":"pkg:github/pyihe/secret","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/pyihe%2Fsecret","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/pyihe%2Fsecret/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/pyihe%2Fsecret/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/pyihe%2Fsecret/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/pyihe","download_url":"https://codeload.github.com/pyihe/secret/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/pyihe%2Fsecret/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28130020,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-12-30T02:00:05.476Z","response_time":64,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["encryption-algorithm","go"],"created_at":"2025-12-30T17:04:29.420Z","updated_at":"2025-12-30T17:07:18.090Z","avatar_url":"https://github.com/pyihe.png","language":"Go","funding_links":[],"categories":[],"sub_categories":[],"readme":"# [secret](https://github.com/pyihe/secret)\n\nusual encryption algorithm written in go\n\n#### Function\n\n##### Cipher\n\n|Type|Mode|Padding|\n|:----|:----|:----|\n|DES|ECB/CBC|PKCS5/PKCS7/Zero/None|\n|3DES|ECB/CBC|PKCS5/PKCS7/Zero/None|\n|AES|ECB/CBC|PKCS5/PKCS7/Zero/None|\n|DES|CFB/OFB/CTR/GCM||\n|3DES|CFB/OFB/CTR/GCM||\n|AES|CFB/OFB/CTR/GCM||\n|RC4 |-|-|\n|RSA|Encrypt/Decrypt/Sign/Verify|-|\n\n##### Hash\n\n|Name|\n|:---|\n|Hash|\n|DoubleHash|\n\n##### Sign\u0026\u0026Verify\n\n|Name|Description|\n|:---|:----------|\n|ECC(ECDSA) |Sign/Verify|\n|DSA|Sign/Verify|\n|EdDSA|Sign/Verify|\n\n#### Example\n\n```go\npackage main\n\nimport (\n\t\"crypto/rand\"\n\t\"fmt\"\n\t\"github.com/pyihe/secret\"\n\t\"io\"\n)\n\nfunc main() {\n    var c = secret.NewCipher()\n    var nonce = make([]byte, 12) // 随机向量\n    _, _ = io.ReadFull(rand.Reader, nonce)\n    //encrypt\n    var encryptReq = \u0026secret.SymRequest{\n        PlainData:   \"I Love China!\",\n        Key:         []byte(\"1234567812345678\"),\n        Type:        secret.SymTypeAES,\n        ModeType:    secret.BlockModeGCM,\n        PaddingType: secret.PaddingTypeNoPadding,\n        AddData:     []byte(\"this is additional data\"),\n        Nonce:       nonce,\n    }\n    cipherStr, err := c.SymEncryptToString(encryptReq)\n    if err != nil {\n        //handle err\n    }\n    \n    //decrypt\n    //if decrypts in another server with GCM mode, then your need to set nonce to decrypt\n    var decryptReq = \u0026secret.SymRequest{\n        PlainData:   nil,\n        CipherData:  cipherStr,\n        Key:         []byte(\"1234567812345678\"),\n        Type:        secret.SymTypeAES,\n        ModeType:    secret.BlockModeGCM,\n        PaddingType: secret.PaddingTypeNoPadding,\n        AddData:     []byte(\"this is additional data\"),\n        Nonce:       nonce, // this value must be the same with encryptReq\n    }\n    plainBytes, err := c.SymDecrypt(decryptReq)\n    if err != nil {\n        //handle err\n    }\n    //unmarshal plainBytes or use it directly\n    \n    //c.SetRSAKey(privateKey, secret.PKCSLevel1) to set key if key is already exist\n    _, _, err = c.GenerateRSAKey(4096, \"../conf\", secret.PKCSLevel1)\n    if err != nil {\n        //handle err\n    }\n    \n    cipherStr, err = c.RSAEncryptToString(plainBytes, secret.RSAEncryptTypeOAEP, nil)\n    if err != nil {\n        //handle err\n    }\n    plainBytes, err = c.RSADecrypt(cipherStr, secret.RSAEncryptTypeOAEP, nil)\n    if err != nil {\n        //handle err\n    }\n    //output: I Love China!\n    fmt.Printf(\"%s\\n\", plainBytes)\n}\n```","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fpyihe%2Fsecret","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fpyihe%2Fsecret","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fpyihe%2Fsecret/lists"}