{"id":20896231,"url":"https://github.com/waitingsong/node-myca-cli","last_synced_at":"2025-08-31T03:43:18.480Z","repository":{"id":57306477,"uuid":"119653274","full_name":"waitingsong/node-myca-cli","owner":"waitingsong","description":"Create Self-signed CA certificate for development use and issue server or client certificates, generated using openssl","archived":false,"fork":false,"pushed_at":"2019-01-23T12:22:26.000Z","size":285,"stargazers_count":8,"open_issues_count":0,"forks_count":1,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-04-01T13:51:09.909Z","etag":null,"topics":["ca","certificate","ecc","myca","openssl","pfx","pkcs12","rsa","san","self-signed-certificate","x509"],"latest_commit_sha":null,"homepage":"","language":"TypeScript","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/waitingsong.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2018-01-31T07:48:54.000Z","updated_at":"2022-06-22T23:56:20.000Z","dependencies_parsed_at":"2022-09-20T22:44:30.182Z","dependency_job_id":null,"html_url":"https://github.com/waitingsong/node-myca-cli","commit_stats":null,"previous_names":[],"tags_count":12,"template":false,"template_full_name":null,"purl":"pkg:github/waitingsong/node-myca-cli","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/waitingsong%2Fnode-myca-cli","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/waitingsong%2Fnode-myca-cli/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/waitingsong%2Fnode-myca-cli/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/waitingsong%2Fnode-myca-cli/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/waitingsong","download_url":"https://codeload.github.com/waitingsong/node-myca-cli/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/waitingsong%2Fnode-myca-cli/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":272936309,"owners_count":25018160,"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-08-31T02:00:09.071Z","response_time":79,"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":["ca","certificate","ecc","myca","openssl","pfx","pkcs12","rsa","san","self-signed-certificate","x509"],"created_at":"2024-11-18T10:34:25.070Z","updated_at":"2025-08-31T03:43:18.428Z","avatar_url":"https://github.com/waitingsong.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# myca-cli\n\nA command line for [myca](https://www.npmjs.com/package/myca) for creating my CA center, \ngenerating a self signed x509 certificate, issuing server certificate from node.js via openssl. \nMultiple center supported. RSA, EC(P-256, P-384) supported.\n\n[![Version](https://img.shields.io/npm/v/myca-cli.svg)](https://www.npmjs.com/package/myca-cli)\n[![License](https://img.shields.io/badge/license-MIT-blue.svg)](https://opensource.org/licenses/MIT)\n\n\n## Installing\n\n```bash\nnpm install -g myca-cli\n```\n\n## myca module\n- [myca](https://www.npmjs.com/package/myca)\n\n\n## Usage\n\n- Initialize default center\n  ```bash\n  myca init\n  ```\n\n  will output:\n  ```bash\n  Default center created at path: \"C:\\Users\\\u003cuser\u003e\\.myca\"\n  ```\n\n- Initialize CA cert of default center\n  ```bash\n  myca initca --days=10950 --pass=mycapass \\\n    --cn=\"my root ca\" --o=\"my company\" --c=CN \\\n  ```\n  will output:\n  ```bash\n  CA certificate created with:\n    centerName: \"default\"\n    crtFile: \"C:\\Users\\\u003cuser\u003e\\.myca\\ca.crt\"\n    privateKeyFile: \"C:\\Users\\\u003cuser\u003e\\.myca\\ca.key\"\n  ```\n\n- Issue a RSA serve certificate\n  ```bash\n  myca issue --kind=server --days=730 --pass=fooo \\\n    --cn=\"waitingsong.com\" --o=\"my company\" --c=CN --caKeyPass=mycapass \\\n  ```\n\n  will output:\n  ```bash\n  Issue a Certificate with:\n    pubKey:\n  -----BEGIN PUBLIC KEY-----\n  MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAxJunjvIoZ5bFQsA9D/1A\n  MHt36viM7AJZFpQdmVuTLUZXEiTFU6gMdBarikHsXt0xRPcnGHiP1hgSsTIh2j1k\n  3HiNinwfV/MePvy/8f/XWY+J3BbljQCPQmtUIZAnBebiVcvQrL1cP4l5xgJiv5/p\n  EdRhCs92J/1MMDxhp41BzatBKwbQJ7UQtLnTdWXCs/qptTgaD6vh4a3snWHlfatg\n  TsfzjmSmiXcEYGZM9z6tDrSjR9kBZoog+9DTh+FCdVaasL7QvYlWlOzsjSO2yvLX\n  lYQJ9VJbBGxV0cOKbmPm46aMK6n5br/75CAm8cHyfgsE0MhxH2uxQW3leUy+3MHK\n  ZwIDAQAB\n  -----END PUBLIC KEY-----\n\n    pass: \"fooo\"\n    privateKeyFile: \"C:\\Users\\\u003cuser\u003e\\.myca\\server\\01.key\"\n    privateUnsecureKeyFile: \"C:\\Users\\\u003cuser\u003e\\.myca\\server\\01.key.unsecure\"\n    centerName: \"default\"\n    caKeyFile: \"C:\\Users\\\u003cuser\u003e\\.myca\\ca.key\"\n    caCrtFile: \"C:\\Users\\\u003cuser\u003e\\.myca\\ca.crt\"\n    csrFile: \"C:\\Users\\\u003cuser\u003e\\.myca\\server\\01.csr\"\n    crtFile: \"C:\\Users\\\u003cuser\u003e\\.myca\\server\\01.crt\"\n  ```\n\n- Initialize a center named ec\n  ```bash\n  // path can be omitted\n  myca initcenter --name=ec --path=\"c:/users/\u003cuser\u003e/.myca-ec\"\n  ```\n\n  will output:\n  ```bash\n  center created with:\n    centerName: \"ec\"\n    path: \"c:/users/\u003cuser\u003e/.myca-ec\"\n  ```\n\n- Create self-signed EC CA certificate under center ec (default P-256)\n  ```bash\n  myca initca --days=10950 --pass=mycapass \\\n    --cn=\"my root ca\" --o=\"my company\" --c=CN --centerName=ec --alg=ec \\\n  ```\n\n  will output:\n  ```bash\n  CA certificate created with:\n    centerName: \"ec\"\n    crtFile: \"c:\\users\\\u003cuser\u003e\\.myca-ec\\ca.crt\"\n    privateKeyFile: \"c:\\users\\\u003cuser\u003e\\.myca-ec\\ca.key\"\n  ```\n\n- Issue a ec server certificate by center ec CA cert\n  ```bash\n  myca issue --kind=server --days=730 --pass=fooo \\\n    --cn=\"foo.waitingsong.com\" --o=\"my comany\" --c=CN --caKeyPass=mycapass \\\n    --centerName=ec --alg=ec \\\n  ```\n\n- Issue a serve certificate with Domain Name SANs\n  ```bash\n  myca issue --kind=server --days=730 --pass=fooo \\\n    --cn=\"waitingsong.com\" --o=\"my company\" --c=CN --caKeyPass=mycapass \\\n    --SAN=\"foo.waitingsong.com, bar.waitingsong.com\" \\\n  ```\n\n- Issue a serve certificate with IP SANs\n  ```bash\n  myca issue --kind=server --days=730 --pass=fooo \\\n    --cn=\"waitingsong.com\" --o=\"my company\" --c=CN --caKeyPass=mycapass \\\n    --ips=192.168.0.1 \\\n\n  myca issue --kind=server --days=730 --pass=fooo \\\n    --cn=\"waitingsong.com\" --o=\"my company\" --c=CN --caKeyPass=mycapass \\\n    --ips=\"192.168.0.1, 192.168.0.2\" \\\n  ```\n\n- Issue a RSA client p12/pfx certificate\n  ```bash\n  myca issue --kind=client --days=730 --pass=fooo \\\n    --cn=\"waitingsong.com\" --o=\"my company\" --c=CN --caKeyPass=mycapass \\\n  ```\n\n  will output:\n  ```bash\n  Issue a Certificate with:\n    pubKey:\n  -----BEGIN PUBLIC KEY-----\n  MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAsu8wZDZ0a/HNtlJPqCjs\n  9Isg795iUAJ+5OREb08hPthDN4/LOoLgepIyWbZ/A+0Gv8jHkbqlUvOJV5O5ggjR\n  ezpK3jXln621nbjS3Fzs/uw4+40e4RX7fYIoE9sk94rP+od1ZMRjE8+e+qb34ubC\n  WiXtsyR4EyaRen23IqLNlvxGlcg4xLczaCDA06zkva+wL7qvLYF2331X/rZ+dQgY\n  xh6iWKO7C9qcliF23OOByYIKS8jqQ8ngwHIEogIqNBdt/QyEVN7CvF4M6abQnrrx\n  9wnnmlaRX2WiybsA06wWl7+4BgKjeULehCVQOpMsS/3QV1dO79vn9hZWM/dAPlnF\n  QwIDAQAB\n  -----END PUBLIC KEY-----\n\n    pass: \"fooo\"\n    privateKeyFile: \"C:\\Users\\\u003cuser\u003e\\.myca\\client\\0A.key\"\n    centerName: \"default\"\n    caKeyFile: \"C:\\Users\\\u003cuser\u003e\\.myca\\ca.key\"\n    caCrtFile: \"C:\\Users\\\u003cuser\u003e\\.myca\\ca.crt\"\n    csrFile: \"C:\\Users\\\u003cuser\u003e\\.myca\\client\\0A.csr\"\n    crtFile: \"C:\\Users\\\u003cuser\u003e\\.myca\\client\\0A.crt\"\n    pfxFile: \"C:\\Users\\\u003cuser\u003e\\.myca\\client\\0A.p12\"\n  ```\n\n\n## License\n\n[MIT](LICENSE)\n\n\n## Languages\n\n- [English](README.md)\n- [中文](README.zh-CN.md)\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fwaitingsong%2Fnode-myca-cli","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fwaitingsong%2Fnode-myca-cli","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fwaitingsong%2Fnode-myca-cli/lists"}